﻿@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard-dynamic-subset.min.css');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+KR:wght@400;600;700&display=swap');

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  /* 쿨 그린 팔레트 (웜 그린 → 쿨 제이드/틸 계열) */
  --green-950: #0a1c17;
  --green-900: #11322a;
  --green-800: #18463b;
  --green-700: #205e4f;
  --green-600: #2c7c69;
  --green-500: #3a9b84;
  --green-100: #e4f1ed;
  --green-50:  #eff7f4;
  /* 골드 제거 → 쿨 민트-제이드 액센트로 재정의 (변수명은 유지해 전 참조 자동 반영) */
  --gold:      #4fb39a;
  --gold-light:#cdeae0;
  --white:     #ffffff;
  --paper:     #f6f8f7;
  --ink:       #1c2420;
  --ink-muted: #55605b;
  --ink-light: #8a958f;
  --border:    #d9e7e1;
  --font-serif: 'Noto Serif KR', Georgia, serif;
  --font-sans:  'Pretendard', 'Apple SD Gothic Neo', -apple-system, sans-serif;
  --text-xs:   0.75rem;
  --text-sm:   0.875rem;
  --text-base: 1rem;
  --text-lg:   1.125rem;
  --text-xl:   1.25rem;
  --text-2xl:  1.5rem;
  --text-3xl:  1.875rem;
  --text-4xl:  2.25rem;
  --text-5xl:  3rem;
  --space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;
  --space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;
  --space-16:4rem;--space-20:5rem;--space-24:6rem;
  --max-w:1200px;--max-w-text:760px;
  --radius-sm:4px;--radius-md:8px;--radius-lg:16px;--radius-xl:32px;--radius-full:9999px;
  --shadow-sm:0 1px 4px rgba(0,0,0,.08);
  --shadow-md:0 4px 16px rgba(0,0,0,.12);
  --shadow-lg:0 8px 32px rgba(0,0,0,.16);
  --ease:cubic-bezier(.4,0,.2,1);
  --dur:220ms;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--ink);background:var(--white);line-height:1.75;overflow-x:clip}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* TYPOGRAPHY */
h1,h2,h3,h4{font-family:var(--font-serif);font-weight:700;line-height:1.35;letter-spacing:-.02em}
h1{font-size:clamp(var(--text-3xl),5vw,var(--text-5xl))}
h2{font-size:clamp(var(--text-2xl),3.5vw,var(--text-4xl))}
h3{font-size:clamp(var(--text-xl),2.5vw,var(--text-3xl))}
h4{font-size:var(--text-xl)}
p{margin-bottom:var(--space-4)}
p:last-child{margin-bottom:0}

/* LAYOUT */
.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--space-6)}
.container--narrow{max-width:var(--max-w-text)}
.section{padding-block:var(--space-20)}
.section--paper{background:var(--paper)}
.section--green{background:var(--green-900);color:var(--white)}
.section--green-light{background:var(--green-50)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}.grid-2.break-md{grid-template-columns:1fr}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.section{padding-block:var(--space-12)}}

/* SECTION HEADER */
.section-header{margin-bottom:var(--space-12)}
.section-header--center{text-align:center}
.section-label{display:inline-block;font-size:var(--text-sm);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--green-700);margin-bottom:var(--space-3)}
.section--green .section-label{color:var(--gold)}
.section-title{color:var(--green-900)}
.section--green .section-title{color:var(--white)}
.section-desc{margin-top:var(--space-4);color:var(--ink-muted);font-size:var(--text-lg);max-width:60ch}
.section-header--center .section-desc{margin-inline:auto}
.section--green .section-desc{color:rgba(255,255,255,.75)}
.section-title::after{content:'';display:block;width:40px;height:3px;background:var(--gold);margin-top:var(--space-3)}
.section-header--center .section-title::after{margin-inline:auto}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--green-900);box-shadow:0 2px 12px rgba(0,0,0,.25);will-change:transform;transition:transform .45s var(--ease),background .4s var(--ease),box-shadow var(--dur) var(--ease)}
.site-header--hidden{transform:translateY(-100%)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:68px;gap:var(--space-6)}
.site-logo{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}
.site-logo img,.site-logo svg{height:44px;width:auto}
.site-nav{display:flex;align-items:center;gap:var(--space-1)}
.nav-item{position:relative}
.nav-link{display:block;padding:var(--space-2) var(--space-4);color:rgba(255,255,255,.88);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-sm);transition:color var(--dur),background var(--dur);white-space:nowrap}
.nav-link:hover,.nav-link.active{color:var(--white);background:rgba(255,255,255,.1)}
.nav-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-8px);min-width:180px;background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-2);opacity:0;visibility:hidden;transition:opacity var(--dur),transform var(--dur);pointer-events:none}
.nav-item:hover .nav-dropdown,.nav-item:focus-within .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:auto}
.nav-dropdown a{display:block;padding:var(--space-2) var(--space-4);color:var(--ink);font-size:var(--text-sm);border-radius:var(--radius-sm);transition:background var(--dur)}
.nav-dropdown a:hover{background:var(--green-50);color:var(--green-900)}
.header-cta{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:var(--space-2);border-radius:var(--radius-sm)}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:transform var(--dur),opacity var(--dur)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:900px){
  .nav-toggle{display:flex}
  .site-nav{display:none;position:absolute;top:68px;left:0;right:0;background:var(--green-900);flex-direction:column;align-items:stretch;padding:var(--space-4) var(--space-6) var(--space-6);box-shadow:var(--shadow-lg);gap:0}
  .site-nav.open{display:flex}
  .nav-dropdown{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:rgba(255,255,255,.08);border-radius:var(--radius-md);margin-top:var(--space-1);padding-left:var(--space-4)}
  .nav-dropdown a{color:rgba(255,255,255,.8)}
  .nav-dropdown a:hover{background:rgba(255,255,255,.1);color:var(--white)}
  .header-cta .btn--outline{display:none}
}
.page-body{padding-top:68px}
.home.page-body{padding-top:0}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:.65em 1.5em;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;letter-spacing:.02em;transition:all var(--dur) var(--ease);white-space:nowrap;cursor:pointer}
.btn--primary{background:var(--green-700);color:var(--white)}
.btn--primary:hover{background:var(--green-600);box-shadow:0 6px 18px rgba(32,94,79,.42);transform:translateY(-1px)}
.btn--green{background:var(--green-700);color:var(--white)}
.btn--green:hover{background:var(--green-600);box-shadow:0 4px 16px rgba(45,107,62,.4);transform:translateY(-1px)}
.btn--outline{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.5)}
.btn--outline:hover{border-color:var(--white);background:rgba(255,255,255,.08)}
.btn--ghost{background:transparent;color:var(--green-700);border:1.5px solid var(--green-700)}
.btn--ghost:hover{background:var(--green-700);color:var(--white)}
.btn--lg{padding:.8em 2em;font-size:var(--text-base)}
.btn--sm{padding:.45em 1em;font-size:var(--text-xs)}

/* FLOATING CTA */
.floating-cta{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:900;display:flex;flex-direction:column;gap:var(--space-2)}
.floating-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:var(--white);box-shadow:var(--shadow-md);transition:transform var(--dur),box-shadow var(--dur);white-space:nowrap}
.floating-btn:hover{transform:translateX(-4px);box-shadow:var(--shadow-lg)}
.floating-btn--naver{background:#03c75a}
.floating-btn--kakao{background:#fee500;color:#391b1b}
.floating-btn--phone{background:var(--green-700)}
.floating-btn svg{width:18px;height:18px;flex-shrink:0}
@media(max-width:600px){
  .floating-cta{bottom:var(--space-4);right:var(--space-3)}
  .floating-btn span{display:none}
  .floating-btn{padding:var(--space-3);border-radius:50%}
}

/* HERO */
.hero{position:sticky;top:0;min-height:100vh;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--green-900);z-index:0}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--green-950) 0%,var(--green-800) 60%,var(--green-700) 100%)}
.hero-bg-img{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;opacity:.18}
.hero-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(79,179,154,.12) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.05) 0%,transparent 40%)}
.hero-content{position:relative;z-index:2;color:var(--white);padding-block:var(--space-24);max-width:680px}
.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:rgba(79,179,154,.2);border:1px solid rgba(79,179,154,.4);border-radius:var(--radius-full);padding:var(--space-1) var(--space-4);font-size:var(--text-sm);color:var(--gold-light);margin-bottom:var(--space-6);letter-spacing:.05em}
.hero-title{font-family:var(--font-serif);font-size:clamp(2rem,5vw,3.5rem);line-height:1.25;margin-bottom:var(--space-6);color:var(--white)}
.hero-title em{font-style:normal;color:var(--gold)}
.hero-desc{font-size:clamp(var(--text-base),2vw,var(--text-lg));color:rgba(255,255,255,.8);line-height:1.8;margin-bottom:var(--space-10);max-width:52ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-12)}
.hero-stats{display:flex;flex-wrap:wrap;gap:var(--space-8)}
.hero-stat-num{font-family:var(--font-serif);font-size:var(--text-3xl);font-weight:700;color:var(--gold);line-height:1}
.hero-stat-label{font-size:var(--text-sm);color:rgba(255,255,255,.65);margin-top:var(--space-1)}

/* NOTICE BAR */
.notice-bar{background:var(--green-50);border-bottom:1px solid var(--border);padding:var(--space-2) 0}
.notice-bar-inner{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-6);font-size:var(--text-sm);color:var(--ink-muted)}
.notice-bar strong{color:var(--green-900)}
.notice-item{display:flex;align-items:center;gap:var(--space-2)}

/* CARDS */
.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow var(--dur),transform var(--dur);border:1px solid var(--border)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.card-img{width:100%;aspect-ratio:4/3;object-fit:cover}
.card-body{padding:var(--space-6)}
.card-tag{display:inline-block;font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--green-700);background:var(--green-50);border-radius:var(--radius-full);padding:2px 10px;margin-bottom:var(--space-3)}
.card-title{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--green-900);margin-bottom:var(--space-2)}
.card-desc{color:var(--ink-muted);font-size:var(--text-sm)}

/* ICON CARD */
.icon-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-8);border:1px solid var(--border);transition:box-shadow var(--dur),transform var(--dur)}
.icon-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.icon-card-icon{width:56px;height:56px;border-radius:var(--radius-md);background:var(--green-50);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-5);color:var(--green-700)}
.icon-card-icon svg{width:28px;height:28px}
.icon-card-title{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--green-900);margin-bottom:var(--space-3)}
.icon-card-desc{color:var(--ink-muted);font-size:var(--text-sm);line-height:1.7}

/* STEP */
.step-list{display:flex;flex-direction:column;gap:var(--space-6)}
.step-item{display:flex;gap:var(--space-6);align-items:flex-start}
.step-num{flex-shrink:0;width:48px;height:48px;border-radius:50%;background:var(--green-900);color:var(--white);font-family:var(--font-serif);font-size:var(--text-xl);font-weight:700;display:flex;align-items:center;justify-content:center}
.step-content h4{font-family:var(--font-serif);color:var(--green-900);margin-bottom:var(--space-2)}
.step-content p{color:var(--ink-muted);font-size:var(--text-sm);margin:0}

/* TABLE */
.info-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}
.info-table th,.info-table td{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.info-table th{background:var(--green-50);font-weight:600;color:var(--green-900);width:140px;white-space:nowrap}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:none}

/* BREADCRUMB */
.breadcrumb{background:var(--green-900);padding:var(--space-16) 0 var(--space-12)}
.breadcrumb-nav{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:rgba(255,255,255,.6);margin-bottom:var(--space-4)}
.breadcrumb-nav a{color:rgba(255,255,255,.6)}
.breadcrumb-nav a:hover{color:var(--white)}
.breadcrumb-nav span{color:rgba(255,255,255,.4)}
.breadcrumb-nav strong{color:var(--white)}
.breadcrumb-title{font-family:var(--font-serif);color:var(--white);font-size:clamp(var(--text-2xl),4vw,var(--text-4xl))}
.breadcrumb-sub{color:rgba(255,255,255,.7);margin-top:var(--space-2);font-size:var(--text-base)}

/* ACCORDION */
.accordion-item{border-bottom:1px solid var(--border)}
.accordion-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) 0;font-family:var(--font-serif);font-size:var(--text-lg);color:var(--green-900);text-align:left;gap:var(--space-4);cursor:pointer}
.accordion-arrow{width:20px;height:20px;flex-shrink:0;color:var(--green-700);transition:transform var(--dur)}
.accordion-btn[aria-expanded="true"] .accordion-arrow{transform:rotate(180deg)}
.accordion-body{overflow:hidden;max-height:0;transition:max-height .35s var(--ease)}
.accordion-body-inner{padding-bottom:var(--space-6);color:var(--ink-muted);line-height:1.8;font-size:var(--text-sm)}

/* HOURS */
.hours-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:rgba(255,255,255,.06);border-radius:var(--radius-md);font-size:var(--text-sm)}
.hours-day{font-weight:600}
.hours-time{color:rgba(255,255,255,.75)}
.hours-row.today{background:rgba(79,179,154,.2);border:1px solid rgba(79,179,154,.4)}

/* MAP */
.map-placeholder{width:100%;aspect-ratio:16/7;background:var(--green-100);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.map-placeholder iframe{width:100%;height:100%;border:0;border-radius:var(--radius-lg)}

/* PHOTO GRID */
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}
.photo-grid__item{border-radius:var(--radius-md);overflow:hidden;aspect-ratio:4/3}
.photo-grid__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.photo-grid__item:hover img{transform:scale(1.04)}
.photo-grid__item--wide{grid-column:span 2;aspect-ratio:8/3}
@media(max-width:600px){.photo-grid{grid-template-columns:1fr 1fr}.photo-grid__item--wide{grid-column:span 2}}

/* HIGHLIGHT BOX */
.highlight-box{background:var(--green-50);border-left:4px solid var(--green-700);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:var(--space-6);margin-block:var(--space-6)}
.highlight-box p{margin:0;color:var(--ink)}
.notice-disclaimer{font-size:var(--text-xs);color:var(--ink-light);text-align:center;margin-top:var(--space-8);padding-top:var(--space-4);border-top:1px solid var(--border)}

/* FOOTER */
.site-footer{background:var(--green-950);color:rgba(255,255,255,.7);padding-block:var(--space-16) var(--space-8)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:var(--space-8);padding-bottom:var(--space-10);border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:var(--space-8)}
.footer-brand-name{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--white);margin-top:var(--space-4);margin-bottom:var(--space-3)}
.footer-brand-desc{font-size:var(--text-sm);line-height:1.7;color:rgba(255,255,255,.55)}
.footer-col-title{font-size:var(--text-sm);font-weight:700;color:var(--white);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--space-4)}
.footer-links{display:flex;flex-direction:column;gap:var(--space-2)}
.footer-links a{font-size:var(--text-sm);color:rgba(255,255,255,.6);transition:color var(--dur)}
.footer-links a:hover{color:var(--white)}
.footer-nap{font-size:var(--text-sm);line-height:2}
.footer-nap strong{color:var(--white);display:block}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4);font-size:var(--text-xs);color:rgba(255,255,255,.4)}
.footer-util-links{display:flex;gap:var(--space-4)}
.footer-util-links a{color:rgba(255,255,255,.4)}
.footer-util-links a:hover{color:rgba(255,255,255,.8)}
@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-top{grid-template-columns:1fr}.footer-bottom{flex-direction:column;align-items:flex-start}}

/* ROOT DIAGRAM (홈 루트코즈) */
.root-diagram{display:flex;flex-direction:column;align-items:center;gap:0}
.root-core{order:1;position:relative;text-align:center;background:var(--green-900);color:var(--white);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-10);box-shadow:var(--shadow-md);z-index:2}
.root-core-label{display:block;font-size:var(--text-xs);letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:var(--space-1)}
.root-core strong{font-family:var(--font-serif);font-size:var(--text-3xl);color:var(--white);display:block}
.root-core-sub{display:block;font-size:var(--text-sm);color:rgba(255,255,255,.65);margin-top:var(--space-2)}
.root-diagram::before{order:2;content:'';width:2px;height:40px;background:linear-gradient(var(--green-700),var(--border));margin-block:var(--space-4)}
.root-branches{order:3;display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);width:100%}
.root-branch{display:flex;flex-direction:column;gap:var(--space-2);background:var(--white);border:1px solid var(--border);border-top:3px solid var(--green-700);border-radius:var(--radius-lg);padding:var(--space-6);transition:box-shadow var(--dur),transform var(--dur)}
.root-branch:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.root-branch-dir{font-size:var(--text-xs);font-weight:600;letter-spacing:.06em;color:var(--green-700)}
.root-branch strong{font-family:var(--font-serif);font-size:var(--text-xl);color:var(--green-900)}
.root-branch-list{font-size:var(--text-sm);color:var(--ink-muted)}
@media(max-width:700px){.root-branches{grid-template-columns:1fr}}

/* SYMPTOM SELF-CHECK (홈 담적 자가체크) */
.symptom-check{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-top:var(--space-8)}
@media(max-width:600px){.symptom-check{grid-template-columns:1fr}}
.symptom{width:100%;text-align:left;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--ink);transition:border-color var(--dur),background var(--dur),color var(--dur)}
.symptom::before{content:'';width:22px;height:22px;border:2px solid var(--border);border-radius:6px;flex-shrink:0;transition:background var(--dur),border-color var(--dur);background-repeat:no-repeat;background-position:center;background-size:14px}
.symptom:hover{border-color:var(--green-500)}
.symptom[aria-pressed="true"]{border-color:var(--green-700);background:var(--green-50);color:var(--green-900);font-weight:600}
.symptom[aria-pressed="true"]::before{background-color:var(--green-700);border-color:var(--green-700);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")}
.symptom-result{margin-top:var(--space-6);padding:var(--space-8);background:var(--green-900);color:var(--white);border-radius:var(--radius-lg);text-align:center}
.symptom-result strong{color:var(--gold);font-size:var(--text-xl)}
.symptom-result p{color:rgba(255,255,255,.82)}
.symptom-result .btn{margin-top:var(--space-4)}

/* FAQ ACCORDION 폭 보정 */
.faq-list{max-width:var(--max-w-text);margin-inline:auto}

/* UTILS */
.text-gold{color:var(--gold)}.text-green{color:var(--green-700)}.text-muted{color:var(--ink-muted)}.text-white{color:var(--white)}.text-center{text-align:center}
.tag-list{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-4)}
.tag{display:inline-block;padding:var(--space-1) var(--space-3);background:var(--green-50);color:var(--green-800);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}
.divider{border:none;border-top:1px solid var(--border);margin-block:var(--space-8)}
.skip-link{position:absolute;top:-100px;left:var(--space-4);z-index:9999;background:var(--gold);color:var(--green-950);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-weight:700;transition:top .2s}
.skip-link:focus{top:var(--space-4)}
img[loading="lazy"]{opacity:0;transition:opacity .4s}
img[loading="lazy"].loaded{opacity:1}

/* ============================================================
   MOTION / SCROLL FX  — sampled from oculi.co.kr
   (GSAP + ScrollTrigger + Lenis 방식 차용)
   ============================================================ */

/* 홈: 최상단=반투명 글래스 플로팅 바 → 스크롤 시 녹색 풀폭 바로 펼쳐짐 */
.home .site-header{background:transparent;box-shadow:none}
.home .site-header.scrolled{background:var(--green-900);box-shadow:0 2px 12px rgba(0,0,0,.25)}
@media(min-width:901px){
  /* A. 상단 플로팅 글래스 */
  .home .site-header .header-inner{
    margin-top:50px;height:60px;
    background:rgba(255,255,255,.16);
    -webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%);
    border:1px solid rgba(255,255,255,.28);
    border-radius:var(--radius-full);
    box-shadow:0 12px 40px rgba(13,31,20,.38);
    padding-inline:var(--space-6) var(--space-2);
    transition:margin-top .45s var(--ease),height .45s var(--ease),background .45s var(--ease),
      border-color .45s var(--ease),border-radius .45s var(--ease),box-shadow .45s var(--ease),
      padding .45s var(--ease);
  }
  /* B. 스크롤 → 풀폭 녹색 바로 펼쳐짐 (글래스 배경/라운드 제거, 양옆으로 확장) */
  .home .site-header.scrolled .header-inner{
    margin-top:0;height:68px;
    background:transparent;
    -webkit-backdrop-filter:none;backdrop-filter:none;
    border-color:transparent;border-radius:0;box-shadow:none;
    padding-inline:0;
  }
}

/* 풀스크린 히어로를 "아래 패널이 위로 올라와 덮는" 오버랩 구조 */
.overlap{position:relative;z-index:2;background:var(--white);
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  margin-top:-56px;overflow:hidden;
  box-shadow:0 -28px 70px rgba(13,31,20,.4)}
.hero-content{will-change:transform,opacity}
.hero-bg-img{will-change:transform}

/* 히어로 타이틀: 마스크 안에서 아래→위로 솟아오르는 텍스트 */
.hero-title .line{display:block;overflow:hidden;padding-bottom:.04em}
.hero-title .line>*{display:inline-block}

/* 플로팅 CTA: 스크롤 시 등장 (JS 활성 시에만 숨김 → no-JS 안전) */
.js .floating-cta{opacity:0;transform:translateX(24px);pointer-events:none;
  transition:opacity .4s var(--ease),transform .4s var(--ease)}
.js .floating-cta.visible{opacity:1;transform:none;pointer-events:auto}

/* 스크롤 등장 기본 상태 (no-GSAP 폴백용 / GSAP은 자체 처리) */
[data-reveal]{will-change:transform,opacity}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .hero{position:relative}
  .overlap{margin-top:0;box-shadow:none}
  .js .floating-cta{opacity:1;transform:none;pointer-events:auto}
  [data-reveal]{opacity:1!important;transform:none!important}
}

/* ============================================================
   v3 리뉴얼 — 시네마틱 히어로(사진 모션+문구 전환) · 원장/저서 · 고지문 · 힐링
   팔레트: 쿨그린 · 골드 제거. 온기는 사진·여백·호흡으로.
   ============================================================ */

/* ── 히어로: 사진 켄번즈 크로스페이드 + 문구 전환 (24s 루프, 4장면) ── */
.hero--cine{position:sticky;top:0;min-height:100vh;min-height:100svh;display:flex;align-items:center;overflow:hidden;background:var(--green-950);z-index:0}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.06);animation:heroSlide 24s var(--ease) infinite;will-change:opacity,transform}
.hero-slide:nth-child(1){animation-delay:0s}
.hero-slide:nth-child(2){animation-delay:6s}
.hero-slide:nth-child(3){animation-delay:12s}
.hero-slide:nth-child(4){animation-delay:18s}
@keyframes heroSlide{0%{opacity:0;transform:scale(1.06)}3%{opacity:1}21%{opacity:1}25%{opacity:0;transform:scale(1.14)}100%{opacity:0;transform:scale(1.14)}}
.hero-veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(96deg,rgba(8,26,21,.9) 0%,rgba(8,26,21,.64) 44%,rgba(8,26,21,.3) 100%),
  linear-gradient(0deg,rgba(8,26,21,.62) 0%,transparent 38%)}
.hero--cine .hero-content{position:relative;z-index:2;color:var(--white);width:100%;padding-block:var(--space-24)}
.hero-stage{position:relative;min-height:clamp(230px,42vh,360px);max-width:780px}
.hero-phrase{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;gap:var(--space-5);opacity:0;transform:translateY(22px);animation:heroPhrase 24s var(--ease) infinite}
.hero-phrase--1{animation-delay:0s}
.hero-phrase--2{animation-delay:6s}
.hero-phrase--3{animation-delay:12s}
.hero-phrase--end{animation-delay:18s}
@keyframes heroPhrase{0%{opacity:0;transform:translateY(22px)}4%{opacity:1;transform:none}21%{opacity:1;transform:none}25%{opacity:0;transform:translateY(-16px)}100%{opacity:0;transform:translateY(-16px)}}
.hero-phrase-main{font-family:var(--font-serif);font-weight:700;font-size:clamp(2rem,5.4vw,3.7rem);line-height:1.26;letter-spacing:-.022em}
.hero-phrase-sub{font-size:clamp(var(--text-base),1.9vw,var(--text-lg));color:rgba(255,255,255,.82);line-height:1.7;max-width:46ch;font-weight:400}
.hero-phrase--end .hero-phrase-main{color:var(--gold-light)}
.hero-phrase--end .hero-phrase-sub{letter-spacing:.06em;color:rgba(255,255,255,.7)}
/* 진행 인디케이터 */
.hero-dots{position:absolute;left:var(--space-6);bottom:calc(var(--space-12) + var(--space-4));z-index:3;display:flex;gap:var(--space-2)}
.hero-dot{width:30px;height:3px;border-radius:3px;background:rgba(255,255,255,.26);overflow:hidden}
.hero-dot::after{content:'';display:block;height:100%;width:100%;background:var(--gold-light);transform:scaleX(0);transform-origin:left;animation:heroDot 24s linear infinite}
.hero-dot:nth-child(1)::after{animation-delay:0s}
.hero-dot:nth-child(2)::after{animation-delay:6s}
.hero-dot:nth-child(3)::after{animation-delay:12s}
.hero-dot:nth-child(4)::after{animation-delay:18s}
@keyframes heroDot{0%{transform:scaleX(0)}3%{transform:scaleX(.04)}21%{transform:scaleX(1)}25%{transform:scaleX(1);opacity:0}26%{opacity:1}100%{transform:scaleX(0)}}
/* 스크롤 큐 */
.hero-scroll{position:absolute;left:50%;bottom:var(--space-10);transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.55);font-size:var(--text-xs);letter-spacing:.2em;display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}
.hero-scroll::after{content:'';width:1px;height:36px;background:linear-gradient(rgba(255,255,255,.55),transparent);animation:heroScroll 1.9s var(--ease) infinite}
@keyframes heroScroll{0%{opacity:0;transform:translateY(-10px)}40%{opacity:1}100%{opacity:0;transform:translateY(14px)}}
@media(max-width:600px){.hero-scroll{display:none}.hero-dots{bottom:var(--space-10)}}

/* ── 원장 인트로 + 저서 ── */
.intro-split{display:grid;grid-template-columns:.82fr 1.18fr;gap:var(--space-12);align-items:center}
@media(max-width:860px){.intro-split{grid-template-columns:1fr;gap:var(--space-8)}}
.intro-portrait{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/5;background:var(--green-100)}
.intro-portrait img{width:100%;height:100%;object-fit:cover}
.author-books{display:flex;gap:var(--space-6);align-items:center;flex-wrap:wrap;margin-top:var(--space-8);padding:var(--space-6);background:var(--green-50);border-radius:var(--radius-lg);border:1px solid var(--border)}
.author-books img{height:160px;width:auto;filter:drop-shadow(0 12px 26px rgba(10,28,21,.24))}
.author-books-text{flex:1;min-width:220px}
.author-books-text p{font-size:var(--text-sm);color:var(--ink-muted);margin:0}

/* ── 의료법 고지문 ── */
.legal-note{font-size:var(--text-xs);line-height:1.75;color:var(--ink-muted);background:var(--green-50);border:1px dashed var(--border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);margin-top:var(--space-6)}
.legal-note + .legal-note{margin-top:var(--space-3)}
.section--green .legal-note{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.18);color:rgba(255,255,255,.62)}

/* ── 힐링 케어 포토 ── */
.care-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}
@media(max-width:860px){.care-grid{grid-template-columns:1fr 1fr}}
.care-tile{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow-sm)}
.care-tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.care-tile:hover img{transform:scale(1.05)}
.care-tile figcaption{position:absolute;left:0;right:0;bottom:0;padding:var(--space-5) var(--space-4) var(--space-4);background:linear-gradient(0deg,rgba(8,26,21,.82),transparent);color:var(--white)}
.care-tile figcaption strong{display:block;font-family:var(--font-serif);font-size:var(--text-lg)}
.care-tile figcaption span{font-size:var(--text-xs);color:rgba(255,255,255,.72)}

/* ── 하단 마케팅(통계) ── */
.stat-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-12);margin-bottom:var(--space-12)}
.stat-strip .hero-stat-num{font-family:var(--font-serif);font-size:var(--text-5xl);font-weight:700;color:var(--green-700);line-height:1;text-align:center}
.stat-strip .hero-stat-label{font-size:var(--text-sm);color:var(--ink-muted);margin-top:var(--space-2);text-align:center}

/* ── 지도 ── */
.map-cta{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--space-8);align-items:center}
@media(max-width:860px){.map-cta{grid-template-columns:1fr}}

/* ── 모션 강화 지원 (패럴랙스·클립 와이프) ── */
.care-tile img,.intro-portrait img,.photo-grid__item img{will-change:transform}
.section-title{will-change:clip-path,transform}
.breadcrumb-title{will-change:clip-path,transform}

@media (prefers-reduced-motion: reduce){
  .care-tile img,.intro-portrait img,.photo-grid__item img{transform:none!important;will-change:auto}
  .hero-slide{animation:none;transform:none;opacity:0}
  .hero-slide:nth-child(1){opacity:1}
  .hero-phrase{animation:none;position:relative;inset:auto;opacity:1;transform:none;margin-bottom:var(--space-8)}
  .hero-phrase--2,.hero-phrase--3,.hero-phrase--end{display:none}
  .hero-stage{min-height:auto}
  .hero-dot::after,.hero-scroll::after{animation:none}
}

/* ── 스크롤 리빌 — 단일 .reveal 클래스 · 스크롤 기반 · 백스톱(절대 안 멈춤) ── */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease);will-change:opacity,transform}
.js .reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .js .reveal{opacity:1!important;transform:none!important;transition:none!important}
}
