:root{color-scheme:light;--paper: #f4f1e8;--surface: #fffaf0;--surface-2: #e8e5d9;--ink: #1f2724;--muted: #69736d;--line: #c9c5b8;--order: #1d6f8a;--chaos: #a4443b;--spell: #785e9f;--action: #174f3e;--action-2: #c2df7b;--danger: #b9473f;--shadow: 0 10px 24px rgba(31, 39, 36, .12)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--paper);color:var(--ink);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input{font:inherit}button{min-height:40px;border:0;border-radius:6px;background:var(--action);color:#fff;font-weight:800;cursor:pointer;padding:0 16px}button.secondary{background:var(--action-2);color:#1c2b1f}button.danger{background:var(--danger)}button:disabled{cursor:not-allowed;opacity:.45}input{width:100%;border:1px solid var(--line);border-radius:6px;background:#fffdf7;color:var(--ink);padding:10px 12px}.network-shell{width:min(1880px,100%);margin:0 auto;padding:18px}.network-topbar,.backend-form,.session-card,.player-header,.battle-strip,.hand-strip,.side-panel,.phase-banner{border:1px solid var(--line);background:rgba(255,250,240,.86)}.network-topbar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;padding:14px 18px}.network-topbar p,.menu-title p{margin:0 0 4px;color:var(--muted);font-size:13px;font-weight:800;text-transform:uppercase}.network-topbar h1,.menu-title h1{margin:0;font-size:34px;line-height:1}.quiet-link{color:var(--ink);font-weight:800;text-decoration:none}.connection-pill{min-width:92px;border-radius:999px;background:var(--surface-2);color:var(--muted);font-weight:800;padding:9px 14px;text-align:center}.connection-pill.online{background:#d4e9d0;color:#1f5a36}.connection-pill.error{background:#efd0ca;color:#8b2e25}.network-lobby{display:grid;gap:14px;margin-top:14px}.backend-form{display:grid;grid-template-columns:1fr auto;gap:12px;padding:14px}.backend-form label,.lobby-card label{display:grid;gap:6px;color:var(--muted);font-size:13px;font-weight:800}.lobby-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.lobby-card,.session-card{border-radius:8px;padding:16px;box-shadow:var(--shadow)}.lobby-card{display:grid;gap:14px;background:var(--surface)}.lobby-card h2{margin:0;font-size:22px}.session-card{display:flex;align-items:center;justify-content:space-between;gap:16px}.session-card span,.session-card small{display:block;color:var(--muted);font-weight:800}.session-card strong{display:block;font-size:30px}.session-actions{display:flex;flex-wrap:wrap;gap:8px}.lobby-message,.network-notice{min-height:26px;margin:0;color:var(--muted);font-weight:800}.network-message-error{color:var(--danger)}.network-lobby-body{color-scheme:dark;color:#f5e7bf;background:linear-gradient(180deg,rgba(8,9,10,.94),rgba(22,14,10,.98)),repeating-linear-gradient(90deg,rgba(209,170,88,.1) 0 1px,transparent 1px 44px),repeating-linear-gradient(0deg,rgba(108,116,98,.13) 0 2px,transparent 2px 52px),#0a0c0d}.network-lobby-body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:linear-gradient(90deg,transparent 0 9%,rgba(190,156,88,.13) 9% 9.4%,transparent 9.4% 18%),linear-gradient(135deg,transparent 0 48%,rgba(120,43,38,.18) 48% 49%,transparent 49%),linear-gradient(45deg,transparent 0 62%,rgba(27,82,61,.16) 62% 63%,transparent 63%);background-size:420px 420px,520px 520px,560px 560px;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.82),transparent 88%);mask-image:linear-gradient(to bottom,rgba(0,0,0,.82),transparent 88%)}.network-lobby-page{position:relative;z-index:1;width:min(1180px,100%);min-height:calc(100vh - 36px);display:grid;grid-template-rows:auto 1fr;font-family:Georgia,Times New Roman,Songti SC,STSong,serif}.network-lobby-page .arcane-topbar{border-color:#cea64e75;border-radius:8px;background:linear-gradient(180deg,rgba(72,43,25,.88),rgba(30,18,13,.94)),repeating-linear-gradient(90deg,rgba(255,225,150,.08) 0 1px,transparent 1px 18px);color:#f6e4b3;box-shadow:0 16px 46px #00000061,inset 0 1px #ffe5a02e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.network-lobby-page .quiet-link{color:#f0d38a;text-shadow:0 1px 0 rgba(0,0,0,.42)}.network-lobby-page .network-topbar p{color:#eece86c7}.network-lobby-page .network-topbar h1{color:#fff1bf;font-weight:900;text-shadow:0 2px 0 rgba(0,0,0,.42),0 0 18px rgba(205,156,66,.22)}.network-lobby-page .connection-pill{border:1px solid rgba(206,166,78,.44);background:rgba(20,30,26,.84);color:#f6e4b3e0}.network-lobby-page .connection-pill.online{background:rgba(24,73,53,.88);color:#d8f3cb}.network-lobby-page .connection-pill.error{background:rgba(97,31,31,.9);color:#ffd0bd}.network-lobby-page .network-lobby{align-content:center;gap:18px;margin-top:28px}.feishu-auth-panel{display:flex;align-items:center;justify-content:space-between;gap:14px;width:min(980px,100%);justify-self:center;margin-top:18px;border:1px solid rgba(206,166,78,.42);border-radius:8px;background:linear-gradient(180deg,rgba(61,38,24,.9),rgba(28,18,14,.92)),repeating-linear-gradient(90deg,rgba(255,222,145,.06) 0 1px,transparent 1px 20px);color:#f6e4b3;padding:14px 18px;box-shadow:0 16px 44px #00000047}.feishu-auth-panel[hidden]{display:none}.feishu-auth-panel span,.auth-user-pill{color:#f6e4b3bd;font-size:13px;font-weight:900}.feishu-auth-panel strong{display:block;margin-top:3px;color:#fff1bf;font-size:20px}.auth-actions{display:flex;flex-wrap:wrap;gap:10px}.feishu-login-button,.feishu-logout-button,.auth-user-pill{border:1px solid rgba(206,166,78,.44);border-radius:999px}.feishu-login-button,.feishu-logout-button{min-height:38px;background:rgba(29,84,62,.72);color:#fff1bf;font-family:Georgia,Times New Roman,Songti SC,STSong,serif}.feishu-logout-button{background:rgba(90,34,30,.72)}.login-page{width:min(980px,100%)}.login-card{align-content:start;border:1px solid rgba(143,104,46,.34);background:linear-gradient(180deg,rgba(255,249,235,.98),rgba(246,238,221,.96)),repeating-linear-gradient(0deg,rgba(122,93,45,.05) 0 1px,transparent 1px 24px);color:#302418;box-shadow:inset 0 0 0 1px #fffdf4b8,0 18px 44px #0000003d}.login-card h2{color:#3e2a18;font-size:32px;line-height:1.15;font-weight:900}.login-card .room-code-field{color:#6a4724;font-size:14px;font-weight:900}.login-card .room-code-field input{border:1px solid rgba(138,103,52,.3);background:rgba(255,252,244,.96);color:#2b2016;box-shadow:inset 0 2px 8px #62472114}.login-card .room-code-field input::placeholder{color:#49321a7a}.login-rune{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border:1px solid rgba(206,166,78,.54);border-radius:999px;background:rgba(22,30,28,.72);color:#f7df9d;font-size:26px}.login-status{min-height:44px;margin:0;color:#5b4733;font-weight:700;line-height:1.5}.login-status.error{color:#9d3127}.login-actions{display:grid;gap:12px}.login-preview-tip{color:#74593a;line-height:1.5}.mobile-login-hint{margin:18px 0 0;max-width:46ch;color:#f5e7bfd1;line-height:1.6}.mobile-feishu-button{width:100%;min-height:48px}.login-page .primary-magic,.login-page .secondary-magic{min-height:54px;border:1px solid rgba(208,166,80,.62);color:#fff1c9;font-size:17px;font-family:Georgia,Times New Roman,Songti SC,STSong,serif;box-shadow:0 12px 26px #00000038,inset 0 1px #fff2b82e}.login-page .primary-magic{background:linear-gradient(180deg,#8b3429,#521c1d)}.login-page .secondary-magic{background:linear-gradient(180deg,#245c43,#0f342a)}.login-page .primary-magic:hover:not(:disabled),.login-page .secondary-magic:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}.auth-user-pill{display:inline-flex;align-items:center;min-height:38px;padding:0 14px;background:rgba(20,30,26,.76)}.arcane-portal{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,440px);align-items:stretch;gap:28px;width:min(980px,100%);min-height:460px;justify-self:center;overflow:hidden;border:1px solid rgba(207,168,82,.56);border-radius:8px;background:linear-gradient(90deg,rgba(18,37,30,.96),rgba(76,27,25,.88) 56%,rgba(28,25,28,.96)),repeating-linear-gradient(90deg,rgba(235,198,112,.08) 0 1px,transparent 1px 28px),linear-gradient(180deg,rgba(255,239,184,.1),transparent 34%);box-shadow:0 26px 80px #0000006b,inset 0 0 0 1px #ffeab017;padding:34px}.arcane-portal:before,.arcane-portal:after{content:"";position:absolute;pointer-events:none}.arcane-portal:before{top:18px;right:18px;bottom:18px;left:18px;border:1px solid rgba(226,186,94,.24);border-radius:6px;box-shadow:inset 0 0 0 1px #2916108c}.arcane-portal:after{top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,rgba(255,234,174,.12),transparent 24% 76%,rgba(255,234,174,.08)),linear-gradient(135deg,transparent 0 46%,rgba(229,187,91,.12) 46% 47%,transparent 47%),linear-gradient(45deg,transparent 0 59%,rgba(42,94,70,.12) 59% 60%,transparent 60%);opacity:.9}.portal-copy,.room-access-card{position:relative;z-index:1}.portal-copy{display:grid;align-content:center;gap:18px;min-width:0}.portal-copy:before{content:"";width:104px;height:8px;border:1px solid rgba(238,205,126,.76);border-radius:999px;background:linear-gradient(90deg,#6f221f 0 31%,#d9b665 31% 36%,#1d543e 36% 67%,#d9b665 67% 72%,#2c3541 72%);box-shadow:0 8px 18px #00000052}.arcane-kicker{margin:0;color:#efce82d1;font-size:13px;font-weight:900;letter-spacing:0;text-transform:uppercase}.portal-copy h2,.portal-copy h1{max-width:560px;margin:0;color:#fff1bf;font-size:clamp(42px,7vw,78px);line-height:.98;letter-spacing:0;font-weight:900;text-shadow:0 3px 0 rgba(0,0,0,.42),0 0 20px rgba(212,164,72,.24)}.arcane-subtitle{max-width:430px;margin:0;color:#f6e4b3d1;font-size:18px;font-weight:700;line-height:1.6}.network-lobby-page .room-access-card{align-self:center;display:grid;gap:18px;min-height:290px;border:1px solid rgba(168,111,38,.72);background:linear-gradient(180deg,rgba(255,242,202,.97),rgba(225,199,139,.94)),repeating-linear-gradient(0deg,rgba(104,71,31,.07) 0 1px,transparent 1px 26px);color:#2c2112;box-shadow:inset 0 0 0 1px #fffdebb8,0 18px 44px #00000052}.network-lobby-page .room-code-field{color:#6f3b22;font-size:14px;font-weight:900}.network-lobby-page .room-code-field input{min-height:64px;border-color:#764c1f75;background:linear-gradient(180deg,rgba(255,250,232,.94),rgba(237,216,170,.9));color:#2a2115;font-size:24px;font-weight:900;letter-spacing:0;box-shadow:inset 0 2px 8px #58391721}.network-lobby-page .room-code-field input::placeholder{color:#482f1873}.lobby-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.network-lobby-page .primary-magic,.network-lobby-page .secondary-magic{min-height:54px;border:1px solid rgba(230,190,91,.64);color:#fff1bf;font-size:17px;font-family:Georgia,Times New Roman,Songti SC,STSong,serif;box-shadow:0 12px 26px #00000040,inset 0 1px #fff2b833}.network-lobby-page .primary-magic{background:linear-gradient(180deg,#8b3429,#521c1d)}.network-lobby-page .secondary-magic{background:linear-gradient(180deg,#245c43,#0f342a)}.network-lobby-page .primary-magic:hover:not(:disabled),.network-lobby-page .secondary-magic:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}.network-lobby-page .session-card{width:min(980px,100%);justify-self:center;border-color:#cea64e70;background:linear-gradient(180deg,rgba(61,38,24,.9),rgba(28,18,14,.92)),repeating-linear-gradient(90deg,rgba(255,222,145,.06) 0 1px,transparent 1px 20px);color:#f6e4b3}.network-lobby-page .session-card span,.network-lobby-page .session-card small,.network-lobby-page .lobby-message{color:#f6e4b3c2}.network-lobby-page .session-card strong{color:#f0d38a}.network-lobby-page .session-actions button{border:1px solid rgba(206,166,78,.42);background:rgba(29,84,62,.5);color:#fff1bf;font-family:Georgia,Times New Roman,Songti SC,STSong,serif}.network-lobby-page .network-message-error{color:#ffcab7}.network-game{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:14px;margin-top:14px}.game-main,.table-layout{display:grid;gap:12px;min-width:0}.opponent-panel,.self-panel{display:grid;gap:10px;min-width:0}.battle-board{display:grid;gap:0;border:2px solid #b8bcad;background:#d9ddd2}.battle-board .battle-strip{border:0;border-radius:0;background:transparent}.battle-board .battle-strip+.battle-strip{border-top:2px solid #b8bcad}.phase-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:58px;padding:12px 16px;border-left:8px solid var(--action)}.phase-banner strong{font-size:24px}.phase-banner small{color:var(--muted);font-weight:800}.phase-banner.ended{border-left-color:var(--danger)}.player-zone{display:grid;gap:10px;min-width:0}.player-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 14px}.player-title{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.player-title h2{margin:0;font-size:26px}.player-meta{margin-top:4px;color:var(--muted);font-weight:700}.player-actions,.card-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.battle-strip,.hand-strip{min-height:174px;padding:12px}.opponent-panel .hand-strip{min-height:120px}.strip-title{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px;color:var(--muted);font-weight:900}.card-row{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.game-card{position:relative;flex:0 0 214px;min-height:154px;border:1px solid var(--line);border-top:7px solid var(--muted);border-radius:8px;background:#fffdf7;box-shadow:0 6px 14px #1f27241a;padding:12px}.game-card.order-card.character-card{border-top-color:var(--order)}.game-card.chaos-card.character-card{border-top-color:var(--chaos)}.game-card.spell-card{border-top-color:var(--spell)}.game-card.selectable{outline:3px solid #e7cb54;cursor:pointer}.game-card.tapped{filter:saturate(.7)}.card-head{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px}.cost-badge{min-width:42px;height:42px;border-radius:50%;background:#ecd25e;display:grid;place-items:center;font-size:24px;font-weight:900}.card-name{min-width:0;font-size:22px;font-weight:900;white-space:normal;overflow-wrap:anywhere}.card-type{margin:5px 0 0;color:var(--muted);font-size:13px;font-weight:800}.card-text{min-height:54px;margin:10px 0;line-height:1.45}.stats-row,.tag-row{display:flex;flex-wrap:wrap;gap:6px}.stat-chip,.tag-chip{border:1px solid var(--line);border-radius:999px;background:#fffaf0;color:var(--ink);font-weight:900;padding:4px 9px}.tag-chip{background:var(--surface-2);color:var(--muted);font-size:12px}.card-actions{justify-content:flex-start;margin-top:10px;border-top:1px solid var(--line);padding-top:10px}.card-action{min-height:36px;background:var(--action);padding:0 12px}.card-back{display:grid;place-items:center;flex:0 0 120px;min-height:154px;border:2px solid #214e43;border-radius:8px;background:repeating-linear-gradient(135deg,#183d33 0 12px,#245846 12px 24px);color:#f7f1df;font-weight:900}.empty-slot{display:grid;place-items:center;flex:1 0 180px;min-height:132px;border:1px dashed var(--line);color:var(--muted);font-weight:800}.side-panel{display:grid;align-content:start;gap:12px;padding:12px}.side-section{border-bottom:1px solid var(--line);padding-bottom:12px}.side-section:last-child{border-bottom:0}.side-section h2{margin:0 0 8px;font-size:18px}.side-actions{display:grid;gap:8px;margin-top:10px}.focus-track{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.focus-slot{min-height:34px;border:1px solid var(--line);border-radius:5px;display:grid;place-items:center;color:var(--muted);font-weight:900}.focus-slot.active{background:#e7cb54;color:#201f18}.log-list{display:grid;gap:6px;max-height:360px;overflow:auto;padding:0;margin:0;list-style:none}.log-list li{border-radius:5px;background:rgba(255,255,255,.58);padding:7px 8px;color:#39413d;font-size:13px;line-height:1.35}.menu-shell{width:min(960px,calc(100% - 32px));min-height:100vh;margin:0 auto;display:grid;align-content:center;gap:28px}.menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.menu-card{display:grid;gap:12px;min-height:210px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink);text-decoration:none;padding:22px;box-shadow:var(--shadow)}.menu-card.primary{border-top:8px solid var(--action)}.menu-card span,.menu-card small{color:var(--muted);font-weight:800}.menu-card strong{font-size:30px}@media (max-width: 980px){.network-game,.lobby-grid,.menu-grid,.network-topbar,.player-header,.backend-form,.session-card{grid-template-columns:1fr}.arcane-portal{grid-template-columns:1fr;min-height:auto;padding:24px}.portal-copy h2{font-size:44px}.lobby-actions{grid-template-columns:1fr}.session-card{display:grid}.feishu-auth-panel{align-items:stretch;flex-direction:column}.player-actions{justify-content:flex-start}}@media (max-width: 680px){.network-shell{padding:12px}.network-lobby-page{min-height:calc(100vh - 24px)}.arcane-portal{padding:18px;gap:18px}.portal-copy h2,.portal-copy h1{font-size:34px;line-height:1.1}.login-card{padding:14px}.mobile-login-hint{max-width:none;font-size:14px}.feishu-auth-panel,.session-card{padding:12px 14px}}
