@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.min.css');

/* =========================================================
   오늘도 재테크 — 디자인 시스템 v3 (Light / ZEROTOMAX 결)
   화이트 + soft 섹션 + 블루 브랜드 + 소프트 섀도 / Pretendard
   (기존 클래스명 유지: --coral = 브랜드 블루로 매핑)
   ========================================================= */

:root{
  --brand:#2962ff; --brand-ink:#1647d6; --brand-soft:#eaf0ff; --brand-soft-2:#dbe6ff;
  --accent:#7c5cff; --good:#12b76a; --good-soft:#e7f8ef;

  /* 기존 클래스 호환용 별칭 */
  --coral:#2962ff; --coral-press:#1647d6; --coral-deep:#1647d6;
  --coral-tint:#eaf0ff; --coral-tint-2:#f3f6ff;

  --ink:#0b1324; --ink-soft:#48526b; --gray:#5a6379; --gray-2:#8a93a6;
  --line:#e7ebf2; --line-strong:#d7deeb; --line-soft:#eef1f6;

  --paper:#ffffff; --paper-2:#f6f8fb; --paper-3:#ffffff; --paper-4:#f6f8fb;

  --shadow-sm:0 1px 2px rgba(16,24,40,.04),0 2px 6px -1px rgba(16,24,40,.06);
  --shadow-md:0 6px 16px -6px rgba(16,24,40,.10),0 14px 36px -10px rgba(16,24,40,.12);
  --shadow-lg:0 30px 70px -16px rgba(16,24,40,.22);

  --radius:12px; --radius-lg:20px;
  --maxw:1160px; --gut:clamp(20px,5vw,40px);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}
body{
  margin:0;font-family:'Pretendard','Pretendard Variable',-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Malgun Gothic',sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.6;font-size:16px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
  word-break:keep-all;overflow-wrap:break-word;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--brand);color:#fff}

.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.section{padding:clamp(56px,8vw,104px) 0;position:relative}
.section.soft{background:var(--paper-2)}
.section-tight{padding:clamp(36px,5vw,60px) 0;position:relative}
.hr{height:1px;background:var(--line);border:0;margin:0}
.center{text-align:center}

/* ---------- Typography ---------- */
h1,h2,h3,h4{margin:0;letter-spacing:-.022em;line-height:1.18;font-weight:800;color:var(--ink)}
.display{font-size:clamp(34px,5vw,60px);line-height:1.1;letter-spacing:-.03em;font-weight:800}
.h-xl{font-size:clamp(26px,3.4vw,40px);line-height:1.14}
.h-lg{font-size:clamp(22px,2.6vw,30px)}
.h-md{font-size:19px;font-weight:800;letter-spacing:-.01em}
.lede{font-size:clamp(16px,1.4vw,18.5px);color:var(--ink-soft);line-height:1.6}
.muted{color:var(--ink-soft)}
.dim{color:var(--gray-2)}
.cor{color:var(--brand)}
.dot{color:var(--brand)}

.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:800;
  letter-spacing:.05em;text-transform:uppercase;color:var(--brand)}
.eyebrow::before{content:"";width:18px;height:2px;background:var(--brand);border-radius:2px}

.section-head{margin-bottom:38px;max-width:680px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head .more{font-size:14px;color:var(--brand);font-weight:700}
.section-head h2{margin-top:14px}
.section-head p{font-size:17px;color:var(--ink-soft);margin:14px 0 0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;
  padding:12px 22px;border-radius:var(--radius);border:1px solid transparent;
  transition:transform .12s ease,box-shadow .12s ease,background .15s ease,border-color .15s ease;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn-sm{font-size:14px;padding:9px 16px}
.btn-coral{background:var(--brand);color:#fff;box-shadow:0 8px 20px rgba(41,98,255,.28)}
.btn-coral:hover{background:var(--brand-ink);box-shadow:0 10px 26px rgba(41,98,255,.34)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{border-color:#cfd6e4}
.btn-light{background:#fff;color:var(--brand);box-shadow:var(--shadow-sm)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#1c2740}
.btn.active{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}
.link-arrow{font-weight:700;color:var(--brand)}
.link-arrow:hover{color:var(--brand-ink)}

/* ---------- Tag / badge-pill ---------- */
.tag{display:inline-block;background:var(--brand-soft);color:var(--brand-ink);
  font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:999px;letter-spacing:.01em}
.tag-ink{background:var(--paper-2);color:var(--ink-soft);border:1px solid var(--line-2)}
.badge-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:7px 14px;font-size:13.5px;font-weight:700;color:var(--ink-soft);box-shadow:var(--shadow-sm)}
.badge-pill .bdot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 4px var(--good-soft)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(255,255,255,.9);border-color:var(--line);box-shadow:0 6px 22px rgba(16,24,40,.05)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{font-weight:800;font-size:19px;letter-spacing:-.03em;color:var(--ink)}
.nav-links{display:flex;gap:4px;margin-left:34px;margin-right:auto}
.nav-links a{font-size:15px;color:var(--ink-soft);font-weight:600;padding:9px 13px;border-radius:10px;transition:.15s}
.nav-links a:hover{background:var(--paper-2);color:var(--ink)}
.nav-links a.active{color:var(--ink);background:var(--paper-2)}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-search{font-size:18px;color:var(--ink-soft);line-height:0}
.nav-search:hover{color:var(--ink)}
.nav-toggle{display:none;background:none;border:0;font-size:22px;color:var(--ink);padding:4px;line-height:0}

@media(max-width:860px){
  .nav-links{position:absolute;left:var(--gut);right:var(--gut);top:74px;flex-direction:column;gap:2px;
    margin:0;background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px;
    box-shadow:var(--shadow-md);transform:translateY(-10px);opacity:0;pointer-events:none;transition:.18s ease}
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{padding:12px 14px;font-size:16px}
  .nav-toggle{display:block}
}

/* ---------- Hero ---------- */
.hero{padding:clamp(40px,6vw,84px) 0 clamp(20px,3vw,40px)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,56px);align-items:center}
.hero h1,.hero .display{margin:22px 0 18px}
.hero h1 .hl,.hl{color:var(--brand)}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
.hero-note{margin-top:18px;font-size:14px;color:var(--gray-2);display:flex;align-items:center;gap:8px;font-weight:600}
.hero-note .ck{color:var(--good);font-weight:800}

/* hero mockup */
.mock-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:18px;position:relative}
.mock-top{display:flex;align-items:center;gap:8px;padding:4px 6px 14px;border-bottom:1px solid var(--line-soft)}
.mock-top .d{width:10px;height:10px;border-radius:50%;background:#e4e8f0}
.mock-top .t{margin-left:10px;font-size:12.5px;color:var(--gray-2);font-weight:700}
.mock-hero{margin:16px 0;border-radius:16px;padding:22px 22px 18px;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(140deg,#1c2a5e,#3d2d92 95%)}
.mock-hero .pt{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.18);backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.3);font-size:11px;font-weight:800;padding:5px 10px;border-radius:999px}
.mock-hero .k{font-size:12px;opacity:.9;font-weight:700;margin-top:26px}
.mock-hero .v{font-size:30px;font-weight:900;letter-spacing:-.03em;margin-top:2px}
.mock-hero svg{display:block;width:100%;height:54px;margin-top:8px}
.mock-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.mock-metric{background:var(--paper-2);border-radius:12px;padding:12px}
.mock-metric .k{font-size:11px;color:var(--gray-2);font-weight:700}
.mock-metric .v{font-size:17px;font-weight:800;letter-spacing:-.02em;margin-top:2px}
.mock-metric .v small{font-size:12px;color:var(--good);font-weight:800;margin-left:3px}
.float-chip{position:absolute;z-index:3;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-md);
  padding:11px 14px;display:flex;align-items:center;gap:10px;font-weight:800;font-size:13.5px}
.float-chip .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:#fff;flex:none;font-size:14px}
.float-chip small{display:block;font-size:11px;color:var(--gray-2);font-weight:600}
.float-chip.one{top:-20px;right:-12px;animation:floaty 5s ease-in-out infinite}
.float-chip.two{bottom:-30px;left:-26px;animation:floaty 6s ease-in-out infinite .6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* logos strip */
.logos{padding:42px 0 6px}
.logos .cap{text-align:center;font-size:13px;font-weight:700;color:var(--gray-2);letter-spacing:.03em;margin-bottom:20px}
.logo-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 40px}
.logo-row span{font-size:18px;font-weight:800;color:#aeb6c6;letter-spacing:-.02em;transition:color .2s}
.logo-row span:hover{color:var(--ink-soft)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);
  border-radius:var(--radius-lg);background:#fff;box-shadow:var(--shadow-md);overflow:hidden}
.stats .cell{padding:28px 26px;border-right:1px solid var(--line-soft)}
.stats .cell:last-child{border-right:0}
.stats .num{font-size:clamp(26px,3vw,38px);font-weight:800;letter-spacing:-.03em;color:var(--brand)}
.stats .lbl{font-size:14px;color:var(--ink-soft);font-weight:600;margin-top:4px}

/* ---------- Feature cards (svc / why / bento 호환) ---------- */
.grid{display:grid;gap:22px}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc,.bento .b{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 26px;
  box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.svc:hover,.bento .b:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#d7deeb}
.svc .ic,.bento .b .ico{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;
  background:var(--brand-soft);color:var(--brand);margin-bottom:16px}
.svc h3,.bento .b h3{font-size:18.5px;font-weight:800;margin:0 0 8px;letter-spacing:-.01em}
.svc p,.bento .b p{margin:0;color:var(--ink-soft);font-size:14.5px;line-height:1.55}
.svc .n,.bento .b .n{font-size:13px;font-weight:800;color:var(--brand);letter-spacing:.04em}
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.bento .span-2{grid-column:span 2}
.ic-grad{background:linear-gradient(140deg,#2962ff,#7c5cff)!important;color:#fff!important}
.ic-teal{background:linear-gradient(140deg,#0ea5e9,#22c1a6)!important;color:#fff!important}
.ic-violet{background:linear-gradient(140deg,#7c5cff,#b06bff)!important;color:#fff!important}

/* ---------- Callout (navy 강조) ---------- */
.callout,.band-coral{border-radius:var(--radius-lg);padding:clamp(28px,3.6vw,42px);
  background:linear-gradient(120deg,#0b1324,#1b2c52);color:#fff;position:relative;overflow:hidden}
.callout .big .pct{font-size:clamp(44px,6vw,64px);font-weight:900;letter-spacing:-.04em;line-height:1;
  background:linear-gradient(120deg,#5b8bff,#a98bff);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Insight cards / thumb ---------- */
.card{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#d7deeb}
.card .thumb{border-radius:0;height:158px}
.card-body{padding:18px 20px 22px}
.card h3{font-size:16.5px;font-weight:800;line-height:1.4;margin:10px 0 0;letter-spacing:-.01em}
.card .meta{font-size:11.5px;color:var(--gray-2);margin-top:11px}
.card p.excerpt{font-size:13.5px;color:var(--ink-soft);margin:8px 0 0;line-height:1.55}
.thumb{background:linear-gradient(140deg,#eef3ff,#f6f8fb);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;border-radius:12px;border:1px solid var(--line-soft)}
.thumb .tag{position:absolute;top:12px;left:12px}
.thumb svg{width:80%;height:60%}
.thumb .num{position:absolute;right:14px;bottom:6px;font-size:54px;font-weight:800;color:rgba(41,98,255,.12);letter-spacing:-.04em;line-height:1}

.list-item{display:flex;gap:14px;padding:16px 0;border-top:1px solid var(--line-soft);align-items:flex-start}
.list-item:first-child{border-top:0}
.list-item .thumb{width:64px;height:64px;flex-shrink:0;border-radius:12px}
.list-item .thumb svg{width:72%;height:58%}
.list-item h3{font-size:15px;font-weight:700;line-height:1.4;margin:6px 0 4px}
.list-item .meta{font-size:11px;color:var(--gray-2)}
.list-num{font-size:13px;font-weight:800;color:var(--brand);min-width:22px}
.side-head{font-size:13px;font-weight:800;border-bottom:2px solid var(--ink);padding-bottom:9px;margin-bottom:2px}

/* legacy hero-grid feature (column/article) */
.hero-feature .thumb{height:clamp(220px,30vw,320px);margin-bottom:18px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.hero-feature h1,.hero-feature h2{font-size:clamp(24px,3vw,34px);line-height:1.24;margin:0 0 12px}

/* ---------- Bands ---------- */
.band{border-radius:var(--radius-lg);position:relative;overflow:hidden}
.band-tint{background:var(--paper-2);border:1px solid var(--line)}
.band-paper{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.band-inner{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;
  gap:28px;flex-wrap:wrap;padding:clamp(28px,3.6vw,42px) clamp(24px,3vw,42px)}
.band-coral .muted,.band-coral .lede,.callout .muted{color:#c5cee0}

/* ---------- Forms ---------- */
.field{height:48px;border:1px solid var(--line);border-radius:var(--radius);padding:0 16px;font-size:14.5px;
  background:#fff;font-family:inherit;color:var(--ink);width:100%;box-shadow:var(--shadow-sm)}
.field::placeholder{color:var(--gray-2)}
.field:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
textarea.field{height:auto;padding:14px 16px;min-height:112px;line-height:1.6;resize:vertical}
select.field{appearance:none}
.label{display:block;font-size:12.5px;font-weight:700;color:var(--ink-soft);margin:0 0 8px}
.inline-form{display:flex;gap:10px;flex-wrap:wrap}
.inline-form .field{width:auto;flex:1;min-width:200px}
.form-grid{display:grid;gap:16px;grid-template-columns:1fr 1fr}
.form-note{font-size:12px;color:var(--gray-2);line-height:1.6}
.form-ok{background:var(--good-soft);color:#0f7a4d;border:1px solid #bdebd2;border-radius:var(--radius);
  padding:14px 16px;font-size:14px;font-weight:700;display:none}
.form-ok.show{display:block}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.steps .step{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 20px;box-shadow:var(--shadow-sm)}
.steps .n{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--brand-soft);
  color:var(--brand);font-weight:800;font-size:16px;margin-bottom:14px}
.steps .step .step-cap{display:block;font-size:11px;font-weight:800;letter-spacing:.09em;color:var(--gray-2);margin:0 0 3px}
.steps .step h3,.steps .step h4{font-size:17px;font-weight:800;margin:0 0 6px;letter-spacing:-.01em}
.steps .step p{font-size:13.5px;color:var(--ink-soft);margin:0;line-height:1.55}

/* ---------- Editorial rows ---------- */
.rows{border-top:1px solid var(--ink)}
.rows .r{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.rows .r .t{font-size:clamp(16px,1.8vw,19px);font-weight:700;letter-spacing:-.01em}
.rows .r .n{font-size:12.5px;color:var(--gray-2)}

/* ---------- Article prose ---------- */
.article{max-width:720px;margin:0 auto}
.article .kicker{margin-bottom:16px}
.article h1{font-size:clamp(28px,3.8vw,44px);line-height:1.18;margin:0 0 16px}
.article .byline{display:flex;gap:12px;align-items:center;font-size:13px;color:var(--ink-soft);
  padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-bottom:36px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:800;font-size:14px}
.prose{font-size:17px;line-height:1.85;color:var(--ink-soft)}
.prose>p{margin:0 0 24px}
.prose h2{font-size:24px;font-weight:800;color:var(--ink);margin:44px 0 14px;letter-spacing:-.02em}
.prose h3{font-size:18px;font-weight:800;color:var(--ink);margin:30px 0 10px}
.prose strong{color:var(--ink);font-weight:800}
.prose blockquote{margin:30px 0;padding:8px 0 8px 22px;border-left:3px solid var(--brand);font-size:19px;font-weight:700;color:var(--ink);line-height:1.5;letter-spacing:-.01em}
.prose ul{margin:0 0 24px;padding-left:20px}
.prose li{margin:0 0 9px}
.prose li::marker{color:var(--brand)}
.prose .figure{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px 24px;margin:30px 0}
.prose .figure .cap{font-size:12.5px;color:var(--gray-2);margin-top:10px}

.disclaimer{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px 20px;font-size:12.5px;color:var(--gray);line-height:1.7}
.disclaimer b{color:var(--ink-soft);font-weight:700}

/* ---------- Simulator ---------- */
.sim{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:34px;align-items:center;
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,36px);background:#fff;box-shadow:var(--shadow-md)}
.sim .fv{font-size:clamp(30px,4vw,44px);font-weight:800;letter-spacing:-.03em}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:var(--line-strong);border-radius:3px;margin:10px 0}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--brand);border:3px solid #fff;box-shadow:0 0 0 1px var(--brand),0 4px 10px rgba(41,98,255,.4);cursor:pointer}
input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--brand);border:3px solid #fff;cursor:pointer}

/* ---------- Footer ---------- */
.site-footer{background:var(--paper-2);border-top:1px solid var(--line)}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;padding:clamp(48px,5vw,72px) 0 36px}
.footer-inner h4{font-size:12px;letter-spacing:.04em;color:var(--gray-2);font-weight:800;text-transform:uppercase;margin:0 0 14px}
.footer-inner a{display:block;font-size:13.5px;color:var(--ink-soft);padding:5px 0}
.footer-inner a:hover{color:var(--brand)}
.footer-brand .brand{font-size:18px;display:inline-block;margin-bottom:12px}
.footer-brand p{font-size:13px;color:var(--gray);line-height:1.7;margin:0 0 16px;max-width:300px}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--ink-soft);font-size:17px;background:#fff}
.socials a:hover{border-color:var(--brand);color:var(--brand)}
.footer-base{border-top:1px solid var(--line);padding:20px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--gray-2)}

/* ---------- Inner page hero ---------- */
.page-hero{padding:clamp(52px,7vw,96px) 0 clamp(30px,3vw,44px);border-bottom:1px solid var(--line);background:var(--paper-2)}
.page-hero .display{margin:16px 0 0}
.page-hero .lede{margin-top:20px;max-width:660px}
.badge-soon{display:inline-block;background:var(--brand-soft);color:var(--brand-ink);font-size:11px;font-weight:800;letter-spacing:.06em;padding:6px 13px;border-radius:999px;text-transform:uppercase}
.pad-card{border:1px solid var(--line);border-radius:16px;padding:clamp(24px,3vw,32px);background:#fff;box-shadow:var(--shadow-sm)}

/* kakao floating */
.kakao-fab{position:fixed;right:20px;bottom:20px;z-index:70;background:#fae100;color:#3a1d1d;font-weight:800;
  font-size:14px;padding:13px 18px;border-radius:999px;box-shadow:var(--shadow-md);display:inline-flex;align-items:center;gap:8px}
.kakao-fab:hover{transform:translateY(-2px)}

/* ---------- Responsive ---------- */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .g-3,.svc-grid,.bento{grid-template-columns:1fr 1fr}
  .bento .span-2{grid-column:span 2}
  .steps{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .stats .cell:nth-child(2){border-right:0}
  .stats .cell{border-bottom:1px solid var(--line-soft)}
  .sim{grid-template-columns:1fr;gap:24px}
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:620px){
  .g-3,.g-2,.svc-grid,.bento,.form-grid,.stats{grid-template-columns:1fr}
  .bento .span-2{grid-column:span 1}
  .steps{grid-template-columns:1fr}
  .band-inner{flex-direction:column;align-items:flex-start}
  .inline-form{width:100%}
  .footer-inner{grid-template-columns:1fr 1fr}
}

/* =========================================================
   ETF 컨설팅 원페이지 랜딩 (기존 토큰만 사용)
   ========================================================= */
/* 스크롤 등장 애니메이션 (JS 있을 때만 숨김 → FOUC 방지) */
html.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.js .reveal{opacity:1!important;transform:none!important;transition:none}}

/* 플레이스홀더(요청자가 채울 부분) */
.ph{background:var(--brand-soft);border:1px dashed var(--brand);border-radius:6px;padding:0 7px;color:var(--brand-ink);font-weight:700;font-size:.92em;white-space:nowrap}
.ph-box{border:1.5px dashed var(--brand);border-radius:16px;background:var(--brand-soft);color:var(--brand-ink);
  display:flex;align-items:center;justify-content:center;text-align:center;padding:22px;font-weight:700;font-size:14px;line-height:1.6}

/* 히어로 신뢰 라인 */
.hero-trust{margin-top:20px;font-size:14px;color:var(--gray);display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-weight:600}
.hero-trust b{color:var(--ink)}

/* 히어로 목업 — 포트폴리오 배분 */
.mock-alloc{display:grid;gap:9px;margin-top:8px}
.alloc{display:grid;grid-template-columns:92px 1fr 34px;align-items:center;gap:9px;font-size:11.5px;font-weight:700}
.alloc .bar{height:7px;border-radius:5px;background:rgba(255,255,255,.25)}
.alloc .bar i{display:block;height:100%;background:#fff;border-radius:5px}
.alloc b{text-align:right}

/* 공감 체크리스트 */
.check-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.check-item{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 22px;box-shadow:var(--shadow-sm)}
.check-item .ic{flex:none;width:26px;height:26px;border-radius:50%;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;font-weight:800;font-size:14px;margin-top:1px}
.check-item p{margin:0;font-size:15.5px;color:var(--ink);font-weight:600;line-height:1.5}
.lead-close{margin-top:28px;font-size:clamp(17px,2vw,21px);font-weight:700;color:var(--ink);text-align:center;letter-spacing:-.01em}

/* 프로세스 타임라인 연결선 */
.steps.timeline .step{position:relative}
.steps.timeline .step:not(:last-child)::after{content:"";position:absolute;top:41px;right:-18px;width:18px;height:2px;
  background:repeating-linear-gradient(90deg,var(--line-strong) 0 6px,transparent 6px 11px)}

/* 컨설턴트 소개 — 2패널 카드 */
.about-grid{display:grid;grid-template-columns:.78fr 1.22fr;gap:0;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-md)}
.about-photo{border-radius:0;min-height:360px;height:100%;object-fit:cover}
.about-photo.ph-box{border:0;background:linear-gradient(160deg,#e6edff,#f2f5fb);color:var(--brand-ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;text-align:center;padding:24px}
.about-photo .pic-ic{width:58px;height:58px;border-radius:50%;background:rgba(41,98,255,.12);display:grid;place-items:center;color:var(--brand)}
.about-photo .pic-lbl{font-size:14.5px;font-weight:800}
.about-photo .pic-sub{font-size:12px;color:var(--brand);font-weight:600;opacity:.85}
.about-body{padding:clamp(30px,4vw,48px);display:flex;flex-direction:column;justify-content:center}
.about-body h3{font-size:25px;margin:0 0 5px;letter-spacing:-.02em}
.about-role{color:var(--brand);font-weight:700;font-size:14.5px;margin:0 0 20px}
.about-chips{display:flex;flex-wrap:wrap;gap:9px;margin:0 0 22px}
.about-chip{display:inline-flex;align-items:center;gap:7px;background:var(--brand-soft);color:var(--brand-ink);font-size:13.5px;font-weight:700;padding:9px 14px;border-radius:10px}
.about-chip .ic{width:6px;height:6px;border-radius:50%;background:var(--brand);flex:none}
.about-quote{margin:0;padding:20px 22px;background:var(--paper-2);border-radius:14px;font-size:15.5px;line-height:1.78;color:var(--ink-soft);font-weight:500}
.about-quote-note{display:block;width:fit-content;margin-top:14px;font-size:12px;font-weight:700;color:var(--brand-ink);background:var(--brand-soft);padding:4px 9px;border-radius:6px}

/* 비교 테이블 */
.compare-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table.compare{width:100%;border-collapse:separate;border-spacing:0;min-width:600px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
table.compare th,table.compare td{padding:16px 18px;text-align:center;font-size:14.5px;border-bottom:1px solid var(--line-soft)}
table.compare tbody tr:last-child td{border-bottom:0}
table.compare thead th{font-weight:800;font-size:14px;color:var(--ink-soft);background:var(--paper-2)}
table.compare tbody td:first-child,table.compare thead th:first-child{text-align:left;font-weight:700;color:var(--ink);background:var(--paper-2)}
table.compare .hl-col{background:var(--brand-soft);color:var(--brand-ink);font-weight:800}
table.compare thead th.hl-col{background:var(--brand);color:#fff}
.cmp-o{color:var(--good);font-weight:800}.cmp-x{color:var(--gray-2);font-weight:800}.cmp-t{color:var(--accent);font-weight:800}

/* 후기 */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm)}
.review-card .quote{font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.01em;margin:0 0 10px;line-height:1.5}
.review-card .body{font-size:14px;color:var(--ink-soft);line-height:1.65;margin:0 0 16px}
.review-card .who{font-size:12.5px;color:var(--gray-2);font-weight:600}

/* 추천/비추천 */
.qualify{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.qcol{border-radius:var(--radius-lg);padding:clamp(24px,3vw,32px);border:1px solid var(--line);background:#fff}
.qcol.good{border-color:#bfe6d2;background:linear-gradient(180deg,var(--good-soft),#fff)}
.qcol h3{font-size:19px;margin:0 0 16px}
.qcol ul{list-style:none;padding:0;margin:0}
.qcol li{display:flex;gap:10px;align-items:flex-start;padding:9px 0;font-size:15px;color:var(--ink);font-weight:500;line-height:1.5}
.qcol .mk{flex:none;font-weight:800}
.qcol.good .mk{color:var(--good)}.qcol.bad .mk{color:var(--gray-2)}

/* FAQ */
.faq details{border-bottom:1px solid var(--line);padding:20px 4px}
.faq details:first-child{border-top:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;font-size:17px;font-weight:700;letter-spacing:-.01em;color:var(--ink);display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brand);font-weight:800;font-size:22px;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq .ans{font-size:15px;color:var(--ink-soft);line-height:1.75;margin:14px 0 0;max-width:760px}

/* 최종 CTA */
.final{background:linear-gradient(120deg,#0b1324,#1b2c52);border-radius:var(--radius-lg);text-align:center;padding:clamp(44px,6vw,76px) clamp(24px,4vw,40px)}
.final h2{color:#fff;font-size:clamp(26px,3.8vw,42px);margin:0 0 14px}
.final p{color:#c5cee0;font-size:16px;margin:0 auto 28px;max-width:580px}

/* 모바일 sticky CTA */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:80;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);padding:12px 16px calc(12px + env(safe-area-inset-bottom));box-shadow:0 -6px 22px rgba(16,24,40,.08);
  transform:translateY(120%);transition:transform .25s ease;display:none}
.mobile-cta .btn{width:100%;justify-content:center;font-size:16px;padding:15px}
.mobile-cta.show{transform:none}

@media(max-width:920px){
  .about-grid{grid-template-columns:1fr}
  .about-photo{min-height:230px}
  .review-grid{grid-template-columns:1fr 1fr}
  .steps.timeline .step:not(:last-child)::after{display:none}
}
@media(max-width:760px){
  .check-list{grid-template-columns:1fr}
  .qualify{grid-template-columns:1fr}
  .review-grid{grid-template-columns:1fr}
  .mobile-cta{display:block}
  body{padding-bottom:74px}
}
.only-desktop{display:inline}
@media(max-width:620px){.only-desktop{display:none}}

/* 좌측 섹션 트래커 (scroll-spy) */
section[id]{scroll-margin-top:84px}
.side-nav{position:fixed;left:18px;top:50%;transform:translateY(-50%);z-index:55;
  display:flex;flex-direction:column;gap:13px;pointer-events:none}
.side-nav a{position:relative;display:block;pointer-events:auto}
.side-nav .tick{display:block;width:20px;height:2px;border-radius:2px;background:#c7cede;
  transition:width .18s ease,background .18s ease}
.side-nav a:hover .tick,.side-nav a.active .tick{width:34px;background:var(--brand)}
.side-nav .lbl{position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%) translateX(-6px);
  background:var(--brand);color:#fff;font-size:13px;font-weight:800;padding:7px 14px;border-radius:999px;
  white-space:nowrap;box-shadow:var(--shadow-md);opacity:0;transition:opacity .18s ease,transform .18s ease;pointer-events:none}
.side-nav a:hover .lbl,.side-nav a.active .lbl{opacity:1;transform:translateY(-50%)}
@media(max-width:760px){
  .side-nav{left:7px;gap:12px}
  .side-nav .lbl{display:none}
  .side-nav .tick{width:11px}
  .side-nav a:hover .tick,.side-nav a.active .tick{width:18px}
}

/* =========================================================
   인터랙션 강화 (Fable pass) — 모션·호버·카톡
   ========================================================= */

/* 스크롤 진행바 */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:100;
  background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:0 3px 3px 0;
  box-shadow:0 0 10px rgba(41,98,255,.5)}

/* 히어로 로드인 + 배경 블롭 */
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes blobA{from{transform:translate(0,0) scale(1)}to{transform:translate(-40px,30px) scale(1.12)}}
@keyframes blobB{from{transform:translate(0,0) scale(1)}to{transform:translate(36px,-24px) scale(1.08)}}
.hero{position:relative}
.hero::before{content:"";position:absolute;top:-140px;right:-120px;width:560px;height:560px;pointer-events:none;
  background:radial-gradient(circle at 40% 40%,rgba(41,98,255,.14),transparent 65%);filter:blur(4px);
  animation:blobA 11s ease-in-out infinite alternate}
.hero::after{content:"";position:absolute;bottom:-160px;left:-140px;width:520px;height:520px;pointer-events:none;
  background:radial-gradient(circle at 55% 45%,rgba(124,92,255,.10),transparent 65%);filter:blur(4px);
  animation:blobB 13s ease-in-out infinite alternate}
.hero .hero-grid{position:relative;z-index:1}
html.js .hero .badge-pill{animation:fadeUp .7s ease .05s both}
html.js .hero h1{animation:fadeUp .8s ease .16s both}
html.js .hero .lead{animation:fadeUp .8s ease .3s both}
html.js .hero .hero-actions{animation:fadeUp .8s ease .42s both}
html.js .hero .hero-trust{animation:fadeUp .8s ease .52s both}
html.js .hero .hero-visual{animation:fadeUp .9s ease .5s both}

/* 헤드라인 하이라이트 스윕 */
.hero .hl{position:relative;z-index:0}
.hero .hl::after{content:"";position:absolute;left:-2%;bottom:6%;height:34%;width:0;z-index:-1;
  background:rgba(41,98,255,.14);border-radius:6px}
html.js .hero .hl::after{animation:hlSweep .7s ease 1s both}
@keyframes hlSweep{to{width:104%}}

/* 목업 배분 바 채워지기 + 3D 틸트 */
.mock-alloc .bar i{transform-origin:left center}
html.js .mock-alloc .alloc:nth-child(1) .bar i{animation:growBar .9s cubic-bezier(.22,1,.36,1) .9s both}
html.js .mock-alloc .alloc:nth-child(2) .bar i{animation:growBar .9s cubic-bezier(.22,1,.36,1) 1.05s both}
html.js .mock-alloc .alloc:nth-child(3) .bar i{animation:growBar .9s cubic-bezier(.22,1,.36,1) 1.2s both}
html.js .mock-alloc .alloc:nth-child(4) .bar i{animation:growBar .9s cubic-bezier(.22,1,.36,1) 1.35s both}
@keyframes growBar{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.hero-visual .mock-card{transition:transform .16s ease,box-shadow .3s ease;will-change:transform}
.hero-visual .mock-card:hover{box-shadow:0 40px 90px -20px rgba(16,24,40,.3)}

/* 키워드 마키 */
.kw-marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:13px 0;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.kw-track{display:flex;width:max-content;will-change:transform}
.kw-track span{font-size:13px;font-weight:700;color:var(--ink-soft);background:var(--paper-2);margin-right:10px;
  border:1px solid var(--line);padding:7px 15px;border-radius:999px;white-space:nowrap;transition:.2s}
.kw-track span:hover{background:var(--brand-soft);color:var(--brand-ink);border-color:#cdd9ff;transform:translateY(-2px)}
@media(max-width:760px){
  .kw-marquee{-webkit-mask-image:linear-gradient(90deg,transparent,#000 18%,#000 82%,transparent);
    mask-image:linear-gradient(90deg,transparent,#000 18%,#000 82%,transparent)}
}

/* 스태거 등장 */
html.js .reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
html.js .reveal-stagger.in>*{opacity:1;transform:none}
.reveal-stagger.in>*:nth-child(1){transition-delay:.04s}
.reveal-stagger.in>*:nth-child(2){transition-delay:.12s}
.reveal-stagger.in>*:nth-child(3){transition-delay:.2s}
.reveal-stagger.in>*:nth-child(4){transition-delay:.28s}
.reveal-stagger.in>*:nth-child(5){transition-delay:.36s}
.reveal-stagger.in>*:nth-child(6){transition-delay:.44s}
.reveal-stagger.in>*:nth-child(7){transition-delay:.52s}
.reveal-stagger.in>*:nth-child(8){transition-delay:.6s}
.reveal.in .eyebrow::before{animation:eyeGrow .5s ease both}
@keyframes eyeGrow{from{width:0}to{width:18px}}

/* 카드 호버 — 체크리스트 */
.check-item{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.check-item:hover{transform:translateY(-4px);border-color:#cdd9ff;box-shadow:var(--shadow-md)}
.check-item .ic{transition:transform .22s ease,background .22s ease,color .22s ease}
.check-item:hover .ic{background:var(--brand);color:#fff;transform:scale(1.15) rotate(8deg)}

/* 카드 호버 — 서비스(철학) : 그라데이션 스윕 + 아이콘 팝 */
.svc{position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;top:0;left:0;height:3px;width:0;border-radius:3px;
  background:linear-gradient(90deg,var(--brand),var(--accent));transition:width .38s ease}
.svc:hover::before{width:100%}
.svc .ic{transition:transform .28s cubic-bezier(.34,1.56,.64,1)}
.svc:hover .ic{transform:scale(1.12) rotate(-7deg)}

/* 스텝 카드 호버 + 번호 반전 */
.steps .step{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.steps .step:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#d7deeb}
.steps .n{transition:background .22s ease,color .22s ease,transform .22s ease}
.steps .step:hover .n{background:var(--brand);color:#fff;transform:scale(1.08)}

/* 후기 카드 — 큰따옴표 장식 + 리프트 */
.review-card{position:relative;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;overflow:hidden}
.review-card::before{content:"\201C";position:absolute;top:-8px;right:10px;font-size:88px;font-weight:800;
  color:var(--brand-soft);line-height:1;pointer-events:none;transition:color .2s ease,transform .3s ease}
.review-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:#cdd9ff}
.review-card:hover::before{color:var(--brand-soft-2);transform:scale(1.15) rotate(-6deg)}

/* 추천/비추천 호버 */
.qcol{transition:transform .18s ease,box-shadow .18s ease}
.qcol:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.qcol li{transition:transform .15s ease}
.qcol li:hover{transform:translateX(4px)}

/* 비교표 행 호버 */
table.compare tbody tr td{transition:background .15s ease}
table.compare tbody tr:hover td:not(.hl-col){background:#eef2f9}
table.compare tbody tr:hover td:first-child{color:var(--brand-ink)}

/* about 칩 호버 */
.about-chip{transition:background .2s ease,color .2s ease,transform .2s ease}
.about-chip:hover{background:var(--brand);color:#fff;transform:translateY(-2px)}
.about-chip:hover .ic{background:#fff}

/* FAQ */
.faq summary{transition:color .15s ease}
.faq summary:hover{color:var(--brand)}
.faq details[open] .ans{animation:faqIn .32s ease}
@keyframes faqIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* 버튼 — 샤인 스윕 + 리플 + 자석(JS) */
.btn{position:relative;overflow:hidden}
.btn-coral::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-20deg);transition:left .55s ease}
.btn-coral:hover::after{left:140%}
.btn .ripple{position:absolute;border-radius:50%;transform:scale(0);animation:rip .55s ease-out forwards;pointer-events:none}
@keyframes rip{to{transform:scale(3.2);opacity:0}}
.nav-right .btn-coral{animation:ctaGlow 3.4s ease-in-out infinite}
@keyframes ctaGlow{0%,100%{box-shadow:0 8px 20px rgba(41,98,255,.28)}50%{box-shadow:0 8px 30px rgba(41,98,255,.55)}}

/* 카카오 — 고정 플로팅 버튼 + 최종 버튼 */
.kakao-fab{position:fixed;right:22px;bottom:22px;z-index:85;width:58px;height:58px;border-radius:50%;
  background:#FAE100;display:grid;place-items:center;padding:0;font-size:0;
  box-shadow:0 12px 28px rgba(16,24,40,.24);transition:transform .2s ease,box-shadow .2s ease}
.kakao-fab:hover{transform:translateY(-4px) scale(1.06);box-shadow:0 16px 34px rgba(16,24,40,.3)}
.kakao-fab svg{width:28px;height:28px;display:block}
.kakao-fab::before{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #FAE100;
  animation:kping 2.6s ease-out infinite;pointer-events:none}
@keyframes kping{0%{transform:scale(1);opacity:.8}70%{transform:scale(1.55);opacity:0}100%{transform:scale(1.55);opacity:0}}
.kakao-fab .kf-tip{position:absolute;right:calc(100% + 13px);top:50%;transform:translateY(-50%) translateX(8px);
  background:var(--ink);color:#fff;font-size:12.5px;font-weight:700;padding:8px 13px;border-radius:9px;
  white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease}
.kakao-fab:hover .kf-tip{opacity:1;transform:translateY(-50%)}
.btn-kakao{background:#FAE100;color:#3A1D1D}
.btn-kakao:hover{background:#F2D900}
@media(max-width:760px){
  .kakao-fab{right:14px;bottom:calc(86px + env(safe-area-inset-bottom));width:54px;height:54px}
  .kakao-fab .kf-tip{display:none}
}

/* =========================================================
   시네마틱 패스 — 오브 링 · 발광 · 그리드 플로어 (레퍼런스 재현)
   ========================================================= */

/* 히어로 — 목업 뒤 궤도 링 (CoinOrb) */
.hero-visual{isolation:isolate}
.hero-visual .mock-card{z-index:1}
.hero-rings{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:920px;height:600px;
  pointer-events:none;z-index:0;overflow:hidden;
  -webkit-mask-image:radial-gradient(58% 58% at 50% 50%,#000 42%,transparent 76%);
  mask-image:radial-gradient(58% 58% at 50% 50%,#000 42%,transparent 76%)}
.hero-rings i{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:50%;
  border:1px solid rgba(41,98,255,.14)}
.hero-rings i:nth-child(1){width:470px;height:470px;animation:orbit 20s linear infinite}
.hero-rings i:nth-child(2){width:640px;height:640px;border-color:rgba(41,98,255,.10);animation:orbit 30s linear infinite reverse}
.hero-rings i:nth-child(3){width:820px;height:820px;border-color:rgba(124,92,255,.08);animation:orbit 42s linear infinite}
.hero-rings i::before{content:"";position:absolute;top:-4px;left:50%;margin-left:-4px;width:8px;height:8px;
  border-radius:50%;background:var(--brand);opacity:.55;box-shadow:0 0 10px 2px rgba(41,98,255,.55)}
@keyframes orbit{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* 목업 리포트 로테이션 — 패널 내용 슬라이드 + 지표 슬롯 롤링 (모션은 main.js WAAPI가 구동:
   맨 아래 전역 reduce-motion 규칙이 CSS 애니메이션을 죽여도 동작해야 하므로 여기엔 transition 없음) */
.mock-stage{position:relative;overflow:hidden}
.mock-slide.ghost{position:absolute;inset:0}
.mock-metric .v.rolling{overflow:hidden}
.mm-strip{display:block;will-change:transform}
.mm-strip>span{display:block}
html.js .mock-alloc.resw .alloc:nth-child(1) .bar i{animation:growBar .7s cubic-bezier(.22,1,.36,1) .05s both}
html.js .mock-alloc.resw .alloc:nth-child(2) .bar i{animation:growBar .7s cubic-bezier(.22,1,.36,1) .15s both}
html.js .mock-alloc.resw .alloc:nth-child(3) .bar i{animation:growBar .7s cubic-bezier(.22,1,.36,1) .25s both}
html.js .mock-alloc.resw .alloc:nth-child(4) .bar i{animation:growBar .7s cubic-bezier(.22,1,.36,1) .35s both}

/* 목업 그라데이션 패널 — 주기적 샤인 */
.mock-hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.22) 46%,transparent 60%);
  transform:translateX(-130%);animation:sheen 5s ease-in-out 2s infinite}
@keyframes sheen{0%{transform:translateX(-130%)}45%,100%{transform:translateX(130%)}}

/* 히어로 헤드라인 — 그라데이션 시머 */
.hero .hl{background:linear-gradient(90deg,var(--brand) 0%,#7c5cff 45%,var(--brand) 90%);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;animation:hlShimmer 7s linear infinite}
@keyframes hlShimmer{to{background-position:-220% 0}}

/* 히어로 잔별 (은은한 트윙클) */
.fx-dots{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.fx-dots::before,.fx-dots::after{content:"";position:absolute;top:0;left:0;width:4px;height:4px;border-radius:50%;background:transparent}
.fx-dots::before{box-shadow:12vw 66px 0 rgba(41,98,255,.26),34vw 40px 0 rgba(124,92,255,.24),56vw 110px 0 rgba(41,98,255,.28),78vw 56px 0 rgba(41,98,255,.3),91vw 150px 0 rgba(124,92,255,.24);animation:twinkle 4s ease-in-out infinite alternate}
.fx-dots::after{box-shadow:22vw 120px 0 rgba(41,98,255,.2),68vw 34px 0 rgba(124,92,255,.26),88vw 330px 0 rgba(41,98,255,.26),95vw 90px 0 rgba(41,98,255,.24);animation:twinkle 5s ease-in-out 1.2s infinite alternate}
@keyframes twinkle{from{opacity:.25}to{opacity:1}}

/* 비교표 등장 시 강조열 글로우 */
.reveal.in table.compare thead th.hl-col{animation:colGlow 1.6s ease .4s 1}
@keyframes colGlow{0%,100%{box-shadow:none}50%{box-shadow:0 0 0 3px rgba(41,98,255,.35),0 10px 34px rgba(41,98,255,.45)}}

/* ---------- 최종 CTA — 시네마틱 오브 스테이지 ---------- */
.final{position:relative;overflow:hidden;background:radial-gradient(130% 150% at 50% -10%,#1d2f55 0%,#0e1730 42%,#070d1e 100%)}
.final>*{position:relative;z-index:2}
.final .fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;border-radius:inherit}
/* 상단 라이트 빔 */
.fx-beam{position:absolute;top:-30%;left:50%;transform:translateX(-50%);width:70%;height:70%;
  background:radial-gradient(50% 60% at 50% 40%,rgba(120,165,255,.28),transparent 70%);filter:blur(28px);
  animation:beamGlow 6s ease-in-out infinite alternate}
@keyframes beamGlow{from{opacity:.6}to{opacity:1}}
/* 동심원 필 링 (CoinOrb) */
.fx-rings{position:absolute;left:50%;top:66%;width:0;height:0}
.fx-rings i{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:999px;
  border:1.5px solid rgba(130,168,255,.05);
  background:linear-gradient(180deg,rgba(130,168,255,.015),rgba(130,168,255,0) 60%);
  box-shadow:0 -18px 44px -18px rgba(130,168,255,.05) inset}
.fx-rings i:nth-child(1){width:380px;height:130px;animation:ringBreathe 4.5s ease-in-out infinite}
.fx-rings i:nth-child(2){width:580px;height:210px;border-color:rgba(130,168,255,.038);animation:ringBreathe 4.5s ease-in-out .5s infinite}
.fx-rings i:nth-child(3){width:800px;height:300px;border-color:rgba(130,168,255,.028);animation:ringBreathe 4.5s ease-in-out 1s infinite}
.fx-rings i:nth-child(4){width:1040px;height:400px;border-color:rgba(130,168,255,.018);animation:ringBreathe 4.5s ease-in-out 1.5s infinite}
.fx-rings i::before{content:"";position:absolute;top:-3px;left:50%;margin-left:-3px;width:6px;height:6px;border-radius:50%;
  background:#9db8ff;opacity:.32;box-shadow:0 0 8px 1px rgba(130,168,255,.35);animation:twinkle 3s ease-in-out infinite alternate}
@keyframes ringBreathe{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.035)}}
/* 원근 그리드 플로어 (Doks) — 은은하게 */
.fx-grid{position:absolute;left:-20%;right:-20%;top:52%;bottom:-12%;
  background-image:linear-gradient(rgba(140,172,255,.01) 1px,transparent 1px),linear-gradient(90deg,rgba(140,172,255,.01) 1px,transparent 1px);
  background-size:46px 46px;transform:perspective(420px) rotateX(56deg);transform-origin:top center;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 26%,#000 72%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 26%,#000 72%,transparent)}
/* 별밭 */
.fx-star{position:absolute;top:0;left:0;width:3px;height:3px;border-radius:50%;background:transparent;
  box-shadow:14vw 44px 0 rgba(255,255,255,.4),30vw 120px 0 rgba(255,255,255,.55),44vw 30px 0 rgba(255,255,255,.35),
  58vw 90px 0 rgba(255,255,255,.5),72vw 50px 0 rgba(255,255,255,.4),86vw 130px 0 rgba(255,255,255,.5),
  8vw 160px 0 rgba(255,255,255,.3),64vw 180px 0 rgba(255,255,255,.35);
  animation:twinkle 3.5s ease-in-out infinite alternate}
/* 커서 추적 글로우(JS가 --mx/--my 갱신) — 흰 빛이 커서를 따라다님 */
.final::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;border-radius:inherit;
  background:radial-gradient(190px at var(--mx,50%) var(--my,40%),rgba(120,165,255,.22),rgba(100,145,255,.08) 45%,transparent 72%);
  mix-blend-mode:screen;opacity:0;transition:opacity .3s ease}
.final:hover::after{opacity:1}
#finalCta{scroll-margin-top:90px}
/* 한정 배지 */
.final-badge{display:inline-block;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);
  color:#fff;font-weight:700;font-size:13px;padding:5px 13px;border-radius:999px;margin-left:4px}
/* 남은 자리 배지 (버튼 느낌·기능 없음, 네이비 배경용) */
.slots-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.26);color:#fff;font-weight:700;font-size:12.5px;
  padding:7px 15px;border-radius:999px;letter-spacing:.01em}
.slots-badge::before{content:"";width:6px;height:6px;border-radius:50%;background:#FFD84D;
  box-shadow:0 0 8px rgba(255,216,77,.8);animation:twinkle 2.4s ease-in-out infinite alternate}
/* 카드 전체 클릭 (제목 링크를 카드 전면으로 확장) */
.card{position:relative}
.card .card-link::after{content:"";position:absolute;inset:0;z-index:1}
/* 최종 CTA 버튼 승격 */
.final .btn-light{box-shadow:0 14px 40px -10px rgba(120,165,255,.55),0 0 0 1px rgba(255,255,255,.25) inset}
.final .btn-light:hover{box-shadow:0 18px 50px -10px rgba(120,165,255,.75)}

@media(max-width:760px){
  .hero-rings{display:none}
  .fx-rings i:nth-child(4){display:none}
}

/* 모션 최소화 존중 */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
