/* ══════════════════════════════════════════════════════════
   PG 건강검진 — premium financial-checkup design system
   ══════════════════════════════════════════════════════════ */
:root{
  /* ink / dark surfaces */
  --ink:#080C1C; --ink-2:#0E1530; --navy:#16224D; --navy-2:#1D2C63;
  /* accents */
  --azure:#2F5BFF; --azure-deep:#1E3FB8; --azure-soft:#ECF1FF;
  --gold:#C8A24A; --gold-lt:#E3C271; --gold-soft:#F6EEDA;
  /* slate neutrals */
  --s900:#0F172A; --s800:#1E293B; --s700:#334155; --s600:#475569;
  --s500:#64748B; --s400:#94A3B8; --s300:#CBD5E1; --s200:#E2E8F0;
  --s100:#F1F5F9; --s50:#F8FAFC;
  /* semantic */
  --ok:#15825A; --ok-soft:#E4F3EC; --warn:#C77C16; --warn-soft:#FBF0DC;
  --risk:#C8453C; --risk-soft:#FBEAE8;
  --bg:#F4F6FB; --white:#fff;
  --radius:18px; --radius-sm:12px;
  --sh-sm:0 1px 2px rgba(15,23,42,.06);
  --sh:0 14px 40px -22px rgba(15,23,42,.32);
  --sh-card:0 1px 2px rgba(15,23,42,.05),0 12px 28px -20px rgba(15,23,42,.28);
  --maxw:500px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{min-height:100%;font-family:'Pretendard',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg);color:var(--s900);overflow-x:hidden;-webkit-font-smoothing:antialiased;
  font-feature-settings:"tnum" 1,"case" 1}
body{position:relative}
body::before{content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(120% 60% at 50% -10%,#EEF2FC 0%,var(--bg) 55%)}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* ══ INTRO ══ */
.intro{position:fixed;inset:0;z-index:200;background:var(--ink);overflow:hidden}
.intro.out{animation:introOut .55s var(--ease) forwards}
@keyframes introOut{to{opacity:0;pointer-events:none}}
.intro-grad{position:absolute;inset:0;background:
  radial-gradient(80% 55% at 50% 38%,rgba(47,91,255,.22),transparent 70%),
  linear-gradient(180deg,#0A1024 0%,#0C1330 55%,#080C1C 100%)}
.intro-noise{position:absolute;inset:0;opacity:.06;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.ig{position:absolute;inset:0;display:grid;grid-template-rows:repeat(4,1fr);gap:9px;padding:14px;z-index:0}
.ig-row{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;transition:transform .5s cubic-bezier(.4,0,1,1),opacity .4s ease}
.ig-cell{display:flex;align-items:center;justify-content:center;border-radius:14px;backdrop-filter:blur(1px)}
.t1{font-size:22px;opacity:.1;background:rgba(255,255,255,.015);border:1px solid rgba(255,255,255,.05)}
.t2{font-size:30px;opacity:.22;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.09)}
.t3{font-size:38px;opacity:.42;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15)}
.t4{font-size:48px;opacity:.72;background:rgba(255,255,255,.09);border:1.5px solid rgba(200,162,74,.32);box-shadow:0 0 28px rgba(200,162,74,.1)}
.ig-ov{position:absolute;inset:0;background:radial-gradient(ellipse 74% 66% at 50% 46%,rgba(8,12,28,.86) 26%,rgba(8,12,28,.52) 100%);z-index:1}
.ig-lbl{position:absolute;z-index:2;font-size:9px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:rgba(255,255,255,.2)}
.ig-lbl.lo{bottom:18px;left:20px}.ig-lbl.hi{top:18px;right:20px;color:var(--gold-lt);opacity:.7}
.ig-cont{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 30px;transition:opacity .5s ease}
.ig-eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;color:var(--gold-lt);letter-spacing:2px;text-transform:uppercase;margin-bottom:22px}
.ig-eyebrow::before,.ig-eyebrow::after{content:'';width:18px;height:1px;background:rgba(200,162,74,.4)}
.ig-title{font-size:clamp(46px,13vw,62px);font-weight:900;color:#fff;letter-spacing:-3px;line-height:.92;margin-bottom:16px}
.ig-title em{font-style:normal;color:#7FA0FF}
.ig-sub{font-size:15.5px;color:rgba(255,255,255,.6);margin-bottom:30px;font-weight:500;line-height:1.6;max-width:300px}
.ig-meta{display:flex;gap:18px;margin-bottom:34px}
.ig-meta div{display:flex;flex-direction:column;gap:3px}
.ig-meta b{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.5px}
.ig-meta span{font-size:10.5px;color:rgba(255,255,255,.4);font-weight:600;letter-spacing:.3px}
.ig-meta i{width:1px;background:rgba(255,255,255,.12);align-self:stretch}
.ig-btn{display:inline-flex;align-items:center;gap:12px;padding:17px 40px;background:linear-gradient(180deg,#fff,#F2F5FF);border:none;border-radius:50px;
  font-family:inherit;font-size:16.5px;font-weight:800;color:var(--ink);cursor:pointer;
  box-shadow:0 10px 36px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.1);letter-spacing:-.3px;transition:transform .18s var(--ease),box-shadow .18s}
.ig-btn:hover{transform:translateY(-2px);box-shadow:0 16px 44px rgba(0,0,0,.46)}
.ig-btn .arr{display:inline-flex;width:24px;height:24px;border-radius:50%;background:var(--azure);color:#fff;align-items:center;justify-content:center;font-size:13px;transition:transform .18s}
.ig-btn:hover .arr{transform:translateX(3px)}
.ig-hint{margin-top:18px;font-size:11.5px;color:rgba(255,255,255,.3);font-weight:500}
.ig-explore{margin-top:16px;display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:rgba(255,255,255,.5);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.18);padding-bottom:2px;transition:color .16s,border-color .16s}
.ig-explore:hover{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.5)}
.ig-explore b{color:var(--gold-lt);font-weight:700}

/* ══ HEADER ══ */
.hdr{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.86);backdrop-filter:saturate(1.4) blur(14px);border-bottom:1px solid var(--s200)}
.hdr-in{max-width:var(--maxw);margin:0 auto;padding:14px 22px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:9px;font-size:16px;font-weight:800;color:var(--navy);letter-spacing:-.4px;white-space:nowrap}
.hdr-lbl{white-space:nowrap}
.brand .dot{width:9px;height:9px;border-radius:50%;background:linear-gradient(135deg,var(--azure),var(--azure-deep));box-shadow:0 0 0 4px var(--azure-soft)}
.hdr-lbl{font-size:11px;color:var(--s400);font-weight:600;letter-spacing:.3px}

/* ══ PROGRESS ══ */
.prog{position:fixed;top:53px;left:0;right:0;z-index:99;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);padding:13px 22px 15px}
.prog.hide{display:none}
.prog-head{max-width:var(--maxw);margin:0 auto 9px;display:flex;justify-content:space-between;align-items:center}
.prog-step{font-size:11px;font-weight:700;color:var(--azure);letter-spacing:.4px;white-space:nowrap}
.prog-pct{font-size:11px;font-weight:700;color:var(--s400);white-space:nowrap}
.prog-track{height:5px;background:var(--s200);border-radius:3px;overflow:hidden;max-width:var(--maxw);margin:0 auto}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--azure),var(--azure-deep));border-radius:3px;transition:width .45s var(--ease);position:relative}
.prog-fill::after{content:'';position:absolute;right:0;top:0;bottom:0;width:14px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5))}

/* ══ QUIZ ══ */
.quiz{padding-top:118px;min-height:100vh;overflow:hidden}
.stage{position:relative;min-height:calc(100vh - 118px);overflow:hidden}
.card{position:absolute;top:0;left:0;right:0;min-height:calc(100vh - 118px);padding:30px 22px 130px;
  display:flex;flex-direction:column;max-width:var(--maxw);margin:0 auto;
  transition:transform .26s var(--ease),opacity .2s ease;will-change:transform,opacity}
.card.enter{transform:translateX(28px);opacity:0;pointer-events:none}
.card.active{transform:translateX(0);opacity:1}
.card.exit{transform:translateX(-28px);opacity:0;pointer-events:none}
.card-qno{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--azure);letter-spacing:.4px;margin-bottom:16px}
.card-qno .qb{font-variant-numeric:tabular-nums}
.card-qno .qt{color:var(--s400);font-weight:600}
.card-q{font-size:clamp(21px,5.6vw,25px);font-weight:800;color:var(--navy);line-height:1.42;letter-spacing:-.6px;margin-bottom:10px;text-wrap:pretty;white-space:pre-line}
.card-sub{font-size:14px;color:var(--s500);line-height:1.65;margin-bottom:28px;font-weight:500}
.card-sub.quote{background:var(--azure-soft);border-left:3px solid var(--azure);border-radius:0 10px 10px 0;
  padding:12px 16px;color:var(--navy-2);font-weight:600;font-style:italic}
.opts{display:flex;flex-direction:column;gap:11px}
.opts.g2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.ob{width:100%;padding:17px 18px;background:var(--white);border:1.5px solid var(--s200);border-radius:14px;
  font-family:inherit;font-size:14.5px;font-weight:600;color:var(--s800);cursor:pointer;text-align:left;
  transition:all .2s var(--ease);display:flex;align-items:center;gap:13px;box-shadow:var(--sh-sm);line-height:1.45}
.ob:hover{border-color:var(--azure);color:var(--navy);transform:translateY(-1px);box-shadow:0 8px 20px -12px rgba(47,91,255,.5)}
.ob.sel{background:linear-gradient(135deg,var(--navy),var(--navy-2));border-color:var(--navy);color:#fff;box-shadow:0 10px 26px -12px rgba(22,34,77,.7)}
.ck{width:22px;height:22px;border-radius:50%;border:2px solid var(--s300);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:transparent;transition:all .2s}
.ob:hover .ck{border-color:var(--azure)}
.ob.sel .ck{background:var(--gold);border-color:var(--gold);color:var(--ink)}

/* ══ NAV ══ */
.nav{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,rgba(244,246,251,0),var(--bg) 30%);padding:18px 22px calc(18px + env(safe-area-inset-bottom));z-index:100}
.nav.hide{display:none}
.nav-in{max-width:var(--maxw);margin:0 auto;display:flex;gap:11px}
.bp{width:50px;height:52px;border:1.5px solid var(--s200);border-radius:14px;background:var(--white);cursor:pointer;font-size:18px;color:var(--s500);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .16s;box-shadow:var(--sh-sm)}
.bp:hover{border-color:var(--navy);color:var(--navy)}.bp:disabled{opacity:.35;cursor:default}
.bn{flex:1;height:52px;background:linear-gradient(130deg,var(--navy),var(--azure-deep));color:#fff;font-family:inherit;font-size:15.5px;font-weight:700;border:none;border-radius:14px;cursor:pointer;transition:transform .16s,box-shadow .16s;box-shadow:0 12px 26px -12px rgba(30,63,184,.7)}
.bn:hover{transform:translateY(-1px)}.bn:disabled{opacity:.4;cursor:default;transform:none;box-shadow:none}
.nav-hint{flex:1;height:52px;display:none;align-items:center;justify-content:center;gap:7px;font-size:12.5px;color:var(--s400);font-weight:600}
.nav-hint.show{display:flex}
.nav-hint .pulse{width:7px;height:7px;border-radius:50%;background:var(--azure);animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.3)}}

/* ══ LOADING ══ */
.loading{position:fixed;inset:0;background:linear-gradient(180deg,#0A1024,#080C1C);z-index:200;display:none;flex-direction:column;align-items:center;justify-content:center;gap:26px;opacity:0;transition:opacity .45s}
.loading.show{display:flex;opacity:1}
.l-ring{position:relative;width:108px;height:108px}
.l-ring svg{transform:rotate(-90deg)}
.l-ring .bg{fill:none;stroke:rgba(255,255,255,.08);stroke-width:6}
.l-ring .fg{fill:none;stroke:url(#lg);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .12s linear}
.l-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;color:#fff;letter-spacing:-1px}
.l-txt{color:rgba(255,255,255,.72);font-size:15px;font-weight:600;min-height:24px;text-align:center;transition:opacity .3s}
.l-brand{font-size:12px;font-weight:700;color:rgba(200,162,74,.7);letter-spacing:2.5px;text-transform:uppercase}

/* ══ RESULTS — single scroll ══ */
.res{display:none;padding-top:53px;min-height:100vh}
.res-scroll{max-width:var(--maxw);margin:0 auto;padding-bottom:60px}
.reveal{animation:revealUp .55s var(--ease)}
@keyframes revealUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ── HERO (shared, shareable) ── */
.hero{position:relative;padding:30px 22px 36px;text-align:center;overflow:hidden;
  background:#0F1733;
  background:radial-gradient(90% 60% at 50% 0%,#1B2A60 0%,#111935 52%,#0A0F24 100%)}
.hero-noise{position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-in{position:relative;z-index:1}
.hero-chips{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;margin-bottom:18px}
.hero-chip{font-size:10.5px;font-weight:700;padding:5px 12px;border-radius:20px;letter-spacing:.2px;white-space:nowrap}
.hero-co{color:rgba(255,255,255,.42);font-size:11px;font-weight:700;letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}
.tc-char{height:148px;width:148px;position:relative;margin:0 auto 6px}
.tc-main{position:absolute;top:52%;left:50%;line-height:1;z-index:5;filter:drop-shadow(0 10px 24px rgba(0,0,0,.4))}
.tc-zone{position:absolute;inset:0;pointer-events:none;overflow:visible;z-index:20}
.tc-char .halo{position:absolute;inset:8%;border-radius:50%;background:radial-gradient(circle,rgba(127,160,255,.22),transparent 68%);z-index:0}
.hero-name{font-size:clamp(25px,7vw,30px);font-weight:900;color:#fff;letter-spacing:-1px;margin-bottom:14px}
.evo{display:flex;align-items:center;justify-content:center;gap:5px;margin:6px 0 18px}
.evo-em{font-size:22px;opacity:.22;line-height:1;transition:all .3s}
.evo-em.cur{font-size:30px;opacity:1;background:rgba(255,255,255,.08);border:1.5px solid rgba(200,162,74,.4);border-radius:12px;padding:6px 8px;box-shadow:0 0 22px rgba(200,162,74,.14)}
.evo-em.nxt{opacity:.45}
.evo-arr{font-size:11px;color:rgba(255,255,255,.25)}

/* rank block in hero */
.hero-rank{display:flex;align-items:stretch;justify-content:center;gap:0;margin:0 auto 16px;max-width:348px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden}
.hr-cell{flex:1;padding:16px 8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:88px}
.hr-cell+.hr-cell{border-left:1px solid rgba(255,255,255,.1)}
.hr-val{font-size:24px;font-weight:900;letter-spacing:-1px;line-height:1;display:flex;align-items:baseline;justify-content:center;gap:1px}
.hr-val.gold{color:#E3C271}
.hr-val.white{color:#fff}
.hr-val small{font-size:12px;font-weight:700;color:rgba(255,255,255,.45)}
.hr-lbl{font-size:10.5px;font-weight:600;color:rgba(255,255,255,.6);letter-spacing:.2px;line-height:1.3;text-align:center}
.hero-desc{font-size:13.5px;color:rgba(255,255,255,.68);line-height:1.8;max-width:300px;margin:0 auto}
.hero-next{display:flex;align-items:center;gap:12px;margin:16px auto 0;max-width:330px;
  background:rgba(255,255,255,.06);border:1px solid rgba(200,162,74,.3);border-radius:14px;padding:11px 15px;text-align:left}
.hn-ic{font-size:26px;line-height:1;flex-shrink:0}
.hn-tx{display:flex;flex-direction:column;gap:2px;min-width:0}
.hn-lbl{font-size:9.5px;font-weight:700;color:var(--gold-lt);letter-spacing:.7px;text-transform:uppercase}
.hn-to{font-size:13px;font-weight:700;color:#fff;line-height:1.35}
.bench-foot{font-size:10.5px;color:var(--s400);line-height:1.6;padding:4px 4px 0;margin-top:2px;text-wrap:pretty}
.bench-foot b{color:var(--s600);font-weight:700}
.live-tag{display:inline-flex;align-items:center;gap:5px;margin-left:9px;font-size:9.5px;font-weight:800;color:var(--ok);background:var(--ok-soft);padding:2px 8px;border-radius:20px;letter-spacing:.2px;vertical-align:middle}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(21,130,90,.5);animation:livePulse 1.8s infinite}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(21,130,90,.45)}70%{box-shadow:0 0 0 6px rgba(21,130,90,0)}100%{box-shadow:0 0 0 0 rgba(21,130,90,0)}}

/* ── section label ── */
.sec{padding:26px 22px 10px}
.sec-lbl{font-size:11px;font-weight:700;color:var(--s400);letter-spacing:1px;text-transform:uppercase;display:flex;align-items:center;gap:10px}
.sec-lbl::after{content:'';flex:1;height:1px;background:var(--s200)}
.sec-title{font-size:18px;font-weight:800;color:var(--navy);letter-spacing:-.5px;margin-top:8px}
.sec-title small{display:block;font-size:12.5px;font-weight:500;color:var(--s500);margin-top:5px;letter-spacing:0}

/* ── generic card ── */
.wrap{padding:0 18px;display:flex;flex-direction:column;gap:12px}
.card-w{background:var(--white);border-radius:var(--radius);border:1px solid var(--s200);padding:18px;box-shadow:var(--sh-card)}

/* ── category benchmark bars (B) ── */
.cat-card{background:var(--white);border-radius:var(--radius-sm);border:1px solid var(--s200);padding:15px 17px;box-shadow:var(--sh-sm)}
.cat-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}
.cat-nm{font-size:13px;font-weight:700;color:var(--s800);display:flex;align-items:center;gap:8px}
.cat-nm .ic{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;background:var(--azure-soft)}
.cat-lv{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:8px}
.cat-bar{position:relative;height:9px;background:var(--s100);border-radius:5px;margin:14px 0 6px}
.cat-fill{height:100%;border-radius:5px;transition:width 1s var(--ease)}
.cat-avg{position:absolute;top:-5px;width:2px;height:19px;background:var(--s500);border-radius:1px;transform:translateX(-50%)}
.cat-avg::before{content:'평균';position:absolute;top:-15px;left:50%;transform:translateX(-50%);font-size:8.5px;font-weight:700;color:var(--s500);white-space:nowrap}
.cat-you{position:absolute;top:-22px;transform:translateX(-50%);font-size:8.5px;font-weight:800;color:var(--navy);white-space:nowrap;transition:left 1s var(--ease)}
.cat-you::after{content:'';position:absolute;left:50%;top:13px;transform:translateX(-50%);border-left:3px solid transparent;border-right:3px solid transparent;border-top:4px solid var(--navy)}
.cat-desc{font-size:11.5px;color:var(--s500);line-height:1.55}

/* ── risk warnings (B) ── */
.risk-card{background:var(--white);border-radius:var(--radius-sm);border:1px solid var(--s200);padding:14px 16px;display:flex;gap:12px;align-items:flex-start;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.risk-card.flag{border-left:3px solid var(--risk)}
.risk-ic{width:30px;height:30px;border-radius:9px;background:var(--risk-soft);color:var(--risk);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.risk-body{flex:1;min-width:0}
.risk-t{font-size:13px;font-weight:700;color:var(--s900);margin-bottom:3px;line-height:1.4}
.risk-d{font-size:11.5px;color:var(--s500);line-height:1.5}
.risk-locked{margin-top:8px;background:var(--s50);border:1px dashed var(--s300);border-radius:9px;padding:9px 11px;display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--s500);font-weight:600}
.risk-locked .blur{filter:blur(5px);user-select:none;font-weight:800;color:var(--navy);letter-spacing:1px}
.risk-locked .lk{margin-left:auto;font-size:11px;font-weight:700;color:var(--azure);white-space:nowrap}

/* saving teaser (B) */
.save-card{background:linear-gradient(135deg,var(--navy),var(--azure-deep));border-radius:var(--radius);padding:20px;color:#fff;box-shadow:var(--sh);position:relative;overflow:hidden}
.save-card .glow{position:absolute;top:-40%;right:-20%;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(200,162,74,.3),transparent 70%)}
.save-lbl{font-size:11.5px;font-weight:600;color:rgba(255,255,255,.6);margin-bottom:8px;position:relative}
.save-val{font-size:34px;font-weight:900;letter-spacing:-1.5px;position:relative;display:flex;align-items:baseline;gap:6px}
.save-val .blur{filter:blur(8px);user-select:none}
.save-val .gold{color:#E3C271}
.save-note{font-size:11.5px;color:rgba(255,255,255,.55);margin-top:8px;position:relative;line-height:1.5}

/* ── ranking ladder (A) ── */
.ladder{display:flex;flex-direction:column-reverse;gap:8px}
.lad-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:var(--white);border:1px solid var(--s200);box-shadow:var(--sh-sm);transition:all .2s}
.lad-row.you{background:linear-gradient(135deg,var(--navy),var(--navy-2));border-color:var(--navy);box-shadow:var(--sh);transform:scale(1.02)}
.lad-tier{font-size:10px;font-weight:800;color:var(--s400);width:42px;flex-shrink:0;letter-spacing:.3px}
.lad-row.you .lad-tier{color:var(--gold-lt)}
.lad-em{font-size:24px;line-height:1}
.lad-info{flex:1;min-width:0}
.lad-nm{font-size:13px;font-weight:700;color:var(--s800)}
.lad-row.you .lad-nm{color:#fff}
.lad-meta{font-size:10.5px;color:var(--s400);font-weight:600}
.lad-row.you .lad-meta{color:rgba(255,255,255,.6)}
.lad-badge{font-size:10px;font-weight:800;color:var(--gold-lt);background:rgba(200,162,74,.15);padding:4px 9px;border-radius:8px;white-space:nowrap}

/* percentile bar (A) */
.pct-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--s200);padding:20px 18px;box-shadow:var(--sh-card)}
.pct-top{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}
.pct-big{font-size:40px;font-weight:900;letter-spacing:-2px;color:var(--navy);line-height:1}
.pct-big em{font-style:normal;font-size:18px;color:var(--azure)}
.pct-cap{font-size:12px;color:var(--s500);font-weight:600;text-align:right;line-height:1.5}
.pct-rail{position:relative;height:12px;border-radius:6px;background:linear-gradient(90deg,#E2E8F0,#CBD5E1);overflow:visible;margin:26px 0 10px}
.pct-grad{position:absolute;inset:0;border-radius:6px;background:linear-gradient(90deg,#C8453C,#C77C16 40%,#15825A 78%,var(--navy))}
.pct-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--navy);box-shadow:0 4px 10px rgba(15,23,42,.3);transition:left 1s var(--ease)}
.pct-flag{position:absolute;bottom:24px;transform:translateX(-50%);background:var(--navy);color:#fff;font-size:11px;font-weight:800;padding:5px 10px;border-radius:8px;white-space:nowrap;transition:left 1s var(--ease)}
.pct-flag::after{content:'';position:absolute;left:50%;bottom:-5px;transform:translateX(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--navy)}
.pct-scale{display:flex;justify-content:space-between;font-size:10px;color:var(--s400);font-weight:600}

/* peer compare (A) */
.peer{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.peer-card{background:var(--white);border-radius:var(--radius-sm);border:1px solid var(--s200);padding:15px;box-shadow:var(--sh-sm);text-align:center}
.peer-card .pe{font-size:30px;line-height:1;margin-bottom:7px;opacity:.85}
.peer-tag{font-size:10px;font-weight:700;letter-spacing:.3px;margin-bottom:4px}
.peer-nm{font-size:12.5px;font-weight:700;color:var(--s800)}
.peer-d{font-size:10.5px;color:var(--s400);margin-top:3px}

/* ── benchmark quadrant (C) ── */
.quad-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--s200);padding:18px;box-shadow:var(--sh-card)}
.quad{position:relative;width:100%;aspect-ratio:1;background:
  linear-gradient(0deg,rgba(47,91,255,.03),rgba(47,91,255,.03)),
  repeating-linear-gradient(90deg,transparent,transparent calc(25% - 1px),var(--s100) calc(25% - 1px),var(--s100) 25%),
  repeating-linear-gradient(0deg,transparent,transparent calc(25% - 1px),var(--s100) calc(25% - 1px),var(--s100) 25%);
  border:1px solid var(--s200);border-radius:12px;overflow:hidden}
.quad-axis{position:absolute;background:var(--s300)}
.quad-axis.x{left:0;right:0;top:50%;height:1px}
.quad-axis.y{top:0;bottom:0;left:50%;width:1px}
.quad-dot{position:absolute;width:7px;height:7px;border-radius:50%;background:var(--s300);transform:translate(-50%,50%)}
.quad-you{position:absolute;width:18px;height:18px;border-radius:50%;background:var(--navy);border:3px solid #fff;box-shadow:0 4px 12px rgba(22,34,77,.5),0 0 0 6px rgba(47,91,255,.15);transform:translate(-50%,50%);z-index:3;transition:all 1.1s var(--ease)}
.quad-you::after{content:'나';position:absolute;top:-26px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;font-size:10px;font-weight:800;padding:3px 8px;border-radius:7px;white-space:nowrap}
.quad-lbl{position:absolute;font-size:9.5px;font-weight:700;color:var(--s400);letter-spacing:.3px}
.quad-lbl.tl{top:8px;left:9px}.quad-lbl.tr{top:8px;right:9px;text-align:right}
.quad-lbl.bl{bottom:8px;left:9px}.quad-lbl.br{bottom:8px;right:9px;text-align:right}
.quad-axislbl{display:flex;justify-content:space-between;margin-top:10px;font-size:10.5px;color:var(--s500);font-weight:600}
.quad-ynote{font-size:10.5px;color:var(--s500);font-weight:600;text-align:center;margin-bottom:8px}

/* distribution curve (C) */
.dist-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--s200);padding:18px;box-shadow:var(--sh-card)}
.dist-svg{width:100%;height:120px;display:block;overflow:visible}
.dist-cap{display:flex;justify-content:space-between;font-size:10.5px;color:var(--s400);font-weight:600;margin-top:6px}
.dist-note{font-size:12px;color:var(--s600);line-height:1.6;margin-top:12px;text-align:center}
.dist-note b{color:var(--navy);font-weight:800}

/* mini benchmark (C) */
.mini{display:flex;flex-direction:column;gap:10px}
.mini-row{display:flex;align-items:center;gap:11px}
.mini-nm{font-size:12px;font-weight:600;color:var(--s700);width:88px;flex-shrink:0}
.mini-track{flex:1;position:relative;height:7px;background:var(--s100);border-radius:4px}
.mini-fill{height:100%;border-radius:4px;transition:width 1s var(--ease)}
.mini-avg{position:absolute;top:-3px;width:2px;height:13px;background:var(--s400);border-radius:1px;transform:translateX(-50%)}
.mini-val{font-size:11px;font-weight:800;color:var(--navy);width:30px;text-align:right;flex-shrink:0}

/* ── CTA ── */
.cta-wrap{padding:28px 18px 0}
.cta-card{background:linear-gradient(160deg,#fff,#F4F7FF);border-radius:var(--radius);border:1px solid var(--s200);padding:22px;box-shadow:var(--sh-card);position:relative;overflow:hidden}
.cta-eyebrow{font-size:11px;font-weight:700;color:var(--azure);letter-spacing:.8px;text-transform:uppercase;margin-bottom:8px}
.cta-ttl{font-size:17px;font-weight:800;color:var(--navy);line-height:1.45;letter-spacing:-.4px;margin-bottom:5px;text-wrap:pretty}
.cta-sub{font-size:12.5px;color:var(--s500);line-height:1.6;margin-bottom:16px}
.cta-btns{display:flex;flex-direction:column;gap:10px}
.btn-c{width:100%;height:54px;background:linear-gradient(130deg,var(--navy),var(--azure-deep));color:#fff;font-family:inherit;font-size:15.5px;font-weight:700;border:none;border-radius:14px;cursor:pointer;transition:transform .16s,box-shadow .16s;box-shadow:0 12px 28px -12px rgba(30,63,184,.7);display:flex;align-items:center;justify-content:center;gap:8px}
.btn-c:hover{transform:translateY(-2px);box-shadow:0 16px 34px -12px rgba(30,63,184,.8)}
.btn-shr{width:100%;height:48px;background:var(--white);border:1.5px solid var(--s200);border-radius:14px;font-family:inherit;font-size:14px;font-weight:700;color:var(--s700);cursor:pointer;transition:all .16s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-shr:hover{border-color:var(--navy);color:var(--navy);transform:translateY(-1px)}
.btn-shr.copied{border-color:var(--ok);color:var(--ok);background:var(--ok-soft)}
.trust{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:14px;flex-wrap:wrap}
.trust span{font-size:10.5px;color:var(--s400);font-weight:600;display:flex;align-items:center;gap:5px}
.btn-r{margin:20px auto 0;font-size:12.5px;color:var(--s400);background:none;border:none;cursor:pointer;font-family:inherit;display:block;text-align:center;font-weight:600}
.btn-r:hover{color:var(--s600)}

/* shared-view teaser */
.shared-teaser{padding:34px 22px;text-align:center}
.shared-teaser .em{font-size:38px;margin-bottom:14px}
.shared-teaser h3{font-size:17px;font-weight:800;color:var(--navy);margin-bottom:7px}
.shared-teaser p{font-size:13px;color:var(--s500);margin-bottom:20px;line-height:1.7}
.shared-teaser a{display:inline-flex;align-items:center;gap:8px;padding:15px 32px;background:linear-gradient(130deg,var(--navy),var(--azure-deep));color:#fff;border-radius:14px;font-size:14.5px;font-weight:700;text-decoration:none;box-shadow:0 12px 28px -12px rgba(30,63,184,.7)}

/* ══ POPUP ══ */
.overlay{position:fixed;inset:0;background:rgba(8,12,28,.55);backdrop-filter:blur(3px);z-index:300;display:none;align-items:flex-end;justify-content:center}
.overlay.show{display:flex}
.popup{background:var(--white);border-radius:24px 24px 0 0;padding:24px 22px calc(26px + env(safe-area-inset-bottom));width:100%;max-width:var(--maxw);animation:shUp .35s var(--ease);max-height:92vh;overflow-y:auto}
@keyframes shUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.ph{width:40px;height:4px;background:var(--s200);border-radius:2px;margin:0 auto 20px}
.popup h3{font-size:18px;font-weight:800;color:var(--navy);margin-bottom:5px;letter-spacing:-.4px}
.psub{font-size:12.5px;color:var(--s500);margin-bottom:18px;line-height:1.65}
.pf-row{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.pi{width:100%;height:46px;border:1.5px solid var(--s200);border-radius:11px;padding:0 13px;font-family:inherit;font-size:14px;color:var(--s900);margin-bottom:9px;outline:none;transition:border-color .16s,box-shadow .16s;background:var(--white)}
.pi:focus{border-color:var(--azure);box-shadow:0 0 0 4px var(--azure-soft)}
.pi::placeholder{color:var(--s400)}
.cbx{background:var(--s50);border-radius:11px;padding:13px 14px;margin:4px 0 14px;font-size:11.5px;color:var(--s500);line-height:1.7}
.crow{display:flex;align-items:flex-start;gap:9px;margin-bottom:6px}.crow:last-child{margin-bottom:0}
.crow input{margin-top:2px;accent-color:var(--azure);flex-shrink:0;cursor:pointer;width:15px;height:15px}
.crow label{cursor:pointer}
.psub-btn{width:100%;height:50px;background:linear-gradient(130deg,var(--navy),var(--azure-deep));color:#fff;font-family:inherit;font-size:15px;font-weight:700;border:none;border-radius:13px;cursor:pointer;transition:transform .16s;box-shadow:0 12px 26px -12px rgba(30,63,184,.7)}
.psub-btn:hover{transform:translateY(-1px)}
.pok{text-align:center;padding:18px 0}
.pok .ico{font-size:44px;margin-bottom:14px}
.pok p{font-size:16px;font-weight:800;color:var(--navy);margin-bottom:6px}
.pok span{font-size:13px;color:var(--s500)}

/* ══ character fx ══ */
.fx-el{position:absolute;pointer-events:none;z-index:15;line-height:1}
.zb{position:absolute;font-weight:900;pointer-events:none;line-height:1;animation:zRise 2.4s ease-out forwards;z-index:20}
@keyframes zRise{0%{opacity:0;transform:translateY(0) scale(.4) rotate(-14deg)}18%{opacity:.9}100%{opacity:0;transform:translateY(-70px) scale(1.1) rotate(16deg)}}
@keyframes animCarnivore{0%,50%{transform:translate(-50%,-50%) scale(1) rotate(0)}62%{transform:translate(-50%,-50%) scale(.82) rotate(-12deg)}74%{transform:translate(-50%,-50%) scale(1.48) rotate(6deg)}88%,100%{transform:translate(-50%,-50%) scale(1) rotate(0)}}
@keyframes animHerbivore{0%,100%{transform:translate(-50%,-50%) translateY(0) rotate(0)}35%{transform:translate(-50%,-50%) translateY(-9px) rotate(-3deg)}65%{transform:translate(-50%,-50%) translateY(-4px) rotate(2deg)}}
@keyframes animBird{0%,100%{transform:translate(-50%,-50%) rotate(0) scale(1)}12%{transform:translate(-50%,-50%) rotate(-14deg) scale(1.08) translateY(-6px)}24%{transform:translate(-50%,-50%) rotate(11deg) scale(1.05) translateY(-9px)}36%{transform:translate(-50%,-50%) rotate(-8deg) scale(1.07) translateY(-4px)}48%{transform:translate(-50%,-50%) rotate(6deg) scale(1.04) translateY(-6px)}65%{transform:translate(-50%,-50%) rotate(0) scale(1) translateY(0)}}
@keyframes animOcean{0%,100%{transform:translate(-50%,-50%) translateX(0) rotate(0)}25%{transform:translate(-50%,-50%) translateX(-11px) rotate(-5deg)}75%{transform:translate(-50%,-50%) translateX(11px) rotate(5deg)}}

/* ══ responsive ══ */
@media(min-width:600px){
  .ig-sub{font-size:17px}
  .hero-desc{font-size:14.5px}
}
@media print{.hdr,.prog,.nav,.loading,.overlay,.intro,#tweaksMount{display:none!important}.res{display:block!important}}

/* ── nowrap polish (Korean syllable wrapping) ── */
.cat-nm,.cat-lv,.pct-big,.pct-cap,.pct-scale span,.trust span,.quad-lbl,.quad-axislbl span,.dist-cap span,.btn-r,.lad-nm,.lad-meta,.lad-badge,.peer-tag,.hr-lbl,.save-lbl{white-space:nowrap}
.cat-nm{min-width:0}
.quad-ynote,.quad-axislbl{white-space:nowrap}
