/* Autogenerated by richieste-it for form ID 518 */
:root {
	--fr-font-family: inherit;

	/* 🎨 DA PERSONALIZZARE — COLORI BRAND */
	--fr-label-color: #1a1a1a;
	--fr-field-text-color: #1a1a1a;
	--fr-placeholder-color: #6c757d;
	--fr-link-color: #1e283c;
	--fr-icon-color: #1e283c;
	--fr-accent-color: #1e283c;
	--fr-bg-form: #f8f9fa;
	--fr-field-bg: #ffffff;
	--fr-border-color: #ced4da;
	--fr-border-focus: #1e283c;
	--fr-button-bg: #1e283c;
	--fr-button-bg-hover: #192131;
	--fr-button-text-color: #ffffff;

	/* RADIUS */
	--fr-border-radius: 6px;
	--fr-button-border-radius: 6px;

	/* ⛔ MAI CAMBIARE I FONT SIZE (devono essere inherit) */
	--fr-label-font-size: inherit;
	--fr-labelcheck-font-size: inherit;
	--fr-field-text-font-size: inherit;
}


/* ======================================================================
   CONTENITORE
   ====================================================================== */

.form-richieste {
	max-width: 600px;
	width: 100%;
	margin: 20px auto;
	padding: 25px;
	background-color: var(--fr-bg-form);
	font-family: var(--fr-font-family);
	box-sizing: border-box;
	border-radius: 12px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
	container-type: inline-size;
	container-name: fr-form;
}

.form-richieste div:not(.campo):not(.riga):not(.campo *):not(.riga *) {
	margin: 10px auto;
}


/* ======================================================================
   LINK
   ====================================================================== */

.form-richieste a {
	color: var(--fr-link-color);
	text-decoration: underline;
}

.form-richieste a:hover {
	text-decoration: none;
}


/* ======================================================================
   LABEL
   ====================================================================== */

.form-richieste label {
	display: block;
	margin-bottom: 5px;
	font-weight: 600;
	color: var(--fr-label-color);
	font-size: var(--fr-label-font-size);
}

.form-richieste label#label-check {
	font-size: var(--fr-labelcheck-font-size);
}

/* Modalità NO LABEL — nasconde visivamente ma mantiene accessibilità */
.form-richieste.fr-no-label label,
.form-richieste .fr-no-label label {
	visibility: hidden;
}


/* ======================================================================
   CAMPI / BORDI
   ====================================================================== */

.form-richieste input[type="text"],
.form-richieste input[type="tel"],
.form-richieste input[type="email"],
.form-richieste input[type="number"],
.form-richieste input[type="date"],
.form-richieste select,
.form-richieste textarea {
	width: 100%;
	max-width: 100%;
	min-width: 0; /* DIFENSIVO: evita overflow in flex/grid parent */
	padding: 0 12px;
	height: 44px;
	border: 1px solid var(--fr-border-color);
	background-color: var(--fr-field-bg);
	color: var(--fr-field-text-color);
	font-size: var(--fr-field-text-font-size);
	box-sizing: border-box;
	border-radius: var(--fr-border-radius);
	text-overflow: ellipsis; /* DIFENSIVO: placeholder lungo non rompe layout */
	transition:
		border-color 0.2s ease-in-out,
		box-shadow 0.2s ease-in-out,
		background-color 0.2s ease-in-out;
}

.form-richieste textarea {
	height: auto;
	min-height: 100px;
	padding: 10px 12px;
	resize: vertical;
	line-height: 1.5;
}

/* Focus */
.form-richieste input:focus,
.form-richieste select:focus,
.form-richieste textarea:focus {
	outline: none;
	border-color: var(--fr-border-focus);
	box-shadow: 0 0 0 3px rgba(30, 40, 60, 0.2);
}

/* Placeholder */
.form-richieste ::placeholder {
	color: var(--fr-placeholder-color);
	opacity: 1;
}


/* ======================================================================
   CHECKBOX / RADIO
   ====================================================================== */

.form-richieste input[type="checkbox"],
.form-richieste input[type="radio"] {
	cursor: pointer;
	vertical-align: middle;
}

/* Checkbox custom — sovrascrive stili del tema con alta specificità */
.form-richieste input[type="checkbox"]:not(#fr-x) {
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	appearance: none !important;
	width: 17px !important;
	height: 17px !important;
	min-width: 17px !important;
	border: 2px solid #ced4da !important;
	border-radius: 3px !important;
	background-color: #ffffff !important;
	background-image: none !important;
	cursor: pointer !important;
	flex-shrink: 0 !important;
	vertical-align: middle !important;
	transition: background-color 0.15s ease, border-color 0.15s ease !important;
}

/* Nasconde il ::before del tema (spunta ciana) */
.form-richieste input[type="checkbox"]:checked::before {
	display: none !important;
}

/* Stato checked — colore brand + spunta SVG bianca */
.form-richieste input[type="checkbox"]:checked:not(#fr-x) {
	background-color: #1e283c !important;
	border-color: #1e283c !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' d='M2.5 8l3.5 3.5 7.5-7'/%3E%3C/svg%3E") !important;
	background-size: 11px !important;
	background-position: center !important;
	background-repeat: no-repeat !important;
}

.form-richieste input[type="radio"] {
	transform: scale(1.15);
	margin-right: 6px;
	accent-color: #1e283c !important;
}

.form-richieste .form-check {
	display: flex;
	flex-flow: row wrap;
	align-items: center;
}


/* ======================================================================
   RADIO "TIPO CLIENTE" INLINE
   ====================================================================== */

.form-richieste .tipo-soggetto-wrapper {
	display: flex;
	align-items: center;
	gap: 15px;
	flex-wrap: wrap; /* se troppo stretto, "Privato/Azienda" va a capo ma resta inline finchu00e9 possibile */
	min-width: 0; /* DIFENSIVO */
}

.form-richieste .tipo-soggetto-wrapper .ts-label-titolo {
	margin: 0;
	font-weight: 600;
}

.form-richieste .ts-option {
	display: flex;
	align-items: center;
	gap: 5px;
	margin: 0 !important;
}

.form-richieste .tipo-soggetto-wrapper .ts-label-opzione {
	margin: 0;
	font-weight: normal;
	cursor: pointer;
}

.form-richieste .tipo-soggetto-wrapper input[type="radio"] {
	transform: scale(1.15);
	margin: 0;
}


/* ======================================================================
   CONSENSI (privacy e marketing)
   ====================================================================== */

.form-richieste .checkbox-wrapper {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	min-width: 0; /* DIFENSIVO */
	word-wrap: break-word;
	overflow-wrap: anywhere; /* DIFENSIVO: link/parole lunghe non esplodono il layout */
}

.form-richieste .checkbox-wrapper input[type="checkbox"] {
	align-self: flex-start;
	margin-top: 2px;
	flex-shrink: 0;
}

.form-richieste .checkbox-wrapper label,
.form-richieste .checkbox-wrapper span {
	white-space: normal;
	line-height: 1.4;
	font-weight: normal;
	margin: 0;
	font-size: 0.7em;
}

.form-richieste .checkbox-wrapper label#label-check {
	font-size: 0.7em !important;
}


/* ======================================================================
   SELECT
   ====================================================================== */

.form-richieste select {
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23cccccc%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
	background-repeat: no-repeat;
	background-position: right 12px top 50%;
	background-size: 10px auto;
	padding-right: 30px;
}


/* ======================================================================
   PULSANTI
   ====================================================================== */

.form-richieste button[type="submit"],
.form-richieste input[type="submit"] {
	display: inline-block;
	background-color: var(--fr-button-bg);
	color: var(--fr-button-text-color);
	font-size: var(--fr-field-text-font-size);
	font-weight: 700;
	padding: 0 25px;
	height: 48px;
	line-height: 48px;
	border: none;
	border-radius: var(--fr-button-border-radius);
	cursor: pointer;
	transition: background-color 0.2s ease;
	width: 100%;
	text-align: center;
}

.form-richieste button[type="submit"]:hover,
.form-richieste input[type="submit"]:hover {
	background-color: var(--fr-button-bg-hover);
}


/* ======================================================================
   ICONE INPUT
   ====================================================================== */

.form-richieste .input-icon {
	position: relative;
}

.form-richieste .input-icon svg {
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
	height: 18px;
	max-width: 18px;
	max-height: 18px;
	fill: var(--fr-icon-color);
	opacity: 0.8;
	pointer-events: none;
}

.form-richieste .input-icon input[type="text"],
.form-richieste .input-icon input[type="tel"],
.form-richieste .input-icon input[type="email"],
.form-richieste .input-icon input[type="number"],
.form-richieste .input-icon input[type="date"],
.form-richieste .input-icon select,
.form-richieste .input-icon textarea {
	padding-left: 40px;
}


/* ======================================================================
   LAYOUT BASE
   ====================================================================== */

.form-richieste .riga {
	display: flex;
	flex-wrap: wrap;
	min-width: 0; /* DIFENSIVO: permette shrink in parent flex/grid */
}

.form-richieste .campo {
	padding: 5px 10px;
	box-sizing: border-box;
	min-width: 0; /* DIFENSIVO: senza questo i flex item overflowano */
	max-width: 100%; /* DIFENSIVO: mai più larghi del container */
}

/* Larghezze intrinseche: flex-basis = soglia minima per stare affiancati.
   Sotto quella soglia il campo collassa a riga intera AUTOMATICAMENTE
   (flex-wrap + min-width), senza bisogno di container/media query.
   Funziona su QUALUNQUE container: antincendio.roma.it, antennista,
   colonne 33%, sidebar Elementor, full-width, tutto. */
.form-richieste .w-100 { flex: 1 1 100%; max-width: 100%; }
.form-richieste .w-50  { flex: 1 1 240px; max-width: 100%; }
.form-richieste .w-70  { flex: 1 1 320px; max-width: 100%; }
.form-richieste .w-30  { flex: 1 1 160px; max-width: 100%; }
.form-richieste .w-25  { flex: 1 1 140px; max-width: 100%; }

/* IMPORTANTE: nascosta ma NON con display:none */
.form-richieste .riga-sistema {
	overflow: hidden;
	height: 0;
	padding: 0;
	margin: 0;
}

/* reCAPTCHA invisibile */
.grecaptcha-badge {
	visibility: hidden;
	opacity: 0;
}

/* ======================================================================
   FORM ADATTIVO
   Il collasso dei campi affiancati è gestito intrinsecamente da flex +
   min-width sopra. Le container queries qui servono SOLO a rifinire
   padding, altezze e spazi quando il form è molto stretto.
   Se il browser non supporta @container (Safari < 15.4, FF < 110,
   Chrome < 105) il form resta comunque funzionante grazie al flex-wrap.
   ====================================================================== */

/* Container stretto (es. sidebar Elementor / colonna 33% 300-480px) */
@container fr-form (max-width: 480px) {
	.form-richieste {
		padding: 15px;
	}
	.form-richieste .campo {
		padding: 4px 6px;
	}
	.form-richieste input[type="text"],
	.form-richieste input[type="tel"],
	.form-richieste input[type="email"],
	.form-richieste input[type="number"],
	.form-richieste input[type="date"],
	.form-richieste select {
		height: 40px;
		padding: 0 10px;
	}
	/* Icona più stretta per non mangiare spazio al placeholder ("comune") */
	.form-richieste .input-icon svg { left: 8px; width: 16px; height: 16px; }
	.form-richieste .input-icon input[type="text"],
	.form-richieste .input-icon input[type="tel"],
	.form-richieste .input-icon input[type="email"],
	.form-richieste .input-icon input[type="number"],
	.form-richieste .input-icon input[type="date"],
	.form-richieste .input-icon select,
	.form-richieste .input-icon textarea {
		padding-left: 30px;
	}
	/* Freccia select più vicina al bordo */
	.form-richieste select {
		background-position: right 8px top 50%;
		padding-right: 22px;
	}
	.form-richieste textarea {
		min-height: 80px;
	}
	/* "Sei un: Privato Azienda" resta SEMPRE inline */
	.form-richieste .tipo-soggetto-wrapper {
		gap: 8px;
		font-size: 0.9em;
	}
	.form-richieste button[type="submit"],
	.form-richieste input[type="submit"] {
		height: 44px;
		font-size: 0.95em;
	}
}

/* Container ultra-stretto (sidebar 220-300px) — modalità compatta aggressiva:
   shrink font inputs, icona minima, tipo-soggetto SEMPRE inline anche a costo
   di ridurre la grandezza. Gestisce i casi sidebar Elementor a ~180-200px
   (tipico tablet 764-900px dove la sidebar non è ancora collassata). */
@container fr-form (max-width: 300px) {
	.form-richieste {
		padding: 10px;
		border-radius: 8px;
		font-size: 13px; /* base ridotta → tutti gli em scalano */
	}
	.form-richieste .campo {
		padding: 3px 4px;
	}
	.form-richieste input[type="text"],
	.form-richieste input[type="tel"],
	.form-richieste input[type="email"],
	.form-richieste input[type="number"],
	.form-richieste input[type="date"],
	.form-richieste select,
	.form-richieste textarea {
		height: 38px;
		padding: 0 6px;
		font-size: 12px !important; /* override inherit → placeholder leggibile */
	}
	.form-richieste textarea { height: auto; min-height: 70px; padding: 6px 8px; }
	/* Icona mini per lasciare più spazio al testo */
	.form-richieste .input-icon svg { left: 6px; width: 13px; height: 13px; }
	.form-richieste .input-icon input[type="text"],
	.form-richieste .input-icon input[type="tel"],
	.form-richieste .input-icon input[type="email"],
	.form-richieste .input-icon input[type="number"],
	.form-richieste .input-icon input[type="date"],
	.form-richieste .input-icon select,
	.form-richieste .input-icon textarea {
		padding-left: 24px;
	}
	.form-richieste select {
		background-position: right 4px top 50%;
		background-size: 8px auto;
		padding-right: 16px;
	}
	/* "Sei un: Privato Azienda" — FORZATO inline, nowrap, con shrink */
	.form-richieste .tipo-soggetto-wrapper {
		flex-wrap: nowrap;
		gap: 6px;
		font-size: 11px;
		white-space: nowrap;
		overflow: hidden;
	}
	.form-richieste .tipo-soggetto-wrapper .ts-label-titolo { font-size: 11px; }
	.form-richieste .ts-option { flex-shrink: 1; min-width: 0; }
	.form-richieste input[type="radio"] { transform: scale(0.9); }
	.form-richieste button[type="submit"],
	.form-richieste input[type="submit"] {
		padding: 0 8px;
		font-size: 12px;
		height: 40px;
	}
	.form-richieste .checkbox-wrapper label,
	.form-richieste .checkbox-wrapper span {
		font-size: 0.62em;
		line-height: 1.3;
	}
}

/* Fallback viewport per browser senza container query: rifiniture compatte
   sotto 600px. Il collasso dei campi è già garantito da flex, non serve qui. */
@supports not (container-type: inline-size) {
	@media (max-width: 600px) {
		.form-richieste {
			padding: 15px;
		}
		.form-richieste input[type="text"],
		.form-richieste input[type="tel"],
		.form-richieste input[type="email"],
		.form-richieste input[type="number"],
		.form-richieste input[type="date"],
		.form-richieste select {
			height: 40px;
		}
	}
}

/* ======================================================================
   BOT E SUBMIT SECURITY (Honeypot)
   ====================================================================== */

.form-richieste.is-submitting button[type="submit"],
.form-richieste.is-submitting input[type="submit"] {
    opacity: 0.7;
    cursor: wait;
    pointer-events: none;
}

.hp-field {
    position: absolute;
    left: -9999px;
    top: -9999px;
    height: 1px;
    width: 1px;
    overflow: hidden;
}

/* HONEYPOT AND SUBMIT BUTTON RULES */
.form-richieste.is-submitting button[type="submit"],
.form-richieste.is-submitting input[type="submit"] {
    opacity: 0.7;
    cursor: wait;
    pointer-events: none;
}

.hp-field {
    position: absolute;
    left: -9999px;
    top: -9999px;
    height: 1px;
    width: 1px;
    overflow: hidden;
}