:root{--bg: #15131c;--panel: #1f1c2c;--panel-2: #29253b;--p1: #5a8dee;--p2: #d65a5a;--gold: #e6c460;--text: #efe6d6;--muted: #837e93;--border: #3a334a;--military: #b04a3a;--political: #b08a3a;--scientific: #3a8db0;--cultural: #a64aa3;--religious: #c8b46a;--token: #5a5a5a;--mythological: #6e3aa6;--wood-frame: #1c120a;--wood-board: #3f2c1a;--wood-board-2: #33220f;--wood-beam: #271708;--wood-beam-edge: #5a3c20;--wood-slot: #2a1c0f}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;flex:1;padding:16px;gap:16px;max-width:1200px;margin:0 auto;width:100%}@media (max-width: 720px){.app{padding:8px;gap:8px}}.app-header{display:flex;justify-content:space-between;align-items:center}.app-header h1{margin:0;font-size:22px;letter-spacing:1px}@media (max-width: 720px){.app-header{flex-direction:column;align-items:flex-start;gap:4px}.app-header h1{font-size:16px}.app-header>div:last-child{font-size:11px}}.app-header .turn{color:var(--gold);font-weight:700}.app-header--game{padding-left:52px}.board{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:10px;flex:1 1 auto;min-height:0;padding:12px;border-radius:16px;background-color:var(--wood-frame);background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.22) 0 1px,transparent 1px 9px),linear-gradient(180deg,#251710,#160d06);border:1px solid #0d0805;box-shadow:inset 0 1px #78502840,0 10px 30px #00000073}.location{display:flex;flex-direction:column;min-height:0;min-width:0;padding:7px;border-radius:10px;background-color:var(--wood-board);background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.12) 0 1px,transparent 1px 6px),repeating-linear-gradient(90deg,rgba(255,220,170,.04) 0 1px,transparent 1px 13px),linear-gradient(180deg,var(--wood-board),var(--wood-board-2));border:1px solid #110a04;box-shadow:inset 0 1px #b482502e,inset 0 0 22px #00000059}.score-p1{color:var(--p1)}.score-p2{color:var(--p2)}.score-leader{font-weight:700;text-decoration:underline}.slots-side{display:flex;flex-direction:column;gap:4px;flex:1 1 0;min-height:0;min-width:0}.slot{flex:1 1 0;min-height:30px;min-width:0;border-radius:6px;border:1px solid rgba(0,0,0,.45);background:var(--wood-slot);box-shadow:inset 0 2px 5px #0000008c,inset 0 -1px #96643726;display:flex;align-items:center;justify-content:center;position:relative;font-size:11px;color:#c8a36a73}.slot.legal{cursor:pointer;border-color:var(--gold);box-shadow:inset 0 0 12px #e6c46059,0 0 8px #e6c46066}.slot.current-turn{box-shadow:inset 0 2px 5px #00000080,inset 0 0 0 1px #e6c4604d}.location-beam{position:relative;display:flex;align-items:center;justify-content:space-between;gap:6px;padding:0 10px;height:22px;margin:5px 0;border-radius:4px;background-color:var(--wood-beam);background-image:repeating-linear-gradient(0deg,rgba(0,0,0,.25) 0 1px,transparent 1px 4px),linear-gradient(180deg,var(--wood-beam-edge),var(--wood-beam) 45%,#160c03);box-shadow:inset 0 1px #c8965a80,inset 0 -2px 4px #0009,0 2px 5px #00000080}.location-beam-label{flex:1;min-width:0;text-align:center;font-family:Georgia,Times New Roman,serif;font-size:10px;font-style:italic;font-variant:small-caps;letter-spacing:1.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#e6c98a;text-shadow:0 1px 1px rgba(0,0,0,.85)}.beam-score{flex:0 0 auto;min-width:18px;font-size:14px;font-weight:700;font-variant-numeric:tabular-nums;text-shadow:0 1px 2px rgba(0,0,0,.8)}.beam-score.score-p1{text-align:left}.beam-score.score-p2{text-align:right}.tile{width:100%;height:100%;border-radius:8px;display:grid;place-items:center;position:relative;overflow:hidden;color:#f3e9d6;border:1px solid rgba(0,0,0,.55);box-shadow:inset 0 1px #ffebc847,inset 0 -4px 9px #00000073,0 2px 6px #0000008c}.tile:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background-image:repeating-linear-gradient(94deg,rgba(0,0,0,.16) 0 1px,transparent 1px 6px);opacity:.7;pointer-events:none}.tile-name{font-weight:700;font-size:clamp(9px,1.45vw,12px);line-height:1.1;text-align:center;padding:2px 5px;color:#f7efde;text-shadow:0 1px 2px rgba(0,0,0,.85);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tile-power{position:absolute;bottom:3px;right:3px;min-width:17px;height:17px;padding:0 3px;display:grid;place-items:center;border-radius:9px;font-size:11px;font-weight:800;color:#2a1d05;background:linear-gradient(180deg,#f0d27e,var(--gold));border:1px solid rgba(120,90,20,.7);box-shadow:0 1px 2px #0009}.tile.token{opacity:.85;border-style:dotted}.tile.disabled{filter:grayscale(.7)}.tile-disabled-mark{position:absolute;top:2px;left:4px;font-size:12px;color:var(--muted)}.tile{animation:tile-reveal .22s ease-out}@keyframes tile-reveal{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.tile.cat-military{background:linear-gradient(165deg,#6e3326,#3a1812)}.tile.cat-political{background:linear-gradient(165deg,#6f5224,#3c2a0f)}.tile.cat-scientific{background:linear-gradient(165deg,#3c4a52,#1f2a30)}.tile.cat-cultural{background:linear-gradient(165deg,#4f2c52,#2a1530)}.tile.cat-religious{background:linear-gradient(165deg,#6d5c2b,#3f3214)}.tile.cat-mythological{background:linear-gradient(165deg,#382452,#1b1030)}.tile.cat-token{background:linear-gradient(165deg,#4a3c2c,#261d12)}.tile.side-p1{box-shadow:inset 3px 0 0 var(--p1),inset 0 1px #ffe6be38,0 2px 5px #00000080}.tile.side-p2{box-shadow:inset -3px 0 0 var(--p2),inset 0 1px #ffe6be38,0 2px 5px #00000080}@media (max-width: 720px){.board{gap:6px;padding:7px;border-radius:10px}.location{padding:5px;border-radius:8px}.slot{min-height:26px;font-size:9px}.tile-power{min-width:14px;height:14px;font-size:9px;bottom:2px;right:2px}.location-beam{height:20px;margin:5px 0;padding:0 3px;gap:2px}.location-beam-label{font-size:8px;letter-spacing:0;font-variant:normal}.beam-score{font-size:10px;min-width:0}.slots-side{gap:3px}}.hand-area{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px}.hand-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}.hand-tile{width:120px;min-height:60px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);padding:8px 22px 8px 10px;display:flex;flex-direction:column;justify-content:center;cursor:pointer;position:relative;font-size:11px;color:var(--text);flex-shrink:0}@media (max-width: 720px){.hand-area{padding:8px;border-radius:8px}.hand-row{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:6px;margin-top:4px;padding-bottom:4px}.hand-tile{width:104px;min-height:54px}}.hand-tile.selected{outline:2px solid var(--gold);transform:translateY(-4px)}.hand-tile-name{font-weight:700;font-size:12px;line-height:1.15}.hand-tile-power{position:absolute;top:4px;right:6px;color:var(--gold);font-weight:700}.controls{display:flex;justify-content:space-between;align-items:center;gap:12px}@media (max-width: 720px){.controls{flex-direction:column;align-items:stretch}.controls>div{width:100%;justify-content:center}.menu-actions{flex-wrap:wrap}.menu-actions button{flex:1 1 40%}.db-grid{grid-template-columns:1fr;max-height:70vh}.mission-list,.replay-hands{grid-template-columns:1fr}.invite-code{font-size:24px;letter-spacing:8px;padding:12px 16px}}button{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 14px;cursor:pointer;font-size:13px}button:hover{background:var(--border)}button.primary{background:var(--gold);color:#1f1500;border-color:var(--gold);font-weight:700}button:disabled{opacity:.5;cursor:not-allowed}.status-bar{font-size:13px;color:var(--muted)}.endgame{background:var(--panel-2);border:1px solid var(--gold);border-radius:12px;padding:16px;text-align:center;font-size:16px;margin-top:12px}.endgame h2{margin:0 0 8px;color:var(--gold)}.endgame.endgame-won{border-color:#6abf6a}.endgame.endgame-won h2{color:#6abf6a}.endgame.endgame-lost{border-color:#d65a5a}.endgame.endgame-lost h2{color:#d65a5a}.mission-select{display:flex;flex-direction:column;gap:16px;max-width:720px;margin:0 auto;width:100%}.mission-list{display:flex;flex-direction:column;gap:12px}.mission-card{display:flex;align-items:center;gap:14px;width:100%;text-align:left;padding:16px 18px;border:1px solid var(--border);border-left:4px solid var(--muted);border-radius:12px;background:linear-gradient(180deg,var(--panel-2),var(--panel));cursor:pointer;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.mission-card:hover{transform:translateY(-2px);border-color:var(--gold);box-shadow:0 10px 24px #00000059}.mission-card.diff-easy{border-left-color:#6abf6a}.mission-card.diff-medium{border-left-color:var(--gold)}.mission-card.diff-hard{border-left-color:#d65a5a}.mission-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.mission-row{display:flex;align-items:center;gap:10px}.mission-title{font-weight:700;font-size:17px;color:var(--text)}.mission-card .mission-flavor{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mission-diff{flex:0 0 auto;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 12px;border-radius:999px;color:var(--muted);background:#ffffff0d}.mission-card.diff-easy .mission-diff{color:#6abf6a}.mission-card.diff-medium .mission-diff{color:var(--gold)}.mission-card.diff-hard .mission-diff{color:#d65a5a}.mission-flavor{font-style:italic;color:var(--muted);font-size:13px}.mission-done{flex:0 0 auto;font-size:11px;font-weight:700;letter-spacing:.5px;color:#6abf6a}.mission-objective{background:var(--panel);border:1px solid var(--gold);border-radius:8px;padding:8px 12px;font-size:13px}.history{display:flex;flex-direction:column;gap:12px}.history-list{display:flex;flex-direction:column;gap:6px}.history-row{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;display:flex;gap:16px;cursor:pointer;align-items:center}.history-row:hover{border-color:var(--gold)}.history-row.won{border-left:4px solid #6abf6a}.history-row.lost{border-left:4px solid #d65a5a}.history-row.draw{border-left:4px solid var(--muted)}.history-result{font-weight:700;min-width:60px}.history-meta{display:flex;flex-direction:column;gap:2px;font-size:13px}.history-meta .dim{color:var(--muted);font-size:11px}.history-summary{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 14px}.history-events{display:flex;flex-direction:column;gap:12px;max-height:60vh;overflow-y:auto}.history-turn{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-family:monospace;font-size:12px}.history-turn-header{color:var(--gold);margin-bottom:4px}.history-event{color:var(--muted)}.replay-controls{display:flex;gap:8px;align-items:center;justify-content:center;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:8px 12px}.replay-controls .dim{color:var(--muted);min-width:80px;text-align:center}.replay-submissions{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-family:monospace;font-size:12px;display:flex;gap:24px;justify-content:center}.replay-hands{display:grid;grid-template-columns:1fr 1fr;gap:12px}.replay-hand-row{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.replay-hand-tile{width:52px;height:73px}.menu{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:24px;text-align:center}.menu p{color:var(--muted)}.menu-actions{display:flex;justify-content:center;gap:12px;margin:16px 0 8px}.menu-hint{font-size:12px;color:var(--muted)}.join-row{display:flex;justify-content:center;gap:8px;margin-top:8px}.join-input{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:14px;font-family:monospace;letter-spacing:4px;text-align:center;width:120px;text-transform:uppercase}.invite-code{background:var(--panel-2);border:2px solid var(--gold);border-radius:8px;font-family:monospace;font-size:36px;letter-spacing:12px;padding:16px 24px;margin:12px 0;display:inline-block;color:var(--gold)}.auth-handle{color:var(--gold);font-weight:700}.deck-builder{display:flex;flex-direction:column;gap:12px}.db-header{display:flex;justify-content:space-between;align-items:baseline}.db-header h2{margin:0}.db-status{color:var(--gold);font-weight:700}.db-status.db-incomplete{color:var(--muted)}.db-decks{display:flex;gap:8px;flex-wrap:wrap}.db-deck-chip{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:96px;padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);cursor:pointer}.db-deck-chip.active{border-color:var(--gold);box-shadow:inset 0 0 0 1px var(--gold)}.db-deck-chip-name{font-weight:700;font-size:13px;color:var(--text)}.db-deck-chip-count{font-size:11px;color:var(--muted)}.db-deck-new{justify-content:center;align-items:center;color:var(--muted);border-style:dashed}.db-edit-bar{display:flex;align-items:center;gap:10px}.db-name-input{flex:1;min-width:0;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:15px;font-weight:700}.db-name-input:focus{outline:none;border-color:var(--gold)}.db-delete{flex:0 0 auto}.db-filters{display:flex;gap:6px;flex-wrap:wrap}.db-filter{text-transform:capitalize;padding:4px 10px;font-size:12px}.db-filter.active{background:var(--gold);color:#1f1500;border-color:var(--gold)}.db-tray{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--border);border-radius:12px;background:var(--panel)}.db-tray-slots{display:grid;grid-template-columns:repeat(10,1fr);gap:8px;align-items:start}.db-tile-empty{cursor:default}.db-tile-art.db-tile-art-empty{border-style:dashed;border-color:var(--border);background:#ffffff04;box-shadow:none}.db-tile-empty:hover .db-tile-art{transform:none;border-color:var(--border);box-shadow:none}.db-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:10px;max-height:56vh;overflow-y:auto;padding:4px}.db-tile{display:flex;flex-direction:column;gap:6px;padding:0;border:0;background:transparent;cursor:pointer;text-align:center}.db-tile-art{position:relative;aspect-ratio:3 / 4;border-radius:10px;border:1px solid var(--border);background:linear-gradient(160deg,var(--panel-2),var(--panel));display:grid;place-items:center;overflow:hidden;transition:transform .1s ease,border-color .1s ease,box-shadow .1s ease}.db-tile:hover .db-tile-art{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 10px 22px #0006}.db-tile.in-deck .db-tile-art{border-color:var(--gold);box-shadow:inset 0 0 0 2px var(--gold)}.db-tile-initial{font-size:clamp(28px,6vw,44px);font-weight:800;color:#efe6d680}.db-tile-power{position:absolute;top:4px;left:6px;font-weight:800;font-size:14px;color:var(--gold);text-shadow:0 1px 3px rgba(0,0,0,.8)}.db-tile-check{position:absolute;top:4px;right:6px;font-weight:800;color:var(--gold)}.db-tile-remove{position:absolute;top:2px;right:6px;font-size:16px;font-weight:800;color:var(--p2);opacity:0;transition:opacity .1s ease}.db-tile-mini:hover .db-tile-remove{opacity:1}.db-tile-name{font-size:12px;font-weight:600;line-height:1.15;color:var(--text);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.db-tile-mini .db-tile-name{font-size:10px;-webkit-line-clamp:1}.db-tile-art.cat-military{background:linear-gradient(160deg,#3a1714,#1c0f10)}.db-tile-art.cat-political{background:linear-gradient(160deg,#3a2d12,#1c160c)}.db-tile-art.cat-scientific{background:linear-gradient(160deg,#123444,#0d2024)}.db-tile-art.cat-cultural{background:linear-gradient(160deg,#2f1240,#1a0e26)}.db-tile-art.cat-religious{background:linear-gradient(160deg,#3a3212,#1f1c0c)}.db-tile-art.cat-mythological{background:linear-gradient(160deg,#221344,#120c26)}.hover-pop{position:fixed;z-index:80;width:240px;transform:translate(-50%,-100%);padding:10px 12px;border-radius:10px;border:1px solid var(--gold);background:var(--panel);box-shadow:0 14px 34px #0000008c;pointer-events:none}.hover-pop.flip{transform:translate(-50%)}.hover-pop-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.hover-pop-name{font-weight:700;font-size:13px}.hover-pop-power{color:var(--gold);font-weight:700}.hover-pop-text{font-size:12px;line-height:1.4;color:var(--text)}@media (max-width: 720px){.db-tray-slots{grid-template-columns:repeat(5,1fr)}.db-grid{grid-template-columns:repeat(auto-fill,minmax(92px,1fr));max-height:none;overflow:visible}}.db-actions{display:flex;justify-content:flex-end;gap:12px}.menu-screen{position:relative;flex:1;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(20px,4vw,56px);gap:clamp(28px,6vh,64px);background:radial-gradient(1200px 600px at 50% -10%,rgba(230,196,96,.1),transparent 60%),radial-gradient(900px 520px at 50% 120%,rgba(90,141,238,.08),transparent 55%)}.menu-inner{width:min(1040px,100%);display:flex;flex-direction:column;align-items:center;gap:clamp(28px,5vh,52px)}.menu-title{text-align:center}.menu-title h1{margin:0;font-size:clamp(36px,7vw,68px);letter-spacing:clamp(2px,1vw,8px);font-weight:800;color:var(--gold);text-shadow:0 2px 28px rgba(230,196,96,.25)}.menu-tagline{margin:12px 0 0;color:var(--muted);font-size:clamp(14px,2.2vw,18px)}.menu-grid{width:100%;display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2.2vw,24px)}.menu-play{display:none}.menu-card{display:flex;flex-direction:column;align-items:flex-start;gap:8px;text-align:left;padding:clamp(18px,3vw,28px);min-height:clamp(120px,17vh,184px);border-radius:16px;border:1px solid var(--border);background:linear-gradient(180deg,var(--panel-2),var(--panel));font-size:inherit;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.menu-card:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 14px 32px #00000059;background:linear-gradient(180deg,var(--panel-2),var(--panel))}.menu-card-primary{border-color:#e6c46080;background:linear-gradient(180deg,rgba(230,196,96,.14),var(--panel))}.menu-card-primary:hover{background:linear-gradient(180deg,rgba(230,196,96,.2),var(--panel))}.menu-card .menu-icon{width:clamp(28px,4vw,38px);height:clamp(28px,4vw,38px);color:var(--gold)}.menu-card-label{font-size:clamp(18px,2.6vw,25px);font-weight:700;color:var(--text)}.menu-card-sub{font-size:clamp(12px,1.8vw,14px);color:var(--muted)}.menu-stats{margin:0;color:var(--muted);font-size:13px;text-align:center}.menu-welcome{margin:12px 0 0;font-size:clamp(13px,2vw,16px);color:var(--text);opacity:.9}.menu-welcome b{color:var(--gold)}.menu-card-learn{grid-column:1 / -1;flex-direction:row;align-items:center;min-height:0;gap:16px;padding:16px clamp(18px,3vw,26px);border-color:#e6c46066;background:linear-gradient(180deg,rgba(230,196,96,.1),var(--panel))}.menu-card-learn:hover{background:linear-gradient(180deg,rgba(230,196,96,.16),var(--panel))}.menu-card-learn .menu-icon{flex:0 0 auto}.menu-card-learn-text{display:flex;flex-direction:column;gap:4px;align-items:flex-start;text-align:left}.menu-corner{position:fixed;right:clamp(14px,3vw,32px);bottom:clamp(14px,3vh,32px);display:flex;gap:12px;z-index:20}.icon-btn{width:clamp(46px,7vw,56px);height:clamp(46px,7vw,56px);padding:0;border-radius:14px;display:grid;place-items:center;color:var(--text);background:var(--panel-2);border:1px solid var(--border)}.icon-btn:hover{color:var(--gold);border-color:var(--gold);background:var(--panel-2)}.icon-btn .icon-svg{width:56%;height:56%}.game-gear{position:fixed;top:clamp(10px,2vw,20px);left:clamp(10px,2vw,20px);z-index:30}.tabbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:40;align-items:flex-end;justify-content:space-around;gap:8px;padding:8px 16px calc(10px + env(safe-area-inset-bottom));background:linear-gradient(180deg,rgba(31,28,44,.6),var(--panel));border-top:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;border:0;background:transparent;color:var(--muted)}.tab:hover{background:transparent;color:var(--text)}.tab.active{color:var(--gold)}.tab .menu-icon{width:24px;height:24px}.tab-label{font-size:11px;font-weight:600;letter-spacing:.3px}.tab-center{color:var(--text)}.tab-center-disc{display:grid;place-items:center;width:60px;height:60px;margin-top:-28px;border-radius:50%;color:#1f1500;background:var(--gold);border:4px solid var(--bg);box-shadow:0 8px 20px #e6c46066}.tab-center-disc .menu-icon{width:30px;height:30px}@media (max-width: 720px){.menu-grid{display:none}.menu-play{display:flex;flex-direction:column;gap:14px;width:100%}.tabbar{display:flex}.menu-corner{top:clamp(14px,3vw,24px);bottom:auto}.menu-screen{justify-content:flex-start;padding-top:clamp(56px,12vh,110px);padding-bottom:110px}.app--tabbed{padding-bottom:100px}}.overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:16px;background:#08060ea8;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:overlay-fade .14s ease-out}@keyframes overlay-fade{0%{opacity:0}to{opacity:1}}.overlay-panel{width:min(520px,100%);max-height:88vh;overflow-y:auto;padding:clamp(20px,4vw,30px);border-radius:18px;background:var(--panel);border:1px solid var(--border);box-shadow:0 24px 70px #0000008c;animation:overlay-rise .16s ease-out}@keyframes overlay-rise{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.overlay-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.overlay-head h2{margin:0;font-size:22px;color:var(--gold)}.overlay-close{width:36px;height:36px;padding:0;border-radius:10px;display:grid;place-items:center;color:var(--muted);background:transparent;border:1px solid var(--border)}.overlay-close:hover{color:var(--text);border-color:var(--gold);background:transparent}.overlay-close .icon-svg{width:18px;height:18px}.overlay-body{display:flex;flex-direction:column;gap:18px}.overlay-section{display:flex;flex-direction:column;gap:8px}.overlay-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.overlay-note{margin:0;font-size:12px;color:var(--muted)}.overlay-action{width:100%;text-align:center;padding:12px 14px;font-size:15px;border-radius:10px}.overlay-action.primary{background:var(--gold);color:#1f1500;border-color:var(--gold);font-weight:700}.overlay-account{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px}.overlay-account .overlay-action,a.overlay-action{width:auto;text-decoration:none;color:var(--text);display:inline-block}.seg-group{display:flex;gap:8px}.seg-btn{flex:1;padding:10px;font-size:14px}.seg-btn.active{background:var(--gold);color:#1f1500;border-color:var(--gold);font-weight:700}.howto section{margin-bottom:14px}.howto section:last-child{margin-bottom:0}.howto h3{margin:0 0 4px;font-size:15px;color:var(--gold)}.howto p{margin:0;font-size:14px;line-height:1.5;color:var(--text)}:root{--field: #26411d;--field-2: #1a2e13;--lane: #5b4327;--lane-2: #45331c;--front-line: #9a2f2f;--front-line-2: #732020;--card-back: #221c2e;--card-back-2: #161120}.board{position:relative;display:flex;grid-template-columns:none;grid-auto-rows:auto;gap:0;flex:1 1 auto;min-height:0;padding:14px clamp(58px,9vw,88px);border-radius:16px;background-color:var(--field);background-image:repeating-linear-gradient(118deg,rgba(0,0,0,.1) 0 2px,transparent 2px 8px),radial-gradient(130% 90% at 50% -5%,rgba(150,190,110,.1),transparent 60%),linear-gradient(180deg,#2d4823,var(--field-2));border:1px solid #0e1809;box-shadow:inset 0 1px #96c86e2e,0 10px 30px #00000073}.board-field{flex:1 1 auto;min-width:0;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(6px,1.4vw,12px)}.location{display:flex;flex-direction:column;min-height:0;min-width:0;padding:6px 5px;border-radius:10px;background-color:var(--lane);background-image:repeating-linear-gradient(91deg,rgba(0,0,0,.1) 0 1px,transparent 1px 8px),repeating-linear-gradient(0deg,rgba(0,0,0,.1) 0 1px,transparent 1px 11px),linear-gradient(180deg,var(--lane),var(--lane-2));border:1px solid #2a1c0d;box-shadow:inset 0 1px #be96642e,inset 0 0 20px #0006}.location.location-legal{outline:2px solid rgba(230,196,96,.5);outline-offset:-2px;box-shadow:inset 0 0 20px #0006,0 0 16px #e6c46038}.slots-side{display:flex;flex-direction:column;gap:clamp(3px,.8vw,6px);flex:1 1 0;min-height:0;min-width:0;align-items:center}.slot{flex:1 1 0;min-height:22px;width:100%;border:0;background:transparent;box-shadow:none;display:grid;place-items:center;position:relative;padding:0}.slot-mark{height:100%;width:auto;aspect-ratio:5 / 7;max-width:100%;display:grid;place-items:center;border-radius:6px;border:1px dashed rgba(0,0,0,.35);background:#00000024;color:#f5ebd74d;font-size:10px;font-weight:700}.slot.legal{cursor:pointer}.slot.legal .slot-mark{border:1px solid var(--gold);color:var(--gold);background:#e6c46024;box-shadow:0 0 12px #e6c46080,inset 0 0 10px #e6c46040}.slot.current-turn .slot-mark{border-color:#e6c46059}.location-beam{position:relative;display:flex;align-items:center;justify-content:space-between;gap:6px;padding:0 6px;height:clamp(20px,3.2vh,26px);margin:clamp(4px,1vh,8px) 0;border-radius:5px;background-color:var(--front-line);background-image:linear-gradient(180deg,#b03a3a,var(--front-line) 55%,var(--front-line-2));border-top:1px solid rgba(255,190,190,.35);border-bottom:1px solid rgba(0,0,0,.45);box-shadow:inset 0 1px #ffc8c840,inset 0 -2px 5px #00000073,0 2px 6px #00000073}.location-beam-label{flex:1;min-width:0;text-align:center;font-family:Georgia,Times New Roman,serif;font-size:clamp(8px,1.3vw,11px);font-style:italic;font-variant:small-caps;letter-spacing:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#ffe7e0;text-shadow:0 1px 2px rgba(0,0,0,.7)}.location-beam .beam-score{flex:0 0 auto;min-width:20px;padding:1px 6px;border-radius:6px;font-size:clamp(11px,1.6vw,14px);font-weight:800;font-variant-numeric:tabular-nums;text-align:center;background:#00000047;text-shadow:0 1px 2px rgba(0,0,0,.8)}.location-beam .score-p1{color:#c4d6ff}.location-beam .score-p2{color:#ffd0d0}.location-beam .score-leader{box-shadow:inset 0 0 0 1px var(--gold);text-decoration:none}.tile{height:100%;width:auto;aspect-ratio:5 / 7;max-width:100%;margin:0 auto;border-radius:8px;display:flex;flex-direction:column;place-items:stretch;position:relative;overflow:hidden;color:#f3e9d6;border:1px solid rgba(0,0,0,.55);box-shadow:inset 0 1px #ffebc84d,inset 0 -4px 9px #0006,0 2px 6px #0000008c;animation:tile-reveal .22s ease-out}.tile:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background-image:linear-gradient(160deg,rgba(255,255,255,.14),transparent 45%);opacity:.8;pointer-events:none}.tile .tile-name{flex:0 0 auto;margin:0;padding:3px 4px;font-weight:700;font-size:clamp(7px,1.15vw,11px);line-height:1.05;text-align:center;color:#fbf3e2;text-shadow:0 1px 2px rgba(0,0,0,.9);background:#0000004d;border-bottom:1px solid rgba(0,0,0,.3);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.tile .tile-power{position:absolute;bottom:3px;right:3px;min-width:16px;height:16px;padding:0 3px}.tile.side-p1{box-shadow:inset 0 3px 0 var(--p1),inset 0 1px #ffe6be38,0 2px 6px #00000080}.tile.side-p2{box-shadow:inset 0 3px 0 var(--p2),inset 0 1px #ffe6be38,0 2px 6px #00000080}.deck-pile{position:absolute;z-index:2;width:clamp(42px,7vw,64px);display:flex;flex-direction:column;align-items:center;gap:4px}.deck-pile-p2{top:12px;left:9px}.deck-pile-p1{bottom:12px;right:9px}.deck-pile-stack{position:relative;width:100%;aspect-ratio:5 / 7}.deck-pile-stack[data-empty=true]{opacity:.3}.deck-card{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:6px;background-color:var(--card-back);background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.04) 0 3px,transparent 3px 6px),linear-gradient(160deg,var(--card-back),var(--card-back-2));border:1px solid rgba(0,0,0,.6);box-shadow:0 2px 5px #00000080}.deck-card:nth-child(1){transform:translate(3px,3px);opacity:.55}.deck-card:nth-child(2){transform:translate(1.5px,1.5px);opacity:.8}.deck-card-face{display:grid;place-items:center}.deck-card-mark{font-size:clamp(14px,2.4vw,22px);color:#e6c4608c;text-shadow:0 1px 2px rgba(0,0,0,.7)}.deck-pile-p1 .deck-card{border-color:#5a8dee8c}.deck-pile-p2 .deck-card{border-color:#d65a5a8c}.deck-pile-count{font-size:clamp(11px,1.6vw,13px);font-weight:800;color:var(--text);background:#0006;border-radius:999px;padding:1px 9px;text-shadow:0 1px 2px rgba(0,0,0,.7)}.opp-hand{display:flex;align-items:center;justify-content:center;gap:12px;min-height:24px;margin:-2px 0 -12px;overflow:hidden}.opp-hand-fan{display:flex;padding-left:14px}.opp-hand-card{width:clamp(24px,4.5vw,34px);height:clamp(34px,6.5vw,48px);margin-left:-14px;border-radius:5px;transform:translateY(-42%);background-color:var(--card-back);background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.04) 0 3px,transparent 3px 6px),linear-gradient(160deg,var(--card-back),var(--card-back-2));border:1px solid rgba(214,90,90,.5);box-shadow:0 2px 5px #00000073}.opp-hand-count{font-size:12px;color:var(--muted);white-space:nowrap}.hand-area{background:linear-gradient(180deg,rgba(90,141,238,.1),var(--panel));border:1px solid var(--border);border-top:2px solid rgba(90,141,238,.4);border-radius:12px;padding:10px 12px}.hand-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.hand-title{font-weight:700;color:var(--text)}.hand-hint{font-size:12px;color:var(--muted)}.hand-empty{color:var(--muted);align-self:center;padding:20px 0}.hand-row{display:flex;gap:10px;flex-wrap:nowrap;justify-content:center;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:8px;padding-bottom:4px}.hand-tile{width:clamp(64px,11vw,84px);height:clamp(90px,15.4vw,118px);min-height:0;border-radius:10px;border:1px solid rgba(0,0,0,.5);padding:0;display:flex;flex-direction:column;cursor:pointer;position:relative;overflow:hidden;color:#f3e9d6;flex-shrink:0;box-shadow:inset 0 1px #ffebc840,0 3px 8px #0006;transition:transform .12s ease,box-shadow .12s ease}.hand-tile:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(160deg,rgba(255,255,255,.14),transparent 45%);pointer-events:none}.hand-tile:hover{transform:translateY(-3px);box-shadow:0 10px 22px #00000073}.hand-tile.selected{outline:2px solid var(--gold);transform:translateY(-8px);box-shadow:0 12px 26px #00000080,0 0 14px #e6c46066}.hand-tile-name{margin-top:auto;padding:4px 5px;font-weight:700;font-size:clamp(9px,1.4vw,12px);line-height:1.1;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.85);background:#00000052;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.hand-tile-power{position:absolute;top:4px;left:5px;min-width:18px;height:18px;padding:0 4px;display:grid;place-items:center;border-radius:9px;font-size:12px;font-weight:800;color:#2a1d05;background:linear-gradient(180deg,#f0d27e,var(--gold));border:1px solid rgba(120,90,20,.7);box-shadow:0 1px 2px #0009}.hand-tile.cat-military{background:linear-gradient(165deg,#6e3326,#3a1812)}.hand-tile.cat-political{background:linear-gradient(165deg,#6f5224,#3c2a0f)}.hand-tile.cat-scientific{background:linear-gradient(165deg,#3c4a52,#1f2a30)}.hand-tile.cat-cultural{background:linear-gradient(165deg,#4f2c52,#2a1530)}.hand-tile.cat-religious{background:linear-gradient(165deg,#6d5c2b,#3f3214)}.hand-tile.cat-mythological{background:linear-gradient(165deg,#382452,#1b1030)}.hand-tile.cat-token{background:linear-gradient(165deg,#4a3c2c,#261d12)}@media (max-width: 720px){.board{padding:8px clamp(50px,14vw,64px);border-radius:10px}.board-field{gap:5px}.location{padding:5px 4px;border-radius:8px}.deck-pile-p2{top:8px;left:5px}.deck-pile-p1{bottom:8px;right:5px}.tile .tile-power{min-width:14px;height:14px;font-size:9px}.hand-area{padding:8px;border-radius:10px}.hand-row{gap:7px}.opp-hand{margin:0 0 -10px}}.tutorial-banner{width:100%;display:flex;align-items:center;gap:14px;text-align:left;padding:16px clamp(16px,3vw,24px);border-radius:16px;border:1px solid var(--gold);background:linear-gradient(180deg,#e6c4602e,#e6c4600f);color:var(--text);box-shadow:0 10px 28px #00000059;animation:tutorial-pulse 2.4s ease-in-out infinite}@keyframes tutorial-pulse{0%,to{box-shadow:0 10px 28px #00000059}50%{box-shadow:0 10px 28px #00000059,0 0 0 3px #e6c46047}}.tutorial-banner:hover{background:linear-gradient(180deg,#e6c46042,#e6c4601a)}.tutorial-banner-badge{flex:0 0 auto;font-size:11px;font-weight:800;letter-spacing:1px;color:#1f1500;background:var(--gold);padding:5px 9px;border-radius:999px}.tutorial-banner-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.tutorial-banner-title{font-size:clamp(17px,2.4vw,22px);font-weight:800;color:var(--gold)}.tutorial-banner-sub{font-size:clamp(12px,1.8vw,14px);color:var(--muted)}.tutorial-banner-go{flex:0 0 auto;font-size:18px;color:var(--gold)}.coach-mark{align-self:center;width:100%;max-width:520px;display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;border:1px solid var(--gold);background:linear-gradient(180deg,rgba(230,196,96,.16),var(--panel));box-shadow:0 6px 18px #0006;animation:overlay-rise .2s ease-out}.coach-mark-dot{flex:0 0 auto;width:10px;height:10px;border-radius:50%;background:var(--gold);animation:coach-ping 1.4s ease-out infinite}@keyframes coach-ping{0%{box-shadow:0 0 #e6c46099}to{box-shadow:0 0 0 10px #e6c46000}}.coach-mark-text{flex:1;min-width:0;font-size:14px;font-weight:600;color:var(--text)}.coach-mark-skip{flex:0 0 auto;padding:6px 12px;font-size:13px}.coaching .location-legal{animation:lane-pulse 1.3s ease-in-out infinite}@keyframes lane-pulse{0%,to{outline-color:#e6c46080;box-shadow:inset 0 0 20px #0006,0 0 16px #e6c46038}50%{outline-color:#e6c460f2;box-shadow:inset 0 0 20px #0006,0 0 24px #e6c4608c}}.db-guide{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid var(--gold);background:linear-gradient(180deg,rgba(230,196,96,.1),var(--panel))}.db-guide-text{flex:1;min-width:200px;font-size:13px;line-height:1.45;color:var(--text)}.db-guide-actions{display:flex;gap:8px;flex-wrap:wrap}.flight-card{border-radius:10px;box-shadow:0 16px 34px #0000008c}
