/* ============================================================
   더착한치과 — Premium Tech Design System (Apple-grade)
   라이트 그레이 그라데이션 · 초미니멀 · 무채색 · 큰 제품샷.
   "세련되고 비쌈". 한 화면 = 한 메시지. 부드러운 모션.
   Pretendard 단일. 절제된 한 톤 액센트.
   ── 2026 native web tech 적용:
      View Transitions API · Scroll-driven Animations · @property
      text-wrap:balance/pretty · :has() · color-mix() · content-visibility
      Container Queries · light-dark() ready
   ============================================================ */

/* ===== 2026: View Transitions API — cross-document morph (MPA) ===== */
@view-transition { navigation: auto; }

/* ===== 2026: @property — typed custom props for smooth animatable gradients/glows ===== */
@property --glow-x { syntax: "<percentage>"; inherits: false; initial-value: 50%; }
@property --glow-y { syntax: "<percentage>"; inherits: false; initial-value: 50%; }
@property --grad-angle { syntax: "<angle>"; inherits: false; initial-value: 0deg; }
@property --ring-pct { syntax: "<number>"; inherits: false; initial-value: 0; }
@property --sheen { syntax: "<percentage>"; inherits: false; initial-value: -120%; }

/* ---------- TOKENS — "WARM PAPER × TRUST BLUE" ----------
   원장 설문 직접 반영: Q24 따뜻하고 친근한 + Q25 블루 + 믿음직한 장인.
   웜 아이보리 종이 + 트러스트 블루 액센트 + 브라스 세컨더리.
   따뜻한 신뢰. 빼기의 미학. 넉넉한 여백.                       */
:root{
  color-scheme: light;
  /* base — warm ivory / off-white (NOT pure white) */
  --bg:#FBFAF6;          /* warm ivory paper */
  --bg-2:#F4F2EC;        /* warm sand */
  --bg-3:#EAE7DD;        /* deeper sand */
  --bg-dark:#152333;     /* deep trust navy for stages */
  --bg-dark-2:#1D3049;
  --card:#FFFFFF;
  --glass:rgba(251,250,246,.72);
  --line:#E3DFD3;        /* warm hairline */
  --line-2:#D4CFC0;

  /* ink — navy near-black (trust) on warm paper */
  --ink:#1A222E;         /* navy near-black */
  --ink-2:#222C3A;       /* navy charcoal */
  --ink-3:#3E4956;
  --ink-soft:#6A737E;    /* cool secondary */
  --ink-faint:#9AA1AA;   /* cool tertiary */
  --on-dark:#F2F1EB;
  --on-dark-soft:#A8B2C0;

  /* accent — TRUST BLUE (원장 선택 컬러) + warm brass secondary */
  --accent:#1E6FB8;      /* trust blue — 믿음직한, 의료 신뢰 */
  --accent-d:#114A7E;    /* deep blue */
  --accent-l:#4A95D6;    /* light blue */
  --accent-soft:#E7F0F9; /* pale blue tint */
  --accent-2:#B08D57;    /* warm brass — 따뜻함 담당 secondary */
  --accent-teal:#2DD4BF; /* fresh teal — dark-stage glow only */

  /* type — editorial serif + clean sans pairing */
  --sans:"Pretendard Variable",Pretendard,-apple-system,BlinkMacSystemFont,"SF Pro Display",system-ui,"Segoe UI",sans-serif;
  /* Latin glyphs → Newsreader; Korean glyphs → Nanum Myeongjo (per-glyph fallback) */
  --serif:"Newsreader","Nanum Myeongjo","Pretendard Variable",Georgia,"Times New Roman",serif;
  --serif-kr:"Nanum Myeongjo","Newsreader",Georgia,serif;

  /* fluid scale — airy editorial cadence */
  --fs-display:clamp(2.7rem,6.4vw,5.2rem);
  --fs-h1:clamp(2.3rem,4.6vw,3.7rem);
  --fs-h2:clamp(1.9rem,3.7vw,3rem);
  --fs-h3:clamp(1.25rem,1.9vw,1.6rem);
  --fs-lead:clamp(1.12rem,1.5vw,1.4rem);
  --fs-eyebrow:.78rem;

  /* radius — soft, organic, not techy */
  --radius-sm:10px;
  --radius:14px;
  --radius-lg:20px;
  --radius-xl:28px;
  --radius-pill:100px;

  /* shadows — navy-tinted, soft, diffuse */
  --sh-xs:0 1px 2px rgba(20,35,55,.04);
  --sh-sm:0 4px 18px rgba(20,35,55,.05);
  --sh:0 14px 44px rgba(20,35,55,.07);
  --sh-md:0 24px 64px rgba(20,35,55,.10);
  --sh-lg:0 44px 110px rgba(20,35,55,.14);
  --sh-glow:0 30px 90px rgba(30,111,184,.18);

  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease:cubic-bezier(.4,0,.2,1);

  /* ===== legacy aliases — remapped to Calm Clinical palette ===== */
  --paper:var(--bg);
  --paper-2:var(--bg-2);
  --brand:var(--ink-2);
  --sand:var(--bg-2);
  --teal-glow:var(--accent);
  --d-fg-soft:var(--ink-soft);
  --blue:var(--accent);
  --blue-d:var(--accent-d);
  --blue-l:var(--accent-l);
  --blue-soft:var(--accent-soft);
  --blue-50:var(--accent-soft);
  --blue-100:#CFE2F4;
  --blue-grad-a:var(--ink-2);
  --blue-grad-b:var(--ink);
  --mint:var(--accent);
  --mint-50:var(--accent-soft);
  --cream:var(--bg);
  --cream-2:var(--bg-2);
  --warm-line:var(--line);
  --peach:var(--accent-2);
  --navy:var(--ink);
  --navy-2:var(--ink-2);
  --navy-3:var(--ink-3);
  --navy-soft:var(--bg-2);
  --navy-tint:var(--bg-3);
  /* gold legacy → warm brass secondary */
  --gold:var(--accent-2);
  --gold-d:#977542;
  --gold-l:#C6A56E;
  --gold-soft:#F3ECDF;
  --gold-line:var(--line-2);
  --on-navy:var(--on-dark);
  --on-navy-soft:var(--on-dark-soft);
  --line-3:var(--line-2);
}

/* ---------- RESET / BASE ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink-2);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  letter-spacing:-.012em;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
/* 2026: text-wrap balances headlines, pretties body — no orphans, even ragging */
h1,h2,h3,h4{line-height:1.08;letter-spacing:-.035em;font-weight:700;color:var(--ink);text-wrap:balance}
p,.lead,blockquote{text-wrap:pretty}
::selection{background:var(--ink);color:#fff}

/* 2026: content-visibility — skip rendering offscreen sections (faster paint) */
.assure,.philo,.core,.digital,.doctor,.journey,.compare,.tlist,.marquee-band{
  content-visibility:auto;contain-intrinsic-size:auto 600px;
}

/* ============================================================
   2026 NATIVE WEB TECH
   ============================================================ */

/* ── Scroll-driven reading progress bar (animation-timeline: scroll) ── */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:100%;z-index:2000;transform-origin:0 50%;
  transform:scaleX(0);pointer-events:none;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  box-shadow:0 0 12px color-mix(in oklab,var(--accent) 70%,transparent);
}
@supports (animation-timeline: scroll()){
  .scroll-progress{
    animation:sp-grow linear;
    animation-timeline:scroll(root block);
  }
}
@keyframes sp-grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}

/* ── Scroll-driven reveal (pure CSS, view() timeline) — progressive enhancement ── */
@supports (animation-timeline: view()){
  @media (prefers-reduced-motion: no-preference){
    .reveal{opacity:1;transform:none} /* JS class no longer required */
    .reveal:not(.in){
      animation:reveal-in linear both;
      animation-timeline:view();
      animation-range:entry 0% entry 38%;
    }
  }
}
@keyframes reveal-in{
  from{opacity:0;transform:translateY(34px)}
  to{opacity:1;transform:translateY(0)}
}

/* ── Editorial headline mask-reveal: serif h2 rises out of a clip as it enters view ── */
@supports (animation-timeline: view()){
  @media (prefers-reduced-motion: no-preference){
    .shead h2{
      animation:head-mask linear both;
      animation-timeline:view();
      animation-range:entry 4% entry 42%;
    }
  }
}
@keyframes head-mask{
  from{opacity:0;clip-path:inset(0 0 100% 0);transform:translateY(12px)}
  to{opacity:1;clip-path:inset(0 0 0 0);transform:translateY(0)}
}

/* ── View Transitions API: name persistent elements so they morph across pages ── */
@view-transition{ navigation:auto; }
::view-transition-old(root),::view-transition-new(root){
  animation-duration:.42s;animation-timing-function:var(--ease-out);
}
.site-header{view-transition-name:site-header}
.scroll-progress{view-transition-name:scroll-progress}
.floating-cta{view-transition-name:floating-cta}
@media (prefers-reduced-motion: reduce){
  ::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none !important}
}

/* ---------- LAYOUT ---------- */
.container{max-width:1080px;margin:0 auto;padding:0 28px}
.container-wide{max-width:1280px;margin:0 auto;padding:0 28px}
section{position:relative}

/* ---------- EYEBROW (minimal label) ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:var(--fs-eyebrow);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);
}
/* editorial tick before the kicker label */
.eyebrow::before{display:inline-block;content:"";width:22px;height:1px;background:var(--accent);opacity:.55}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}
.eyebrow.on-navy{color:var(--accent-2);letter-spacing:.14em}
.eyebrow.on-navy::before{background:var(--accent-2)}

/* ---------- SECTION HEAD (editorial) ---------- */
.shead{position:relative;max-width:760px;margin-bottom:60px;padding-top:30px}
/* hairline divider above the head */
.shead::before{content:"";position:absolute;top:0;left:0;width:64px;height:2px;background:var(--accent)}
.shead.center{margin-left:auto;margin-right:auto;text-align:center;padding-top:34px}
.shead.center::before{left:50%;transform:translateX(-50%)}
/* big editorial index number floating in the gutter */
.shead[data-index]::after{
  content:attr(data-index);
  position:absolute;top:18px;right:-8px;
  font-family:var(--serif);font-weight:400;font-style:normal;
  font-size:clamp(3.2rem,6vw,5.4rem);line-height:1;
  color:var(--accent);opacity:.10;letter-spacing:-.04em;pointer-events:none;
}
.shead.center[data-index]::after{right:auto;left:50%;top:-14px;transform:translateX(-50%)}
.shead h2{font-family:var(--serif);font-size:var(--fs-h2);margin:14px 0 18px;font-weight:700;letter-spacing:-.022em;line-height:1.16;word-break:keep-all}
.shead h2 em{font-style:normal;color:var(--accent);font-weight:700}
.shead h2 .gold{color:var(--accent);font-style:normal}
.shead p{font-size:var(--fs-lead);color:var(--ink-soft);line-height:1.55;font-weight:400}
/* dark-section variant (digital) */
.digital .shead::before{background:var(--accent-2)}
.digital .shead[data-index]::after{color:var(--accent-2);opacity:.14}
.section-title{font-size:var(--fs-h2);margin-bottom:14px;letter-spacing:-.04em}
.section-lead{font-size:var(--fs-lead);color:var(--ink-soft)}

/* ---------- BUTTONS (apple-style) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 26px;border-radius:var(--radius-pill);
  font-weight:500;font-size:1rem;letter-spacing:-.01em;
  transition:transform .3s var(--ease-out),background .25s,opacity .2s,box-shadow .3s;
  white-space:nowrap;cursor:pointer;
}
.btn i{font-size:.92em}
/* 2026: primary btn — sheen sweep via @property --sheen + color-mix hover tint */
.btn-primary,.btn-gold,.btn-accent{background:var(--accent);color:#fff;position:relative;overflow:hidden;isolation:isolate}
.btn-primary::after,.btn-gold::after,.btn-accent::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(105deg,transparent var(--sheen),rgba(255,255,255,.35) calc(var(--sheen) + 18%),transparent calc(var(--sheen) + 40%))}
.btn-primary:hover,.btn-gold:hover,.btn-accent:hover{background:color-mix(in oklab,var(--accent) 82%,#000);transform:scale(1.03)}
.btn-primary:hover::after,.btn-gold:hover::after,.btn-accent:hover::after{animation:sheen .7s ease-out}
@keyframes sheen{from{--sheen:-120%}to{--sheen:120%}}
.btn-ghost,.btn-outline{background:transparent;color:var(--accent);box-shadow:inset 0 0 0 1px var(--line-2)}
.btn-ghost:hover,.btn-outline:hover{box-shadow:inset 0 0 0 1px var(--accent);color:var(--accent)}
.btn-ghost.on-navy{background:transparent;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.4)}
.btn-ghost.on-navy:hover{background:rgba(255,255,255,.1);box-shadow:inset 0 0 0 1px rgba(255,255,255,.7)}
.btn-lg{padding:16px 34px;font-size:1.08rem}
.btn-nav{padding:10px 20px;font-size:.92rem}
/* apple text-link variant */
.btn-link{background:none;color:var(--accent);padding:0;font-weight:500}
.btn-link:hover{text-decoration:underline}

/* ============================================================
   HEADER — apple translucent bar
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .4s var(--ease-out)}
.site-header .bar{
  display:flex;align-items:center;gap:30px;
  max-width:1280px;margin:0 auto;padding:16px 28px;transition:all .4s var(--ease-out);
}
.site-header.scrolled{
  background:rgba(255,255,255,.72);backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.site-header.scrolled .bar{padding:11px 28px}
/* 2026: :has() — solidify header automatically while a mega-menu is open (no JS) */
.site-header:has(.nav-top>li:hover .mega),.site-header:has(.mega:hover),.site-header:has(.nav-top>li>a:focus-visible){
  background:rgba(255,255,255,.92);backdrop-filter:blur(22px) saturate(180%);
  border-bottom:1px solid rgba(0,0,0,.07);
}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand .logo{
  width:38px;height:38px;border-radius:11px;
  background:var(--ink);display:grid;place-items:center;color:#fff;font-size:1.05rem;
}
.brand .nm{display:flex;flex-direction:column;line-height:1.1}
.brand .nm b{font-size:1.12rem;font-weight:600;letter-spacing:-.03em;color:var(--ink)}
.brand .nm small{font-size:.6rem;font-weight:500;letter-spacing:.18em;color:var(--ink-faint);text-transform:uppercase}

.nav-top{display:flex;align-items:center;gap:2px;margin-left:18px}
.nav-top>li{position:relative}
.nav-top>li>a{
  display:flex;align-items:center;gap:5px;padding:8px 15px;border-radius:8px;
  font-weight:500;font-size:.95rem;color:var(--ink-2);transition:color .2s,background .2s;
}
.nav-top>li>a i{font-size:.62rem;opacity:.5;transition:transform .25s}
.nav-top>li>a:hover{color:var(--ink)}
.nav-top>li:hover>a i{transform:rotate(180deg)}

.mega,.mega-wide{
  position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(8px);
  background:rgba(255,255,255,.85);backdrop-filter:blur(24px) saturate(180%);
  border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--sh-md);padding:12px;opacity:0;visibility:hidden;transition:all .3s var(--ease-out);min-width:220px;
}
.mega-wide{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;min-width:420px}
.nav-top>li:hover .mega,.nav-top>li:hover .mega-wide{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega a,.mega-wide a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:9px;font-size:.92rem;font-weight:500;color:var(--ink-2);transition:all .18s;white-space:nowrap}
.mega a i,.mega-wide a i{width:16px;text-align:center;color:var(--ink-faint);font-size:.85rem}
.mega a:hover,.mega-wide a:hover{background:var(--bg-2);color:var(--ink)}
.mega a:hover i,.mega-wide a:hover i{color:var(--accent)}

.header-cta{display:flex;align-items:center;gap:16px;margin-left:auto;flex-shrink:0}
.header-phone{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}
.header-phone .lbl{font-size:.6rem;font-weight:500;letter-spacing:.1em;color:var(--ink-faint);text-transform:uppercase}
.header-phone .num{font-size:1.05rem;font-weight:600;color:var(--ink);letter-spacing:-.02em}
.nav-toggle{display:none;width:42px;height:42px;border-radius:11px;background:var(--bg-2);color:var(--ink);font-size:1.2rem;place-items:center}

/* ---------- MOBILE DRAWER ---------- */
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(6px);z-index:1100;opacity:0;visibility:hidden;transition:all .35s}
.drawer-backdrop.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(86vw,360px);background:rgba(255,255,255,.96);backdrop-filter:blur(20px);z-index:1101;transform:translateX(100%);transition:transform .42s var(--ease-out);overflow-y:auto;box-shadow:-20px 0 60px rgba(0,0,0,.14)}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line)}
.drawer-close{width:42px;height:42px;border-radius:11px;background:var(--bg-2);color:var(--ink-2);font-size:1.15rem;display:grid;place-items:center}
.drawer nav{padding:14px 12px}
.drawer nav>a,.drawer .dgroup>span{display:block;padding:14px 16px;font-size:1.05rem;font-weight:600;color:var(--ink);border-radius:10px}
.drawer .dsub{padding:2px 0 10px}
.drawer .dsub a{display:flex;align-items:center;gap:10px;padding:10px 28px;font-size:.95rem;color:var(--ink-soft);font-weight:400}
.drawer .dsub a i{color:var(--ink-faint);width:16px;font-size:.85rem}
.drawer-foot{padding:18px 22px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px}
.drawer-foot .btn{width:100%}

/* ============================================================
   HERO — apple "one message" stage, centered
   ============================================================ */
/* ===== HERO — Calm Clinical editorial asymmetric ===== */
.hero{
  position:relative;padding:152px 0 96px;overflow:hidden;text-align:left;
  background:
    radial-gradient(110% 80% at 88% 8%, var(--accent-soft) 0%, transparent 52%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
}
.hero-inner{
  position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;
  align-items:center;gap:clamp(40px,6vw,96px);max-width:1240px;margin:0 auto;
}
.hero-text{max-width:none}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-pill);
  background:var(--card);border:1px solid var(--line);
  font-size:.82rem;font-weight:500;color:var(--ink-soft);margin-bottom:30px;box-shadow:var(--sh-xs);
}
.hero-badge i{color:var(--accent)}
.hero h1{
  font-family:var(--serif);font-size:var(--fs-display);font-weight:700;
  letter-spacing:-.022em;margin-bottom:30px;line-height:1.08;color:var(--ink);
  word-break:keep-all;
}
.hero h1 .accent-word{
  font-style:normal;color:var(--accent);font-weight:700;
}
.hero .lead{font-size:var(--fs-lead);color:var(--ink-soft);line-height:1.62;margin:0 0 38px;max-width:520px;font-weight:400}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px;justify-content:flex-start}
.hero-trust{display:flex;flex-wrap:wrap;gap:14px 28px;justify-content:flex-start;margin:0;list-style:none;padding-top:30px;border-top:1px solid var(--line)}
.hero-trust .tc{display:flex;align-items:center;gap:9px;font-size:.92rem;font-weight:500;color:var(--ink-3)}
.hero-trust .tc i{color:var(--accent);font-size:.82rem}

/* hero visual — calm sage stage, framed editorial card */
.hero-visual{position:relative}
.hero-frame{
  position:relative;width:100%;aspect-ratio:4/5;border-radius:var(--radius-xl);overflow:hidden;margin:0;
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in oklab,var(--accent) 22%,var(--bg-dark)) 0%, transparent 62%),
    linear-gradient(160deg,var(--bg-dark-2) 0%,var(--bg-dark) 100%);
  box-shadow:var(--sh-lg);display:grid;place-items:center;
  border:1px solid color-mix(in oklab,var(--accent) 30%,var(--bg-dark));
}
.hero-frame::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 70% at 50% 100%,rgba(0,0,0,.35),transparent 55%);
}
.hero-frame .ph{font-size:8rem;color:color-mix(in oklab,var(--accent) 55%,#fff);opacity:.55;filter:drop-shadow(0 18px 36px rgba(0,0,0,.45))}
.hero-frame img{width:100%;height:100%;object-fit:cover}
.hero-stat{
  position:absolute;z-index:2;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--sh-md);
}
.hero-stat .n{font-family:var(--serif);font-size:1.7rem;font-weight:500;color:var(--ink);letter-spacing:-.02em;line-height:1}
.hero-stat .n .u{font-size:.9rem;font-weight:500;color:var(--ink-soft);margin-left:2px;font-family:var(--sans)}
.hero-stat .l{font-size:.74rem;color:var(--ink-soft);margin-top:5px;font-weight:500}
.hero-stat.s1{top:24px;left:-24px}
.hero-stat.s2{bottom:24px;right:-20px}
@media (max-width:920px){
  .hero{padding:128px 0 72px;text-align:left}
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-visual{max-width:440px;margin:0 auto;width:100%}
  .hero-frame{aspect-ratio:16/11}
  .hero-stat.s1{left:14px}
  .hero-stat.s2{right:14px}
  .hero-actions,.hero-trust{justify-content:flex-start}
}

/* ============================================================
   STAT BAND — minimal, borderless, big numbers
   ============================================================ */
.statband{padding:80px 0 30px}
.statband .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line)}
.statband .item{background:#fff;padding:40px 24px;text-align:center;transition:background .3s}
.statband .item:hover{background:var(--bg-2)}
.statband .n{font-size:3rem;font-weight:700;color:var(--ink);letter-spacing:-.05em;line-height:1}
.statband .n .u{font-size:1.1rem;font-weight:600;color:var(--ink-soft);margin-left:3px}
.statband .l{font-size:.9rem;color:var(--ink-soft);margin-top:12px;font-weight:500}

/* ============================================================
   ASSURANCE — minimal cards
   ============================================================ */
.assure{padding:110px 0}
.assure-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.assure-card{
  position:relative;background:var(--bg-2);border-radius:var(--radius-lg);border:1px solid var(--line);
  padding:44px 36px 38px;overflow:hidden;transition:transform .4s var(--ease-out),box-shadow .4s,border-color .4s;
  transform-style:preserve-3d;will-change:transform;
}
.assure-card:hover{box-shadow:var(--sh-md);border-color:var(--line-2)}
.assure-card>*{position:relative;z-index:1}
.assure-card .idx{position:absolute;top:30px;right:34px;font-size:2.4rem;font-weight:700;color:var(--line-2);letter-spacing:-.04em;z-index:1}
.assure-card .ico{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-size:1.55rem;background:#fff;color:var(--ink);margin-bottom:26px;box-shadow:var(--sh-xs)}
.assure-card h3{font-size:var(--fs-h3);margin-bottom:14px;letter-spacing:-.03em}
.assure-card p{color:var(--ink-soft);line-height:1.65;font-size:1rem;font-weight:400}
/* light-card spotlight */
.assure-card .bento-glow,.core-card .bento-glow{position:absolute;inset:0;z-index:0;opacity:0;transition:opacity .35s;pointer-events:none;
  background:radial-gradient(340px circle at var(--glow-x) var(--glow-y),rgba(0,113,227,.1),transparent 60%)}
.assure-card:hover .bento-glow,.core-card:hover .bento-glow,.assure-card:focus-within .bento-glow,.core-card:focus-within .bento-glow{opacity:1}

/* ============================================================
   PHILOSOPHY — big quote, minimal
   ============================================================ */
.philo{padding:110px 0;background:var(--ink);color:var(--on-dark)}
.philo-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:64px;align-items:center}
.philo-quote{position:relative}
.philo-quote .mark{font-size:4rem;font-weight:700;color:rgba(255,255,255,.18);line-height:.6;display:block;margin-bottom:10px}
.philo-quote blockquote{font-family:var(--serif);font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:700;line-height:1.5;letter-spacing:-.012em;color:#fff;margin-bottom:28px;word-break:keep-all}
.philo-quote cite{font-style:normal;font-weight:600;color:var(--on-dark);display:flex;flex-direction:column;gap:4px}
.philo-quote cite span{font-weight:400;font-size:.9rem;color:var(--on-dark-soft)}
.philo-values{display:flex;flex-direction:column;gap:12px}
.value-row{display:flex;gap:18px;align-items:flex-start;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:22px 24px;transition:background .3s}
.value-row:hover{background:rgba(255,255,255,.09)}
.value-row .ico{flex-shrink:0;width:48px;height:48px;border-radius:13px;background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;font-size:1.2rem}
.value-row h4{font-size:1.1rem;margin-bottom:5px;color:#fff}
.value-row p{color:var(--on-dark-soft);font-size:.94rem;line-height:1.55;font-weight:400}

/* ============================================================
   CORE TREATMENTS — big product cards
   ============================================================ */
.core{padding:110px 0}
.core-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.core-card{
  position:relative;display:flex;flex-direction:column;background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius-xl);overflow:hidden;transition:transform .45s var(--ease-out),box-shadow .45s,border-color .45s;
  transform-style:preserve-3d;will-change:transform;
}
.core-card:hover{box-shadow:var(--sh-md);border-color:var(--line-2)}
.core-card .cc-img,.core-card .cc-body{position:relative;z-index:1}
.cc-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(160deg,#1d1d1f,#0b0b0d)}
.cc-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.core-card:hover .cc-img img{transform:scale(1.05)}
.cc-img .ph{position:absolute;inset:0;display:grid;place-items:center;font-size:4rem;color:rgba(255,255,255,.18)}
.cc-num{position:absolute;top:18px;left:18px;font-size:.85rem;font-weight:600;color:rgba(255,255,255,.7);letter-spacing:.05em}
.cc-body{padding:30px 30px 34px}
.cc-body .tag{display:inline-block;font-size:.74rem;font-weight:600;letter-spacing:.02em;color:var(--accent);margin-bottom:12px}
.cc-body h3{font-size:var(--fs-h3);margin-bottom:11px;letter-spacing:-.03em}
.cc-body p{color:var(--ink-soft);line-height:1.6;font-size:.98rem;margin-bottom:18px;font-weight:400}
.cc-more{display:inline-flex;align-items:center;gap:6px;font-weight:500;font-size:.95rem;color:var(--accent)}
.cc-more i{font-size:.78rem;transition:transform .25s}
.core-card:hover .cc-more i{transform:translateX(4px)}

/* ============================================================
   DIGITAL — dark product stage with glow
   ============================================================ */
.digital{position:relative;padding:120px 0;color:var(--on-dark);overflow:hidden;
  background:radial-gradient(1100px 700px at 75% 18%,var(--bg-dark-2) 0%,var(--bg-dark) 58%)}
.digital::before{content:"";position:absolute;top:8%;right:-8%;width:620px;height:620px;border-radius:50%;
  background:radial-gradient(circle,rgba(30,111,184,.32),transparent 65%);filter:blur(40px);pointer-events:none}
.digital::after{content:"";position:absolute;bottom:-10%;left:-6%;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(176,141,87,.12),transparent 65%);filter:blur(40px);pointer-events:none}
.digital .container{position:relative;z-index:1}
.digital .eyebrow{color:color-mix(in oklab,var(--accent) 60%,#fff)}
.digital .shead h2{color:#fff;letter-spacing:-.026em;font-family:var(--serif);font-weight:700}
.digital .shead h2 span{color:var(--accent-2)}
.digital .shead p{color:var(--on-dark-soft)}
/* subtle noise overlay */
.bento-noise{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E")}

/* ===== BENTO GRID ===== */
.bento{position:relative;z-index:1;display:grid;grid-template-columns:repeat(6,1fr);
  grid-auto-rows:minmax(110px,auto);gap:18px}
.bento-card{position:relative;overflow:hidden;border-radius:var(--radius-lg);
  background:linear-gradient(160deg,rgba(255,255,255,.075),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.09);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.07),0 24px 50px -30px rgba(0,0,0,.6);
  padding:28px;display:flex;flex-direction:column;justify-content:flex-end;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s,box-shadow .35s;
  transform-style:preserve-3d;will-change:transform;
  /* 2026: container queries — cards adapt to their own width, not viewport */
  container-type:inline-size}
.bento-card:hover{border-color:rgba(255,255,255,.2);box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 36px 70px -34px rgba(0,0,0,.7)}
/* 2026: animated conic gradient border via @property --grad-angle (only on hover/focus) */
.bento-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;z-index:0;opacity:0;
  transition:opacity .4s;pointer-events:none;
  background:conic-gradient(from var(--grad-angle),transparent 0deg,color-mix(in oklab,var(--accent) 90%,#fff) 70deg,var(--accent-2) 150deg,transparent 230deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude}
.bento-card:hover::before,.bento-card:focus-within::before{opacity:.9;animation:grad-spin 4s linear infinite}
@keyframes grad-spin{to{--grad-angle:360deg}}
/* mouse spotlight glow — driven by @property typed --glow-x/--glow-y for smoothness */
.bento-glow{position:absolute;inset:0;z-index:0;opacity:0;transition:opacity .35s;pointer-events:none;
  background:radial-gradient(360px circle at var(--glow-x) var(--glow-y),rgba(45,212,191,.22),transparent 60%)}
.bento-card:hover .bento-glow,.bento-card:focus-within .bento-glow{opacity:1}
.bento-card>*{position:relative;z-index:1}
.bento-kicker{display:inline-flex;align-items:center;gap:7px;font-size:.74rem;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;color:color-mix(in oklab,var(--accent) 50%,#fff);margin-bottom:14px}
.bento-card h3{color:#fff;font-size:1.5rem;line-height:1.2;letter-spacing:-.02em;margin-bottom:12px;font-weight:700;font-family:var(--serif);word-break:keep-all}
.bento-card h4{color:#fff;font-size:1.1rem;letter-spacing:-.01em;margin-bottom:7px;font-weight:600}
.bento-card p{color:var(--on-dark-soft);font-size:.92rem;line-height:1.55;font-weight:400}
.bento-icon{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;font-size:1.35rem;color:#fff;
  background:linear-gradient(150deg,rgba(30,111,184,.6),rgba(45,212,191,.3));margin-bottom:16px;
  box-shadow:0 10px 30px -12px rgba(30,111,184,.6)}
/* card spans */
.b-feature{grid-column:span 4;grid-row:span 2;justify-content:flex-end;min-height:380px;padding:0}
.b-feature .bento-img{position:absolute;inset:0;z-index:0}
.b-feature .bento-img img{width:100%;height:100%;object-fit:cover;opacity:.62}
.b-feature .bento-img-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,13,.1) 0%,rgba(11,11,13,.55) 55%,rgba(11,11,13,.92) 100%)}
.b-feature .bento-body{position:relative;z-index:2;padding:34px}
.b-feature h3{font-size:2rem}
.b-ring{grid-column:span 2;grid-row:span 2;align-items:center;justify-content:center;text-align:center;gap:6px}
.b-lab{grid-column:span 3}
.b-plagen{grid-column:span 3}
.b-pain{grid-column:span 3}
.b-scan{grid-column:span 3}
.bento-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.bento-chips span{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:500;color:#fff;
  padding:6px 12px;border-radius:var(--radius-pill);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1)}
.bento-chips span b{color:#7fb4ff;font-weight:700}
.bento-dots{display:flex;gap:7px;margin-top:18px}
.bento-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.25)}
.bento-dots span:first-child{background:var(--accent);box-shadow:0 0 14px var(--accent)}
/* 2026: container query — when a bento card itself is narrow, shrink its type */
@container (max-width: 320px){
  .bento-card h3{font-size:1.3rem}
  .bento-card{padding:22px}
  .b-feature .bento-body{padding:24px}
}
/* progress ring */
.ring{position:relative;width:150px;height:150px}
.ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring circle{fill:none;stroke-width:9;stroke-linecap:round}
.ring .ring-bg{stroke:rgba(255,255,255,.1)}
.ring .ring-fg{stroke:#2DD4BF;stroke-dasharray:327;stroke-dashoffset:327;transition:stroke-dashoffset 1.6s cubic-bezier(.2,.7,.2,1);
  filter:drop-shadow(0 0 8px rgba(45,212,191,.6))}
.ring.on .ring-fg{stroke-dashoffset:var(--off,7);animation:ring-pulse 2.6s ease-in-out 1.6s infinite}
@keyframes ring-pulse{0%,100%{filter:drop-shadow(0 0 7px rgba(45,212,191,.55))}50%{filter:drop-shadow(0 0 15px rgba(45,212,191,.8))}}
.ring-num{position:absolute;inset:0;display:grid;place-items:center;font-size:2.4rem;font-weight:500;color:#fff;letter-spacing:-.03em;font-family:var(--serif)}
.ring-num i{font-size:1.2rem;font-style:normal;color:var(--on-dark-soft);margin-left:2px}

/* ===== MARQUEE ===== */
.marquee-band{padding:34px 0;background:var(--bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.marquee{position:relative;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:0;width:max-content;animation:mq 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
/* 2026: scroll-driven marquee speed-up — track scrubs with page scroll for parallax feel */
@supports (animation-timeline: scroll()){
  .marquee-track{animation:mq 38s linear infinite,mq-scrub linear;animation-timeline:auto,scroll(root block)}
}
@keyframes mq-scrub{to{transform:translateX(-50%)}}
.mq-item{display:inline-flex;align-items:center;gap:14px;padding:0 30px;font-size:1.15rem;font-weight:600;color:var(--ink-3);letter-spacing:-.02em;white-space:nowrap}
.mq-item i{font-size:.32rem;color:var(--accent)}
@keyframes mq{to{transform:translateX(-50%)}}

/* ============================================================
   DOCTOR — big portrait, minimal info
   ============================================================ */
.doctor{padding:110px 0;background:var(--bg-2)}
.doctor-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.doctor-photo{position:relative;border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:4/5;background:linear-gradient(160deg,#1d1d1f,#0b0b0d);box-shadow:var(--sh-md)}
.doctor-photo img{width:100%;height:100%;object-fit:cover}
.doctor-photo .ph{position:absolute;inset:0;display:grid;place-items:center;font-size:6rem;color:rgba(255,255,255,.18)}
.doctor-photo .ribbon{position:absolute;bottom:24px;left:24px;background:rgba(255,255,255,.85);backdrop-filter:blur(14px);color:var(--ink);font-weight:600;font-size:.92rem;padding:9px 20px;border-radius:var(--radius-pill)}
.doctor-info .lic{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;font-weight:500;color:var(--accent);margin-bottom:18px}
.doctor-info h3{font-size:clamp(2rem,3.4vw,2.8rem);margin-bottom:8px;letter-spacing:-.04em}
.doctor-info h3 span{font-size:.5em;font-weight:500;color:var(--ink-soft);margin-left:8px}
.doctor-info .tl{font-size:1.3rem;font-weight:600;color:var(--ink);margin-bottom:18px;letter-spacing:-.03em}
.doctor-info .ph-text{color:var(--ink-soft);line-height:1.7;margin-bottom:26px;font-size:1.05rem;font-weight:400}
.doctor-creds{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:30px}
.doctor-creds .cred{display:inline-flex;align-items:center;gap:8px;font-size:.88rem;font-weight:500;color:var(--ink-2);background:#fff;border:1px solid var(--line);padding:9px 16px;border-radius:var(--radius-pill)}
.doctor-creds .cred i{color:var(--ink-faint)}

/* ============================================================
   JOURNEY — minimal numbered
   ============================================================ */
.journey{padding:110px 0}
.journey-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;counter-reset:jstep}
.journey-step{position:relative;counter-increment:jstep;background:#fff;padding:40px 30px;transition:background .3s}
.journey-step:hover{background:var(--bg-2)}
.journey-step .num{display:block;font-size:.85rem;font-weight:600;color:var(--accent);margin-bottom:22px;letter-spacing:.05em}
.journey-step .num::before{content:"0" counter(jstep)}
.journey-step .ico{width:52px;height:52px;border-radius:14px;background:var(--bg-2);color:var(--ink);display:grid;place-items:center;font-size:1.3rem;margin-bottom:20px}
.journey-step:hover .ico{background:#fff}
.journey-step h4{font-size:1.15rem;margin-bottom:9px;letter-spacing:-.02em}
.journey-step p{color:var(--ink-soft);font-size:.92rem;line-height:1.55;font-weight:400}

/* ============================================================
   COMPARE TABLE — minimal monochrome
   ============================================================ */
.compare{padding:110px 0;background:var(--bg-2)}
.compare-table{max-width:980px;margin:0 auto;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--sh-sm)}
.compare-table .row{display:grid;grid-template-columns:1.1fr 1.4fr 1.1fr;align-items:stretch}
.compare-table .row+.row{border-top:1px solid var(--line)}
.compare-table .row.head{background:var(--ink);color:#fff}
.compare-table .row.head .cell{font-weight:600;padding:22px 28px;display:flex;align-items:center;gap:8px;letter-spacing:-.02em}
.compare-table .row.head .cell.us{background:rgba(255,255,255,.08)}
.compare-table .cell{padding:20px 28px;display:flex;align-items:center;gap:10px;font-size:.98rem}
.compare-table .cell.label{font-weight:600;color:var(--ink);background:var(--bg-2)}
.compare-table .cell.us{font-weight:600;color:var(--ink)}
.compare-table .cell.us i{color:var(--accent);font-size:1.05rem}
.compare-table .cell.them{color:var(--ink-faint)}
.compare-table .cell.them i{color:var(--line-2);font-size:.9rem}

/* ============================================================
   TLIST — all departments, minimal
   ============================================================ */
.tlist{padding:110px 0}
.tlist-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.tlist-card{display:flex;align-items:center;gap:14px;background:var(--bg-2);border-radius:var(--radius);padding:20px;transition:transform .3s var(--ease-out),background .3s}
.tlist-card:hover{transform:translateY(-4px);background:var(--bg-3)}
.tlist-card .ico{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:#fff;color:var(--ink);display:grid;place-items:center;font-size:1.1rem;box-shadow:var(--sh-xs)}
.tlist-card .nm{font-weight:600;font-size:1rem;color:var(--ink);letter-spacing:-.02em}
.tlist-card .sub{font-size:.8rem;color:var(--ink-faint);margin-top:2px}

/* ============================================================
   CTA BAND — dark stage
   ============================================================ */
.cta-band{padding:130px 0;overflow:hidden;background:radial-gradient(900px 500px at 50% 0%,var(--bg-dark-2),var(--bg-dark));color:var(--on-dark);text-align:center}
.cta-band::before{content:"";position:absolute;bottom:-160px;left:50%;transform:translateX(-50%);width:760px;height:420px;background:radial-gradient(circle,rgba(30,111,184,.28),transparent 70%);filter:blur(30px)}
.cta-band .inner{position:relative;z-index:1;max-width:720px;margin:0 auto}
.cta-band .eyebrow{color:var(--accent)}
.cta-band h2{color:#fff;font-family:var(--serif);font-weight:700;font-size:var(--fs-h1);margin:16px 0 18px;letter-spacing:-.022em;line-height:1.2;word-break:keep-all}
.cta-band h2 .gold{color:#fff}
.cta-band p{color:var(--on-dark-soft);font-size:var(--fs-lead);margin-bottom:34px;font-weight:400}
.cta-band .actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.cta-band .btn-gold{background:#fff;color:var(--ink)}
.cta-band .btn-gold:hover{background:var(--bg-2);transform:scale(1.03)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--bg-2);color:var(--ink-soft);padding:72px 0 30px;border-top:1px solid var(--line)}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--line)}
.footer-brand .brand .nm b{color:var(--ink)}
.footer-brand .brand .nm small{color:var(--ink-faint)}
.footer-brand p{margin:18px 0;line-height:1.7;font-size:.92rem;max-width:300px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:40px;height:40px;border-radius:11px;background:#fff;color:var(--ink-2);display:grid;place-items:center;transition:all .25s;box-shadow:var(--sh-xs)}
.footer-social a:hover{color:var(--accent);transform:translateY(-3px)}
.footer-col h5{color:var(--ink);font-size:.95rem;font-weight:600;margin-bottom:16px}
.footer-col a,.footer-col p{display:block;font-size:.9rem;color:var(--ink-soft);margin-bottom:11px;transition:color .2s}
.footer-col a:hover{color:var(--ink)}
.footer-bottom{padding-top:26px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;align-items:center}
.footer-bottom .links{display:flex;gap:20px}
.footer-bottom .links a{font-size:.85rem;color:var(--ink-soft)}
.footer-bottom .links a:hover{color:var(--ink)}
.footer-bottom .copy{font-size:.82rem;color:var(--ink-faint)}
.footer-disclaimer{margin-top:18px;font-size:.78rem;color:var(--ink-faint);line-height:1.6}

/* ============================================================
   FLOATING CTA (mobile)
   ============================================================ */
.floating-cta{position:fixed;bottom:16px;left:16px;right:16px;z-index:900;display:none;gap:10px}
.floating-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;border-radius:var(--radius);font-weight:600;font-size:1rem;box-shadow:var(--sh-md)}
.floating-cta .call{background:#fff;color:var(--ink);border:1px solid var(--line-2)}
.floating-cta .book{background:var(--accent);color:#fff}

/* ============================================================
   PAGE HERO (inner pages) — minimal light grey stage
   ============================================================ */
.page-hero{position:relative;padding:160px 0 70px;overflow:hidden;background:linear-gradient(180deg,#fff,var(--bg-2));text-align:center}
.page-hero.has-img .bg{position:absolute;inset:0;z-index:0}
.page-hero.has-img .bg img{width:100%;height:100%;object-fit:cover;opacity:.1}
.page-hero.has-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.7),var(--bg-2))}
.page-hero .container,.page-hero .ph-inner{position:relative;z-index:2}
.page-hero .eyebrow{margin-bottom:16px}
.page-hero h1{font-size:var(--fs-h1);margin-bottom:16px;letter-spacing:-.04em}
.page-hero p{font-size:var(--fs-lead);color:var(--ink-soft);max-width:640px;margin:0 auto;font-weight:400}
.page-hero .hero-badge{margin-bottom:18px}
.page-hero .ph-actions,.page-hero .hero-actions{margin-top:28px;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.page-hero .btn-ghost{background:transparent}
.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.85rem;color:var(--ink-faint);margin-bottom:24px;justify-content:center}
.breadcrumb a{color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb .sep,.breadcrumb i{font-size:.7rem;opacity:.5}
.on-light .breadcrumb,.on-light .breadcrumb a{color:var(--ink-soft)}

/* ============================================================
   DETAIL LAYOUT (treatment pages)
   ============================================================ */
.detail-section{padding:80px 0}
.detail-layout{display:grid;grid-template-columns:240px 1fr;gap:60px;align-items:start;text-align:left}
.detail-toc{position:sticky;top:100px;background:var(--bg-2);border-radius:var(--radius);padding:24px}
.detail-toc .toc-label{font-size:.72rem;font-weight:600;letter-spacing:.06em;color:var(--ink-faint);text-transform:uppercase;margin-bottom:14px;display:block}
.detail-toc a{display:block;padding:9px 12px;border-radius:9px;font-size:.92rem;color:var(--ink-soft);font-weight:500;transition:all .2s}
.detail-toc a:hover{background:#fff;color:var(--ink)}
.detail-body>h2{font-size:var(--fs-h3);margin:0 0 16px;letter-spacing:-.03em}
.detail-body section{margin-bottom:52px;scroll-margin-top:100px}
.detail-body p{color:var(--ink-3);line-height:1.8;margin-bottom:14px}
.aeo-answer{background:var(--bg-2);border-left:3px solid var(--accent);border-radius:var(--radius);padding:24px 28px;margin-bottom:28px}
.aeo-answer p{margin:0;color:var(--ink-2);font-weight:400}

.sub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin:8px 0 20px}
.sub-card{background:var(--bg-2);border-radius:var(--radius);padding:26px;transition:transform .3s,background .3s}
.sub-card:hover{transform:translateY(-4px);background:var(--bg-3)}
.sub-card h4{font-size:1.08rem;margin-bottom:8px;color:var(--ink);letter-spacing:-.02em}
.sub-card p{font-size:.92rem;color:var(--ink-soft);line-height:1.6;margin:0;font-weight:400}
.cmp-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius);overflow:hidden;margin:8px 0;box-shadow:var(--sh-xs)}
.cmp-table th,.cmp-table td{padding:15px 18px;text-align:left;font-size:.94rem;border-bottom:1px solid var(--line)}
.cmp-table th{background:var(--ink);color:#fff;font-weight:600}
.cmp-table tr:last-child td{border-bottom:none}
.cmp-table td{background:#fff}
.related-box{background:var(--bg-2);border-radius:var(--radius-lg);padding:32px;margin-top:32px}
.related-box h3{font-size:1.2rem;margin-bottom:16px;letter-spacing:-.02em}
.chip-row,.chip{display:inline-flex}
.chip-row{flex-wrap:wrap;gap:10px}
.chip{align-items:center;gap:8px;background:#fff;border:1px solid var(--line-2);border-radius:var(--radius-pill);padding:9px 18px;font-size:.9rem;font-weight:500;color:var(--ink-2);transition:all .2s}
.chip:hover{border-color:var(--ink);color:var(--ink);transform:translateY(-2px)}
.chip i{color:var(--ink-faint)}

/* ============================================================
   FAQ
   ============================================================ */
.faq-wrap,.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .3s}
.faq-item:hover{border-color:var(--line-2)}
.faq-item.open{border-color:var(--ink-faint)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 26px;font-size:1.05rem;font-weight:600;color:var(--ink);text-align:left;letter-spacing:-.02em}
.faq-q .ico,.faq-icon{flex-shrink:0;width:28px;height:28px;border-radius:8px;background:var(--bg-2);color:var(--ink);display:grid;place-items:center;font-size:.85rem;transition:transform .35s var(--ease-out)}
.faq-item.open .faq-q .ico,.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--ink);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 26px 24px;color:var(--ink-soft);line-height:1.75;font-size:.97rem;font-weight:400}

/* ============================================================
   GENERIC SECTIONS / CARDS
   ============================================================ */
.sec{padding:90px 0}
.sec-sm{padding:60px 0}
.section{padding:90px 0}
.section.sand{background:var(--bg-2)}
.section.navy{background:var(--ink);color:var(--on-dark)}
.card,.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--sh-xs)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--sh)}
.value-card,.tc-icon,.stat,.stats .stat{background:var(--bg-2);border-radius:var(--radius);padding:28px}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px}
.stat .num,.num-tag{font-size:2.4rem;font-weight:700;color:var(--ink);letter-spacing:-.04em}
.stat .lbl{color:var(--ink-soft);font-size:.9rem;margin-top:6px}

.license{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px 20px;display:flex;align-items:center;gap:10px;box-shadow:var(--sh-xs);font-weight:500;color:var(--ink-2)}
.license i{color:var(--ink-faint)}

.doctor-card{display:grid;grid-template-columns:.7fr 1.3fr;gap:36px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--sh-xs);align-items:center}
.career-timeline{position:relative;padding-left:28px}
.career-timeline li{position:relative;padding:0 0 18px 8px;color:var(--ink-3);line-height:1.6}
.career-timeline li::before{content:"";position:absolute;left:-20px;top:8px;width:9px;height:9px;border-radius:50%;background:var(--ink);box-shadow:0 0 0 4px var(--bg-2)}
.career-timeline::after{content:"";position:absolute;left:-16px;top:8px;bottom:8px;width:1px;background:var(--line-2)}

.hours-table{width:100%;border-collapse:collapse}
.hours-table td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:.95rem}
.hours-table td:first-child{font-weight:600;color:var(--ink)}
.hours-table td:last-child{color:var(--ink-soft);text-align:right}

.form-field,.field{margin-bottom:18px}
.form-field label,.field label,.lbl{display:block;font-weight:600;font-size:.9rem;color:var(--ink);margin-bottom:8px}
.form-field input,.form-field select,.form-field textarea,.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line-2);border-radius:12px;font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus,.field input:focus,.field textarea:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,.06)}
.checkbox-row{display:flex;align-items:center;gap:10px;font-size:.92rem;color:var(--ink-2)}

.ba-slider{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--sh);user-select:none;aspect-ratio:16/10;background:var(--bg-3)}
.ba-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba-after,.after{clip-path:inset(0 0 0 50%)}
.ba-handle,.handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;box-shadow:0 0 0 1px rgba(0,0,0,.1);cursor:ew-resize}
.ba-handle::after,.handle::after{content:"\f337";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:#fff;color:var(--ink);display:grid;place-items:center;box-shadow:var(--sh)}
.ba-label{position:absolute;top:14px;padding:6px 14px;border-radius:var(--radius-pill);font-size:.8rem;font-weight:600;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);color:var(--ink)}

.article-body{max-width:760px;margin:0 auto;line-height:1.85;color:var(--ink-3)}
.article-body h2{font-size:1.6rem;margin:40px 0 16px;letter-spacing:-.03em}
.article-body h3{font-size:1.25rem;margin:30px 0 12px;letter-spacing:-.02em}
.article-body p{margin-bottom:18px}
.article-body img{border-radius:var(--radius);margin:24px 0}

.go{display:inline-flex;align-items:center;gap:6px;font-weight:500;color:var(--accent)}
.grad{color:var(--ink)}

/* ============================================================
   REVEAL ANIMATION — apple-style fade up
   ============================================================ */
.reveal,.reveal-up,.reveal-scale{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.reveal-scale{transform:scale(.97)}
.reveal.in,.reveal-up.in,.reveal-scale.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-up,.reveal-scale{opacity:1 !important;transform:none !important;transition:none}
  *{scroll-behavior:auto !important}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .philo-grid,.digital-grid,.doctor-grid{grid-template-columns:1fr;gap:44px}
  .doctor-photo{max-width:440px;margin:0 auto;aspect-ratio:4/4}
  .statband .grid{grid-template-columns:repeat(2,1fr)}
  .core-grid{grid-template-columns:repeat(2,1fr)}
  /* bento → 2 columns */
  .bento{grid-template-columns:repeat(2,1fr)}
  .b-feature{grid-column:span 2;grid-row:auto;min-height:340px}
  .b-ring,.b-lab,.b-plagen,.b-pain,.b-scan{grid-column:span 1;grid-row:auto}
  .b-ring{min-height:240px}
  .journey-grid{grid-template-columns:repeat(2,1fr)}
  .tlist-grid{grid-template-columns:repeat(3,1fr)}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .detail-layout{grid-template-columns:1fr}
  .detail-toc{position:static;margin-bottom:24px}
  .nav-top,.header-phone{display:none}
  .hero-stat.s1{top:14px;left:14px}
  .hero-stat.s2{bottom:14px;right:14px}
}
@media (max-width:760px){
  .nav-toggle{display:grid}
  .header-cta .btn-nav{display:none}
  .assure-grid,.core-grid,.grid-2,.grid-3,.split{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr;gap:14px}
  .b-feature,.b-ring,.b-lab,.b-plagen,.b-pain,.b-scan{grid-column:span 1}
  .bento-card{padding:24px}
  .bento-card h3,.b-feature h3{font-size:1.5rem}
  .mq-item{font-size:1rem;padding:0 20px}
  .journey-grid{grid-template-columns:1fr 1fr}
  .tlist-grid{grid-template-columns:repeat(2,1fr)}
  .doctor-card{grid-template-columns:1fr}
  .hero{padding:140px 0 0}
  .hero-stat{padding:10px 14px}
  .hero-stat .n{font-size:1.4rem}
  .floating-cta{display:flex}
  body{padding-bottom:78px}
  section,.assure,.philo,.core,.digital,.doctor,.journey,.compare,.tlist,.cta-band{padding-top:72px;padding-bottom:72px}
  .compare-table .row{grid-template-columns:1fr}
  .compare-table .row.head{display:none}
  .compare-table .cell{padding:14px 22px}
  .compare-table .cell::before{content:attr(data-l);font-weight:600;color:var(--ink-faint);margin-right:auto;font-size:.85rem}
  .compare-table .cell.label{justify-content:flex-start;font-size:1.05rem;background:var(--bg-2)}
  .compare-table .cell.label::before{display:none}
}
@media (max-width:460px){
  .statband .grid{grid-template-columns:1fr 1fr}
  .tlist-grid,.journey-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
}

/* ============================================================
   CALM CLINICAL — restrained motion layer
   빼기의 미학. 단 하나의 절제된 모션: 줄별 페이드업 + 미세 종이 질감.
   (오로라 블롭 · 마그네틱 버튼 · 글로우 커서 제거)
   ============================================================ */

@property --wght { syntax: "<number>"; inherits: false; initial-value: 500; }

.hero{position:relative;overflow:hidden;isolation:isolate}
.hero-inner,.hero-visual{position:relative;z-index:1}

/* ===== KINETIC TYPOGRAPHY — 줄별 차분한 페이드업 (와이프 제거) ===== */
.kinetic .line{display:block}
@media (prefers-reduced-motion: no-preference){
  .hero-text .kinetic .line{opacity:0;transform:translateY(14px);animation:line-rise .9s var(--ease-out) forwards}
  .hero-text .kinetic .line:nth-child(1){animation-delay:.10s}
  .hero-text .kinetic .line:nth-child(2){animation-delay:.22s}
  .hero-text .kinetic .line:nth-child(3){animation-delay:.34s}
}
@keyframes line-rise{to{opacity:1;transform:none}}

/* ===== FILM GRAIN — 종이 질감, 더 미세하게 (정적) ===== */
.grain{position:fixed;inset:0;z-index:2500;pointer-events:none;opacity:.025;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
@media (prefers-reduced-motion: reduce){.grain{display:none}}

/* ============================================================
   FABLE LAYER — 환자 1인칭 여정 스크롤텔링 + 퍼널 10단계 스토리맵
   ============================================================ */

/* ===== FABLE — 5장 스크롤텔링 ===== */
.fable{padding:120px 0;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);position:relative;content-visibility:auto;contain-intrinsic-size:auto 1800px}
.fable-track{position:relative;max-width:860px;margin:64px auto 0;padding-left:64px}
.fable-spine{position:absolute;left:23px;top:0;bottom:0;width:2px;background:var(--line-2);border-radius:2px;overflow:hidden}
.fable-spine-fill{display:block;width:100%;height:100%;background:linear-gradient(180deg,var(--accent),var(--accent-2));transform-origin:top;transform:scaleY(0)}
@supports (animation-timeline: scroll()){
  .fable-track{view-timeline:--fable block}
  .fable-spine-fill{animation:spine-grow linear forwards;animation-timeline:--fable;animation-range:entry 10% exit 90%}
}
@keyframes spine-grow{from{transform:scaleY(0)}to{transform:scaleY(1)}}

.fable-chapter{position:relative;margin-bottom:56px}
.fable-chapter:last-child{margin-bottom:0}
.fable-marker{position:absolute;left:-64px;top:8px;width:48px;height:48px;border-radius:50%;background:var(--card);border:2px solid var(--accent);display:grid;place-items:center;box-shadow:0 4px 14px rgba(30,111,184,.16);z-index:1}
.fable-no{font-family:var(--serif);font-weight:600;font-size:1.05rem;color:var(--accent)}
.fable-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg,20px);padding:38px 40px;overflow:hidden;transition:box-shadow .35s,transform .35s}
.fable-card:hover{box-shadow:0 18px 44px rgba(20,35,55,.09);transform:translateY(-3px)}
.fable-kicker{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);margin-bottom:14px}
.fable-card h3{font-family:var(--serif);font-size:1.5rem;font-weight:700;letter-spacing:-.015em;margin-bottom:16px;color:var(--ink)}
.fable-narration{font-family:var(--serif-kr);font-style:normal;font-size:1.08rem;line-height:1.85;color:var(--ink-3);margin-bottom:22px;word-break:keep-all;text-wrap:pretty}
.fable-guide{border-top:1px dashed var(--line-2);padding-top:18px}
.fable-guide .fg-label{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;font-weight:700;color:var(--accent);margin-bottom:8px;letter-spacing:.04em}
.fable-guide p{font-size:.95rem;line-height:1.7;color:var(--ink-soft);word-break:keep-all}
.fable-coda{margin:72px auto 0;max-width:640px;text-align:center;font-family:var(--serif-kr);font-size:1.25rem;font-weight:700;color:var(--ink);letter-spacing:-.01em;word-break:keep-all}
.fable-coda::before{content:"✦";display:block;color:var(--accent-2);font-size:.9rem;margin-bottom:16px}

/* ===== FUNNEL — 10단계 스토리맵 ===== */
.funnel{padding:120px 0;background:var(--bg);content-visibility:auto;contain-intrinsic-size:auto 1400px}
.funnel-phases{display:flex;justify-content:center;gap:10px;margin:48px 0 40px;flex-wrap:wrap}
.fp-tab{appearance:none;border:1px solid var(--line-2);background:var(--card);border-radius:999px;padding:10px 22px;font-family:var(--sans);font-size:.9rem;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:all .25s;display:flex;flex-direction:column;align-items:center;line-height:1.25}
.fp-tab small{font-size:.62rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}
.fp-tab:hover{border-color:var(--accent);color:var(--accent)}
.fp-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.fp-tab.active small{color:rgba(255,255,255,.7)}

.funnel-map{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.funnel-line{position:absolute;top:50%;left:2%;right:2%;height:2px;z-index:0;pointer-events:none;
  background-image:linear-gradient(90deg,var(--accent-l) 0 6px,transparent 6px 16px);background-size:16px 2px;background-repeat:repeat-x;opacity:.30;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
@media (prefers-reduced-motion: no-preference){.funnel-line{animation:funnel-flow 1.4s linear infinite}}
@keyframes funnel-flow{to{background-position:16px 0}}
.funnel-step{position:relative;z-index:1;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px 20px;transition:all .3s;display:flex;flex-direction:column;gap:8px}
.funnel-step:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(20,35,55,.09);border-color:var(--accent)}
.funnel-step.dim{opacity:.22;filter:saturate(.3)}
.fs-num{font-family:var(--serif);font-size:.85rem;font-weight:600;color:var(--accent-2);letter-spacing:.06em}
.fs-ico{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-size:1.05rem}
.funnel-step h4{font-size:1.02rem;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.funnel-step p{font-size:.83rem;line-height:1.6;color:var(--ink-soft);word-break:keep-all;flex:1}
.fs-phase{align-self:flex-start;font-size:.68rem;font-weight:700;letter-spacing:.05em;border-radius:6px;padding:3px 9px}
.fs-before{background:#EDF1ED;color:#4E7259}
.fs-visit{background:var(--accent-soft);color:var(--accent)}
.fs-after{background:#F6F0E4;color:var(--accent-2)}

/* ===== TREATMENT FABLE — 3막 우화 ===== */
.t-fable{padding:64px 0 8px;background:var(--bg)}
.t-fable-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg,20px);overflow:hidden}
.t-fable-act{background:var(--card);padding:36px 32px;position:relative;transition:background .3s}
.t-fable-act:hover{background:var(--bg-2)}
.act-no{display:block;font-family:var(--serif);font-size:.8rem;font-weight:600;letter-spacing:.16em;color:var(--accent-2);margin-bottom:6px}
.act-label{display:block;font-size:1.1rem;font-weight:700;letter-spacing:-.01em;color:var(--ink);margin-bottom:14px}
.t-fable-act p{font-family:var(--serif-kr);font-size:.95rem;line-height:1.85;color:var(--ink-3);word-break:keep-all;text-wrap:pretty}
.t-fable-act:first-child p{font-style:normal}

/* ===== responsive ===== */
@media (max-width:1080px){
  .funnel-map{grid-template-columns:repeat(3,1fr)}
  .funnel-line{display:none}
}
@media (max-width:768px){
  .fable{padding:84px 0}
  .fable-track{padding-left:50px;margin-top:44px}
  .fable-marker{left:-50px;width:40px;height:40px}
  .fable-spine{left:19px}
  .fable-card{padding:28px 24px}
  .fable-narration{font-size:1rem}
  .funnel{padding:84px 0}
  .funnel-map{grid-template-columns:repeat(2,1fr);gap:12px}
  .t-fable-grid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .funnel-map{grid-template-columns:1fr}
}

/* ============================================================
   TRUST BLUE POLISH — "따뜻한 종이 위의 신뢰 블루"
   원장 설문 반영: Q24 따뜻하고 친근한 · Q25 블루 · 믿음직한 장인
   recolor를 넘어선 디자인 레이어: 그라디언트 깊이 + 블루 시그니처
   ============================================================ */

/* ── 버튼: 평면 블루 → 신뢰 블루 그라디언트 (깊이감) ── */
.btn-primary,.btn-gold,.btn-accent{
  background:linear-gradient(170deg,var(--accent-l) -40%,var(--accent) 45%,var(--accent-d) 130%);
  box-shadow:0 10px 26px -10px rgba(30,111,184,.55),inset 0 1px 0 rgba(255,255,255,.22);
}
.btn-primary:hover,.btn-gold:hover,.btn-accent:hover{
  background:linear-gradient(170deg,var(--accent) -20%,var(--accent-d) 60%,#0D3A64 140%);
  box-shadow:0 14px 32px -10px rgba(30,111,184,.65),inset 0 1px 0 rgba(255,255,255,.18);
}

/* ── 히어로: accent-word에 따뜻한 손그림 밑줄 (장인의 터치) ── */
.hero h1 .accent-word{position:relative;white-space:nowrap}
.hero h1 .accent-word::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:.04em;height:.16em;z-index:-1;
  background:linear-gradient(90deg,rgba(30,111,184,.16),rgba(74,149,214,.30) 50%,rgba(45,212,191,.18));
  border-radius:999px;transform:skewX(-8deg);
}

/* ── 히어로 스테이지: 네이비 + 블루/틸 듀얼 글로우 ── */
.hero-frame{
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in oklab,var(--accent) 34%,var(--bg-dark)) 0%, transparent 62%),
    radial-gradient(80% 60% at 80% 100%, rgba(45,212,191,.14) 0%, transparent 60%),
    linear-gradient(160deg,var(--bg-dark-2) 0%,var(--bg-dark) 100%);
  border:1px solid color-mix(in oklab,var(--accent) 38%,var(--bg-dark));
}
.hero-stat .n{color:var(--accent-d)}

/* ── 히어로 배경: 페이퍼 위 블루 워시 강화 ── */
.hero{
  background:
    radial-gradient(110% 80% at 88% 8%, var(--accent-soft) 0%, transparent 55%),
    radial-gradient(60% 50% at 0% 100%, #F0EBDF 0%, transparent 60%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
}

/* ── 다크 스테이지(digital/cta-band): 네이비 위 틸 포인트 ── */
.digital .shead h2 span{color:var(--accent-teal)}
.bento-chips span b{color:#7CC4F0}
.cta-band .eyebrow{color:var(--accent-teal)}
.cta-band .eyebrow::before{background:var(--accent-teal)}

/* ── 퍼널 액티브 탭: 블루 그라디언트 ── */
.fp-tab.active{
  background:linear-gradient(170deg,var(--accent) 0%,var(--accent-d) 130%);
  border-color:var(--accent-d);
  box-shadow:0 8px 20px -8px rgba(30,111,184,.5);
}

/* ── 퍼블 스파인: 블루→틸 여정 그라디언트 ── */
.fable-spine-fill{background:linear-gradient(180deg,var(--accent-l),var(--accent) 45%,var(--accent-teal))}

/* ── 스크롤 프로그레스: 블루→틸 ── */
.scroll-progress{background:linear-gradient(90deg,var(--accent),var(--accent-teal))}

/* ── 플로팅 CTA: 그라디언트 통일 ── */
.floating-cta .book{background:linear-gradient(170deg,var(--accent) 0%,var(--accent-d) 130%)}

/* ── 브랜드 로고칩: 네이비→블루 그라디언트 (헤더 시그니처) ── */
.brand .logo{background:linear-gradient(150deg,var(--accent) 0%,var(--accent-d) 100%);box-shadow:0 4px 12px -4px rgba(30,111,184,.45)}

/* ── 카드 호버 보더: 은은한 블루 ── */
.assure-card:hover,.core-card:hover{border-color:color-mix(in oklab,var(--accent) 30%,var(--line))}
.assure-card .bento-glow,.core-card .bento-glow{
  background:radial-gradient(340px circle at var(--glow-x) var(--glow-y),rgba(30,111,184,.10),transparent 60%)}

/* ── 선택 영역: 블루 ── */
::selection{background:var(--accent);color:#fff}

/* ── 따뜻함 보존: doctor/marquee 등 웜 섹션의 브라스 포인트 유지 ── */
.doctor-photo .ribbon{color:var(--accent-d)}
.fable-coda::before{color:var(--accent)}

/* ============================================================
   VECTOR MOTION LAYER — 극한 폴리시
   히어로 치아 블루프린트 · CTA 여정 별자리 · 마이크로 모션
   ============================================================ */

/* ── 히어로 치아 블루프린트 SVG ── */
.htv{position:absolute;inset:0;width:100%;height:100%;display:block}
.htv-label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.22em;fill:rgba(124,196,240,.45)}

/* 치아 윤곽 — 스트로크 드로잉 (페이지 진입 시 그려짐) */
.htv-tooth{stroke-dasharray:1000;stroke-dashoffset:1000;
  filter:drop-shadow(0 0 14px rgba(74,149,214,.5)) drop-shadow(0 6px 28px rgba(30,111,184,.35));
  animation:htv-draw 2.6s var(--ease-out) .5s forwards}
@keyframes htv-draw{to{stroke-dashoffset:0}}
.htv-cusp{stroke-dasharray:100;stroke-dashoffset:100;animation:htv-draw-c 1.2s var(--ease-out) 2.4s forwards}
@keyframes htv-draw-c{to{stroke-dashoffset:0}}

/* 치아 전체 — 그려진 뒤 부유 */
.htv-float{animation:htv-float 7s ease-in-out 3.2s infinite}
@keyframes htv-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* 오빗 링 — 서로 반대 방향 회전 */
.htv-orbit{transform-origin:200px 235px;animation:htv-spin 36s linear infinite}
.htv-orbit.rev{animation:htv-spin 26s linear infinite reverse}
@keyframes htv-spin{to{transform:rotate(360deg)}}

/* 크로스헤어 — 미세 호흡 */
.htv-cross{animation:htv-breathe 4.5s ease-in-out infinite}
@keyframes htv-breathe{0%,100%{opacity:.85}50%{opacity:.4}}

/* 식립 타깃 — 펄스 (정밀함의 시그니처) */
.htv-target{transform-origin:158px 330px;opacity:0;animation:htv-target-in .6s var(--ease-out) 3s forwards,htv-pulse 2.4s ease-in-out 3.6s infinite}
@keyframes htv-target-in{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}
@keyframes htv-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}

/* 스캔 라인 — 위→아래 스윕 */
.htv-scan{animation:htv-scan 5.5s var(--ease) 1.2s infinite}
@keyframes htv-scan{0%{transform:translateY(96px);opacity:0}8%{opacity:1}72%{opacity:1}80%,100%{transform:translateY(352px);opacity:0}}

/* 데이터 포인트 — 순차 블링크 */
.htv-plus path{opacity:.15;animation:htv-blink 3.6s ease-in-out infinite}
.htv-plus .p2{animation-delay:.9s}
.htv-plus .p3{animation-delay:1.8s}
.htv-plus .p4{animation-delay:2.7s}
@keyframes htv-blink{0%,100%{opacity:.15}50%{opacity:.9}}

/* 헤일로 — 느린 맥동 */
.htv-halo{animation:htv-halo 8s ease-in-out infinite}
@keyframes htv-halo{0%,100%{opacity:.8}50%{opacity:1}}

/* ── CTA 여정 별자리 SVG ── */
.cta-band{position:relative}
.ctav{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.cta-band .inner{position:relative;z-index:1}
.ctav-node{animation:ctav-twinkle 4s ease-in-out infinite}
.ctav-node.n2{animation-delay:.8s}.ctav-node.n3{animation-delay:1.6s}
.ctav-node.n4{animation-delay:2.4s}.ctav-node.n5{animation-delay:3.2s}
@keyframes ctav-twinkle{0%,100%{opacity:.35}50%{opacity:1}}

/* ── 마이크로 인터랙션 극한 폴리시 ── */

/* 페이블 마커 — 현재 읽는 장 부근에서 은은한 블루 링 펄스 */
.fable-chapter:hover .fable-marker{border-color:var(--accent);box-shadow:0 0 0 6px rgba(30,111,184,.10),0 4px 14px rgba(30,111,184,.22);transition:box-shadow .4s,border-color .4s}
.fable-marker{transition:box-shadow .4s,border-color .4s}

/* 퍼널 스텝 — 호버 시 아이콘 칩 블루 반전 */
.fs-ico{transition:background .3s,color .3s,transform .3s var(--ease-out)}
.funnel-step:hover .fs-ico{background:var(--accent);color:#fff;transform:scale(1.08) rotate(-4deg)}

/* 코어 카드 — 화살표에 블루 트랙 */
.cc-more{position:relative}
.cc-more::after{content:"";position:absolute;left:0;bottom:-4px;height:1.5px;width:0;background:var(--accent);transition:width .35s var(--ease-out)}
.core-card:hover .cc-more::after{width:100%}

/* 어슈어 카드 — 아이콘 리프트 + 블루 틴트 */
.assure-card .ico{transition:transform .4s var(--ease-out),background .35s,color .35s,box-shadow .35s}
.assure-card:hover .ico{transform:translateY(-4px);background:var(--accent-soft);color:var(--accent-d);box-shadow:0 8px 20px -8px rgba(30,111,184,.35)}

/* 히어로 스탯 카드 — 부유 (시차) */
@media (prefers-reduced-motion: no-preference){
  .hero-stat.s1{animation:stat-float 6s ease-in-out 1s infinite}
  .hero-stat.s2{animation:stat-float 6s ease-in-out 2.6s infinite}
}
@keyframes stat-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* 헤더 예약 버튼 — 은은한 어텐션 링 (8초 주기, 과하지 않게) */
@media (prefers-reduced-motion: no-preference){
  .header-cta .btn-nav{animation:cta-ring 8s ease-out 4s infinite}
}
@keyframes cta-ring{0%,92%,100%{box-shadow:0 10px 26px -10px rgba(30,111,184,.55),inset 0 1px 0 rgba(255,255,255,.22),0 0 0 0 rgba(30,111,184,.35)}96%{box-shadow:0 10px 26px -10px rgba(30,111,184,.55),inset 0 1px 0 rgba(255,255,255,.22),0 0 0 9px rgba(30,111,184,0)}}

/* 마퀴 도트 — 블루/틸 교차 */
.mq-item:nth-child(even) i{color:var(--accent-teal)}

/* 컴페어 테이블 us 셀 — 호버 행 블루 워시 */
.compare-table .row:not(.head):hover .cell.us{background:var(--accent-soft);transition:background .3s}
.compare-table .cell.us{transition:background .3s}

/* 페이블 스파인 — 채워지는 끝에 글로우 헤드 (여정의 현재 위치) */
.fable-spine-fill{position:relative;box-shadow:0 0 12px rgba(30,111,184,.4)}
.fable-spine-fill::after{content:"";position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);width:8px;height:8px;border-radius:50%;
  background:var(--accent-teal);box-shadow:0 0 10px rgba(45,212,191,.8),0 0 22px rgba(45,212,191,.4)}

/* ── reduced-motion: 벡터 모션 전부 정지, 최종 상태 고정 ── */
@media (prefers-reduced-motion: reduce){
  .htv-tooth,.htv-cusp{stroke-dashoffset:0;animation:none}
  .htv-target{opacity:1;animation:none}
  .htv-float,.htv-orbit,.htv-orbit.rev,.htv-cross,.htv-scan,.htv-plus path,.htv-halo,
  .ctav-node,.hero-stat.s1,.hero-stat.s2,.header-cta .btn-nav{animation:none !important}
  .htv-scan{display:none}
  .ctav-dot{display:none}
}


/* ============ 자동 인링크 (백과사전 연결) ============ */
.inlink{color:var(--accent);text-decoration:none;border-bottom:1px dashed rgba(30,111,184,.45);transition:all .18s ease;font-weight:600}
.inlink:hover{color:var(--accent-d);border-bottom-style:solid;background:var(--accent-soft)}
