@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700;9..144,900&family=Nunito:wght@400;500;600;700;800;900&display=swap";:root{--sky-top: #d2dde7;--sky-mid: #c3d0dc;--sky-bottom: #b6c4d0;--cream: #fbf6ea;--parchment: #f6eedc;--parchment-deep: #ece0c4;--panel: #fff9ee;--panel-edge: #e6d8ba;--ink: #3a2c1e;--ink-soft: #6f5b43;--ink-faint: #9c8a72;--field: #7fb45f;--field-deep: #5f9444;--city: #d9c191;--road: #efe7d3;--terracotta: #c4583a;--terracotta-deep: #a3472d;--gold: #d8a93f;--gold-deep: #b78525;--slate: #4d6275;--accent: var(--terracotta);--accent-deep: var(--terracotta-deep);--shadow-sm: 0 2px 6px rgba(58, 44, 30, .1);--shadow-md: 0 10px 28px rgba(58, 44, 30, .16);--shadow-lg: 0 26px 60px rgba(40, 30, 18, .3);--ring: 0 0 0 4px rgba(216, 169, 63, .3);--radius-sm: 8px;--radius: 14px;--radius-lg: 22px;--radius-pill: 999px;--font-display: "Fraunces", "Iowan Old Style", Georgia, serif;--font-ui: "Nunito", ui-rounded, "Segoe UI", system-ui, sans-serif}.scene-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 90% at 50% -10%,var(--sky-top) 0%,var(--sky-mid) 45%,var(--sky-bottom) 100%);overflow:hidden}.scene-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");opacity:.05;mix-blend-mode:multiply;pointer-events:none}.scene-veil{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(80% 70% at 50% 42%,transparent 30%,rgba(110,126,140,.18) 78%,rgba(70,84,96,.4) 100%),linear-gradient(180deg,rgba(210,221,231,.3) 0%,transparent 22%,transparent 70%,rgba(60,72,84,.28) 100%)}.card{position:relative;background:linear-gradient(180deg,var(--panel) 0%,var(--parchment) 100%);border:1px solid var(--panel-edge);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),inset 0 1px #ffffffb3}.card:before{content:"";position:absolute;inset:1px 1px auto 1px;height:40%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:linear-gradient(180deg,rgba(255,255,255,.45),transparent);pointer-events:none}.display{font-family:var(--font-display);font-weight:900;color:var(--ink);letter-spacing:-.01em;line-height:.98;font-optical-sizing:auto}.eyebrow{font-family:var(--font-ui);font-weight:800;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}.btn{font-family:var(--font-ui);font-weight:800;font-size:15px;border:none;border-radius:var(--radius);padding:13px 22px;cursor:pointer;color:var(--ink);background:var(--cream);box-shadow:0 4px 0 var(--parchment-deep),var(--shadow-sm);transition:transform .08s ease,box-shadow .08s ease,filter .15s ease,background .15s ease;-webkit-user-select:none;user-select:none}.btn:hover{filter:brightness(1.03)}.btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--parchment-deep),var(--shadow-sm)}.btn:focus-visible{outline:none;box-shadow:0 4px 0 var(--parchment-deep),var(--ring)}.btn:disabled{cursor:not-allowed;filter:grayscale(.4) opacity(.65);box-shadow:0 3px 0 var(--parchment-deep)}.btn-primary{color:#fff8ef;background:linear-gradient(180deg,var(--terracotta) 0%,var(--terracotta-deep) 100%);box-shadow:0 5px #7f3420,var(--shadow-md);text-shadow:0 1px 1px rgba(120,40,24,.5)}.btn-primary:active{box-shadow:0 1px #7f3420,var(--shadow-sm)}.btn-primary:focus-visible{box-shadow:0 5px #7f3420,var(--ring)}.btn-primary:disabled{box-shadow:0 4px #7f3420}.btn-gold{color:#4a3408;background:linear-gradient(180deg,#efc057 0%,var(--gold-deep) 100%);box-shadow:0 5px #8a6212,var(--shadow-md)}.btn-gold:active{box-shadow:0 1px #8a6212,var(--shadow-sm)}.btn-gold:focus-visible{box-shadow:0 5px #8a6212,var(--ring)}.btn-block{width:100%;display:block}.btn-sm{padding:8px 14px;font-size:13px;border-radius:var(--radius-sm);box-shadow:0 3px 0 var(--parchment-deep)}.btn-sm:active{box-shadow:0 1px 0 var(--parchment-deep)}.btn-ghost{background:transparent;box-shadow:inset 0 0 0 2px var(--panel-edge);color:var(--ink-soft)}.btn-ghost:active{transform:translateY(2px);box-shadow:inset 0 0 0 2px var(--panel-edge)}.seg{display:flex;gap:4px;padding:5px;background:var(--parchment-deep);border-radius:var(--radius);box-shadow:inset 0 2px 5px #3a2c1e24}.seg-btn{flex:1;font-family:var(--font-ui);font-weight:800;font-size:13px;border:none;border-radius:10px;padding:9px 4px;cursor:pointer;background:transparent;color:var(--ink-faint);transition:all .16s ease}.seg-btn:hover{color:var(--ink-soft)}.seg-btn[aria-selected=true]{background:linear-gradient(180deg,var(--cream),var(--panel));color:var(--terracotta-deep);box-shadow:var(--shadow-sm),inset 0 1px #fff}.field-label{display:block;font-family:var(--font-ui);font-weight:800;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px}.input{width:100%;box-sizing:border-box;font-family:var(--font-ui);font-weight:600;font-size:15px;color:var(--ink);background:var(--cream);border:2px solid var(--panel-edge);border-radius:var(--radius-sm);padding:11px 14px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.input::placeholder{color:var(--ink-faint);opacity:.7}.input:focus{border-color:var(--gold);box-shadow:var(--ring)}.input-code{font-family:var(--font-display);font-weight:700;letter-spacing:.32em;text-align:center;text-transform:uppercase;font-size:26px}.select{font-family:var(--font-ui);font-weight:700;font-size:13px;color:var(--ink);background:var(--cream);border:2px solid var(--panel-edge);border-radius:var(--radius-sm);padding:9px 10px;cursor:pointer;outline:none;transition:border-color .15s ease}.select:focus{border-color:var(--gold)}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes floatY{0%,to{transform:translateY(0) rotate(var(--r, 0deg))}50%{transform:translateY(-14px) rotate(var(--r, 0deg))}}@keyframes pop{0%{transform:scale(.8);opacity:0}60%{transform:scale(1.06)}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-up{animation:fadeUp .6s cubic-bezier(.2,.8,.2,1) both}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--sky-bottom);color:var(--ink);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,select{font-family:inherit}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#3a2c1e38;border-radius:999px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:#3a2c1e61;background-clip:padding-box}.board-scroll{overflow:hidden;flex:1;background:#2d5016;display:flex;align-items:flex-start;justify-content:flex-start;position:relative}.board-scroll[data-meeple-focus=true]:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at center,#ffebb429,#0000003d 52%,#00000070),linear-gradient(to bottom,#ffffff08,#00000014);opacity:1}.board-scroll:after{transition:opacity .26s cubic-bezier(.22,1,.36,1);opacity:0}.board-scroll[data-meeple-focus-phase=entering]:after,.board-scroll[data-meeple-focus-phase=active]:after{opacity:1}.board-scroll[data-meeple-focus-phase=exiting]:after{opacity:0}.board-canvas{position:relative;will-change:transform}.board-stage{position:relative}.placed-tile-shell{transform-origin:center;animation:tile-place-in .26s cubic-bezier(.18,.89,.32,1.24) both}.meeple-piece{animation:meeple-pop-in .24s cubic-bezier(.16,1,.3,1) both}.segment-hit-pulse{animation:target-pulse 1.6s ease-in-out infinite}.tile-inline-svg>svg{width:100%;height:100%;display:block}.tile-inline-svg [id^=segment-]{transition:filter .12s ease}.tile-seg--hl{filter:brightness(1.22) saturate(1.35) drop-shadow(0 0 2.5px gold) drop-shadow(0 0 1px rgba(255,215,0,.9))}.segment-hit-group:hover .segment-hit-fallback{r:7;opacity:1}.segment-hit-group:active .segment-hit-fallback{opacity:.8}.meeple-focus-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0;transition:opacity .26s cubic-bezier(.22,1,.36,1)}.meeple-focus-overlay[data-state=entering],.meeple-focus-overlay[data-state=active]{opacity:1}.meeple-focus-overlay[data-state=exiting]{opacity:0}.meeple-focus-spotlight{position:absolute;border-radius:50%;background:radial-gradient(circle,#fffae67a,#ffe0a042 30%,#ffcd561a,#ffcd5600 74%);filter:blur(3px) saturate(1.12);opacity:0;transform:scale(.88) translateZ(0);transition:opacity .26s cubic-bezier(.22,1,.36,1),transform .26s cubic-bezier(.22,1,.36,1);animation:meeple-focus-breathe 1.35s ease-in-out infinite,meeple-focus-parallax 2.4s ease-in-out infinite}.meeple-focus-overlay[data-state=entering] .meeple-focus-spotlight,.meeple-focus-overlay[data-state=active] .meeple-focus-spotlight{opacity:1;transform:scale(1)}.meeple-focus-overlay[data-state=exiting] .meeple-focus-spotlight{opacity:0;transform:scale(.9)}.meeple-focus-ring{position:absolute;border-radius:18px;box-shadow:0 0 0 2px #fff7ddf5,0 0 0 10px #ffcd563d,0 0 34px #ffcd568c,inset 0 0 0 1px #ffffff3d;background:linear-gradient(135deg,#ffffff29,#ffcd5614);opacity:0;transform:scale(.92) translateZ(0);transition:opacity .26s cubic-bezier(.22,1,.36,1),transform .26s cubic-bezier(.22,1,.36,1);animation:meeple-focus-ring 1.35s ease-in-out infinite,meeple-focus-parallax-reverse 2.4s ease-in-out infinite}.meeple-focus-overlay[data-state=entering] .meeple-focus-ring,.meeple-focus-overlay[data-state=active] .meeple-focus-ring{opacity:1;transform:scale(1)}.meeple-focus-overlay[data-state=exiting] .meeple-focus-ring{opacity:0;transform:scale(.92)}@keyframes meeple-focus-breathe{0%,to{transform:scale(.98);opacity:.78}50%{transform:scale(1.03);opacity:1}}@keyframes meeple-focus-parallax{0%,to{transform:scale(.98) translate3d(-7px,-3px,0)}50%{transform:scale(1.03) translate3d(7px,3px,0)}}@keyframes meeple-focus-parallax-reverse{0%,to{transform:scale(.995) translate3d(5px,2px,0)}50%{transform:scale(1.01) translate3d(-5px,-2px,0)}}@keyframes meeple-focus-ring{0%,to{transform:scale(.995);opacity:.88}50%{transform:scale(1.015);opacity:1}}.segment-hit-group{cursor:pointer}.segment-hit{pointer-events:all;fill:transparent;stroke:none}.segment-hit-line{pointer-events:all;fill:none;stroke:transparent;stroke-width:20;stroke-linecap:round}.segment-hit-fallback{pointer-events:all;fill:var(--player-color);opacity:.85;stroke:#fff;stroke-width:1;paint-order:stroke;transition:r .12s ease,opacity .12s ease}.segment-hit-fallback--bare{fill:var(--player-color);opacity:.55;stroke:gold;stroke-width:2;animation:target-pulse 1.6s ease-in-out infinite}@keyframes tile-place-in{0%{opacity:0;transform:scale(.76) rotate(-2.5deg) translateY(-6px);filter:blur(2px) saturate(1.04)}68%{opacity:1;transform:scale(1.02) rotate(.8deg) translateY(1px);filter:blur(0) saturate(1.06)}to{opacity:1;transform:scale(1) rotate(0);filter:blur(0) saturate(1)}}@keyframes meeple-pop-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.48) translateY(-12px);filter:blur(1.2px) drop-shadow(0 2px 3px rgba(0,0,0,.2))}58%{opacity:1;transform:translate(-50%,-50%) scale(1.12,.94) translateY(2px);filter:blur(0)}78%{opacity:1;transform:translate(-50%,-50%) scale(.98,1.02) translateY(0);filter:blur(0)}to{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0);filter:blur(0)}}@keyframes target-pulse{0%,to{opacity:.22;filter:drop-shadow(0 0 0 rgba(255,215,0,0))}50%{opacity:.42;filter:drop-shadow(0 0 7px rgba(255,215,0,.24))}}.tile-history-highlight{animation:tile-history-highlight 3s ease forwards}@keyframes tile-history-highlight{0%{box-shadow:0 0 0 2px #63b3edf2,0 0 18px #63b3ed8c;opacity:1}70%{box-shadow:0 0 0 2px #63b3edf2,0 0 18px #63b3ed8c;opacity:1}to{box-shadow:0 0 0 2px #63b3ed00,0 0 #63b3ed00;opacity:0}}@media (prefers-reduced-motion: reduce){.board-scroll:after,.meeple-focus-overlay,.meeple-focus-spotlight,.meeple-focus-ring,.placed-tile-shell,.meeple-piece,.segment-hit-pulse,.board-canvas{animation:none!important;transition-duration:1ms!important}.board-scroll[data-meeple-focus=true]:after{opacity:1}.meeple-focus-overlay,.meeple-focus-overlay[data-state=entering],.meeple-focus-overlay[data-state=active]{opacity:1;transform:none}}.menu-screen{position:relative;height:100vh;width:100vw;overflow:hidden;display:flex;align-items:center;justify-content:flex-start;background:radial-gradient(120% 90% at 50% -10%,var(--sky-top),var(--sky-mid) 45%,var(--sky-bottom))}.showcase{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.showcase canvas{pointer-events:none!important}.menu-veil{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background:linear-gradient(90deg,rgba(214,223,231,.78) 0%,rgba(210,221,231,.4) 32%,transparent 56%),radial-gradient(90% 80% at 60% 44%,transparent 40%,rgba(96,112,126,.16) 80%,rgba(54,66,78,.4) 100%),linear-gradient(180deg,rgba(210,221,231,.28) 0%,transparent 24%,transparent 64%,rgba(48,60,72,.3) 100%)}.menu-meeple{position:absolute;z-index:1;filter:drop-shadow(0 8px 10px rgba(40,30,18,.28));animation:floatY var(--dur, 7s) ease-in-out infinite;opacity:.9;pointer-events:none}.menu-stage{position:relative;z-index:2;display:flex;flex-direction:column;align-items:flex-start;gap:24px;padding:28px;margin-left:clamp(20px,6vw,110px);max-height:100vh}.hero-head{text-align:left;animation:fadeUp .7s cubic-bezier(.2,.8,.2,1) both}.hero-crest{display:inline-flex;align-items:center;gap:9px;padding:6px 16px;border-radius:var(--radius-pill);background:#fff9eeb8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:var(--shadow-sm),inset 0 1px #fff;margin-bottom:16px}.hero-crest .dot{width:8px;height:8px;border-radius:50%;background:var(--terracotta)}.hero-title{font-family:var(--font-display);font-weight:900;font-size:clamp(46px,6.5vw,84px);line-height:.9;letter-spacing:-.02em;color:var(--ink);text-shadow:0 2px 0 rgba(255,255,255,.55),0 18px 40px rgba(40,30,18,.28)}.hero-title .accent{color:var(--terracotta)}.hero-sub{margin-top:12px;font-size:16px;font-weight:600;color:var(--ink-soft);text-shadow:0 1px 0 rgba(255,255,255,.6)}.menu-card{width:min(440px,92vw);padding:26px 28px 28px;animation:fadeUp .7s cubic-bezier(.2,.8,.2,1) .08s both}.menu-card .stack{display:flex;flex-direction:column;gap:14px;margin-top:18px}.error-banner{margin-top:14px;padding:10px 14px;border-radius:var(--radius-sm);background:#c4583a1f;border:1px solid rgba(196,88,58,.35);color:var(--terracotta-deep);font-size:13px;font-weight:600;text-align:center}.player-rows{display:flex;flex-direction:column;gap:9px}.player-row{display:flex;gap:8px;align-items:center}.player-row .input{flex:2}.player-row .select{flex:1.4}.row-remove{flex-shrink:0;width:38px;height:38px;border-radius:var(--radius-sm);border:2px solid rgba(196,88,58,.3);background:#c4583a14;color:var(--terracotta-deep);font-size:16px;font-weight:800;cursor:pointer;transition:all .14s ease}.row-remove:hover{background:#c4583a29}.add-player{font-family:var(--font-ui);font-weight:700;font-size:14px;color:var(--slate);background:transparent;border:2px dashed var(--panel-edge);border-radius:var(--radius-sm);padding:11px;cursor:pointer;transition:all .15s ease}.add-player:hover{border-color:var(--gold);color:var(--gold-deep);background:#d8a93f0f}.code-stamp{font-family:var(--font-display);font-weight:900;font-size:40px;letter-spacing:.28em;text-indent:.28em;text-align:center;color:var(--terracotta-deep);background:var(--parchment-deep);border:2px dashed var(--gold);border-radius:var(--radius);padding:14px 0;box-shadow:inset 0 2px 6px #3a2c1e1f}.invite-link{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--slate);background:var(--cream);border:2px solid var(--panel-edge);border-radius:var(--radius-sm);padding:9px 12px;word-break:break-all}.lobby-player{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);background:var(--cream);border:2px solid var(--panel-edge);font-weight:700;color:var(--ink)}.lobby-player .host-tag{margin-left:auto;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep)}.waiting-note{text-align:center;color:var(--ink-faint);font-weight:600;font-size:14px}.connecting{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:18px;color:var(--ink)}.spinner{width:46px;height:46px;border-radius:50%;border:5px solid rgba(58,44,30,.15);border-top-color:var(--terracotta);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 880px){.menu-screen{justify-content:center}.menu-stage{margin-left:0;align-items:center}.hero-head{text-align:center}.menu-veil{background:radial-gradient(80% 70% at 50% 44%,transparent 30%,rgba(96,112,126,.2) 78%,rgba(54,66,78,.46) 100%),linear-gradient(180deg,rgba(210,221,231,.45) 0%,transparent 26%,transparent 64%,rgba(48,60,72,.34) 100%)}}.game-layout{display:flex;height:100vh;overflow:hidden;background:var(--sky-bottom);font-family:var(--font-ui);color:var(--ink)}.board-area{flex:1;min-width:0;height:100%;position:relative;display:flex}.board-view-toggle{position:absolute;top:14px;right:14px;z-index:5;display:flex;gap:2px;padding:3px;border-radius:999px;border:1px solid var(--panel-edge);background:linear-gradient(180deg,var(--panel) 0%,var(--parchment) 100%);box-shadow:var(--shadow-sm),0 2px 10px #281e122e;cursor:pointer;font-family:var(--font-display);font-weight:900;font-size:12px;letter-spacing:.02em}.board-view-toggle span{padding:4px 11px;border-radius:999px;color:var(--ink-soft);transition:background .15s ease,color .15s ease}.board-view-toggle span.is-active{background:linear-gradient(180deg,var(--terracotta),var(--terracotta-deep));color:#fff5ec;box-shadow:0 2px #7f3420}.board-view-toggle:hover{filter:brightness(1.03)}.board-view-toggle:focus-visible{outline:2px solid var(--terracotta);outline-offset:2px}.game-sidebar{width:256px;flex-shrink:0;background:linear-gradient(180deg,var(--panel) 0%,var(--parchment) 100%);border-right:1px solid var(--panel-edge);box-shadow:3px 0 22px #281e1224;display:flex;flex-direction:column;overflow-y:auto;z-index:2}.game-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 14px;border-bottom:1px solid var(--panel-edge)}.game-brand .mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(180deg,var(--terracotta),var(--terracotta-deep));box-shadow:0 3px #7f3420,var(--shadow-sm);display:grid;place-items:center;color:#fff5ec;font-family:var(--font-display);font-weight:900;font-size:20px}.game-brand .name{font-family:var(--font-display);font-weight:900;font-size:21px;letter-spacing:-.01em;color:var(--ink)}.sidebar-section{border-bottom:1px solid var(--panel-edge);padding:6px 0}.sidebar-section:last-child{border-bottom:none}.game-timeline{width:232px;flex-shrink:0;background:linear-gradient(180deg,var(--panel) 0%,var(--parchment) 100%);border-left:1px solid var(--panel-edge);box-shadow:-3px 0 22px #281e1224;display:flex;flex-direction:column;overflow:hidden;z-index:2}.hud-label{font-family:var(--font-ui);font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}.hud-pad{padding:14px}.player-panel{display:flex;flex-direction:column;gap:7px}.player-chip{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:var(--radius-sm);background:var(--cream);border:2px solid transparent;box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.player-chip.active{transform:translate(2px);box-shadow:var(--shadow-md)}.player-chip .pname{flex:1;font-size:14px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-chip.active .pname{font-weight:900}.player-chip .pscore{font-family:var(--font-display);font-weight:900;font-size:18px;color:var(--terracotta-deep);font-variant-numeric:tabular-nums}.player-chip .pmeeples{display:flex;align-items:center;gap:3px;color:var(--ink-soft);font-size:12px;font-weight:700;font-variant-numeric:tabular-nums}.turn-flag{margin-left:auto;font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.tile-preview{display:flex;flex-direction:column;align-items:center;gap:12px}.deck-pill{font-size:12px;font-weight:700;color:var(--ink-soft);background:var(--parchment-deep);padding:4px 12px;border-radius:var(--radius-pill)}.tile-frame{width:104px;height:104px;position:relative;border-radius:var(--radius-sm);padding:6px;background:linear-gradient(180deg,var(--city),#c9ad7a);box-shadow:var(--shadow-md),inset 0 1px #fff6}.tile-frame img{width:100%;height:100%;display:block;border-radius:4px;transition:transform .18s cubic-bezier(.2,.8,.2,1)}.tile-frame.empty{background:var(--parchment-deep);border:2px dashed var(--panel-edge);opacity:.7}.rotate-row{display:flex;gap:10px}.rotate-btn{width:46px;height:40px;font-size:22px;line-height:1;display:grid;place-items:center;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--ink);background:var(--cream);box-shadow:0 3px 0 var(--parchment-deep),var(--shadow-sm);transition:transform .08s ease,box-shadow .08s ease}.rotate-btn:hover{filter:brightness(1.04)}.rotate-btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--parchment-deep)}.controls{display:flex;flex-direction:column;gap:10px}.prompt{text-align:center;border-radius:var(--radius-sm);background:var(--cream);border:2px solid var(--panel-edge);padding:11px 10px}.prompt .who{font-family:var(--font-display);font-weight:900;font-size:16px;color:var(--ink)}.prompt .what{font-size:12px;font-weight:600;color:var(--ink-soft);margin-top:2px}.btn-danger{color:var(--terracotta-deep);background:#c4583a14;box-shadow:inset 0 0 0 2px #c4583a4d}.btn-danger:active{transform:translateY(2px);box-shadow:inset 0 0 0 2px #c4583a4d}.timeline-head{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 10px;border-bottom:1px solid var(--panel-edge);flex-shrink:0}.timeline-count{font-weight:800;font-size:12px;color:var(--ink-faint);background:var(--parchment-deep);padding:2px 9px;border-radius:var(--radius-pill)}.timeline-scroll{flex:1;overflow-y:auto;padding:10px}.timeline-empty{color:var(--ink-faint);font-size:13px;font-weight:600;padding:10px 4px;text-align:center}.move-card{padding:8px;margin-bottom:7px;border-radius:var(--radius-sm);background:var(--cream);border:1px solid var(--panel-edge);border-left-width:4px;box-shadow:var(--shadow-sm);animation:pop .3s cubic-bezier(.2,.8,.2,1) both}.move-card .thumb{width:38px;height:38px;flex-shrink:0;overflow:hidden;border-radius:6px;background:var(--parchment-deep);box-shadow:inset 0 0 0 1px var(--panel-edge)}.move-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}.move-pname{font-size:13px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.move-coord{font-size:11px;font-weight:600;color:var(--ink-faint);margin-top:1px}.move-turn{font-size:11px;font-weight:800;color:var(--ink-faint);flex-shrink:0;font-variant-numeric:tabular-nums}.move-section-label{font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);border-top:1px solid var(--panel-edge);padding-top:5px;margin:6px 0 4px}.move-kv{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-soft);padding:1px 0}.move-reasoning{font-size:11px;color:var(--ink-soft);font-style:italic;line-height:1.5}.endgame-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 100% at 50% 0%,#60707e8c,#281e12c7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeUp .4s ease both}.endgame-card{width:min(420px,92vw);padding:30px 34px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px}.endgame-trophy{font-size:52px;line-height:1;animation:pop .5s cubic-bezier(.2,.8,.2,1) .1s both;filter:drop-shadow(0 6px 8px rgba(120,90,20,.4))}.endgame-title{font-family:var(--font-display);font-weight:900;font-size:30px;color:var(--ink)}.endgame-winner{font-size:15px;font-weight:700;color:var(--ink-soft)}.endgame-winner b{color:var(--terracotta-deep)}.score-table{width:100%;display:flex;flex-direction:column;gap:8px}.score-row{display:flex;align-items:center;gap:11px;padding:10px 13px;border-radius:var(--radius-sm);background:var(--cream);border:2px solid var(--panel-edge)}.score-row.first{background:linear-gradient(180deg,#fbedc4,#f4dca0);border-color:var(--gold);box-shadow:var(--shadow-sm)}.score-row .rank{width:22px;font-family:var(--font-display);font-weight:900;font-size:16px;color:var(--ink-faint);text-align:center}.score-row.first .rank{color:var(--gold-deep)}.score-row .sdot{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:inset 0 0 0 2px #00000026}.score-row .sname{flex:1;text-align:left;font-weight:700;color:var(--ink)}.score-row .sscore{font-family:var(--font-display);font-weight:900;font-size:20px;color:var(--ink);font-variant-numeric:tabular-nums}.endgame-actions{display:flex;gap:10px;width:100%}.exit-fab{position:fixed;bottom:24px;right:24px;z-index:100}
