/* =========================================================
   한화엔진 준법 트레이딩 데스크 · Design System
   ========================================================= */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard-dynamic-subset.css');
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap');

:root{
  /* surfaces */
  --bg:#06090F; --bg2:#0A0E16;
  --s1:#0E141E; --s2:#131B28; --s3:#182334; --s0:#080C13;
  --line:rgba(255,255,255,.07); --line2:rgba(255,255,255,.12);
  /* text */
  --text:#EAF1F8; --sub:#AFBECE; --muted:#7889A0; --faint:#54657C;
  /* brand */
  --brand:#FB6514; --brand2:#FF8A3D; --brandGlow:rgba(251,101,20,.45);
  /* market — KR convention: red up, blue down */
  --up:#F6465D; --upGlow:rgba(246,70,93,.5);
  --down:#2E7DF6; --downGlow:rgba(46,125,246,.45);
  --mint:#16C784; --mintGlow:rgba(22,199,132,.5);
  --gold:#F5C542; --violet:#9B6BF0;
  /* category */
  --privacy:#3D87F2;--fair:#F0A83C;--bribe:#FB6514;--secret:#9B6BF0;--account:#16C784;--ethics:#E0608C;--export:#2BC4C0;
  --ui:'Pretendard','Apple SD Gothic Neo',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --disp:'Space Grotesk',var(--ui);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--text); font-family:var(--ui); line-height:1.45;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; min-height:100vh;
  background-image:
    radial-gradient(1100px 600px at 50% -8%, rgba(251,101,20,.13), transparent 60%),
    radial-gradient(900px 700px at 90% 110%, rgba(46,125,246,.08), transparent 60%),
    linear-gradient(180deg,#080C13 0%, #05080D 100%);
  background-attachment:fixed;
}
/* faint grid overlay */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.55),transparent 70%);
}
.num{font-family:var(--mono); font-variant-numeric:tabular-nums; letter-spacing:-.01em}
.up{color:var(--up)!important} .down{color:var(--down)!important} .mint{color:var(--mint)!important}
::selection{background:rgba(251,101,20,.32)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:10px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2);background-clip:content-box}

.wrap{max-width:1280px;margin:0 auto;padding:16px 18px 26px;position:relative;z-index:1}

/* ---------- topbar ---------- */
.topbar{height:46px;display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:11.5px;color:var(--sub)}
.brand .mark{display:grid;grid-template-columns:repeat(3,5px);gap:2.5px;align-items:end}
.brand .mark i{width:5px;border-radius:1.5px;background:var(--brand);box-shadow:0 0 10px var(--brandGlow)}
.brand .mark i:nth-child(1){height:8px;opacity:.55}.brand .mark i:nth-child(2){height:14px}.brand .mark i:nth-child(3){height:11px;opacity:.8}
.brand b{color:var(--text);font-weight:900;letter-spacing:.05em}
.tape{display:flex;gap:8px;font-size:11.5px}
.tape .chip{display:flex;align-items:center;gap:7px;border:1px solid var(--line);background:rgba(255,255,255,.025);border-radius:999px;padding:7px 12px;font-weight:700;color:var(--muted);backdrop-filter:blur(8px)}
.tape .chip b{color:var(--text);font-family:var(--mono)}
.cloud-dot{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:999px;padding:7px 11px;background:rgba(255,255,255,.025);font-size:11px;font-weight:800;color:var(--muted);letter-spacing:.06em}
.cloud-dot::before{content:"";width:7px;height:7px;border-radius:50%;background:#5A6B80;transition:.3s}
.cloud-dot.on::before{background:var(--mint);box-shadow:0 0 12px var(--mintGlow);animation:pulseDot 1.8s infinite}
.cloud-dot.off::before{background:var(--gold);box-shadow:0 0 12px rgba(245,197,66,.5)}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.4}}

/* ---------- card shell ---------- */
.card{position:relative;border:1px solid var(--line);border-radius:24px;overflow:hidden;
  background:linear-gradient(180deg,rgba(16,22,32,.92),rgba(9,13,20,.96));
  box-shadow:0 40px 120px -30px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.04);}
.card::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:linear-gradient(125deg,rgba(251,101,20,.06),transparent 30%,rgba(46,125,246,.04) 75%,transparent);}
.card>*{position:relative;z-index:1}
.screen{display:none}.screen.active{display:block;animation:screenIn .42s cubic-bezier(.22,1,.36,1) both}
@keyframes screenIn{from{opacity:0;transform:translateY(10px) scale(.994)}to{opacity:1;transform:none}}

/* ---------- buttons ---------- */
.btn{position:relative;border:0;border-radius:14px;font-family:var(--ui);font-weight:800;font-size:15px;padding:14px 18px;cursor:pointer;
  background:linear-gradient(180deg,var(--brand2),var(--brand));color:#1a0a02;
  box-shadow:0 10px 26px -8px var(--brandGlow),inset 0 1px 0 rgba(255,255,255,.3);transition:transform .1s,filter .18s,box-shadow .18s;overflow:hidden}
.btn:hover{filter:brightness(1.06);box-shadow:0 14px 34px -8px var(--brandGlow),inset 0 1px 0 rgba(255,255,255,.3)}
.btn:active{transform:translateY(1px) scale(.995)}
.btn .arr{display:inline-block;transition:transform .2s}.btn:hover .arr{transform:translateX(3px)}
.btn.ghost{background:rgba(255,255,255,.04);color:var(--text);border:1px solid var(--line2);box-shadow:none}
.btn.ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.22)}
.btn.blue{background:linear-gradient(180deg,#4A92FF,var(--down));color:#fff;box-shadow:0 10px 26px -8px var(--downGlow),inset 0 1px 0 rgba(255,255,255,.25)}
.btn:disabled{opacity:.5;cursor:not-allowed;filter:none}
.btn.shine::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-18deg);animation:shine 3.4s ease-in-out infinite}
@keyframes shine{0%,72%{left:-60%}88%,100%{left:130%}}

/* ============ LOGIN ============ */
.login-grid{display:grid;grid-template-columns:1.08fr .92fr;min-height:728px}
.login-hero{position:relative;padding:42px 40px;border-right:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column}
.login-hero .heroglow{position:absolute;inset:auto -10% -30% -10%;height:420px;background:radial-gradient(circle at 50% 100%,rgba(251,101,20,.2),transparent 65%);pointer-events:none}
.kicker{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;border:1px solid rgba(251,101,20,.34);background:rgba(251,101,20,.09);color:#FFC79E;border-radius:999px;padding:7px 13px;font-size:11.5px;font-weight:800;letter-spacing:.04em;margin-bottom:22px}
.kicker .live{width:7px;height:7px;border-radius:50%;background:var(--up);box-shadow:0 0 10px var(--upGlow);animation:pulseDot 1.4s infinite}
h1{font-family:var(--ui);font-size:52px;line-height:1.02;letter-spacing:-.05em;margin:0 0 16px;font-weight:900}
h1 .rise{color:var(--up)}h1 .fall{color:var(--down)}
.lead{font-size:16px;color:var(--sub);max-width:520px;margin:0 0 auto;line-height:1.6}
.hero-chart{margin:26px 0;border:1px solid var(--line);border-radius:18px;background:radial-gradient(420px 180px at 30% 0%,rgba(46,125,246,.08),transparent),var(--s0);padding:14px 16px;position:relative;overflow:hidden}
.hero-chart .hc-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.hero-chart .hc-name{font-size:12px;font-weight:800;color:var(--muted);letter-spacing:.04em}
.hero-chart .hc-price{font-family:var(--mono);font-size:22px;font-weight:800}
.hero-chart svg{width:100%;height:120px;display:block}
.mw-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.mw{border:1px solid var(--line);border-radius:14px;padding:13px 14px;background:linear-gradient(180deg,var(--s2),var(--s0))}
.mw .k{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.mw .v{font-family:var(--mono);font-size:27px;font-weight:800;margin-top:3px;letter-spacing:-.02em}
.mw .d{font-size:12px;font-weight:700;margin-top:2px;color:var(--sub)}
.ticker{overflow:hidden;white-space:nowrap;margin-top:20px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px 0}
.ticker .run{display:inline-block;animation:scroll 32s linear infinite;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--muted)}
.ticker .run span{margin-right:30px}.ticker .run em{font-style:normal}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.login-panel{padding:42px;display:flex;align-items:center;justify-content:center;background:linear-gradient(150deg,rgba(255,255,255,.018),transparent)}
.login-box{width:100%;max-width:430px}
.login-box h2{font-size:27px;margin:0 0 8px;letter-spacing:-.03em;font-weight:900}
.login-box .psub{color:var(--muted);font-size:13.5px;margin:0 0 26px}
.field{margin-bottom:15px}
.field label{display:block;color:var(--muted);font-size:12px;font-weight:800;margin-bottom:8px;letter-spacing:.02em}
.field label .hint{color:var(--faint);font-weight:600}
.field .ipt{position:relative}
.field input{width:100%;height:52px;border:1px solid var(--line2);background:var(--s0);color:var(--text);border-radius:14px;padding:0 15px;font-size:16px;font-family:var(--ui);outline:none;transition:.18s}
.field input::placeholder{color:var(--faint)}
.field input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(251,101,20,.15);background:#0B1019}
.fast-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 0 16px}
.fast{border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.015));border-radius:14px;padding:12px 14px;color:var(--sub);font-size:12px;font-weight:700;line-height:1.5}
.fast b{display:block;color:var(--text);font-size:14.5px;margin-bottom:2px;font-weight:800}.fast em{font-style:normal;color:var(--brand2);font-family:var(--mono);font-weight:700}
.err{min-height:20px;color:#FF8080;font-size:13px;font-weight:600;margin:2px 0 12px}
.err.shake{animation:shakeX .4s}
@keyframes shakeX{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.login-actions{display:grid;grid-template-columns:1fr .56fr;gap:10px}
.login-actions .btn{width:100%}

/* ============ GAME ============ */
.trade{display:grid;grid-template-columns:320px 1fr 336px;min-height:728px}
.col{padding:20px}
.col.center{border-left:1px solid var(--line);border-right:1px solid var(--line);background:rgba(0,0,0,.12)}

/* left: stock identity + price */
.stock-id{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.stock-id h2{margin:0;font-size:22px;letter-spacing:-.03em;font-weight:900;display:flex;align-items:center;gap:8px}
.stock-id h2 .tk{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--muted);background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:7px;padding:3px 7px;letter-spacing:0}
.stock-id .sub{display:block;color:var(--muted);font-size:11.5px;font-weight:700;margin-top:5px;letter-spacing:.02em}
.mkt-state{border:1px solid rgba(22,199,132,.32);background:rgba(22,199,132,.1);color:#7DEBC0;border-radius:999px;padding:6px 11px;font-size:11px;font-weight:800;display:inline-flex;align-items:center;gap:6px}
.mkt-state::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--mint);box-shadow:0 0 8px var(--mintGlow);animation:pulseDot 1.6s infinite}
.session-chip{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:11.5px;font-weight:800;border:1px solid var(--line);background:rgba(255,255,255,.03);border-radius:999px;padding:6px 11px;margin-top:10px}
.session-chip .num{color:var(--sub)}

.price-board{position:relative;border:1px solid var(--line2);border-radius:20px;padding:20px;margin-bottom:13px;overflow:hidden;
  background:radial-gradient(300px 160px at 78% 12%,rgba(251,101,20,.16),transparent 60%),linear-gradient(180deg,#0B1320,#070B12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 20px 50px -20px rgba(0,0,0,.6)}
.price-board .plabel{font-size:10.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.price-board .price{font-family:var(--mono);font-size:48px;font-weight:800;letter-spacing:-.04em;line-height:1.04;margin-top:4px;text-shadow:0 0 30px rgba(251,101,20,.12);transition:color .3s}
.price-board .price.up{color:var(--up)}.price-board .price.down{color:var(--down)}
.price-board .change{font-family:var(--mono);font-size:14.5px;font-weight:700;margin-top:9px;display:inline-flex;align-items:center;gap:8px}
.price-board .change .badge{padding:3px 8px;border-radius:7px;font-size:12px;font-weight:700}
.price-board .change.up .badge{background:rgba(246,70,93,.14);color:var(--up)}
.price-board .change.down .badge{background:rgba(46,125,246,.14);color:var(--down)}
/* floating gain/loss chip */
.float-chip{position:absolute;right:18px;top:54px;font-family:var(--mono);font-weight:800;font-size:18px;padding:6px 12px;border-radius:10px;pointer-events:none;opacity:0}
.float-chip.go{animation:floatUp 1.25s cubic-bezier(.22,1,.36,1) forwards}
.float-chip.up{color:var(--up);background:rgba(246,70,93,.14);border:1px solid rgba(246,70,93,.4)}
.float-chip.down{color:var(--down);background:rgba(46,125,246,.14);border:1px solid rgba(46,125,246,.4)}
@keyframes floatUp{0%{opacity:0;transform:translateY(8px) scale(.9)}18%{opacity:1;transform:translateY(0) scale(1)}70%{opacity:1;transform:translateY(-14px)}100%{opacity:0;transform:translateY(-30px) scale(.96)}}

.ohlc{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:13px}
.ohlc .stat{background:linear-gradient(180deg,var(--s2),var(--s0));border:1px solid var(--line);border-radius:13px;padding:11px 12px}
.ohlc .k{color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.ohlc .v{font-family:var(--mono);font-size:17px;font-weight:700;margin-top:5px}

.panel{border:1px solid var(--line);background:var(--s0);border-radius:16px;margin-bottom:13px;overflow:hidden}
.panel>h3{margin:0;padding:12px 14px;border-bottom:1px solid var(--line);font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-weight:800;display:flex;align-items:center;justify-content:space-between}
.panel>h3 .live-tag{color:var(--mint);font-size:9.5px;letter-spacing:.06em;display:flex;align-items:center;gap:5px}
.panel>h3 .live-tag::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--mint);box-shadow:0 0 7px var(--mintGlow);animation:pulseDot 1.5s infinite}
.panel .body{padding:13px 14px}

/* orderbook */
.ob{font-family:var(--mono)}
.ob-row{display:grid;grid-template-columns:1fr 86px 64px;gap:8px;align-items:center;padding:5px 14px;font-size:12px;position:relative}
.ob-row .depth{position:absolute;top:2px;bottom:2px;border-radius:4px;opacity:.13}
.ob-row.ask .depth{right:0;background:var(--up)}.ob-row.bid .depth{left:0;background:var(--down)}
.ob-row .px{font-weight:700;text-align:right;position:relative}
.ob-row.ask .px{color:var(--up)}.ob-row.bid .px{color:var(--down)}
.ob-row .qty{color:var(--muted);text-align:right;font-size:11px;position:relative}
.ob-mid{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:rgba(251,101,20,.08);border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:3px 0}
.ob-mid .lab{font-size:10px;font-weight:800;color:var(--brand2);letter-spacing:.06em;font-family:var(--ui)}
.ob-mid .now{font-family:var(--mono);font-weight:800;font-size:15px}

/* center: chart */
.chartbox{position:relative;border:1px solid var(--line2);border-radius:20px;padding:14px 14px 8px;margin-bottom:16px;overflow:hidden;
  background:radial-gradient(560px 240px at 50% -10%,rgba(46,125,246,.08),transparent 65%),var(--s0);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 24px 60px -24px rgba(0,0,0,.6)}
.chart-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.chart-top .ct-l{font-size:12px;font-weight:800;color:var(--muted);display:flex;align-items:center;gap:9px}
.chart-top .ct-l b{color:var(--text)}
.chart-top .seg{display:flex;gap:2px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:9px;padding:2px}
.chart-top .seg span{font-size:10.5px;font-weight:800;color:var(--muted);padding:4px 9px;border-radius:6px}
.chart-top .seg span.on{background:rgba(251,101,20,.16);color:var(--brand2)}
.chart-top .ct-r{font-family:var(--mono);font-size:11.5px;font-weight:600;color:var(--muted)}
svg.chart{width:100%;height:312px;display:block}
.gridline{stroke:rgba(255,255,255,.05);stroke-width:1}
.gridline.dash{stroke-dasharray:2 5}
.axislabel{fill:var(--faint);font-size:9px;font-family:var(--mono)}
.dividerline{stroke:rgba(255,255,255,.1);stroke-width:1}
.areafill{opacity:.5}
.candle .wick{stroke-width:1.6;vector-effect:non-scaling-stroke}
.candle .body{stroke-width:1;vector-effect:non-scaling-stroke;rx:1}
.candle.up .wick,.candle.up .body{stroke:var(--up);fill:var(--up)}
.candle.down .wick,.candle.down .body{stroke:var(--down);fill:var(--down)}
.candle.crash .wick{stroke-width:2.6;filter:drop-shadow(0 0 5px var(--upGlow))}
.candle.crash .body{filter:drop-shadow(0 0 6px var(--upGlow))}
.candle.fresh{animation:candleIn .5s cubic-bezier(.22,1,.36,1) both;transform-origin:bottom}
@keyframes candleIn{from{opacity:0;transform:scaleY(.2)}to{opacity:1;transform:scaleY(1)}}
.volbar{opacity:.4}.volbar.up{fill:var(--up)}.volbar.down{fill:var(--down)}
.last-line{stroke:var(--brand);stroke-dasharray:4 4;stroke-width:1;vector-effect:non-scaling-stroke;opacity:.7}
.last-tag{fill:rgba(251,101,20,.18);stroke:var(--brand);stroke-width:1;vector-effect:non-scaling-stroke}
.last-text{fill:#fff;font-size:10px;font-weight:800;font-family:var(--mono)}
.last-dot{fill:var(--brand);filter:drop-shadow(0 0 6px var(--brandGlow))}
.empty-chart{fill:var(--faint);font-size:13px;font-weight:700;font-family:var(--ui)}
.crashmark{font-size:15px}

/* question */
.q-head{display:flex;justify-content:space-between;align-items:center;margin:14px 0 12px}
.q-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.cat-tag{border-radius:999px;padding:6px 12px;font-size:12px;font-weight:800;color:#0a0e14}
.diff-tag{border:1px solid var(--line2);color:var(--sub);border-radius:999px;padding:5px 11px;font-size:11.5px;font-weight:800;background:rgba(255,255,255,.03)}
.q-progress{font-size:12px;font-weight:800;color:var(--muted);font-family:var(--mono)}
.q-progress b{color:var(--text)}
.qbox{position:relative;border:1px solid var(--line2);border-radius:18px;padding:22px 22px;margin-bottom:14px;
  background:linear-gradient(180deg,#141D29,#0F1722);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.qbox::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:3px;border-radius:3px;background:linear-gradient(var(--brand),var(--brand2))}
.qbox h3{font-size:21px;line-height:1.42;margin:0;letter-spacing:-.02em;font-weight:700;padding-left:14px;text-wrap:pretty}
.qbox.pop{animation:qpop .42s cubic-bezier(.22,1,.36,1) both}
@keyframes qpop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.choices{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.choice{position:relative;text-align:left;display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line2);background:linear-gradient(180deg,var(--s2),var(--s0));color:var(--text);border-radius:15px;padding:16px;min-height:92px;font-size:14.5px;line-height:1.5;cursor:pointer;transition:transform .12s,border-color .15s,background .15s;animation:choiceIn .4s both;font-weight:500}
@keyframes choiceIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.choice:hover{border-color:var(--brand);transform:translateY(-2px);background:linear-gradient(180deg,#1A2535,var(--s1))}
.choice b{flex:none;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:8px;background:rgba(255,255,255,.07);border:1px solid var(--line);color:#fff;font-family:var(--mono);font-weight:700;font-size:13px}
.choice span{padding-top:2px}
.choice.correct{border-color:var(--mint);background:rgba(22,199,132,.1);box-shadow:0 0 0 1px var(--mint),0 12px 30px -12px var(--mintGlow)}
.choice.correct b{background:var(--mint);color:#062416;border-color:transparent}
.choice.wrong{border-color:var(--up);background:rgba(246,70,93,.1);box-shadow:0 0 0 1px var(--up)}
.choice.wrong b{background:var(--up);color:#2a0810;border-color:transparent}
.choice.dim{opacity:.45}
.choice:disabled{cursor:default}

/* feedback */
.feedback{display:none;margin-top:14px;border-radius:16px;border:1px solid var(--line2);background:var(--s0);overflow:hidden}
.feedback.show{display:block;animation:qpop .34s cubic-bezier(.22,1,.36,1) both}
.feedback .fb-bar{height:4px}
.feedback.good .fb-bar{background:linear-gradient(90deg,var(--mint),#0FE39A)}
.feedback.bad .fb-bar{background:linear-gradient(90deg,var(--up),#FF7A8C)}
.feedback .fb-in{padding:16px 18px}
.feedback .result{font-weight:900;font-size:17px;margin-bottom:8px;display:flex;align-items:center;gap:9px;letter-spacing:-.01em}
.feedback .result .ic{font-size:18px}
.feedback p{margin:0;color:var(--sub);font-size:14px;line-height:1.6}
.feedback .ref{margin-top:10px;color:var(--muted);font-size:12px;font-weight:600;display:inline-block;border:1px solid var(--line);background:rgba(255,255,255,.02);border-radius:8px;padding:5px 10px}
.feedback .eventline{margin-top:10px;color:#FFD3B8;background:rgba(251,101,20,.09);border:1px solid rgba(251,101,20,.28);border-radius:10px;padding:9px 12px;font-size:12.5px;font-weight:700}

.nextbar{display:flex;gap:10px;margin-top:15px}
.nextbar .btn{flex:1}.nextbar .btn.primary{flex:1.4}

/* right: dashboards */
.gauge{margin-bottom:14px}.gauge:last-child{margin-bottom:0}
.gauge .grow{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;font-weight:800;margin-bottom:7px}
.gauge .grow .gv{font-family:var(--mono);font-size:15px}
.gauge .track{height:9px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden;position:relative}
.gauge .fill{height:100%;border-radius:999px;transition:width .6s cubic-bezier(.22,1,.36,1);position:relative}
.gauge .fill::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25));border-radius:999px}
.gauge.comp .fill{background:linear-gradient(90deg,#0FA86E,var(--mint))}
.gauge.risk .fill{background:linear-gradient(90deg,#C9344A,var(--up))}
.gauge.acc .fill{background:linear-gradient(90deg,var(--brand),var(--brand2))}

.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:11px}
.mm{border:1px solid var(--line);background:linear-gradient(180deg,var(--s2),var(--s0));border-radius:13px;padding:11px 12px;text-align:center}
.mm .k{color:var(--muted);font-size:9.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.mm .v{font-family:var(--mono);font-size:26px;font-weight:800;margin-top:3px}
.mm.combo .v{color:var(--brand2)}.mm.shield .v{color:var(--mint)}
.mission-txt{border:1px solid rgba(251,101,20,.24);background:rgba(251,101,20,.07);border-radius:12px;padding:10px 12px;color:#FFD3B8;font-size:12px;font-weight:700;line-height:1.5}
.badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;min-height:26px}
.badge-pill{border:1px solid var(--line2);background:rgba(255,255,255,.05);border-radius:999px;padding:5px 10px;font-size:11px;font-weight:800;color:var(--sub)}
.badge-pill.hot{border-color:rgba(251,101,20,.5);background:rgba(251,101,20,.12);color:#FFD3B8;animation:badgePop .5s both}
@keyframes badgePop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.save-line{margin-top:11px;border:1px solid rgba(22,199,132,.24);background:rgba(22,199,132,.06);border-radius:11px;padding:8px 11px;color:#9FEFCF;font-size:11px;font-weight:800;display:flex;align-items:center;gap:7px}
.save-line .dot{width:7px;height:7px;border-radius:50%;background:var(--muted)}
.save-line .dot.ok{background:var(--mint);box-shadow:0 0 8px var(--mintGlow)}
.save-line .dot.err{background:var(--up)}

.news{list-style:none;margin:0;padding:0}
.news li{padding:10px 0;border-bottom:1px solid var(--line);font-size:12.5px;color:var(--sub);line-height:1.5;animation:newsIn .4s both}
@keyframes newsIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}
.news li:last-child{border-bottom:0}
.news .tag{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:6px;margin-right:7px;font-family:var(--ui)}
.news .tag.hot{background:rgba(246,70,93,.16);color:var(--up)}
.news .tag.norm{background:rgba(255,255,255,.06);color:var(--muted)}

.mini-rank{list-style:none;margin:0;padding:0}
.mini-rank li{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
.mini-rank li:last-child{border-bottom:0}
.mini-rank .rk{width:22px;text-align:center;font-family:var(--mono);font-weight:800;color:var(--muted)}
.mini-rank .rk.top{color:var(--brand2)}
.mini-rank .who{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700}
.mini-rank .sc{font-family:var(--mono);font-weight:800;color:var(--brand2)}
.mini-rank .me{color:var(--text)}

/* ============ RESULT ============ */
.result-wrap{padding:40px 34px;max-width:980px;margin:0 auto}
.result-hero{text-align:center;margin:8px 0 26px;position:relative}
.grade-ring{width:150px;height:150px;margin:0 auto 6px;position:relative;display:grid;place-items:center}
.grade-ring svg{position:absolute;inset:0;transform:rotate(-90deg)}
.grade{font-family:var(--disp);font-size:78px;font-weight:700;line-height:1;letter-spacing:-.04em}
.grade-title{font-size:23px;font-weight:900;margin-top:12px;letter-spacing:-.02em}
.grade-sub{color:var(--muted);margin-top:7px;font-size:14px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.6}
.resgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin:22px 0}
.resstat{border:1px solid var(--line);background:linear-gradient(180deg,var(--s2),var(--s0));border-radius:16px;padding:18px 14px;text-align:center}
.resstat .v{font-family:var(--mono);font-size:27px;font-weight:800}
.resstat .k{color:var(--muted);font-size:11.5px;font-weight:800;margin-top:4px;letter-spacing:.02em}
.final-rank{border:1px solid var(--line);background:var(--s0);border-radius:18px;padding:16px 18px;margin-top:20px}
.final-rank h3{margin:0 0 12px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:800}
.ranklist{list-style:none;margin:0;padding:0}
.ranklist li{display:flex;align-items:center;gap:10px;padding:9px 6px;border-bottom:1px solid var(--line);font-size:13.5px;border-radius:8px}
.ranklist li:last-child{border-bottom:0}
.ranklist .rk{width:26px;text-align:center;font-family:var(--mono);font-weight:800;color:var(--muted)}
.ranklist .who{flex:1;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ranklist .who small{color:var(--muted);font-weight:600;font-family:var(--mono)}
.ranklist .sc{font-family:var(--mono);font-weight:800;color:var(--brand2)}
.actions{display:flex;gap:11px;margin-top:20px}.actions .btn{flex:1}

/* ============ RANKING MODAL ============ */
body.rank-open{overflow:hidden}
.rank-modal{position:fixed!important;inset:0!important;z-index:99999!important;display:none!important;align-items:center;justify-content:center;padding:20px}
.rank-modal.open{display:flex!important;animation:modalIn .16s ease both}
@keyframes modalIn{from{opacity:0}to{opacity:1}}
.rank-dim{position:fixed;inset:0;background:rgba(3,6,11,.78);backdrop-filter:blur(12px)}
.rank-panel{position:relative;z-index:1;width:min(1080px,96vw);max-height:88vh;overflow:auto;border:1px solid var(--line2);border-radius:26px;
  background:linear-gradient(180deg,#0F1622,#070B11);box-shadow:0 50px 140px -30px rgba(0,0,0,.85);animation:panelIn .22s cubic-bezier(.22,1,.36,1) both}
@keyframes panelIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.ranking-wrap{padding:30px 32px 34px}
.ranking-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}
.ranking-hero h2{font-size:30px;letter-spacing:-.04em;margin:8px 0 4px;font-weight:900}
.ranking-hero p{margin:0;color:var(--muted);font-size:13px}
.rank-close{flex:none;width:44px;height:44px;border-radius:14px;border:1px solid var(--line2);background:rgba(255,255,255,.05);color:var(--text);font-size:24px;font-weight:300;line-height:1;cursor:pointer;transition:.15s}
.rank-close:hover{border-color:var(--brand);background:rgba(251,101,20,.14)}
/* podium */
.podium{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:11px;align-items:end;margin:18px 0}
.pod{border:1px solid var(--line2);border-radius:18px;padding:16px 14px;text-align:center;background:linear-gradient(180deg,var(--s2),var(--s0));position:relative}
.pod .medal{font-size:26px}
.pod .nm{font-weight:900;font-size:15px;margin-top:6px;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pod .pr{font-family:var(--mono);font-weight:800;font-size:18px;margin-top:3px}
.pod .mt{font-size:11px;color:var(--muted);font-weight:700;margin-top:3px;font-family:var(--mono)}
.pod.p1{background:linear-gradient(180deg,rgba(251,101,20,.16),var(--s0));border-color:rgba(251,101,20,.4);padding-bottom:28px}
.pod.p1 .pr{color:var(--brand2)}
.pod.p2{background:linear-gradient(180deg,rgba(255,255,255,.06),var(--s0))}
.pod.p3{background:linear-gradient(180deg,rgba(205,127,50,.12),var(--s0))}
.pod.empty{opacity:.4}
.ranking-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:16px 0}
.rsum{border:1px solid var(--line);background:linear-gradient(180deg,var(--s2),var(--s0));border-radius:14px;padding:14px}
.rsum .k{color:var(--muted);font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.rsum .v{font-family:var(--mono);font-size:25px;font-weight:800;margin-top:4px}
.rsum.me{border-color:rgba(251,101,20,.42);background:linear-gradient(180deg,rgba(251,101,20,.12),var(--s0))}
.rsum.me .v{color:var(--brand2)}
.ranking-toolbar{display:flex;gap:10px;margin:14px 0}.ranking-toolbar .btn{flex:1}
.rank-table{border:1px solid var(--line);background:var(--s0);border-radius:18px;overflow:hidden}
.rank-thead,.rank-row{display:grid;grid-template-columns:64px 1.3fr .9fr .62fr .62fr .8fr;gap:10px;align-items:center;padding:13px 18px}
.rank-thead{background:rgba(255,255,255,.035);color:var(--muted);font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.rank-row{border-bottom:1px solid var(--line);font-size:14px}.rank-row:last-child{border-bottom:0}
.rank-row .rno{font-family:var(--mono);font-weight:800;color:var(--muted)}
.rank-row .rname{font-weight:800}.rank-row .rname .subtxt{color:var(--faint);font-size:11px;font-weight:600;margin-top:2px}
.rank-row .rprice{font-family:var(--mono);font-weight:800;color:var(--brand2);font-size:15px}
.rank-row .num{font-family:var(--mono)}
.rank-row .subtxt{color:var(--muted);font-size:11.5px;font-family:var(--mono)}
.rank-row.me{background:linear-gradient(90deg,rgba(251,101,20,.14),transparent);box-shadow:inset 3px 0 0 var(--brand)}
.rank-empty{text-align:center;color:var(--muted);padding:32px;font-weight:700}

/* ---------- combo popup (center overlay) ---------- */
.combo-pop{position:fixed;left:50%;top:32%;transform:translate(-50%,-50%);z-index:90000;pointer-events:none;text-align:center;opacity:0}
.combo-pop.go{animation:comboGo 1.1s cubic-bezier(.22,1,.36,1) forwards}
.combo-pop .big{font-family:var(--disp);font-weight:700;font-size:64px;letter-spacing:-.03em;color:var(--brand2);text-shadow:0 0 40px var(--brandGlow)}
.combo-pop .sm{font-weight:800;font-size:15px;color:#FFD3B8;margin-top:2px;letter-spacing:.04em}
@keyframes comboGo{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}22%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}38%{transform:translate(-50%,-50%) scale(1)}78%{opacity:1}100%{opacity:0;transform:translate(-50%,-58%) scale(.96)}}

/* ---------- crash overlay ---------- */
.crash-overlay{position:fixed;inset:0;z-index:95000;display:none;align-items:center;justify-content:center;padding:24px}
.crash-overlay.show{display:flex;animation:modalIn .2s ease both}
.crash-overlay .cdim{position:absolute;inset:0;background:radial-gradient(circle at 50% 45%,rgba(246,70,93,.22),rgba(3,6,11,.84) 60%);backdrop-filter:blur(3px)}
.crash-card{position:relative;z-index:1;width:min(520px,94vw);border:1px solid rgba(246,70,93,.5);border-radius:22px;overflow:hidden;
  background:linear-gradient(180deg,#1A0E14,#0A0709);box-shadow:0 40px 120px -20px rgba(246,70,93,.4),inset 0 1px 0 rgba(255,255,255,.06);animation:crashCardIn .45s cubic-bezier(.22,1,.36,1) both}
@keyframes crashCardIn{from{opacity:0;transform:translateY(20px) scale(.94)}to{opacity:1;transform:none}}
.crash-card .ctop{padding:22px 24px 18px;text-align:center;border-bottom:1px solid rgba(246,70,93,.22)}
.crash-card .cic{font-size:46px;animation:crashShake .5s ease 3}
@keyframes crashShake{0%,100%{transform:rotate(0)}25%{transform:rotate(-9deg)}75%{transform:rotate(9deg)}}
.crash-card .ctitle{font-size:26px;font-weight:900;color:var(--up);margin-top:6px;letter-spacing:-.02em}
.crash-card .cdrop{font-family:var(--mono);font-size:34px;font-weight:800;color:var(--up);margin-top:4px;letter-spacing:-.03em}
.crash-card .cbody{padding:20px 24px 22px}
.crash-card .cinc{font-size:14px;color:var(--sub);line-height:1.65;text-wrap:pretty}
.crash-card .cmeta{display:flex;gap:9px;margin-top:16px}
.crash-card .cmeta .m{flex:1;border:1px solid var(--line);background:rgba(255,255,255,.03);border-radius:12px;padding:10px;text-align:center}
.crash-card .cmeta .mk{font-size:10px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.crash-card .cmeta .mv{font-family:var(--mono);font-size:18px;font-weight:800;margin-top:3px}
.crash-card .cbtn{margin-top:18px}
.crash-card .cbtn .btn{width:100%}

/* screen flashes / shake */
.flash{position:absolute;inset:0;pointer-events:none;opacity:0;z-index:5;border-radius:24px}
.flash.red{background:radial-gradient(circle,rgba(246,70,93,.26),transparent 70%)}
.flash.mint{background:radial-gradient(circle,rgba(22,199,132,.2),transparent 70%)}
.flash.go{animation:flashGo .7s ease}
@keyframes flashGo{0%{opacity:0}28%{opacity:1}100%{opacity:0}}
.card.shake{animation:cardShake .52s ease}
@keyframes cardShake{0%,100%{transform:translateX(0)}14%{transform:translateX(-9px)}30%{transform:translateX(8px)}46%{transform:translateX(-6px)}62%{transform:translateX(5px)}80%{transform:translateX(-3px)}}

/* ---------- responsive ---------- */
@media(max-width:1040px){
  .login-grid,.trade{grid-template-columns:1fr}
  .login-hero{border-right:0;border-bottom:1px solid var(--line)}
  .col.center{border-left:0;border-right:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .mw-grid,.resgrid,.ranking-summary{grid-template-columns:1fr 1fr}
  .tape{display:none}
  h1{font-size:42px}
}
@media(max-width:560px){
  .wrap{padding:10px}
  .login-hero,.login-panel,.col,.result-wrap,.ranking-wrap{padding:18px}
  .choices{grid-template-columns:1fr}
  .resgrid,.ranking-summary,.podium{grid-template-columns:1fr}
  .rank-thead{display:none}
  .rank-row{grid-template-columns:44px 1fr auto;gap:8px}
  .rank-row .num:nth-child(n+4),.rank-row .subtxt:last-child{display:none}
  .price-board .price{font-size:40px}.qbox h3{font-size:18px}
  h1{font-size:34px}.login-actions{grid-template-columns:1fr}
  .combo-pop .big{font-size:48px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important}
}

/* v7 추가: 메인 주식창 캔들 보강 + 상한가 잠금 */
.hero-grid line{stroke:rgba(255,255,255,.08);stroke-width:.8;stroke-dasharray:3 4}
.choice.locked{border-color:rgba(246,70,93,.45);background:rgba(246,70,93,.08);cursor:not-allowed}
.q-progress span{color:var(--muted);font-weight:800;margin-left:4px}
