/* =====================================================================
   Ελευθερία Ζαπαντιώτη, Δικηγόρος (Αγρίνιο)
   Design system: deep legal navy + brass + warm paper.
   Display: Cormorant Garamond (serif). Body: Alegreya Sans.
   ===================================================================== */

:root{
  --navy:#0e2740;
  --navy-2:#0a1d31;     /* darker: footer / cta band */
  --navy-3:#16395b;     /* lighter navy panel */
  --cream:#f6f0e4;      /* page background */
  --cream-2:#fbf6ec;    /* light card */
  --paper:#fffdf8;      /* white-ish card */
  --ink:#1c2733;        /* main text on light */
  --ink-2:#48555f;      /* muted text on light */
  --brass:#b88a3d;      /* brass: borders / decoration / fills */
  --brass-bright:#d6ac5b;/* brass text on navy */
  --brass-deep:#7c591d; /* brass text on cream (contrast-safe) */
  --on-navy:#f2ebdc;    /* text on navy */
  --on-navy-mut:#b3c1d1;/* muted text on navy */
  --line:rgba(14,39,64,.14);
  --line-2:rgba(14,39,64,.07);
  --line-gold:rgba(184,138,61,.34);
  --shadow:0 18px 50px -28px rgba(10,29,49,.5);
  --shadow-sm:0 8px 26px -18px rgba(10,29,49,.45);
  --r:13px;
  --maxw:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Alegreya Sans','Helvetica Neue',system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  font-size:18px;
  line-height:1.68;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

h1,h2,h3,h4{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-weight:600;
  line-height:1.08;
  letter-spacing:.2px;
  margin:0 0 .5em;
  color:var(--navy);
}
h1{font-size:clamp(2.5rem,6vw,4.1rem);font-weight:600;}
h2{font-size:clamp(2rem,4.2vw,3rem);}
h3{font-size:1.5rem;}
p{margin:0 0 1.1em;}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ---------- shared helpers ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:'Alegreya Sans',sans-serif;
  font-weight:700;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass-deep);
  margin:0 0 1.1rem;
}
.eyebrow::before{content:"";width:30px;height:1.5px;background:var(--brass);display:inline-block;}
.eyebrow.is-light{color:var(--brass-bright);}
.eyebrow.is-light::before{background:var(--brass-bright);}
.eyebrow.centered{justify-content:center;}

.lead{font-size:1.22rem;color:var(--ink-2);max-width:60ch;}
.section{padding:clamp(64px,8vw,108px) 0;}
.section--cream{background:var(--cream);}
.section--paper{background:var(--paper);}
.section--tint{background:linear-gradient(180deg,var(--cream-2),var(--cream));}
.section--navy{background:var(--navy);color:var(--on-navy);}
.section--navy h1,.section--navy h2,.section--navy h3,.section--navy h4{color:var(--on-navy);}
.section--navy .lead{color:var(--on-navy-mut);}
.section-head{max-width:62ch;}
.section-head.centered{margin:0 auto;text-align:center;}
.divider-gold{width:54px;height:2px;background:var(--brass);border:0;margin:0 0 1.4rem;}
.centered .divider-gold{margin-left:auto;margin-right:auto;}

/* ---------- buttons ---------- */
.btn{
  --pad-y:.92em;--pad-x:1.5em;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:'Alegreya Sans',sans-serif;
  font-weight:700;font-size:.97rem;letter-spacing:.02em;line-height:1.1;
  padding:var(--pad-y) var(--pad-x);
  border-radius:11px;
  border:1.6px solid transparent;
  cursor:pointer;
  transition:transform .18s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease;
  white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em;flex:0 0 auto;}
.btn--gold{background:var(--brass);color:#13243a;border-color:var(--brass);box-shadow:0 10px 24px -14px rgba(184,138,61,.9);}
.btn--gold:hover{background:#c89a4c;transform:translateY(-2px);}
.btn--navy{background:var(--navy);color:var(--on-navy);border-color:var(--navy);}
.btn--navy:hover{background:#16395b;transform:translateY(-2px);}
.btn--primary{background:var(--navy);color:var(--on-navy);border-color:var(--navy);}
.btn--primary:hover{background:#16395b;transform:translateY(-2px);}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--line);}
.btn--ghost:hover{border-color:var(--brass);color:var(--brass-deep);transform:translateY(-2px);}
.btn--ghost-light{background:transparent;color:var(--on-navy);border-color:rgba(242,235,220,.4);}
.btn--ghost-light:hover{border-color:var(--brass-bright);color:var(--brass-bright);transform:translateY(-2px);}
.btn--block{width:100%;}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:var(--cream);box-shadow:0 1px 0 var(--line-2);}
.topbar{background:var(--navy-2);color:var(--on-navy-mut);font-size:.82rem;}
.topbar-in{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:38px;}
.tb-left{display:flex;align-items:center;gap:22px;flex-wrap:wrap;}
.topbar a{display:inline-flex;align-items:center;gap:.5em;color:var(--on-navy-mut);transition:color .2s;}
.topbar a:hover{color:var(--brass-bright);}
.topbar svg{width:14px;height:14px;color:var(--brass-bright);}
.tb-right{display:inline-flex;align-items:center;gap:.5em;color:var(--brass-bright);font-weight:700;letter-spacing:.04em;}
.tb-right svg{width:14px;height:14px;}

.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:78px;}
.brand{display:inline-flex;align-items:center;gap:13px;}
.brand img{width:46px;height:46px;}
.brand-tx{display:flex;flex-direction:column;line-height:1.05;}
.brand-tx b{font-family:'Cormorant Garamond',serif;font-weight:700;font-size:1.5rem;color:var(--navy);letter-spacing:.2px;}
.brand-tx small{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-2);font-weight:600;}

.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0;}
.nav-links a:not(.btn){
  position:relative;font-weight:600;font-size:.98rem;color:var(--ink);padding:6px 0;transition:color .2s;
}
.nav-links a:not(.btn)::after{
  content:"";position:absolute;left:0;right:0;bottom:-3px;height:1.6px;
  background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .26s ease;
}
.nav-links a:not(.btn):hover{color:var(--brass-deep);}
.nav-links a:not(.btn):hover::after,
.nav-links a:not(.btn).active::after{transform:scaleX(1);}
.nav-links a:not(.btn).active{color:var(--navy);}
.nl-cta{margin-left:6px;}

.nav-toggle{display:none;background:transparent;border:1.4px solid var(--line);border-radius:10px;padding:8px;color:var(--navy);cursor:pointer;}
.nav-toggle svg{width:22px;height:22px;}

/* ---------- hero (home) ---------- */
.hero{
  position:relative;color:var(--on-navy);
  background-color:var(--navy-2);
  background-image:linear-gradient(98deg,rgba(8,21,35,.95) 0%,rgba(8,21,35,.84) 44%,rgba(11,32,54,.5) 100%),url('images/office-desk.jpg');
  background-size:cover;background-position:center right;
}
.hero-in{padding:clamp(80px,12vw,150px) 0 clamp(64px,9vw,120px);max-width:760px;}
.hero h1{color:#fff;margin-bottom:.32em;}
.hero h1 em{font-style:italic;color:var(--brass-bright);font-weight:600;}
.hero-sub{font-size:1.25rem;color:var(--on-navy);opacity:.93;max-width:54ch;margin-bottom:1.9rem;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:2.2rem;}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px 26px;font-size:.92rem;color:var(--on-navy-mut);padding-top:1.4rem;border-top:1px solid rgba(242,235,220,.16);max-width:54ch;}
.hero-meta span{display:inline-flex;align-items:center;gap:.5em;}
.hero-meta svg{width:15px;height:15px;color:var(--brass-bright);}

/* ---------- page hero (inner pages) ---------- */
.page-hero{background:var(--navy);color:var(--on-navy);padding:clamp(58px,8vw,96px) 0 clamp(50px,7vw,78px);position:relative;overflow:hidden;}
.page-hero::after{content:"";position:absolute;right:-120px;top:-80px;width:360px;height:360px;border:1.5px solid rgba(214,172,91,.18);border-radius:50%;}
.page-hero::before{content:"";position:absolute;right:-40px;bottom:-160px;width:300px;height:300px;border:1.5px solid rgba(214,172,91,.12);border-radius:50%;}
.page-hero .container{position:relative;z-index:1;}
.page-hero h1{color:#fff;max-width:18ch;}
.page-hero p{color:var(--on-navy-mut);font-size:1.16rem;max-width:60ch;margin-bottom:0;}
.crumb{display:flex;gap:.5em;font-size:.82rem;letter-spacing:.04em;color:var(--on-navy-mut);margin-bottom:1.3rem;}
.crumb a:hover{color:var(--brass-bright);}
.crumb span{color:var(--brass-bright);}

/* ---------- trust bar ---------- */
.trust-bar{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line-2);
  border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);margin-top:-46px;position:relative;z-index:5;
}
.trust-item{background:var(--paper);padding:26px 24px;display:flex;gap:14px;align-items:flex-start;}
.trust-ic{flex:0 0 auto;width:40px;height:40px;border-radius:10px;background:rgba(184,138,61,.12);display:flex;align-items:center;justify-content:center;}
.trust-ic svg{width:21px;height:21px;color:var(--brass-deep);}
.trust-item b{display:block;font-family:'Cormorant Garamond',serif;font-size:1.32rem;color:var(--navy);line-height:1.1;}
.trust-item span{font-size:.9rem;color:var(--ink-2);}

/* ---------- intro / split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,72px);align-items:center;}
.split.flip .split-media{order:-1;}
.split-media{position:relative;}
.split-media img{width:100%;height:100%;object-fit:cover;border-radius:var(--r);box-shadow:var(--shadow);}
.framed{position:relative;}
.framed::after{content:"";position:absolute;inset:14px -14px -14px 14px;border:1.5px solid var(--line-gold);border-radius:var(--r);z-index:-1;}
.stat-chip{position:absolute;left:-18px;bottom:24px;background:var(--navy);color:var(--on-navy);padding:16px 22px;border-radius:12px;box-shadow:var(--shadow);max-width:220px;}
.stat-chip b{font-family:'Cormorant Garamond',serif;color:var(--brass-bright);font-size:2rem;display:block;line-height:1;}
.stat-chip span{font-size:.82rem;color:var(--on-navy-mut);}

/* ---------- feature cards (real photos) ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.feature-card{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .22s ease,box-shadow .22s ease;}
.feature-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.feature-card .fc-img{aspect-ratio:3/2;overflow:hidden;background:var(--navy-3);}
.feature-card .fc-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.96);}
.feature-card .fc-body{padding:26px 26px 30px;}
.feature-card h3{margin-bottom:.35em;}
.feature-card p{color:var(--ink-2);margin:0;font-size:.99rem;}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;counter-reset:s;}
.step{position:relative;padding-top:8px;}
.step .num{font-family:'Cormorant Garamond',serif;font-size:2.6rem;color:var(--brass-deep);line-height:1;display:block;margin-bottom:.3em;}
.section--navy .step .num{color:var(--brass-bright);}
.step h3{font-size:1.28rem;}
.section--navy .step h3{color:#fff;font-size:1.28rem;}
.section--navy .step p{color:var(--on-navy-mut);font-size:.97rem;margin:0;}
.step::before{content:"";position:absolute;top:20px;left:48px;right:-20px;height:1px;background:rgba(214,172,91,.28);}
.steps .step:last-child::before{display:none;}

/* ---------- service cards (text) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.svc-card{background:var(--paper);border:1px solid var(--line-2);border-top:3px solid var(--brass);border-radius:var(--r);padding:32px 30px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.svc-card .kicker{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-deep);font-weight:700;}
.svc-card h3{margin:.5em 0 .45em;color:var(--navy);}
.svc-card p{color:var(--ink-2);font-size:1rem;}
.svc-card ul{list-style:none;margin:.6em 0 0;padding:0;}
.svc-card li{position:relative;padding-left:1.7em;margin-bottom:.5em;font-size:.97rem;color:var(--ink);}
.svc-card li::before{content:"";position:absolute;left:0;top:.62em;width:9px;height:9px;border:1.6px solid var(--brass);border-bottom:none;border-left:none;transform:rotate(45deg);}
.svc-card .more{display:inline-flex;align-items:center;gap:.45em;margin-top:1.1em;font-weight:700;font-size:.94rem;color:var(--brass-deep);}
.svc-card .more svg{width:1em;height:1em;transition:transform .2s;}
.svc-card:hover .more svg{transform:translateX(4px);}

/* ---------- map block ---------- */
.map-card{display:grid;grid-template-columns:1fr 1.25fr;gap:0;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--paper);}
.map-info{padding:clamp(30px,4vw,48px);}
.map-info h3{font-size:1.9rem;}
.map-row{display:flex;gap:13px;align-items:flex-start;margin-bottom:1.05rem;}
.map-row svg{width:20px;height:20px;color:var(--brass-deep);flex:0 0 auto;margin-top:3px;}
.map-row b{display:block;color:var(--navy);font-size:1.02rem;}
.map-row span,.map-row a{color:var(--ink-2);font-size:.97rem;}
.map-row a:hover{color:var(--brass-deep);}
.map-embed{min-height:340px;background:var(--navy-3);}
.map-embed iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:grayscale(.2) contrast(1.02);}
.map-tall{min-height:300px;height:100%;border-radius:var(--r);overflow:hidden;border:1px solid var(--line-2);background:var(--navy-3);box-shadow:var(--shadow-sm);}
.map-tall iframe{width:100%;height:100%;min-height:480px;border:0;display:block;filter:grayscale(.2) contrast(1.02);}

/* ---------- cta band ---------- */
.cta-band{background:var(--navy-2);color:var(--on-navy);text-align:center;position:relative;overflow:hidden;}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 360px at 50% -30%,rgba(214,172,91,.16),transparent 70%);}
.cta-band .container{position:relative;z-index:1;}
.cta-band h2{color:#fff;}
.cta-band p{color:var(--on-navy-mut);max-width:56ch;margin:0 auto 1.9rem;font-size:1.16rem;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ---------- footer ---------- */
.site-footer{background:var(--navy-2);color:var(--on-navy-mut);padding:72px 0 30px;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:1.1rem;}
.footer-brand img{width:44px;height:44px;}
.footer-brand span{display:flex;flex-direction:column;line-height:1.1;font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--on-navy);}
.footer-brand small{font-family:'Alegreya Sans',sans-serif;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--on-navy-mut);font-weight:600;}
.f-brand-col p{font-size:.95rem;color:var(--on-navy-mut);max-width:36ch;}
.f-cert{display:inline-flex;align-items:center;gap:.55em;margin-top:.4rem;font-size:.84rem;color:var(--brass-bright);font-weight:700;}
.f-cert svg{width:15px;height:15px;}
.footer-col h4{font-family:'Alegreya Sans',sans-serif;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--on-navy);margin-bottom:1.1rem;font-weight:800;}
.footer-col ul{list-style:none;margin:0;padding:0;}
.footer-col li{margin-bottom:.6rem;}
.footer-col a{color:var(--on-navy-mut);font-size:.96rem;transition:color .2s;}
.footer-col a:hover{color:var(--brass-bright);}
.f-contact .row{display:flex;gap:10px;align-items:flex-start;margin-bottom:.8rem;font-size:.95rem;color:var(--on-navy-mut);}
.f-contact .row svg{width:17px;height:17px;color:var(--brass-bright);flex:0 0 auto;margin-top:3px;}
.f-contact a{color:var(--on-navy-mut);}
.f-contact a:hover{color:var(--brass-bright);}
.footer-bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:48px;padding-top:24px;border-top:1px solid rgba(242,235,220,.12);font-size:.82rem;color:var(--on-navy-mut);}

/* ---------- prose (story / pension pages) ---------- */
.prose{max-width:70ch;}
.prose p{color:var(--ink);font-size:1.08rem;}
.prose h2{margin-top:1.8em;}
.prose h3{margin-top:1.4em;color:var(--navy);}
.pull{border-left:3px solid var(--brass);padding:6px 0 6px 24px;margin:2rem 0;font-family:'Cormorant Garamond',serif;font-size:1.7rem;line-height:1.3;color:var(--navy);font-style:italic;}
.note-box{background:var(--cream-2);border:1px solid var(--line-2);border-left:3px solid var(--brass);border-radius:10px;padding:20px 24px;margin:1.6rem 0;font-size:.98rem;color:var(--ink-2);}
.note-box strong{color:var(--navy);}

/* ---------- bullets / value list (text + check) ---------- */
.check-list{list-style:none;margin:1.2rem 0 0;padding:0;display:grid;gap:.9rem;}
.check-list li{position:relative;padding-left:2.1em;color:var(--ink);font-size:1.04rem;}
.check-list li svg{position:absolute;left:0;top:.18em;width:1.25em;height:1.25em;color:var(--brass-deep);}
.section--navy .check-list li{color:var(--on-navy);}
.section--navy .check-list li svg{color:var(--brass-bright);}

/* ---------- faq ---------- */
.faq{max-width:820px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--line);padding:24px 0;}
.faq-item h3{font-size:1.32rem;margin-bottom:.4em;display:flex;gap:.5em;}
.faq-item h3 span{color:var(--brass-deep);font-family:'Alegreya Sans',sans-serif;font-weight:800;font-size:1rem;}
.faq-item p{color:var(--ink-2);margin:0;}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,4vw,56px);align-items:start;}
.info-card{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r);padding:34px;box-shadow:var(--shadow-sm);}
.info-card .row{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line-2);}
.info-card .row:last-child{border-bottom:0;}
.info-card .row .ic{width:42px;height:42px;border-radius:10px;background:rgba(184,138,61,.12);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.info-card .row .ic svg{width:20px;height:20px;color:var(--brass-deep);}
.info-card .row b{display:block;color:var(--navy);font-size:1.04rem;}
.info-card .row a,.info-card .row span{color:var(--ink-2);font-size:.99rem;overflow-wrap:anywhere;}
.info-card .row a:hover{color:var(--brass-deep);}
.hours-table{width:100%;border-collapse:collapse;margin-top:.4rem;}
.hours-table td{padding:8px 0;border-bottom:1px solid var(--line-2);font-size:.98rem;color:var(--ink);}
.hours-table td:last-child{text-align:right;color:var(--ink-2);}
.hours-table tr.today td{color:var(--brass-deep);font-weight:700;}

/* ===================================================================
   BOOKING (rantevou) — Calendly-style
   =================================================================== */
.booking-shell{display:grid;grid-template-columns:320px 1fr;gap:0;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);background:var(--paper);}
.booking-aside{background:var(--navy);color:var(--on-navy);padding:34px 30px;}
.ba-brand{display:flex;align-items:center;gap:11px;font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:#fff;margin-bottom:1.5rem;}
.ba-brand img{width:40px;height:40px;}
.ba-line{display:flex;gap:13px;align-items:flex-start;margin-bottom:1.15rem;}
.ba-line svg{width:20px;height:20px;color:var(--brass-bright);flex:0 0 auto;margin-top:2px;}
.ba-line strong{display:block;color:#fff;font-size:1rem;}
.ba-line div{font-size:.88rem;color:var(--on-navy-mut);}
.ba-summary{margin-top:1.4rem;padding-top:1.4rem;border-top:1px solid rgba(242,235,220,.15);}
.ba-summary .row{display:flex;justify-content:space-between;gap:12px;margin-bottom:.6rem;font-size:.92rem;}
.ba-summary .row span{color:var(--on-navy-mut);}
.ba-summary .row b{color:var(--brass-bright);text-align:right;}
.ba-sel{margin-top:1.5rem;font-size:.8rem;color:var(--on-navy-mut);background:rgba(255,255,255,.05);border-radius:9px;padding:13px 15px;line-height:1.5;}

.booking-main{padding:clamp(26px,3.5vw,40px);}
.steps-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1.8rem;}
.steps-bar .pill{display:inline-flex;align-items:center;gap:.5em;font-size:.82rem;font-weight:600;color:var(--ink-2);padding:6px 13px;border-radius:9px;background:var(--cream-2);border:1px solid var(--line-2);}
.steps-bar .pill .dot{width:8px;height:8px;border-radius:50%;background:var(--line);}
.steps-bar .pill.active{color:var(--navy);border-color:var(--line-gold);background:rgba(184,138,61,.1);}
.steps-bar .pill.active .dot{background:var(--brass);}
.steps-bar .pill.done .dot{background:var(--brass);}

.bk-step{display:none;animation:fade .35s ease;}
.bk-step.active{display:block;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.bk-step h2{font-size:1.7rem;}
.bk-step .sub{color:var(--ink-2);margin-bottom:1.4rem;font-size:1rem;}

.svc-list{display:grid;gap:12px;}
.svc{display:flex;align-items:center;gap:16px;width:100%;text-align:left;background:var(--paper);border:1.5px solid var(--line);border-radius:12px;padding:16px 18px;cursor:pointer;transition:border-color .18s,transform .18s,box-shadow .18s;font-family:inherit;}
.svc:hover{border-color:var(--brass);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.svc.sel{border-color:var(--brass);background:rgba(184,138,61,.07);}
.svc .ic{width:46px;height:46px;border-radius:10px;background:var(--navy);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.svc .ic svg{width:22px;height:22px;color:var(--brass-bright);}
.svc .meta{flex:1;}
.svc .meta b{display:block;color:var(--navy);font-size:1.05rem;}
.svc .meta span{font-size:.88rem;color:var(--ink-2);}
.svc .pr{text-align:right;font-size:.85rem;color:var(--ink-2);}
.svc .pr b{display:block;color:var(--brass-deep);font-family:'Cormorant Garamond',serif;font-size:1.4rem;}

.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.cal-head .mname{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--navy);}
.cal-nav{display:flex;gap:8px;}
.cal-nav button{width:38px;height:38px;border-radius:9px;border:1.5px solid var(--line);background:var(--paper);color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.cal-nav button:hover:not(:disabled){border-color:var(--brass);color:var(--brass-deep);}
.cal-nav button:disabled{opacity:.35;cursor:not-allowed;}
.cal-nav svg{width:18px;height:18px;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:7px;}
.cal-grid .dow{text-align:center;font-size:.72rem;font-weight:700;letter-spacing:.05em;color:var(--ink-2);text-transform:uppercase;padding:6px 0;}
.cal-day{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:.96rem;font-weight:600;color:var(--ink);border:1.5px solid transparent;}
.cal-day.empty{visibility:hidden;}
.cal-day.off{color:#b9b0a0;background:var(--cream-2);}
.cal-day.free{cursor:pointer;background:var(--paper);border-color:var(--line);color:var(--navy);transition:all .16s;}
.cal-day.free:hover{border-color:var(--brass);background:rgba(184,138,61,.08);transform:translateY(-2px);}
.cal-day.free .ndots{position:absolute;bottom:6px;left:0;right:0;display:flex;gap:3px;justify-content:center;}
.cal-day.free .ndots i{width:4px;height:4px;border-radius:50%;background:var(--brass);}
.cal-day.sel{background:var(--navy);color:#fff;border-color:var(--navy);}
.cal-day.sel .ndots i{background:var(--brass-bright);}
.cal-legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px;font-size:.82rem;color:var(--ink-2);}
.cal-legend span{display:inline-flex;align-items:center;gap:.5em;}
.cal-legend i{width:13px;height:13px;border-radius:4px;display:inline-block;}
.cal-legend .l-free{background:var(--paper);border:1.5px solid var(--line);}
.cal-legend .l-sel{background:var(--navy);}
.cal-legend .l-off{background:var(--cream-2);border:1.5px solid var(--line-2);}

.slot-head{display:flex;align-items:center;gap:14px;margin-bottom:1.3rem;}
.slot-head .back{width:40px;height:40px;border-radius:9px;border:1.5px solid var(--line);background:var(--paper);color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.slot-head .back:hover{border-color:var(--brass);color:var(--brass-deep);}
.slot-head .back svg{width:18px;height:18px;}
.slot-head .dsel{font-size:.9rem;color:var(--ink-2);}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;}
.slot{padding:13px 8px;border:1.5px solid var(--line);border-radius:10px;background:var(--paper);color:var(--navy);font-weight:700;font-size:.98rem;cursor:pointer;transition:all .16s;font-family:inherit;}
.slot:hover{border-color:var(--brass);background:rgba(184,138,61,.08);transform:translateY(-2px);}
.slot.sel{background:var(--navy);color:#fff;border-color:var(--navy);}
.slots-empty{padding:30px;text-align:center;color:var(--ink-2);background:var(--cream-2);border-radius:12px;}

.field{margin-bottom:1.1rem;}
.field label{display:block;font-weight:700;font-size:.9rem;color:var(--navy);margin-bottom:.4rem;}
.field input,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:1rem;color:var(--ink);background:var(--cream-2);transition:border-color .18s;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brass);background:var(--paper);}
.field .hint{font-size:.82rem;color:var(--ink-2);margin-top:.4rem;}
.demo-badge{display:flex;gap:.6em;align-items:flex-start;background:var(--cream-2);border:1px solid var(--line-2);border-left:3px solid var(--brass);border-radius:9px;padding:13px 15px;font-size:.86rem;color:var(--ink-2);margin:1.2rem 0;}
.demo-badge svg{width:18px;height:18px;color:var(--brass-deep);flex:0 0 auto;margin-top:1px;}
.form-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:.6rem;}

.confirm{text-align:center;max-width:520px;margin:0 auto;padding:10px 0;}
.confirm .check{width:74px;height:74px;border-radius:50%;background:rgba(184,138,61,.14);display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;}
.confirm .check svg{width:38px;height:38px;color:var(--brass-deep);}
.confirm .sub{color:var(--ink-2);margin-bottom:1.6rem;}
.recap{text-align:left;background:var(--cream-2);border:1px solid var(--line-2);border-radius:12px;padding:22px 24px;margin-bottom:1.6rem;}
.recap .row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:.96rem;}
.recap .row:last-child{border-bottom:0;}
.recap .row span{color:var(--ink-2);}
.recap .row b{color:var(--navy);text-align:right;}
.confirm .note{font-size:.84rem;color:var(--ink-2);}

/* ---------- reveal ---------- */
.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease;}
.js .reveal.in{opacity:1;transform:none;}
.js .reveal.d1{transition-delay:.08s;}
.js .reveal.d2{transition-delay:.16s;}
.js .reveal.d3{transition-delay:.24s;}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none;}}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .feature-grid{grid-template-columns:1fr 1fr;}
  .steps{grid-template-columns:1fr 1fr;}
  .step::before{display:none;}
  .map-card{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .split{grid-template-columns:1fr;gap:36px;}
  .split.flip .split-media{order:0;}
  .stat-chip{left:16px;}
}
@media (max-width:860px){
  .nav-toggle{display:inline-flex;}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:4px;
    background:var(--cream);padding:14px 24px 22px;
    box-shadow:0 16px 30px -18px rgba(10,29,49,.5);
    border-top:1px solid var(--line-2);
    display:none;
  }
  .nav-links.open{display:flex;}
  .nav-links a:not(.btn){padding:11px 4px;border-bottom:1px solid var(--line-2);}
  .nav-links a:not(.btn)::after{display:none;}
  .nl-cta{margin:10px 0 0;}
  .nav-links .btn{width:100%;}
  .trust-bar{grid-template-columns:1fr 1fr;}
}
@media (max-width:680px){
  body{font-size:17px;}
  .topbar{display:none;}
  .booking-shell{grid-template-columns:1fr;}
  .booking-aside{display:none;}
  .trust-bar{grid-template-columns:1fr;margin-top:-30px;}
  .feature-grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .svc-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:28px;}
  .hero-cta .btn{flex:1 1 auto;}
  .stat-chip{position:static;margin-top:16px;max-width:none;}
}
