/* ─── Page Overrides ─── */
:root{ --container:640px; --page-gutter:24px; }
@media(max-width:640px){ :root{ --page-gutter:28px; } }

body{
  background:
    radial-gradient(ellipse 75% 55% at 50% 10%, rgba(32,42,72,.85) 0%, transparent 60%),
    radial-gradient(ellipse 90% 60% at 50% 100%, rgba(22,28,50,.6) 0%, transparent 55%),
    linear-gradient(180deg, var(--navy3) 0%, var(--navy2) 40%, var(--navy) 100%);
  background-attachment:fixed;
  background-repeat:no-repeat;
  letter-spacing:0;
  line-height:var(--lh-body);
  opacity:0;
}
body.fonts-ready{
  opacity:1;
  transition:opacity .3s ease;
}

/* ─── Layout ─── */
.container{
  max-width:var(--container); margin:0 auto;
  padding-left:var(--page-gutter); padding-right:var(--page-gutter);
}

/* ─── Hero Viewport (풀화면) ─── */
.hero-viewport{
  position:relative;
  min-height:100vh; min-height:100dvh;
  display:flex; flex-direction:column;
  justify-content:center; align-items:center;
  padding:0 0 80px;
  width:100%; overflow-x:clip;
}
.hero-viewport .scroll-hint{
  position:absolute; bottom:12px; left:0; right:0;
  display:flex; flex-direction:column; align-items:center;
  padding:0;
}

/* ─── Hero ─── */
.hero{
  padding:0 var(--page-gutter) var(--sp-4);
  width:100%;
}

/* ─── 1:1 서비스 인트로 ─── */
.service-intro{
  position:relative; z-index:1;
  text-align:center;
  padding:var(--sp-48) var(--page-gutter) var(--sp-32);
}
.service-intro-text{
  font-family:'Noto Serif KR',serif; font-weight:700;
  font-size:clamp(18px,4.2vw,34px); color:var(--white);
  line-height:var(--lh-heading); letter-spacing:var(--ls-ko-title);
}
.service-intro-text span{ color:var(--gold); }
.service-intro-sub{
  margin-top:var(--sp-8); font-weight:300;
  font-size:clamp(12px,1.7vw,14px); color:var(--body);
  letter-spacing:-.01em; line-height:var(--lh-body);
}

/* ─── 2 Track ─── */
.track-section{ position:relative; z-index:1; padding:0 var(--page-gutter) var(--sp-48); }
.track-cards{ display:grid; grid-template-columns:1fr 1fr; gap:14px; max-width:560px; margin:0 auto; }
.track-card{
  padding:28px 22px; text-align:center;
  border:1px solid rgba(201,165,92,.12); border-radius:16px;
  background:rgba(201,165,92,.02);
  display:flex; flex-direction:column; align-items:center; gap:0;
  transition:border-color .25s, background .25s;
}
.track-card:hover{ border-color:rgba(201,165,92,.35); background:rgba(201,165,92,.05); }
.track-label{ margin-bottom:8px; }
.track-name{
  font-family:'Noto Serif KR',serif; font-size:clamp(16px,3.5vw,20px);
  font-weight:700; color:var(--gold-lt); letter-spacing:var(--ls-ko-title);
  margin-bottom:10px;
}
.track-desc{
  font-size:12px; color:var(--body); line-height:1.6; letter-spacing:-.01em; margin-bottom:14px;
}
.track-detail{
  font-size:11px; color:var(--muted); line-height:1.6; letter-spacing:-.01em;
  padding:10px 14px; border:1px solid rgba(201,165,92,.08);
  border-radius:10px; background:rgba(201,165,92,.02); margin-bottom:14px;
}
.track-tags{ display:flex; flex-wrap:wrap; justify-content:center; gap:4px; margin-bottom:14px; }
.track-tags span{
  font-size:10px; color:var(--gold); padding:3px 10px;
  border:1px solid rgba(201,165,92,.15); border-radius:999px;
}
.track-price{
  font-family:'Cormorant Garamond',serif; font-size:clamp(20px,4vw,26px);
  font-weight:600; color:var(--white); letter-spacing:-.02em; margin-bottom:14px;
}
.track-price-row{ display:flex; flex-direction:column; gap:3px; margin-bottom:14px; text-align:center; }
.track-free{ font-size:12px; color:var(--gold); font-weight:500; }
.track-price-sm{ font-size:12px; color:var(--muted); }
.track-btn{
  display:inline-block; padding:10px 28px;
  border:1px solid rgba(201,165,92,.35); border-radius:999px;
  font-size:12px; font-weight:500; color:var(--gold-lt);
  text-decoration:none; transition:all .2s;
  background:rgba(201,165,92,.04);
}
.track-btn:hover{ border-color:var(--gold); background:rgba(201,165,92,.1); }
.track-btn:active{ transform:scale(.96); }
@media(max-width:520px){
  .track-cards{ grid-template-columns:1fr; gap:12px; }
}

.hero-glow{
  position:absolute; top:-60px; left:50%; transform:translateX(-50%);
  width:500px; height:500px;
  background:radial-gradient(ellipse, rgba(25,35,80,0.55) 0%, transparent 70%);
  pointer-events:none;
}
.title-card{
  width:min(280px,72vw); aspect-ratio:5/7;
  animation:fadeUp .9s ease both;
}
.card-sub{ margin-bottom:var(--sp-16); }
.card-title-ko{
  font-size:clamp(28px,9vw,46px);
  margin-bottom:var(--sp-8);
}
.card-title-en{ font-size:clamp(9px,2.4vw,12px); }
.hero-copy{
  margin-top:var(--sp-32); animation:fadeUp .9s .2s ease both;
}
.hero-copy h1{
  font-family:'Noto Serif KR',serif; font-weight:700;
  font-size:clamp(18px,4.2vw,34px); color:var(--white);
  line-height:var(--lh-heading); letter-spacing:var(--ls-ko-title);
}
.hero-copy h1 span{ color:var(--gold); }
.hero-copy p{
  margin-top:var(--sp-16);
}
.gold-line{ margin:var(--sp-16) auto 0; }

/* ─── Self Reading Promo ─── */
.self-reading{
  position:relative; z-index:1; text-align:center;
  padding:var(--sp-8) var(--page-gutter) var(--sp-4);
  animation:fadeUp .9s .35s ease both;
}
.self-reading .btn-sparkle{
  width:min(250px,66vw); padding:16px 0;
  justify-content:center;
}
.self-reading-desc{
  font-weight:300; font-size:clamp(12px,1.6vw,13px);
  color:var(--body); line-height:1.5;
  letter-spacing:-.01em; margin-top:var(--sp-8); margin-bottom:0;
  max-width:360px; margin-left:auto; margin-right:auto;
}
.self-reading-note{
  font-size:11px; font-weight:300; color:var(--body);
  letter-spacing:-.01em; margin-top:var(--sp-4);
}
.self-reading-note strong{ font-weight:600; }
.self-reading-note span{ margin:0 4px; opacity:.4; }

/* ─── Scroll Indicator ─── */
.scroll-hint{
  display:flex; flex-direction:column; align-items:center;
  padding:var(--sp-4) 0;
  animation:fadeUp .8s 1s ease both;
}
.scroll-line{
  width:1px; height:28px;
  background:linear-gradient(to bottom, rgba(201,165,92,0), rgba(201,165,92,0.4), rgba(201,165,92,0));
  position:relative; overflow:hidden;
}
.scroll-line::after{
  content:''; position:absolute;
  top:-12px; left:-1px;
  width:3px; height:12px; border-radius:2px;
  background:var(--gold-lt);
  box-shadow:0 0 6px rgba(201,165,92,0.5);
  animation:scrollDrop 2s ease-in-out infinite;
}
@keyframes scrollDrop{
  0%{ top:-12px; opacity:0; }
  20%{ opacity:1; }
  80%{ opacity:1; }
  100%{ top:28px; opacity:0; }
}
.scroll-hint-text{
  font-family:'Cormorant Garamond',serif;
  font-size:10px; font-weight:500;
  letter-spacing:var(--ls-en-wide); text-transform:uppercase;
  color:var(--gold-dk); margin-top:6px;
}

/* ─── Category List ─── */
.btns-section{
  position:relative; z-index:1;
  padding:var(--sp-32) var(--page-gutter) var(--sp-48);
}
.cat-label{
  font-size:11px; letter-spacing:var(--ls-en-wider);
  text-align:center; margin-bottom:var(--sp-32);
}
.cat-list{ display:flex; flex-direction:column; }
.cat-item{
  display:grid; grid-template-columns:48px 1fr;
  gap:var(--sp-16); padding:var(--sp-24) 0;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.cat-item:last-child{ border-bottom:none; }
.cat-icon{
  display:flex; align-items:center; justify-content:center;
  padding-top:2px;
}
.cat-icon svg{ width:26px; height:26px; opacity:.45; }
.cat-title{
  font-weight:600; font-size:14px; color:var(--gold-lt);
  margin-bottom:var(--sp-4); line-height:var(--lh-heading);
}
.cat-desc{
  font-weight:300; font-size:13px; color:var(--body);
  line-height:var(--lh-body); margin-bottom:var(--sp-8);
}
.cat-tags{ display:flex; flex-wrap:wrap; gap:4px; }
.cat-tags a{
  font-weight:400; font-size:10px; color:var(--gold);
  background:rgba(201,165,92,.06); border:1px solid rgba(201,165,92,.12);
  border-radius:999px; padding:2px 8px;
  text-decoration:none; transition:all .2s;
}
.cat-tags a:hover{ color:var(--gold-lt); border-color:rgba(201,165,92,.3); background:rgba(201,165,92,.12); }
.cat-tags a:active{ transform:scale(.95); }

/* ─── Trust ─── */
.trust{
  position:relative; z-index:1;
  border-top:1px solid rgba(201,165,92,0.16);
  border-bottom:1px solid rgba(201,165,92,0.16);
  padding:var(--sp-64) var(--page-gutter); text-align:center;
}
.trust-hook{
  font-family:'Noto Serif KR',serif; font-weight:700;
  font-size:clamp(16px,3vw,22px); color:var(--white);
  line-height:var(--lh-heading); letter-spacing:var(--ls-ko-title);
  margin-bottom:var(--sp-32); max-width:var(--container);
  margin-left:auto; margin-right:auto;
}
.trust-features{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:var(--sp-16); max-width:var(--container); margin:0 auto var(--sp-32);
}
.trust-feature{
  padding:var(--sp-24) var(--sp-16);
  border:1px solid rgba(201,165,92,0.18); border-radius:12px;
  background:rgba(201,165,92,0.03);
}
.trust-feature-num{
  font-family:'Cormorant Garamond',serif; font-weight:600;
  font-size:clamp(22px,4vw,30px); color:var(--gold-lt);
  letter-spacing:-.03em; line-height:var(--lh-tight); margin-bottom:var(--sp-4);
}
.trust-feature-label{
  font-weight:400; font-size:12px; color:var(--body);
  letter-spacing:-.01em; line-height:var(--lh-body);
}
.trust-sub{
  font-weight:300; font-size:clamp(13px,1.8vw,14.5px);
  color:var(--body); line-height:var(--lh-loose);
  letter-spacing:-.01em; max-width:var(--container); margin:0 auto;
}

/* ─── How It Works ─── */
.manual{
  position:relative; z-index:1;
  padding-top:var(--sp-64); padding-bottom:var(--sp-64);
}
.section-label{
  font-size:11px; letter-spacing:var(--ls-en-wider);
  text-align:center; margin-bottom:var(--sp-48);
}
.steps{ display:flex; flex-direction:column; }
.step{
  display:grid; grid-template-columns:48px 1fr;
  gap:var(--sp-16); padding:var(--sp-24) 0;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.step:last-child{ border-bottom:none; }
.step-num{
  font-family:'Cormorant Garamond',serif; font-weight:400;
  font-size:28px; color:rgba(201,165,92,0.17);
  line-height:var(--lh-tight); padding-top:2px;
}
.step-title{
  font-weight:600; font-size:14px; color:var(--gold-lt);
  margin-bottom:var(--sp-4); letter-spacing:-.02em; line-height:var(--lh-heading);
}
.step-desc{
  font-weight:300; font-size:13px; color:var(--body);
  line-height:var(--lh-body); letter-spacing:-.01em;
}
.step-example{
  margin-top:var(--sp-8); padding:var(--sp-8) var(--sp-16);
  border-left:2px solid var(--gold-dk);
  background:rgba(201,165,92,0.04);
  font-weight:300; font-size:12px; color:var(--muted);
  line-height:var(--lh-loose); letter-spacing:-.01em;
}

/* ─── Pricing ─── */
.pricing{
  position:relative; z-index:1;
  padding-top:var(--sp-48); padding-bottom:var(--sp-64);
}
.pricing-inner{
  border:1px solid rgba(201,165,92,0.22); border-radius:16px;
  padding:var(--sp-32) var(--sp-24);
  background:rgba(201,165,92,0.03); text-align:center;
}
.pricing-label{
  font-size:11px; letter-spacing:var(--ls-en-wider);
  margin-bottom:var(--sp-24);
}
.pricing-row{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:var(--sp-8); margin-bottom:var(--sp-24);
}
.pricing-card{
  padding:var(--sp-24) var(--sp-16);
  border:1px solid rgba(201,165,92,0.16); border-radius:12px;
  background:rgba(255,255,255,.04);
}
.pricing-card-title{
  font-weight:600; font-size:13px; color:var(--gold-lt);
  letter-spacing:-.01em; line-height:var(--lh-heading); margin-bottom:var(--sp-4);
}
.pricing-card-desc{
  font-size:11px; color:var(--muted); margin-bottom:var(--sp-8); letter-spacing:-.01em;
}
.pricing-card-price{
  font-family:'Cormorant Garamond',serif; font-weight:600;
  font-size:clamp(20px,4vw,26px); color:var(--white);
  letter-spacing:-.02em; line-height:var(--lh-tight); margin-bottom:var(--sp-4);
}
.pricing-card-unit{
  font-weight:300; font-size:11px; color:var(--muted); letter-spacing:-.01em;
}
.pricing-note{
  font-weight:300; font-size:12px; color:var(--muted);
  letter-spacing:-.01em; line-height:var(--lh-body);
}

/* ─── CTA ─── */
.cta{
  position:relative; z-index:1;
  padding:var(--sp-48) var(--page-gutter) var(--sp-80); text-align:center;
}
.cta-character{
  display:block; width:min(260px,65vw); height:auto;
  margin:0 auto var(--sp-8);
  filter:drop-shadow(0 8px 32px rgba(0,0,0,.5));
  animation:fadeUp .8s ease both;
  -webkit-mask-image:linear-gradient(to bottom, black 50%, transparent 90%);
  mask-image:linear-gradient(to bottom, black 50%, transparent 90%);
}
.cta-text{
  font-family:'Noto Serif KR',serif; font-weight:700;
  font-size:clamp(18px,3.5vw,26px); color:var(--white);
  margin-bottom:var(--sp-8); line-height:var(--lh-heading); letter-spacing:var(--ls-ko-title);
}
.cta-sub-text{
  font-weight:300; font-size:clamp(13px,1.6vw,14px);
  color:var(--body); margin-bottom:var(--sp-32);
  line-height:var(--lh-body); letter-spacing:-.01em;
}
.cta-btn{
  display:inline-flex; align-items:center; gap:var(--sp-8);
  border:1px solid var(--gold); color:var(--gold-lt);
  padding:14px 40px; font-weight:500; font-size:14px;
  letter-spacing:.06em; cursor:pointer; border-radius:999px;
  background:rgba(201,165,92,0.06);
  transition:background .25s, color .25s, box-shadow .25s;
  text-decoration:none; -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
}
.cta-btn:hover{
  background:var(--gold); color:var(--navy);
  box-shadow:0 0 22px rgba(201,165,92,0.28);
}
.cta-note{
  margin-top:var(--sp-16); font-weight:300;
  font-size:12px; color:var(--muted); letter-spacing:-.01em;
}

/* ─── Footer Override ─── */
footer{ padding:var(--sp-48) var(--page-gutter); }
.footer-brand{ font-size:clamp(15px,2.5vw,18px); margin-bottom:var(--sp-8); }
.footer-copy{ margin-bottom:var(--sp-24); }
.footer-link{
  display:block; font-weight:300; font-size:11px;
  color:var(--muted); text-decoration:none;
  margin-bottom:var(--sp-8); letter-spacing:.04em;
  transition:color .2s;
}
.footer-link:hover{ color:var(--gold-lt); }
.footer-divider{
  width:28px; height:1px; background:rgba(201,165,92,.12);
  margin:var(--sp-16) auto;
}
.family-link{
  font-size:12px; font-weight:400; color:var(--muted);
  text-decoration:none; letter-spacing:.03em; transition:color .2s;
}
.family-link:hover{ color:var(--gold-lt); }

/* ─── PC (768px+) ─── */
@media(min-width:768px){
  .hero-viewport{ padding:0 0 100px; }
  .hero-viewport .scroll-hint{ bottom:20px; }
  .title-card{ width:min(380px,42vw); }
  .card-title-ko{ font-size:clamp(32px,4.5vw,46px); margin-bottom:var(--sp-16); }
  .card-sub{ margin-bottom:var(--sp-24); font-size:13px; }
  .card-title-en{ font-size:12px; }
  .self-reading .btn-sparkle{
    width:min(334px,44vw); /* 380 × 0.88 = outer rect */
    padding:20px 0; font-size:16px;
  }
  .self-reading-note{ font-size:13px; margin-top:var(--sp-8); }
  .scroll-line{ height:36px; }
  .scroll-hint-text{ font-size:11px; }
  .service-intro{ padding:var(--sp-80) var(--page-gutter) var(--sp-48); }
  .service-intro-text{ font-size:clamp(22px,3vw,32px); }
  .service-intro-sub{ font-size:14px; margin-top:var(--sp-16); }
  .cta-character{ width:min(300px,35vw); }
}

/* ─── Mobile ─── */
@media(max-width:480px){
  .trust-features{ grid-template-columns:1fr; gap:8px; }
  .pricing-row{ grid-template-columns:1fr; gap:8px; }
}
@media(min-width:481px) and (max-width:767px){
  .pricing-row{ grid-template-columns:1fr 1fr; gap:8px; }
}

/* ─── Scroll Reveal ─── */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}
