:root{color-scheme:light;font-family:Palatino Linotype,Book Antiqua,Georgia,serif;background:#fbf8f1;color:#1f1810;--ink: #23160d;--paper: #eadbbd;--paper-deep: #dfcca7;--panel: rgba(241, 231, 205, .97);--brass: #8c6426;--brass-dark: #5b3f16;--rail: #2f3a42;--signal: #5d1f1a;--display-font: "Agency FB", "Arial Narrow", "Franklin Gothic Demi Cond", "Haettenschweiler", sans-serif;--brick-image: url(/assets/brick-texture.png);--wood-sign-image: url(/assets/wood-sign.png);--brick-gap: 3px;--brick-px-width: 200;--brick-px-height: 63;--header-brick-columns: 8;--brick: linear-gradient(180deg, rgba(63, 34, 21, .22), rgba(63, 34, 21, .22)), var(--brick-image)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-height:100vh;background:#fbf8f1;background-attachment:fixed}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;background:radial-gradient(circle at top center,rgba(242,228,192,.16),transparent 30%),transparent}.app-shell--immersive{background:#fbf8f1}.app-header{display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:1rem 1.25rem;background:linear-gradient(180deg,#271c13fa,#1c130cfa),#23160d;color:#f0e3c1;border-bottom:4px double #9e7b3d;position:sticky;top:0;z-index:30}.brand{display:flex;flex-direction:column;gap:.15rem;letter-spacing:.03em}.brand span{font-size:1.3rem;font-weight:700;font-family:var(--display-font);text-transform:uppercase;letter-spacing:.08em}.brand small{color:#cbb287}.app-main{padding:1rem}.app-main--immersive{padding:0;height:100vh;overflow:hidden;background:#fbf8f1}.page-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.single-column{grid-template-columns:minmax(0,980px);justify-content:center}.wide-panel{grid-column:1 / -1}.panel,.hero-card,.rules-card,.overlay-frame{background:linear-gradient(180deg,#f7eed8fa,#e4d4b4fa),var(--paper);border:1px solid var(--brass-dark);box-shadow:inset 0 0 0 2px #c39d58,inset 0 0 0 6px #5c391438,0 10px 28px #0f0a073d;padding:1rem}.panel--immersive-error{max-width:48rem;margin:2rem auto}.station-sheet{position:relative}.station-sheet:before,.overlay-frame:before{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;border:1px solid rgba(90,63,22,.35);pointer-events:none}.hero-card{max-width:960px;margin:2rem auto;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.hero-copy h1,.panel h1,.rules-card h2,.overlay-frame h2{margin:0;font-weight:700;letter-spacing:.03em;font-family:var(--display-font);text-transform:uppercase}.eyebrow{margin:0 0 .35rem;text-transform:uppercase;letter-spacing:.12em;font-size:.73rem;color:var(--signal);font-family:var(--display-font)}.line-copy{margin:.25rem 0 0;color:#4e3a23}.auth-form,.stack-form,.score-editor{display:grid;gap:.8rem}label{display:grid;gap:.35rem;font-weight:600;color:#392514}input,select,textarea{width:100%;border:1px solid rgba(67,44,20,.4);padding:.75rem .85rem;background:#f7f0db;color:var(--ink)}input:focus,select:focus,textarea:focus{outline:2px solid rgba(140,100,38,.45);outline-offset:2px}.primary-button,.ghost-button,.accordion-trigger,.inline-link{border:1px solid #4f3618;padding:.72rem 1rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:linear-gradient(180deg,#f4e7c7,#d7b97a);color:#35200f;box-shadow:inset 0 0 0 1px #fff5db80;font-family:var(--display-font)}.primary-button,.danger-button{background:linear-gradient(180deg,#7a2f24,#4d1811);color:#f5ead4}.header-actions,.button-row,.map-controls,.legend-row,.team-actions,.control-banner__actions,.control-banner__metrics,.command-strip{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}.wrap-row{align-items:stretch}.role-pill,.status-banner,.presence-pill,.selected-chip,.legend-chip,.identity-chip,.toast-banner,.signal-box{border:1px solid rgba(69,47,21,.55);padding:.4rem .7rem;background:#f4e8c9f5}.role-pill{background:#c8af772e}.status-banner{display:inline-flex;align-items:center;justify-content:center;font-weight:700;margin-top:.75rem}.status-online{background:#c5e0c5f2}.status-reconnecting{background:#efdda9f2}.status-offline{background:#e3b9b0f2}.toast-banner{margin-top:.75rem}.panel-header,.rules-header,.team-card-header,.map-toolbar,.overlay-frame__header,.control-banner{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.games-list,.team-list,.feed-list,.accordion-list,.selected-list,.metric-stack,.scoreboard{display:grid;gap:.75rem}.game-card,.team-card,.join-card,.score-card{border:1px solid rgba(67,44,20,.35);padding:.9rem;background:linear-gradient(180deg,#f6edd6f0,#e7d6b1f0)}.map-panel,.map-stage{position:relative}.map-stage--immersive{height:100vh;min-height:100vh;overflow:hidden;background:#fbf8f1}.map-shell{overflow:hidden;border:1px solid rgba(55,37,18,.45);background:#fbf8f1;min-height:430px;touch-action:none}.map-stage--immersive .map-shell{min-height:100vh;height:100vh;border:none}.game-map{width:100%;height:auto;display:block}.map-stage--immersive .game-map{height:100%;width:100%}.station-label{font-size:16px;fill:#30415a;font-weight:700;paint-order:stroke;stroke:#f7efdcc7;stroke-width:3px;user-select:none;-webkit-user-select:none;pointer-events:none}.legend-row{margin-top:.75rem}.legend-row--map{position:absolute;left:1rem;bottom:1rem;max-width:min(50rem,calc(100vw - 2rem));margin:0;z-index:7}.legend-chip{display:inline-flex;gap:.45rem;align-items:center;background:#fbf8f1b3;color:#1e1811;border-color:#36261424;text-shadow:none;font-family:var(--display-font);letter-spacing:.03em;font-size:.65rem;padding:.22rem .34rem}.legend-swatch,.team-swatch{width:.55rem;height:.55rem;display:inline-block}.identity-chip,.signal-box{display:inline-flex;gap:.5rem;align-items:center}.signal-box{flex-direction:column;align-items:flex-start;min-width:8rem}.signal-box span{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:#5c4424;font-family:var(--display-font)}.selected-chip,.presence-pill{background:#ece1c4f2}.presence-pill.online{background:#cde1c9f2}.presence-pill.offline{background:#e7d6bdf2}.team-meta{display:grid;gap:.4rem;margin:.6rem 0}.feed-item,.score-row{display:grid;gap:.35rem;padding:.7rem 0;border-bottom:1px solid rgba(73,49,23,.15)}.feed-item:last-child,.score-row:last-child{border-bottom:none}.feed-undo{justify-self:start;border:none;background:transparent;color:#7b1f1a;padding:0;text-transform:uppercase;letter-spacing:.08em}.accordion-item{border:1px solid rgba(67,44,20,.25);overflow:hidden}.accordion-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(180deg,#ecd9ad,#d1b06c)}.accordion-panel{padding:.9rem 1rem}.error-text{color:#8a2218}.success-text{color:#264322}.immersive-game{position:relative;min-height:100vh;color:#f5ead4}.live-map-overlay{position:absolute;z-index:10}.top-overlay{top:0;left:0;right:0;padding:1rem}.control-banner{padding:.85rem 1rem;background:var(--brick);border:1px solid #3f2417;box-shadow:inset 0 0 0 1px #f5deb414,0 10px 24px #120c0847;align-items:stretch}.control-banner__title,.control-banner__metrics,.control-banner__actions{position:relative;padding:.85rem 1rem;background:linear-gradient(180deg,#f9f1ddf7,#e6d8b8f7);border:1px solid rgba(72,47,23,.76);color:#25180f;flex:1 1 16rem}.control-banner>*+*:before{content:"";position:absolute;left:-1rem;top:-.85rem;bottom:-.85rem;width:.75rem;background:var(--brick);border-left:1px solid rgba(53,32,18,.5);border-right:1px solid rgba(53,32,18,.5)}.control-banner__title h1,.control-banner__title p,.control-banner__actions,.control-banner__metrics{color:#25180f}.command-strip{left:1rem;right:1rem;top:9rem;padding:.75rem;background:var(--brick);border:1px solid #3f2417;box-shadow:0 8px 20px #120c0838}.claim-desk{left:1rem;top:13.5rem;bottom:1rem;width:min(27rem,calc(100vw - 2rem))}.dormant-claim-note{left:1rem;top:13.7rem;padding:.7rem .9rem;background:#fbf6ecf2;border:1px solid #6b4a21;color:#22160d}.info-desk{right:1rem;top:13.5rem;bottom:1rem;width:min(31rem,calc(100vw - 2rem))}.overlay-frame{position:relative;height:100%;color:var(--ink)}.overlay-frame--scroll{overflow:auto}.admin-box{margin-top:1rem}.map-controls--overlay{position:absolute;right:1rem;bottom:1rem;z-index:7}.map-controls button{min-width:4.2rem}@media(max-width:960px){.top-overlay,.command-strip{position:absolute}.command-strip{top:11.8rem}.claim-desk,.info-desk{left:1rem;right:1rem;width:auto;top:auto;bottom:1rem;max-height:44vh}.dormant-claim-note{top:auto;bottom:1rem;right:1rem}}@media(max-width:720px){.app-main{padding:.85rem}.app-main--immersive{padding:0}.panel-header,.rules-header,.map-toolbar,.overlay-frame__header,.control-banner{flex-direction:column}.control-banner>*+*:before{display:none}.map-stage--immersive,.map-stage--immersive .map-shell{height:100dvh;min-height:100dvh}.top-overlay{padding:.7rem}.command-strip{left:.7rem;right:.7rem;top:13.8rem}.claim-desk,.info-desk{left:.7rem;right:.7rem;bottom:.7rem;max-height:50vh}.legend-row--map,.map-controls--overlay{left:.7rem;right:.7rem}.map-controls--overlay{bottom:4.2rem;justify-content:flex-end}}.underground-layout{height:100vh;background:#fbf8f1;color:#20160f;display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden}.brick-header-wall{position:relative;overflow:hidden;width:100%;padding:0;display:grid;grid-template-columns:repeat(17,minmax(0,1fr));grid-template-rows:repeat(11,minmax(0,1fr));flex:0 0 auto}.header-brick-tile{background-repeat:no-repeat;background-size:100% 100%;background-position:center}.title-plaque,.metric-tile{background-image:linear-gradient(180deg,#f8f2e8e0,#ece5dae0),url(/assets/bricks/brick_grout_03_200x63.png);background-repeat:repeat,repeat;background-size:auto,200px 63px;background-position:center,center;border:none;box-shadow:inset 0 0 0 1px #fffdf78c,0 1px #735e4a2e;z-index:1}.title-plaque{grid-column:4 / span 11;grid-row:2 / span 5;display:grid;place-items:center;text-align:center;padding:.2rem .75rem .3rem}.title-mark{display:block;width:min(100%,675px);max-height:72%;object-fit:contain}.title-plaque .line-copy{color:#34231a;margin:0;font-size:clamp(.45rem,.75vw,.72rem)}.metrics-wall{display:contents}.metric-tile{display:grid;place-items:center;text-align:center;padding:.15rem .35rem}.metric-tile--hops{grid-column:2 / span 1;grid-row:7 / span 4}.metric-tile--time-left{grid-column:4 / span 3;grid-row:8 / span 3}.metric-tile--next-draw{grid-column:8 / span 3;grid-row:8 / span 3}.metric-tile--underground{grid-column:12 / span 3;grid-row:8 / span 3}.metric-tile--cards{grid-column:16 / span 1;grid-row:7 / span 4}.metric-tile span{font-size:clamp(.55rem,.9vw,.8rem);line-height:1;text-transform:uppercase;letter-spacing:.06em;color:#413027;font-family:var(--display-font)}.metric-tile strong{font-family:var(--display-font);font-size:clamp(1rem,2vw,1.95rem);line-height:1;letter-spacing:.04em;color:#201711}.underground-stage{min-height:0;display:grid;grid-template-rows:minmax(0,1fr);gap:0;overflow:hidden}.sign-row{position:absolute;top:-1px;left:0;right:0;z-index:7;display:grid;grid-template-columns:1fr auto 1fr;align-items:start;padding:0 clamp(1rem,4vw,2.4rem) 0;pointer-events:none}.sign-row>*{pointer-events:auto}.wood-sign{justify-self:center;border:none;padding:0;background:transparent;font-family:var(--display-font);text-transform:uppercase;letter-spacing:.05em;color:#f6f0e6;text-shadow:0 1px 2px rgba(0,0,0,.75);white-space:pre-line;line-height:1.05;display:grid;place-items:center;background-image:var(--wood-sign-image);background-repeat:no-repeat;background-position:center;background-size:contain;mix-blend-mode:multiply;transform:none;line-height:1.02;text-align:center}.wood-sign>span{display:inline-block;transform:translateY(.16em)}.wood-sign:disabled{opacity:.75}.wood-sign--small{width:94px;height:44px;font-size:.75rem;align-self:start}.wood-sign--small:first-child{justify-self:start}.wood-sign--small:last-child{justify-self:end}.wood-sign--hero{width:min(234px,calc(100vw - 8rem));height:86px;font-size:clamp(.91rem,1.56vw,1.24rem);padding:0 1.8rem;margin-top:0}.map-board{position:relative;height:100%;min-height:0;border-bottom:2px solid #2f2620;background:#fbf8f1;overflow:hidden}.header-status-tile{display:grid;place-items:stretch;z-index:2}.header-status-tile .status-banner{margin:0;min-width:0;height:100%;width:100%;padding:.02rem .08rem 0;text-align:center;border:none;box-shadow:inset 0 0 0 1px #fffaee59,0 1px #6c544126}.status-banner--compact{font-family:var(--display-font);text-transform:uppercase;letter-spacing:.03em;font-size:clamp(.7rem,1.26vw,1.18rem);line-height:.9}.header-status-tile .status-online{background:linear-gradient(180deg,#d7ebcdf5,#b2d4a2f5);color:#183015}.header-status-tile .status-reconnecting{background:linear-gradient(180deg,#efe1b0f5,#dcb46ef5);color:#4a2d0d}.header-status-tile .status-offline{background:linear-gradient(180deg,#e9c2b4f5,#cc8a78f5);color:#4b1714}.map-board__toast{position:absolute;left:1rem;top:clamp(4.6rem,9vw,6.4rem);z-index:6;max-width:min(24rem,calc(100% - 2rem))}.map-sidebar{position:absolute;top:1rem;bottom:1rem;z-index:8;width:min(26rem,calc(100vw - 2rem))}.map-sidebar--claim{right:1rem}.map-sidebar--info{left:1rem;width:min(31rem,calc(100vw - 2rem))}.underground-map-stage{height:100%;min-height:0;background:#fbf8f1}.underground-map-stage .map-shell{height:100%;min-height:0;background:#fbf8f1;border:none}.underground-map-stage .game-map{width:100%;height:100%}.legend-board{background:transparent;border-top:none;display:grid;align-content:center;justify-items:center;gap:.35rem;padding:.45rem .7rem}.legend-board--overlay{position:absolute;left:0;right:0;bottom:0;min-height:3.7rem;z-index:5}.legend-board__title{font-family:var(--display-font);text-transform:uppercase;letter-spacing:.12em;font-size:.65rem;color:#1c1611}.legend-row--board{justify-content:center;margin:0}.legend-row--board .legend-chip{background:transparent}.underground-layout--minimal .utility-toolbar{display:none}.underground-layout .status-banner:not(.status-banner--compact),.underground-layout .toast-banner{background:#fcf6eaf5;color:#20160f}.underground-layout .overlay-frame,.underground-layout .panel,.underground-layout .hero-card,.underground-layout .rules-card{background:linear-gradient(180deg,#f8f0dcfa,#eaddc1fa),var(--paper)}@media(max-width:1080px){.wood-sign--hero{width:min(220px,calc(100vw - 7rem))}}@media(max-width:820px){.sign-row{grid-template-columns:1fr auto 1fr;justify-items:stretch;gap:.5rem;padding:0 .5rem}.wood-sign--hero{width:min(220px,calc(100vw - 10rem))}.map-sidebar,.map-sidebar--info,.map-sidebar--claim{left:.75rem;right:.75rem;width:auto;top:auto;bottom:.75rem;max-height:min(58vh,34rem)}.map-board__toast{left:.75rem;right:auto;max-width:min(15rem,calc(100% - 1.5rem))}.legend-board{min-height:4.75rem}}@media(max-width:640px){.metric-tile strong{font-size:clamp(.92rem,4vw,1.1rem)}.wood-sign--small{width:84px;height:39px;font-size:.66rem}.wood-sign--hero{width:min(198px,calc(100vw - 9rem));height:76px;font-size:.82rem;padding:0 1.3rem}}
