:root{color-scheme:light;--bg:#f5f3ec;--ink:#202124;--muted:#67645f;--line:#d9d2c2;--panel:#fffdf7;--accent:#0b6f6a;--accent-strong:#084f4c;--gold:#d89b2b;--red:#b84a45;--blue:#3867a8;--thinker-orange:#e06a1f;--thinker-orange-strong:#a34e15;--shadow:0 20px 60px rgba(45,39,28,0.16)}*{box-sizing:border-box}body,html{min-height:100%}body{margin:0;background:linear-gradient(135deg,rgba(11,111,106,.12),transparent 34%),linear-gradient(315deg,rgba(216,155,43,.14),transparent 35%),var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}a,button{-webkit-tap-highlight-color:transparent}.shell{width:min(1120px,calc(100vw - 32px));margin:0 auto;padding:32px 0 56px}.hero{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);grid-gap:28px;gap:28px;align-items:center;min-height:430px}.hero>*{min-width:0}.catalog-hero{grid-template-columns:1fr;min-height:280px}.game-hero{margin-top:18px}.hero h1{max-width:760px;margin:0;font-size:clamp(2.4rem,6vw,5.4rem);line-height:.95;letter-spacing:0}.hero p{max-width:600px;color:var(--muted);font-size:1.06rem;line-height:1.7}.eyebrow{margin:0 0 14px;color:var(--accent-strong);font-weight:800;text-transform:uppercase;letter-spacing:.08em}.table-scene{position:relative;min-height:330px;border:2px solid rgba(32,33,36,.08);border-radius:8px;background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.72),transparent 42%),linear-gradient(145deg,#0b6f6a,#2f827d 48%,#173f3d);box-shadow:var(--shadow);overflow:hidden}.table-scene:before{content:"";position:absolute;inset:42px 36px;border:2px dashed rgba(255,255,255,.35);border-radius:50%}.table-card,.table-chip{position:absolute;display:grid;place-items:center;border-radius:8px;color:#202124;font-weight:900;box-shadow:0 12px 24px rgba(0,0,0,.2)}.table-card{width:108px;height:146px;background:#fffdf7;border:8px solid #efe3c5}.card-a{left:22%;top:18%;transform:rotate(-12deg)}.card-b{right:18%;top:26%;transform:rotate(10deg)}.card-c{left:40%;bottom:12%;transform:rotate(3deg)}.table-chip{right:18%;bottom:16%;width:74px;height:74px;border-radius:50%;background:var(--gold);color:#2b210d}.mode-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:18px;gap:18px;align-items:stretch}.citadel-scene{background:radial-gradient(circle at 50% 42%,rgba(255,255,255,.55),transparent 40%),linear-gradient(145deg,#314f42,#8b733e 52%,#27382f)}.game-cover-hero{display:grid;place-items:center;width:100%;max-width:100%;min-height:330px;border:2px solid rgba(32,33,36,.08);border-radius:8px;background:#171717;box-shadow:var(--shadow);overflow:hidden}.game-cover-hero img{display:block;width:100%;max-width:100%;height:100%;max-height:420px;object-fit:contain}.game-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:18px;gap:18px}.game-card{display:grid;grid-gap:14px;gap:14px;min-height:360px;background:rgba(255,253,247,.92);border:1px solid var(--line);border-radius:8px;padding:20px;box-shadow:0 14px 36px rgba(45,39,28,.08);color:inherit}.game-card-cover{display:flex;max-width:100%;height:180px;border:1px solid rgba(32,33,36,.08);border-radius:8px;background:#171717;overflow:hidden;justify-content:center}.game-card-cover img{max-width:100%;max-height:100%;object-fit:contain}.game-card p{margin:0;color:var(--muted);line-height:1.55}.card-action{display:inline-flex;gap:8px;align-items:center;align-self:end;color:var(--accent-strong);font-weight:900;text-decoration:none}.card-action-row,.page-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px}.page-toolbar{margin-bottom:18px}.language-switcher{display:inline-flex;align-items:center;gap:4px;width:-moz-fit-content;width:fit-content;padding:4px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.86)}.language-switcher button{min-height:30px;border:0;border-radius:6px;background:transparent;color:var(--muted);padding:4px 9px;font-weight:900;cursor:pointer}.language-switcher button.active{background:var(--accent);color:#fff}.help-trigger{width:auto}.help-backdrop{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:18px;background:rgba(20,20,20,.45)}.help-modal{display:grid;grid-gap:16px;gap:16px;width:min(720px,calc(100vw - 28px));max-height:min(760px,calc(100vh - 28px));overflow:auto;border:1px solid var(--line);border-radius:8px;background:var(--panel);padding:20px;box-shadow:var(--shadow)}.help-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.help-header h2,.help-section h3{margin:0}.help-section{display:grid;grid-gap:8px;gap:8px}.help-section ul{margin:0;padding-left:20px}.help-roster{display:grid;grid-gap:8px;gap:8px;padding-left:0!important;list-style:none}.help-roster li{display:grid;grid-gap:4px;gap:4px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff}.help-roster span{color:var(--muted);line-height:1.45}.panel{background:rgba(255,253,247,.92);border:1px solid var(--line);border-radius:8px;padding:20px;box-shadow:0 14px 36px rgba(45,39,28,.08)}.quiet-panel{background:rgba(255,253,247,.66)}.panel-heading{display:flex;gap:12px;align-items:flex-start;margin-bottom:18px}.panel-heading svg{flex:0 0 auto;color:var(--accent)}.panel h2,.panel h3{margin:0;font-size:1.2rem}.panel p{margin:6px 0 0;line-height:1.55}.field,.panel p{color:var(--muted)}.field{display:grid;grid-gap:7px;gap:7px;margin-bottom:14px;font-size:.92rem;font-weight:700}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:11px 12px}.danger-button,.ghost-button,.icon-button,.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:42px;border-radius:8px;border:1px solid transparent;padding:10px 14px;font-weight:800;text-decoration:none;cursor:pointer}.primary-button{width:100%;background:var(--accent);color:#fff}.secondary-button{width:100%;background:#fff}.ghost-button,.secondary-button{color:var(--accent-strong);border-color:var(--line)}.ghost-button{background:transparent}.danger-button{background:var(--red);color:#fff}.icon-button{min-width:42px;width:42px;padding:0;background:#fff;color:var(--ink);border-color:var(--line)}button:disabled{cursor:not-allowed;opacity:.55}.error-text{color:var(--red);font-weight:800}.room-layout{display:grid;grid-template-columns:320px minmax(0,1fr);grid-gap:18px;gap:18px;align-items:start}.stack{display:grid;grid-gap:14px;gap:14px}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.player-list{display:grid;grid-gap:8px;gap:8px;padding:0;margin:0;list-style:none}.player-row{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:42px;padding:9px 10px;border:1px solid var(--line);border-radius:8px;background:#fff}.player-setup{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:10px;gap:10px}.player-card{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:54px;padding:10px 10px 10px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;font-weight:850}.player-card span{min-width:0;overflow-wrap:anywhere}.add-player-row{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:10px;gap:10px;align-items:end}.add-player-row .field{margin-bottom:0}.add-player-button{width:auto;white-space:nowrap}.status-pill{display:inline-flex;align-items:center;gap:5px;min-height:26px;border-radius:999px;padding:3px 9px;background:rgba(11,111,106,.1);color:var(--accent-strong);font-size:.78rem;font-weight:900}.status-pill.warn{background:rgba(184,74,69,.12);color:var(--red)}.status-pill.thinker-pill{background:rgba(224,106,31,.16);color:var(--thinker-orange-strong)}.field-hint{margin:0;font-size:.82rem;color:var(--muted)}.player-row.thinker-row{border-color:var(--thinker-orange);background:rgba(224,106,31,.1)}.player-row.thinker-row span:first-child{display:inline-flex;align-items:center;gap:6px}.thinker-icon{color:var(--thinker-orange-strong);flex-shrink:0}.thinker-tag{display:inline-flex;align-items:center;border-radius:999px;padding:1px 8px;background:var(--thinker-orange);color:#fff;font-size:.7rem;font-weight:900}.secret-card{display:grid;place-items:center;min-height:260px;border-radius:8px;border:2px solid var(--line);background:linear-gradient(160deg,rgba(216,155,43,.18),transparent 48%),#fffdf7;text-align:center;padding:28px}.secret-card strong{display:block;margin-top:10px;font-size:clamp(2rem,8vw,4.4rem);line-height:1}.nine-upper-card{text-align:left}.nine-upper-card strong{font-size:clamp(1.5rem,4vw,2.8rem);line-height:1.08}.vote-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:10px;gap:10px}.vote-button{min-height:58px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);font-weight:850;cursor:pointer}.result-banner{border-radius:8px;padding:16px;background:#202124;color:#fff}.citadel-shell{width:min(1380px,calc(100vw - 32px))}.citadel-layout{grid-template-columns:300px minmax(0,1fr)}.citadel-private{display:block;min-height:0;padding:18px;border:1px solid var(--line);border-radius:8px;background:linear-gradient(135deg,rgba(216,155,43,.18),transparent 50%),#fff}.citadel-private-main{display:grid;grid-gap:10px;gap:10px}.private-stack{display:grid;grid-gap:12px;gap:12px}.citadel-private strong{display:inline;margin-top:0;font-size:clamp(1.1rem,2.2vw,1.55rem);line-height:1.15}.citadel-resource-row{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:6px;font-weight:900}.citadel-resource-row span{display:inline-flex;align-items:center;gap:6px}.private-character-line{display:grid;grid-template-columns:clamp(58px,12vw,82px) minmax(0,1fr);grid-gap:12px;gap:12px;align-items:start}.private-character-line .character-art{width:100%;max-height:116px;aspect-ratio:2/3}.private-character-summary{display:flex;flex-wrap:wrap;align-items:center;gap:6px 12px;font-weight:900}.private-character-summary span{display:inline-flex;align-items:center;gap:5px}.private-status-divider{color:var(--muted)}.owned-character-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.selected-character-card,.selected-draft-box{display:flex;align-items:center;gap:12px}.selected-character-card{align-items:flex-start}.selected-character-card p{margin:4px 0 0}.selected-draft-box{flex-wrap:wrap;justify-content:space-between;padding:12px;border:1px solid rgba(216,155,43,.55);border-radius:8px;background:rgba(255,249,234,.95)}.action-box,.draft-status-box,.hand-box,.lobby-order-box{border:1px solid var(--line);border-radius:8px;background:#fff;padding:14px}.order-row{padding-right:6px}.order-buttons{display:inline-flex;gap:5px}.order-buttons .icon-button{min-width:32px;width:32px;min-height:32px}.draft-status-box{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;color:var(--muted);font-weight:800}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(142px,168px));grid-gap:10px;gap:10px;justify-content:start}.character-card{display:grid;grid-gap:8px;gap:8px;width:100%;max-width:168px;min-height:270px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:14px;text-align:left;cursor:pointer;overflow:hidden}.image-character-card{grid-template-rows:auto auto auto 1fr auto;padding:10px}.character-card.selected{border-color:#d89b2b;box-shadow:0 0 0 3px rgba(216,155,43,.2)}.character-card.role-noble{border-top:6px solid #d9a327}.character-card.role-religious{border-top:6px solid #2f80c9}.character-card.role-trade{border-top:6px solid #2f8c4c}.character-card.role-military{border-top:6px solid #b84a45}.card-image-button{display:block;width:100%;border:0;padding:0;background:transparent;cursor:zoom-in;touch-action:manipulation}.card-image-button img{display:block;width:100%;height:100%;object-fit:cover;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.card-image-fallback{display:grid;place-items:center;width:100%;height:100%;min-height:inherit;padding:10px;border-radius:inherit;background:linear-gradient(145deg,rgba(108,50,142,.2),transparent 48%),linear-gradient(315deg,rgba(216,155,43,.18),transparent 42%),#f8f2e6;color:rgba(45,39,28,.78);font-size:.78rem;font-weight:800;line-height:1.2;text-align:center;white-space:normal}.character-art,.character-art-fallback{width:100%;aspect-ratio:2/3;height:auto;max-height:190px;border-radius:6px;background:linear-gradient(145deg,rgba(216,155,43,.22),transparent 45%),linear-gradient(315deg,rgba(11,111,106,.18),transparent 40%),#f4ead5}.character-art img{border-radius:6px}.card-preview-backdrop{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:18px;background:rgba(15,15,15,.72)}.card-preview-modal{position:relative;display:grid;place-items:center;width:min(560px,calc(100vw - 28px));max-height:calc(100vh - 28px)}.card-preview-modal img{display:block;max-width:100%;max-height:calc(100vh - 28px);border-radius:10px;box-shadow:var(--shadow)}.card-preview-close{position:absolute;right:8px;top:8px;z-index:1}.character-art-fallback{display:grid;place-items:center;color:rgba(32,33,36,.5);font-size:4rem;font-weight:950}.waiting-card{display:grid;place-items:center;min-height:210px;border:1px dashed var(--line);border-radius:8px;background:rgba(255,253,247,.75);color:var(--muted);text-align:center;padding:18px}.waiting-card strong{color:var(--ink);font-size:3rem}.character-card:disabled{cursor:not-allowed}.character-card strong{font-size:1.1rem}.character-card small,.district-card small{color:var(--muted);line-height:1.35}.rank-badge{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;background:var(--ink);color:#fff}.district-word,.rank-badge{font-weight:900}.district-word.noble{color:#a66f00}.district-word.religious{color:#1f6fb2}.district-word.trade{color:#1f7a3f}.district-word.military{color:#a83c38}.district-word.unique{color:#7b2cbf}.action-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:10px;gap:10px;align-items:end}.or-divider{display:grid;place-items:center;color:var(--muted);font-weight:900}.turn-action-board{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px;align-items:start}.action-box h3,.hand-box h3{margin:0}.action-box p,.hand-box p{margin-bottom:12px}.action-box.action-done{position:relative;opacity:.72}.action-box.action-done:after{content:"Done";position:absolute;right:10px;top:10px;padding:3px 8px;border-radius:999px;background:rgba(47,140,76,.14);color:#1f7a3f;font-size:.72rem;font-weight:950}.ability-note{margin:8px 0 0;color:var(--muted);font-size:.86rem}.pending-box{border-color:rgba(216,155,43,.7);background:rgba(255,248,232,.95)}.compact-field{margin-bottom:0}.district-row,.hand-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));grid-gap:8px;gap:8px}.district-card{display:grid;position:relative;grid-gap:5px;gap:5px;align-content:space-between;min-height:112px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 8px 22px rgba(45,39,28,.07)}.district-card.unique{min-height:176px}.district-card strong{font-size:.95rem;line-height:1.12}.district-card.noble{border-top:7px solid #d9a327;background:linear-gradient(180deg,rgba(217,163,39,.2),rgba(255,255,255,0) 56%),#fffdf6}.district-card.religious{border-top:7px solid #2f80c9;background:linear-gradient(180deg,rgba(47,128,201,.18),rgba(255,255,255,0) 56%),#f7fbff}.district-card.trade{border-top:7px solid #2f8c4c;background:linear-gradient(180deg,rgba(47,140,76,.18),rgba(255,255,255,0) 56%),#f7fff9}.district-card.military{border-top:7px solid #b84a45;background:linear-gradient(180deg,rgba(184,74,69,.18),rgba(255,255,255,0) 56%),#fff8f7}.district-card.unique{border-top:7px solid #7b2cbf;background:linear-gradient(180deg,rgba(123,44,191,.2),rgba(255,255,255,0) 56%),#fcf8ff}.district-ability{display:block;padding-top:5px;border-top:1px solid rgba(123,44,191,.16);font-size:.76rem}.city-heading,.district-topline{display:flex;align-items:center;justify-content:space-between;gap:10px}.district-cost-pill{gap:3px;min-width:34px;height:28px;border-radius:50%;background:rgba(216,155,43,.2);color:#5b3d09;font-weight:900}.district-cost-pill,.district-type-badge{display:inline-flex;align-items:center;justify-content:center}.district-type-badge{justify-self:stretch;min-width:0;min-height:28px;padding:4px 8px;border-radius:7px;color:#fff;font-size:.72rem;font-weight:950;text-transform:capitalize}.district-type-badge.noble{background:#b98514}.district-type-badge.religious{background:#2f80c9}.district-type-badge.trade{background:#2f8c4c}.district-type-badge.military{background:#b84a45}.district-type-badge.unique{background:#7b2cbf;padding-right:28px}.district-topline .unique-star{position:absolute;top:7px;right:8px;min-width:24px;width:24px;height:24px;background:#7b2cbf;color:#fff;font-size:.9rem}.current-turn-card{display:grid;grid-template-columns:clamp(62px,10vw,86px) minmax(0,1fr);grid-gap:12px;gap:12px;align-items:start;padding:12px;border:1px solid var(--line);border-radius:8px;background:rgba(255,253,247,.86)}.current-turn-card .character-art{max-height:128px}.current-turn-card strong{font-size:1.05rem}.done-chip{background:rgba(47,140,76,.13);color:#1f7a3f}.end-turn-ready{box-shadow:0 0 0 4px rgba(216,155,43,.22);transform:translateY(-1px)}.inline-stats{display:flex;flex-wrap:wrap;gap:9px;align-items:center}.inline-stats span{gap:4px}.inline-stats span,.mini-button{display:inline-flex;align-items:center}.mini-button{justify-content:center;gap:5px;min-height:32px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--accent-strong);font-size:.82rem;font-weight:900;cursor:pointer}.inline-confirm{display:inline-grid;grid-template-columns:1fr auto auto;align-items:center;gap:6px;width:100%;min-height:36px;padding:5px;border:1px solid rgba(216,155,43,.48);border-radius:8px;background:rgba(255,249,234,.98);color:var(--ink);font-size:.78rem;font-weight:850}.inline-confirm.stacked{grid-template-columns:1fr;justify-items:stretch}.inline-confirm.stacked>span{text-align:center}.confirm-mini{background:rgba(47,140,76,.14);color:#1f7a3f}.danger-mini{color:var(--red)}.city-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:14px;gap:14px}.city-board{align-content:start}.city-heading h3{margin:0}.log-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.log-heading h3{margin:0}.log-pager{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-weight:900}.turn-log-list{display:grid;grid-gap:12px;gap:12px;margin-top:12px}.turn-log-group{display:grid;grid-gap:8px;gap:8px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.turn-log-group h4{margin:0;color:var(--accent-strong);font-size:.92rem}@media (max-width:900px){.hero,.mode-grid,.room-layout{grid-template-columns:1fr}.hero{min-height:auto}.citadel-layout,.citadel-private,.turn-action-board{grid-template-columns:1fr}}@media (max-width:540px){.shell{width:min(100vw - 20px,1120px);padding-top:18px}.table-scene{min-height:260px}.table-card{width:86px;height:116px;border-width:6px}}