:root{
    --ink:#16333c;          /* deep slate-teal text */
    --ink-soft:#537079;
    --deep:#123f52;         /* deep water */
    --deep-2:#0e526b;
    --ocean:#2a7ba0;        /* calm ocean */
    --sky:#6fb0cb;          /* mid water */
    --mist:#cbe4ec;         /* pale water */
    --foam:#e9f3f6;         /* near-white water */
    --paper:#f5fafb;        /* page background */
    --teal:#4f9f97;         /* soft seafoam accent */
    --line:#d5e6eb;
    --ease:cubic-bezier(.22,.7,.24,1);
    --serif:"Fraunces",Georgia,serif;
    --sans:"Figtree",system-ui,-apple-system,sans-serif;
    --maxw:1160px;
    --shadow:0 18px 50px -24px rgba(18,63,82,.4);
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0;background:var(--paper);color:var(--ink);
    font-family:var(--sans);font-size:17px;line-height:1.68;
    -webkit-font-smoothing:antialiased;overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  ::selection{background:var(--sky);color:#fff}
  :focus-visible{outline:3px solid var(--ocean);outline-offset:3px;border-radius:6px}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.12;letter-spacing:-.01em;margin:0;color:var(--ink)}
  h1{font-size:clamp(2.3rem,5.4vw,3.9rem);font-weight:400}
  h2{font-size:clamp(1.9rem,3.9vw,2.9rem);font-weight:400}
  h3{font-size:1.35rem}
  p{margin:0}
  .eyebrow{font-family:var(--serif);font-style:italic;font-size:1.02rem;color:var(--ocean);letter-spacing:.01em}
  .lead{color:var(--ink-soft);font-size:1.14rem;line-height:1.7}

  /* buttons */
  .btn{
    display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:600;font-size:1rem;
    padding:.92rem 1.55rem;border-radius:999px;border:1.5px solid var(--deep);
    background:var(--deep);color:#fff;cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s;
    box-shadow:0 10px 24px -12px rgba(18,63,82,.6);
  }
  .btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(18,63,82,.7);background:var(--deep-2)}
  .btn.ghost{background:transparent;color:var(--deep);box-shadow:none}
  .btn.ghost:hover{background:var(--foam);transform:translateY(-2px)}
  .btn.light{background:#fff;color:var(--deep);border-color:#fff}
  .btn.light:hover{background:var(--foam)}
  .btn .arw{transition:transform .2s var(--ease)}
  .btn:hover .arw{transform:translateX(3px)}

  /* ---------- top bar ---------- */
  .topbar{background:var(--deep);color:#dcf0f5;font-size:.9rem}
  .topbar-in{display:flex;align-items:center;justify-content:center;gap:1.6rem;flex-wrap:wrap;padding:.55rem 24px;text-align:center}
  .topbar a{color:#fff;font-weight:600}
  .topbar a:hover{text-decoration:underline}
  .topbar .msg{color:#bfe0e9}
  .topbar .sep{opacity:.35}

  /* ---------- header ---------- */
  .header{position:sticky;top:0;z-index:70;background:rgba(245,250,251,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  .header-in{display:flex;align-items:center;justify-content:space-between;height:74px;gap:1rem}
  .brand{display:flex;align-items:center;gap:.7rem}
  .brand .ripple{width:34px;height:34px;flex:none;position:relative}
  .brand .ripple span{position:absolute;inset:0;border:2px solid var(--ocean);border-radius:50%;opacity:.9}
  .brand .ripple span:nth-child(2){inset:6px;border-color:var(--sky)}
  .brand .ripple span:nth-child(3){inset:12px;border-color:var(--teal);background:var(--teal);opacity:.5}
  .brand .name{line-height:1.05}
  .brand .name b{font-family:var(--serif);font-weight:500;font-size:1.28rem;display:block;color:var(--ink)}
  .brand .name small{font-family:var(--sans);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
  .nav{display:flex;align-items:center;gap:1.7rem}
  .nav a{font-weight:500;color:var(--ink);font-size:.98rem;transition:color .15s}
  .nav a:hover{color:var(--ocean)}
  .header-cta{display:flex;align-items:center;gap:.9rem}
  .header .btn{padding:.7rem 1.15rem;font-size:.94rem}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
  .burger span{width:24px;height:2px;background:var(--ink);border-radius:2px}

  /* ---------- hero ---------- */
  .hero{position:relative;background:linear-gradient(180deg,#dff0f5 0%,#bcdfe9 46%,#8ec6da 100%);overflow:hidden;padding:clamp(56px,8vw,96px) 0 150px}
  .hero-in{position:relative;z-index:3;display:grid;grid-template-columns:1.08fr .92fr;gap:56px;align-items:center}
  .hero-title-wrap{position:relative}
  .hero h1{max-width:16ch}
  .reflection{position:absolute;left:0;top:100%;transform:scaleY(-1);opacity:.16;filter:blur(1px);
    -webkit-mask-image:linear-gradient(to bottom,#000,transparent 72%);mask-image:linear-gradient(to bottom,#000,transparent 72%);
    pointer-events:none;font-family:var(--serif);font-weight:400;line-height:1.12;letter-spacing:-.01em;
    font-size:clamp(2.3rem,5.4vw,3.9rem);max-width:16ch;color:var(--deep)}
  .hero-sub{margin-top:1.5rem;max-width:40ch;color:#173d4b;font-size:1.16rem;line-height:1.65}
  .hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:2rem}
  .hero-trust{display:flex;align-items:center;gap:.7rem;margin-top:1.9rem;color:#194351;font-weight:500;font-size:.96rem}
  .stars{color:#e6a94b;letter-spacing:2px}

  /* hero visual: still-water card with concentric ripples */
  .hero-visual{position:relative;height:420px;border-radius:26px;overflow:hidden;box-shadow:var(--shadow);
    background:linear-gradient(160deg,#4a9bbd,#1b5c78 70%);border:1px solid rgba(255,255,255,.35)}
  .hero-visual .ripples{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);width:120%;aspect-ratio:1}
  .hero-visual .ripples i{position:absolute;inset:0;margin:auto;border:1.5px solid rgba(255,255,255,.4);border-radius:50%;
    width:16%;height:16%;animation:spread 6s var(--ease) infinite}
  .hero-visual .ripples i:nth-child(2){animation-delay:1.5s}
  .hero-visual .ripples i:nth-child(3){animation-delay:3s}
  .hero-visual .ripples i:nth-child(4){animation-delay:4.5s}
  @keyframes spread{0%{width:8%;height:8%;opacity:.7}100%{width:135%;height:135%;opacity:0}}
  .hero-visual .caption{position:absolute;left:24px;bottom:22px;right:24px;color:#eaf6fa;z-index:2}
  .hero-visual .caption em{font-family:var(--serif);font-style:italic;font-size:1.35rem;line-height:1.3;display:block}
  .hero-visual .caption span{font-size:.82rem;opacity:.85;display:block;margin-top:.4rem;letter-spacing:.02em}

  /* animated hero waves */
  .hero-waves{position:absolute;left:0;right:0;bottom:-1px;z-index:2;line-height:0}
  .hero-waves svg{width:200%;height:auto;display:block}
  .hero-waves .w1{opacity:.5;animation:drift 22s linear infinite}
  .hero-waves .w2{opacity:.7;animation:drift 16s linear infinite reverse;margin-top:-60px}
  .hero-waves .w3{animation:drift 28s linear infinite;margin-top:-70px}
  @keyframes drift{to{transform:translateX(-50%)}}

  /* ---------- section base ---------- */
  section{position:relative}
  .band{padding:clamp(64px,8vw,104px) 0}
  .center{text-align:center;max-width:62ch;margin:0 auto}
  .center .lead{margin-top:1.1rem}
  .center h2{margin-top:.5rem}
  .band .center h1{margin-top:.5rem}

  /* intro / reassurance */
  .intro{background:var(--foam)}
  .intro .quote{font-family:var(--serif);font-weight:400;font-size:clamp(1.9rem,4vw,2.9rem);line-height:1.28;color:var(--deep);max-width:20ch;margin:0 auto;text-align:center}
  .intro p.lead{max-width:58ch;margin:1.6rem auto 0;text-align:center}

  /* about preview */
  .about-in{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
  .portrait{position:relative;aspect-ratio:4/5;border-radius:24px;background:linear-gradient(160deg,#cfe6ee,#8ec6da);
    box-shadow:var(--shadow);display:grid;place-items:center;overflow:hidden;border:1px solid rgba(255,255,255,.5)}
  .portrait .init{font-family:var(--serif);font-size:6rem;color:#fff;opacity:.9}
  .portrait::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 30% 20%,rgba(255,255,255,.35),transparent 60%)}
  .about-copy .eyebrow{margin-bottom:.8rem;display:block}
  .about-copy h2{margin-bottom:1.1rem}
  .about-copy p+p{margin-top:1rem}
  .about-copy .btn{margin-top:1.8rem}

  /* support cards */
  .support{background:var(--foam)}
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
  .card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 24px;transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
  .card .ic{width:46px;height:46px;border-radius:13px;background:var(--mist);display:grid;place-items:center;margin-bottom:1rem}
  .card .ic svg{width:24px;height:24px;stroke:var(--deep);fill:none;stroke-width:1.7}
  .card h3{font-size:1.18rem;margin-bottom:.35rem}
  .card p{color:var(--ink-soft);font-size:.98rem;line-height:1.55}
  .cards-foot{text-align:center;margin-top:34px}
  .textlink{color:var(--ocean);font-weight:600;border-bottom:2px solid var(--sky);padding-bottom:2px}
  .textlink:hover{border-color:var(--ocean)}

  /* fees */
  .fees-in{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:44px;max-width:760px;margin-left:auto;margin-right:auto}
  .fee{background:#fff;border:1px solid var(--line);border-radius:20px;padding:34px 30px;text-align:center}
  .fee.feature{background:linear-gradient(165deg,var(--deep),var(--deep-2));border-color:var(--deep);color:#fff}
  .fee h3{font-size:1.15rem;font-family:var(--sans);font-weight:600;letter-spacing:.02em}
  .fee.feature h3{color:#cfeaf1}
  .fee .price{font-family:var(--serif);font-size:3rem;font-weight:400;margin:.4rem 0 .2rem}
  .fee .per{color:var(--ink-soft);font-size:.92rem}
  .fee.feature .per{color:#a9d6e3}
  .fees-note{text-align:center;color:var(--ink-soft);margin-top:1.6rem;font-size:.98rem}

  /* what to expect */
  .expect{background:linear-gradient(180deg,var(--foam),var(--paper))}
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
  .step{position:relative;padding:0 6px}
  .step .num{font-family:var(--serif);font-size:2.2rem;color:var(--sky);line-height:1}
  .step h3{font-size:1.12rem;margin:.5rem 0 .35rem}
  .step p{color:var(--ink-soft);font-size:.96rem;line-height:1.55}
  .step:not(:last-child)::after{content:"";position:absolute;right:-8px;top:14px;width:16px;height:2px;background:var(--sky);border-radius:2px}

  /* reviews */
  .reviews{background:var(--foam)}
  .rev-badge{display:inline-flex;align-items:center;gap:.7rem;background:#fff;border:1px solid var(--line);border-radius:999px;padding:.5rem 1rem;box-shadow:var(--shadow);margin-bottom:1.2rem}
  .rev-badge .stars{font-size:1.05rem}
  .rev-badge b{font-family:var(--sans)}
  .rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
  .rev{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 24px;display:flex;flex-direction:column;gap:.9rem}
  .rev .stars{font-size:1rem}
  .rev p{color:var(--ink);font-size:1.02rem;line-height:1.6}
  .rev .who{color:var(--ink-soft);font-size:.9rem;font-weight:600;margin-top:auto}
  .rev-foot{text-align:center;margin-top:34px;display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

  /* location */
  .loc-in{display:grid;grid-template-columns:1fr 1.1fr;gap:44px;align-items:center}
  .loc-copy h2{margin-bottom:1rem}
  .loc-detail{display:flex;flex-direction:column;gap:.9rem;margin:1.6rem 0}
  .loc-detail .r{display:flex;gap:.8rem;align-items:flex-start}
  .loc-detail .r svg{width:20px;height:20px;stroke:var(--ocean);fill:none;stroke-width:1.8;flex:none;margin-top:3px}
  .loc-detail .r span b{display:block;font-weight:600}
  .loc-detail .r span small{color:var(--ink-soft);font-size:.95rem}
  .map{position:relative;height:340px;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);
    background:linear-gradient(160deg,#cfe6ee,#8ec6da);display:grid;place-items:center;text-align:center;padding:24px;color:var(--deep)}
  .map .pin{width:46px;height:46px;border-radius:50% 50% 50% 0;background:var(--ocean);transform:rotate(-45deg);position:relative;margin-bottom:1rem;box-shadow:0 10px 20px -8px rgba(18,63,82,.6)}
  .map .pin::after{content:"";position:absolute;inset:14px;background:#fff;border-radius:50%}
  .map small{display:block;margin-top:.4rem;font-size:.85rem;color:var(--ink-soft)}

  /* callback form */
  .callback{background:linear-gradient(165deg,var(--deep),#0d3d52);color:#eaf6fa;position:relative;overflow:hidden}
  .callback::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
    border:1px solid rgba(255,255,255,.12);top:-160px;right:-120px}
  .callback::after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;
    border:1px solid rgba(255,255,255,.1);top:-80px;right:-40px}
  .cb-in{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.05fr;gap:52px;align-items:start}
  .cb-copy h2{color:#fff}
  .cb-copy .eyebrow{color:#8fd0e0}
  .cb-copy .lead{color:#bfe0e9;margin-top:1.1rem}
  .cb-copy .call-big{display:inline-flex;align-items:center;gap:.6rem;margin-top:1.7rem;font-family:var(--serif);font-size:1.6rem;color:#fff}
  .cb-copy .call-big svg{width:26px;height:26px;stroke:#8fd0e0;fill:none;stroke-width:1.8}
  .cb-form{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:22px;padding:28px}
  .cb-form .grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .field{margin-bottom:14px}
  .field label{display:block;font-size:.86rem;font-weight:600;color:#cfeaf1;margin-bottom:.35rem}
  .field input,.field select,.field textarea{
    width:100%;font-family:var(--sans);font-size:1rem;color:#fff;padding:.75rem .85rem;border-radius:12px;
    background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);transition:.15s}
  .field input::placeholder,.field textarea::placeholder{color:#9fc4d0}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:#8fd0e0;background:rgba(255,255,255,.14)}
  .field select option{color:#16333c}
  .field textarea{resize:vertical;min-height:84px}
  .consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.85rem;color:#bfe0e9;line-height:1.5;margin:4px 0 16px}
  .consent input{margin-top:4px;accent-color:var(--sky);width:18px;height:18px;flex:none}
  .cb-form .btn{width:100%;justify-content:center}
  .cb-form .privacy-note{font-size:.78rem;color:#9fc4d0;margin-top:1rem;text-align:center;line-height:1.5}

  /* ---------- footer ---------- */
  footer{background:var(--deep-2);color:#cfe6ee;padding-top:0}
  .foot-wave{line-height:0}
  .foot-wave svg{width:100%;height:auto;display:block}
  .foot-in{max-width:var(--maxw);margin:0 auto;padding:56px 24px 0;display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1fr;gap:36px}
  .foot-brand .brand .name b{color:#fff}
  .foot-brand .brand .name small{color:#9fc4d0}
  .foot-brand p{margin-top:1rem;color:#a9d6e3;max-width:32ch;font-size:.96rem}
  .foot-brand .social{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.2rem;color:#fff;font-weight:600;font-size:.95rem}
  .foot-brand .social .fbi{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center;transition:.18s}
  .foot-brand .social:hover .fbi{background:var(--sky)}
  .foot-brand .social svg{width:17px;height:17px;fill:#fff}
  .foot-col h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#8fd0e0;margin:0 0 1.1rem}
  .foot-col a,.foot-col p{display:block;color:#cfe6ee;font-size:.96rem;margin-bottom:.62rem;transition:color .15s}
  .foot-col a:hover{color:#fff}
  .hours-row{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem;color:#cfe6ee;margin-bottom:.4rem}
  .hours-row span:last-child{color:#a9d6e3}
  .foot-bottom{max-width:var(--maxw);margin:44px auto 0;padding:20px 24px 34px;border-top:1px solid rgba(255,255,255,.12);
    display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#9fc4d0}
  .foot-bottom .links{display:flex;gap:1.3rem}
  .foot-bottom a:hover{color:#fff}

  /* mobile floating quick-contact */
  .quick{position:fixed;right:16px;bottom:16px;z-index:80;display:none;flex-direction:column;gap:12px}
  .quick a{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;box-shadow:0 12px 26px -10px rgba(18,63,82,.7);border:1.5px solid #fff}
  .quick a svg{width:24px;height:24px;fill:#fff}
  .quick .q-call{background:var(--deep)}
  .quick .q-mail{background:var(--ocean)}
  .quick .q-back{background:var(--teal)}
  .quick a .ring{position:absolute;inset:0;border-radius:50%;border:2px solid var(--deep);animation:qr 2.6s var(--ease) infinite;pointer-events:none}
  @keyframes qr{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.55);opacity:0}}

  /* cookie banner */
  .cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:120;background:#fff;border:1px solid var(--line);
    border-radius:16px;box-shadow:0 20px 50px -18px rgba(18,63,82,.5);padding:18px 20px;
    display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center;max-width:760px;margin:0 auto}
  .cookie p{font-size:.9rem;color:var(--ink-soft);flex:1;min-width:220px}
  .cookie a{color:var(--ocean);font-weight:600}
  .cookie .btn{padding:.6rem 1.2rem;font-size:.92rem}
  .cookie.hide{display:none}

  /* reveal */
  .reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
  .reveal.in{opacity:1;transform:none}

  /* responsive */
  @media(max-width:900px){
    .hero-in,.about-in,.loc-in,.cb-in{grid-template-columns:1fr;gap:38px}
    .reflection{display:none}
    .cards,.rev-grid{grid-template-columns:1fr 1fr}
    .steps{grid-template-columns:1fr 1fr;gap:26px}
    .step:not(:last-child)::after{display:none}
    .foot-in{grid-template-columns:1fr 1fr}
    .nav{display:none}
    .burger{display:flex}
    .header .header-cta .btn{display:none}
    .quick{display:flex}
    .hero-visual{height:300px}
  }
  @media(max-width:560px){
    body{font-size:16px}
    .cards,.rev-grid,.fees-in,.cb-form .grid2,.foot-in{grid-template-columns:1fr}
    .topbar .msg{display:none}
    .foot-bottom{flex-direction:column;text-align:center}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important;scroll-behavior:auto}
    .reveal{opacity:1;transform:none}
  }

/* ---------- mobile nav drawer ---------- */
.mobile-nav{display:none;position:fixed;inset:0;z-index:90;background:rgba(18,63,82,.45)}
.mobile-nav.open{display:block}
.mobile-nav-panel{position:absolute;right:0;top:0;bottom:0;width:min(320px,88vw);background:var(--paper);padding:24px;box-shadow:var(--shadow);overflow-y:auto}
.mobile-nav-panel a{display:block;padding:.75rem 0;font-weight:600;border-bottom:1px solid var(--line)}
.mobile-nav-panel .btn{margin-top:1rem;width:100%;justify-content:center}
.mobile-nav-close{position:absolute;top:12px;right:12px;background:none;border:0;font-size:1.5rem;cursor:pointer}

/* ---------- nav dropdown ---------- */
.nav-item{position:relative}
.nav-item .sub{display:none;position:absolute;top:100%;left:0;min-width:220px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:.5rem 0;box-shadow:var(--shadow);z-index:60}
.nav-item:hover .sub,.nav-item:focus-within .sub{display:block}
.nav-item .sub a{display:block;padding:.55rem 1rem;font-size:.94rem}
.nav-item .sub a:hover{background:var(--foam)}

/* ---------- page hero ---------- */
.page-hero{padding:clamp(48px,7vw,80px) 0;background:linear-gradient(180deg,var(--foam),var(--paper));border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2rem,4.5vw,3rem)}

/* ---------- treatments list ---------- */
.treat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:2rem}
.treat-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;font-size:.98rem;color:var(--ink-soft)}
.treat-item b{color:var(--ink);font-weight:600;display:block;margin-bottom:.35rem}
.treat-summary{font-size:.92rem;color:var(--muted);margin:.25rem 0 .4rem}
.treat-desc{font-size:.9rem;color:var(--ink-soft)}
.admin-image-field{margin-bottom:1rem}
.admin-image-preview img{max-width:180px;max-height:120px;border-radius:10px;border:1px solid var(--line);display:block;margin-bottom:.5rem}
.admin-readonly-path{width:100%;font-size:.85rem;background:#f5fafb}
.admin-remove-image{display:block;margin-top:.5rem;font-size:.9rem}

/* ---------- forms (light) ---------- */
.form-light .field label{color:var(--ink-soft)}
.form-light .field input,.form-light .field select,.form-light .field textarea{
  color:var(--ink);background:#fff;border:1px solid var(--line)}
.form-light .field input:focus,.form-light .field select:focus,.form-light .field textarea:focus{
  border-color:var(--ocean);background:#fff}
.form-light .consent{color:var(--ink-soft)}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* ---------- google embed ---------- */
.embed-wrap{border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);min-height:340px;background:var(--foam)}
.embed-wrap iframe{width:100%;min-height:340px;border:0;display:block}

/* ---------- admin (layout only on template tokens) ---------- */
.admin-wrap{min-height:100vh;background:var(--foam)}
.admin-bar{background:var(--deep);color:#fff;padding:.75rem 1.5rem}
.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 52px)}
.admin-side{background:#fff;border-right:1px solid var(--line);padding:1.25rem}
.admin-side a{display:block;padding:.55rem .25rem;color:var(--ink);font-weight:500}
.admin-side a:hover{color:var(--ocean)}
.admin-main{padding:1.5rem}
.admin-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.25rem;margin-bottom:1rem}
.admin-table{width:100%;border-collapse:collapse;font-size:.95rem}
.admin-table th,.admin-table td{padding:.6rem .5rem;border-bottom:1px solid var(--line);text-align:left}
.flash{padding:.75rem 1rem;border-radius:12px;margin-bottom:1rem}
.flash.ok{background:#e8f5f0;color:#1d5c42;border:1px solid #b8e0cf}
.flash.err{background:#fdeeee;color:#7a2b2b;border:1px solid #f0c4c4}
.admin-login{max-width:420px;margin:4rem auto;padding:2rem;background:#fff;border-radius:20px;border:1px solid var(--line);box-shadow:var(--shadow)}
.admin-h1{font-size:1.6rem;margin-bottom:.6rem}
.admin-h2{font-size:1.2rem;margin:1.2rem 0 .8rem}
.admin-lead{font-size:1rem;margin-bottom:.4rem}
.admin-note{font-size:.92rem;color:var(--muted);margin:.6rem 0}
.admin-tabs{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1rem}
.admin-tabs a{padding:.45rem .8rem;border:1px solid var(--line);border-radius:999px;font-size:.88rem;color:var(--ink)}
.admin-tabs a.active{background:var(--deep);color:#fff;border-color:var(--deep)}
.admin-dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.9rem}
.admin-dash-card{display:block;padding:1rem;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--ink);text-decoration:none}
.admin-dash-card strong{display:block;margin-bottom:.35rem}
.admin-dash-card span{font-size:.9rem;color:var(--muted)}
.admin-bar-in{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.admin-bar-link{color:#fff;text-decoration:underline;margin-left:1rem}
.admin-table-wrap{overflow:auto}
.admin-inline-form{display:inline}
.admin-btn-sm{padding:.4rem .8rem;font-size:.85rem}
.session-types{margin-top:2rem}
.session-list{list-style:none;padding:0;margin:1rem auto 0;max-width:36ch;text-align:left}
.session-list li{padding:.35rem 0;border-bottom:1px solid var(--line)}

@media(max-width:900px){
  .treat-grid{grid-template-columns:1fr 1fr}
  .admin-shell{grid-template-columns:1fr}
  .admin-side{display:flex;flex-wrap:wrap;gap:.5rem 1rem}
}
@media(max-width:560px){
  .treat-grid{grid-template-columns:1fr}
}
