:root{--bg-1: #1a0e1f;--bg-2: #2a1018;--bg-3: #3a1c12;--board: #e9c886;--board-edge: #b8945a;--line: #3a2412;--cho: #1f6e3a;--cho-glow: #34b06a;--han: #b03030;--han-glow: #ff5252;--gold: #f6c948;--gold-2: #d4a017;--gold-deep: #8a5e0a;--text: #f6efd9;--text-dim: #c8b89a;--muted: #8b7a5c;--card: #fff8e6;--card-text: #2a1808;--surface: rgba(255, 248, 230, .06);--surface-2: rgba(255, 248, 230, .1);--surface-line: rgba(246, 201, 72, .22);--shadow-card: 0 10px 30px rgba(0, 0, 0, .45), 0 2px 0 rgba(255, 255, 255, .04) inset;--shadow-soft: 0 6px 18px rgba(0, 0, 0, .35);--glow-gold: 0 0 0 1px rgba(246, 201, 72, .35), 0 0 24px rgba(246, 201, 72, .18)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;color:var(--text);font-family:Apple SD Gothic Neo,Noto Sans KR,system-ui,-apple-system,Segoe UI,sans-serif;overscroll-behavior:none;-webkit-font-smoothing:antialiased}body{min-height:100vh;background:radial-gradient(1200px 600px at 20% -10%,rgba(176,48,48,.3),transparent 60%),radial-gradient(900px 500px at 100% 10%,rgba(246,201,72,.18),transparent 55%),radial-gradient(800px 700px at 50% 110%,rgba(31,110,58,.18),transparent 60%),linear-gradient(180deg,var(--bg-1) 0%,var(--bg-2) 50%,var(--bg-3) 100%);background-attachment:fixed;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.app{display:flex;flex-direction:column;min-height:100vh}.hud{display:flex;align-items:center;gap:10px;padding:10px 14px;background:linear-gradient(180deg,#00000073,#0000000d);border-bottom:1px solid var(--surface-line);position:sticky;top:0;z-index:10;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.brand{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text);font-weight:800;font-size:1.05rem;letter-spacing:.3px}.brand .brand-logo{display:block}.brand-name{background:linear-gradient(180deg,#fff7d8,#f6c948 60%,#b78a14);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 1px 0 rgba(0,0,0,.25)}.hud-stats{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px 5px 8px;border-radius:999px;font-weight:800;font-size:.82rem;background:linear-gradient(180deg,#ffffff1a,#ffffff05);border:1px solid var(--surface-line);color:var(--text);box-shadow:0 2px 6px #0006,0 1px #ffffff0f inset;white-space:nowrap}.chip-ico{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;font-size:.7rem;font-weight:900;color:#1a0e1f}.chip-level .chip-ico{background:linear-gradient(180deg,#ffd76b,#d4a017);box-shadow:0 0 8px #f6c94899}.chip-coin .chip-ico{background:linear-gradient(180deg,#f6c948,#8a5e0a)}.chip-gem .chip-ico{background:linear-gradient(180deg,#6ce0ff,#1f6e9a);color:#fff}.nav-back{margin-left:4px;width:34px;height:34px;display:grid;place-items:center;border-radius:12px;text-decoration:none;color:var(--text);font-weight:900;background:var(--surface);border:1px solid var(--surface-line)}.nav-back:active{transform:scale(.96)}main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:14px 14px 96px}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:9;display:grid;grid-template-columns:repeat(5,1fr);padding:6px 8px calc(6px + env(safe-area-inset-bottom));background:linear-gradient(180deg,#140810d9,#0a0408f2);border-top:1px solid var(--surface-line);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 4px;text-decoration:none;color:var(--text-dim);font-size:.72rem;font-weight:700;border-radius:12px;transition:color .15s,transform .15s}.tab-ico{font-size:1.25rem;filter:grayscale(.4) brightness(.85);transition:filter .15s,transform .15s}.tab.active{color:var(--gold)}.tab.active .tab-ico{filter:none;transform:translateY(-2px) scale(1.1);text-shadow:0 0 12px rgba(246,201,72,.6)}.tab.active .tab-label{text-shadow:0 0 8px rgba(246,201,72,.4)}.tab:active{transform:scale(.95)}.home{display:flex;flex-direction:column;gap:18px}.hero{position:relative;border-radius:22px;padding:22px 20px 24px;overflow:hidden;background:radial-gradient(80% 90% at 100% 0%,rgba(246,201,72,.3),transparent 60%),radial-gradient(80% 80% at 0% 100%,rgba(176,48,48,.45),transparent 60%),linear-gradient(135deg,#4a1818,#2a0e10,#1a0a14);border:1px solid rgba(246,201,72,.35);box-shadow:var(--shadow-card),var(--glow-gold)}.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}.hero-glyph{position:absolute;font-family:"Noto Serif KR",serif;font-weight:800;font-size:220px;line-height:1;opacity:.08;user-select:none}.hero-glyph-cho{left:-20px;bottom:-60px;color:#34b06a;transform:rotate(-8deg)}.hero-glyph-han{right:-10px;top:-40px;color:#ff5252;transform:rotate(6deg)}.hero-content{position:relative}.hero-tag{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:1.2px;padding:4px 10px;border-radius:99px;background:#f6c94826;color:var(--gold);border:1px solid rgba(246,201,72,.4);text-transform:uppercase}.hero-title{display:flex;align-items:baseline;gap:10px;margin:10px 0 4px;font-size:clamp(2rem,7vw,2.6rem);font-weight:900;letter-spacing:-.5px;background:linear-gradient(180deg,#fff7d8,#f6c948 55%,#b78a14);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 2px 0 rgba(0,0,0,.25)}.hero-title-sub{font-family:"Noto Serif KR",serif;font-size:.55em;background:none;-webkit-text-fill-color:rgba(246,201,72,.6);letter-spacing:6px}.hero-lead{margin:0 0 18px;color:var(--text-dim);font-size:.95rem}.hero-cta{display:inline-flex;align-items:center;gap:14px;padding:14px 22px;border-radius:16px;text-decoration:none;font-weight:900;background:linear-gradient(180deg,rgba(255,255,255,.18),transparent 60%),linear-gradient(180deg,#ffd76b,#f6c948 50%,#d4a017);color:#2a1808;box-shadow:0 0 0 1px #f6c94899,0 8px 24px #f6c94859,0 2px #fff6 inset,0 -3px #8a5e0a66 inset;transition:transform .12s,filter .12s}.hero-cta:active{transform:translateY(2px) scale(.99);filter:brightness(.95)}.hero-cta-label{font-size:1.6rem;letter-spacing:4px}.hero-cta-sub{font-size:.78rem;font-weight:700;opacity:.7;border-left:1px solid rgba(42,24,8,.3);padding-left:14px}.hero-cta-arrow{margin-left:auto;font-size:.9rem;background:#2a1808d9;color:var(--gold);width:26px;height:26px;border-radius:50%;display:grid;place-items:center}.missions{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media (max-width: 520px){.missions{grid-template-columns:1fr}}.mission{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:16px;background:var(--surface);border:1px solid var(--surface-line);box-shadow:var(--shadow-soft)}.mission-ico{font-size:1.4rem;width:40px;height:40px;display:grid;place-items:center;border-radius:12px;background:linear-gradient(180deg,#f6c94840,#f6c9480d);border:1px solid rgba(246,201,72,.3)}.mission-body{flex:1;min-width:0}.mission-title{font-weight:800;font-size:.92rem}.mission-desc{color:var(--text-dim);font-size:.8rem;margin-top:2px}.mission-bar{margin-top:6px;height:6px;border-radius:99px;background:#0006;overflow:hidden;border:1px solid var(--surface-line)}.mission-bar-fill{height:100%;background:linear-gradient(90deg,var(--cho-glow),var(--gold));box-shadow:0 0 8px #f6c94880}.mission-reward{font-weight:900;color:var(--gold);font-size:.95rem;background:#f6c9481f;border:1px solid rgba(246,201,72,.35);padding:4px 8px;border-radius:8px}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:4px 4px 10px}.section-head h2{font-size:1.1rem;margin:0;font-weight:900;color:var(--text)}.section-sub{color:var(--muted);font-size:.82rem;font-weight:700}.mode-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media (min-width: 720px){.mode-grid{grid-template-columns:repeat(3,1fr)}}.mode-card{position:relative;display:flex;flex-direction:column;border-radius:18px;text-decoration:none;color:var(--text);background:linear-gradient(180deg,#ffffff0f,#ffffff05),linear-gradient(180deg,#2a1822,#1a0e16);border:1px solid var(--surface-line);box-shadow:var(--shadow-card);overflow:hidden;transition:transform .15s,box-shadow .15s}.mode-card:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(120% 80% at 100% 0%,var(--card-glow, rgba(246, 201, 72, .18)),transparent 55%);z-index:1}.mode-card:active{transform:translateY(2px) scale(.99)}.mode-cho{--card-glow: rgba(52, 176, 106, .3);border-color:#34b06a59}.mode-han{--card-glow: rgba(255, 82, 82, .3);border-color:#ff525259}.mode-gold{--card-glow: rgba(246, 201, 72, .32);border-color:#f6c94873}.mode-image{position:relative;width:100%;aspect-ratio:240 / 140;overflow:hidden;border-bottom:1px solid var(--surface-line)}.mode-image svg{display:block;width:100%;height:100%;transition:transform .3s ease}.mode-card:hover .mode-image svg{transform:scale(1.04)}.mode-image:after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(120% 80% at 50% 100%,rgba(26,14,8,.35),transparent 55%),linear-gradient(180deg,rgba(26,14,8,.05) 0%,transparent 30%,rgba(26,14,8,.18) 100%)}.mode-body{position:relative;z-index:1;display:flex;flex-direction:column;gap:8px;padding:12px 14px;flex:1}.mode-text{flex:1}.mode-title{font-weight:900;font-size:1.05rem;letter-spacing:-.2px;color:var(--text)}.mode-desc{color:var(--text-dim);font-size:.82rem;margin-top:2px}.mode-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:8px;border-top:1px dashed var(--surface-line)}.mode-level{color:var(--gold);font-weight:800;font-size:.78rem;letter-spacing:.4px}.mode-go{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:.7rem;background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1808;font-weight:900;box-shadow:0 4px 10px #f6c94866}.mode-badge{position:absolute;top:10px;right:10px;font-size:.66rem;font-weight:900;letter-spacing:1.2px;padding:3px 8px;border-radius:99px;z-index:1}.badge-new{background:linear-gradient(180deg,#34b06a,#1f6e3a);color:#fff8e6;box-shadow:0 0 12px #34b06a80}.badge-hot{background:linear-gradient(180deg,#ff7a4a,#b03030);color:#fff8e6;box-shadow:0 0 12px #ff525280}.badge-live{background:linear-gradient(180deg,#ff5252,#8a1a1a);color:#fff8e6;box-shadow:0 0 14px #ff525299;animation:livePulse 1.4s ease-in-out infinite}@keyframes livePulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.rules-hint{background:var(--surface);border:1px solid var(--surface-line);border-radius:14px;padding:10px 14px}.rules-hint summary{cursor:pointer;font-weight:800;display:flex;align-items:center;gap:8px;color:var(--text);list-style:none}.rules-hint summary::-webkit-details-marker{display:none}.rules-hint .rules-ico{font-size:1.1rem}.rules-hint ul{margin:8px 0 4px;padding-left:18px;color:var(--text-dim);font-size:.88rem;line-height:1.6}.rules-hint b{color:var(--gold)}.play{display:grid;grid-template-columns:minmax(280px,1fr) 320px;gap:16px;align-items:start;-webkit-user-select:none;user-select:none}.play input,.play textarea,.play [contenteditable=true]{-webkit-user-select:text;user-select:text}@media (max-width: 880px){.play{grid-template-columns:1fr}}.play-board{background:radial-gradient(60% 80% at 50% 0%,rgba(246,201,72,.18),transparent 60%),linear-gradient(180deg,#00000040,#0000008c);border:1px solid var(--surface-line);border-radius:20px;padding:14px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-card)}.board-wrap{width:100%;max-width:620px;aspect-ratio:540 / 600;margin:0 auto}.board{width:100%;height:100%;display:block;filter:drop-shadow(0 12px 28px rgba(0,0,0,.5));border-radius:8px;background:transparent}.board.flipped{transform:rotate(180deg)}.board.flipped text{transform-box:fill-box}.cell{cursor:pointer}.cell-static{cursor:default}.cell:hover rect{fill:#ffdc6426}.play-side{background:linear-gradient(180deg,#ffffff0f,#ffffff05),linear-gradient(180deg,#2a1822,#1a0e16);border:1px solid var(--surface-line);border-radius:18px;padding:14px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:12px;color:var(--text)}.info{display:flex;flex-direction:column;gap:8px}.turn{display:flex;align-items:center;gap:10px;font-weight:800}.turn-dot{width:14px;height:14px;border-radius:50%;background:var(--cho);box-shadow:0 0 12px var(--cho-glow)}.turn.han .turn-dot{background:var(--han);box-shadow:0 0 12px var(--han-glow)}.check{background:#ff52522e;color:#ff8a8a;padding:2px 8px;border:1px solid rgba(255,82,82,.4);border-radius:99px;margin-left:6px;font-size:.82rem;font-weight:800;animation:livePulse 1.2s ease-in-out infinite}.thinking{color:var(--gold);font-weight:700}.captured{display:flex;flex-direction:column;gap:4px}.captured .lbl{font-size:.82rem;color:var(--text-dim);margin-right:6px}.captured .lbl.cho{color:var(--cho-glow)}.captured .lbl.han{color:var(--han-glow)}.piece-mini{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--cho);margin-right:4px;font-size:.85rem;background:#fff8e6;color:var(--cho);font-weight:800}.piece-mini.han{border-color:var(--han);color:var(--han)}.score{color:var(--text-dim);font-size:.88rem}.actions{display:flex;flex-wrap:wrap;gap:8px}button{background:linear-gradient(180deg,rgba(255,255,255,.12),transparent 50%),linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1808;border:0;padding:10px 14px;border-radius:12px;font-weight:800;cursor:pointer;font-size:.92rem;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:0 4px 12px #f6c94840,0 1px #fff6 inset,0 -2px #8a5e0a73 inset;transition:transform .1s,filter .1s}button:hover{filter:brightness(1.06)}button:active{transform:translateY(1px) scale(.99)}button:disabled{opacity:.5;cursor:not-allowed;filter:saturate(.4)}button.danger{background:linear-gradient(180deg,rgba(255,255,255,.12),transparent 50%),linear-gradient(180deg,#ff5252,#8a1a1a);color:#fff8e6;box-shadow:0 4px 12px #ff525259,0 1px #ffffff2e inset,0 -2px #500a0a80 inset}button.ghost{background:transparent;color:var(--gold);border:1px solid rgba(246,201,72,.5);box-shadow:none}input,select{font-size:.92rem;padding:9px 10px;border:1px solid var(--surface-line);border-radius:10px;background:#0000004d;color:var(--text)}input::placeholder{color:var(--muted)}select{color:var(--text)}select option{background:#2a1018;color:var(--text)}.ai-config{display:flex;flex-direction:column;gap:8px}.ai-config .row{display:flex;gap:8px;flex-wrap:wrap}.moves{border-top:1px dashed var(--surface-line);padding-top:10px;max-height:320px;overflow:auto}.moves-title{font-weight:800;margin-bottom:6px;color:var(--text-dim)}.moves ol{margin:0;padding-left:16px;font-size:.9rem;color:var(--text)}.moves .num{color:var(--muted);margin-right:6px}.online-lobby{background:linear-gradient(180deg,#ffffff0f,#ffffff05),linear-gradient(180deg,#2a1822,#1a0e16);border:1px solid var(--surface-line);border-radius:20px;padding:22px;box-shadow:var(--shadow-card);max-width:720px;margin:8px auto;color:var(--text)}.lobby-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}@media (max-width: 600px){.lobby-actions{grid-template-columns:1fr}}.lobby-card{background:var(--surface);border:1px solid var(--surface-line);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px}.server-url{display:flex;flex-direction:column;gap:4px;margin-top:8px}.server-url input{width:100%}.room-info{font-size:.92rem;color:var(--text-dim);display:flex;flex-direction:column;gap:4px}.room-info strong{color:var(--gold);font-size:1.15rem;letter-spacing:2px}.reconnect-banner{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:#f6c9481f;border:1px solid rgba(246,201,72,.35);color:var(--gold);font-size:.88rem}.reconnect-spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(246,201,72,.3);border-top-color:var(--gold);animation:queue-spin .9s linear infinite;flex-shrink:0}.chat{border-top:1px dashed var(--surface-line);padding-top:8px;display:flex;flex-direction:column;gap:6px}.chat-log{max-height:100px;overflow:auto;font-size:.88rem}.chat form{display:flex;gap:6px}.chat input{flex:1}.lobby-card h3{margin:0}.lobby-sub{color:var(--text-dim);font-size:.86rem;margin:0}.queue-status{display:flex;align-items:center;gap:16px;margin:18px 0;padding:14px 16px;background:var(--surface);border:1px solid var(--surface-line);border-radius:14px}.queue-spinner{width:34px;height:34px;border-radius:50%;border:3px solid rgba(246,201,72,.25);border-top-color:var(--gold);animation:queue-spin 1s linear infinite;flex-shrink:0}@keyframes queue-spin{to{transform:rotate(360deg)}}.queue-elapsed{font-size:1.6rem;font-weight:900;color:var(--text);font-variant-numeric:tabular-nums}.queue-mode{color:var(--text-dim);font-size:.9rem}.puzzle-head h3{margin:4px 0;color:var(--text)}.puzzle-meta{display:flex;gap:8px;align-items:center}.puzzle-meta .cat{background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1808;padding:3px 10px;border-radius:99px;font-size:.78rem;font-weight:800;box-shadow:0 0 10px #f6c94859}.puzzle-meta .diff{color:var(--gold);font-weight:800}.puzzle-status .ok{color:var(--cho-glow);font-weight:900}.puzzle-status .bad{color:var(--han-glow);font-weight:800}.hint{background:#f6c9481a;border-left:4px solid var(--gold);padding:8px 12px;border-radius:8px;font-size:.9rem;color:var(--text)}.replay{display:flex;flex-direction:column;gap:8px}.replay-controls{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.replay-controls button{padding:7px 11px;font-size:1rem}.replay-step{color:var(--text-dim);font-size:.88rem}.spectator-head select{width:100%;margin:6px 0}.spectator-head p{color:var(--text-dim);font-size:.88rem;margin:6px 0}.shop{display:flex;flex-direction:column;gap:14px}.shop-head h1{margin:0;font-size:1.5rem;color:var(--gold);letter-spacing:.4px}.shop-sub{margin:4px 0 0;color:var(--text-dim);font-size:.9rem}.shop-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.shop-tabs::-webkit-scrollbar{display:none}.shop-tab{flex:0 0 auto;padding:7px 14px;border-radius:999px;border:1px solid rgba(246,201,72,.25);background:#28160e80;color:var(--text-dim);font-weight:700;font-size:.88rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.shop-tab.active{background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1408;border-color:var(--gold)}.shop-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.shop-card{position:relative;display:flex;flex-direction:column;padding:12px;gap:10px;background:linear-gradient(160deg,#3a1d10,#20100a);border:1px solid rgba(246,201,72,.18);border-radius:14px;box-shadow:0 4px 14px #00000073}.shop-card.accent-cho{border-color:#34b06a59}.shop-card.accent-han{border-color:#ff52524d}.shop-card.accent-gold{border-color:#f6c94873}.shop-badge{position:absolute;top:8px;right:8px;padding:2px 8px;border-radius:6px;font-size:.7rem;font-weight:900;letter-spacing:.3px}.badge-new{background:var(--cho);color:#f0ffe6}.badge-hot{background:var(--han);color:#fff0f0}.shop-thumb{height:86px;display:grid;place-items:center;border-radius:10px;background:radial-gradient(circle at 30% 25%,rgba(255,247,216,.2),transparent 60%),linear-gradient(180deg,#f3e2b5,#c9a66b)}.shop-glyph{font-family:"Noto Serif KR",serif;font-weight:900;font-size:2.4rem;color:#4a1a0a;text-shadow:0 1px 0 rgba(255,255,255,.4)}.accent-cho .shop-glyph{color:#0e3f22}.accent-han .shop-glyph{color:#7a1f1f}.accent-gold .shop-glyph{color:#6a4810}.shop-meta{display:flex;flex-direction:column;gap:2px;min-height:60px}.shop-cat{font-size:.7rem;color:var(--text-dim);letter-spacing:.4px;text-transform:uppercase}.shop-name{margin:0;font-size:1rem;color:var(--text)}.shop-desc{margin:0;font-size:.82rem;color:var(--text-dim);line-height:1.35}.shop-buy{margin-top:auto;padding:9px 10px;border:none;border-radius:10px;background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1408;font-weight:900;font-size:.95rem;cursor:pointer;transition:transform .1s,filter .15s}.shop-buy:hover{filter:brightness(1.05)}.shop-buy:active{transform:scale(.97)}.shop-buy.free{background:#34b06a2e;color:var(--cho-glow);border:1px solid rgba(52,176,106,.45);cursor:default}.league{display:flex;flex-direction:column;gap:14px}.league-head h1{margin:0;font-size:1.5rem;color:var(--gold);letter-spacing:.4px}.league-sub{margin:4px 0 0;color:var(--text-dim);font-size:.9rem}.tier-badge{display:inline-block;line-height:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.tier-badge.compact{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.league-banner{display:flex;align-items:center;gap:14px;padding:14px;border-radius:16px;background:linear-gradient(160deg,#3a1d10,#20100a);border:1px solid rgba(246,201,72,.3);box-shadow:0 6px 18px #00000080}.league-banner.accent-sin{border-color:#37809e8c;background:linear-gradient(160deg,#102a3a,#08161e)}.league-banner.accent-wang{border-color:#f6c94880}.league-banner.accent-janggun{border-color:#b4c3cd73;background:linear-gradient(160deg,#2a2e34,#15181c)}.league-banner.accent-byeongsa{border-color:#7a48188c}.league-banner-meta{flex:1;min-width:0}.league-banner-tier{font-size:.95rem;color:var(--text-dim)}.league-banner-tier strong{color:var(--gold);font-size:1.2rem;margin-right:4px}.league-banner-rating{font-size:1.45rem;font-weight:900;color:var(--text);margin-top:2px}.league-progress{margin-top:8px}.league-progress-bar{height:8px;border-radius:999px;background:#ffffff14;overflow:hidden}.league-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--gold-2),var(--gold));box-shadow:0 0 8px #f6c94880}.league-progress-text{margin-top:5px;font-size:.82rem;color:var(--text-dim)}.league-progress-text b{color:var(--gold)}.league-play{display:flex;align-items:center;gap:12px;margin-top:10px;padding:14px 16px;background:linear-gradient(180deg,#f6c9481a,#f6c94805);border:1px solid rgba(246,201,72,.35);border-radius:16px;box-shadow:var(--shadow-soft),var(--glow-gold)}.league-play-meta{flex:1;min-width:0}.league-play-title{color:var(--gold);font-weight:900;font-size:1.05rem;letter-spacing:.3px}.league-play-sub{color:var(--text-dim);font-size:.86rem;margin-top:2px}.league-cta{flex-shrink:0;display:inline-block;padding:12px 18px;border-radius:99px;background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1808;font-weight:900;text-decoration:none;letter-spacing:.4px;box-shadow:0 0 16px #f6c94859}.league-cta:hover{filter:brightness(1.05)}.league-cta.disabled{background:#ffffff14;color:var(--text-dim);box-shadow:none;cursor:not-allowed}@media (max-width: 480px){.league-play{flex-direction:column;align-items:stretch}.league-cta{text-align:center}}.league-summary{display:flex;align-items:center;padding:10px 6px;background:#28160e80;border:1px solid rgba(246,201,72,.18);border-radius:12px}.ls-cell{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0}.ls-num{font-size:1.05rem;font-weight:900;color:var(--text)}.ls-lbl{font-size:.74rem;color:var(--text-dim)}.ls-sep{width:1px;align-self:stretch;background:#f6c9482e;margin:4px 0}.league-tabs{display:flex;gap:6px}.league-tab{flex:1;padding:8px 10px;border-radius:999px;border:1px solid rgba(246,201,72,.25);background:#28160e80;color:var(--text-dim);font-weight:700;font-size:.88rem;cursor:pointer}.league-tab.active{background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1408;border-color:var(--gold)}.league-list{display:flex;flex-direction:column;gap:6px}.league-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:#28160e73;border:1px solid rgba(246,201,72,.15)}.league-row.me-row{margin-top:6px;border-color:var(--gold);background:linear-gradient(90deg,#f6c9482e,#28160e99)}.rank-no{width:56px;font-weight:900;color:var(--text-dim);font-size:.92rem}.rank-no.rank-top{color:var(--gold)}.rank-name{flex:1;min-width:0;color:var(--text);font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-name em{color:var(--gold);font-style:normal;margin-left:4px;font-size:.82rem}.rank-rating{font-weight:800;color:var(--gold);font-size:.92rem;white-space:nowrap}.league-season{display:flex;flex-direction:column;gap:10px}.season-card{padding:14px;border-radius:14px;background:linear-gradient(160deg,#3a1d10,#20100a);border:1px solid rgba(246,201,72,.25)}.season-title{font-size:1.1rem;font-weight:900;color:var(--gold)}.season-desc{margin:6px 0 12px;color:var(--text-dim);font-size:.88rem;line-height:1.45}.season-rewards{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.reward-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:#140a0673;border:1px solid rgba(246,201,72,.18)}.reward-row.accent-sin{border-color:#37809e73}.reward-row.accent-wang{border-color:#f6c94873}.reward-row.accent-janggun{border-color:#b4c3cd66}.reward-row.accent-byeongsa{border-color:#7a481873}.reward-meta{display:flex;flex-direction:column}.reward-meta strong{color:var(--text)}.reward-meta span{font-size:.82rem;color:var(--text-dim)}.league-tiers{display:flex;flex-direction:column;gap:10px}.tier-card{display:flex;gap:14px;align-items:center;padding:14px;border-radius:14px;background:linear-gradient(160deg,#3a1d10,#20100a);border:1px solid rgba(246,201,72,.2)}.tier-card.accent-sin{border-color:#37809e80}.tier-card.accent-wang{border-color:#f6c94880}.tier-card.accent-janggun{border-color:#b4c3cd73}.tier-card.accent-byeongsa{border-color:#7a481880}.tier-meta{display:flex;flex-direction:column;gap:3px}.tier-name strong{font-size:1.1rem;color:var(--text);margin-right:6px}.tier-name span{font-family:"Noto Serif KR",serif;color:var(--text-dim)}.tier-range{color:var(--gold);font-weight:800;font-size:.9rem}.tier-blurb{color:var(--text-dim);font-size:.85rem;line-height:1.45}.auth-button{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;border-radius:999px;border:1px solid rgba(246,201,72,.4);background:#28160e99;color:var(--gold);font-weight:800;font-size:.82rem;cursor:pointer;margin-left:6px;max-width:160px}.auth-name{color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px}.auth-overlay{position:fixed;inset:0;z-index:50;background:#0000008c;display:grid;place-items:center;padding:16px}.auth-modal{width:min(360px,100%);display:flex;flex-direction:column;gap:10px;padding:18px;background:linear-gradient(160deg,#3a1d10,#1a0d05);border:1px solid rgba(246,201,72,.35);border-radius:14px;box-shadow:0 12px 32px #0009}.auth-modal header{display:flex;align-items:center;justify-content:space-between}.auth-modal h2{margin:0;color:var(--gold);font-size:1.1rem}.auth-close{background:none;border:none;color:var(--text-dim);font-size:1.4rem;cursor:pointer}.auth-modal label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:var(--text-dim)}.auth-modal input{padding:10px 12px;border-radius:10px;border:1px solid rgba(246,201,72,.25);background:#00000059;color:var(--text);font-size:.95rem}.auth-error{margin:0;color:#ff8a8a;font-size:.85rem}.auth-submit{padding:10px 12px;border:none;border-radius:10px;background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1408;font-weight:900;cursor:pointer}.auth-submit:disabled{opacity:.6;cursor:progress}.auth-switch{background:none;border:none;color:var(--text-dim);font-size:.82rem;cursor:pointer;text-decoration:underline}.setup-modal{width:min(440px,100%);gap:12px}.setup-modal .setup-side{margin:0;padding:10px 12px 12px;border:1px solid rgba(246,201,72,.18);border-radius:12px;background:#0000002e;display:flex;flex-direction:column;gap:6px}.setup-modal legend{padding:0 6px;color:var(--gold);font-size:.82rem;font-weight:800;letter-spacing:.04em}.setup-option{display:grid;grid-template-columns:18px auto 1fr;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;cursor:pointer;background:#00000040;border:1px solid rgba(246,201,72,.12);color:var(--text)}.setup-option:hover{border-color:#f6c94859}.setup-option.on{border-color:var(--gold);background:#f6c9481f}.setup-option input[type=radio]{margin:0;accent-color:var(--gold)}.setup-preview{display:inline-flex;gap:1px;align-items:center;padding:6px 8px;border-radius:8px;background:linear-gradient(180deg,#e9c886,#b8945a);border:1px solid rgba(0,0,0,.3);box-shadow:inset 0 1px #ffffff40}.setup-piece{display:block;width:18px;height:18px;opacity:.65;filter:drop-shadow(0 1px 0 rgba(0,0,0,.2));transition:transform .15s}.setup-piece.hi{width:30px;height:30px;opacity:1;filter:drop-shadow(0 2px 3px rgba(0,0,0,.45));z-index:1}.setup-option.on .setup-piece.hi,.setup-locked .setup-piece.hi{transform:scale(1.06)}.setup-label{font-size:.88rem;font-weight:800;color:var(--text)}.setup-alt{font-size:.78rem;color:var(--text-dim);font-weight:500}.setup-step{font-size:.82rem;color:var(--text-dim);font-weight:600}.setup-locked{display:flex;flex-direction:column;gap:4px;padding:8px 10px;border-radius:10px;background:#0000004d;border:1px dashed rgba(246,201,72,.2)}.setup-locked-row{display:grid;grid-template-columns:32px auto 1fr;align-items:center;gap:10px;font-size:.85rem}.setup-locked-label{font-weight:900;color:var(--gold);letter-spacing:.04em}.setup-locked-name{color:var(--text);font-weight:700;font-size:.85rem}.setup-modal .exit-modal-actions button:not(.ghost){background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1408}.exit-modal{gap:14px}.exit-modal-body{margin:0;color:var(--text-dim);font-size:.92rem;line-height:1.5}.exit-modal-actions{display:flex;gap:8px;justify-content:flex-end}.exit-modal-actions button{padding:8px 14px;border-radius:10px;cursor:pointer;font-weight:800;font-size:.9rem;border:1px solid transparent}.exit-modal-actions .ghost{background:#0000004d;color:var(--text);border-color:#f6c94840}.exit-modal-actions .danger{background:linear-gradient(180deg,#c0392b,#8e2418);color:#fff}.user-modal{gap:14px}.user-card{display:flex;align-items:center;gap:14px;padding:12px;background:#00000040;border:1px solid rgba(246,201,72,.18);border-radius:12px}.user-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid rgba(246,201,72,.55);background:#00000059;display:inline-flex;align-items:center;justify-content:center}.user-avatar-fallback{font-family:"Noto Serif KR",serif;color:var(--gold);font-weight:900;font-size:1.5rem;line-height:1}.user-meta{display:flex;flex-direction:column;gap:4px;min-width:0}.user-name{color:var(--text);font-weight:800;font-size:1.05rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-tier{display:flex;align-items:center;gap:6px;font-size:.88rem;color:var(--text-dim)}.user-tier strong{color:var(--text)}.user-tier-glyph{font-family:"Noto Serif KR",serif;font-weight:900;font-size:1rem;line-height:1;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(246,201,72,.45)}.user-tier-glyph.tier-sin{background:#bff0ff;color:#0c3a52;border-color:#37809e}.user-tier-glyph.tier-wang{background:#fde490;color:#5a3a06;border-color:#a4760d}.user-tier-glyph.tier-janggun{background:#dbe2e6;color:#2b3640;border-color:#5e7080}.user-tier-glyph.tier-byeongsa{background:#e3b890;color:#3a1d08;border-color:#7a4818}.user-rating{color:var(--gold);font-weight:800}.user-rank{color:var(--text-dim);font-size:.8rem}.user-currency{display:grid;grid-template-columns:1fr 1fr;gap:8px}.user-currency-cell{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 10px;border-radius:10px;background:#00000040;border:1px solid rgba(246,201,72,.18);color:var(--text);font-weight:800}.user-currency-ico{color:var(--gold)}.user-stats{display:flex;flex-direction:column;gap:6px}.user-stats-title{margin:4px 0 0;font-size:.78rem;color:var(--text-dim);font-weight:700;letter-spacing:.04em}.user-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.user-stats-row.cols-3{grid-template-columns:repeat(3,1fr)}.user-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border-radius:10px;background:#00000040;border:1px solid rgba(246,201,72,.15)}.user-stat-num{color:var(--text);font-weight:800;font-size:.95rem}.user-stat-lbl{color:var(--text-dim);font-size:.72rem}.user-stats-week{margin:0;color:var(--text-dim);font-size:.78rem}.user-logout{margin-top:4px;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,138,138,.45);background:#50141459;color:#ff8a8a;font-weight:800;cursor:pointer}.user-logout:hover{background:#781e1e73}.onboard-overlay{position:fixed;inset:0;z-index:80;background:radial-gradient(ellipse at top,#401c0ceb,#0a0604f5);display:grid;place-items:center;padding:20px;backdrop-filter:blur(2px)}.onboard-card{width:min(380px,100%);display:flex;flex-direction:column;gap:18px;padding:26px 22px;background:linear-gradient(160deg,#3a1d10,#1a0d05);border:1px solid rgba(246,201,72,.35);border-radius:18px;box-shadow:0 18px 48px #000000a6}.onboard-brand{display:flex;flex-direction:column;align-items:center;gap:6px}.onboard-brand h1{margin:4px 0 0;color:var(--gold);font-size:1.5rem;letter-spacing:.08em}.onboard-brand p{margin:0;color:var(--text-dim);font-size:.85rem}.onboard-actions{display:flex;flex-direction:column;gap:10px}.onboard-btn{position:relative;padding:12px 14px;border-radius:12px;border:1px solid rgba(246,201,72,.25);font-weight:800;font-size:.95rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.onboard-kakao{background:#fee500;color:#2a1d00;border-color:#c9b300}.onboard-kakao .kakao-glyph{font-size:1.1rem}.onboard-soon{position:absolute;top:-8px;right:10px;background:#1a0d05;color:var(--gold);border:1px solid var(--gold);border-radius:999px;padding:1px 8px;font-size:.7rem;letter-spacing:.04em}.onboard-kakao:disabled{opacity:.6;cursor:progress}.onboard-kakao-note{margin:-4px 0 0;padding:10px 12px;background:#fee50014;border:1px solid rgba(254,229,0,.28);border-radius:10px;color:var(--text);font-size:.88rem;display:flex;gap:10px;align-items:center}.onboard-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid rgba(254,229,0,.45);background:#0000004d;flex-shrink:0}.auth-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:1px solid rgba(246,201,72,.55);background:#00000059;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.auth-avatar-fallback{font-family:"Noto Serif KR",serif;color:var(--gold);font-weight:900;font-size:.95rem;line-height:1}.onboard-nick{background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1408;border-color:transparent}.onboard-foot{margin:4px 2px 0;color:var(--text-dim);font-size:.78rem;text-align:center}.onboard-form{display:flex;flex-direction:column;gap:10px}.onboard-label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--text-dim)}.onboard-label input{padding:11px 12px;border-radius:10px;border:1px solid rgba(246,201,72,.25);background:#00000059;color:var(--text);font-size:1rem}.onboard-status{margin:0;min-height:1.1em;font-size:.82rem}.onboard-status-idle,.onboard-status-checking,.onboard-status-short{color:var(--text-dim)}.onboard-status-ok{color:#7be07b}.onboard-status-taken{color:#ff8a8a}.onboard-submit{background:linear-gradient(180deg,var(--gold),var(--gold-2));color:#2a1408;border-color:transparent}.onboard-submit:disabled{opacity:.55;cursor:not-allowed}.onboard-back{background:none;border:none;color:var(--text-dim);font-size:.85rem;cursor:pointer}.league-online-note{margin:4px 4px 0;color:var(--text-dim);font-size:.78rem;text-align:center;letter-spacing:.01em}.league-online-sep{opacity:.5}.shop-loading{color:var(--text-dim);font-size:.9rem}.shop-err{color:#ff8a8a;font-size:.9rem}.shop-toast{position:fixed;left:50%;transform:translate(-50%);bottom:96px;padding:10px 16px;background:#140a06eb;color:var(--gold);border:1px solid var(--gold);border-radius:999px;z-index:30;font-weight:700;box-shadow:0 6px 18px #0009}@media (max-height: 520px) and (orientation: landscape){.hud{padding:6px 12px}main{padding:8px 8px 80px}.play-side{padding:10px}.moves{max-height:160px}.hero{padding:14px 16px}.hero-title{font-size:1.6rem}.tabbar{padding:4px 6px calc(4px + env(safe-area-inset-bottom))}}.chip-attendance{cursor:pointer;border:none;background:#28180c66;display:inline-flex;align-items:center;gap:6px}.chip-attendance:hover{background:#3c241099}.attendance-pulse{box-shadow:0 0 #f6c94899;animation:attendancePulse 1.6s ease-out infinite}@keyframes attendancePulse{0%{box-shadow:0 0 #f6c94899}70%{box-shadow:0 0 0 8px #f6c94800}to{box-shadow:0 0 #f6c94800}}.attendance-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin:8px 0}.attendance-day{border:1px solid rgba(246,201,72,.25);border-radius:6px;padding:8px 4px;text-align:center;background:#140a0666;font-size:.78rem}.attendance-day.claimed{background:#3c2410b3;border-color:#f6c94880;opacity:.7}.attendance-day.next{border-color:var(--gold);box-shadow:0 0 8px #f6c94866}.attendance-day-label{color:var(--text-dim);font-size:.72rem}.attendance-day-amt{color:var(--gold);font-weight:700;margin-top:2px}.chip-pass{background:linear-gradient(180deg,#f6c94833,#b46e1426);border:1px solid var(--gold);color:var(--gold)}.chip-pass .chip-ico{color:var(--gold)}
