/* ============================================================
   STRUTTURE — CSS
   ============================================================ */

/* Pagina dettaglio struttura */
.paf-structure-page .divisione-page3 {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 2rem;
	align-items: start;
}

@media (max-width: 991px) {
	.paf-structure-page .divisione-page3 {
		grid-template-columns: 1fr;
	}
}

/* Galleria */
.paf-structure-cover {
	width: 100%;
	/* aspect-ratio fisso al posto di max-height: dà alla cover un box stabile
	   che object-fit:cover riempie senza bordi/bande né stiramento, qualunque
	   sia il rapporto d'aspetto della foto caricata. */
	aspect-ratio: 16 / 10;
	height: auto;
	max-height: 420px;
	object-fit: cover;
	object-position: center;
	border-radius: 12px;
}

.gallery-thumb {
	width: 100px;
	/* aspect-ratio invece di width/height fissi disallineati (100x72 ≈ 1.39):
	   il box resta coerente e object-fit:cover non lascia bordi. */
	aspect-ratio: 4 / 3;
	height: auto;
	object-fit: cover;
	object-position: center;
	border-radius: 6px;
	cursor: pointer;
	transition: opacity .2s;
}

.gallery-thumb:hover {
	opacity: .8;
}

/* Titolo */
.paf-structure-title {
	font-size: 1.8rem;
	font-weight: 700;
	margin-bottom: .5rem;
}

/* ============================
   Sezione unità disponibili
   ============================ */

.paf-units-section {
	background: #fff;
	border-radius: 13px;
	padding: 1.5em 2em;
	margin-bottom: 2vh;
}

.paf-units-section h2 {
	display: flex;
	align-items: center;
	gap: .5rem;
}

.paf-units-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--c-tasti, #5e5e5e);
	color: var(--c-tasti-secondari, #d7f551);
	font-size: 12px;
	font-weight: 700;
	min-width: 24px;
	height: 24px;
	padding: 0 .5em;
	border-radius: 24px;
}

.paf-units-alert {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 300;
	font-size: 14px;
	color: var(--c-text-secondario, #6c6c6c);
	background: var(--c-bg, #efefef);
	border-radius: 10px;
	padding: .8em 1.2em;
	margin-bottom: 1rem;
}

.paf-units-alert--warn {
	color: #92400e;
	background: #fef3c7;
}

/* Card unità */
.paf-unit-card {
	display: flex;
	align-items: stretch;
	gap: 0;
	padding: 0;
	border: 1px solid transparent;
	border-radius: 13px;
	margin-bottom: .75rem;
	min-height: 140px;
	background: #f8f9fa;
	overflow: hidden;
	transition: box-shadow .15s ease, border-color .15s ease;
	position: relative;
}

.paf-unit-card:hover {
	box-shadow: 0 2px 8px rgba(0, 0, 0, .1);
}

.paf-unit-card--unavailable {
	opacity: .45;
}

.paf-unit-card--selected {
	border-color: var(--c-tasti-secondari, #d7f551);
}

/* Checkbox sovrapposta alla foto */
.paf-unit-check {
	position: absolute;
	top: .5rem;
	left: .5rem;
	z-index: 2;
	flex-shrink: 0;
}

.paf-unit-check .form-check-input {
	box-shadow: 0 1px 4px rgba(0,0,0,.2);
}

.paf-unit-check .form-check-input:checked {
	background-color: #009cbb;
	border-color: #009cbb;
}

.paf-unit-check .form-check-input:focus {
	border-color: #009cbb;
	box-shadow: 0 0 0 .25rem rgba(0, 156, 187, .25);
}

/* Immagine: altezza piena della card (desktop).
   Su mobile è sovrascritta a 100% + aspect-ratio 3:2 nella media query. */
.paf-unit-img {
	width: 240px;
	object-fit: cover;
	flex-shrink: 0;
	align-self: stretch;
}

/* Contenuto a destra della foto */
.paf-unit-content {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: .75rem .85rem;
	position: relative;
}

.paf-unit-info {
	min-width: 0;
}

.paf-unit-info strong {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 16px;
	font-weight: 600;
	color: var(--c-text, #282828);
	display: block;
	margin-bottom: 4px;
}

/* Titolo unità cliccabile (apre il modal dettagli) */
.paf-unit-title {
	cursor: pointer;
}

/* Chevron a fianco del titolo — visibile solo su mobile (vedi media query);
   su desktop il link "Dettagli alloggio" resta in alto a destra. */
.paf-unit-title-chevron {
	display: none;
	font-size: 12px;
	font-weight: 600;
	color: #009cbb;
	margin-left: .4em;
	vertical-align: baseline;
	transition: transform .15s ease;
}

.paf-unit-title:hover .paf-unit-title-chevron {
	transform: translateX(2px);
}

.paf-unit-meta {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 300;
	font-size: 14px;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-unit-features {
	display: flex;
	flex-wrap: wrap;
	gap: .3rem;
	margin-top: 8px;
}

.paf-unit-feature-tag {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 12px;
	color: var(--c-text-secondario, #6c6c6c);
	background: #fff;
	padding: .2em .55em;
	border-radius: 4px;
}

.paf-unit-feature-tag i {
	font-size: 11px;
}

.paf-unit-badge-unavail {
	display: inline-block;
	background: var(--c-bg, #efefef);
	color: var(--c-text-secondario, #6c6c6c);
	font-size: 11px;
	font-weight: 600;
	padding: .2em .6em;
	border-radius: 20px;
	margin-top: 4px;
}

/* Riga azioni in basso: stepper pax a sinistra */
.paf-unit-actions {
	margin-top: auto;
	padding-top: 8px;
}

/* Stepper pax inline */
.paf-pax-alloc {
	display: flex;
	align-items: center;
	gap: 4px;
}

.paf-pax-alloc .paf-pax-alloc-label {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 13px;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-pax-alloc .paf-pax-alloc-value {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 14px;
	font-weight: 600;
	min-width: 14px;
	text-align: center;
}

.paf-pax-alloc .paf-stepper-btn {
	width: 24px;
	height: 24px;
	font-size: 10px;
}

.paf-pax-alloc .paf-stepper-btn:disabled {
	opacity: .3;
	cursor: not-allowed;
}

.paf-unit-price-value {
	display: inline-block;
	background: var(--c-tasti, #5e5e5e);
	color: var(--c-tasti-secondari, #d7f551);
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-weight: 600;
	font-size: 15px;
	padding: .25em .6em;
	border-radius: .6em;
}

.paf-unit-price-from {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 300;
	font-size: 13px;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-unit-price-na {
	color: var(--c-text-secondario, #6c6c6c);
	font-size: 14px;
}

.paf-unit-price-row {
	position: absolute;
	bottom: .75rem;
	right: .85rem;
}

.paf-unit-price-original {
	font-size: 13px;
	color: var(--c-text-secondario, #6c6c6c);
	margin-right: .3em;
}

/* Il prezzo scontato usa lo stesso colore del prezzo normale
   (evita un terzo colore in card). La distinzione resta nel
   prezzo barrato a fianco (.paf-unit-price-original). */

/* Sidebar nights label */
.paf-sidebar-nights {
	font-size: 11px;
	font-weight: 600;
	color: var(--c-text-secondario, #6c6c6c);
	text-transform: uppercase;
	letter-spacing: .03em;
}

/* Sidebar total row */
.paf-sidebar-total-row {
	font-size: 15px;
}

/* Sidebar deposit rows */
.paf-sidebar-deposit-row {
	font-size: 14px;
	padding: 3px 0;
}

.paf-sidebar-deposit-row small {
	font-size: 11.5px;
}

/* Sidebar unit blocks */
.paf-sidebar-unit-block {
	padding: 8px 10px;
	margin-bottom: 6px;
	background: #fff;
	border-radius: 8px;
}

.paf-sidebar-unit-block:last-child {
	margin-bottom: 0;
}

.paf-sidebar-unit-row {
	padding: 0;
	font-size: 13px;
}

.paf-sidebar-unit-row > span:first-child {
	font-weight: 600;
	color: var(--c-text, #282828);
}

.paf-sidebar-unit-row > span:last-child {
	white-space: nowrap;
	flex-shrink: 0;
	padding-left: .5rem;
}

/* Extra costs inline per unit */
.paf-sidebar-extra-row {
	font-size: 11.5px;
	padding: 2px 0 2px 2px;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-sidebar-extra-row > span:last-child,
.paf-sidebar-extra-row .fw-semibold {
	white-space: nowrap;
	flex-shrink: 0;
	margin-left: auto;
	padding-left: .5rem;
	font-size: 11.5px;
	font-weight: 500 !important;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-sidebar-extra-row .form-check {
	gap: 4px;
}

.paf-sidebar-extra-row .form-check-input {
	margin-top: 1px;
	width: 13px;
	height: 13px;
	border-color: #bbb;
}

.paf-sidebar-extra-row .form-check-input:checked {
	background-color: var(--c-tasti, #5e5e5e);
	border-color: var(--c-tasti, #5e5e5e);
}

.paf-sidebar-extra-row label span {
	font-weight: 400;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-sidebar-extra-row small {
	font-size: 10px;
}

.paf-sidebar-extra-row i.fa-check-circle {
	font-size: 10px;
	opacity: .6;
}

/* Prezzo extra opzionale: barrato quando non selezionato */
.paf-extra-price-off {
	font-size: 11.5px;
	font-weight: 500;
	color: #b0b0b0;
	text-decoration: line-through;
	white-space: nowrap;
	flex-shrink: 0;
	padding-left: .5rem;
}

.paf-extra-price-on {
	font-size: 11.5px;
	font-weight: 500;
	color: var(--c-text, #282828);
	white-space: nowrap;
	flex-shrink: 0;
	padding-left: .5rem;
}

/* Bottone dettagli — posizionato in alto a destra */
.paf-unit-btn-detail {
	position: absolute;
	top: .5rem;
	right: .85rem;
	padding: 0;
	border: none;
	background: transparent;
	color: #009cbb;
	font-family: "Roboto Condensed", sans-serif;
	font-size: 13px;
	font-weight: 400;
	cursor: pointer;
	transition: color .15s ease;
}

.paf-unit-btn-detail:hover {
	color: #007a94;
	text-decoration: underline;
}

/* Pannello sticky */
.sticky-slot {
	position: sticky;
	top: 100px;
}

#modulo-fisso-prenota {
	padding: 1.2rem 1.4rem;
}

/* ============================
   Modal dettaglio unità
   ============================ */

#unitDetailModal {
	z-index: 100001;
}

#unitDetailModal ~ .modal-backdrop,
body.modal-open > .modal-backdrop {
	z-index: 100000;
}

#unitDetailModal .modal-content {
	border-radius: 15px;
	border: none;
}

#unitDetailModal .modal-header {
	border-bottom: none;
	padding: 1.2rem 1.5rem;
}

#unitDetailModal .modal-title {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-weight: 700;
	font-size: 20px;
	color: var(--c-text, #282828);
}

#unitDetailModal .modal-body {
	padding: 1.5rem;
	scrollbar-width: none;
	-ms-overflow-style: none;
}

#unitDetailModal .modal-body::-webkit-scrollbar {
	display: none;
}

.paf-unit-modal-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
}

@media (max-width: 768px) {
	.paf-unit-modal-grid {
		grid-template-columns: 1fr;
	}
}

/* Gallery */
.paf-unit-modal-gallery {
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.paf-unit-modal-hero {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	border-radius: 10px;
	cursor: pointer;
	transition: filter .15s ease;
}

.paf-unit-modal-hero:hover {
	filter: brightness(.9);
}

.paf-unit-modal-thumbs {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .5rem;
}

.paf-unit-modal-thumb-wrap {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3;
	border-radius: 8px;
	overflow: hidden;
	cursor: pointer;
}

.paf-unit-modal-thumb {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: filter .15s ease;
}

.paf-unit-modal-thumb-wrap:hover .paf-unit-modal-thumb {
	filter: brightness(.85);
}

/* Overlay "+N foto" sull'ultima thumb quando ce ne sono altre nel lightbox */
.paf-unit-modal-thumb-more {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, .5);
	color: #fff;
	font-size: 1.25rem;
	font-weight: 600;
	pointer-events: none;
}

/* Info */
.paf-unit-modal-info {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

/* Stats row */
.paf-unit-modal-stats {
	display: flex;
	flex-wrap: wrap;
	gap: .75rem;
}

.paf-unit-modal-stat {
	display: flex;
	align-items: center;
	gap: .4rem;
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 300;
	font-size: .9rem;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-unit-modal-stat svg {
	fill: none;
	stroke: currentColor;
	stroke-width: 1.5;
	stroke-linecap: round;
	stroke-linejoin: round;
	flex-shrink: 0;
}

/* Descrizione */
.paf-unit-modal-desc {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 300;
	font-size: .9rem;
	color: var(--c-text-secondario, #6c6c6c);
	line-height: 1.6;
}

/* Section titles */
.paf-unit-modal-section {
	border-top: 1px solid var(--c-bg, #efefef);
	padding-top: .75rem;
}

.paf-unit-modal-section-title {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: .8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--c-text, #282828);
	margin-bottom: .75rem;
}

/* Features grid */
.paf-unit-modal-features {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .5rem;
}

.paf-unit-modal-feature {
	display: flex;
	align-items: center;
	gap: .5rem;
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 300;
	font-size: .88rem;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-unit-modal-feature i {
	width: 20px;
	text-align: center;
	color: var(--c-text-secondario, #6c6c6c);
}

/* Ricorda */
.paf-unit-modal-remember {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.paf-unit-modal-remember-item {
	display: flex;
	align-items: flex-start;
	gap: .6rem;
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 300;
	font-size: .88rem;
	color: var(--c-text-secondario, #6c6c6c);
	padding: .6rem 0;
	border-bottom: 1px solid var(--c-bg, #efefef);
}

.paf-unit-modal-remember-item:last-child {
	border-bottom: none;
}

.paf-unit-modal-remember-item i {
	width: 18px;
	text-align: center;
	color: var(--c-text-secondario, #6c6c6c);
	margin-top: 2px;
	flex-shrink: 0;
}

/* CTA modal */
#btnCheckAvailability {
	background: var(--c-tasti-secondari, #d7f551) !important;
	color: var(--c-text, #282828) !important;
	border: none;
	border-radius: 10px;
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-weight: 600;
	font-size: 15px;
	padding: 12px;
	transition: filter .15s ease;
}

#btnCheckAvailability:hover {
	filter: brightness(.92);
}

/* Lightbox immagini modal */
.paf-unit-modal-hero,
.paf-unit-modal-thumb {
	cursor: zoom-in;
}

.paf-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, .85);
	z-index: 100002;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: zoom-out;
	animation: pafLbIn .2s ease;
}

.paf-lightbox img {
	max-width: 92vw;
	max-height: 90vh;
	object-fit: contain;
	border-radius: 6px;
}

@keyframes pafLbIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}

/* Card struttura nei risultati ricerca */
.paf-card--structure {
	border: 2px solid var(--paf-primary, #2563eb);
}

.paf-card--structure .paf-badge--units {
	background: var(--paf-primary, #2563eb);
	color: #fff;
	font-size: .75rem;
	padding: .25rem .6rem;
	border-radius: 20px;
}

/* ============================
   Campi form sidebar prenotazione
   ============================ */

.paf-field {
	background: #f8f9fa;
	border: 2px solid transparent;
	border-radius: 10px;
	padding: .6rem 1rem;
	min-height: 52px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	margin-bottom: .75rem;
	transition: border-color .15s ease;
	cursor: pointer;
}

.paf-field:focus-within {
	border-color: transparent;
}

/* Label integrata */
.paf-field-label {
	display: block;
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 12px;
	color: var(--c-text-secondario, #6c6c6c);
	margin-bottom: 2px;
	pointer-events: none;
}

.paf-field-label i {
	font-size: 11px;
}

/* Input testo (date) */
.paf-field-input {
	display: block;
	width: 100%;
	border: none;
	background: transparent;
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-weight: 600;
	font-size: 14px;
	color: var(--c-text, #282828);
	padding: 0;
	outline: none;
	cursor: pointer;
}

.paf-field-input::placeholder {
	font-weight: 400;
	font-size: 14px;
	color: var(--c-text-secondario, #6c6c6c);
}

/* Stepper ospiti */
.paf-field--stepper {
	flex-direction: row;
	align-items: center;
	gap: .5rem;
	padding: .6rem 1rem;
	cursor: default;
}

.paf-stepper-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border: 1.5px solid var(--c-text-secondario, #6c6c6c);
	border-radius: 50%;
	background: transparent;
	color: var(--c-text, #282828);
	font-size: 14px;
	cursor: pointer;
	transition: background .15s ease, border-color .15s ease;
	flex-shrink: 0;
	padding: 0;
	line-height: 1;
}

.paf-stepper-btn:focus {
	outline: none;
	box-shadow: none;
}

.paf-stepper-btn:hover {
	background: var(--c-tasti, #5e5e5e);
	border-color: var(--c-tasti, #5e5e5e);
	color: #fff;
}

.paf-stepper-btn:active {
	transform: scale(.92);
}

.paf-stepper-value {
	flex: 1;
	text-align: center;
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-weight: 600;
	font-size: 14px;
	color: var(--c-text, #282828);
	user-select: none;
}


/* Note info sidebar */
#discount_box {
	font-weight: 400 !important;
}

#discount_box .small {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 12px;
	color: var(--c-text-secondario, #6c6c6c) !important;
	margin-bottom: 4px;
}

/* Riepilogo selezione */
#selection-box {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 13px;
	background: #f2f3f5;
	border-radius: 10px;
}

#selection-box > .fw-bold.small {
	font-size: 11px !important;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--c-text-secondario, #6c6c6c);
	font-weight: 600 !important;
	margin-bottom: 8px !important;
}

/* Link secondari sidebar */
#modulo-fisso-prenota a.text-muted {
	color: #009cbb !important;
	text-decoration: none;
	font-weight: 600;
}

#modulo-fisso-prenota a.text-muted:hover {
	text-decoration: underline;
}

/* ============================
   Mobile — card unità
   ============================ */

@media (max-width: 575px) {

	/* Pannello unità trasparente su mobile: elimina l'annidamento
	   card-dentro-pannello che rubava larghezza (padding 2em laterali).
	   La card grigia resta come "tile" selezionabile. */
	.paf-units-section {
		background: transparent;
		border-radius: 0;
		padding: 0;
	}

	/* Ritmo verticale del titolo di sezione (ora "nudo" fuori dal pannello):
	   più aria sopra per staccarlo dal blocco precedente, meno sotto
	   per legarlo alla lista che introduce. Il margin-top collassa con il
	   margin-bottom del pannello sopra → prevale 20px. */
	.paf-units-section h2 {
		margin-top: 20px;
		margin-bottom: 14px;
	}

	.paf-unit-card {
		flex-direction: column;
	}

	/* Foto larga, in alto — aspect ratio 3:2 */
	.paf-unit-img {
		width: 100%;
		height: auto;
		aspect-ratio: 3 / 2;
	}

	.paf-unit-info strong {
		font-size: 14px;
	}

	.paf-unit-meta {
		font-size: 12px;
	}

	/* Stepper a sinistra, prezzo a destra, sulla stessa riga nel flusso */
	.paf-unit-actions {
		display: flex;
		align-items: center;
		justify-content: space-between;
		flex-wrap: wrap;
		gap: .4rem;
	}

	/* Prezzo nel flusso (non più absolute): evita overlap con lo stepper */
	.paf-unit-price-row {
		position: static;
		bottom: auto;
		right: auto;
		margin-left: auto;
	}

	/* Su mobile il link "Dettagli alloggio" è sostituito dal titolo
	   cliccabile col chevron → nascondiamo la riga dedicata. */
	.paf-unit-btn-detail {
		display: none;
	}

	/* Titolo = trigger dei dettagli: mostriamo il chevron azzurrino */
	.paf-unit-title-chevron {
		display: inline-block;
	}

	/* Modal fullscreen */
	#unitDetailModal .modal-dialog {
		margin: 0;
		max-width: 100%;
		min-height: 100%;
	}

	#unitDetailModal .modal-content {
		border-radius: 0;
		min-height: 100vh;
	}

	.paf-unit-modal-grid {
		grid-template-columns: 1fr;
	}
}

/* ============================================================
   CHECKOUT STRUTTURA
   ============================================================ */

/* Header con cover */
.paf-checkout-header {
	display: flex;
	align-items: center;
	gap: 1.2rem;
	background: #fff;
	border-radius: 13px;
	padding: 1.2em 1.5em;
	margin-bottom: 1.2rem;
}

.paf-checkout-cover {
	width: 110px;
	height: 80px;
	object-fit: cover;
	border-radius: 10px;
	flex-shrink: 0;
}

.paf-checkout-header-text {
	flex: 1;
	min-width: 0;
}

.paf-checkout-title {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--c-text, #282828);
	margin: 0 0 .3rem;
}

.paf-checkout-address {
	display: flex;
	align-items: center;
	gap: .4rem;
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 300;
	font-size: .9rem;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-checkout-address .paf-icon-svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

/* Form wrap */
.paf-checkout-form-wrap {
	background: #fff;
	border-radius: 13px;
	padding: 1.5em 2em;
}

/* Section titles */
.paf-checkout-section-title {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: .85rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--c-text, #282828);
	margin: 0 0 1rem;
}

/* Grid 2-col */
.paf-checkout-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .9rem;
}

@media (max-width: 575px) {
	.paf-checkout-grid {
		grid-template-columns: 1fr;
	}
}

/* Field */
.paf-checkout-field {
	display: flex;
	flex-direction: column;
}

.paf-checkout-field--full {
	grid-column: 1 / -1;
}

/* Label */
.paf-checkout-label {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 12px;
	color: var(--c-text-secondario, #6c6c6c);
	margin-bottom: 4px;
}

.paf-checkout-label i {
	font-size: 11px;
	margin-right: 2px;
}

.paf-req {
	color: #e74c3c;
	font-weight: 600;
}

/* Input */
.paf-checkout-input {
	display: block;
	width: 100%;
	padding: .55rem .8rem;
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 14px;
	font-weight: 500;
	color: var(--c-text, #282828);
	background: #f8f9fa;
	border: 2px solid transparent;
	border-radius: 10px;
	outline: none;
	transition: border-color .15s ease, background .15s ease;
}

.paf-checkout-input:focus {
	border-color: var(--c-tasti-secondari, #d7f551);
	background: #fff;
}

/* Select */
.paf-checkout-select {
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%236c6c6c' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right .8rem center;
	padding-right: 2rem;
	cursor: pointer;
}

/* Textarea */
.paf-checkout-textarea {
	display: block;
	width: 100%;
	min-height: 110px;
	padding: .55rem .8rem;
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 14px;
	font-weight: 500;
	color: var(--c-text, #282828);
	background: #f8f9fa;
	border: 2px solid transparent;
	border-radius: 10px;
	outline: none;
	resize: vertical;
	transition: border-color .15s ease, background .15s ease;
}

.paf-checkout-textarea:focus {
	border-color: var(--c-tasti-secondari, #d7f551);
	background: #fff;
}

/* Hint sotto campo */
.paf-checkout-hint {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 11px;
	color: var(--c-text-secondario, #6c6c6c);
	margin-top: 3px;
	padding-left: 2px;
}

.paf-checkout-hint i {
	font-size: 10px;
	margin-right: 2px;
}

/* Error message */
.paf-checkout-error {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 12px;
	color: #e74c3c;
	margin-top: 3px;
	padding-left: 2px;
}

/* Divider */
.paf-checkout-divider {
	height: 1px;
	background: var(--c-bg, #efefef);
	margin: 1.4rem 0;
}

/* Checkboxes — stile paf-filter-check (coerente con modal filtri ricerca) */
.paf-filter-check {
	display: flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	padding: 6px 0;
	user-select: none;
}

.paf-filter-check input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	width: 20px;
	height: 20px;
	min-width: 20px;
	border: 1.5px solid #ccc;
	border-radius: 5px;
	background: #fff;
	cursor: pointer;
	position: relative;
	transition: background .15s, border-color .15s;
}

.paf-filter-check input[type="checkbox"]:checked {
	background: var(--c-tasti-secondari, #d7f551);
	border-color: var(--c-tasti-secondari, #d7f551);
}

.paf-filter-check input[type="checkbox"]:checked::after {
	content: '';
	position: absolute;
	left: 6px;
	top: 2px;
	width: 5px;
	height: 10px;
	border: solid var(--c-text, #282828);
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.paf-filter-check input[type="checkbox"].is-invalid {
	border-color: #e74c3c;
}

.paf-filter-check-label {
	font-size: 14px;
	color: var(--c-text, #282828);
	display: flex;
	align-items: center;
	gap: 5px;
}

/* Link terms/privacy sottolineati */
.paf-checkout-link {
	color: #009cbb;
	text-decoration: underline;
	font-weight: 500;
}

.paf-checkout-link:hover {
	color: #007a94;
}

/* Sidebar actions */
.paf-checkout-actions {
	display: flex;
	gap: .5rem;
}

.paf-checkout-actions .paf-booking-back,
.paf-checkout-actions .paf-booking-submit {
	flex: 1;
	text-align: center;
}

/* ============================================================
   RIEPILOGO STRUTTURA
   ============================================================ */

/* Summary data grid */
.paf-summary-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .5rem .9rem;
}

.paf-summary-item {
	display: flex;
	flex-direction: column;
	gap: 1px;
}

.paf-summary-label {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 12px;
	color: var(--c-text-secondario, #6c6c6c);
}

.paf-summary-item strong {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 14px;
	font-weight: 600;
	color: var(--c-text, #282828);
}

.paf-summary-note {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 14px;
	color: var(--c-text, #282828);
	line-height: 1.5;
	margin: 0;
}

/* Payment toggle */
.paf-payment-toggle {
	display: flex;
	gap: .5rem;
}

.paf-payment-toggle .payment-btn {
	flex: 1;
	padding: .7rem 1rem;
	border: 2px solid var(--c-bg, #efefef);
	border-radius: 10px;
	background: #fff;
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 13px;
	font-weight: 600;
	color: var(--c-text, #282828);
	cursor: pointer;
	text-align: center;
	transition: border-color .15s ease, background .15s ease;
}

.paf-payment-toggle .payment-btn:hover {
	border-color: var(--c-tasti-secondari, #d7f551);
}

.paf-payment-toggle .payment-btn.active {
	border-color: var(--c-tasti-secondari, #d7f551);
	background: var(--c-tasti-secondari, #d7f551);
	color: var(--c-text, #282828);
}

.paf-payment-toggle .payment-btn i {
	font-size: 14px;
}

/* ============================================================
   CONFERMA STRUTTURA
   ============================================================ */

/* Stats grid (checkin, checkout, ospiti, notti) */
.paf-confirm-details {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: .5rem;
	margin: 1.2rem 0;
}

.paf-confirm-stat {
	text-align: center;
	padding: .8rem .5rem;
	background: #f8f9fa;
	border-radius: 10px;
}

.paf-confirm-stat-label {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 11px;
	color: var(--c-text-secondario, #6c6c6c);
	text-transform: uppercase;
	letter-spacing: .03em;
	margin-bottom: 2px;
}

.paf-confirm-stat-value {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-weight: 700;
	font-size: 14px;
	color: var(--c-text, #282828);
}

/* Unità prenotate */
.paf-confirm-units {
	margin-bottom: 1rem;
}

.paf-confirm-unit-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: .5rem .8rem;
	background: #f8f9fa;
	border-radius: 8px;
	margin-bottom: .4rem;
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 13px;
	font-weight: 600;
	color: var(--c-text, #282828);
}

/* Totali */
.paf-confirm-totals {
	background: #f8f9fa;
	border-radius: 10px;
	padding: .8rem 1rem;
	margin-bottom: 1rem;
}

.paf-confirm-total-row {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: .3rem 0;
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 14px;
	color: var(--c-text, #282828);
}

.paf-confirm-total-row--final {
	border-top: 1px solid var(--c-bg, #efefef);
	margin-top: .4rem;
	padding-top: .6rem;
	font-weight: 700;
	font-size: 16px;
}

/* Riferimento */
.paf-confirm-ref {
	text-align: center;
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 12px;
	color: var(--c-text-secondario, #6c6c6c);
	margin-top: .5rem;
}

.paf-confirm-ref code {
	font-size: 11px;
	background: #f8f9fa;
	padding: .15em .4em;
	border-radius: 4px;
}

/* Messaggi finali */
.paf-confirm-thanks {
	font-family: var(--f-font1, "Raleway", sans-serif);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--c-text, #282828);
	margin-bottom: .3rem;
}

.paf-confirm-msg {
	font-family: "Roboto Condensed", sans-serif;
	font-weight: 400;
	font-size: 14px;
	color: var(--c-text-secondario, #6c6c6c);
	margin-bottom: 0;
}

/* Mobile checkout + summary + confirm tweaks */
@media (max-width: 575px) {
	.paf-checkout-header {
		gap: .8rem;
		padding: 1em;
	}

	.paf-checkout-cover {
		width: 80px;
		height: 60px;
	}

	.paf-checkout-form-wrap {
		padding: 1.2em 1.2em;
	}

	.paf-checkout-title {
		font-size: 1.15rem;
	}

	.paf-summary-grid {
		grid-template-columns: 1fr;
	}

	.paf-payment-toggle {
		flex-direction: column;
	}

	.paf-confirm-details {
		grid-template-columns: repeat(2, 1fr);
	}
}
