/* components.css — stili delle sezioni Adamo Apartments */

/* ===== Header ============================================================ */
.hdr { position: fixed; inset: 0 0 auto 0; z-index: 60; transition: background .35s ease, box-shadow .35s ease, border-color .35s ease; border-bottom: 1px solid transparent; }
.hdr.is-solid { background: oklch(0.975 0.008 85 / 0.86); backdrop-filter: blur(14px); border-color: var(--greige); box-shadow: var(--shadow-sm); }
.hdr__inner { display: flex; align-items: center; justify-content: space-between; height: 74px; gap: 24px; }
.hdr__logo { display: inline-flex; align-items: center; gap: 11px; color: #fff; transition: color .35s ease; }
.hdr.is-solid .hdr__logo { color: var(--ink); }
.hdr__logo-mark { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; background: var(--accent); color: var(--accent-contrast); font-family: var(--font-display); font-size: 20px; font-weight: 600; flex: none; }
.hdr__logo-name { font-family: var(--font-display); font-size: 22px; font-weight: 600; letter-spacing: 0.01em; white-space: nowrap; }
.hdr__nav { display: flex; gap: 28px; margin-left: auto; }
.hdr__link { font-size: 14px; font-weight: 500; color: #fff; opacity: .9; transition: color .35s ease, opacity .2s ease; position: relative; padding: 4px 0; }
.hdr.is-solid .hdr__link { color: var(--ink-soft); }
.hdr__link:hover { opacity: 1; color: var(--accent); }
.hdr__right { display: flex; align-items: center; gap: 14px; }
.hdr__cta { padding: 10px 22px; }
.langsw { display: inline-flex; border: 1px solid oklch(1 0 0 / 0.4); border-radius: var(--radius); overflow: hidden; }
.hdr.is-solid .langsw { border-color: var(--greige-2); }
.langsw__btn { font-size: 12px; font-weight: 600; letter-spacing: 0.04em; padding: 7px 10px; color: #fff; transition: background .2s, color .2s; }
.hdr.is-solid .langsw__btn { color: var(--ink-soft); }
.langsw__btn.is-on { background: var(--accent); color: var(--accent-contrast); }
.hdr__burger { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.hdr__burger span { width: 22px; height: 2px; background: #fff; transition: background .35s; }
.hdr.is-solid .hdr__burger span { background: var(--ink); }
.hdr__mobile { display: none; }

/* ===== Hero ============================================================== */
.hero { position: relative; min-height: 100svh; display: flex; flex-direction: column; justify-content: flex-end; gap: clamp(30px, 5vh, 52px); padding-bottom: clamp(40px, 7vh, 84px); padding-top: 120px; color: #fff; }
.hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; background-color: oklch(0.5 0.03 70); }
.hero__bg.ph::after { display: none; }
.hero__scrim { position: absolute; inset: 0; background: linear-gradient(to top, oklch(0.2 0.02 60 / 0.7) 0%, oklch(0.2 0.02 60 / 0.15) 45%, oklch(0.2 0.02 60 / 0.35) 100%); }
.hero__content { position: relative; z-index: 2; display: flex; flex-direction: column; }
.hero__eyebrow { font-size: 13px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; opacity: .92; margin-bottom: 20px; }
.hero__title { font-size: clamp(46px, 7.6vw, 92px); line-height: 1.0; color: #fff; max-width: 14ch; }
.hero__payoff { font-family: var(--font-display); font-size: clamp(22px, 3vw, 32px); font-weight: 400; font-style: italic; line-height: 1.25; margin-top: 20px; max-width: 24ch; }
.hero__sub { font-size: clamp(15px, 1.5vw, 18px); opacity: .9; margin-top: 16px; max-width: 52ch; }
.hero__widget { position: relative; z-index: 3; width: 100%; }

/* ===== Widget disponibilità ============================================= */
.availw { display: flex; gap: 0; background: var(--paper); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 10px; align-items: stretch; flex-wrap: wrap; }
.availw__field { flex: 1 1 150px; display: flex; flex-direction: column; gap: 5px; padding: 10px 16px; border-right: 1px solid var(--greige); }
.availw__field--g { flex: 0 0 auto; }
.availw__lbl { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.availw__field input { border: none; background: none; font-family: var(--font-body); font-size: 15px; font-weight: 600; color: var(--ink); padding: 2px 0; }
.availw__field input::-webkit-calendar-picker-indicator { opacity: .5; cursor: pointer; }
.availw__cta { flex: 0 0 auto; margin-left: 6px; padding-inline: 22px; }
.availw--compact { box-shadow: var(--shadow-md); }

.stepper { display: inline-flex; align-items: center; gap: 6px; }
.stepper button { width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--greige-2); display: grid; place-items: center; color: var(--ink); transition: border-color .2s, background .2s; }
.stepper button:hover { border-color: var(--accent); color: var(--accent); }
.stepper span { min-width: 22px; text-align: center; font-weight: 700; font-size: 16px; }

/* ===== Sezioni generiche ================================================ */
.section { padding-block: var(--section-y); }
.section-head { max-width: 720px; margin-bottom: clamp(36px, 5vw, 64px); }
.section-head .eyebrow { margin-bottom: 18px; }
.section-head--center { margin-inline: auto; text-align: center; }
.section-head--center .eyebrow::before { display: none; }
.section-head .lede { margin-top: 16px; }

/* ===== Galleria ========================================================= */
.gallery { background: var(--sand); }
.gallery__grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; gap: 14px; }
.gallery__cell { position: relative; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s; }
.gallery__cell:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.gallery__cell--wide { grid-column: span 2; }
.gallery__cell--tall { grid-row: span 2; }
.gallery__ph { width: 100%; height: 100%; }
.gallery__zoom { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border-radius: 50%; background: oklch(1 0 0 / 0.85); color: var(--ink); display: grid; place-items: center; opacity: 0; transform: scale(.85); transition: opacity .25s, transform .25s; }
.gallery__cell:hover .gallery__zoom { opacity: 1; transform: scale(1); }

/* ===== Lightbox ========================================================= */
.lightbox { position: fixed; inset: 0; z-index: 100; background: oklch(0.18 0.01 60 / 0.92); display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 12px; padding: clamp(16px, 4vw, 48px); animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; } }
.lightbox__fig { grid-column: 2; max-width: min(1100px, 90vw); }
.lightbox__img { width: min(1100px, 86vw); height: min(72vh, 720px); border-radius: var(--radius-lg); background-color: oklch(0.45 0.02 70); }
.lightbox__cap { color: oklch(1 0 0 / 0.8); font-size: 13px; margin-top: 14px; text-align: center; letter-spacing: 0.02em; }
.lightbox__close { position: absolute; top: 18px; right: 22px; width: 46px; height: 46px; border-radius: 50%; background: oklch(1 0 0 / 0.12); color: #fff; display: grid; place-items: center; transition: background .2s; }
.lightbox__close:hover { background: oklch(1 0 0 / 0.24); }
.lightbox__nav { width: 52px; height: 52px; border-radius: 50%; background: oklch(1 0 0 / 0.12); color: #fff; display: grid; place-items: center; align-self: center; transition: background .2s; }
.lightbox__nav:hover { background: oklch(1 0 0 / 0.24); }
.lightbox__nav--prev { grid-column: 1; justify-self: start; }
.lightbox__nav--next { grid-column: 3; justify-self: end; }

/* ===== La casa ========================================================== */
.apt__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(36px, 6vw, 88px); align-items: start; }
.apt__specs { display: flex; gap: clamp(20px, 4vw, 48px); margin: 30px 0; flex-wrap: wrap; }
.apt__spec { display: flex; flex-direction: column; }
.apt__spec-n { font-family: var(--font-display); font-size: 38px; font-weight: 500; line-height: 1; color: var(--accent-deep); }
.apt__spec-l { font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); margin-top: 6px; }
.apt__desc p { margin-bottom: 16px; color: var(--ink-soft); max-width: 54ch; }
.apt__amen-title { font-size: 22px; margin: 30px 0 16px; }
.amenities { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 13px 20px; }
.amenity { display: flex; align-items: center; gap: 12px; font-size: 15px; font-weight: 500; }
.amenity__ic { width: 42px; height: 42px; border-radius: 50%; background: var(--accent-soft); color: var(--accent-deep); display: grid; place-items: center; flex: none; }
.apt__media { display: grid; grid-template-rows: 1.3fr 1fr; gap: 14px; position: sticky; top: 100px; }
.apt__media-a { width: 100%; height: 360px; border-radius: var(--radius-lg); }
.apt__media-b { width: 78%; height: 230px; border-radius: var(--radius-lg); justify-self: end; margin-top: -60px; box-shadow: var(--shadow-md); border: 6px solid var(--paper); }

/* ===== Calendario ======================================================= */
.cal-sec { background: var(--sand); }
.cal__card { max-width: 880px; margin: 0 auto; background: var(--paper); border-radius: var(--radius-xl); box-shadow: var(--shadow-md); padding: clamp(20px, 3.5vw, 40px); }
.cal__legend { display: flex; gap: 22px; justify-content: center; font-size: 13px; color: var(--ink-soft); margin-bottom: 8px; }
.cal__legend span { display: inline-flex; align-items: center; gap: 7px; }
.dot { width: 11px; height: 11px; border-radius: 3px; display: inline-block; }
.dot--free { background: var(--paper); border: 1px solid var(--greige-2); }
.dot--occ { background: var(--greige); position: relative; }
.dot--sel { background: var(--accent); }
.cal__head { display: flex; justify-content: flex-end; gap: 10px; margin: 10px 0 4px; }
.cal__arrow { width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--greige-2); display: grid; place-items: center; color: var(--ink); transition: border-color .2s, background .2s, color .2s; }
.cal__arrow:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); }
.cal__arrow:disabled { opacity: .3; cursor: not-allowed; }
.cal__months { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 4vw, 48px); }
.cal__mtitle { font-family: var(--font-display); font-size: 21px; font-weight: 600; text-align: center; margin-bottom: 12px; text-transform: capitalize; }
.cal__wd { display: grid; grid-template-columns: repeat(7, 1fr); margin-bottom: 6px; }
.cal__wd span { text-align: center; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted); }
.cal__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cal__cell { aspect-ratio: 1; display: grid; place-items: center; font-size: 14px; font-weight: 500; border-radius: 8px; color: var(--ink); transition: background .15s, color .15s; position: relative; }
.cal__cell--empty { background: none; }
.cal__cell:not(.is-disabled):hover { background: var(--accent-soft); }
.cal__cell.is-disabled { color: var(--greige-2); cursor: not-allowed; }
.cal__cell.is-occupied { color: var(--muted); text-decoration: line-through; background: var(--sand); }
.cal__cell.is-range, .cal__cell.is-hover { background: var(--accent-soft); border-radius: 0; color: var(--accent-deep); }
.cal__cell.is-ci, .cal__cell.is-co { background: var(--accent); color: var(--accent-contrast); font-weight: 700; }
.cal__cell.is-ci { border-radius: 8px 0 0 8px; }
.cal__cell.is-co { border-radius: 0 8px 8px 0; }
.cal__msg { text-align: center; color: var(--accent-deep); font-size: 14px; font-weight: 600; margin-top: 14px; }
.cal__foot { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--greige); }
.cal__sel { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.cal__pill { display: inline-flex; align-items: center; gap: 8px; background: var(--accent-soft); color: var(--accent-deep); padding: 7px 14px; border-radius: 100px; font-size: 14px; font-weight: 600; }
.cal__nights { font-size: 14px; color: var(--ink-soft); font-weight: 600; }
.cal__clear { font-size: 13px; color: var(--muted); text-decoration: underline; }
.cal__note { display: flex; align-items: center; gap: 8px; justify-content: center; font-size: 12.5px; color: var(--muted); margin-top: 18px; }

/* ===== Tariffe ========================================================== */
.rates__grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.rates__extras { list-style: none; margin-top: 28px; border-top: 1px solid var(--greige); }
.rates__extras li { display: flex; justify-content: space-between; padding: 14px 0; border-bottom: 1px solid var(--greige); font-size: 15px; }
.rates__extras span { color: var(--ink-soft); }
.rates__cards { display: grid; gap: 14px; }
.rates__card { display: grid; grid-template-columns: 1fr auto; align-items: center; row-gap: 2px; background: var(--paper); border: 1px solid var(--greige); border-radius: var(--radius-lg); padding: 22px 26px; transition: transform .25s, box-shadow .25s; }
.rates__card.is-feat { border-color: var(--accent); box-shadow: var(--shadow-md); }
.rates__season { font-family: var(--font-display); font-size: 23px; font-weight: 600; }
.rates__period { font-size: 13px; color: var(--muted); grid-column: 1; }
.rates__price { grid-row: 1 / span 2; grid-column: 2; font-family: var(--font-display); font-size: 40px; font-weight: 500; color: var(--accent-deep); }
.rates__price small { font-family: var(--font-body); font-size: 14px; color: var(--muted); font-weight: 500; }

/* ===== La zona ========================================================== */
.zona__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(32px, 5vw, 64px); align-items: stretch; }
.zona__list { list-style: none; display: grid; gap: 4px; align-content: start; }
.zona__item { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 16px; padding: 16px 8px; border-bottom: 1px solid var(--greige); }
.zona__ic { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--greige-2); color: var(--accent-deep); display: grid; place-items: center; }
.zona__name { font-weight: 600; font-size: 16px; }
.zona__meta { font-size: 13px; color: var(--muted); text-align: right; white-space: nowrap; }
.zona__map { position: relative; border-radius: var(--radius-lg); overflow: hidden; min-height: 380px; box-shadow: var(--shadow-sm); }
.zona__map-ph { position: absolute; inset: 0; }
.zona__pin { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -100%); color: var(--accent); filter: drop-shadow(0 4px 6px oklch(0 0 0 / .3)); }
.zona__maplink { position: absolute; bottom: 16px; left: 16px; display: inline-flex; align-items: center; gap: 7px; background: var(--paper); padding: 9px 16px; border-radius: 100px; font-size: 13px; font-weight: 600; box-shadow: var(--shadow-sm); }

/* ===== Recensioni ======================================================= */
.reviews__score { display: inline-flex; align-items: center; gap: 10px; margin-top: 18px; font-size: 16px; color: var(--ink-soft); }
.reviews__score b { font-size: 20px; color: var(--ink); }
.reviews__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.review { background: var(--paper); border: 1px solid var(--greige); border-radius: var(--radius-lg); padding: 26px; display: flex; flex-direction: column; gap: 14px; }
.review blockquote { font-family: var(--font-display); font-size: 19px; line-height: 1.4; font-style: italic; color: var(--ink); text-wrap: pretty; }
.review figcaption { display: flex; flex-direction: column; gap: 2px; margin-top: auto; }
.review__name { font-weight: 700; font-size: 15px; }
.review__meta { font-size: 13px; color: var(--muted); }

/* ===== FAQ ============================================================== */
.faq { background: var(--sand); }
.faq__grid { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(32px, 5vw, 72px); align-items: start; }
.faq__list { list-style: none; }
.faq__item { border-bottom: 1px solid var(--greige); }
.faq__q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 18px; text-align: left; font-family: var(--font-display); font-size: clamp(19px, 2.2vw, 23px); font-weight: 600; padding: 22px 0; color: var(--ink); }
.faq__toggle { flex: none; width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--greige-2); display: grid; place-items: center; color: var(--accent-deep); transition: background .2s, border-color .2s; }
.faq__q:hover .faq__toggle { background: var(--accent-soft); }
.faq__a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.faq__item.is-open .faq__a { max-height: 320px; }
.faq__a p { padding-bottom: 24px; color: var(--ink-soft); max-width: 60ch; }

/* ===== Richiesta prenotazione =========================================== */
.book__grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px, 5vw, 72px); align-items: start; }
.book__assure { list-style: none; margin-top: 26px; display: grid; gap: 12px; }
.book__assure li { display: flex; align-items: center; gap: 11px; font-size: 15px; font-weight: 500; }
.book__assure svg { color: var(--accent); flex: none; }
.book__panel { background: var(--paper); border: 1px solid var(--greige); border-radius: var(--radius-xl); padding: clamp(22px, 3vw, 36px); box-shadow: var(--shadow-md); }
.book__dates { margin-bottom: 18px; }
.book__pickdates { width: 100%; display: flex; align-items: center; justify-content: center; gap: 10px; padding: 16px; border: 1.5px dashed var(--greige-2); border-radius: var(--radius-lg); color: var(--accent-deep); font-weight: 600; font-size: 15px; transition: border-color .2s, background .2s; }
.book__pickdates:hover { border-color: var(--accent); background: var(--accent-soft); }
.book__dates-ok { display: flex; align-items: center; gap: 18px; background: var(--sand); border-radius: var(--radius-lg); padding: 16px 20px; }
.book__dates-ok > div { display: flex; flex-direction: column; }
.book__d-lbl { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }
.book__dates-ok b { font-size: 16px; }
.book__edit { margin-left: auto; font-size: 13px; color: var(--accent-deep); text-decoration: underline; font-weight: 600; }
.field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 16px; }
.field > span { font-size: 13px; font-weight: 600; color: var(--ink-soft); display: inline-flex; align-items: center; gap: 7px; }
.field input, .field textarea { font-family: var(--font-body); font-size: 15px; color: var(--ink); background: var(--ivory); border: 1px solid var(--greige-2); border-radius: var(--radius); padding: 12px 14px; transition: border-color .2s, box-shadow .2s; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.field textarea { resize: vertical; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field--guests { flex-direction: row; align-items: center; justify-content: space-between; background: var(--ivory); border: 1px solid var(--greige-2); border-radius: var(--radius); padding: 10px 16px; }
.field--guests > span { margin: 0; }
.book__quote { background: var(--sand); border-radius: var(--radius-lg); padding: 18px 20px; margin: 6px 0 18px; }
.book__q-row { display: flex; justify-content: space-between; font-size: 14px; color: var(--ink-soft); padding: 5px 0; }
.book__q-tot { border-top: 1px solid var(--greige-2); margin-top: 6px; padding-top: 12px; font-size: 17px; font-weight: 700; color: var(--ink); }
.book__priv { font-size: 12px; color: var(--muted); text-align: center; margin-top: 14px; }
.book__done { text-align: center; padding: 24px 8px; }
.book__done-ic { width: 64px; height: 64px; border-radius: 50%; background: var(--accent-soft); color: var(--accent-deep); display: grid; place-items: center; margin: 0 auto 18px; }
.book__done h3 { font-size: 28px; margin-bottom: 10px; }
.book__done p { color: var(--ink-soft); max-width: 38ch; margin: 0 auto 8px; }
.book__ref { font-size: 14px; margin: 14px 0 20px !important; }

/* ===== Footer =========================================================== */
.footer { background: var(--ink); color: oklch(0.86 0.01 75); padding-top: clamp(56px, 8vw, 96px); }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 48px; }
.footer__logo { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-size: 24px; font-weight: 600; color: #fff; margin-bottom: 14px; }
.footer__logo .hdr__logo-mark { width: 32px; height: 32px; font-size: 18px; }
.footer__brand p { font-size: 14px; opacity: .8; margin-bottom: 12px; max-width: 38ch; }
.footer__disc { font-size: 13px; opacity: .65; border-left: 2px solid var(--accent); padding-left: 12px; }
.footer__col h4 { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: oklch(0.7 0.01 75); margin-bottom: 16px; font-weight: 700; }
.footer__col a, .footer__col span { display: flex; align-items: center; gap: 9px; font-size: 14px; margin-bottom: 11px; color: oklch(0.86 0.01 75); transition: color .2s; }
.footer__col a:hover { color: #fff; }
.footer__col svg { opacity: .7; flex: none; }
.footer__cin { background: oklch(1 0 0 / 0.08); padding: 8px 12px !important; border-radius: var(--radius); font-size: 13px !important; }
.footer__cin b { color: var(--accent-contrast); letter-spacing: 0.05em; }
.footer__links { display: flex; gap: 16px; margin-top: 4px; }
.footer__links a { display: inline; text-decoration: underline; opacity: .8; }
.footer__bottom { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 22px 0 30px; border-top: 1px solid oklch(1 0 0 / 0.1); font-size: 12.5px; opacity: .6; margin-top: 8px; }

/* ===== Cookie banner ==================================================== */
.cookie { position: fixed; left: clamp(16px, 4vw, 32px); right: clamp(16px, 4vw, 32px); bottom: clamp(16px, 4vw, 28px); z-index: 90; max-width: 720px; margin: 0 auto; background: var(--paper); border: 1px solid var(--greige); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 18px 22px; display: flex; align-items: center; gap: 22px; flex-wrap: wrap; animation: cookieUp .4s ease; }
@keyframes cookieUp { from { transform: translateY(20px); opacity: 0; } }
.cookie p { font-size: 14px; color: var(--ink-soft); flex: 1 1 280px; }
.cookie__btns { display: flex; gap: 10px; margin-left: auto; }
.cookie__btns .btn { padding: 10px 18px; font-size: 14px; }

/* ===== Responsive ======================================================= */
@media (max-width: 940px) {
  .hdr__nav, .hdr__cta { display: none; }
  .hdr__burger { display: flex; }
  .hdr__mobile { display: flex; flex-direction: column; gap: 6px; padding: 16px var(--gutter) 24px; background: var(--paper); border-top: 1px solid var(--greige); box-shadow: var(--shadow-md); }
  .hdr__mlink { text-align: left; padding: 13px 4px; font-size: 16px; font-weight: 500; border-bottom: 1px solid var(--greige); }
  .apt__grid, .rates__grid, .zona__grid, .faq__grid, .book__grid { grid-template-columns: 1fr; }
  .apt__media { flex-direction: row; position: static; grid-template-rows: none; grid-template-columns: 1fr 1fr; }
  .apt__media-b { margin-top: 0; width: 100%; }
  .reviews__grid { grid-template-columns: 1fr 1fr; }
  .gallery__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .availw { flex-direction: column; padding: 12px; gap: 4px; }
  .availw__field { border-right: none; border-bottom: 1px solid var(--greige); flex-basis: auto; }
  .availw__field--g { flex-direction: row; align-items: center; justify-content: space-between; }
  .availw__cta { margin: 6px 0 0; width: 100%; }
  .cal__months { grid-template-columns: 1fr; gap: 30px; }
  .reviews__grid, .amenities { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; gap: 28px; }
  .footer__bottom { flex-direction: column; gap: 6px; }
  .hero { padding-bottom: 40px; gap: 28px; }
}

/* ---- Foto reali (quando `src` è presente nella config) ------------------- */
img.phimg { display: block; width: 100%; height: 100%; object-fit: cover; border-radius: inherit; }
.lightbox__img { object-fit: contain; background-color: oklch(0.2 0.01 70); }
