/* Paperlogy — 메인 히어로 헤드라인용 디스플레이 서체(둥글고 신뢰감). 본문은 Pretendard 유지 */
@font-face{font-family:'Paperlogy';font-weight:700;font-style:normal;font-display:swap;
  src:url('fonts/Paperlogy-7Bold.woff2') format('woff2')}
@font-face{font-family:'Paperlogy';font-weight:800;font-style:normal;font-display:swap;
  src:url('fonts/Paperlogy-8ExtraBold.woff2') format('woff2')}

:root{
  /* 참바른병원 로고 추출 팔레트 — 블루 Primary / 그린 Secondary */
  --navy:#0B3D5C; --navy2:#0F4E76;              /* 딥 블루 (다크 섹션) */
  --teal:#08A3EA; --teal-d:#0678AE;             /* Primary 블루 (기존 teal 토큰명 유지) */
  --gold:#86C11E;                                /* Secondary 그린 (기존 gold 토큰명 유지) */
  --green:#86C11E; --green-d:#5F8F12;
  --blue-tint:#E7F5FD; --green-tint:#F1F8E2;
  --proof-rose:#08A3EA; --proof-rose-2:#86C11E; --proof-cyan:#40c7ff;
  --olive:#60652E; --slate:#5F6C73;
  --ink:#1B2530; --mut:#5b6b7f; --line:#e6ecf3; --bg:#f5f8fb; --wrap:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Pretendard Variable',Pretendard,-apple-system,'Apple SD Gothic Neo','Noto Sans KR',sans-serif;color:var(--ink);background:#fff;-webkit-font-smoothing:antialiased;line-height:1.6}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
.demo-tag{position:fixed;top:84px;left:16px;z-index:80;background:rgba(14,26,40,.72);color:#9ED927;font-size:11px;font-weight:600;padding:6px 12px;border-radius:20px;backdrop-filter:blur(6px);letter-spacing:.02em;pointer-events:none}
@media(max-width:900px){.demo-tag{display:none}}

/* ---------- Header ---------- */
header{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:20px 34px;transition:.3s ease;border-bottom:1px solid transparent}
header .logo{font-size:23px;font-weight:800;letter-spacing:-.6px;color:#fff;transition:.3s}
header .logo b{color:var(--teal)}
nav.gnb{display:flex;gap:34px}
nav.gnb a{color:rgba(255,255,255,.9);font-size:15.5px;font-weight:600;position:relative;padding:4px 0;transition:.2s}
nav.gnb a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--teal);transition:.25s}
nav.gnb a:hover{color:#fff}
nav.gnb a:hover::after{right:0}
.head-right{display:flex;align-items:center;gap:18px}
.lang{color:rgba(255,255,255,.7);font-size:13px;font-weight:500}
.btn-book{background:var(--teal);color:#ffffff;font-family:'Paperlogy','Pretendard Variable',Pretendard,sans-serif;font-weight:800;font-size:14.5px;padding:11px 20px;border-radius:30px;transition:.2s}
.btn-book:hover{background:#28B4F5;transform:translateY(-1px);box-shadow:0 8px 20px rgba(8,163,234,.35)}
/* 밝은 슬라이드 위 — 다크 텍스트 헤더 */
header.on-light:not(.solid) nav.gnb a{color:var(--ink)}
header.on-light:not(.solid) nav.gnb a:hover{color:var(--teal-d)}
header.on-light:not(.solid) .lang{color:var(--mut)}
header.on-light:not(.solid) .logo img{filter:none}
/* scrolled state */
header.solid{background:#fff;border-bottom-color:var(--line);padding:14px 34px;box-shadow:0 4px 24px rgba(14,42,71,.06)}
header.solid .logo{color:var(--navy)}
header.solid nav.gnb a{color:var(--ink)}
header.solid .lang{color:var(--mut)}

/* ---------- Hero ---------- */
.hero{position:relative;height:100vh;min-height:640px;overflow:hidden;--slide-duration:6000ms}
/* ---- full-width carousel ---- */
.hero-track{position:absolute;inset:0}
.slide{position:absolute;inset:0;display:flex;align-items:center;opacity:0;z-index:0;pointer-events:none;clip-path:inset(0 0 0 0);will-change:clip-path}
.slide.is-leaving{opacity:1;z-index:1}
.slide.is-active{opacity:1;z-index:2;pointer-events:auto;animation:curtainReveal .92s cubic-bezier(.76,0,.24,1) both}
	.slide::before{content:"";position:absolute;inset:0;z-index:-2;background-image:var(--bg);background-size:cover;background-position:var(--bg-pos,center);transform-origin:var(--kb-origin,center)}
@keyframes curtainReveal{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
.curtain-sheen{position:absolute;top:0;bottom:0;left:0;z-index:1;width:clamp(82px,10vw,150px);pointer-events:none;opacity:0;transform:translate3d(-160px,0,0);background:linear-gradient(90deg,rgba(255,255,255,0) 0%,rgba(8,163,234,.2) 30%,rgba(255,255,255,.58) 48%,rgba(134,193,30,.18) 62%,rgba(255,255,255,0) 100%);filter:blur(.2px);mix-blend-mode:screen;will-change:transform,opacity}
.slide.is-active .curtain-sheen{animation:curtainSheen .9s cubic-bezier(.76,0,.24,1) both}
@keyframes curtainSheen{0%{opacity:0;transform:translate3d(-160px,0,0)}14%{opacity:.82}76%{opacity:.68}100%{opacity:0;transform:translate3d(100vw,0,0)}}
/* 좌측 텍스트 가독성 + 우측 원장 노출: 좌강조 가로 그라디언트 + 하단 비네트 */
.slide::after{content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(90deg,rgba(7,20,34,.86) 0%,rgba(8,22,38,.66) 32%,rgba(8,22,38,.22) 58%,rgba(8,22,38,.04) 100%),
    linear-gradient(0deg,rgba(6,17,30,.52) 0%,rgba(6,17,30,0) 34%)}
/* hero-in = 좌측정렬 카피 (원장은 배경 이미지에 포함) */
.hero-in{position:relative;z-index:2;width:100%;display:flex;align-items:center;padding-bottom:96px}
.hero-copy{max-width:660px;text-align:left}
/* staggered reveal — 슬라이드 활성 시 카피 요소가 순차 등장 (gamtan aosText) */
.slide .hero-copy>*{opacity:0;transform:translateY(18px);transition:opacity .24s ease,transform .32s ease}
.slide.is-active .hero-copy>*{opacity:1;transform:none;transition:opacity .68s cubic-bezier(.45,0,.2,1),transform .72s cubic-bezier(.2,.75,.25,1)}
.slide.is-active .hero-copy>:nth-child(1){transition-delay:.34s}
.slide.is-active .hero-copy>:nth-child(2){transition-delay:.44s}
.slide.is-active .hero-copy>:nth-child(3){transition-delay:.54s}
.slide.is-active .hero-copy>:nth-child(4){transition-delay:.64s}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 3px rgba(8,163,234,.22)}
/* 우측 의료진 프로모 카드 (실제 인물) */
.hero-doc{flex:none;width:290px;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 26px 64px rgba(6,18,31,.44)}
.hd-tag{background:linear-gradient(90deg,var(--navy),var(--navy2));color:#fff;text-align:center;padding:14px 12px;font-weight:800;font-size:16px;letter-spacing:-.3px;position:relative}
.hd-tag::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--green))}
.hd-photo{height:298px;background-size:cover;background-position:center top;background-color:#e9edf1}
.hd-cap{padding:16px 16px 20px;text-align:center}
.hd-cap small{color:var(--teal-d);font-weight:700;font-size:13px}
.hd-cap b{display:block;font-size:22px;font-weight:800;margin:4px 0 8px;color:var(--ink)}
.hd-cap b i{font-size:15px;font-weight:600;color:var(--mut);font-style:normal;margin-left:2px}
.hd-cap span{display:block;font-size:12.5px;color:var(--mut);line-height:1.5}
/* 좌측 플로팅 전화예약 카드 */
.hero-call{position:absolute;left:0;top:52%;transform:translateY(-50%);z-index:7;width:62px;
  background:#fff;border-radius:0 14px 14px 0;box-shadow:0 16px 40px rgba(6,18,31,.32);
  padding:16px 0 14px;display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--navy);transition:.2s}
.hero-call:hover{box-shadow:0 20px 46px rgba(8,163,234,.4)}
.hero-call .lab{font-size:11.5px;font-weight:700;color:var(--mut)}
.hero-call b{writing-mode:vertical-rl;font-size:19px;font-weight:800;letter-spacing:.04em;color:var(--navy)}
.hero-call .go{width:26px;height:26px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center}
.hero-call .go svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;transform:rotate(90deg)}
/* 공통 헥사곤 강점 4 */
.hero-hex{position:absolute;left:0;right:0;bottom:96px;z-index:4;display:flex;gap:16px;justify-content:center}
.hex{width:104px;height:116px;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:rgba(8,163,234,.92);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff}
.hex.alt{background:rgba(134,193,30,.94)}
.hex .hx-i svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.hex b{font-size:13px;font-weight:700;letter-spacing:-.3px}
/* arrows — 우하단 페어 (wrap 우측 패딩선에 정렬) */
.hero-arrow{position:absolute;bottom:38px;z-index:7;width:48px;height:48px;border-radius:50%;
  background:rgba(8,20,34,.34);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:.2s}
.hero-arrow.next{right:max(28px,calc((100% - var(--wrap))/2 + 28px))}
.hero-arrow.prev{right:max(84px,calc((100% - var(--wrap))/2 + 84px))}
.hero-arrow:hover{background:var(--teal);border-color:transparent;box-shadow:0 10px 24px rgba(8,163,234,.4)}
.hero-arrow svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.hero-arrow.prev svg{transform:rotate(180deg)}
/* 라벨 탭 내비게이터 (gamtan data-title) — 하단 좌측 정렬 */
.hero-tabs{position:absolute;left:0;right:0;bottom:26px;z-index:6;display:flex;gap:0}
.htab{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:12px 26px 12px 20px;
  background:none;border:none;border-left:1px solid rgba(255,255,255,.18);cursor:pointer;text-align:left;transition:.25s}
.htab:first-child{border-left:none;padding-left:0}
.htab .i{font-size:11px;font-weight:700;letter-spacing:.1em;color:rgba(255,255,255,.5);font-variant-numeric:tabular-nums}
.htab b{font-size:16px;font-weight:800;letter-spacing:-.3px;color:rgba(255,255,255,.66);transition:.25s}
.htab small{font-size:12px;font-weight:600;color:rgba(255,255,255,.44)}
.htab::before,.htab::after{content:"";position:absolute;left:20px;right:26px;bottom:2px;height:2px;border-radius:2px;transform-origin:left}
.htab::before{background:rgba(255,255,255,.18);transform:scaleX(0)}
.htab::after{background:var(--teal);transform:scaleX(0)}
.htab:first-child::before,.htab:first-child::after{left:0}
.htab:hover b{color:rgba(255,255,255,.9)}
.htab.is-active .i{color:var(--teal)}
.htab.is-active b{color:#fff}
.htab.is-active small{color:#bfe4fb}
.htab.is-active::before{transform:scaleX(1)}
.htab.is-active::after{animation:tabProgress var(--slide-duration) linear forwards}
@keyframes tabProgress{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:#BEE7FB;font-weight:700;font-size:14px;letter-spacing:.02em;
  background:rgba(8,163,234,.14);border:1px solid rgba(8,163,234,.4);padding:7px 15px;border-radius:30px;margin-bottom:22px}
.eyebrow .star{color:var(--gold)}
.hero h1,.hero .hero-hx{color:#fff;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:clamp(34px,5.1vw,64px);line-height:1.16;font-weight:800;letter-spacing:-1.8px;text-shadow:0 2px 34px rgba(0,0,0,.34)}
/* 히어로1(단체컷) — 상하 분리 구도 v7: 인물 상단, 카피는 하단 클린 영역 (오버레이·필터·그림자 제로) */
.hero-group-slide{align-items:flex-end}
/* v9 시네마틱 풀블리드 — 표준 슬라이드와 동일한 cover 처리 */
.hero-group-slide .hero-in{justify-content:center;padding-top:0;padding-bottom:126px;align-items:flex-end}
.hero-group-slide .hero-copy{max-width:1120px;text-align:center}
.hero-group-slide h1{font-size:clamp(30px,4.1vw,56px);color:var(--navy);line-height:1.12;letter-spacing:-1.2px;text-shadow:none}
@media(min-width:1025px){.hero-group-slide h1{white-space:nowrap}}
.hero-group-slide .cta-row{justify-content:center;margin-top:24px}
.hero-group-slide::after{background:
  linear-gradient(180deg,rgba(7,20,34,.34) 0%,rgba(7,20,34,0) 16%,rgba(7,20,34,0) 100%),
  linear-gradient(0deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.78) 14%,rgba(255,255,255,.42) 25%,rgba(255,255,255,0) 42%)}
.hero-kicker{display:inline-flex;align-items:center;justify-content:center;gap:12px;margin-bottom:18px;color:rgba(11,61,92,.76);font-size:13.5px;font-weight:800;letter-spacing:.2em}
.hero-kicker i{width:36px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--teal),var(--green))}
.hero-kicker span{letter-spacing:.06em}

/* 탭 스트립 — 라이트 글래스 필 (하단 인물 위에서도 정돈되어 보이게) */
.hero .hero-tabs{background:rgba(255,255,255,.6);backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.75);border-radius:20px;padding:10px 22px;
  left:50%;right:auto;transform:translateX(-50%);width:max-content;max-width:calc(100% - 56px);
  box-shadow:0 18px 44px rgba(14,42,71,.16)}
.htab .i{color:rgba(11,61,92,.45)}
.htab b{color:rgba(11,61,92,.62)}
.htab small{color:rgba(11,61,92,.4)}
.htab{border-left-color:rgba(11,61,92,.14)}
.htab.is-active .i{color:var(--teal-d)}
.htab.is-active b{color:var(--navy)}
.htab.is-active small{color:var(--teal-d)}
@media(max-width:900px){
  .hero-group-slide .hero-in{padding-bottom:168px}
  .hero-group-slide .hero-copy{max-width:calc(100vw - 32px)}
  .hero-group-slide h1{max-width:100%;font-size:clamp(25px,8vw,34px);line-height:1.18;letter-spacing:-.7px;white-space:normal!important;text-wrap:balance!important}
  .hero-kicker{max-width:100%;gap:8px;row-gap:4px;flex-wrap:wrap;font-size:11.5px;letter-spacing:.16em;white-space:normal}
  .hero-kicker i{width:28px}
  .hero-kicker span{font-size:11px;letter-spacing:0}
  .hero-group-slide .cta-row{flex-direction:column;align-items:center;gap:10px;margin-top:20px}
  .hero-group-slide .btn{width:min(100%,260px);justify-content:center;padding:14px 18px;font-size:14px}
  .hero .hero-tabs{bottom:78px}
}
.hero h1 span,.hero .hero-hx span{background:linear-gradient(96deg,var(--teal) 0%,#3fc0f5 55%,var(--green) 130%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--teal)}
.hero-group-slide h1 span{position:relative;display:inline-block}
.hero-group-slide h1 span::after{content:"";position:absolute;left:2%;right:2%;bottom:-.08em;height:.08em;border-radius:999px;background:linear-gradient(90deg,var(--teal),var(--green));transform:scaleX(0);transform-origin:left;transition:transform .72s cubic-bezier(.22,1,.36,1) 1.12s}
.hero-group-slide.is-active h1 span::after{transform:scaleX(1)}
.hero-group-slide:not(.is-active) h1 span::after{transition-delay:0s}
.hero-group-slide.is-active::before{animation:kbSlow 8.5s cubic-bezier(.25,.46,.45,.94) both}
@keyframes kbSlow{from{transform:scale(1.045)}to{transform:scale(1)}}
@media(max-width:900px){.hero-group-slide h1 span{display:block;width:fit-content;max-width:100%;margin:0 auto;white-space:normal}}
.hero .sub{color:#e0ebf5;font-size:clamp(15px,1.55vw,18.5px);margin-top:20px;max-width:560px;line-height:1.72;text-shadow:0 1px 16px rgba(0,0,0,.3)}
.cta-row{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:9px;padding:16px 28px;border-radius:14px;font-size:16px;font-weight:800;transition:.2s;cursor:pointer;border:none}
.btn.p{background:var(--teal);color:#ffffff}
.btn.p:hover{background:#28B4F5;transform:translateY(-2px);box-shadow:0 12px 28px rgba(8,163,234,.4)}
.btn.g{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.42);backdrop-filter:blur(6px)}
.btn.g:hover{background:rgba(255,255,255,.2)}
#hd.on-light:not(.solid) nav.gnb a{color:var(--navy)!important}
#hd.on-light:not(.solid) nav.gnb a:hover{color:var(--teal-d)!important}
.hero-group-slide .btn.g{background:transparent;color:var(--navy);border-color:rgba(11,61,92,.24);backdrop-filter:none;-webkit-backdrop-filter:none}
.hero-group-slide .btn.g:hover{background:rgba(11,61,92,.06);box-shadow:none}
/* sound toggle */
.sound{position:absolute;right:34px;top:104px;z-index:3;width:44px;height:44px;border-radius:50%;
  background:rgba(8,20,34,.5);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.28);color:#fff;font-size:16px;cursor:pointer;transition:.2s}
.sound:hover{background:rgba(8,163,234,.5)}
/* scroll cue */
.scrollcue{position:absolute;left:50%;bottom:34px;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.7);font-size:12px;letter-spacing:.15em;text-align:center}
.scrollcue .mouse{width:24px;height:38px;border:2px solid rgba(255,255,255,.5);border-radius:14px;margin:0 auto 8px;position:relative}
.scrollcue .mouse::after{content:"";position:absolute;left:50%;top:7px;width:4px;height:7px;background:#fff;border-radius:3px;transform:translateX(-50%);animation:wheel 1.5s infinite}
@keyframes wheel{0%{opacity:1;top:7px}100%{opacity:0;top:18px}}

/* ---------- Quick actions ---------- */
.quick{background:#fff;border-bottom:1px solid var(--line);position:relative;z-index:4}
.quick .wrap{display:grid;grid-template-columns:repeat(5,1fr)}
.quick a{display:flex;flex-direction:column;align-items:center;gap:10px;padding:26px 8px;border-left:1px solid var(--line);transition:.2s;color:var(--ink)}
.quick a:first-child{border-left:none}
.quick a:hover{background:var(--bg);color:var(--teal-d)}
.quick .qi{width:46px;height:46px;border-radius:50%;background:#E7F5FD;display:flex;align-items:center;justify-content:center;font-size:22px;transition:.2s}
.quick a:hover .qi{background:var(--teal);transform:translateY(-3px)}
.quick b{font-size:15px;font-weight:700}
.quick small{color:var(--mut);font-size:12px}

/* ---------- generic section ---------- */
section.block{padding:96px 0}
.sec-h{text-align:center;margin-bottom:52px}
.sec-h .en{color:var(--teal-d);font-weight:800;font-size:13.5px;letter-spacing:.14em;margin-bottom:10px}
.sec-h .ko{font-size:clamp(26px,3.4vw,36px);font-weight:800;letter-spacing:-.8px}
.sec-h p{color:var(--mut);margin-top:14px;font-size:16px}
.reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* specialty centers */
.centers{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.center{border:1px solid var(--line);border-radius:20px;padding:34px 26px;background:#fff;transition:.25s;position:relative;overflow:hidden}
.center::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--teal),var(--teal-d));transform:scaleX(0);transform-origin:left;transition:.3s}
.center:hover{border-color:transparent;box-shadow:0 20px 44px rgba(14,42,71,.12);transform:translateY(-5px)}
.center:hover::before{transform:scaleX(1)}
.center .ci{width:62px;height:62px;border-radius:16px;background:#E7F5FD;display:flex;align-items:center;justify-content:center;font-size:30px;margin-bottom:20px}
.center h3{font-size:20px;font-weight:800;margin-bottom:8px}
.center .desc{color:var(--mut);font-size:14px;line-height:1.6;margin-bottom:16px}
.center ul{list-style:none;display:flex;flex-wrap:wrap;gap:7px}
.center li{font-size:12.5px;color:var(--navy2);background:var(--bg);border:1px solid var(--line);padding:4px 10px;border-radius:20px}
.center .go{display:inline-block;margin-top:18px;color:var(--teal-d);font-weight:700;font-size:14px}
/* ---- 토스풍 3D 아이콘 (퀵메뉴 · 진료영역) ---- */
.qi3d{width:58px;height:58px;object-fit:contain;filter:drop-shadow(0 8px 14px rgba(8,90,150,.18));transition:transform .25s cubic-bezier(.2,.7,.2,1)}
.quick a:hover .qi3d{transform:translateY(-4px) scale(1.04)}
.ci3d{width:70px;height:70px;object-fit:contain;margin-bottom:16px;filter:drop-shadow(0 10px 18px rgba(8,90,150,.2));transition:transform .25s cubic-bezier(.2,.7,.2,1)}
.center:hover .ci3d{transform:translateY(-3px) scale(1.05)}

/* philosophy */
.philo{background:var(--bg)}
.why-philo{position:relative;overflow:hidden}
.why-philo::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 62% at 78% 28%,rgba(8,163,234,.12),transparent 62%),linear-gradient(180deg,#f8fbfe 0%,#f1f6fb 100%);pointer-events:none}
.why-philo .wrap{position:relative;display:grid;grid-template-columns:minmax(0,.86fr) minmax(420px,1.14fr);gap:28px 56px;align-items:start}
.why-philo .txt{padding-top:16px}
.why-philo .txt .en{color:var(--teal-d);font-weight:800;font-size:13.5px;letter-spacing:.14em;margin-bottom:12px}
.why-philo .txt h2{font-family:'Paperlogy','Pretendard Variable',Pretendard,sans-serif;font-size:clamp(27px,3.35vw,40px);font-weight:800;line-height:1.28;letter-spacing:-.4px}
.why-philo .txt h2 span{color:var(--teal-d)}
.why-philo .txt p{color:#33475b;font-size:16px;margin-top:20px;line-height:1.84;max-width:560px}
.philo-proof{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:26px}
.philo-proof div{background:#fff;border:1px solid rgba(230,236,243,.95);border-radius:16px;padding:16px 18px;box-shadow:0 12px 30px rgba(14,42,71,.06)}
.philo-proof dt{color:var(--teal-d);font-size:12px;font-weight:800;letter-spacing:.08em}
.philo-proof dd{margin-top:5px;color:var(--navy);font-size:15px;font-weight:800}
.philo-visual{position:relative;min-height:360px;border-radius:22px;overflow:hidden;background:#e9f3fb;box-shadow:0 28px 70px rgba(14,42,71,.14),inset 0 0 0 1px rgba(255,255,255,.74)}
.philo-visual img{width:100%;height:100%;min-height:360px;object-fit:cover;object-position:center}
.philo-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0) 42%,rgba(6,18,31,.22) 100%);pointer-events:none}
.philo-visual figcaption{position:absolute;left:22px;bottom:20px;z-index:1;display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:16px;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.76);box-shadow:0 14px 32px rgba(14,42,71,.13);backdrop-filter:blur(14px)}
.philo-visual figcaption b{color:var(--navy);font-size:15px;font-weight:800}
.philo-visual figcaption span{color:#4a6176;font-size:12.5px;font-weight:700}
.philo-points{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
.pp{position:relative;background:#fff;border:1px solid rgba(230,236,243,.95);border-radius:18px;padding:22px 22px 24px;box-shadow:0 14px 34px rgba(14,42,71,.07);overflow:hidden}
.pp::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--green))}
.pp .n{width:40px;height:40px;border-radius:14px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;margin-bottom:16px}
.pp small{display:block;color:var(--teal-d);font-size:12px;font-weight:800;letter-spacing:.08em;margin-bottom:6px}
.pp h4{font-size:17px;font-weight:800;margin-bottom:8px;line-height:1.42}
.pp p{color:var(--mut);font-size:14px;line-height:1.66}

/* doctors */
.docs{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.doc{border-radius:20px;overflow:hidden;background:#fff;border:1px solid var(--line);transition:.25s}
.doc:hover{box-shadow:0 20px 44px rgba(14,42,71,.13);transform:translateY(-4px)}
.doc .ph{aspect-ratio:4/3.4;background-size:cover;background-position:center top;background-color:#dfe8f1}
.doc .info{padding:22px 24px}
.doc .role{color:var(--teal-d);font-weight:700;font-size:13px;letter-spacing:.02em}
.doc h3{font-size:21px;font-weight:800;margin:6px 0 12px}
.doc h3 span{font-size:15px;font-weight:600;color:var(--mut);margin-left:3px}
.doc .ph{background-position:center top;background-size:cover}
.doc ul{list-style:none;display:grid;gap:6px}
.doc li{color:var(--mut);font-size:13.5px;padding-left:16px;position:relative}
.doc li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--teal)}

/* trust counter band */
.trust{background:
  radial-gradient(circle at 82% 12%,rgba(8,163,234,.22),transparent 34%),
  radial-gradient(circle at 14% 92%,rgba(134,193,30,.16),transparent 32%),
  linear-gradient(154deg,#071827 0%,#0A3350 48%,#0B3D5C 100%);color:#fff;position:relative;overflow:hidden}
.trust::before{content:"";position:absolute;inset:0;background:
  linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:86px 86px;mask-image:linear-gradient(180deg,rgba(0,0,0,.78),transparent 92%);pointer-events:none}
.trust::after{content:"";position:absolute;left:50%;top:0;width:min(860px,72vw);height:1px;transform:translateX(-50%);background:linear-gradient(90deg,transparent,var(--proof-rose),var(--proof-cyan),transparent);opacity:.8}
.trust .wrap{position:relative;z-index:1}
#numbers,#numbers-kpis{scroll-margin-top:74px}
.sec-h.light .en{color:#7fd0f7}
.sec-h.light .ko{color:#fff}
.sec-h.light p{color:#bcd2e6}
.sec-h.light .en::before{background:#7fd0f7}
.numbers-dashboard{display:grid;grid-template-columns:minmax(0,.92fr) minmax(520px,1.08fr);gap:24px;align-items:stretch}
.patient-chart,.trust .t{position:relative;border:1px solid rgba(202,230,248,.12);background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.038));box-shadow:0 24px 62px rgba(2,11,20,.24),inset 0 1px 0 rgba(255,255,255,.11);backdrop-filter:blur(18px);overflow:hidden}
.patient-chart{border-radius:26px;padding:30px 32px 26px;min-height:438px}
.patient-chart::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 72% 28%,rgba(134,193,30,.13),transparent 38%),linear-gradient(120deg,rgba(64,199,255,.12),transparent 44%);pointer-events:none}
.chart-copy,.chart-figure,.chart-note{position:relative;z-index:1}
.chart-kicker{display:inline-flex;align-items:center;min-height:32px;padding:0 18px;border-radius:999px;background:linear-gradient(90deg,var(--teal),var(--green));box-shadow:0 12px 34px rgba(8,163,234,.24);color:#fff;font-size:13px;font-weight:800;letter-spacing:.02em}
.chart-copy h3{display:flex;align-items:baseline;gap:7px;margin-top:18px;font-size:clamp(38px,5.2vw,62px);font-weight:800;line-height:1;letter-spacing:-2px;color:#fff}
.chart-copy h3 .count{font-variant-numeric:tabular-nums;background:linear-gradient(180deg,#fff 0%,#dcefff 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.chart-copy h3 .count.counting{-webkit-text-fill-color:#fff}
.chart-copy h3 i{font-style:normal;color:var(--green);font-size:.43em;font-weight:800;letter-spacing:-.4px}
.chart-copy p{margin-top:12px;color:#bcd2e6;font-size:14.5px;line-height:1.7}
.chart-figure{height:252px;margin-top:26px;padding:18px 18px 0}
.chart-grid{position:absolute;left:18px;right:18px;top:18px;bottom:42px;background:repeating-linear-gradient(180deg,rgba(255,255,255,.18) 0 1px,transparent 1px 50px)}
.chart-line{position:absolute;inset:12px 6px 30px;width:calc(100% - 12px);height:calc(100% - 42px);overflow:visible}
.chart-line polyline{fill:none;stroke:url(#patientLine);stroke-width:4.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:690;stroke-dashoffset:690;filter:drop-shadow(0 8px 16px rgba(8,163,234,.28))}
.chart-line circle{fill:#071827;stroke:var(--green);stroke-width:4;opacity:0;transform-box:fill-box;transform-origin:center;filter:drop-shadow(0 0 12px rgba(134,193,30,.36))}
.patient-bars{position:relative;z-index:1;display:grid;grid-template-columns:repeat(5,1fr);align-items:end;gap:14px;height:100%;padding:38px 0 0}
.patient-point{height:100%;display:grid;grid-template-rows:1fr auto auto;align-items:end;justify-items:center;gap:7px;min-width:0}
/* 막대 비율 = 값/80,000 (10,600 · 37,000 · 46,000 · 67,000 · 80,000) */
.patient-point-2016{--bar:.1325}
.patient-point-2018{--bar:.4625}
.patient-point-2020{--bar:.575}
.patient-point-2023{--bar:.8375}
.patient-point-2026{--bar:1}
.patient-bar{width:min(54px,68%);height:100%;max-height:152px;border-radius:16px 16px 5px 5px;background:linear-gradient(180deg,var(--teal),rgba(255,255,255,.74));box-shadow:0 12px 24px rgba(8,163,234,.22);transform:scaleY(.05);transform-origin:bottom;opacity:.7}
.patient-point b{color:#f2f7fb;font-size:13px;font-weight:800;line-height:1.2;text-align:center;white-space:nowrap}
.patient-point small{color:#93acc4;font-size:12px;font-weight:700}
.chart-note{margin-top:2px;color:#7f9ab4;font-size:12px;text-align:center}
.numbers-dashboard.in .patient-bar{transform:scaleY(var(--bar));opacity:1;transition:transform .9s cubic-bezier(.16,1,.3,1),opacity .45s ease}
.numbers-dashboard.in .patient-point:nth-child(2) .patient-bar{transition-delay:.08s}
.numbers-dashboard.in .patient-point:nth-child(3) .patient-bar{transition-delay:.16s}
.numbers-dashboard.in .patient-point:nth-child(4) .patient-bar{transition-delay:.24s}
.numbers-dashboard.in .patient-point:nth-child(5) .patient-bar{transition-delay:.32s}
.numbers-dashboard.in .chart-line polyline{animation:drawPatientLine 1.15s .18s cubic-bezier(.16,1,.3,1) forwards}
.numbers-dashboard.in .chart-line circle{animation:popPatientDot .38s cubic-bezier(.16,1,.3,1) forwards}
.numbers-dashboard.in .chart-line circle:nth-of-type(2){animation-delay:.22s}
.numbers-dashboard.in .chart-line circle:nth-of-type(3){animation-delay:.34s}
.numbers-dashboard.in .chart-line circle:nth-of-type(4){animation-delay:.46s}
.numbers-dashboard.in .chart-line circle:nth-of-type(5){animation-delay:.58s}
@keyframes drawPatientLine{to{stroke-dashoffset:0}}
@keyframes popPatientDot{from{opacity:0;transform:scale(.55)}to{opacity:1;transform:scale(1)}}
.trust-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:16px;text-align:left}
.trust .t{min-height:216px;border-radius:18px;padding:26px 24px 24px;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(156deg,rgba(255,255,255,.09),rgba(255,255,255,.038) 54%,rgba(8,28,44,.18));transition:transform .25s ease,background .25s ease,border-color .25s ease,box-shadow .25s ease;isolation:isolate}
.trust .t::before{content:"";position:absolute;left:18px;right:18px;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(127,208,247,.74),rgba(134,193,30,.54),transparent);opacity:.78}
.trust .t::after{content:"";position:absolute;inset:1px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,0) 37%),radial-gradient(circle at 83% 18%,rgba(8,163,234,.08),transparent 31%);border-radius:17px;z-index:-1;opacity:.9}
.trust .t:hover{background:linear-gradient(156deg,rgba(255,255,255,.115),rgba(255,255,255,.048) 56%,rgba(8,28,44,.2));border-color:rgba(127,208,247,.25);transform:translateY(-3px);box-shadow:0 24px 58px rgba(2,11,20,.26),inset 0 1px 0 rgba(255,255,255,.16)}
/* 기본 상태 = 진입 애니메이션 종료 상태와 동일 — 애니메이션은 backwards로만 채워
   완료 후 일반 스타일로 복귀 → 호버 transition이 애니메이션과 충돌 없이 부드럽게 동작 */
.kpi-visual{position:absolute;right:18px;top:18px;width:80px;height:80px;display:flex;align-items:center;justify-content:center;opacity:.56;filter:drop-shadow(0 12px 18px rgba(2,11,20,.16)) saturate(.82);pointer-events:none;transform:translate3d(0,0,0) scale(1)}
.kpi-visual img{width:100%;height:100%;object-fit:contain}
.numbers-dashboard:not(.in) .kpi-visual{opacity:0;transform:translate3d(12px,14px,0) scale(.88)}
.numbers-dashboard.in .kpi-visual{animation:kpiVisualIn .78s .14s cubic-bezier(.16,1,.3,1) backwards}
.numbers-dashboard:not(.in) .trust-grid .t{opacity:.55;transform:translate3d(0,18px,0) scale(.98)}
.numbers-dashboard.in .trust-grid .t{animation:kpiCardIn .7s cubic-bezier(.16,1,.3,1) backwards}
.numbers-dashboard.in .trust-grid .t:nth-child(2){animation-delay:.08s}
.numbers-dashboard.in .trust-grid .t:nth-child(3){animation-delay:.16s}
.numbers-dashboard.in .trust-grid .t:nth-child(4){animation-delay:.24s}
@keyframes kpiCardIn{from{opacity:.55;transform:translate3d(0,18px,0) scale(.98)}to{opacity:1;transform:translate3d(0,0,0) scale(1)}}
@keyframes kpiVisualIn{from{opacity:0;transform:translate3d(12px,14px,0) scale(.88)}to{opacity:.56;transform:translate3d(0,0,0) scale(1)}}
.kpi-meta{position:relative;z-index:1;display:block;align-self:flex-start;margin-bottom:auto;color:rgba(127,208,247,.72);font-size:11px;font-weight:800;letter-spacing:.12em;line-height:1}
.kpi-meta::after{content:"";display:block;width:34px;height:1px;margin-top:12px;background:linear-gradient(90deg,rgba(127,208,247,.6),rgba(134,193,30,.34),transparent)}
.trust-grid .t>b{display:flex;align-items:baseline;gap:7px;white-space:nowrap;margin-top:48px;font-size:clamp(40px,3.65vw,50px)!important;font-weight:800;color:#fff;line-height:.98;letter-spacing:-1.3px}
.trust-grid .t>b .count{font-size:1em!important}
.trust .t b .count{font-variant-numeric:tabular-nums;background:linear-gradient(180deg,#fff 0%,#dcefff 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.trust .t b i{color:rgba(158,217,39,.92);font-style:normal;font-size:.34em;font-weight:800;letter-spacing:-.3px;transform:translateY(-.02em)}
.trust .t .count.counting{color:#fff;-webkit-text-fill-color:#fff}
.trust .t span{display:block;color:#eef7ff;font-size:15px;font-weight:800;line-height:1.45;margin-top:14px}
.trust .t span em{display:block;color:#8fa6ba;font-size:12.5px;font-style:normal;font-weight:600;margin-top:5px}

/* ---- 참돌이 마스코트 CTA 밴드 ---- */
.mascot-cta{background:linear-gradient(115deg,var(--blue-tint) 0%,#eef7e6 100%);position:relative;overflow:hidden;padding:44px 0}
.mascot-cta::before{content:"";position:absolute;right:-120px;bottom:-120px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(8,163,234,.12),transparent 70%)}
.mascot-cta .wrap{position:relative;display:flex;align-items:center;gap:20px}
.mascot-fig{flex:none;width:190px;text-align:center;filter:drop-shadow(0 16px 24px rgba(8,90,150,.18))}
.mascot-fig .mascot{width:190px;height:auto;animation:mascotFloat 4.5s ease-in-out infinite}
@keyframes mascotFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.mc-copy{flex:1}
.mc-eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--teal-d);font-weight:700;font-size:13.5px;background:rgba(255,255,255,.7);border:1px solid rgba(8,163,234,.25);padding:6px 14px;border-radius:30px;margin-bottom:14px}
.mc-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(134,193,30,.22)}
.mascot-cta h2{font-size:clamp(24px,3vw,34px);font-weight:800;letter-spacing:-.8px;color:var(--navy);line-height:1.25}
.mascot-cta h2 b{color:var(--teal)}
.mascot-cta p{color:#4a5a6b;font-size:16px;line-height:1.7;margin:14px 0 24px;max-width:600px}
.btn.ghost{background:#fff;color:var(--teal-d);border:1.5px solid var(--teal);box-shadow:0 6px 18px rgba(8,163,234,.14)}
.btn.ghost:hover{background:var(--blue-tint);transform:translateY(-2px)}
@media(max-width:760px){
  .mascot-cta .wrap{flex-direction:column;text-align:center;gap:6px}
  .mascot-fig{width:150px}.mascot-fig .mascot{width:150px}
  .mascot-cta p{margin-left:auto;margin-right:auto}
  .mascot-cta .cta-row{justify-content:center}
  .mc-copy .cta-row{flex-direction:column}
}

/* facility */
.facility{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:14px;height:520px}
.fc{border-radius:18px;background-size:cover;background-position:center;position:relative;overflow:hidden}
.fc:first-child{grid-row:span 2}
.fc .cap{position:absolute;left:0;right:0;bottom:0;padding:20px;background:linear-gradient(transparent,rgba(6,18,32,.82));color:#fff;font-weight:700;font-size:15px}
.fc .cap small{display:block;color:#bcd0e2;font-weight:500;font-size:12px;margin-top:2px}

/* reviews */
	.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
	#reviews .wrap{display:block}
	.rev{position:relative;border:1px solid rgba(230,236,243,.95);border-radius:20px;padding:28px;background:
	  linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,251,254,.96));box-shadow:0 14px 34px rgba(14,42,71,.07);overflow:hidden;transition:.25s}
	.rev::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,var(--teal),var(--green));opacity:.75}
	.rev::after{content:"”";position:absolute;right:22px;top:14px;color:rgba(8,163,234,.09);font-size:82px;font-weight:800;line-height:1}
	.rev:hover,.rev.featured{border-color:rgba(8,163,234,.28);box-shadow:0 22px 48px rgba(14,42,71,.12);transform:translateY(-4px)}
	.rev-top{position:relative;z-index:1;display:flex;align-items:center;gap:13px;margin-bottom:18px}
	.rev .score{width:48px;height:48px;border-radius:16px;background:var(--green-tint);color:var(--green-d);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;box-shadow:inset 0 0 0 1px rgba(134,193,30,.18)}
	.rev .star{color:var(--gold);font-size:14px;letter-spacing:1.5px;line-height:1}
	.rev-top small{display:block;margin-top:5px;color:var(--mut);font-size:12px;font-weight:600}
	.rev p{position:relative;z-index:1;font-size:15px;line-height:1.74;color:#28384a;min-height:106px}
	.rev .by{position:relative;z-index:1;margin-top:20px;padding-top:16px;border-top:1px solid var(--line);color:var(--mut);font-size:13px;display:flex;justify-content:space-between;gap:14px}
	.rev .by b{color:var(--navy2)}

/* blog / notice */
.info-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:40px}
.blog-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.bcard{border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.2s;background:#fff}
.bcard:hover{box-shadow:0 14px 30px rgba(14,42,71,.1);transform:translateY(-3px)}
.bcard .thumb{aspect-ratio:16/9;background-size:cover;background-position:center;background-color:#e7eef5}
.bcard .b{padding:18px 20px}
.bcard .tag{color:var(--teal-d);font-size:12px;font-weight:700}
.bcard h4{font-size:16px;font-weight:700;margin:6px 0;line-height:1.4}
.bcard small{color:var(--mut);font-size:12.5px}
.notice-box{border:1px solid var(--line);border-radius:16px;padding:8px 24px 16px}
.notice-box .nh{display:flex;justify-content:space-between;align-items:center;padding:16px 0 12px;border-bottom:2px solid var(--navy)}
.notice-box .nh b{font-size:18px;font-weight:800}
.notice-box .nh a{color:var(--mut);font-size:13px}
.notice-box li{list-style:none;display:flex;justify-content:space-between;gap:14px;padding:15px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.notice-box li:last-child{border-bottom:none}
.notice-box li a{color:#2a3a4c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.notice-box li a:hover{color:var(--teal-d)}
.notice-box li time{color:var(--mut);font-size:12.5px;flex:none}

/* visit / map */
.visit{background:var(--navy);color:#fff;scroll-margin-top:72px}
.visit .wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.visit h2{font-size:30px;font-weight:800;letter-spacing:-.6px;margin-bottom:24px}
.visit .row{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.visit .row .k{color:var(--teal);font-weight:700;min-width:92px;font-size:14px}
.visit .row .v{color:#dbe7f2;font-size:15px}
.visit .row .v b{color:#fff}
.mapbox{display:block;width:100%;aspect-ratio:4/3;border-radius:18px;background-size:cover;background-position:center;background-color:#0a1c30;border:1px solid rgba(255,255,255,.14);position:relative;overflow:hidden;transition:.25s}
.mapbox:hover{border-color:rgba(127,208,247,.55);box-shadow:0 18px 44px rgba(2,11,20,.35)}
.kakao-map{box-shadow:0 22px 54px rgba(2,11,20,.24);isolation:isolate}
.map-embed{position:absolute;inset:0;overflow:hidden;background:#10283d;pointer-events:none}
.map-embed iframe{position:absolute;left:-74%;top:-78%;display:block;width:190%;height:190%;border:0;background:#10283d;filter:saturate(.92) contrast(.98)}
.map-actions{position:absolute;left:16px;right:16px;bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 14px 13px 16px;border:1px solid rgba(255,255,255,.22);border-radius:16px;background:rgba(6,18,31,.78);backdrop-filter:blur(12px);box-shadow:0 12px 30px rgba(2,11,20,.26);pointer-events:none}
.map-actions{z-index:2}
.map-actions span{color:#dbe7f2;font-size:13.5px;line-height:1.45}
.map-actions span b{display:block;color:#fff;font-size:15px}
.map-actions a{flex:none;display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 15px;border-radius:30px;background:var(--teal);color:#fff;font-size:13px;font-weight:800;box-shadow:0 8px 20px rgba(8,163,234,.28);pointer-events:auto;transition:.2s}
.map-actions a:hover{background:#28B4F5;transform:translateY(-1px)}
.channel-links{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px}
.channel-links a{display:flex;align-items:center;gap:8px;min-height:46px;padding:0 12px;border:1px solid rgba(255,255,255,.16);border-radius:14px;background:rgba(255,255,255,.055);color:#dbe7f2;font-size:13px;font-weight:800;transition:.2s}
.channel-links a:hover{background:rgba(8,163,234,.16);border-color:rgba(127,208,247,.42);color:#fff;transform:translateY(-1px)}
.channel-links svg{width:17px;height:17px;flex:none;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.mapbox .pin{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);text-align:center}
.mapbox .pin .dot{width:20px;height:20px;background:var(--teal);border:4px solid #fff;border-radius:50%;margin:0 auto;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.mapbox .pin span{display:inline-block;margin-top:8px;background:#fff;color:var(--navy);font-weight:800;font-size:13px;padding:5px 12px;border-radius:20px}

/* footer */
footer.site{background:#0a1826;color:#8ba3ba;padding:56px 0 40px;font-size:13.5px}
footer.site .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
footer.site .logo{font-size:22px;font-weight:800;color:#fff;margin-bottom:14px}
footer.site .logo b{color:var(--teal)}
footer.site p{line-height:1.8}
footer.site h5{color:#cddcea;font-size:14px;margin-bottom:14px;font-weight:700}
footer.site ul{list-style:none;display:grid;gap:9px}
footer.site a:hover{color:var(--teal)}
footer.site .copy{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.1);margin-top:12px;padding-top:22px;color:#6d879e;font-size:12.5px}

/* fixed bottom bar (mobile CTA) */
.fixbar{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;background:var(--navy)}
.fixbar a{flex:1;text-align:center;color:#fff;padding:14px 4px;font-size:13px;font-weight:700;border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;gap:3px}
.fixbar a:last-child{border-right:none}
.fixbar a.accent{background:var(--teal);color:#ffffff}
	.fixbar a i{font-size:17px;font-style:normal}
	.float-menu{position:fixed;right:10px;top:50%;transform:translateY(-50%);z-index:88;display:grid;gap:8px}
	.float-menu a,.float-menu button{width:58px;min-height:58px;border:1px solid rgba(230,236,243,.95);border-radius:18px;background:rgba(255,255,255,.94);color:var(--navy);box-shadow:0 14px 34px rgba(14,42,71,.12);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;font:700 12px/1.2 'Pretendard Variable',Pretendard,sans-serif;cursor:pointer;backdrop-filter:blur(12px);transition:.2s}
	.float-menu a:hover,.float-menu button:hover{background:var(--teal);border-color:var(--teal);color:#fff;transform:translateY(-2px);box-shadow:0 16px 34px rgba(8,163,234,.28)}
	.float-menu .fm-book{background:var(--teal);border-color:var(--teal);color:#fff}
	.float-menu svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
	.float-menu img{width:30px;height:30px;object-fit:contain;filter:drop-shadow(0 3px 6px rgba(14,42,71,.18))}
	.float-menu a:hover img{transform:scale(1.12);transition:.2s}
	.float-menu .fm-top svg{transform:rotate(-90deg)}

/* ---------- responsive ---------- */
@media(max-width:1024px){
  .centers{grid-template-columns:repeat(2,1fr)}
  .docs{grid-template-columns:1fr}
  .why-philo .wrap{grid-template-columns:1fr;gap:28px}
  .philo-points{grid-template-columns:1fr 1fr}
  .info-grid{grid-template-columns:1fr}
  .numbers-dashboard{grid-template-columns:1fr}
  .visit .wrap{grid-template-columns:1fr}
  .visit .wrap>*{min-width:0}
  .kakao-map{min-height:360px}
  .facility{grid-template-columns:1fr 1fr;height:auto}
  .facility .fc{aspect-ratio:16/10}.facility .fc:first-child{grid-row:auto}
}
@media(max-width:900px){
  nav.gnb,.head-right .lang,.head-right .btn-book{display:none}
  header,header.solid{padding:14px 18px}
  .wrap{padding:0 18px}
  /* 모바일: 배경 하단(원장)을 살리고 텍스트는 상단 좌측 */
	  .hero-in{align-items:flex-start;padding:118px 18px 132px}
  .hero-copy{max-width:100%}
  .hero .sub{max-width:100%}
	  .slide::before{background-position:var(--bg-pos-mobile,74% center)}
  .slide::after{background:linear-gradient(180deg,rgba(7,20,34,.8) 0%,rgba(8,22,38,.42) 40%,rgba(8,22,38,.28) 62%,rgba(7,20,34,.72) 100%)}
  .hero-arrow{display:none}
  .hero-tabs{bottom:16px;gap:0}
  .htab{padding:8px 12px}
  .htab small{display:none}
  .htab b{font-size:14px}
  .visit .cta-row{flex-direction:column}
  .visit .cta-row .btn{justify-content:center;width:100%}
  .channel-links{grid-template-columns:1fr}
  .quick .wrap{grid-template-columns:repeat(3,1fr)}
  .quick a:nth-child(4),.quick a:nth-child(5){border-top:1px solid var(--line)}
  .quick a:nth-child(4){border-left:none}
  section.block{padding:64px 0}
  .centers{grid-template-columns:1fr}
  .revs,.blog-cards,.philo-points{grid-template-columns:1fr}
  .philo-proof{grid-template-columns:1fr}
  .philo-visual,.philo-visual img{min-height:260px}
  .philo-visual figcaption{left:14px;right:14px;top:14px;bottom:auto;align-items:flex-start;flex-direction:column;gap:3px}
  .trust-grid{grid-template-columns:1fr 1fr;gap:14px}
  .patient-chart{border-radius:22px;padding:24px 18px 20px;min-height:auto}
  .chart-copy h3{font-size:clamp(34px,12vw,48px);letter-spacing:-1.2px}
  .chart-figure{height:238px;margin-top:20px;padding-left:4px;padding-right:4px}
  .chart-line{inset:12px -7px 30px;width:calc(100% + 14px)}
  .patient-bars{gap:6px}
  .patient-point b{font-size:11px;white-space:normal;min-height:28px}
  .patient-bar{width:min(38px,76%)}
  .trust .t{min-height:194px;padding:22px 18px}
  .kpi-visual{width:70px;height:70px;right:14px;top:14px}
  .trust-grid .t>b{font-size:clamp(36px,9.8vw,44px)!important;letter-spacing:-1px;margin-top:42px}
  .facility{grid-template-columns:1fr}
  footer.site .wrap{grid-template-columns:1fr}
	  .fixbar{display:flex}
	  .float-menu{display:none}
  body{padding-bottom:60px}
}
@media(max-width:560px){
  .numbers-dashboard{gap:16px}
  .trust-grid{grid-template-columns:1fr}
  .chart-copy h3{flex-wrap:wrap;row-gap:5px}
  .chart-copy h3 i{font-size:.5em}
  .trust .t{min-height:184px}
  .kpi-visual{width:66px;height:66px}
  .map-embed iframe{left:-112%;top:-126%;width:240%;height:280%}
  .map-actions{align-items:flex-start;flex-direction:column}
  .map-actions a{width:100%}
}
@media(prefers-reduced-motion:reduce){
  .numbers-dashboard .patient-bar{transform:scaleY(var(--bar));opacity:1}
  .numbers-dashboard .chart-line polyline{stroke-dashoffset:0}
  .numbers-dashboard .chart-line circle{opacity:1;transform:scale(1)}
}

/* ============ Sub-page shared ============ */
.subhero{position:relative;min-height:340px;display:flex;align-items:flex-end;overflow:hidden;background:var(--navy)}
.subhero .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.42}
.subhero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,22,38,.6),rgba(9,22,38,.9))}
.subhero .in{position:relative;z-index:2;width:100%;padding:0 0 44px}
.subhero .crumb{color:#9fc4ea;font-size:13px;margin-bottom:14px}
.subhero .crumb a{color:#9fc4ea}.subhero .crumb a:hover{color:#fff}
.subhero .en{color:var(--teal);font-weight:800;font-size:13.5px;letter-spacing:.14em;margin-bottom:8px}
.subhero h1{color:#fff;font-size:clamp(30px,4.4vw,46px);font-weight:800;letter-spacing:-1px}
.subhero p{color:#cfe0f0;font-size:17px;margin-top:14px;max-width:640px;line-height:1.7}
/* header default solid on subpages */
header.subpage{position:sticky;background:#fff;border-bottom-color:var(--line)}
header.subpage .logo{color:var(--navy)}
header.subpage nav.gnb a{color:var(--ink)}
header.subpage .lang{color:var(--mut)}

/* intro lead */
.lead{max-width:820px;margin:0 auto 8px;text-align:center}
.lead h2{font-size:clamp(23px,3vw,32px);font-weight:800;letter-spacing:-.6px;line-height:1.35}
.lead h2 span{color:var(--teal-d)}
.lead p{color:#3a4a5c;font-size:16px;margin-top:18px;line-height:1.85}

/* disease accordion */
.acc{max-width:900px;margin:0 auto;display:grid;gap:12px}
.acc details{border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden;transition:.2s}
.acc details[open]{border-color:var(--teal);box-shadow:0 12px 30px rgba(8,163,234,.1)}
.acc summary{list-style:none;cursor:pointer;padding:22px 26px;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:space-between;gap:12px}
.acc summary::-webkit-details-marker{display:none}
.acc summary .tg{flex:none;width:26px;height:26px;border-radius:50%;background:var(--bg);color:var(--teal-d);display:flex;align-items:center;justify-content:center;font-weight:700;transition:.2s}
.acc details[open] summary .tg{background:var(--teal);color:#fff;transform:rotate(45deg)}
.acc .body{padding:0 26px 24px;color:#3a4a5c;font-size:15px;line-height:1.8}
.acc .body .sym{margin-top:14px;background:var(--bg);border-radius:12px;padding:16px 18px}
.acc .body .sym b{display:block;color:var(--navy);font-size:14px;margin-bottom:8px}
.acc .body .sym li{margin-left:18px;font-size:14px;color:#48586a}

/* treatment cards */
.treat{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tcard{border:1px solid var(--line);border-radius:18px;padding:30px 26px;background:#fff;transition:.25s}
.tcard:hover{box-shadow:0 18px 40px rgba(14,42,71,.1);transform:translateY(-4px)}
.tcard .tag{display:inline-block;font-size:12px;font-weight:800;color:var(--teal-d);background:#E7F5FD;padding:5px 12px;border-radius:20px;margin-bottom:14px}
.tcard h3{font-size:20px;font-weight:800;margin-bottom:10px}
.tcard p{color:var(--mut);font-size:14.5px;line-height:1.7}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 22px}
.step::before{counter-increment:s;content:"0" counter(s);display:block;font-size:26px;font-weight:800;color:var(--teal);margin-bottom:12px}
.step h4{font-size:16.5px;font-weight:800;margin-bottom:6px}
.step p{color:var(--mut);font-size:13.5px;line-height:1.6}

/* equipment grid */
.equip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.eq{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center}
.eq .ei{font-size:28px;margin-bottom:10px}
.eq b{display:block;font-size:15px;margin-bottom:6px}
.eq p{color:var(--mut);font-size:12.5px;line-height:1.55}

/* cta band */
.ctaband{background:linear-gradient(115deg,var(--navy),var(--navy2));color:#fff;border-radius:22px;padding:52px 44px;text-align:center;position:relative;overflow:hidden}
.ctaband::before{content:"";position:absolute;right:-120px;bottom:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(8,163,234,.25),transparent 70%)}
.ctaband h2{position:relative;font-size:clamp(24px,3vw,32px);font-weight:800;letter-spacing:-.6px}
.ctaband p{position:relative;color:#bcd0e2;margin-top:12px;font-size:16px}
.ctaband .cta-row{position:relative;justify-content:center;margin-top:28px}

/* big doctor profile (about) */
.profile{display:grid;grid-template-columns:340px 1fr;gap:40px;align-items:center;margin-bottom:40px}
.profile:nth-child(even){grid-template-columns:1fr 340px}
.profile:nth-child(even) .pph{order:2}
.profile .pph{aspect-ratio:4/4.4;border-radius:20px;background-size:cover;background-position:center top;background-color:#dfe8f1}
.profile .role{color:var(--teal-d);font-weight:800;font-size:14px}
.profile h3{font-size:30px;font-weight:800;margin:8px 0 4px}
.profile .sub{color:var(--mut);font-size:15px;margin-bottom:18px}
.profile ul{list-style:none;display:grid;gap:9px}
.profile li{padding-left:18px;position:relative;color:#3a4a5c;font-size:15px}
.profile li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:50%;background:var(--teal)}

@media(max-width:1024px){.treat,.equip,.steps{grid-template-columns:repeat(2,1fr)}.profile,.profile:nth-child(even){grid-template-columns:1fr}.profile:nth-child(even) .pph{order:0}.profile .pph{max-width:340px}}
@media(max-width:720px){.treat,.equip,.steps{grid-template-columns:1fr}.subhero{min-height:260px}.ctaband{padding:38px 22px}}

/* background tint only (no grid) — for sub-pages */
.tint{background:var(--bg)}

/* ============ SVG icon system ============ */
.svg-sprite{position:absolute;width:0;height:0;overflow:hidden}
/* stroke + fill inherit down to the symbol's <path> elements */
.ci svg,.qi svg,.fixbar i svg,.btn svg,.mapbox .dot svg{
  fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;
  vector-effect:non-scaling-stroke}
/* specialty-center tiles */
.center .ci{color:var(--teal-d)}
.center .ci svg{width:32px;height:32px}
.center:hover .ci{background:var(--teal);color:#fff;transition:.25s}
/* quick-action circles */
.quick .qi{color:var(--teal-d)}
.quick .qi svg{width:24px;height:24px}
.quick a:hover .qi{color:#fff}
/* fixed mobile bar */
.fixbar a i{display:flex;align-items:center;justify-content:center}
.fixbar a i svg{width:21px;height:21px;stroke-width:1.9}
/* inline button icons */
.btn svg{width:18px;height:18px;stroke-width:2;flex:none}
.btn .ico-r{margin-left:-2px}
.btn .ico-l{margin-right:-2px}

/* ============ Brand · 실제 로고 이미지 ============ */
/* 헤더: 투명(히어로 위) 상태 — 컬러 로고 + 가독성용 섀도우로 브랜드 컬러 유지 */
header .logo{display:flex;align-items:center;line-height:0}
header .logo img{height:42px;width:auto;display:block;transition:height .3s ease;
  filter:drop-shadow(0 1px 4px rgba(6,18,31,.45))}
/* 솔리드(흰 배경) 상태 — 섀도우 제거, 살짝 축소 */
header.solid .logo img,header.subpage .logo img{height:36px;filter:none}
/* 푸터(다크): 화이트 녹아웃 로고 — 다크 배경에서 깔끔하게 */
footer.site .logo{line-height:0}
footer.site .logo img{height:40px;width:auto;margin-bottom:16px;filter:brightness(0) invert(1);opacity:.92}

/* 진료영역 카드 상단 바 — 블루→그린 투톤으로 브랜드 시그널 */
.center::before{background:linear-gradient(90deg,var(--teal),var(--green))!important}

/* ============ 한글 조판 (KLREQ · ddd-typography Layer 4) ============ */
/* KLREQ §7.1: 한글 본문은 단어 단위 줄바꿈(keep-all). overflow-wrap로 초장문 안전장치 */
:lang(ko){word-break:keep-all;overflow-wrap:anywhere}
/* 제목·CTA는 균형 줄바꿈으로 들쭉날쭉 방지 */
@supports (text-wrap:balance){
  .hero h1,.hero .hero-hx,.sec-h .ko,.lead h2,.why-philo .txt h2,.ctaband h2,.center h3,.pp h4,.bcard h4,.visit h2{text-wrap:balance}
}
/* 본문 장문은 pretty로 고아 단어 방지 */
@supports (text-wrap:pretty){
  .hero .sub,.why-philo .txt p,.lead p,.rev p,.sec-h p,.center .desc,.doc li{text-wrap:pretty}
}

/* ============ Polish · numerals ============ */
.trust .t b,.count,.notice-box li time,.visit .row .v b{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* ============ Polish · accessibility ============ */
:where(a,button,summary,.btn,input,[tabindex]):focus-visible{
  outline:2.5px solid var(--teal);outline-offset:3px;border-radius:6px}
header.solid nav.gnb a:focus-visible,nav.gnb a:focus-visible{outline-offset:6px}
::selection{background:var(--teal);color:#fff}
.eyebrow .star,.rev .star{font-variant:normal}

/* ============ Polish · hero refinement ============ */
.hero-media::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(0deg,rgba(6,18,31,.42) 0%,transparent 30%),
             radial-gradient(120% 80% at 78% 20%,rgba(8,163,234,.10),transparent 60%)}
.hero-in .eyebrow{backdrop-filter:blur(4px)}
/* subtle top-fade so white nav text always reads over bright sky */
.hero::before{content:"";position:absolute;inset:0 0 auto 0;height:180px;z-index:1;
  background:linear-gradient(180deg,rgba(6,18,31,.34),transparent);pointer-events:none}

/* section eyebrow — small brand tick before the EN label */
.sec-h .en,.why-philo .txt .en,.subhero .en{display:inline-flex;align-items:center;gap:9px}
.sec-h .en::before{content:"";width:22px;height:2px;background:var(--teal);border-radius:2px}

/* card keyword chips — brand tint on hover */
.center li{transition:.2s}
.center:hover li{border-color:var(--blue-tint);background:var(--blue-tint);color:var(--teal-d)}

/* ============ Symptom body map — 어디가 불편하신가요 (index) ============ */
.bodymap{background:
  radial-gradient(circle at 18% 14%,rgba(8,163,234,.2),transparent 36%),
  radial-gradient(circle at 88% 88%,rgba(134,193,30,.13),transparent 30%),
  linear-gradient(160deg,#071827 0%,#0A3350 52%,#0B3D5C 100%);color:#fff;position:relative;overflow:hidden}
.bodymap::before{content:"";position:absolute;inset:0;background:
  linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:86px 86px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.7),transparent 90%);pointer-events:none}
.bodymap .wrap{position:relative;z-index:1}
.bm-grid{display:grid;grid-template-columns:minmax(320px,.9fr) 1.1fr;gap:28px 56px;align-items:center}
/* 인체 피규어 + 핫스팟 */
.bm-fig{position:relative;max-width:400px;margin:0 auto;filter:drop-shadow(0 30px 60px rgba(2,11,20,.45));
  overflow:hidden;border-radius:26px}
/* 부위 확대 줌 래퍼 — transform은 JS가 부위 좌표 기준으로 설정 */
.bm-zoomer{position:relative;transition:transform .72s cubic-bezier(.22,.9,.24,1);will-change:transform}
.bm-fig>.bm-zoomer>img,.bm-fig>img{width:100%;height:auto}
.bm-spot{position:absolute;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;
  background:radial-gradient(circle,rgba(8,163,234,.5) 0%,rgba(8,163,234,.22) 62%,rgba(8,163,234,.08) 100%);
  border:2px solid rgba(199,235,255,.95);cursor:pointer;padding:0;
  display:flex;align-items:center;justify-content:center;transition:.25s;z-index:2;
  box-shadow:0 0 0 4px rgba(8,163,234,.18),0 0 22px rgba(64,199,255,.55),inset 0 0 10px rgba(64,199,255,.35)}
.bm-spot::before{content:"";width:13px;height:13px;border-radius:50%;background:#fff;box-shadow:0 0 14px rgba(64,199,255,1),0 0 4px #fff;transition:.25s}
.bm-spot::after{content:"";position:absolute;inset:-9px;border-radius:50%;border:2px solid rgba(157,220,255,.7);animation:bmPulse 2.2s ease-out infinite}
@keyframes bmPulse{0%{transform:scale(.62);opacity:.95}70%{transform:scale(1.3);opacity:0}100%{opacity:0}}
.bm-spot .tip{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);white-space:nowrap;
  background:rgba(9,26,42,.86);border:1px solid rgba(127,208,247,.4);backdrop-filter:blur(8px);
  color:#dff1fd;font-size:12.5px;font-weight:700;padding:5px 12px;border-radius:20px;opacity:0;pointer-events:none;transition:.2s}
.bm-spot.tip-l .tip{left:auto;right:calc(100% + 10px)}
/* 데스크톱: 라벨 상시 노출로 클릭 지점 명시 */
@media(min-width:1025px){.bm-spot .tip{opacity:.92}}
.bm-spot:hover .tip,.bm-spot.is-active .tip{opacity:1}
.bm-spot:hover{background:radial-gradient(circle,rgba(8,163,234,.72) 0%,rgba(8,163,234,.3) 62%,rgba(8,163,234,.1) 100%)}
/* 줌 상태 — 핫스팟 크기 보정(스케일 상쇄) + 비활성 스팟 숨김 */
.bm-fig.is-zoomed .bm-spot{transform:translate(-50%,-50%) scale(.52);opacity:0;pointer-events:none;transition:.4s}
.bm-fig.is-zoomed .bm-spot.is-active{opacity:1;pointer-events:auto}
.bm-fig.is-zoomed .bm-spot::after{animation:none;opacity:0}
.bm-fig.is-zoomed .bm-spot .tip{font-size:16px}
.bm-reset{position:absolute;right:12px;top:12px;z-index:3;display:inline-flex;align-items:center;gap:7px;
  padding:10px 16px;border-radius:30px;border:1px solid rgba(199,235,255,.5);cursor:pointer;font-family:inherit;
  background:rgba(9,26,42,.78);backdrop-filter:blur(10px);color:#dff1fd;font-size:13px;font-weight:800;transition:.2s}
.bm-reset svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.bm-reset:hover{background:var(--teal);border-color:var(--teal);color:#fff}
.bm-reset[hidden]{display:none}
.bm-hint{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);z-index:3;white-space:nowrap;
  padding:7px 14px;border-radius:20px;background:rgba(9,26,42,.62);backdrop-filter:blur(8px);
  color:#9dc6e4;font-size:11.5px;font-weight:600;pointer-events:none;transition:.3s}
.bm-fig.is-zoomed .bm-hint{opacity:0}
.bm-spot.is-active{background:var(--teal);border-color:#fff;box-shadow:0 0 0 5px rgba(8,163,234,.28),0 10px 30px rgba(8,163,234,.5)}
.bm-spot.is-active::before{background:#fff;box-shadow:0 0 10px #fff}
.bm-spot.is-active::after{animation:none;opacity:0}
/* 우측 패널 */
.bm-panel{min-height:430px}
/* 부위 칩 — 한 줄 고정(넘치면 가로 스크롤) */
.bm-chips{display:flex;flex-wrap:nowrap;gap:7px;margin-bottom:22px;overflow-x:auto;padding-bottom:4px;
  scrollbar-width:none;-webkit-overflow-scrolling:touch}
.bm-chips::-webkit-scrollbar{display:none}
.bm-chip{flex:none;padding:8px 13px;border-radius:30px;border:1px solid rgba(202,230,248,.24);background:rgba(255,255,255,.05);
  color:#bcd2e6;font-size:12.5px;font-weight:700;cursor:pointer;transition:.2s;font-family:inherit;white-space:nowrap}
.bm-chip:hover{border-color:rgba(127,208,247,.6);color:#fff}
.bm-chip.is-active{background:var(--teal);border-color:var(--teal);color:#fff;box-shadow:0 8px 22px rgba(8,163,234,.35)}
.bm-pane{border:1px solid rgba(202,230,248,.14);border-radius:24px;padding:32px 34px;
  background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.03));backdrop-filter:blur(18px);
  box-shadow:0 24px 62px rgba(2,11,20,.24),inset 0 1px 0 rgba(255,255,255,.1)}
.bm-pane[hidden]{display:none}
.bm-pane .bp-kicker{color:#7fd0f7;font-size:12px;font-weight:800;letter-spacing:.12em}
.bm-pane h3{font-size:clamp(22px,2.4vw,28px);font-weight:800;letter-spacing:-.5px;margin:8px 0 10px;color:#fff}
.bm-pane .bp-desc{color:#bcd2e6;font-size:14.5px;line-height:1.7}
.bm-pane ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;margin:22px 0 4px}
.bm-pane li{position:relative;padding:12px 14px 12px 38px;border-radius:12px;background:rgba(255,255,255,.05);
  border:1px solid rgba(202,230,248,.1);color:#eef7ff;font-size:14px;font-weight:600}
.bm-pane li::before{content:"";position:absolute;left:13px;top:50%;transform:translateY(-50%);width:15px;height:15px;border-radius:50%;
  background:rgba(134,193,30,.18) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%239ED927" stroke-width="3.4" stroke-linecap="round" stroke-linejoin="round"><path d="M4 12.5l5 5 11-11.5"/></svg>') center/9px no-repeat}
.bm-pane .bp-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1)}
.bm-pane .bp-cta .go-clinic{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;
  background:var(--teal);color:#fff;font-size:14px;font-weight:800;transition:.2s}
.bm-pane .bp-cta .go-clinic:hover{background:#28B4F5;transform:translateY(-2px);box-shadow:0 10px 24px rgba(8,163,234,.4)}
.bm-pane .bp-cta .go-book{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.32);color:#fff;font-size:14px;font-weight:800;transition:.2s}
.bm-pane .bp-cta .go-book:hover{background:rgba(255,255,255,.16)}
.bm-note{margin-top:16px;color:#7f9ab4;font-size:12px}
@media(max-width:1024px){
  .bm-grid{grid-template-columns:1fr;gap:8px}
  .bm-fig{max-width:300px}
  .bm-panel{min-height:0}
}
@media(max-width:900px){
  .bm-chips{flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px;margin-left:-18px;margin-right:-18px;padding-left:18px;padding-right:18px}
  .bm-chip{flex:none}
  .bm-pane{padding:24px 20px}
  .bm-pane ul{grid-template-columns:1fr}
  .bm-spot{width:30px;height:30px}
  .bm-spot .tip{display:none}
}

.center-stage{display:grid;grid-template-columns:minmax(330px,.74fr) minmax(0,1.26fr);gap:22px;align-items:stretch}
.center-stack{display:grid;gap:12px}
.center-row{position:relative;width:100%;min-height:108px;display:grid;grid-template-columns:56px minmax(0,1fr) 70px;align-items:center;gap:16px;padding:18px 20px;border:1px solid rgba(230,236,243,.95);border-radius:20px;background:#fff;text-align:left;font-family:inherit;cursor:pointer;overflow:hidden;box-shadow:0 16px 36px rgba(14,42,71,.06);transition:transform .42s cubic-bezier(.16,1,.3,1),border-color .32s ease,box-shadow .32s ease,background .32s ease}
.center-row::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(8,163,234,.1),rgba(134,193,30,.08));opacity:0;transition:opacity .32s ease}
.center-row::after{content:"";position:absolute;left:0;top:18px;bottom:18px;width:4px;border-radius:0 4px 4px 0;background:linear-gradient(180deg,var(--teal),var(--green));transform:scaleY(.35);opacity:0;transition:.32s cubic-bezier(.16,1,.3,1)}
.center-row:hover,.center-row:focus-visible,.center-row.is-active{border-color:rgba(8,163,234,.34);background:#fafdff;box-shadow:0 22px 48px rgba(14,42,71,.11);transform:translateX(8px)}
.center-row:hover::before,.center-row.is-active::before{opacity:1}
.center-row.is-active::after{opacity:1;transform:scaleY(1)}
.center-no{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:16px;background:var(--navy);color:#fff;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:15px;font-weight:800;font-variant-numeric:tabular-nums}
.center-copy{position:relative;z-index:1;display:grid;gap:5px;min-width:0}
.center-copy b{font-size:20px;font-weight:800;letter-spacing:0;line-height:1.25;color:var(--ink)}
.center-copy small{color:var(--mut);font-size:13.5px;font-weight:600;line-height:1.45}
.center-row img{position:relative;z-index:1;width:68px;height:68px;object-fit:contain;filter:drop-shadow(0 12px 18px rgba(8,90,150,.18));transition:transform .42s cubic-bezier(.16,1,.3,1)}
.center-row:hover img,.center-row.is-active img{transform:translateY(-5px) scale(1.08) rotate(3deg)}
.center-showcase{position:relative;min-height:488px;border-radius:28px;overflow:hidden;background:var(--navy);box-shadow:0 30px 76px rgba(14,42,71,.18),inset 0 0 0 1px rgba(255,255,255,.14)}
.center-panel{position:absolute;inset:0;isolation:isolate}
.center-panel[hidden]{display:none}
.center-panel img{width:100%;height:100%;object-fit:cover;transform:scale(1.03);filter:saturate(1.04);animation:centerImageIn .7s cubic-bezier(.16,1,.3,1) both}
.center-panel::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,18,31,.74),rgba(6,18,31,.28) 52%,rgba(6,18,31,.05)),linear-gradient(0deg,rgba(6,18,31,.72),rgba(6,18,31,0) 48%)}
.center-panel-copy{position:absolute;z-index:1;left:34px;right:34px;bottom:30px;max-width:560px;color:#fff;animation:centerCopyIn .58s cubic-bezier(.16,1,.3,1) both}
.center-panel-copy span{display:inline-flex;align-items:center;gap:9px;color:#7fd0f7;font-size:12px;font-weight:800;letter-spacing:.12em;margin-bottom:10px}
.center-panel-copy span::before{content:"";width:22px;height:2px;border-radius:2px;background:var(--green)}
.center-panel-copy h3{font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:clamp(25px,3.2vw,38px);font-weight:800;line-height:1.28;letter-spacing:0}
.center-panel-copy p{margin-top:12px;color:#d7e8f5;font-size:15.5px;line-height:1.72;max-width:500px}
.center-panel-copy ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.center-panel-copy li{padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#eef7ff;font-size:12.5px;font-weight:800}
@keyframes centerImageIn{from{opacity:.36;transform:scale(1.1)}to{opacity:1;transform:scale(1.03)}}
@keyframes centerCopyIn{from{opacity:0;transform:translate3d(0,22px,0)}to{opacity:1;transform:none}}

.why-philo{background:#f7fbff}
.why-philo::before{background:radial-gradient(70% 72% at 82% 18%,rgba(8,163,234,.18),transparent 58%),radial-gradient(56% 58% at 18% 82%,rgba(134,193,30,.12),transparent 56%),linear-gradient(180deg,#fbfdff 0%,#eef6fc 100%)}
/* sticky 제거 — 스크롤 시 .philo-proof 카드가 아래 .pp 카드 뒤로 겹쳐 보이는 문제 */
.why-philo .txt{position:relative}
.why-philo .txt h2{letter-spacing:0}
.philo-visual{border-radius:30px;box-shadow:0 34px 92px rgba(14,42,71,.18),inset 0 0 0 1px rgba(255,255,255,.8)}
.philo-visual img{transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.philo-visual:hover img{transform:scale(1.035)}
.why-layers{position:absolute;inset:0;z-index:2;pointer-events:none}
.why-chip{position:absolute;display:inline-flex;align-items:center;min-height:36px;padding:0 15px;border-radius:999px;background:rgba(255,255,255,.86);border:1px solid rgba(255,255,255,.78);box-shadow:0 14px 34px rgba(14,42,71,.16);backdrop-filter:blur(14px);color:var(--navy);font-size:12.5px;font-weight:800}
.why-chip::before{content:"";width:7px;height:7px;margin-right:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(8,163,234,.14)}
.why-chip.c1{left:20px;top:20px}
.why-chip.c2{right:24px;top:32%}
.why-chip.c3{right:28px;bottom:96px}
.philo-points{align-items:stretch}
.pp{border-radius:22px;transition:transform .32s cubic-bezier(.16,1,.3,1),box-shadow .32s ease,border-color .32s ease}
.pp:hover{transform:translateY(-6px);border-color:rgba(8,163,234,.28);box-shadow:0 26px 58px rgba(14,42,71,.12)}

.doctors-premium{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#f4f9fd 100%)}
.doctors-premium::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 46% at 50% 0%,rgba(8,163,234,.12),transparent 68%);pointer-events:none}
.doctors-premium .wrap{position:relative}
.doctors-premium .docs{grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
.doctors-premium .doc{position:relative;border-radius:26px;overflow:hidden;border:1px solid rgba(230,236,243,.95);box-shadow:0 18px 44px rgba(14,42,71,.08);background:#fff;isolation:isolate}
.doctors-premium .doc::before{content:"";position:absolute;inset:auto 12px 12px 12px;height:46%;border-radius:22px;background:linear-gradient(180deg,rgba(8,163,234,.14),rgba(134,193,30,.09));opacity:0;transform:translateY(22px);transition:.42s cubic-bezier(.16,1,.3,1);z-index:-1}
.doctors-premium .doc:hover{box-shadow:0 30px 72px rgba(14,42,71,.16);transform:translateY(-8px)}
.doctors-premium .doc:hover::before{opacity:1;transform:none}
.doctors-premium .doc .ph{aspect-ratio:1/1.22;background-size:cover;background-position:center top;filter:saturate(.98);transition:transform .58s cubic-bezier(.16,1,.3,1),filter .4s ease}
.doctors-premium .doc:hover .ph{transform:scale(1.045);filter:saturate(1.06) contrast(1.02)}
.doctors-premium .doc .info{position:relative;margin-top:-28px;border-radius:24px 24px 0 0;background:linear-gradient(180deg,rgba(255,255,255,.96),#fff);padding:22px 20px 24px;box-shadow:0 -16px 30px rgba(14,42,71,.06)}
.doctors-premium .doc .role{display:inline-flex;padding:6px 10px;border-radius:999px;background:var(--blue-tint);color:var(--teal-d);font-size:11.5px;font-weight:800}
.doctors-premium .doc h3{font-size:22px;letter-spacing:0}
.doctors-premium .doc li{font-size:13px;line-height:1.5}
/* 보기 링크를 카드 최하단 한 줄에 정렬 */
.doctors-premium .doc{display:flex;flex-direction:column}
.doctors-premium .doc .info{flex:1;display:flex;flex-direction:column}
.doctors-premium .doc .doc-more{margin-top:auto;padding-top:16px;align-self:flex-start}
.doc-more{display:inline-flex;margin-top:16px;color:var(--teal-d);font-size:13px;font-weight:800}
.doc-more::after{content:"";width:16px;height:16px;margin-left:6px;background:currentColor;mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11h12.2l-5.1-5.1L12.5 4.5 20 12l-7.5 7.5-1.4-1.4 5.1-5.1H4z"/></svg>') center/contain no-repeat}

.facility-stage{display:grid;grid-template-columns:minmax(0,1fr) 230px;gap:18px;align-items:stretch}
.facility-main{position:relative;min-height:590px;border-radius:30px;overflow:hidden;background:var(--navy);box-shadow:0 34px 86px rgba(14,42,71,.18)}
.facility-panel{position:absolute;inset:0;isolation:isolate}
.facility-panel[hidden]{display:none}
.facility-panel img{width:100%;height:100%;object-fit:cover;animation:facilityImageIn .78s cubic-bezier(.16,1,.3,1) both}
.facility-panel::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,18,31,.08),rgba(6,18,31,.18) 45%,rgba(6,18,31,.72)),linear-gradient(0deg,rgba(6,18,31,.72),transparent 44%)}
.facility-copy{position:absolute;right:32px;bottom:30px;z-index:1;width:min(460px,calc(100% - 64px));padding:24px 26px;border-radius:22px;background:rgba(7,24,39,.72);border:1px solid rgba(255,255,255,.16);box-shadow:0 24px 54px rgba(2,11,20,.28);color:#fff;backdrop-filter:blur(14px);animation:facilityCopyIn .58s cubic-bezier(.16,1,.3,1) both}
.facility-copy span{color:#7fd0f7;font-size:12px;font-weight:800;letter-spacing:.12em}
.facility-copy h3{margin-top:9px;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:clamp(22px,2.5vw,30px);font-weight:800;line-height:1.34;letter-spacing:0}
.facility-copy p{margin-top:10px;color:#d7e8f5;font-size:14.5px;line-height:1.7}
.facility-rail{display:grid;gap:10px}
.facility-tab{height:100%;min-height:94px;padding:18px 18px;border:1px solid var(--line);border-radius:18px;background:#fff;text-align:left;font-family:inherit;cursor:pointer;box-shadow:0 14px 34px rgba(14,42,71,.06);transition:.32s cubic-bezier(.16,1,.3,1)}
.facility-tab span{display:block;color:var(--teal-d);font-size:12px;font-weight:800;font-variant-numeric:tabular-nums;margin-bottom:7px}
.facility-tab b{display:block;color:var(--ink);font-size:16px;font-weight:800;line-height:1.28}
.facility-tab:hover,.facility-tab.is-active{background:var(--navy);border-color:var(--navy);transform:translateX(-6px);box-shadow:0 22px 48px rgba(11,61,92,.22)}
.facility-tab:hover span,.facility-tab.is-active span{color:#7fd0f7}
.facility-tab:hover b,.facility-tab.is-active b{color:#fff}
@keyframes facilityImageIn{from{opacity:.42;transform:scale(1.065)}to{opacity:1;transform:scale(1)}}
@keyframes facilityCopyIn{from{opacity:0;transform:translate3d(18px,22px,0)}to{opacity:1;transform:none}}

@media(max-width:1024px){
  .center-stage,.facility-stage{grid-template-columns:1fr}
  .center-showcase{min-height:430px}
  .why-philo .txt{position:relative;top:auto}
  .doctors-premium .docs{grid-template-columns:repeat(2,minmax(0,1fr))}
  .facility-main{min-height:470px}
  .facility-rail{grid-auto-flow:column;grid-auto-columns:minmax(160px,1fr);overflow-x:auto;padding-bottom:8px}
  .facility-tab{min-height:78px}
  .facility-tab:hover,.facility-tab.is-active{transform:translateY(-4px)}
}
@media(max-width:900px){
  .hero-group-slide::after{background:
    linear-gradient(180deg,rgba(7,20,34,.34) 0%,rgba(7,20,34,0) 16%,rgba(7,20,34,0) 100%),
    linear-gradient(0deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.78) 14%,rgba(255,255,255,.42) 25%,rgba(255,255,255,0) 42%)}
  .center-stage{gap:16px}
  .center-row{grid-template-columns:44px minmax(0,1fr) 52px;min-height:92px;padding:15px 16px;transform:none!important}
  .center-no{width:38px;height:38px;border-radius:13px}
  .center-copy b{font-size:17px}
  .center-copy small{font-size:12.5px}
  .center-row img{width:50px;height:50px}
  .center-showcase{min-height:410px;border-radius:22px}
  .center-panel-copy{left:20px;right:20px;bottom:22px}
  .center-panel-copy h3{font-size:24px}
  .why-chip{display:none}
  .doctors-premium .docs{grid-template-columns:1fr}
  .doctors-premium .doc .ph{aspect-ratio:4/3.5}
  .facility-main{min-height:410px;border-radius:22px}
  .facility-copy{left:18px;right:18px;bottom:18px;width:auto;padding:20px}
}
@media(min-width:1025px){.hero-group-slide h1{white-space:nowrap;text-wrap:nowrap}}
@media(prefers-reduced-motion:reduce){.hero-group-slide.is-active::before{animation:none!important}}

/* ============ Facility page — 신축 이전 (facility.html) ============ */
/* 히어로: 신축 외관 풀블리드 */
.fhero{position:relative;height:88vh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden;background:var(--navy)}
.fhero .media{position:absolute;inset:0}
.fhero .media img{width:100%;height:100%;object-fit:cover;object-position:center 58%}
.fhero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(7,20,34,.78) 0%,rgba(8,22,38,.5) 38%,rgba(8,22,38,.12) 72%,rgba(8,22,38,.02) 100%),
  linear-gradient(0deg,rgba(6,17,30,.66) 0%,rgba(6,17,30,0) 46%)}
.fhero .in{position:relative;z-index:2;width:100%;padding-bottom:132px}
.fhero h1{color:#fff;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:clamp(32px,4.6vw,58px);line-height:1.18;font-weight:800;letter-spacing:-1.6px;text-shadow:0 2px 34px rgba(0,0,0,.34)}
.fhero h1 span{background:linear-gradient(96deg,var(--teal) 0%,#3fc0f5 55%,var(--green) 130%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.fhero .sub{color:#e0ebf5;font-size:clamp(15px,1.55vw,18.5px);margin-top:18px;max-width:600px;line-height:1.74;text-shadow:0 1px 16px rgba(0,0,0,.3)}
.fhero .hero-copy>*{opacity:0;transform:translateY(18px);animation:fheroIn .8s cubic-bezier(.2,.75,.25,1) forwards}
.fhero .hero-copy>:nth-child(2){animation-delay:.12s}
.fhero .hero-copy>:nth-child(3){animation-delay:.22s}
.fhero .hero-copy>:nth-child(4){animation-delay:.32s}
@keyframes fheroIn{to{opacity:1;transform:none}}
/* 규모 스트립 — 히어로 하단에 겹치는 글라스 카드 */
.fstats{position:relative;z-index:6;margin-top:-76px}
.fstats .grid{display:grid;grid-template-columns:repeat(4,1fr);border-radius:22px;overflow:hidden;
  background:rgba(9,26,42,.78);border:1px solid rgba(202,230,248,.16);backdrop-filter:blur(18px);
  box-shadow:0 30px 70px rgba(2,11,20,.35),inset 0 1px 0 rgba(255,255,255,.1)}
.fstats .fs{padding:28px 26px 24px;border-left:1px solid rgba(255,255,255,.09)}
.fstats .fs:first-child{border-left:none}
.fstats small{display:block;color:rgba(127,208,247,.8);font-size:11px;font-weight:800;letter-spacing:.12em;margin-bottom:10px}
.fstats b{display:flex;align-items:baseline;gap:5px;color:#fff;font-size:clamp(26px,2.6vw,36px);font-weight:800;letter-spacing:-1px;line-height:1}
.fstats b .count{font-variant-numeric:tabular-nums;background:linear-gradient(180deg,#fff 0%,#dcefff 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.fstats b .count.counting{-webkit-text-fill-color:#fff}
.fstats b i{color:var(--green);font-style:normal;font-size:.42em;font-weight:800}
.fstats span{display:block;color:#9db6ca;font-size:12.5px;font-weight:600;margin-top:7px}
.fstats .note{margin-top:12px;color:var(--mut);font-size:12px;text-align:right}
/* 시그니처 공간 — 교차 에디토리얼 행 */
.spaces{display:grid;gap:84px}
.srow{display:grid;grid-template-columns:1.12fr .88fr;gap:56px;align-items:center}
.srow.flip .simg{order:2}
.simg{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 30px 72px rgba(14,42,71,.16);background:#e9f3fb}
.simg img{width:100%;height:auto;aspect-ratio:16/10;object-fit:cover;transition:transform 1s cubic-bezier(.2,.7,.2,1)}
.srow:hover .simg img{transform:scale(1.035)}
.simg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0) 62%,rgba(6,18,31,.18) 100%);pointer-events:none}
.simg .fl-chip{position:absolute;left:18px;top:18px;z-index:1;display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:30px;background:rgba(255,255,255,.86);border:1px solid rgba(255,255,255,.7);
  backdrop-filter:blur(12px);color:var(--navy);font-weight:800;font-size:13px;box-shadow:0 10px 26px rgba(14,42,71,.16)}
.simg .fl-chip i{width:7px;height:7px;border-radius:50%;background:var(--teal);font-style:normal}
.stxt .n{font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:clamp(44px,4.6vw,64px);font-weight:800;line-height:1;
  background:linear-gradient(180deg,var(--blue-tint),rgba(231,245,253,.1));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  -webkit-text-stroke:1.5px rgba(8,163,234,.4)}
.stxt small{display:block;color:var(--teal-d);font-size:13px;font-weight:800;letter-spacing:.12em;margin:16px 0 10px}
.stxt h3{font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:clamp(23px,2.5vw,31px);font-weight:800;letter-spacing:-.5px;line-height:1.32}
.stxt p{color:#3a4a5c;font-size:15.5px;line-height:1.8;margin-top:14px;max-width:480px}
.stxt ul{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.stxt li{font-size:12.5px;color:var(--navy2);background:var(--bg);border:1px solid var(--line);padding:5px 12px;border-radius:20px}
/* 층별 안내 — 좌측 레일 + 우측 패널 */
.floors{display:grid;grid-template-columns:230px 1fr;gap:28px;align-items:start}
.fl-rail{display:grid;gap:8px}
.fl-btn{display:flex;align-items:center;gap:14px;padding:15px 18px;border:1px solid var(--line);border-radius:14px;
  background:#fff;cursor:pointer;text-align:left;font-family:inherit;transition:.2s}
.fl-btn .no{flex:none;min-width:38px;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:17px;font-weight:800;color:var(--teal-d);font-variant-numeric:tabular-nums}
.fl-btn .nm{font-size:14.5px;font-weight:700;color:var(--ink)}
.fl-btn:hover{border-color:rgba(8,163,234,.4);background:var(--blue-tint)}
.fl-btn.is-active{background:var(--navy);border-color:var(--navy);box-shadow:0 14px 30px rgba(11,61,92,.24)}
.fl-btn.is-active .no{color:#7fd0f7}
.fl-btn.is-active .nm{color:#fff}
.fl-pane{display:grid;grid-template-columns:1.05fr .95fr;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff;box-shadow:0 20px 48px rgba(14,42,71,.08)}
.fl-pane[hidden]{display:none}
.fl-pane .ph{min-height:340px;background:#e9f3fb}
.fl-pane .ph img{width:100%;height:100%;object-fit:cover}
.fl-pane .bd{padding:36px 36px 32px;display:flex;flex-direction:column}
.fl-pane .bd .fno{color:var(--teal-d);font-size:13px;font-weight:800;letter-spacing:.12em}
.fl-pane .bd h3{font-size:24px;font-weight:800;letter-spacing:-.4px;margin:8px 0 12px}
.fl-pane .bd p{color:#3a4a5c;font-size:15px;line-height:1.78}
.fl-pane .bd ul{list-style:none;display:grid;gap:9px;margin-top:20px}
.fl-pane .bd li{padding-left:24px;position:relative;color:#3a4a5c;font-size:14px}
.fl-pane .bd li::before{content:"";position:absolute;left:0;top:5px;width:14px;height:14px;border-radius:50%;
  background:var(--blue-tint) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%230678AE" stroke-width="3.4" stroke-linecap="round" stroke-linejoin="round"><path d="M4 12.5l5 5 11-11.5"/></svg>') center/8px no-repeat}
.fl-pane .bd .fmeta{margin-top:auto;padding-top:22px;color:var(--mut);font-size:12.5px}
/* 설계 원칙 카드 상단 라인 */
.fprin .tcard{position:relative;overflow:hidden}
.fprin .tcard::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--green))}
/* 신축 프로젝트 알림 배너 (index 시설 섹션 하단) */
.fac-more{margin-top:26px;display:flex;justify-content:center}
@media(max-width:1024px){
  .srow,.srow.flip{grid-template-columns:1fr;gap:22px}
  .srow.flip .simg{order:0}
  .stxt p{max-width:100%}
  .spaces{gap:56px}
  .floors{grid-template-columns:1fr}
  .fl-rail{grid-auto-flow:column;grid-auto-columns:max-content;overflow-x:auto;padding-bottom:6px}
  .fl-btn{padding:11px 14px}
  .fl-pane{grid-template-columns:1fr}
  .fl-pane .ph{min-height:220px;aspect-ratio:16/9}
}
@media(max-width:900px){
  .fhero{height:78vh;min-height:520px}
  .fhero .in{padding-bottom:110px}
  .fstats{margin-top:-58px}
  .fstats .grid{grid-template-columns:1fr 1fr}
  .fstats .fs{padding:20px 18px 18px}
  .fstats .fs:nth-child(3){border-left:none}
  .fstats .fs:nth-child(3),.fstats .fs:nth-child(4){border-top:1px solid rgba(255,255,255,.09)}
  .fstats .note{text-align:left}
}

/* ============ Sub-page category tab strip (도수교정치료 등) ============ */
.subnav{position:relative;z-index:5;background:#fff;border-bottom:1px solid var(--line)}
.subnav .row{display:flex;gap:6px;overflow-x:auto;padding:10px 0;-webkit-overflow-scrolling:touch}
.subnav a{flex:none;padding:11px 20px;border-radius:30px;font-size:14.5px;font-weight:700;color:var(--mut);transition:.2s;border:1px solid transparent}
.subnav a:hover{color:var(--teal-d);background:var(--blue-tint)}
.subnav a.is-active{background:var(--navy);color:#fff;box-shadow:0 10px 24px rgba(11,61,92,.22)}

/* ============ 자가진단 인터랙티브 체크리스트 (correction.html) ============ */
.chk{max-width:880px;margin:0 auto;border:1px solid var(--line);border-radius:24px;background:#fff;
  box-shadow:0 24px 56px rgba(14,42,71,.08);overflow:hidden}
.chk-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding:30px 34px 0}
.chk-head h3{font-size:clamp(19px,2.2vw,24px);font-weight:800;letter-spacing:-.4px}
.chk-head p{color:var(--mut);font-size:13.5px;margin-top:6px}
.chk-count{flex:none;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-weight:800;font-size:30px;color:var(--teal-d);font-variant-numeric:tabular-nums;line-height:1}
.chk-count i{font-style:normal;font-size:.5em;color:var(--mut);font-weight:700}
.chk-bar{height:8px;border-radius:8px;background:var(--bg);margin:20px 34px 8px;overflow:hidden}
.chk-bar i{display:block;height:100%;width:0;border-radius:8px;background:linear-gradient(90deg,var(--teal),var(--green));transition:width .45s cubic-bezier(.2,.75,.25,1)}
.chk-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:18px 34px 8px}
.chk-item{display:flex;align-items:center;gap:13px;padding:14px 16px;border:1px solid var(--line);border-radius:14px;
  cursor:pointer;transition:.2s;background:#fff;user-select:none}
.chk-item:hover{border-color:rgba(8,163,234,.45);background:var(--blue-tint)}
.chk-item input{position:absolute;opacity:0;pointer-events:none}
.chk-item .box{flex:none;width:22px;height:22px;border-radius:7px;border:1.5px solid #c6d4e2;background:#fff;position:relative;transition:.18s}
.chk-item .box::after{content:"";position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="3.6" stroke-linecap="round" stroke-linejoin="round"><path d="M5 12.5l4.5 4.5L19 7.5"/></svg>') center/13px no-repeat;opacity:0;transform:scale(.4);transition:.18s}
.chk-item .no{flex:none;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:13px;font-weight:800;color:#b8c7d6;font-variant-numeric:tabular-nums;transition:.18s}
.chk-item span{font-size:14.5px;font-weight:600;color:#3a4a5c;line-height:1.45}
.chk-item:has(input:checked){border-color:var(--teal);background:var(--blue-tint);box-shadow:0 10px 24px rgba(8,163,234,.12)}
.chk-item:has(input:checked) .box{background:var(--teal);border-color:var(--teal)}
.chk-item:has(input:checked) .box::after{opacity:1;transform:scale(1)}
.chk-item:has(input:checked) .no{color:var(--teal-d)}
.chk-item:has(input:focus-visible){outline:2.5px solid var(--teal);outline-offset:2px}
.chk-result{margin:16px 34px 30px;border-radius:16px;padding:22px 24px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  background:var(--bg);border:1px solid var(--line);transition:.25s}
.chk-result .msg{flex:1;min-width:240px}
.chk-result .msg b{display:block;font-size:16.5px;font-weight:800;letter-spacing:-.3px;margin-bottom:4px}
.chk-result .msg span{color:var(--mut);font-size:13.5px;line-height:1.6}
.chk-result .act{display:flex;gap:8px;flex-wrap:wrap}
.chk-result .act .go-book{display:inline-flex;align-items:center;gap:7px;padding:12px 20px;border-radius:12px;background:var(--teal);color:#fff;font-size:14px;font-weight:800;transition:.2s}
.chk-result .act .go-book:hover{background:#28B4F5;transform:translateY(-2px);box-shadow:0 10px 24px rgba(8,163,234,.4)}
.chk-result .act .re{display:inline-flex;align-items:center;padding:12px 18px;border-radius:12px;background:#fff;border:1px solid var(--line);color:var(--mut);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:.2s}
.chk-result .act .re:hover{color:var(--ink);border-color:#c6d4e2}
.chk-result.t-ok{background:var(--green-tint);border-color:rgba(134,193,30,.4)}
.chk-result.t-ok .msg b{color:var(--green-d)}
.chk-result.t-warn{background:#FFF7E8;border-color:rgba(224,168,58,.45)}
.chk-result.t-warn .msg b{color:#A9741B}
.chk-result.t-alert{background:var(--blue-tint);border-color:rgba(8,163,234,.45)}
.chk-result.t-alert .msg b{color:var(--teal-d)}
.chk-note{padding:0 34px 26px;color:#8fa0b1;font-size:12px}
@media(max-width:760px){
  .chk-head{padding:24px 20px 0}
  .chk-bar{margin:16px 20px 6px}
  .chk-list{grid-template-columns:1fr;padding:14px 20px 4px}
  .chk-result{margin:12px 20px 24px}
  .chk-note{padding:0 20px 22px}
}

/* ============ 산후교정 최적기 타임라인 (correction.html) ============ */
.pn-time{display:flex;align-items:stretch;gap:0;margin-top:22px;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff}
.pn-time>div{flex:1;padding:18px 18px 16px;position:relative}
.pn-time>div+div{border-left:1px dashed var(--line)}
.pn-time small{display:block;color:var(--teal-d);font-size:11.5px;font-weight:800;letter-spacing:.08em;margin-bottom:6px}
.pn-time b{display:block;font-size:15.5px;font-weight:800;letter-spacing:-.3px}
.pn-time span{display:block;color:var(--mut);font-size:12.5px;margin-top:4px;line-height:1.5}
.pn-time .on{background:var(--blue-tint)}
.pn-time .on::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--green))}
@media(max-width:720px){.pn-time{flex-direction:column}.pn-time>div+div{border-left:none;border-top:1px dashed var(--line)}}

/* ============ 치료 3단계 · 언론/후기 (symptoms.html) ============ */
.steps.cols3{grid-template-columns:repeat(3,1fr)}
@media(max-width:1024px){.steps.cols3{grid-template-columns:repeat(3,1fr)}}
@media(max-width:720px){.steps.cols3{grid-template-columns:1fr}}
.proof2{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}
.proof-card{border:1px solid var(--line);border-radius:20px;background:#fff;padding:28px 28px 24px;box-shadow:0 18px 42px rgba(14,42,71,.06)}
.proof-card>small{display:inline-flex;align-items:center;gap:9px;color:var(--teal-d);font-size:12.5px;font-weight:800;letter-spacing:.12em}
.proof-card>small::before{content:"";width:22px;height:2px;background:var(--teal);border-radius:2px}
.proof-card h3{font-size:19px;font-weight:800;letter-spacing:-.3px;margin:10px 0 16px}
.quote{border-left:3px solid var(--teal);padding:2px 0 2px 16px;margin-bottom:16px}
.quote p{font-size:15px;color:#2c3c4e;font-weight:600;line-height:1.65;letter-spacing:-.2px}
.quote span{display:block;color:var(--mut);font-size:12.5px;margin-top:6px}
.press-list{list-style:none;display:grid;gap:2px}
.press-list li{border-top:1px solid var(--line)}
.press-list li:first-child{border-top:none}
.press-list a{display:flex;align-items:baseline;gap:12px;padding:13px 2px;transition:.15s;border-radius:8px}
.press-list a:hover{background:var(--bg)}
.press-list .src{flex:none;color:var(--teal-d);font-size:12.5px;font-weight:800;min-width:64px}
.press-list .tt{flex:1;font-size:14.5px;font-weight:600;color:#2c3c4e;line-height:1.5}
.press-list time{flex:none;color:#9fb0c0;font-size:12px;font-variant-numeric:tabular-nums}
.proof-card .more{display:inline-flex;align-items:center;gap:7px;margin-top:14px;color:var(--teal-d);font-size:13.5px;font-weight:800}
.proof-card .more:hover{text-decoration:underline}
@media(max-width:900px){.proof2{grid-template-columns:1fr}}
/* 바디맵 확장 — 10부위(머리 포함) 세로 여백 · 이미지 로딩 전 CLS 방지 */
.bm-fig.xl{max-width:380px}
.bm-fig>img{aspect-ratio:1024/1536}
@media(max-width:1024px){.bm-fig.xl{max-width:290px}}

/* ============ High-end pass · WHY CHAMBARUN ============ */
/* 비주얼 카드 — 그라디언트 링 + 심도 강화 */
.philo-visual{box-shadow:0 40px 110px rgba(14,42,71,.2),0 0 0 1px rgba(255,255,255,.85),0 0 0 7px rgba(255,255,255,.35)}
.philo-visual::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;z-index:2;pointer-events:none;
  background:linear-gradient(135deg,rgba(8,163,234,.55),rgba(255,255,255,.1) 38%,rgba(134,193,30,.4));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
/* proof 카드 — 글래스 스탯 칩 (아이콘 좌측, 라벨/값 우측 2행) */
.philo-proof div{display:grid;grid-template-columns:38px 1fr;grid-template-rows:auto auto;column-gap:13px;align-items:center;
  border-radius:18px;padding:14px 18px;
  background:linear-gradient(180deg,#fff,rgba(255,255,255,.86));backdrop-filter:blur(10px);
  border:1px solid rgba(8,163,234,.14);box-shadow:0 16px 38px rgba(14,42,71,.09);transition:.28s}
.philo-proof div::before{grid-row:1/3}
.philo-proof dt{white-space:nowrap}
.philo-proof dd{margin-top:2px;white-space:nowrap}
.philo-proof div::before{content:"";flex:none;width:38px;height:38px;border-radius:13px;border:1.5px solid transparent;
  background:
    url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%230678AE" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><path d="M4 12.5l5 5 11-11.5"/></svg>') center/16px no-repeat,
    linear-gradient(135deg,var(--blue-tint),#fff) padding-box,
    linear-gradient(135deg,var(--teal),var(--green)) border-box}
.philo-proof div:hover{transform:translateY(-3px);box-shadow:0 22px 48px rgba(8,163,234,.16);border-color:rgba(8,163,234,.3)}
/* pp 카드 — 그라디언트 넘버 링 + 단계 커넥터 + 호버 보더 */
.pp{border-radius:24px;padding:26px 26px 28px;box-shadow:0 18px 44px rgba(14,42,71,.08)}
.pp::before{height:0}
.pp .n{width:46px;height:46px;border-radius:16px;font-size:17px;
  background:linear-gradient(135deg,var(--navy),var(--navy2)) padding-box;
  position:relative;box-shadow:0 10px 24px rgba(11,61,92,.28)}
.pp .n::after{content:"";position:absolute;inset:-3px;border-radius:19px;padding:1.5px;
  background:linear-gradient(135deg,var(--teal),var(--green));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude}
.pp{position:relative}
.pp:hover{border-color:transparent;background:
  linear-gradient(#fff,#fff) padding-box,
  linear-gradient(135deg,rgba(8,163,234,.6),rgba(134,193,30,.5)) border-box;
  border:1px solid transparent}
@media(max-width:1024px){.philo-points .pp:not(:last-child)::after{display:none}}

/* ---- WHY 3단계 카드 — 임팩트 리디자인 (고스트 넘버 + 네이비 반전 호버) ---- */
.philo-points{counter-reset:ppn;gap:18px;margin-top:18px}
.philo-points .pp{counter-increment:ppn;min-height:250px;padding:30px 28px 28px;display:flex;flex-direction:column;
  border-radius:26px;overflow:hidden;
  transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s ease,background .45s ease,border-color .4s ease}
.philo-points .pp .n{display:none}
/* 고스트 넘버 워터마크 */
.philo-points .pp::after{content:"0" counter(ppn);position:absolute;right:14px;top:-4px;z-index:0;
  font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:128px;font-weight:800;line-height:1;
  color:transparent;-webkit-text-stroke:1.5px rgba(8,163,234,.2);pointer-events:none;transition:.45s ease}
.philo-points .pp small{position:relative;z-index:1;display:inline-flex;width:fit-content;align-items:center;
  padding:7px 14px;border-radius:20px;background:var(--blue-tint);color:var(--teal-d);
  font-size:12.5px;font-weight:800;letter-spacing:.12em;margin-bottom:0;transition:.4s}
.philo-points .pp h4{position:relative;z-index:1;margin-top:auto;padding-top:34px;
  font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:21px;line-height:1.4;transition:color .4s}
.philo-points .pp p{position:relative;z-index:1;margin-top:10px;font-size:14.5px;line-height:1.7;transition:color .4s}
/* 호버 — 네이비 반전 */
.philo-points .pp:hover{background:linear-gradient(150deg,var(--navy) 0%,var(--navy2) 100%);
  border-color:transparent;transform:translateY(-8px);box-shadow:0 34px 72px rgba(11,61,92,.34)}
.philo-points .pp:hover::after{-webkit-text-stroke-color:rgba(127,208,247,.42)}
.philo-points .pp:hover small{background:rgba(8,163,234,.32);color:#dff1fd}
.philo-points .pp:hover h4{color:#fff}
.philo-points .pp:hover p{color:#c9dcec}

/* ---- WHY 치료 여정 밴드 — 네이비 글래스 + 발광 진행 라인 + 3D 스텝 오브젝트 ---- */
.journey{grid-column:1/-1;position:relative;margin-top:20px;border-radius:30px;padding:46px 44px 44px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;overflow:hidden;isolation:isolate;
  background:
    radial-gradient(80% 130% at 10% 0%,rgba(8,163,234,.18),transparent 52%),
    radial-gradient(70% 120% at 92% 100%,rgba(134,193,30,.12),transparent 46%),
    linear-gradient(150deg,#0A3350 0%,#0F4E76 55%,#0B3D5C 100%);
  border:1px solid rgba(127,208,247,.16);
  box-shadow:0 36px 88px rgba(11,61,92,.32),inset 0 1px 0 rgba(255,255,255,.12)}
.journey::before{content:"";position:absolute;inset:0;z-index:-1;background:
  linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:72px 72px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.8),transparent 85%)}
/* 진행 라인 — 스크롤 진입 시 그려짐 */
.jy-track{position:absolute;left:44px;right:44px;top:182px;height:2px;border-radius:2px;background:rgba(255,255,255,.12)}
.jy-track i{display:block;height:100%;width:0;border-radius:2px;
  background:linear-gradient(90deg,var(--teal),#3fc0f5 55%,var(--green));box-shadow:0 0 16px rgba(8,163,234,.65)}
.journey.reveal.in .jy-track i{width:100%;transition:width 1.5s .35s cubic-bezier(.22,.9,.24,1)}
/* 스텝 */
.jy-step{position:relative;transition:opacity .3s ease}
.journey:hover .jy-step:not(:hover){opacity:.55}
/* 노드는 스텝(밴드 패딩 46px 안쪽) 기준 절대좌표 — 밴드 기준 트랙(top:182px)과 일치: 182-46-7 */
.jy-node{position:absolute;left:1px;top:129px;width:14px;height:14px;border-radius:50%;background:#fff;
  box-shadow:0 0 0 5px rgba(8,163,234,.28),0 0 18px rgba(64,199,255,.85)}
.jy-obj{height:118px;width:auto;filter:drop-shadow(0 18px 32px rgba(2,11,20,.4));
  transition:transform .45s cubic-bezier(.16,1,.3,1),filter .35s ease}
.jy-step:hover .jy-obj{transform:translateY(-7px) scale(1.07);filter:drop-shadow(0 26px 40px rgba(2,11,20,.5)) brightness(1.08)}
.jy-step small{display:block;margin-top:64px;color:#7fd0f7;font-size:12px;font-weight:800;letter-spacing:.15em}
.jy-step h4{margin-top:11px;color:#fff;font-family:'Paperlogy','Pretendard Variable',sans-serif;
  font-size:clamp(19px,1.7vw,22px);font-weight:800;line-height:1.4;letter-spacing:-.3px}
.jy-step p{margin-top:11px;color:#bcd2e6;font-size:14px;line-height:1.72}
/* 진입 스태거 */
.journey.reveal.in .jy-step{animation:jyIn .75s cubic-bezier(.16,1,.3,1) backwards}
.journey.reveal.in .jy-step:nth-child(3){animation-delay:.15s}
.journey.reveal.in .jy-step:nth-child(4){animation-delay:.3s}
@keyframes jyIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.journey.reveal.in .jy-node{animation:jyNode .5s backwards}
.journey.reveal.in .jy-step:nth-child(3) .jy-node{animation-delay:.55s}
.journey.reveal.in .jy-step:nth-child(4) .jy-node{animation-delay:1s}
@keyframes jyNode{from{transform:scale(0)}to{transform:scale(1)}}
@media(max-width:1024px){
  .journey{grid-template-columns:1fr;gap:34px;padding:36px 28px}
  .jy-track,.jy-node{display:none}
  .jy-step small{margin-top:18px}
  .jy-obj{height:96px}
}

/* ---- WHY 스테이지: 메인 씬 (플로팅 에셋 없이 씬 자체로) ---- */
.why-stage{isolation:isolate}
.why-stage .why-scene{display:block;height:100%}
.why-stage .why-scene img{transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
/* 칩 진입 스태거 — 부유 없이 정적 배치 */
.why-stage.reveal.in .why-chip{animation:whyChipIn .7s cubic-bezier(.16,1,.3,1) backwards}
.why-stage.reveal.in .why-chip.c2{animation-delay:.18s}
.why-stage.reveal.in .why-chip.c3{animation-delay:.36s}
@keyframes whyChipIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
/* 헤드라인 키워드 — 그라디언트 시머 */
.why-philo .txt h2 span{background:linear-gradient(100deg,var(--teal-d) 0%,var(--teal) 30%,var(--green) 55%,var(--teal-d) 80%);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:whySheen 5.5s ease-in-out infinite}
@keyframes whySheen{0%,100%{background-position:0% 0}50%{background-position:100% 0}}
/* 01→03 카드 · 커넥터 스태거 진입 */
.philo-points.reveal.in .pp{animation:ppRise .7s cubic-bezier(.16,1,.3,1) backwards}
.philo-points.reveal.in .pp:nth-child(2){animation-delay:.14s}
.philo-points.reveal.in .pp:nth-child(3){animation-delay:.28s}
@keyframes ppRise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* ============ High-end pass · MEDICAL STAFF 카드 ============ */
.doctors-premium .docs{counter-reset:docn;gap:16px}
.doctors-premium .doc{counter-increment:docn;border-radius:28px;
  box-shadow:0 22px 54px rgba(14,42,71,.1),inset 0 0 0 1px rgba(255,255,255,.7)}
/* 에디토리얼 인덱스 넘버 — 사진 좌상단 */
.doctors-premium .doc .ph{position:relative}
.doctors-premium .doc .ph::before{content:"0" counter(docn);position:absolute;left:16px;top:12px;z-index:1;
  font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:34px;font-weight:800;line-height:1;
  color:rgba(255,255,255,.92);-webkit-text-stroke:1px rgba(8,163,234,.35);
  text-shadow:0 4px 18px rgba(11,61,92,.35);opacity:.9}
/* 사진 톤 — 평상시 살짝 절제, 호버 시 선명 */
.doctors-premium .doc .ph{filter:saturate(.88) contrast(.98)}
.doctors-premium .doc:hover .ph{filter:saturate(1.1) contrast(1.04) brightness(1.03);transform:scale(1.05)}
.doctors-premium .doc .ph::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,61,92,.12) 0%,transparent 26%,transparent 62%,rgba(255,255,255,.42) 100%)}
/* 인포 패널 — 글래스 + 그라디언트 헤어라인 */
.doctors-premium .doc .info{border-radius:26px 26px 0 0;padding:20px 20px 22px;
  background:linear-gradient(180deg,rgba(255,255,255,.97),#fff)}
.doctors-premium .doc .info::before{content:"";position:absolute;left:22px;right:22px;top:0;height:2.5px;border-radius:3px;
  background:linear-gradient(90deg,var(--teal),var(--green));opacity:0;transition:.35s}
.doctors-premium .doc:hover .info::before{opacity:1}
.doctors-premium .doc h3{font-family:'Paperlogy','Pretendard Variable',sans-serif}
.doctors-premium .doc li{padding-left:20px}
.doctors-premium .doc li::before{width:13px;height:13px;border-radius:50%;top:4px;
  background:var(--blue-tint) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%230678AE" stroke-width="3.6" stroke-linecap="round" stroke-linejoin="round"><path d="M4 12.5l5 5 11-11.5"/></svg>') center/7px no-repeat}
/* 보기 링크 — 화살표 슬라이드 */
.doctors-premium .doc .doc-more{position:relative}
.doctors-premium .doc .doc-more::after{transition:transform .28s cubic-bezier(.16,1,.3,1)}
.doctors-premium .doc:hover .doc-more::after{transform:translateX(5px)}
/* 카드 전체 그라디언트 링 (호버) */
.doctors-premium .doc:hover{box-shadow:0 34px 80px rgba(14,42,71,.18),0 0 0 1.5px rgba(8,163,234,.35),inset 0 0 0 1px rgba(255,255,255,.8)}

/* ============ MEDICAL STAFF · 익스팬딩 스테이지 ============ */
.staff-stage{display:flex;gap:14px;height:620px}
.staff-panel{position:relative;flex:1;min-width:0;border-radius:26px;overflow:hidden;cursor:pointer;
  background:linear-gradient(180deg,#e8f0f7,#dfe9f2);outline:none;isolation:isolate;
  box-shadow:0 20px 50px rgba(14,42,71,.1),inset 0 0 0 1px rgba(255,255,255,.65);
  transition:flex .72s cubic-bezier(.22,.9,.24,1),box-shadow .4s ease}
.staff-panel.is-active{flex:2.7;box-shadow:0 34px 84px rgba(14,42,71,.2),inset 0 0 0 1px rgba(255,255,255,.8)}
.staff-panel:focus-visible{outline:2.5px solid var(--teal);outline-offset:3px}
.sp-photo{position:absolute;inset:0}
.sp-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;
  filter:saturate(.8) brightness(.97);transition:filter .55s ease,transform .9s cubic-bezier(.16,1,.3,1)}
.staff-panel.is-active .sp-photo img{filter:saturate(1.04) brightness(1.01);transform:scale(1.03)}
/* 접힌 상태 — 하단 네임 칩 */
.sp-name{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:64px 14px 18px;text-align:center;
  background:linear-gradient(180deg,transparent,rgba(7,24,39,.72));
  opacity:1;transition:opacity .35s ease}
.sp-name b{display:block;color:#fff;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:18px;font-weight:800;letter-spacing:-.3px}
.sp-name span{display:block;margin-top:3px;color:#bcd7ea;font-size:11.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.staff-panel.is-active .sp-name{opacity:0}
/* 펼친 상태 — 상세 패널 */
.sp-detail{position:absolute;left:0;right:auto;bottom:0;z-index:3;padding:120px 30px 28px;width:390px;
  background:linear-gradient(180deg,transparent 0%,rgba(7,24,39,.55) 34%,rgba(7,24,39,.92) 100%);
  opacity:0;transform:translateY(26px);pointer-events:none;
  /* 접힐 때는 빠르게 사라져 패널 축소와 텍스트 잔상이 겹치지 않게 */
  transition:opacity .16s ease,transform .3s ease}
.staff-panel.is-active .sp-detail{opacity:1;transform:none;pointer-events:auto;
  transition:opacity .45s ease .22s,transform .55s cubic-bezier(.16,1,.3,1) .22s}
.sp-detail small{color:#7fd0f7;font-size:11.5px;font-weight:800;letter-spacing:.14em}
.sp-detail h3{margin-top:8px;color:#fff;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:clamp(24px,2.4vw,31px);font-weight:800;letter-spacing:-.4px}
.sp-detail h3 i{font-style:normal;font-size:.55em;font-weight:700;color:#bcd7ea;margin-left:5px}
.sp-role{display:inline-flex;margin-top:8px;padding:6px 12px;border-radius:20px;background:rgba(8,163,234,.24);
  border:1px solid rgba(127,208,247,.4);color:#dff1fd;font-size:12.5px;font-weight:800}
.sp-detail ul{list-style:none;display:grid;gap:8px;margin-top:16px}
.sp-detail li{position:relative;padding-left:22px;color:#dbe9f5;font-size:13.5px;line-height:1.55}
.sp-detail li::before{content:"";position:absolute;left:0;top:4px;width:14px;height:14px;border-radius:50%;
  background:rgba(134,193,30,.22) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%239ED927" stroke-width="3.4" stroke-linecap="round" stroke-linejoin="round"><path d="M4 12.5l5 5 11-11.5"/></svg>') center/8px no-repeat}
.sp-more{display:inline-flex;align-items:center;gap:8px;margin-top:18px;padding:11px 18px;border-radius:12px;
  background:var(--teal);color:#fff;font-size:13.5px;font-weight:800;transition:.25s}
.sp-more::after{content:"";width:15px;height:15px;background:currentColor;
  mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11h12.2l-5.1-5.1L12.5 4.5 20 12l-7.5 7.5-1.4-1.4 5.1-5.1H4z"/></svg>') center/contain no-repeat;
  transition:transform .25s}
.sp-more:hover{background:#28B4F5;transform:translateY(-2px);box-shadow:0 12px 28px rgba(8,163,234,.4)}
.sp-more:hover::after{transform:translateX(4px)}
/* 진입 스태거 */
.staff-stage.reveal.in .staff-panel{animation:staffIn .75s cubic-bezier(.16,1,.3,1) backwards}
.staff-stage.reveal.in .staff-panel:nth-child(2){animation-delay:.08s}
.staff-stage.reveal.in .staff-panel:nth-child(3){animation-delay:.16s}
.staff-stage.reveal.in .staff-panel:nth-child(4){animation-delay:.24s}
.staff-stage.reveal.in .staff-panel:nth-child(5){animation-delay:.32s}
@keyframes staffIn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@media(max-width:900px){
  .staff-stage{flex-direction:column;height:auto;gap:10px}
  .staff-panel{flex:none;height:78px;border-radius:20px;transition:height .6s cubic-bezier(.22,.9,.24,1),box-shadow .4s}
  .staff-panel.is-active{flex:none;height:460px}
  .sp-photo img{object-position:center 18%}
  .sp-name{padding:0 18px;top:0;display:flex;align-items:center;gap:10px;text-align:left;background:linear-gradient(90deg,rgba(7,24,39,.62),transparent 70%)}
  .sp-name b{font-size:16px}
  .sp-name span{margin-top:0}
  .sp-detail{padding:90px 22px 22px;width:100%}
}

/* ============ 환자 후기 — 무한 marquee 슬라이드 ============ */
.rev-marquee{overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.rev-track{display:flex;width:max-content;animation:revScroll 58s linear infinite}
.rev-marquee:hover .rev-track{animation-play-state:paused}
.rev-set{display:flex;gap:20px;padding-right:20px}
.rev-set .rev{width:392px;flex:none;display:flex;flex-direction:column}
.rev-set .rev p{flex:1}
@keyframes revScroll{to{transform:translateX(-50%)}}
@media(max-width:720px){.rev-set .rev{width:300px}}
@media (prefers-reduced-motion:reduce){.rev-track{animation:none}}
.review-write-btn{display:inline-flex;align-items:center;justify-content:center;margin-top:22px;padding:11px 18px;border-radius:999px;border:1px solid rgba(8,163,234,.34);background:rgba(255,255,255,.78);color:var(--teal-d);font:800 14px 'Pretendard Variable',Pretendard,sans-serif;cursor:pointer;box-shadow:0 10px 24px rgba(14,42,71,.06);transition:.22s}
.review-write-btn:hover{background:var(--teal);color:#fff;border-color:var(--teal);transform:translateY(-2px);box-shadow:0 16px 34px rgba(8,163,234,.24)}
.new-badge{margin-left:auto;align-self:flex-start;padding:4px 8px;border-radius:999px;background:var(--green);color:#fff;font-size:10px;font-weight:900;letter-spacing:.04em}
.review-modal{position:fixed;inset:0;z-index:130;display:flex;align-items:center;justify-content:center;padding:22px;pointer-events:none}
.review-scrim{position:absolute;inset:0;background:rgba(6,17,30,.5);backdrop-filter:blur(4px);opacity:0;transition:.28s ease}
.review-card{position:relative;z-index:1;width:min(520px,100%);max-height:min(720px,calc(100vh - 44px));overflow:auto;border-radius:24px;background:#fff;box-shadow:0 34px 92px rgba(6,17,30,.28);opacity:0;transform:translateY(18px) scale(.98);transition:.32s cubic-bezier(.16,1,.3,1)}
.review-modal.open{pointer-events:auto}
.review-modal.open .review-scrim{opacity:1}
.review-modal.open .review-card{opacity:1;transform:none}
.review-close{position:absolute;right:18px;top:18px;z-index:2;width:38px;height:38px;border:1px solid rgba(255,255,255,.3);border-radius:12px;background:rgba(255,255,255,.1);color:#fff;font-size:22px;line-height:1;cursor:pointer}
.review-head{padding:28px 30px 24px;background:linear-gradient(150deg,#0A3350,#0F4E76);color:#fff}
.review-head small{color:#7fd0f7;font-size:11.5px;font-weight:800;letter-spacing:.14em}
.review-head b{display:block;margin-top:8px;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:24px;font-weight:800}
.review-head span{display:block;margin-top:7px;color:#bcd2e6;font-size:12.5px}
.review-form{display:grid;gap:15px;padding:28px 30px 30px}
.review-form label{display:grid;gap:7px}
.review-form label>span,.review-stars legend{font-size:13px;font-weight:800;color:var(--navy)}
.review-form input[type=text],.review-form select,.review-form textarea{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font:500 14.5px/1.5 'Pretendard Variable',Pretendard,sans-serif;color:var(--ink);background:#fbfdff;transition:.2s}
.review-form textarea{resize:vertical;min-height:118px}
.review-form :is(input,select,textarea):focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(8,163,234,.12)}
.review-form select{appearance:none;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%235b6b7f" stroke-width="2.4" stroke-linecap="round" stroke-linejoin="round"><path d="M6 9l6 6 6-6"/></svg>');background-repeat:no-repeat;background-position:right 14px center;background-size:16px}
.review-stars{display:flex;align-items:center;gap:4px;border:0;padding:0;margin:0}
.review-stars legend{width:100%;margin-bottom:4px}
.review-stars button{width:34px;height:34px;border:0;background:transparent;color:#c9d3df;font-size:27px;line-height:1;cursor:pointer;transition:.16s}
.review-stars button.is-active,.review-stars button.is-hover{color:#F3B42E;transform:translateY(-1px)}
.review-form .agree{display:flex;align-items:flex-start;gap:10px;cursor:pointer}
.review-form .agree input{position:absolute;opacity:0;pointer-events:none}
.review-form .agree i{flex:none;width:20px;height:20px;border-radius:6px;border:1.5px solid #c6d4e2;background:#fff;position:relative;transition:.18s;margin-top:1px}
.review-form .agree i::after{content:"";position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="3.6" stroke-linecap="round" stroke-linejoin="round"><path d="M5 12.5l4.5 4.5L19 7.5"/></svg>') center/12px no-repeat;opacity:0;transform:scale(.4);transition:.18s}
.review-form .agree:has(input:checked) i{background:var(--teal);border-color:var(--teal)}
.review-form .agree:has(input:checked) i::after{opacity:1;transform:scale(1)}
.review-form .agree span{font-size:13px;color:var(--mut);line-height:1.55}
.review-submit{border:none;border-radius:14px;padding:16px;background:var(--teal);color:#fff;font:800 16px 'Pretendard Variable',Pretendard,sans-serif;cursor:pointer;transition:.2s}
.review-submit:hover{background:#28B4F5;transform:translateY(-2px);box-shadow:0 12px 30px rgba(8,163,234,.4)}
@media(max-width:540px){.review-card{border-radius:20px}.review-head,.review-form{padding-left:22px;padding-right:22px}}

/* ============ High-end pass · BY THE NUMBERS 인터랙션 ============ */
/* 막대 호버 — 포커스 강조 + 형제 감쇠 */
.patient-point{cursor:default;transition:.3s}
.patient-bars:hover .patient-point:not(:hover){opacity:.42}
.patient-point:hover .patient-bar{background:linear-gradient(180deg,#3fc0f5,rgba(255,255,255,.92));
  box-shadow:0 0 0 1.5px rgba(127,208,247,.55),0 16px 38px rgba(8,163,234,.45)}
.patient-point:hover b{color:#fff;text-shadow:0 0 18px rgba(64,199,255,.8)}
.patient-point b,.patient-bar{transition:.3s}
/* KPI 카드 호버 — 아이콘·수치 선명하게 (진입 애니메이션은 backwards라 충돌 없음, 순수 transition) */
.trust .t .count,.trust .t b{transition:.3s}
.trust .t .kpi-visual{transition:opacity .38s cubic-bezier(.16,1,.3,1),transform .38s cubic-bezier(.16,1,.3,1),filter .38s ease}
.trust .t:hover .kpi-visual{opacity:1;filter:drop-shadow(0 16px 26px rgba(2,11,20,.3)) saturate(1.2) brightness(1.06);transform:translate3d(0,0,0) scale(1.14)}
.trust .t:hover b{text-shadow:0 0 26px rgba(127,208,247,.55)}
.trust .t:hover .kpi-meta{color:#9ED927}
.kpi-meta{transition:.3s}
/* 차트 카드 호버 — 은은한 링 */
.patient-chart{transition:.3s}
.patient-chart:hover{border-color:rgba(127,208,247,.28);box-shadow:0 30px 76px rgba(2,11,20,.32),inset 0 1px 0 rgba(255,255,255,.16)}

/* ============ 바디맵 부위별 배경 레이어 (bm-bg-*.webp — codex 생성) ============ */
.bm-bg{position:absolute;inset:0;z-index:0;border-radius:inherit;background-size:cover;background-position:center;
  opacity:0;transform:scale(1.08);transition:opacity .8s ease,transform 1.2s cubic-bezier(.16,1,.3,1);pointer-events:none}
.bm-fig.is-zoomed .bm-bg.is-on{opacity:.5;transform:scale(1)}
.bm-fig .bm-zoomer{z-index:1}

/* ============ 플로팅 메뉴 — 항목별 호버 컬러 ============ */
.float-menu a:nth-of-type(2):hover{background:#FEE500;border-color:#FEE500;color:#191919;box-shadow:0 16px 34px rgba(254,229,0,.35)}
.float-menu a:nth-of-type(3):hover{background:var(--green);border-color:var(--green);box-shadow:0 16px 34px rgba(134,193,30,.32)}
.float-menu a:nth-of-type(4):hover{background:#03C75A;border-color:#03C75A;box-shadow:0 16px 34px rgba(3,199,90,.32)}
.float-menu a:nth-of-type(5):hover{background:linear-gradient(135deg,#F58529,#DD2A7B 55%,#8134AF);border-color:transparent;box-shadow:0 16px 34px rgba(221,42,123,.32)}
.float-menu a:nth-of-type(6):hover{background:linear-gradient(135deg,var(--teal),var(--green));border-color:transparent;box-shadow:0 16px 34px rgba(8,163,234,.3)}

/* ============ 상담 신청 폼 (데모) ============ */
.consult{background:var(--bg)}
.consult-band{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;border-radius:30px;overflow:hidden;
  box-shadow:0 34px 84px rgba(11,61,92,.22)}
.cb-copy{padding:52px 48px;color:#fff;background:
  radial-gradient(80% 120% at 12% 0%,rgba(8,163,234,.2),transparent 52%),
  radial-gradient(70% 110% at 90% 100%,rgba(134,193,30,.13),transparent 46%),
  linear-gradient(150deg,#0A3350 0%,#0F4E76 60%,#0B3D5C 100%)}
.cb-copy .en{display:inline-flex;align-items:center;gap:9px;color:#7fd0f7;font-size:12.5px;font-weight:800;letter-spacing:.14em}
.cb-copy .en::before{content:"";width:22px;height:2px;background:var(--teal);border-radius:2px}
.cb-copy h2{margin-top:14px;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:clamp(26px,2.8vw,36px);font-weight:800;line-height:1.3;letter-spacing:-.5px}
.cb-copy h2 span{background:linear-gradient(96deg,var(--teal) 0%,#3fc0f5 55%,var(--green) 130%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cb-copy p{margin-top:16px;color:#bcd2e6;font-size:15px;line-height:1.75}
.cb-copy ul{list-style:none;margin-top:26px;display:grid;gap:10px}
.cb-copy li{position:relative;padding-left:24px;color:#dbe9f5;font-size:14px}
.cb-copy li b{color:#fff;font-size:16px;margin-left:4px}
.cb-copy li::before{content:"";position:absolute;left:0;top:5px;width:14px;height:14px;border-radius:50%;
  background:rgba(134,193,30,.22) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%239ED927" stroke-width="3.4" stroke-linecap="round" stroke-linejoin="round"><path d="M4 12.5l5 5 11-11.5"/></svg>') center/8px no-repeat}
.cb-form{padding:44px 46px;background:#fff;display:grid;gap:16px;align-content:start}
.cb-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cb-form label{display:grid;gap:7px}
.cb-form label>span{font-size:13px;font-weight:800;color:var(--navy)}
.cb-form input[type=text],.cb-form input[type=tel],.cb-form select,.cb-form textarea{
  width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font:500 14.5px/1.5 'Pretendard Variable',Pretendard,sans-serif;
  color:var(--ink);background:#fbfdff;transition:.2s;appearance:none}
.cb-form textarea{resize:vertical;min-height:96px}
.cb-form :is(input,select,textarea):focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px rgba(8,163,234,.12)}
.cb-form select{background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%235b6b7f" stroke-width="2.4" stroke-linecap="round" stroke-linejoin="round"><path d="M6 9l6 6 6-6"/></svg>');background-repeat:no-repeat;background-position:right 14px center;background-size:16px}
.cb-form .agree{display:flex;align-items:flex-start;gap:10px;cursor:pointer}
.cb-form .agree input{position:absolute;opacity:0;pointer-events:none}
.cb-form .agree i{flex:none;width:20px;height:20px;border-radius:6px;border:1.5px solid #c6d4e2;background:#fff;position:relative;transition:.18s;margin-top:1px}
.cb-form .agree i::after{content:"";position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="3.6" stroke-linecap="round" stroke-linejoin="round"><path d="M5 12.5l4.5 4.5L19 7.5"/></svg>') center/12px no-repeat;opacity:0;transform:scale(.4);transition:.18s}
.cb-form .agree:has(input:checked) i{background:var(--teal);border-color:var(--teal)}
.cb-form .agree:has(input:checked) i::after{opacity:1;transform:scale(1)}
.cb-form .agree span{font-size:13px;color:var(--mut);line-height:1.55}
.cb-submit{border:none;border-radius:14px;padding:16px;background:var(--teal);color:#fff;font:800 16px 'Pretendard Variable',Pretendard,sans-serif;cursor:pointer;transition:.2s}
.cb-submit:hover{background:#28B4F5;transform:translateY(-2px);box-shadow:0 12px 30px rgba(8,163,234,.4)}
.cb-submit:disabled{background:var(--green);transform:none;cursor:default}
.cb-done{color:var(--green-d);font-size:14px;font-weight:700}
.cb-note{color:#8fa0b1;font-size:12px}
.consult-board{background:linear-gradient(180deg,#fff 0%,var(--bg) 100%)}
.cbd-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:24px;align-items:start}
.cbd-list{display:grid;gap:12px}
.cbd-side{position:sticky;top:96px;border:1px solid var(--line);border-radius:22px;background:#fff;padding:28px;box-shadow:0 18px 44px rgba(14,42,71,.08)}
.cbd-side b{display:block;color:var(--navy);font-size:22px;font-weight:800}
.cbd-side p{margin-top:10px;color:var(--mut);font-size:14.5px;line-height:1.7}
.cbd-side .btn{width:100%;justify-content:center;margin-top:20px}
.cbd-side small{display:block;margin-top:14px;color:#8fa0b1;font-size:12px;line-height:1.55}
@media(max-width:1024px){.consult-band{grid-template-columns:1fr}.cb-copy{padding:40px 32px}.cb-form{padding:34px 28px}}
@media(max-width:720px){.cb-form .row2{grid-template-columns:1fr}}

/* ============ 상담 문의 — 스티키 FAB + 슬라이드 드로어 ============ */
.consult-fab{position:fixed;right:22px;bottom:22px;z-index:96;display:inline-flex;align-items:center;gap:9px;
  padding:15px 22px;border:none;border-radius:32px;cursor:pointer;
  background:linear-gradient(135deg,var(--teal),#28B4F5);color:#fff;
  font:800 15px 'Pretendard Variable',Pretendard,sans-serif;
  box-shadow:0 16px 40px rgba(8,163,234,.42);transition:.25s}
.consult-fab svg{width:19px;height:19px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.consult-fab:hover{transform:translateY(-3px);box-shadow:0 22px 50px rgba(8,163,234,.5);background:linear-gradient(135deg,#28B4F5,var(--green))}
.consult-drawer{position:fixed;inset:0;z-index:120;pointer-events:none}
.consult-drawer .cd-scrim{position:absolute;inset:0;background:rgba(6,17,30,.44);backdrop-filter:blur(3px);
  opacity:0;transition:opacity .45s ease}
.consult-drawer .cd-panel{position:absolute;right:0;top:0;bottom:0;width:min(520px,100%);background:#fff;
  box-shadow:-30px 0 80px rgba(6,17,30,.3);display:flex;flex-direction:column;overflow-y:auto;
  transform:translateX(102%);transition:transform .55s cubic-bezier(.22,.9,.24,1)}
.consult-drawer.open{pointer-events:auto}
.consult-drawer.open .cd-scrim{opacity:1}
.consult-drawer.open .cd-panel{transform:none}
.cd-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:26px 28px 20px;
  background:linear-gradient(150deg,#0A3350,#0F4E76);color:#fff}
.cd-head small{color:#7fd0f7;font-size:11.5px;font-weight:800;letter-spacing:.14em}
.cd-head b{display:block;margin-top:7px;font-family:'Paperlogy','Pretendard Variable',sans-serif;font-size:21px;font-weight:800}
.cd-head span{display:block;margin-top:6px;color:#bcd2e6;font-size:12.5px}
.cd-close{flex:none;width:38px;height:38px;border:1px solid rgba(255,255,255,.3);border-radius:12px;background:rgba(255,255,255,.1);
  color:#fff;font-size:22px;line-height:1;cursor:pointer;transition:.2s}
.cd-close:hover{background:rgba(255,255,255,.22)}
.cd-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:18px 28px 0;padding:5px;border-radius:999px;background:#edf4f9;border:1px solid var(--line)}
.cd-tabs button{border:0;border-radius:999px;padding:11px 14px;background:transparent;color:var(--mut);font:800 14px 'Pretendard Variable',Pretendard,sans-serif;cursor:pointer;transition:.2s}
.cd-tabs button.is-active{background:var(--navy);color:#fff;box-shadow:0 10px 24px rgba(11,61,92,.2)}
.cd-tab-panel[hidden]{display:none!important}
.consult-drawer .cb-form{padding:26px 28px 30px}
.cd-history{padding:22px 28px 30px}
.cd-list{display:grid;gap:10px}
.cd-post{border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden;box-shadow:0 10px 24px rgba(14,42,71,.05)}
.cd-post-btn{width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;align-items:center;gap:8px;border:0;background:#fff;padding:15px;text-align:left;font-family:inherit;cursor:pointer}
.cd-post-btn:hover{background:#f8fbfe}
.cd-post-main{min-width:0}
.cd-post-main b{display:block;color:var(--ink);font-size:14.5px;font-weight:800;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cd-post-main small{display:block;margin-top:5px;color:var(--mut);font-size:12px;font-weight:600}
.cd-chip,.cd-state,.cd-new{display:inline-flex;align-items:center;height:24px;padding:0 9px;border-radius:999px;font-size:11px;font-weight:900;white-space:nowrap}
.cd-chip{background:var(--blue-tint);color:var(--teal-d)}
.cd-state.done{background:var(--green-tint);color:var(--green-d)}
.cd-state.pending{background:var(--blue-tint);color:var(--teal-d)}
.cd-new{background:var(--green);color:#fff}
.cd-post.is-locked .cd-post-main b{display:flex;align-items:center;gap:7px}
.cd-post.is-locked .cd-post-main b::before{content:"";width:13px;height:13px;background:var(--mut);mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M7 10V7a5 5 0 0 1 10 0v3h1a2 2 0 0 1 2 2v8a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-8a2 2 0 0 1 2-2h1Zm2 0h6V7a3 3 0 0 0-6 0v3Z"/></svg>') center/contain no-repeat}
.cd-answer{padding:0 15px 16px;color:#34495d;font-size:13.5px;line-height:1.65}
.cd-answer p{padding-top:4px}
.cd-answer blockquote{margin-top:11px;padding:12px 14px;border-left:3px solid var(--navy);border-radius:0 12px 12px 0;background:#f4f8fc;color:#274259;font-weight:600}
.cd-demo{margin-top:14px;color:#8fa0b1;font-size:12px}
@media(max-width:540px){
  .cd-post-btn{grid-template-columns:minmax(0,1fr) auto;gap:7px}
  .cd-state{grid-column:2}
  .cd-chip{grid-column:2;grid-row:1}
}
@media(max-width:900px){.cbd-grid{grid-template-columns:1fr}.cbd-side{position:relative;top:auto}.consult-fab{right:14px;bottom:76px;padding:13px 18px}}

/* ============ Polish · reduced motion ============ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .slide.is-active .hero-copy>*{opacity:1!important;transform:none!important}
  .hero-media .poster{animation:none}
}
