/* ============================================================
   La Casa dei Ricordi — stylesheet
   Palette grounded in the apartment: dusty teal-green (the throw),
   warm sand, oak, soft white, terracotta whisper.
   ============================================================ */
:root{
  --sand:#F5EFE5;
  --sand-2:#ECE3D3;
  --paper:#FFFEFB;
  --teal:#43615A;
  --teal-deep:#324C46;
  --teal-soft:#6E8E86;
  --clay:#C0744E;
  --gold:#B68B55;
  --ink:#26302D;
  --ink-soft:#5C6862;
  --line:rgba(38,48,45,.12);
  --line-2:rgba(38,48,45,.20);
  --shadow:0 18px 50px -28px rgba(38,48,45,.55);
  --shadow-sm:0 8px 24px -16px rgba(38,48,45,.5);
  --r:14px;
  --maxw:1160px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --arch:50% 50% 14px 14px / 26% 26% 4% 4%;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--sand);color:var(--ink);
  font-family:"Mulish",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:clamp(16px,1rem + .15vw,17.5px);line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4{
  font-family:"Fraunces",Georgia,"Times New Roman",serif;
  font-weight:430;line-height:1.08;letter-spacing:-.01em;color:var(--ink);
  margin:0 0 .4em;font-optical-sizing:auto;
}
h1{font-size:clamp(2.5rem,6.2vw,4.4rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.85rem)}
h3{font-size:clamp(1.2rem,1.8vw,1.45rem);font-weight:500}
p{margin:0 0 1rem}
a{color:var(--teal-deep);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
section{padding-block:clamp(64px,9vw,118px)}
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal);margin-bottom:1.1rem;
}
.eyebrow svg{width:20px;height:20px;flex:none}
.eyebrow.on-dark{color:#cfe0da}
.lead{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-soft);max-width:60ch}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--teal-deep);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  background:var(--bg);color:var(--fg);font-weight:700;font-size:.96rem;
  padding:.86rem 1.45rem;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  box-shadow:var(--shadow-sm);white-space:nowrap;
}
.btn svg{width:19px;height:19px}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn.ghost{--bg:transparent;--fg:var(--teal-deep);border-color:var(--line-2);box-shadow:none}
.btn.ghost:hover{background:rgba(67,97,90,.07)}
.btn.light{--bg:#fff;--fg:var(--teal-deep)}
.btn.primary{--bg:var(--teal-deep);--fg:#fff;font-size:1.02rem;padding:.96rem 1.6rem;box-shadow:0 10px 24px rgba(50,76,70,.26)}
.btn.primary:hover{--bg:var(--teal)}
.hero-micro{display:inline-flex;align-items:center;gap:.45rem;margin:.95rem 0 0;font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.hero-micro svg{width:16px;height:16px;color:var(--gold);flex:none}
.btn-row{display:flex;flex-wrap:wrap;gap:.75rem}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(245,239,229,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.site-header.scrolled{border-color:var(--line);background:rgba(245,239,229,.94)}
.nav{display:flex;align-items:center;gap:1.5rem;height:72px}
.brand{display:flex;align-items:center;gap:.62rem;margin-right:auto;color:var(--ink)}
.brand img{width:38px;height:38px}
.brand .txt{display:flex;flex-direction:column;gap:1px}
.brand b{font-family:"Fraunces",serif;font-weight:560;font-size:1.14rem;letter-spacing:-.005em;line-height:1.05;white-space:nowrap;text-transform:none}
.brand .sb{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);font-weight:700;font-family:"Mulish",sans-serif;white-space:nowrap}
.nav-links{display:flex;gap:1.4rem;align-items:center}
.nav-links a{color:var(--ink-soft);font-weight:600;font-size:.92rem;position:relative;padding:.2rem 0;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-right{display:flex;align-items:center;gap:.85rem}
.lang{display:flex;gap:.15rem;background:rgba(255,255,255,.6);border:1px solid var(--line);border-radius:999px;padding:.2rem}
.lang a{font-size:.78rem;font-weight:700;letter-spacing:.04em;color:var(--ink-soft);padding:.28rem .55rem;border-radius:999px;text-transform:uppercase}
.lang a.active{background:var(--teal-deep);color:#fff}
.nav-cta{display:inline-flex}
.burger{display:none;background:none;border:0;cursor:pointer;padding:.4rem;color:var(--ink)}
.burger svg{width:26px;height:26px}

/* ---------- hero ---------- */
.hero{position:relative;padding-top:clamp(28px,4vw,52px)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,60px);align-items:center}
.hero-copy{max-width:36rem}
.hero h1{margin-bottom:.25em}
.hero .lead{margin-bottom:1.7rem}
.facts{display:flex;flex-wrap:wrap;gap:.5rem .55rem;margin:0 0 1.9rem;padding:0;list-style:none}
.facts li{
  display:inline-flex;align-items:center;gap:.42rem;font-size:.84rem;font-weight:700;
  background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.42rem .82rem;color:var(--teal-deep);
}
.facts svg{width:16px;height:16px;color:var(--teal)}
.hero-media{position:relative}
.hero-photo{
  position:relative;border-radius:var(--arch);overflow:hidden;box-shadow:var(--shadow);
  aspect-ratio:4/4.6;background:var(--sand-2);
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-badge{
  position:absolute;left:-18px;bottom:26px;z-index:2;
  background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:.85rem 1.05rem;box-shadow:var(--shadow-sm);max-width:200px;
}
.hero-badge b{font-family:"Fraunces",serif;font-size:1.5rem;display:block;line-height:1;color:var(--teal-deep)}
.hero-badge span{font-size:.74rem;color:var(--ink-soft);font-weight:600}
.booking-links{display:flex;gap:1.1rem;margin-top:1.3rem;flex-wrap:wrap}
.booking-links a{font-size:.82rem;font-weight:700;color:var(--ink-soft);display:inline-flex;align-items:center;gap:.3rem;border-bottom:1.5px solid var(--gold);padding-bottom:1px}
.booking-links a:hover{color:var(--ink)}

/* ---------- highlights ---------- */
.highlights{background:var(--teal-deep);color:#eef4f1}
.highlights .eyebrow{color:#a9c6bd}
.hl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2.2rem}
.hl{padding-right:.5rem}
.hl .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:rgba(255,255,255,.09);margin-bottom:.9rem;color:#dcebe5}
.hl .ic svg{width:23px;height:23px}
.hl h3{color:#fff;font-size:1.12rem;margin-bottom:.3em}
.hl p{color:#bcd0c9;font-size:.92rem;margin:0}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,68px);align-items:center}
.about-media{border-radius:var(--arch);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/4.4}
.about-media img{width:100%;height:100%;object-fit:cover}
.kicker-num{font-family:"Fraunces",serif;color:var(--gold);font-size:1rem;font-weight:600;font-style:italic}

/* ---------- gallery ---------- */
.gallery{background:var(--sand-2)}
.g-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:2.4rem}
.g-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.g-item{position:relative;overflow:hidden;border-radius:12px;cursor:pointer;box-shadow:var(--shadow-sm);background:var(--sand)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.g-item:hover img{transform:scale(1.06)}
.g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(38,48,45,.32));opacity:0;transition:opacity .3s}
.g-item:hover::after{opacity:1}
.g-item .cap{position:absolute;left:12px;bottom:10px;color:#fff;font-size:.8rem;font-weight:700;opacity:0;transform:translateY(6px);transition:.3s;z-index:2;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.g-item:hover .cap{opacity:1;transform:none}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}

/* ---------- rooms ---------- */
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:2.4rem}
.room{background:var(--paper);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease)}
.room:hover{transform:translateY(-4px)}
.room-img{aspect-ratio:16/11;overflow:hidden;background:var(--sand-2)}
.room-img img{width:100%;height:100%;object-fit:cover}
.room-body{padding:1.25rem 1.35rem 1.5rem}
.room-body h3{margin-bottom:.3em}
.room-body p{font-size:.92rem;color:var(--ink-soft);margin:0}
.sleep-note{display:inline-flex;align-items:center;gap:.5rem;margin-top:2.2rem;font-weight:700;color:var(--teal-deep);background:var(--sand-2);border-radius:999px;padding:.55rem 1.1rem;font-size:.9rem}
.sleep-note svg{width:18px;height:18px;color:var(--teal)}

/* ---------- amenities ---------- */
.amenities{background:var(--sand-2)}
.am-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem 2.4rem;margin-top:2.4rem}
.am-col h3{font-size:1.05rem;display:flex;align-items:center;gap:.5rem;margin-bottom:.9rem;padding-bottom:.6rem;border-bottom:1.5px solid var(--line-2)}
.am-col h3 svg{width:20px;height:20px;color:var(--gold)}
.am-col ul{list-style:none;margin:0;padding:0}
.am-col li{display:flex;align-items:flex-start;gap:.55rem;font-size:.92rem;color:var(--ink-soft);padding:.28rem 0}
.am-col li svg{width:16px;height:16px;color:var(--teal);flex:none;margin-top:.28rem}
.am-more{margin-top:2.2rem;font-size:.9rem;color:var(--ink-soft)}
.am-more a{font-weight:700;border-bottom:1.5px solid var(--gold)}

/* ---------- location ---------- */
.loc-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(28px,4vw,56px);align-items:stretch}
.loc-info .addr{font-family:"Fraunces",serif;font-size:1.3rem;color:var(--teal-deep);margin:.2rem 0 1.1rem;font-weight:500}
.near{list-style:none;margin:1.6rem 0 0;padding:0;display:grid;gap:.1rem}
.near li{display:flex;align-items:center;gap:.85rem;padding:.7rem 0;border-bottom:1px solid var(--line)}
.near li:last-child{border-bottom:0}
.near .nm{font-weight:700;color:var(--ink)}
.near .ds{color:var(--ink-soft);font-size:.9rem;margin-left:auto;text-align:right}
.near .ic{width:34px;height:34px;border-radius:9px;background:var(--sand-2);display:grid;place-items:center;color:var(--teal);flex:none}
.near .ic svg{width:18px;height:18px}
.map-frame{border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);min-height:420px;background:var(--sand-2)}
.map-frame iframe{width:100%;height:100%;min-height:420px;border:0;display:block;filter:saturate(.92)}

/* ---------- know ---------- */
.know-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1.3rem;margin-top:2.2rem}
.know{background:var(--paper);border:1px solid var(--line);border-radius:15px;padding:1.2rem 1.3rem}
.know .ic{color:var(--teal);margin-bottom:.6rem}
.know .ic svg{width:24px;height:24px}
.know h3{font-size:.96rem;font-weight:700;font-family:"Mulish",sans-serif;letter-spacing:.01em;margin-bottom:.15em}
.know p{font-size:.88rem;color:var(--ink-soft);margin:0}

/* ---------- contact ---------- */
.contact{background:var(--teal-deep);color:#eef4f1}
.contact .eyebrow{color:#a9c6bd}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.contact h2{color:#fff}
.contact p{color:#c3d6cf}
.contact-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:clamp(1.5rem,3vw,2.4rem)}
.contact-card .row{display:flex;align-items:center;gap:.9rem;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.12);color:#dcebe5;font-weight:600}
.contact-card .row:last-of-type{border-bottom:0}
.contact-card .row svg{width:20px;height:20px;color:#a9c6bd;flex:none}
.contact-card .row a{color:#fff}
.contact-resp{display:flex;align-items:center;gap:.5rem;margin:1rem 0 0;font-size:.86rem;font-weight:600;color:#a9c6bd}
.contact-resp svg{width:18px;height:18px;color:#a9c6bd;flex:none}
.contact-card .btn-row{margin-top:1.4rem}
.host-tag{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.3rem;font-size:.86rem;color:#bcd0c9;white-space:nowrap}
.host-tag svg{width:18px;height:18px;flex:none;color:#a9c6bd}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#c3ccc8;padding-block:clamp(40px,6vw,64px) 28px;font-size:.88rem}
.foot-top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
.foot-brand{display:flex;align-items:center;gap:.6rem;color:#fff}
.foot-brand img{width:34px;height:34px}
.foot-brand b{font-family:"Fraunces",serif;font-size:1.1rem;font-weight:540}
.foot-links{display:flex;gap:1.4rem;flex-wrap:wrap}
.foot-links a{color:#bcc7c2}
.foot-links a:hover{color:#fff}
.foot-bottom{margin-top:2.2rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:#8b9893;font-size:.8rem}
.cin{font-variant-numeric:tabular-nums;letter-spacing:.02em}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;z-index:120;background:rgba(26,33,30,.92);display:none;align-items:center;justify-content:center;padding:3vmin}
.lb.open{display:flex}
.lb img{max-width:94vw;max-height:88vh;border-radius:10px;box-shadow:0 30px 80px -20px rgba(0,0,0,.7)}
.lb button{position:absolute;background:rgba(255,255,255,.14);border:0;color:#fff;width:50px;height:50px;border-radius:50%;cursor:pointer;font-size:1.5rem;display:grid;place-items:center;transition:background .2s}
.lb button:hover{background:rgba(255,255,255,.28)}
.lb .x{top:3vmin;right:3vmin}
.lb .prev{left:2vmin;top:50%;transform:translateY(-50%)}
.lb .next{right:2vmin;top:50%;transform:translateY(-50%)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-grid,.about-grid,.loc-grid,.contact-grid{grid-template-columns:1fr}
  .hero-media{max-width:520px;margin-inline:auto;order:-1}
  .about-media{max-width:520px}
  .hl-grid,.am-grid{grid-template-columns:repeat(2,1fr)}
  .rooms-grid{grid-template-columns:1fr 1fr}
  .g-grid{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:961px) and (max-width:1120px){
  .brand .sb{display:none}
  .brand b{font-size:1.04rem}
  .nav{gap:1rem}
  .nav-links{gap:1.05rem}
  .nav-links a{font-size:.87rem}
  .nav-right{gap:.6rem}
  .nav-cta{display:none}
}
@media (max-width:960px){
  .nav-links,.nav-cta{display:none}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--paper);padding:1.2rem clamp(20px,5vw,40px) 1.6rem;gap:1rem;box-shadow:var(--shadow);border-top:1px solid var(--line)}
  .nav-links.open a{font-size:1.05rem}
  .burger{display:block}
}
@media (max-width:560px){
  .hl-grid,.rooms-grid,.am-grid{grid-template-columns:1fr}
  .g-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .g-wide{grid-column:span 2}
  .hero-badge{left:8px}
  .foot-bottom{flex-direction:column}
}
@media (max-width:560px){
  .nav{height:64px;gap:.5rem}
  .brand img{width:32px;height:32px}
  .brand b{font-size:.95rem;letter-spacing:-.01em}
  .brand .sb{display:none}
  .lang{padding:.15rem}
  .lang a{padding:.26rem .44rem;font-size:.72rem;letter-spacing:.02em}
  .burger{padding:.3rem}
}
@media (max-width:360px){
  .nav{padding-inline:14px;gap:.4rem}
  .brand img{width:28px;height:28px}
  .brand b{font-size:.82rem}
  .lang{padding:.12rem}
  .lang a{padding:.22rem .34rem;font-size:.68rem}
}

/* ---------- availability calendar ---------- */
.availability{background:var(--sand-2)}
.book-direct{margin:1.5rem 0 1.9rem}
.bd-title{display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:var(--teal);margin-bottom:.8rem}
.bd-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
.bd-item{display:flex;align-items:flex-start;gap:.75rem;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:.85rem 1rem}
.bd-ic{flex:none;width:38px;height:38px;border-radius:10px;background:rgba(67,97,90,.1);color:var(--teal-deep);display:flex;align-items:center;justify-content:center}
.bd-ic svg{width:20px;height:20px}
.bd-txt strong{display:block;font-size:.95rem;color:var(--ink);font-weight:800;line-height:1.2}
.bd-txt span{font-size:.82rem;color:var(--ink-soft)}
@media(max-width:680px){.bd-grid{grid-template-columns:1fr}}
/* families */
.families{background:var(--paper)}
.fam-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:1.7rem}
.fam-item{background:var(--sand);border:1px solid var(--line);border-radius:16px;padding:1.4rem}
.fam-item .ic{width:46px;height:46px;border-radius:12px;background:var(--paper);color:var(--teal-deep);display:flex;align-items:center;justify-content:center;margin-bottom:.9rem;border:1px solid var(--line)}
.fam-item .ic svg{width:24px;height:24px}
.fam-item h3{margin:0 0 .35rem;font-size:1.04rem}
.fam-item p{margin:0;color:var(--ink-soft);font-size:.9rem;line-height:1.55}
@media(max-width:900px){.fam-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.fam-grid{grid-template-columns:1fr}}
.cal-root{max-width:720px;margin-top:2.4rem}
.cal-loading{color:var(--ink-soft)}
.cal{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:clamp(1rem,2.5vw,1.6rem);box-shadow:var(--shadow-sm)}
.cal-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.1rem}
.cal-nav{width:38px;height:38px;border-radius:50%;border:1px solid var(--line-2);background:#fff;cursor:pointer;font-size:1.25rem;color:var(--teal-deep);display:grid;place-items:center;transition:background .2s;flex:none}
.cal-nav:hover:not(:disabled){background:var(--sand)}
.cal-nav:disabled{opacity:.32;cursor:default}
.cal-legend{display:flex;gap:1.1rem;font-size:.8rem;color:var(--ink-soft)}
.cal-leg{display:inline-flex;align-items:center;gap:.42rem}
.cal-dot{width:12px;height:12px;border-radius:3px;display:inline-block;flex:none}
.dot-free{background:#fff;border:1.5px solid var(--teal-soft)}
.dot-booked{background:repeating-linear-gradient(135deg,var(--sand-2),var(--sand-2) 3px,#fff 3px,#fff 6px);border:1.5px solid var(--line-2)}
.cal-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.cal-mtitle{font-family:"Fraunces",serif;font-size:1.05rem;font-weight:500;text-align:center;margin-bottom:.6rem;color:var(--teal-deep)}
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:5px}
.cal-week span{text-align:center;font-size:.64rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-soft)}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-pad{aspect-ratio:1}
.cal-day{aspect-ratio:1;border:0;background:transparent;border-radius:9px;font:inherit;font-size:.85rem;font-weight:600;color:var(--ink);cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s}
.cal-day.is-free:hover{background:var(--sand)}
.cal-day.is-past{color:var(--line-2);cursor:default}
.cal-day.is-booked{color:var(--ink-soft);cursor:not-allowed;background:repeating-linear-gradient(135deg,var(--sand-2),var(--sand-2) 4px,#fff 4px,#fff 8px);text-decoration:line-through;opacity:.65}
.cal-day.is-in{background:var(--sand-2);border-radius:0}
.cal-day.is-sel{background:var(--teal-deep);color:#fff}
.cal-day.is-in + .cal-day.is-end{}
.cal-sel{margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--line);min-height:46px;display:flex;flex-direction:column;align-items:stretch;gap:.9rem}
.cal-hint{margin:0;color:var(--ink-soft);font-size:.92rem}
.cal-sel-info{display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap}
.cal-sel-info strong{font-family:"Fraunces",serif;font-size:1.18rem;color:var(--teal-deep)}
.cal-sel-n{font-size:.8rem;color:var(--ink-soft);font-weight:700}
.cal-guests-wrap{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.55rem}
.cal-guests{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.cal-guests-label{font-weight:700;color:var(--ink);font-size:.92rem}
.cal-stepper{display:flex;align-items:center;gap:.2rem;background:var(--paper);border:1px solid var(--line-2);border-radius:999px;padding:.2rem}
.cal-step{width:30px;height:30px;border:0;border-radius:999px;background:var(--sand-2);color:var(--teal-deep);font-size:1.1rem;font-weight:700;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center}
.cal-step:hover{background:var(--teal-deep);color:#fff}
.cal-gval{min-width:1.6rem;text-align:center;font-weight:700;color:var(--ink)}
.cal-sel-act{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.cal-req{flex:1 1 auto;min-width:200px}
.cal-reset{padding:.62rem 1.1rem}
.cal-email{font-size:.85rem;font-weight:700;color:var(--teal-deep);border-bottom:1.5px solid var(--gold);align-self:flex-start;padding-bottom:1px}
.cal-email:hover{color:var(--ink)}
.cal-ack{display:flex;align-items:center;gap:.6rem;background:rgba(67,97,90,.09);border:1px solid var(--teal-soft);border-radius:14px;padding:.9rem 1.1rem;color:var(--teal-deep);font-weight:600;font-size:.95rem}
.cal-ack svg{color:var(--teal);flex:none}
.cal-updated{margin:.9rem 0 0;font-size:.72rem;color:var(--ink-soft);text-align:right}
.cal-how{margin-top:1.6rem}
.cal-how-title{margin:0 0 .7rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:800;color:var(--teal)}
.cal-steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;counter-reset:step}
.cal-steps li{display:flex;align-items:center;gap:.6rem;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:.7rem .85rem;font-size:.86rem;font-weight:600;color:var(--ink)}
.cal-steps .n{flex:none;width:26px;height:26px;border-radius:999px;background:var(--teal-deep);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:800}
.cal-disclaimer{margin-top:1.4rem;font-size:.8rem;color:var(--ink-soft);max-width:720px}
.cal-fallback{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:1.6rem;display:flex;flex-direction:column;gap:1.1rem;align-items:flex-start;max-width:520px;box-shadow:var(--shadow-sm);margin-top:2.4rem}
.cal-fallback p{margin:0;color:var(--ink-soft)}
/* ---------- booking form ---------- */
.cal-form{display:flex;flex-direction:column;gap:.75rem}
.cal-field{display:flex;flex-direction:column;gap:.32rem}
.cal-label{font-size:.82rem;font-weight:700;color:var(--ink-soft);letter-spacing:.01em}
.cal-input{font:inherit;font-size:.95rem;color:var(--ink);background:var(--paper);border:1.5px solid var(--line-2);border-radius:10px;padding:.65rem .85rem;width:100%;box-sizing:border-box;outline:none;transition:border-color .2s,box-shadow .2s}
.cal-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(67,97,90,.12)}
.cal-textarea{resize:vertical;min-height:120px;line-height:1.6}
.cal-form-err{margin:0;font-size:.82rem;font-weight:600;color:var(--clay);min-height:1.2em}
@media (max-width:760px){
  .cal-steps{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .cal-grid{grid-template-columns:1fr;gap:1.6rem}
  .cal-day{font-size:.92rem}
  .cal-req{width:100%}
}
