/* =====================================================================
   CLINICBRAIN — Premium template design system
   Shared across every specialty page. Per-page <style> blocks override
   the theme tokens (--accent / --accent-deep / --gold) and --hero-bg.
   Structure & interactions mirror the Rosmarakis premium build.
   ===================================================================== */
:root{
  --ink:#1b1714;
  --ink-2:#3a322d;
  --muted:#7a6e64;
  --line:#e2d8cb;
  --paper:#f6f1ea;
  --paper-2:#efe7db;
  --cream:#fbf8f3;
  /* theme tokens — overridden per specialty */
  --accent:#8a1c2b;
  --accent-deep:#6c1320;
  --gold:#c08a3e;
  --white:#ffffff;
  --hero-bg:none;
  --shadow-s:0 6px 22px rgba(38,28,22,.10);
  --shadow-l:0 28px 70px rgba(38,28,22,.18);
  --r:14px;
  --r-s:10px;
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1220px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background:var(--paper);
  font-family:"Space Grotesk",system-ui,sans-serif;
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  -webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;
  -webkit-touch-callout:none;
}
img{display:block;max-width:100%;-webkit-user-drag:none;user-drag:none;pointer-events:none}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--accent);color:#fff}

h1,h2,h3,.display{
  font-family:"Fraunces",Georgia,serif;
  font-weight:600;line-height:1.04;letter-spacing:-.01em;
  font-optical-sizing:auto;
}
.shell{width:min(var(--maxw),calc(100% - 80px));margin-inline:auto}

/* ---------- cursor glow ---------- */
.glow{
  position:fixed;top:0;left:0;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 12%,transparent),transparent 62%);
  transform:translate(-50%,-50%);pointer-events:none;z-index:1;
  transition:opacity .4s ease;opacity:0;will-change:transform;
}

/* ---------- scroll progress ---------- */
.progress{position:fixed;inset:0 auto auto 0;height:3px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--accent),var(--gold));transition:width .1s linear}

/* ---------- top bar ---------- */
.topbar{position:fixed;inset:0 0 auto 0;height:78px;z-index:90;display:flex;align-items:center;
  transition:height .35s var(--ease),background .35s ease,box-shadow .35s ease,border-color .35s ease;
  border-bottom:1px solid transparent}
.topbar.scrolled{height:62px;background:rgba(246,241,234,.86);backdrop-filter:blur(16px);
  border-color:var(--line);box-shadow:0 10px 30px rgba(38,28,22,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%;padding-inline:clamp(0px,2.5vw,48px)}
.brand{display:flex;align-items:center;gap:13px}
.brand-mark{position:relative;width:54px;height:54px;flex:none;
  background:url("logo-mark.png") center/contain no-repeat;
  filter:drop-shadow(0 2px 8px rgba(40,28,16,.28))}
.brand-mark svg{display:none}
.brand-txt{display:none}
.topbar.scrolled .brand-mark{width:46px;height:46px;filter:none}
.brand-txt strong{display:block;font-family:"Fraunces",serif;font-weight:600;font-size:19px;line-height:1;color:var(--ink)}
.brand-txt span{display:block;margin-top:4px;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:30px;font-size:13.5px;font-weight:500}
.nav-links a{position:relative;color:var(--ink-2);transition:color .25s ease;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--accent);
  border-radius:2px;transition:width .35s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-side{display:flex;align-items:center;gap:18px}
.nav-phone{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--ink)}
.nav-phone svg{width:15px;height:15px;color:var(--accent)}

.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:48px;padding:0 24px;border-radius:999px;font-weight:600;font-size:14px;
  border:1px solid transparent;cursor:pointer;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .25s ease,color .25s ease;will-change:transform}
.btn svg{width:16px;height:16px}
.btn.primary{background:var(--accent);color:#fff;box-shadow:0 14px 30px color-mix(in srgb,var(--accent) 26%,transparent)}
.btn.primary:hover{background:var(--accent-deep);box-shadow:0 18px 40px color-mix(in srgb,var(--accent) 32%,transparent)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.btn.light{background:#fff;color:var(--accent)}
.btn.outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn.outline-light:hover{background:#fff;color:var(--ink)}
.ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.4);transform:scale(0);
  animation:rip .6s ease-out;pointer-events:none}
@keyframes rip{to{transform:scale(2.6);opacity:0}}

.hamburger{display:flex;flex-direction:column;justify-content:space-between;width:30px;height:18px;cursor:pointer;z-index:200}
.hamburger span{display:block;height:2.5px;width:100%;background:var(--ink);border-radius:3px;transition:.35s var(--ease)}
body.menu-open .hamburger span:nth-child(1){transform:translateY(7.75px) rotate(45deg)}
body.menu-open .hamburger span:nth-child(2){opacity:0}
body.menu-open .hamburger span:nth-child(3){transform:translateY(-7.75px) rotate(-45deg)}

.drawer{position:fixed;inset:0 -100% 0 auto;width:min(360px,82%);z-index:150;
  background:var(--cream);box-shadow:-20px 0 60px rgba(0,0,0,.18);
  padding:108px 36px 40px;display:flex;flex-direction:column;gap:26px;transition:right .45s var(--ease)}
body.menu-open .drawer{right:0}
.drawer a.dlink{font-family:"Fraunces",serif;font-size:26px;font-weight:500;color:var(--ink);
  border-bottom:1px solid var(--line);padding-bottom:14px;display:flex;justify-content:space-between;align-items:baseline}
.drawer a.dlink b{font-family:"Space Grotesk";font-size:12px;color:var(--muted);font-weight:500}
.drawer .btn{margin-top:auto}
.overlay{position:fixed;inset:0;background:rgba(27,23,20,.45);backdrop-filter:blur(3px);z-index:140;
  opacity:0;pointer-events:none;transition:opacity .4s ease}
body.menu-open .overlay{opacity:1;pointer-events:auto}

/* ---------- HERO ---------- */
.hero{position:relative;padding:132px 0 84px;min-height:100vh;display:flex;align-items:center;overflow:hidden;
  background-color:#fff;background-image:var(--hero-bg);background-position:center right;background-size:cover;background-repeat:no-repeat;color:var(--ink)}
.hero::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(100deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.82) 36%,rgba(255,255,255,.25) 62%,rgba(255,255,255,0) 78%)}
.hero .shell{position:relative;z-index:2;display:block;width:100%}
.hero-text{max-width:640px;padding-left:clamp(16px,4vw,72px)}
.hero-mobile-art{display:none}
.hero-doctor-name{display:inline-block;font-family:Fraunces,Georgia,serif;font-size:clamp(30px,3.8vw,48px);font-weight:600;line-height:1.04;color:var(--ink);padding-bottom:14px;margin:0 0 14px;border-bottom:2px solid var(--accent)}
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-size:11.5px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:26px}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--accent)}
.hero h1{font-size:clamp(40px,5.2vw,68px);font-weight:600;margin:0;line-height:1.14}
.hero h1 .it{font-style:italic;font-weight:400;color:var(--accent)}
.hero h1 .word{display:inline-block;overflow:hidden;vertical-align:bottom;
  padding:.18em .02em .1em;margin:-.18em 0 -.1em}
.hero h1 .word i{display:inline-block;font-style:inherit;transform:translateY(115%);
  animation:rise .9s var(--ease) forwards}
@keyframes rise{to{transform:none}}
.hero-copy{max-width:480px;margin:30px 0 36px;font-size:17px;color:var(--ink-2);
  opacity:0;animation:fade .9s var(--ease) .85s forwards}
@keyframes fade{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:fade .9s var(--ease) 1s forwards}
.hero-meta{display:flex;gap:30px;margin-top:42px;opacity:0;animation:fade .9s var(--ease) 1.15s forwards}
.hero-meta .m strong{font-family:"Fraunces",serif;font-size:30px;font-weight:600;display:block;line-height:1}
.hero-meta .m span{font-size:12px;color:var(--muted)}

/* hero animated line */
.ecg-wrap{position:absolute;left:0;right:0;bottom:0;z-index:2;height:120px;pointer-events:none;
  opacity:0;animation:fade 1s ease 1.3s forwards}
.ecg-line{stroke:var(--accent);stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1000;stroke-dashoffset:1000;animation:draw 6s linear infinite}
@keyframes draw{0%{stroke-dashoffset:1000}55%{stroke-dashoffset:0}100%{stroke-dashoffset:-1000}}

/* ---------- marquee ---------- */
.marquee{background:var(--ink);color:var(--paper);overflow:hidden;padding:18px 0;border-block:1px solid #2c2520}
.marquee-track{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:scrollx 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:"Fraunces",serif;font-style:italic;font-size:22px;display:inline-flex;align-items:center;gap:48px}
.marquee span::after{content:"✦";font-style:normal;color:var(--accent);font-size:14px}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- section scaffolding ---------- */
.section{padding:118px 0;position:relative}
.shead{display:grid;grid-template-columns:1fr .8fr;gap:48px;align-items:end;margin-bottom:64px}
.kicker{display:flex;align-items:center;gap:10px;font-size:11.5px;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.kicker .num{font-family:"Fraunces",serif;font-style:italic;color:var(--gold);font-size:13px}
.shead h2{font-size:clamp(33px,4.4vw,58px);font-weight:600;margin:0}
.shead h2 em{font-style:italic;color:var(--accent);font-weight:400}
.shead .lead{color:var(--muted);font-size:16px;max-width:380px}

/* ---------- about ---------- */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:64px;align-items:center}
.about-figure{position:relative;width:min(100%,420px);justify-self:center}
.about-figure img{width:100%;border-radius:var(--r);box-shadow:var(--shadow-l);aspect-ratio:3/4;object-fit:cover;object-position:center top}
.about-figure .tag{position:absolute;bottom:-26px;right:-14px;background:var(--accent);color:#fff;
  padding:24px 28px;border-radius:var(--r);box-shadow:var(--shadow-l);max-width:230px}
.about-figure .tag strong{font-family:"Fraunces",serif;font-size:34px;display:block;line-height:1}
.about-figure .tag span{font-size:12.5px;opacity:.85}
.about-body p{color:var(--ink-2);font-size:16.5px;margin:0 0 18px}
.about-body p.intro{font-family:"Fraunces",serif;font-size:23px;font-weight:500;color:var(--ink);line-height:1.45}
.about-body h2{font-size:clamp(30px,4vw,50px);margin:0 0 22px}
.about-body h2 em{font-style:italic;color:var(--accent)}
.cred-list{list-style:none;padding:0;margin:30px 0 0;display:grid;gap:14px}
.cred-list li{display:flex;gap:14px;align-items:flex-start;font-size:15px}
.cred-list li svg{width:21px;height:21px;color:var(--accent);flex:none;margin-top:1px}
.cred-list li b{color:var(--ink)}
.member-box{margin-top:28px;padding-top:24px;border-top:1px solid var(--line)}
.member-box h3{margin:0 0 14px;font-size:20px;color:var(--ink)}
.member-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.member-list li{position:relative;padding-left:18px;color:var(--ink-2);font-size:15px;line-height:1.55}
.member-list li::before{content:"";position:absolute;left:0;top:.72em;width:6px;height:6px;border-radius:50%;background:var(--accent)}
.member-list b{color:var(--ink)}

/* ---------- services (expanding rows) ---------- */
.svc-list{border-top:1px solid var(--line)}
.svc-row{border-bottom:1px solid var(--line);cursor:pointer;transition:padding .4s var(--ease)}
.svc-head{display:grid;grid-template-columns:54px 1fr auto;gap:22px;align-items:center;padding:30px 6px;transition:color .3s}
.svc-row .no{font-family:"Fraunces",serif;font-style:italic;color:var(--gold);font-size:17px}
.svc-row h3{font-size:clamp(22px,2.6vw,30px);font-weight:500;margin:0;transition:transform .4s var(--ease),color .3s}
.svc-row .ico{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;
  transition:.4s var(--ease);color:var(--accent)}
.svc-row .ico svg{width:18px;height:18px;transition:transform .4s var(--ease)}
.svc-body{max-height:0;overflow:hidden;transition:max-height .5s var(--ease),opacity .4s ease;opacity:0}
.svc-body-inner{padding:0 6px 32px 76px;color:var(--ink-2);max-width:680px}
.svc-body-inner .feats{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.svc-body-inner .feats span,.svc-body-inner .feats a{display:inline-block;background:var(--paper-2);border:1px solid var(--line);padding:6px 13px;border-radius:999px;font-size:12.5px;color:var(--ink-2);text-decoration:none}
.svc-body-inner .feats a{cursor:pointer;transition:background .25s,border-color .25s,color .25s}
.svc-body-inner .feats a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.svc-row:hover h3{transform:translateX(8px);color:var(--accent)}
.svc-row:hover .ico{background:var(--accent);color:#fff;border-color:var(--accent)}
.svc-row.open h3{color:var(--accent)}
.svc-row.open .ico{background:var(--accent);color:#fff;border-color:var(--accent)}
.svc-row.open .ico svg{transform:rotate(45deg)}
.svc-row.open .svc-body{max-height:240px;opacity:1}

/* ---------- exams interactive grid ---------- */
.exams{background:var(--cream);color:var(--ink)}
.exam-grid{display:flex;flex-direction:column;gap:50px}
.exam-folder-group{display:grid;grid-template-columns:repeat(3,1fr);gap:50px 14px}
.exam-folder-group .exam-folder .folder-items{grid-template-columns:1fr}
.exam-folder .folder-title{display:flex;align-items:center;gap:12px;font-family:"Fraunces",serif;font-size:26px;color:var(--accent-deep);margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.exam-folder .folder-title svg{width:28px;height:28px}
.exam-folder .folder-intro{font-size:15px;color:var(--muted);margin:-10px 0 20px;max-width:600px}
.exam-folder .folder-items{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.exam{position:relative;padding:26px 22px;border:1px solid var(--line);border-radius:var(--r);
  background:var(--white);cursor:pointer;transition:transform .4s var(--ease),box-shadow .35s ease,border-color .35s ease;min-height:178px;display:flex;flex-direction:column;justify-content:space-between}
.exam:hover{transform:translateY(-6px);border-color:var(--accent);box-shadow:var(--shadow-s)}
.exam .enum{font-family:"Fraunces",serif;font-style:italic;color:var(--accent);font-size:14px}
.exam .eico{width:40px;height:40px;color:var(--accent);margin-bottom:14px}
.exam .eico svg{width:40px;height:40px}
.exam h4{font-family:"Fraunces",serif;font-weight:500;font-size:18px;margin:0 0 6px;color:var(--ink)}
.exam p{font-size:12.5px;color:var(--muted);margin:0;line-height:1.5}
.exam .home-tag{position:absolute;top:16px;right:16px;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;
  background:var(--accent);color:#fff;padding:4px 8px;border-radius:999px;font-weight:600}

/* ---------- hours ---------- */
.hours{background:var(--cream)}
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.hours-table{border-top:1px solid var(--line)}
.hrow{display:grid;grid-template-columns:1fr auto;gap:16px;padding:18px 8px;border-bottom:1px solid var(--line);
  align-items:center;transition:background .3s ease,padding-left .3s ease}
.hrow .day{font-weight:500;font-size:15.5px}
.hrow .time{font-family:"Fraunces",serif;font-size:15px;color:var(--ink-2);text-align:right}
.hrow .time.closed{color:var(--muted);font-style:italic}
.hrow.closed .day,.hrow.closed .time{color:var(--muted);opacity:.6}
.hrow.closed .time{font-style:italic}
.hrow.today{background:var(--paper-2);padding-left:18px;border-radius:8px}
.hrow.today .day{color:var(--accent)}
.hrow.today .day::after{content:"σήμερα";margin-left:10px;font-family:"Space Grotesk";font-size:10px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--accent);padding:3px 8px;border-radius:999px;vertical-align:middle}
.hours-aside{background:var(--ink);color:var(--paper);border-radius:var(--r);padding:40px;box-shadow:var(--shadow-l)}
.hours-aside .now-status{display:flex;align-items:center;gap:12px;font-family:"Fraunces",serif;font-size:25px;margin:0 0 8px}
.hours-aside .now-sub{color:rgba(246,241,234,.6);font-size:14px;margin:0 0 28px}
.hours-aside .live-clock{font-family:"Fraunces",serif;font-size:46px;font-weight:600;letter-spacing:.01em;margin-bottom:4px}
.hours-aside .live-date{color:rgba(246,241,234,.55);font-size:13px;text-transform:capitalize;margin-bottom:30px}
.hours-aside .btn{width:100%}
.dot{width:9px;height:9px;border-radius:50%;background:var(--muted);position:relative}
.dot.on{background:#1f9d55}
.dot.on::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1.5px solid #1f9d55;
  animation:pulse 1.8s ease-out infinite}
@keyframes pulse{from{transform:scale(.5);opacity:.9}to{transform:scale(1.6);opacity:0}}

/* ---------- stats band ---------- */
.stats{background:var(--accent);color:#fff;padding:64px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat strong{font-family:"Fraunces",serif;font-size:clamp(40px,5vw,60px);font-weight:600;display:block;line-height:1}
.stat span{font-size:13px;opacity:.82;letter-spacing:.04em}
.stat{position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-15px;top:50%;transform:translateY(-50%);
  width:1px;height:54px;background:rgba(255,255,255,.22)}

/* ---------- reviews ---------- */
.reviews .shead{margin-bottom:48px}
.rev-track{display:flex;gap:22px;overflow-x:auto;padding:6px 2px 22px;scroll-snap-type:x mandatory;
  scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.rev-track::-webkit-scrollbar{height:6px}
.rev-track::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px}
.rev-card{flex:0 0 min(420px,84%);scroll-snap-align:start;background:var(--cream);border:1px solid var(--line);
  border-radius:var(--r);padding:34px;display:flex;flex-direction:column;gap:16px}
.rev-card .stars{color:var(--gold);letter-spacing:3px;font-size:16px}
.rev-card p{font-family:"Fraunces",serif;font-size:18px;line-height:1.55;color:var(--ink);margin:0;flex:1}
.rev-who{display:flex;align-items:center;gap:13px}
.rev-who .av{width:44px;height:44px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;
  font-family:"Fraunces",serif;font-size:18px;flex:none}
.rev-who b{display:block;font-size:14.5px}
.rev-who span{font-size:12px;color:var(--muted)}
.rev-hint{font-size:12.5px;color:var(--muted);margin-top:14px;display:flex;align-items:center;gap:8px}
.rev-hint svg{width:15px;height:15px}

/* ---------- contact ---------- */
.contact{background:var(--cream);color:var(--ink)}
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:54px;align-items:stretch}
.contact h2{font-family:"Fraunces",serif;font-size:clamp(34px,4.6vw,56px);font-weight:600;margin:0 0 20px}
.contact h2 em{font-style:italic;color:var(--accent);font-weight:400}
.contact .clead{color:var(--muted);max-width:400px;margin:0 0 36px;font-size:16px}
.cinfo{list-style:none;padding:0;margin:0;display:grid;gap:4px}
.cinfo a,.cinfo li>div{display:flex;gap:16px;align-items:center;padding:18px 0;border-top:1px solid var(--line);transition:padding-left .3s ease}
.cinfo a:hover{padding-left:8px}
.cinfo .ci-ico{width:44px;height:44px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;
  color:var(--accent);flex:none;transition:.3s ease}
.cinfo a:hover .ci-ico{background:var(--accent);border-color:var(--accent);color:#fff}
.cinfo .ci-ico svg{width:18px;height:18px}
.cinfo b{display:block;font-size:16px;color:var(--ink)}
.cinfo span{font-size:12.5px;color:var(--muted)}
.map-card{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-l);min-height:420px;position:relative;border:1px solid var(--line)}
.map-card iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.15) contrast(1.02)}
.contact-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
.contact-actions .btn{min-width:160px}

/* ---------- booking modal ---------- */
.booking-modal{position:fixed;inset:0;z-index:260;display:grid;place-items:center;padding:24px;
  opacity:0;pointer-events:none;transition:opacity .25s ease}
.booking-modal.open{opacity:1;pointer-events:auto}
.booking-modal__backdrop{position:absolute;inset:0;background:rgba(27,23,20,.58);backdrop-filter:blur(6px)}
.booking-modal__panel{position:relative;width:min(980px,100%);height:min(760px,calc(100vh - 48px));
  background:var(--cream);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-l);
  overflow:hidden;display:grid;grid-template-rows:auto 1fr;transform:translateY(16px) scale(.98);
  transition:transform .25s var(--ease)}
.booking-modal.open .booking-modal__panel{transform:none}
.booking-modal__head{display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:18px 22px;border-bottom:1px solid var(--line);background:var(--cream)}
.booking-modal__title{font-family:"Fraunces",serif;font-size:23px;font-weight:600;color:var(--ink);line-height:1.15}
.booking-modal__sub{font-size:12.5px;color:var(--muted);margin-top:3px}
.booking-modal__close{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:#fff;
  color:var(--ink);font-size:28px;line-height:1;cursor:pointer;display:grid;place-items:center;flex:none}
.booking-modal__close:hover{background:var(--ink);color:var(--paper)}
.booking-modal__body{background:#fff;min-height:0}
.booking-modal .calendly-inline-widget{width:100%;height:100%;min-width:320px}
.booking-modal__fallback{padding:24px;color:var(--muted);font-size:14px}
.booking-modal__fallback a{color:var(--accent);font-weight:700;text-decoration:underline;text-underline-offset:3px}
body.booking-open{overflow:hidden}

/* ---------- footer ---------- */
footer{background:var(--cream);color:var(--muted);padding:54px 0 34px;border-top:1px solid var(--line)}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;flex-wrap:wrap;
  padding-bottom:30px;border-bottom:1px solid var(--line);margin-bottom:24px}
.foot-brand strong{font-family:"Fraunces",serif;font-size:22px;color:var(--ink);display:block}
.foot-brand span{font-size:12px;letter-spacing:.16em;text-transform:uppercase}
.foot-nav{display:flex;gap:26px;flex-wrap:wrap;font-size:14px}
.foot-nav a:hover{color:var(--accent)}
.foot-legal{display:flex;flex-wrap:wrap;gap:8px 10px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line);margin-bottom:18px}
.foot-legal a{font-size:12.5px;color:var(--muted);transition:color .2s}
.foot-legal a:hover{color:var(--accent)}
.foot-legal .sep{color:var(--line);font-size:11px}
.foot-bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12px}
.foot-bottom a{color:var(--accent);font-weight:700}
.foot-bottom a:hover{text-decoration:underline;text-underline-offset:3px}

/* ---------- back to top ---------- */
.to-top{position:fixed;right:24px;bottom:24px;width:52px;height:52px;border:none;cursor:pointer;border-radius:50%;
  display:grid;place-items:center;background:var(--ink);color:var(--paper);box-shadow:var(--shadow-l);
  opacity:0;transform:translateY(18px) scale(.85);pointer-events:none;transition:.45s var(--ease);z-index:110}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{background:var(--accent);transform:translateY(-4px)}
.to-top svg{width:20px;height:20px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- legal / prose pages ---------- */
.legal-head{padding:128px 0 56px;background:var(--cream);border-bottom:1px solid var(--line)}
.legal-head .eyebrow{margin-bottom:18px}
.legal-head h1{font-family:"Fraunces",serif;font-size:clamp(34px,5vw,58px);font-weight:600;margin:0;line-height:1.06}
.legal-head .updated{margin-top:16px;font-size:13px;color:var(--muted)}
.legal-wrap{display:grid;grid-template-columns:.34fr 1fr;gap:54px;padding:64px 0 96px;align-items:start}
.legal-toc{position:sticky;top:96px;border-left:2px solid var(--line);padding-left:20px;display:grid;gap:10px}
.legal-toc strong{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.legal-toc a{font-size:14px;color:var(--ink-2);transition:color .2s,transform .2s}
.legal-toc a:hover{color:var(--accent);transform:translateX(3px)}
.legal-body{max-width:760px}
.legal-body h2{font-family:"Fraunces",serif;font-size:clamp(22px,3vw,30px);font-weight:600;margin:42px 0 14px;scroll-margin-top:96px}
.legal-body h2:first-child{margin-top:0}
.legal-body h3{font-family:"Space Grotesk",sans-serif;font-size:17px;font-weight:600;margin:24px 0 8px}
.legal-body p,.legal-body li{color:var(--ink-2);font-size:15.5px;line-height:1.72}
.legal-body ul{padding-left:20px;margin:10px 0 18px}
.legal-body li{margin-bottom:7px}
.legal-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.legal-note{background:var(--paper-2);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:var(--r-s);padding:18px 22px;margin:0 0 28px;font-size:14px;color:var(--ink-2)}
.legal-note b{color:var(--ink)}
.legal-table{width:100%;border-collapse:collapse;margin:14px 0 22px;font-size:13.5px}
.legal-table th,.legal-table td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}
.legal-table th{background:var(--paper-2);font-weight:600;color:var(--ink)}
.legal-foot-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.legal-foot-links a{font-size:13px;padding:7px 14px;border:1px solid var(--line);border-radius:999px;color:var(--ink-2);transition:.2s}
.legal-foot-links a:hover{border-color:var(--accent);color:var(--accent)}
@media (max-width:860px){
  .legal-wrap{grid-template-columns:1fr;gap:30px;padding:40px 0 72px}
  .legal-toc{position:static;border-left:none;border-top:1px solid var(--line);padding:18px 0 0;
    grid-template-columns:1fr 1fr;gap:10px}
  .legal-head{padding:104px 0 44px}
}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .nav{padding-inline:0}
  .hero-text{padding-left:0}
  .about-grid,.hours-grid,.contact-grid{grid-template-columns:1fr;gap:46px}
  .about-figure{width:min(100%,380px)}
  .service-body{order:1}
  .service-toc{order:2}
  .exam-folder-group{grid-template-columns:repeat(2,1fr)}
  .exam-folder .folder-items{grid-template-columns:repeat(2,1fr)}
  .shead{grid-template-columns:1fr;gap:18px;align-items:start}
  .nav-links,.nav-phone{display:none}
  .hamburger{display:flex}
}
@media (max-width:560px){
  .shell{width:calc(100% - 44px)}
  .section{padding:76px 0}
  .shead{margin-bottom:40px}

  .hero{min-height:auto;padding:96px 0 56px;background:#fff}
  .hero::before{display:none}
  .hero .shell{width:calc(100% - 52px)}
  .hero-text{text-align:center}
  .hero-doctor-name{font-size:28px;padding-bottom:10px;margin-bottom:12px}
  .hero-text .eyebrow{font-size:9.5px;letter-spacing:.11em;margin-bottom:16px;justify-content:center}
  .hero-text .eyebrow::before{display:none}
  .hero h1{font-size:clamp(20px,5vw,28px);line-height:1.32;letter-spacing:.003em;word-spacing:.03em}
  .hero h1 br{display:none}
  .hero h1 .word{padding-top:.08em;padding-bottom:.05em;margin-top:0;margin-bottom:0}
  .hero-copy{font-size:14px;line-height:1.62;margin:14px auto 26px}
  .hero-actions{flex-direction:row;flex-wrap:wrap;gap:10px;justify-content:center}
  .hero-actions .btn{width:auto;min-height:44px;padding:0 18px;font-size:12.5px}
  .hero-actions .btn svg{width:15px;height:15px}
  .hero-mobile-art{display:block;width:100%;margin:28px 0 0;border-radius:18px;height:230px;object-fit:cover;
    background:var(--cream);box-shadow:0 16px 38px rgba(38,28,22,.12)}
  .hero-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:24px;
    border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--cream)}
  .hero-meta .m{padding:16px 6px;text-align:center}
  .hero-meta .m + .m{border-left:1px solid var(--line)}
  .hero-meta .m strong{font-size:21px}
  .hero-meta .m span{font-size:10.5px;line-height:1.3;display:block;margin-top:3px}
  .ecg-wrap{display:none}

  .nav-side .btn{display:none}
  .topbar{height:64px;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);border-bottom:0}
  .topbar.scrolled{height:58px;border-color:transparent;box-shadow:none}
  .brand{gap:10px}
  .brand-mark{width:46px;height:46px}
  .topbar.scrolled .brand-mark{width:40px;height:40px}
  .hamburger{width:26px;height:16px}

  .stats{padding:54px 0}
  .stats-grid{grid-template-columns:1fr 1fr;gap:36px 20px}
  .stat:nth-child(2)::after{display:none}
  .stat strong{font-size:42px}

  .exam-folder-group{grid-template-columns:1fr;gap:40px}
  .exam-folder .folder-items{grid-template-columns:repeat(2,1fr);gap:10px}
  .exam{min-height:152px;padding:18px 15px}
  .exam .eico,.exam .eico svg{width:32px;height:32px}
  .exam .eico{margin-bottom:10px}
  .exam h4{font-size:15.5px}
  .exam .home-tag{top:12px;right:12px;font-size:8.5px;padding:3px 6px}

  .svc-head{grid-template-columns:30px 1fr auto;gap:12px;padding:24px 2px}
  .svc-body-inner{padding-left:42px;padding-right:0}
  .svc-row.open .svc-body{max-height:360px}
  .svc-row:hover h3{transform:none}

  .about-figure{width:min(100%,330px)}
  .about-figure .tag{right:-8px;bottom:-20px;padding:18px 22px}
  .about-figure .tag strong{font-size:28px}
  .about-body .intro{font-size:20px}

  .hours-aside{padding:30px}
  .hours-aside .live-clock{font-size:40px}
  .hrow.today .day::after{display:block;margin:6px 0 0}

  .rev-card{padding:26px;flex-basis:86%}
  .rev-card p{font-size:16px}

  .map-card,.map-card iframe{min-height:320px}

  .booking-modal{padding:10px}
  .booking-modal__panel{height:calc(100vh - 20px);border-radius:12px}
  .booking-modal__head{padding:14px 16px}
  .booking-modal__title{font-size:19px}
  .booking-modal__sub{font-size:11.5px}
  .booking-modal__close{width:40px;height:40px}

  .contact-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .contact-actions .btn{min-width:0;width:100%;min-height:44px;padding:0 14px;font-size:12.5px}

  footer{padding:46px 0 34px}
  .foot-top{flex-direction:column;gap:22px;padding-bottom:0;margin-bottom:18px;border-bottom:none}
  .foot-brand strong{font-size:20px}
  .foot-nav{flex-direction:column;gap:0;width:100%}
  .foot-nav a{padding:14px 2px;border-top:1px solid var(--line);font-size:15px;font-weight:500}
  .foot-nav a:last-child{border-bottom:1px solid var(--line)}
  .foot-bottom{flex-direction:column;gap:8px;line-height:1.55;padding-top:20px}

  .marquee span{font-size:18px;gap:40px}
  .to-top{right:16px;bottom:16px;width:46px;height:46px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero h1 .word i{transform:none!important}
  .hero-copy,.hero-actions,.hero-meta,.ecg-wrap{opacity:1!important}
  .glow{display:none}
  /* keep the decorative marquee scrolling even under reduced motion */
  .marquee-track{animation-duration:28s!important;animation-iteration-count:infinite!important}
}
