/* ---------- TOKENS ---------- */
:root{
  --ink:        #0B2433;     /* deep navy text */
  --ink-2:      #2B4658;     /* secondary text */
  --ink-3:      #6B7E8B;     /* tertiary */
  --paper:      #F6F2EC;     /* warm off-white */
  --paper-2:    #EFE9DF;     /* warmer */
  --cream:      #FBF8F3;
  --brand:      #1A6B8E;     /* logo blue */
  --brand-deep: #0F4E6B;
  --brand-soft: #DCE9EF;
  --brand-mist: #EAF1F4;
  --peach:      #E8B7A0;     /* coral accent from photos */
  --peach-soft: #F5E0D3;
  --line:       rgba(11,36,51,.10);
  --line-2:     rgba(11,36,51,.06);
  --shadow-sm:  0 1px 2px rgba(11,36,51,.04), 0 2px 12px rgba(11,36,51,.04);
  --shadow-md:  0 8px 30px -8px rgba(11,36,51,.18), 0 2px 8px rgba(11,36,51,.06);
  --shadow-lg:  0 30px 60px -20px rgba(11,36,51,.25), 0 8px 24px rgba(11,36,51,.08);
  --r-sm: 8px;
  --r-md: 16px;
  --r-lg: 28px;
  --r-xl: 40px;
  --max: 1280px;
}

/* ---------- BASE ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:'Geist', system-ui, -apple-system, sans-serif;
  font-weight:400;
  font-size:17px;
  line-height:1.55;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:none; color:inherit; }
::selection{ background:var(--brand); color:#fff; }

.serif{ font-family:'Instrument Serif', 'Cormorant Garamond', Georgia, serif; font-weight:400; letter-spacing:-0.01em; }
.serif-i{ font-family:'Instrument Serif', Georgia, serif; font-style:italic; font-weight:400; }
.script{ font-family:'Caveat', cursive; font-weight:600; }
.mono{ font-family:'JetBrains Mono', ui-monospace, Menlo, monospace; }
.eyebrow{
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  font-weight:500; color:var(--brand);
}
.wrap{ width:100%; max-width:var(--max); margin:0 auto; padding:0 28px; }
@media(max-width:640px){ .wrap{ padding:0 20px; } body{ font-size:16px; } }

/* ---------- NAV ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  padding:18px 0;
  transition:background .3s ease, padding .3s ease, box-shadow .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(246,242,236,.85);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom-color:var(--line);
  padding:12px 0;
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:42px; width:auto; }
.brand .b-text{ display:flex; flex-direction:column; line-height:1; }
.brand .b-name{ font-family:'Instrument Serif',serif; font-size:18px; letter-spacing:.01em; color:var(--ink); }
.brand .b-sub{ font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); margin-top:4px; }

.nav-links{ display:flex; align-items:center; gap:26px; }
.nav-links a{ font-size:14px; color:var(--ink-2); font-weight:500; position:relative; padding:6px 0; }
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--brand); transition:width .25s ease;
}
.nav-links a:hover{ color:var(--brand); }
.nav-links a:hover::after{ width:100%; }

.cta{
  display:inline-flex; align-items:center; gap:10px;
  padding:13px 22px; border-radius:999px;
  background:var(--ink); color:var(--paper);
  font-size:14px; font-weight:500; letter-spacing:.01em;
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.cta:hover{ background:var(--brand-deep); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.cta .arr{ transition:transform .2s ease; }
.cta:hover .arr{ transform:translateX(3px); }

.cta-light{
  display:inline-flex; align-items:center; gap:10px;
  padding:13px 22px; border-radius:999px;
  border:1px solid var(--line); color:var(--ink);
  font-size:14px; font-weight:500;
  transition:all .2s ease; background:transparent;
}
.cta-light:hover{ border-color:var(--ink); }

.menu-btn{
  display:none; width:42px; height:42px; border-radius:999px;
  border:1px solid var(--line);
  align-items:center; justify-content:center;
}
.menu-btn svg{ width:18px; height:18px; }

@media(max-width:900px){
  .nav-links{ display:none; }
  .cta.nav-cta{ display:none; }
  .lang{ display:none; }
  .menu-btn{ display:inline-flex; }
}

/* language switcher */
.lang{ position:relative; display:inline-flex; }
.lang-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 12px 9px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  font-size:13px; font-weight:500;
  color:var(--ink-2);
  background:transparent;
  transition:all .2s ease;
}
.lang-btn:hover{ color:var(--ink); border-color:var(--ink); }
.lang-btn .globe{ width:14px; height:14px; }
.lang-btn .chev{ width:12px; height:12px; transition:transform .2s ease; }
.lang.open .lang-btn{ color:var(--ink); border-color:var(--ink); }
.lang.open .lang-btn .chev{ transform:rotate(180deg); }
.lang-menu{
  position:absolute; top:calc(100% + 8px); right:0;
  min-width:180px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:14px;
  padding:6px;
  box-shadow:var(--shadow-md);
  display:none;
  z-index:60;
}
.lang.open .lang-menu{ display:block; animation:langIn .15s ease; }
@keyframes langIn{ from{ opacity:0; transform:translateY(-4px); } to{ opacity:1; transform:none; } }
.lang-menu a{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 12px; border-radius:10px;
  font-size:14px; color:var(--ink-2);
  transition:background .15s ease;
}
.lang-menu a:hover{ background:var(--brand-mist); color:var(--ink); }
.lang-menu a.active{ color:var(--brand); font-weight:500; }
.lang-menu a .flag{ font-size:11px; letter-spacing:.12em; color:var(--ink-3); }
.lang-menu a.active .flag{ color:var(--brand); }

.drawer-lang{
  margin-top:auto;
  margin-bottom:12px;
  display:flex; gap:4px;
  padding:4px;
  border:1px solid var(--line);
  border-radius:999px;
}
.drawer-lang a{
  flex:1; padding:10px 12px; border-radius:999px;
  text-align:center; font-size:13px; font-weight:500;
  color:var(--ink-2); transition:all .2s ease;
}
.drawer-lang a.active{ background:var(--ink); color:var(--paper); }
.drawer-lang a:hover:not(.active){ background:var(--brand-mist); color:var(--ink); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:60; pointer-events:none;
  opacity:0; transition:opacity .25s ease;
}
.drawer.open{ opacity:1; pointer-events:auto; }
.drawer-bg{ position:absolute; inset:0; background:rgba(11,36,51,.4); backdrop-filter:blur(6px); }
.drawer-panel{
  position:absolute; top:0; right:0; bottom:0; width:min(360px, 90vw);
  background:var(--paper); padding:24px;
  transform:translateX(100%); transition:transform .3s ease;
  display:flex; flex-direction:column; gap:8px;
}
.drawer.open .drawer-panel{ transform:translateX(0); }
.drawer-panel .close{ align-self:flex-end; width:42px; height:42px; border:1px solid var(--line); border-radius:999px; display:flex; align-items:center; justify-content:center; }
.drawer-panel a.dl{ padding:14px 4px; font-size:18px; color:var(--ink); border-bottom:1px solid var(--line-2); }
.drawer-panel .cta{ margin-top:auto; justify-content:center; }

/* ---------- HERO ---------- */
.hero{
  position:relative; padding:140px 0 60px;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(60% 50% at 80% 30%, rgba(26,107,142,.10), transparent 60%),
    radial-gradient(40% 40% at 10% 70%, rgba(232,183,160,.18), transparent 60%);
  pointer-events:none;
}
.hero-watermark{
  position:absolute; right:-120px; top:60px; width:760px; opacity:.07; z-index:0;
  pointer-events:none;
}
.hero-grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.05fr 1fr;
  gap:40px; align-items:end;
  min-height:78vh;
}
.hero-copy{ padding-bottom:40px; }
.hero-tag{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 14px; border-radius:999px;
  background:rgba(255,255,255,.7); border:1px solid var(--line);
  font-size:12px; color:var(--ink-2); margin-bottom:32px;
  backdrop-filter:blur(8px);
}
.hero-tag .dot{ width:7px; height:7px; border-radius:999px; background:#3FB37F; box-shadow:0 0 0 3px rgba(63,179,127,.18); }
.hero-tag .dot.is-closed{ background:#D87370; box-shadow:0 0 0 3px rgba(216,115,112,.18); }

.hero h1{
  font-family:'Instrument Serif', serif;
  font-weight:400;
  font-size:clamp(46px, 7vw, 104px);
  line-height:.96;
  letter-spacing:-0.025em;
  margin:0 0 28px;
  color:var(--ink);
}
.hero h1 em{
  font-style:italic;
  color:var(--brand);
  position:relative;
  white-space:nowrap;
}
.hero h1 .swirl{
  display:inline-block; transform:translateY(.05em);
}

.hero-sub{
  max-width:480px;
  color:var(--ink-2);
  font-size:18px;
  line-height:1.55;
  margin:0 0 36px;
}
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }

.hero-meta{
  display:flex; gap:32px; margin-top:48px; padding-top:28px;
  border-top:1px solid var(--line);
  max-width:520px;
}
.hero-meta .m{ display:flex; flex-direction:column; gap:4px; }
.hero-meta .m-k{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); }
.hero-meta .m-v{ font-family:'Instrument Serif',serif; font-size:22px; color:var(--ink); }

/* doctor visual stack */
.hero-vis{
  position:relative;
  align-self:end;
  min-height:560px;
}
.hero-glow{
  position:absolute;
  left:50%; top:42%;
  transform:translate(-50%,-50%);
  width:min(560px, 100%); aspect-ratio:1;
  border-radius:999px;
  background:
    radial-gradient(circle at 50% 50%, rgba(220,233,239,.95) 0%, rgba(220,233,239,.55) 45%, rgba(220,233,239,0) 70%);
  z-index:0;
}
.hero-logo-bg{
  position:absolute;
  left:-10px; top:30px;
  width:200px;
  height:auto;
  z-index:1;
  opacity:.95;
  pointer-events:none;
  transform:rotate(-8deg);
}
.hero-doctor{
  position:absolute;
  left:50%; bottom:-12px;
  transform:translateX(-50%);
  width:min(620px, 110%);
  height:auto;
  z-index:2;
  filter:drop-shadow(0 30px 40px rgba(11,36,51,.18));
}

.hero-badge{
  position:absolute; top:18%; right:-10px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:24px;
  padding:14px 18px;
  display:flex; align-items:center; gap:12px;
  box-shadow:var(--shadow-md);
  z-index:3;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease;
}
.hero-badge:hover{ transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.hero-badge .star{ color:#E8B14B; }
.hero-badge .b-num{ font-family:'Instrument Serif',serif; font-size:28px; line-height:1; color:var(--ink); }
.hero-badge .b-cap{ font-size:11px; color:var(--ink-3); letter-spacing:.05em; }

.hero-quote{
  position:absolute; bottom:6%; left:-20px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:20px;
  padding:14px 18px 14px 50px;
  max-width:240px;
  box-shadow:var(--shadow-md);
  z-index:3;
  font-size:13px;
  color:var(--ink-2);
  line-height:1.45;
}
.hero-quote::before{
  content:''; position:absolute; left:14px; top:14px;
  width:26px; height:26px; border-radius:999px;
  background:var(--peach);
  background-image:radial-gradient(circle at 35% 35%, rgba(255,255,255,.6), transparent 60%);
}
.hero-quote .h-q-name{ display:block; margin-top:6px; font-weight:500; color:var(--ink); font-size:12px; }

@media(max-width:960px){
  .hero{ padding:120px 0 40px; }
  .hero-grid{ grid-template-columns:1fr; gap:20px; min-height:auto; }
  .hero-copy{ padding-bottom:0; position:relative; z-index:5; }
  .hero-vis{ min-height:0; aspect-ratio:2/3; max-width:480px; margin:24px auto 0; width:100%; }
  .hero-doctor{ width:100%; }
  .hero-watermark{ width:520px; right:-180px; top:120px; }
  .hero-meta{ flex-wrap:wrap; gap:20px; }
}
@media(max-width:520px){
  .hero-vis{ aspect-ratio:2/3; max-width:none; }
  .hero-logo-bg{ width:200px; top:50px; left:-30px; }
  .hero-glow{ width:90%; top:38%; }
  .hero-doctor{ width:100%; bottom:-8px; }
  .hero-badge{ top:auto; bottom:7%; right:-5px; padding:10px 14px; }
  .hero-badge .b-num{ font-size:22px; }
  .hero-quote{ display:none; }
}

/* ---------- TRUST BAR ---------- */
.trust{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.4);
}
.trust-row{
  display:grid; grid-template-columns:repeat(3, 1fr);
  padding:32px 0;
}
.trust-i{
  padding:6px 24px;
  border-right:1px solid var(--line-2);
  display:flex; flex-direction:column; gap:6px;
}
.trust-i:last-child{ border-right:0; }
.trust-i .t-n{ font-family:'Instrument Serif',serif; font-size:40px; line-height:1; color:var(--brand); letter-spacing:-.02em; }
.trust-i .t-l{ font-size:13px; color:var(--ink-2); }
@media(max-width:760px){
  .trust-row{ grid-template-columns:1fr; gap:20px 0; padding:24px 0; }
  .trust-i{ padding:8px 16px; border-right:0; }
  .trust-i .t-n{ font-size:34px; }
}

/* ---------- SECTION HEAD ---------- */
.sec{ padding:120px 0; position:relative; }
@media(max-width:760px){ .sec{ padding:84px 0; } }
.sec-head{
  display:grid; grid-template-columns:1fr 1.4fr; gap:60px;
  margin-bottom:64px; align-items:end;
}
.sec-head .eyebrow{ margin-bottom:14px; display:block; }
.sec-head h2{
  font-family:'Instrument Serif',serif;
  font-weight:400;
  font-size:clamp(38px, 5vw, 64px);
  line-height:1.02;
  letter-spacing:-.02em;
  margin:0;
  color:var(--ink);
}
.sec-head h2 em{ font-style:italic; color:var(--brand); }
.sec-head .sub{ color:var(--ink-2); max-width:520px; margin:0; font-size:17px; }
@media(max-width:840px){
  .sec-head{ grid-template-columns:1fr; gap:18px; margin-bottom:44px; }
}

/* ---------- SERVICES ---------- */
.services{ background:var(--cream); border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); }
.svc-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:0;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  overflow:hidden;
  background:var(--paper);
}
.svc{
  padding:36px 32px 32px;
  border-right:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
  display:flex; flex-direction:column; gap:14px;
  position:relative;
  transition:background .25s ease;
  min-height:280px;
}
.svc > summary{
  list-style:none;
  display:flex; flex-direction:column; gap:14px;
  align-items:flex-start;
  cursor:default;
  position:relative;
}
.svc > summary::-webkit-details-marker{ display:none; }
.svc-body{ display:flex; flex-direction:column; gap:14px; }
.svc-chev{
  display:none;
  position:absolute; top:6px; right:0;
  width:28px; height:28px;
  border-radius:999px;
  border:1px solid var(--line);
  align-items:center; justify-content:center;
  transition:transform .25s ease;
  color:var(--ink-2);
}
.svc-chev svg{ width:14px; height:14px; }
.svc:hover{ background:var(--brand-mist); }
.svc:nth-child(3n){ border-right:0; }
.svc:nth-last-child(-n+3){ border-bottom:0; }
.svc-num{
  font-family:'Instrument Serif',serif; font-style:italic;
  color:var(--brand); font-size:18px;
}
.svc h3{
  font-family:'Instrument Serif',serif;
  font-weight:400;
  font-size:28px;
  line-height:1.1;
  margin:0;
  color:var(--ink);
  letter-spacing:-.01em;
}
.svc p{ margin:0; color:var(--ink-2); font-size:14.5px; line-height:1.55; }
.svc-list{ list-style:none; padding:0; margin:auto 0 0; font-size:13px; color:var(--ink-3); display:flex; flex-wrap:wrap; gap:8px; }
.svc-list li{ padding:5px 10px; border:1px solid var(--line); border-radius:999px; background:rgba(255,255,255,.6); }
@media(max-width:900px){
  .svc-grid{ grid-template-columns:repeat(2, 1fr); }
  .svc{ min-height:auto; }
  .svc:nth-child(3n){ border-right:1px solid var(--line-2); }
  .svc:nth-child(2n){ border-right:0; }
  .svc:nth-last-child(-n+3){ border-bottom:1px solid var(--line-2); }
  .svc:nth-last-child(-n+2){ border-bottom:0; }
}
@media(max-width:560px){
  .svc-grid{ grid-template-columns:1fr; }
  .svc{
    border-right:0 !important;
    border-bottom:1px solid var(--line-2) !important;
    min-height:auto;
    padding:22px 24px;
    gap:0;
  }
  .svc:last-child{ border-bottom:0 !important; }
  .svc > summary{
    cursor:pointer;
    flex-direction:row; align-items:center;
    flex-wrap:wrap;
    padding-right:42px;
    gap:10px;
  }
  .svc > summary .svc-num{ order:0; margin-right:auto; flex-basis:100%; }
  .svc > summary h3{ font-size:22px; flex-basis:100%; }
  .svc-chev{ display:inline-flex; top:18px; }
  .svc[open] .svc-chev{ transform:rotate(180deg); }
  .svc[open] .svc-body{ margin-top:14px; animation:svcIn .25s ease; }
  @keyframes svcIn{ from{ opacity:0; transform:translateY(-4px); } to{ opacity:1; transform:none; } }
  .svc:hover{ background:transparent; }
}

/* ---------- ABOUT ---------- */
.about-grid{
  display:grid; grid-template-columns:1fr 1.1fr; gap:80px; align-items:center;
}
.about-photo{
  position:relative;
}
.about-photo .ph{
  position:relative;
  border-radius:var(--r-lg);
  overflow:hidden;
  aspect-ratio:4/5;
  background:#000;
  box-shadow:var(--shadow-lg);
}
.about-photo .ph img{ width:100%; height:100%; object-fit:cover; }
.about-photo .stamp{
  position:absolute; left:-26px; bottom:-26px;
  width:140px; height:140px;
  background:var(--paper);
  border-radius:999px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-md);
  padding:8px;
}
.about-photo .stamp img{ width:100%; height:100%; object-fit:contain; }
.about-photo .quote-card{
  position:absolute; top:30px; right:-30px;
  background:var(--paper);
  border-radius:20px;
  padding:18px 22px;
  max-width:240px;
  box-shadow:var(--shadow-md);
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-size:18px;
  line-height:1.3;
  color:var(--ink);
  border:1px solid var(--line);
}
.about-photo .quote-card::before{
  content:'“'; position:absolute; left:14px; top:-2px;
  font-family:'Instrument Serif',serif;
  font-size:54px; color:var(--brand); line-height:1;
}

.about-copy h2{
  font-family:'Instrument Serif',serif; font-weight:400;
  font-size:clamp(36px, 4.4vw, 56px);
  line-height:1.03;
  letter-spacing:-.02em;
  margin:14px 0 24px;
  color:var(--ink);
}
.about-copy h2 em{ font-style:italic; color:var(--brand); }
.about-copy p{ color:var(--ink-2); font-size:17px; margin:0 0 18px; max-width:540px; }
.about-sig{
  margin-top:28px; display:flex; align-items:center; gap:16px;
}
.about-sig .sig{ font-family:'Caveat',cursive; font-size:42px; color:var(--brand); line-height:1; }
.about-sig .sig-l{ font-size:13px; color:var(--ink-3); letter-spacing:.05em; }

.credentials{
  margin-top:36px;
  display:flex; flex-wrap:wrap; gap:10px;
}
.credentials .cred{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px; border-radius:999px;
  border:1px solid var(--line);
  background:var(--cream);
  font-size:13px; color:var(--ink-2);
}
.credentials .cred svg{ width:14px; height:14px; color:var(--brand); }

@media(max-width:900px){
  .about-grid{ grid-template-columns:1fr; gap:60px; }
  .about-photo .quote-card{ right:10px; top:20px; }
  .about-photo .stamp{ left:auto; right:20px; bottom:-30px; width:110px; height:110px; }
}

/* ---------- GALLERY ---------- */
.gallery{ background:var(--paper-2); }
.gal-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  grid-auto-rows:110px;
  gap:12px;
}
.gal-grid .gi{
  border-radius:var(--r-md);
  overflow:hidden;
  position:relative;
  background:#222;
  box-shadow:var(--shadow-sm);
  transition:transform .3s ease;
}
.gal-grid .gi img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.gal-grid .gi:hover img{ transform:scale(1.04); }
.gal-grid .gi-caption{
  position:absolute; left:14px; bottom:14px;
  background:rgba(11,36,51,.6); backdrop-filter:blur(8px);
  color:#fff; font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  padding:6px 10px; border-radius:999px;
  opacity:0; transition:opacity .25s ease;
}
.gal-grid .gi:hover .gi-caption{ opacity:1; }

/* desktop layout */
.gi-a{ grid-column:span 5; grid-row:span 3; }
.gi-b{ grid-column:span 4; grid-row:span 2; }
.gi-c{ grid-column:span 3; grid-row:span 2; }
.gi-d{ grid-column:span 4; grid-row:span 2; }
.gi-e{ grid-column:span 3; grid-row:span 2; }
.gi-f{ grid-column:span 5; grid-row:span 3; }
.gi-g{ grid-column:span 4; grid-row:span 3; }
.gi-h{ grid-column:span 3; grid-row:span 3; }

@media(max-width:900px){
  .gal-grid{ grid-template-columns:repeat(6,1fr); grid-auto-rows:90px; gap:10px; }
  .gi-a{ grid-column:span 6; grid-row:span 2; }
  .gi-b{ grid-column:span 3; grid-row:span 2; }
  .gi-c{ grid-column:span 3; grid-row:span 2; }
  .gi-d{ grid-column:span 4; grid-row:span 2; }
  .gi-e{ grid-column:span 2; grid-row:span 2; }
  .gi-f{ grid-column:span 6; grid-row:span 2; }
  .gi-g{ grid-column:span 3; grid-row:span 2; }
  .gi-h{ grid-column:span 3; grid-row:span 2; }
}

/* ---------- LOCATION ---------- */
.location{
  position:relative;
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
}
.location::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(40% 60% at 80% 30%, rgba(26,107,142,.4), transparent 70%);
}
.loc-grid{
  position:relative;
  display:grid; grid-template-columns:1.05fr 1fr; gap:80px; align-items:center;
}
.loc-photo{
  border-radius:var(--r-lg);
  overflow:hidden;
  aspect-ratio:5/4;
  box-shadow:var(--shadow-lg);
  position:relative;
}
.loc-photo img{ width:100%; height:100%; object-fit:cover; }
.loc-photo .pin{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:60px; height:60px; border-radius:999px;
  background:var(--paper); color:var(--brand);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 0 0 rgba(246,242,236,.5);
  animation:pulse 2.4s ease-out infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(246,242,236,.4); }
  100%{ box-shadow:0 0 0 28px rgba(246,242,236,0); }
}

.loc-copy h2{
  font-family:'Instrument Serif',serif; font-weight:400;
  font-size:clamp(36px, 4.4vw, 56px);
  line-height:1.03; letter-spacing:-.02em;
  margin:14px 0 24px;
  color:var(--paper);
}
.loc-copy h2 em{ font-style:italic; color:var(--peach); }
.loc-copy .sub{ color:rgba(246,242,236,.7); margin:0 0 36px; max-width:460px; }

.loc-info{
  display:grid; grid-template-columns:1fr 1fr; gap:28px 36px;
  margin-bottom:36px;
}
.loc-info .li{ display:flex; flex-direction:column; gap:6px; }
.loc-info .li-k{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:rgba(246,242,236,.5); }
.loc-info .li-v{ font-family:'Instrument Serif',serif; font-size:22px; color:var(--paper); line-height:1.2; }
.loc-info .li-v a:hover{ color:var(--peach); }
.loc-info .li-v.small{ font-family:'Geist',sans-serif; font-size:15px; font-weight:400; }

.hours{
  display:grid; grid-template-columns:repeat(2,1fr); gap:6px 24px;
  padding:24px 0 0; border-top:1px solid rgba(246,242,236,.12);
  font-size:14px;
}
.hours .h-r{ display:flex; justify-content:space-between; }
.hours .h-r .h-d{ color:rgba(246,242,236,.65); }
.hours .h-r .h-t{ color:var(--paper); }
.hours .h-r.closed .h-t{ color:rgba(246,242,236,.4); }

.loc-cta{
  display:flex; flex-wrap:wrap; gap:12px; margin-top:32px;
}
.loc-cta .cta{ background:var(--paper); color:var(--ink); }
.loc-cta .cta:hover{ background:var(--peach); color:var(--ink); }
.loc-cta .cta-light{ border-color:rgba(246,242,236,.25); color:var(--paper); }
.loc-cta .cta-light:hover{ border-color:var(--paper); }

@media(max-width:900px){
  .loc-grid{ grid-template-columns:1fr; gap:50px; }
}
@media(max-width:560px){
  .loc-info{ grid-template-columns:1fr; gap:24px; }
  .hours{ grid-template-columns:1fr; }
}

/* ---------- CTA SECTION ---------- */
.book{
  position:relative; padding:120px 0;
}
.book-card{
  background:linear-gradient(135deg, var(--brand) 0%, var(--brand-deep) 100%);
  color:#fff;
  border-radius:var(--r-xl);
  padding:80px 60px;
  position:relative;
  overflow:hidden;
  text-align:center;
}
.book-card::before{
  content:''; position:absolute; inset:0;
  background:url('../assets/logo-watermark.png') right -80px center/auto 140% no-repeat;
  opacity:.08; filter:brightness(0) invert(1);
}
.book-card .eyebrow{ color:rgba(255,255,255,.7); }
.book-card h2{
  font-family:'Instrument Serif',serif; font-weight:400;
  font-size:clamp(40px, 5.5vw, 76px); line-height:1; letter-spacing:-.02em;
  margin:18px 0 24px; position:relative;
}
.book-card h2 em{ font-style:italic; color:var(--peach-soft); }
.book-card p{ max-width:520px; margin:0 auto 40px; color:rgba(255,255,255,.8); position:relative; font-size:18px; }
.book-actions{ display:inline-flex; gap:14px; flex-wrap:wrap; justify-content:center; position:relative; }
.book-actions .cta{ background:var(--paper); color:var(--ink); }
.book-actions .cta:hover{ background:var(--peach); }
.book-actions .cta-light{ border-color:rgba(255,255,255,.3); color:#fff; }
.book-actions .cta-light:hover{ border-color:#fff; }
@media(max-width:560px){
  .book{ padding:80px 0; }
  .book-card{ padding:56px 28px; border-radius:28px; }
}

/* ---------- FOOTER ---------- */
.foot{
  background:var(--paper);
  border-top:1px solid var(--line);
  padding:64px 0 28px;
}
.foot-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:48px;
  margin-bottom:48px;
}
.foot .f-brand{ display:flex; gap:14px; align-items:flex-start; margin-bottom:18px; }
.foot .f-brand img{ height:48px; width:auto; }
.foot .f-brand .ft{ font-family:'Instrument Serif',serif; font-size:20px; line-height:1.2; }
.foot .f-brand .ft-sub{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); margin-top:6px; }
.foot p{ color:var(--ink-2); font-size:14px; max-width:340px; }
.socials{ display:flex; gap:10px; margin-top:18px; }
.socials a{
  width:38px; height:38px; border-radius:999px;
  border:1px solid var(--line);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--ink-2); transition:all .2s ease;
}
.socials a svg{ width:16px; height:16px; }
.socials a:hover{ background:var(--brand); border-color:var(--brand); color:#fff; }
.foot h4{ font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3); margin:0 0 18px; font-weight:500; }
.foot ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.foot ul a{ color:var(--ink-2); font-size:14px; transition:color .2s; }
.foot ul a:hover{ color:var(--brand); }
.foot-bottom{
  padding-top:28px; border-top:1px solid var(--line);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:12px; color:var(--ink-3);
}
@media(max-width:900px){
  .foot-grid{ grid-template-columns:1fr 1fr; gap:40px 24px; }
}
@media(max-width:640px){
  .foot{ padding:48px 0 24px; }
  .foot-grid{ grid-template-columns:1fr; gap:24px; margin-bottom:32px; }
  .foot-grid > div:not(.f-brand-col){ display:none; }
  .foot p{ font-size:13px; }
}

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

/* ---------- HOURS SECTION ---------- */
.hours-section{ background:var(--paper); }
.hours-head{
  display:flex; justify-content:space-between; align-items:center;
  gap:32px; margin-bottom:48px; flex-wrap:wrap;
}
.hours-head h2{
  font-family:'Instrument Serif',serif; font-weight:400;
  font-size:clamp(38px, 5vw, 64px); line-height:1.02; letter-spacing:-.02em;
  margin:14px 0 0; color:var(--ink);
}
.hours-head h2 em{ font-style:italic; color:var(--brand); }
.hours-status{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 16px; border-radius:999px;
  background:var(--cream); border:1px solid var(--line);
  font-size:13px; color:var(--ink-2);
}
.hours-status .status-dot{
  width:9px; height:9px; border-radius:999px;
  background:var(--ink-3);
}
.hours-status.open .status-dot{ background:#3FB37F; box-shadow:0 0 0 3px rgba(63,179,127,.2); }
.hours-status.closed .status-dot{ background:#D87370; box-shadow:0 0 0 3px rgba(216,115,112,.18); }
.hours-status .status-text strong{ color:var(--ink); font-weight:500; }

.hours-grid{
  display:grid; grid-template-columns:repeat(3, 1fr);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  overflow:hidden;
  background:var(--cream);
}
.hour-day{
  padding:26px 28px;
  display:flex; flex-direction:column; gap:6px;
  border-right:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
  position:relative;
  transition:background .2s ease;
}
.hour-day:nth-child(3n){ border-right:0; }
.hour-day:nth-last-child(-n+3){ border-bottom:0; }
.hour-day .d-name{
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-3);
}
.hour-day .d-time{
  font-family:'Instrument Serif',serif;
  font-size:28px; color:var(--ink); letter-spacing:-.01em;
}
.hour-day.closed .d-time{ color:var(--ink-3); }
.hour-day.today{
  background:var(--brand-mist);
}
.hour-day.today .d-name{ color:var(--brand); }
.hour-day.today::after{
  content:var(--today-label, 'DANAS'); position:absolute; top:14px; right:18px;
  font-size:10px; letter-spacing:.18em;
  color:var(--brand); font-weight:500;
}
@media(max-width:760px){
  .hours-grid{ grid-template-columns:1fr 1fr; }
  .hour-day:nth-child(3n){ border-right:1px solid var(--line-2); }
  .hour-day:nth-child(2n){ border-right:0; }
  .hour-day:nth-last-child(-n+3){ border-bottom:1px solid var(--line-2); }
  .hour-day:nth-last-child(-n+2){ border-bottom:0; }
  .hour-day{ padding:20px 22px; }
  .hour-day .d-time{ font-size:24px; }
}
@media(max-width:480px){
  .hours-grid{ grid-template-columns:1fr; }
  .hour-day{ border-right:0 !important; border-bottom:1px solid var(--line-2) !important; }
  .hour-day:last-child{ border-bottom:0 !important; }
}

/* ---------- TESTIMONIALS ---------- */
.testi-head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:40px; margin-bottom:60px;
}
.testi-head h2{
  font-family:'Instrument Serif',serif; font-weight:400;
  font-size:clamp(38px, 5vw, 64px); line-height:1.02; letter-spacing:-.02em;
  margin:14px 0 0; color:var(--ink); max-width:680px;
}
.testi-head h2 em{ font-style:italic; color:var(--brand); }
.testi-rating{
  display:flex; flex-direction:column; gap:6px; text-align:right;
  flex-shrink:0;
}
.testi-rating .r-stars{ color:#E8B14B; letter-spacing:2px; font-size:18px; }
.testi-rating .r-num{ font-family:'Instrument Serif',serif; font-size:46px; line-height:1; color:var(--ink); }
.testi-rating .r-cap{ font-size:12px; color:var(--ink-3); letter-spacing:.05em; }
.testi-rating .r-cap a{ color:var(--brand); border-bottom:1px solid currentColor; }

.testi-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:20px;
}
.testi-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:32px 30px;
  display:flex; flex-direction:column; gap:18px;
  position:relative;
  transition:transform .25s ease, box-shadow .25s ease;
}
.testi-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); }
.testi-card .stars{
  color:#E8B14B; font-size:14px; letter-spacing:2px;
}
.testi-card .t-body{
  font-family:'Instrument Serif',serif;
  font-size:21px; line-height:1.35;
  color:var(--ink); letter-spacing:-.005em;
  margin:0; flex:1;
}
.testi-card .t-author{
  display:flex; align-items:center; gap:12px;
  margin-top:8px; padding-top:18px;
  border-top:1px solid var(--line-2);
}
.testi-card .t-av{
  width:38px; height:38px; border-radius:999px;
  background:var(--brand-mist); color:var(--brand);
  display:flex; align-items:center; justify-content:center;
  font-family:'Instrument Serif',serif; font-size:17px; font-weight:500;
}
.testi-card .t-name{ font-size:14px; color:var(--ink); font-weight:500; }
.testi-card .t-src{ font-size:11px; color:var(--ink-3); letter-spacing:.05em; }
.testi-card .quote-mark{
  position:absolute; top:18px; right:24px;
  font-family:'Instrument Serif',serif; font-size:56px; line-height:.6;
  color:var(--brand); opacity:.18;
}

@media(max-width:900px){
  .testi-head{ flex-direction:column; align-items:flex-start; margin-bottom:40px; }
  .testi-rating{ text-align:left; }
  .testi-grid{ grid-template-columns:1fr; }
  .testi-card .t-body{ font-size:19px; }
}

/* utility */
.icon{ width:18px; height:18px; stroke-width:1.5; stroke:currentColor; fill:none; }
