@import"https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=Nunito:wght@600;700;800&display=swap";:root{color-scheme:light;--ink: #2B2233;--ink-2: #6B5E72;--surface: #FFFFFF;--surface-cream: #FFF6E0;--surface-soft: #FFFDF8;--hairline: #EDE7F2;--coral: #FF6B5E;--coral-sh: #C9483D;--sunny: #FFC93C;--sunny-sh: #D6A015;--grass: #4CC36A;--grass-sh: #379A52;--sky: #4AA8FF;--sky-sh: #2E7FCC;--grape: #A06CF0;--grape-sh: #7C46C7;--danger: #E23B2E;--danger-sh: #B22D22;--neutral: #C9C2D0;--neutral-sh: #9D94A8;--gold: #FFCB3A;--gold-deep: #F0A92E;--p1: #FF5A52;--p2: #4AA8FF;--p3: #4CC36A;--p4: #FF9F40;--t-forest: #2E8B57;--t-hills: #FF7A4D;--t-pasture: #BDE26A;--t-fields: #FFCB3A;--t-mountains: #9AA7B4;--t-desert: #ECD9A8;--token-bg: #FFF6E0;--redno: #D8392B;--outline: 3px solid var(--ink);--outline-w: 3px;--outline-w-thin: 2.5px;--ink-stroke: 2.5;--shadow: 0 5px 0 rgba(43, 34, 51, .18);--shadow-sm: 0 3px 0 rgba(43, 34, 51, .16);--shadow-lg: 0 8px 0 rgba(43, 34, 51, .22);--shadow-modal: 0 10px 0 rgba(43, 34, 51, .3);--radius: 16px;--radius-lg: 22px;--radius-xl: 28px;--radius-pill: 999px;--head: "Baloo 2", "Trebuchet MS", system-ui, sans-serif;--body: "Nunito", system-ui, -apple-system, "Segoe UI", sans-serif;--mono: "Baloo 2", ui-monospace, Menlo, monospace;--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:linear-gradient(160deg,#9bd7ff,#c9ecff);color:var(--ink);font-family:var(--body);font-weight:700;font-size:15px;line-height:1.4;-webkit-font-smoothing:antialiased}.app{height:100%;display:flex;flex-direction:column}h1,h2,h3{font-family:var(--head);font-weight:800;margin:0}button{font:inherit}:focus-visible{outline:3px solid var(--sky);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important}}.btn{font-family:var(--head);font-weight:700;font-size:14px;color:var(--ink);background:var(--surface);border:var(--outline);border-radius:var(--radius-pill);box-shadow:var(--shadow);padding:10px 18px;min-height:46px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;line-height:1.05;-webkit-user-select:none;user-select:none;transition:transform .08s ease,box-shadow .08s ease}.btn:hover:not(:disabled):not(.btn-disabled){transform:translateY(2px);box-shadow:var(--shadow-sm)}.btn:active:not(:disabled):not(.btn-disabled){transform:translateY(3px);box-shadow:0 2px #2b22332e}.btn-primary{background:var(--coral);color:#fff;box-shadow:0 5px 0 var(--coral-sh)}.btn-primary:hover:not(:disabled),.btn-primary:active:not(:disabled){box-shadow:0 2px 0 var(--coral-sh)}.btn-build{background:var(--grass);color:#fff;box-shadow:0 5px 0 var(--grass-sh)}.btn-build:hover,.btn-build:active{box-shadow:0 2px 0 var(--grass-sh)}.btn-trade{background:var(--sky);color:#fff;box-shadow:0 5px 0 var(--sky-sh)}.btn-trade:hover,.btn-trade:active{box-shadow:0 2px 0 var(--sky-sh)}.btn-dev{background:var(--grape);color:#fff;box-shadow:0 5px 0 var(--grape-sh)}.btn-dev:hover,.btn-dev:active{box-shadow:0 2px 0 var(--grape-sh)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 5px 0 var(--danger-sh)}.btn-danger:hover,.btn-danger:active{box-shadow:0 2px 0 var(--danger-sh)}.btn-ghost,.btn-quiet{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}.btn-quiet{font-weight:700}.btn-disabled,.btn:disabled{background:#e7e1ec;color:#a99fb0;border-color:#c5bcd0;box-shadow:0 5px #d4cbdc;cursor:not-allowed}.btn-disabled:hover,.btn:disabled:hover{transform:none;box-shadow:0 5px #d4cbdc}.btn-pressed{transform:translateY(3px);box-shadow:0 2px 0 var(--coral-sh)!important}.btn.active{background:var(--sunny);color:var(--ink);box-shadow:0 5px 0 var(--sunny-sh)}.btn-small{min-height:36px;padding:5px 12px;font-size:13px;border-width:var(--outline-w-thin);box-shadow:var(--shadow-sm)}.btn-small.btn-primary{box-shadow:0 4px 0 var(--coral-sh)}.btn-small.btn-danger{box-shadow:0 4px 0 var(--danger-sh)}.btn-wide{width:100%;margin-top:12px}.eyebrow{font-family:var(--head);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}.dim{color:var(--ink-2);font-weight:700}.tag{font-family:var(--body);font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;border:2px solid #DFD8E6;background:#f0ecf4;color:var(--ink-2);border-radius:8px;padding:1px 6px;margin-left:6px;flex-shrink:0}.tag-you,.tag-host{background:var(--sunny);border-color:var(--ink);color:var(--ink)}.tag-bot{background:var(--grape);border-color:var(--ink);color:#fff}.tag-ready{background:var(--grass);border-color:var(--ink);color:#fff}.swatch{width:16px;height:16px;border-radius:5px;border:2.5px solid var(--ink);display:inline-block;flex:none}.pdot{width:24px;height:24px;border-radius:50%;border:2.5px solid var(--ink);flex-shrink:0;box-shadow:inset 0 -2px #2b22332e}.panel,.card{background:var(--surface);border:var(--outline);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:16px}.panel-title,.card-title{font-family:var(--head);font-weight:800;font-size:17px;display:flex;align-items:center;gap:8px;margin-bottom:13px}.field{display:block;margin-bottom:14px}.field-label{display:block;font-family:var(--head);font-weight:700;font-size:12px;color:var(--ink-2);margin-bottom:6px}input,select,.input,.select{width:100%;font-family:var(--head);font-weight:700;font-size:16px;color:var(--ink);background:var(--surface-soft);border:var(--outline);border-radius:var(--radius);padding:11px 14px;min-height:46px;box-shadow:inset 0 2px #2b22330f}select,.select{background:var(--surface);box-shadow:var(--shadow-sm);cursor:pointer}input::placeholder{color:#bcb2c6}.code-input{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;text-align:center}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface-soft);border:var(--outline-w-thin) solid var(--ink);border-radius:var(--radius);padding:11px 14px;box-shadow:var(--shadow-sm);font-family:var(--head);font-weight:700;font-size:14px}.switch{width:52px;height:30px;border-radius:var(--radius-pill);border:2.5px solid var(--ink);position:relative;flex-shrink:0;transition:background .15s ease}.switch-on,.switch.on{background:var(--grass)}.switch-off,.switch.off{background:#dad3e0}.switch-knob,.switch .knob{position:absolute;top:2px;width:22px;height:22px;border-radius:50%;background:#fff;border:2px solid var(--ink);transition:left .15s ease}.switch-on .switch-knob,.switch.on .knob{left:25px}.switch-off .switch-knob,.switch.off .knob{left:2px}.stepper{display:flex;align-items:center;gap:12px}.step-btn{width:44px;height:44px;border-radius:13px;border:2.5px solid var(--ink);background:var(--sky);color:#fff;font-family:var(--head);font-weight:800;font-size:26px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 3px 0 var(--sky-sh)}.step-btn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--sky-sh)}.step-val{font-family:var(--head);font-weight:800;font-size:26px;min-width:48px;text-align:center;background:var(--surface-cream);border:2.5px solid var(--ink);border-radius:13px;padding:6px 0}.toasts{position:fixed;bottom:calc(18px + var(--safe-bottom));left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:90;width:min(92vw,420px);pointer-events:none}.toast{background:var(--surface);border:var(--outline);color:var(--ink);font-weight:800;border-radius:var(--radius);box-shadow:var(--shadow);padding:11px 16px;text-align:center;animation:toast-in .18s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}}.conn-banner{background:var(--danger);color:#fff;font-weight:800;text-align:center;padding:7px;font-size:13px;border-bottom:var(--outline)}.home{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:22px;background:linear-gradient(165deg,#ffe3b0,#ffc78a)}.home-hero{text-align:center}.brand{display:flex;align-items:center;justify-content:center;gap:11px}.emblem{filter:drop-shadow(0 5px 0 rgba(43,34,51,.18));margin-bottom:-2px;flex-shrink:0}.logo-badge{width:54px;height:54px;background:var(--coral);border:var(--outline);border-radius:16px;box-shadow:0 5px 0 var(--coral-sh);display:flex;align-items:center;justify-content:center;transform:rotate(-4deg)}.wordmark{font-family:var(--head);font-weight:800;font-size:clamp(40px,11vw,64px);letter-spacing:.01em;color:var(--ink);line-height:1;text-shadow:0 3px 0 rgba(255,255,255,.6)}.wordmark-accent,.wordmark .o-accent{color:var(--coral)}.wordmark:first-letter{color:var(--ink)}.tagline{color:var(--ink-2);font-weight:700;margin:8px 0 0;font-size:15px}.home-card{width:min(92vw,400px);background:var(--surface);border:var(--outline);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-lg)}.home-card .btn-primary{width:100%}.home-divider{display:flex;align-items:center;gap:12px;color:var(--ink-2);font-family:var(--head);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin:16px 0}.home-divider:before,.home-divider:after{content:"";flex:1;height:3px;border-radius:2px;background:var(--hairline)}.join-row{display:flex;gap:8px}.home-foot{color:var(--ink-2);font-weight:700;font-size:13px}.lobby{flex:1;padding:16px;max-width:1100px;margin:0 auto;width:100%;background:linear-gradient(165deg,#ffe3b0,#ffc78a)}.lobby-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;flex-wrap:wrap}.room-code{background:var(--surface-cream);border:var(--outline);border-radius:18px;padding:9px 16px 8px;box-shadow:inset 0 -3px #2b223314}.room-code-lbl{display:block;font-family:var(--body);font-weight:800;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}.room-code-value,.room-code .code{font-family:var(--mono);font-weight:800;font-size:clamp(26px,6vw,36px);letter-spacing:.16em;color:var(--ink);line-height:1.05}.lobby-tabs{display:flex;background:var(--surface);border:var(--outline);border-radius:18px;padding:5px;gap:5px;box-shadow:var(--shadow);margin-bottom:16px}.lobby-tab{flex:1;text-align:center;font-family:var(--head);font-weight:800;font-size:15px;padding:11px 0;border-radius:12px;color:var(--ink-2);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.lobby-tab.active{background:var(--sunny);color:var(--ink);border:2.5px solid var(--ink);box-shadow:var(--shadow-sm)}.lobby-tab-count{font-size:12px;background:var(--ink);color:#fff;border-radius:var(--radius-pill);min-width:18px;padding:1px 5px;line-height:1.3}.lobby-tab.active .lobby-tab-count{background:var(--coral)}.lobby-grid{display:grid;grid-template-columns:1fr;gap:14px}.lobby{padding-bottom:96px}.lobby-grid>section{display:none}.lobby-grid>section.active{display:block}.lobby-startbar{position:fixed;left:0;right:0;bottom:0;z-index:20;padding:12px 14px calc(12px + env(safe-area-inset-bottom));background:linear-gradient(180deg,#ffdcaa00,#ffd9a6 60%);display:flex}.lobby-startbar .btn{flex:1}.lobby-startbar .waiting{flex:1;text-align:center}.player-list{list-style:none;margin:0 0 10px;padding:0;display:flex;flex-direction:column;gap:10px}.player-row{display:flex;align-items:center;gap:11px;background:#fbfafc;border:2.5px solid var(--ink);border-radius:var(--radius);padding:11px 12px;box-shadow:0 3px #2b22331a}.player-row-host,.player-row.host{background:linear-gradient(180deg,#fff9ea,#fff1cf)}.player-nick,.pname{flex:1;font-weight:800;font-size:16px;color:var(--ink);display:flex;align-items:center;gap:7px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.presence,.presence-on,.presence-off{font-size:12px;font-weight:800}.presence-on,.presence.on{color:var(--grass-sh)}.presence-off,.presence.off{color:var(--ink-2)}.row-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.kick{width:36px;height:36px;border-radius:50%;border:2.5px solid var(--ink);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.kick:active{background:#ffe2de}.add-bot{display:flex;align-items:center;gap:12px;background:repeating-linear-gradient(135deg,#fbfafc,#fbfafc 10px,#f3f0f6 10px,#f3f0f6 20px);border:2.5px dashed var(--ink);border-radius:var(--radius);padding:13px 12px;cursor:pointer;color:var(--ink-2);font-weight:800;font-size:15px;margin:10px 0}.add-bot-plus{width:26px;height:26px;border-radius:50%;border:2.5px solid var(--ink);background:var(--grass);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:20px;line-height:1;flex-shrink:0}.settings{display:flex;flex-direction:column;gap:12px}.setting{margin-bottom:0}.setting>span{flex:1}.setting-lbl{font-weight:800;font-size:12px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;display:block}.setting select{width:100%}.setting-check{display:flex;align-items:center;justify-content:flex-start;gap:12px}.setting-check input{width:24px;height:24px;min-height:0;flex:none;accent-color:var(--grass);box-shadow:none}.setting-check em{display:block;font-style:normal;font-size:12px;font-weight:700;color:var(--ink-2)}.segmented{display:flex;background:#f3f0f6;border:2.5px solid var(--ink);border-radius:14px;padding:4px;gap:4px}.seg{flex:1;text-align:center;font-family:var(--head);font-weight:800;font-size:14px;padding:10px 0;border-radius:10px;color:var(--ink-2);cursor:pointer;border:2px solid transparent}.seg-active,.seg.active{background:var(--sunny);color:var(--ink);border:2px solid var(--ink);box-shadow:var(--shadow-sm)}.waiting{text-align:center;color:var(--ink-2);font-weight:700;padding:10px 0 2px}.cta-bar{flex-shrink:0;background:#fff7e7eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-top:var(--outline);padding:12px 16px calc(16px + var(--safe-bottom));box-shadow:0 -6px 14px #2b22331a}.btn-start{background:var(--coral);color:#fff;border:var(--outline);border-radius:var(--radius-pill);padding:16px 0;font-family:var(--head);font-weight:800;font-size:22px;letter-spacing:.02em;box-shadow:0 6px 0 var(--coral-sh);width:100%;display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer}.btn-start:active{transform:translateY(4px);box-shadow:0 2px 0 var(--coral-sh)}.btn-start:disabled{background:#e7e1ec;color:#a99fb0;border-color:#c5bcd0;box-shadow:0 6px #d4cbdc;cursor:not-allowed}.host-note{text-align:center;font-size:12px;font-weight:700;color:var(--ink-2);margin-top:8px}.chatbox{display:flex;flex-direction:column;min-height:220px;max-height:320px}.chat-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:5px;padding-right:4px}.chat-empty{color:var(--ink-2);font-weight:700;font-size:13px;margin:auto}.chat-line{font-size:14px;font-weight:700;overflow-wrap:anywhere}.chat-nick{font-family:var(--head);font-weight:800;margin-right:6px}.chat-text{color:var(--ink)}.chat-form{display:flex;gap:8px;margin-top:10px}.voicebar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 0 2px}.voice-peers{display:flex;gap:6px;flex-wrap:wrap;flex:1}.voice-chip{font-family:var(--head);font-weight:700;font-size:12.5px;background:#fff;border:var(--outline);border-radius:var(--radius-pill);padding:5px 13px 5px 8px;display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow-sm)}.voice-chip.speaking{border-color:var(--grass);box-shadow:0 0 0 3px #4cc36a59,var(--shadow-sm)}.voice-chip-mic{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--ink);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff}.voice-chip.speaking .voice-chip-mic{background:var(--grass)}.game{flex:1;display:flex;flex-direction:column;min-height:0;position:relative;background:linear-gradient(160deg,#9bd7ff,#c9ecff)}.statusbar{flex:0 0 auto;height:30px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;font-family:var(--head);font-weight:800;font-size:14px;color:var(--ink)}.topbar{display:flex;align-items:center;gap:8px;padding:6px 12px 8px;flex:none;overflow-x:auto;scrollbar-width:none}.topbar::-webkit-scrollbar{display:none}.iconbtn{flex:0 0 auto;width:42px;height:42px;border-radius:14px;border:var(--outline);background:var(--surface);box-shadow:0 4px #2b22332e;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);-webkit-user-select:none;user-select:none}.iconbtn:active{transform:translateY(2px);box-shadow:0 2px #2b22332e}.turnbanner{flex:1;min-width:0;height:42px;background:var(--surface);border:var(--outline);border-radius:var(--radius-pill);box-shadow:var(--shadow);display:flex;align-items:center;gap:8px;padding:0 12px}.turnbanner-dot{flex:0 0 auto;width:16px;height:16px;border-radius:50%;background:var(--p1);border:2.5px solid var(--ink)}.turnbanner-text{font-weight:800;font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.turnbanner-text b{font-family:var(--head);font-weight:800;color:var(--coral)}.mictoggle{position:relative;flex:0 0 auto;width:42px;height:42px;border-radius:50%;border:var(--outline);background:var(--grass);box-shadow:0 4px 0 var(--grass-sh);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;-webkit-user-select:none;user-select:none}.mictoggle:active{transform:translateY(2px);box-shadow:0 2px 0 var(--grass-sh)}.mictoggle-pulse:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:3px solid var(--grass);animation:speak-pulse 1.4s ease-out infinite;pointer-events:none}@keyframes speak-pulse{0%{transform:scale(.92);opacity:.9}70%{transform:scale(1.26);opacity:0}to{transform:scale(1.26);opacity:0}}.railwrap{flex:0 0 auto;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:8px 12px 6px;-webkit-mask-image:linear-gradient(90deg,#000 90%,transparent 100%);mask-image:linear-gradient(90deg,#000 90%,transparent 100%)}.railwrap::-webkit-scrollbar{display:none}.rail{display:flex;gap:8px;width:max-content;padding-right:8px}.pcard{position:relative;flex:0 0 auto;display:flex;align-items:center;gap:8px;background:var(--surface);border:var(--outline);border-radius:18px;padding:7px 10px;font-size:13px;box-shadow:0 4px #2b223329}.pcard-current,.pcard.current{background:#fff7e6;box-shadow:0 0 0 3px var(--sunny),0 6px #2b223333}.pcard-current:after,.pcard.current:after{content:"TURN";position:absolute;top:-11px;left:12px;background:var(--coral);color:#fff;font-family:var(--head);font-weight:800;font-size:10px;letter-spacing:.5px;padding:2px 8px;border:2.5px solid var(--ink);border-radius:20px;box-shadow:0 2px 0 var(--coral-sh)}.pcard-disconnected,.pcard.disconnected{opacity:.55}.avwrap{position:relative;flex:0 0 auto}.avatar{position:relative;width:40px;height:40px;border-radius:50%;border:var(--outline);display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:18px;color:#fff;box-shadow:0 3px #2b223333}.avatar-speaking:before,.avatar-speaking:after,.avwrap.speaking:before,.avwrap.speaking:after{content:"";position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border-radius:50%;border:3px solid var(--grass);pointer-events:none}.avatar-speaking:before,.avwrap.speaking:before{animation:speak-pulse 1.4s ease-out infinite}.avatar-speaking:after,.avwrap.speaking:after{animation:speak-pulse 1.4s ease-out infinite .7s}.micbadge{position:absolute;bottom:-3px;right:-5px;width:19px;height:19px;border-radius:50%;border:2.5px solid var(--ink);background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px #2b223338;z-index:2}.micbadge-on,.micbadge.on{background:var(--grass)}.micbadge-off,.micbadge.off{background:var(--coral)}.pinfo{flex:1;min-width:0}.vpline{display:flex;align-items:baseline;gap:3px}.vp{font-family:var(--head);font-weight:800;font-size:20px;color:var(--ink);line-height:1;min-width:18px;text-align:center}.vplabel{font-size:9px;font-weight:800;color:var(--ink-2)}.pmeta,.pstats{display:flex;align-items:center;gap:5px;margin-top:3px;color:var(--ink-2);font-size:12px;font-weight:700}.pmeta-mini{display:inline-flex;align-items:center;gap:3px;background:#fff;border:2px solid var(--ink);border-radius:10px;padding:0 5px 0 3px;font-weight:800;font-size:11px;color:var(--ink)}.badges{position:absolute;top:-9px;right:8px;display:flex;gap:4px}.award-badge{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--ink);display:flex;align-items:center;justify-content:center;box-shadow:0 2px #2b22332e}.award-road{background:var(--grass)}.award-army{background:var(--grape)}.pcard .award{color:var(--grape-sh);font-weight:800;font-size:11px}.pcard .turn-timer{font-family:var(--head);font-variant-numeric:tabular-nums;font-size:11px;color:var(--sky-sh);font-weight:800;white-space:nowrap}.pcard .turn-timer.urgent{color:var(--danger)}.pcard .speak-dot{width:8px;height:8px;border-radius:50%;background:transparent;flex:none}.pcard .speak-dot.on{background:var(--grass);box-shadow:0 0 8px var(--grass)}.board-wrap{flex:1 1 auto;min-height:0;position:relative;touch-action:none;overflow:hidden;display:flex;align-items:center;justify-content:center;margin:0}.board-svg{width:100%;height:100%;display:block;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 8px 0 rgba(43,34,51,.1))}.prompt{position:absolute;top:10px;left:50%;transform:translate(-50%);background:var(--surface);border:var(--outline);color:var(--ink);font-weight:800;border-radius:var(--radius-pill);padding:9px 18px;font-size:14px;z-index:5;white-space:nowrap;display:flex;gap:10px;align-items:center;box-shadow:var(--shadow)}.prompt-urgent{border-color:var(--coral);box-shadow:0 0 0 3px #ff6b5e59,var(--shadow)}.announce-stack{position:absolute;top:60px;left:50%;transform:translate(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none;width:min(94vw,520px)}.announce{background:var(--surface);border:var(--outline);color:var(--ink);font-weight:800;border-radius:var(--radius-pill);padding:8px 18px;font-size:15px;text-align:center;box-shadow:var(--shadow);animation:announce-in .22s ease-out}.announce-good{border-color:var(--grass);box-shadow:0 0 0 3px #4cc36a4d,var(--shadow)}.announce-bad{border-color:var(--danger);box-shadow:0 0 0 3px #e23b2e4d,var(--shadow)}@keyframes announce-in{0%{opacity:0;transform:translateY(-10px) scale(.96)}}.delta-chip{position:absolute;top:-10px;right:-6px;font-family:var(--head);font-weight:800;font-size:16px;padding:1px 8px;border:2.5px solid var(--ink);border-radius:var(--radius-pill);pointer-events:none;animation:delta-float 1.6s ease-out forwards}.gain{background:var(--grass);color:#fff}.loss{background:var(--danger);color:#fff}@keyframes delta-float{0%{opacity:0;transform:translateY(6px)}15%{opacity:1}to{opacity:0;transform:translateY(-26px)}}.trade-popups{position:absolute;bottom:10px;left:50%;transform:translate(-50%);z-index:6;display:flex;flex-direction:column;gap:8px;width:min(94vw,460px)}.trade-popup{background:var(--surface);border:var(--outline);border-radius:var(--radius);padding:10px 12px;box-shadow:var(--shadow);animation:toast-in .18s ease-out}.trade-popup-body{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;font-weight:700}.trade-popup-text{flex:1}.trade-declines{font-size:12px;font-weight:700;color:var(--ink-2);margin-bottom:6px;padding-left:4px}.trade-popup-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center;justify-content:flex-end}.handtoggle{flex:0 0 auto;display:flex;gap:6px;margin:6px 12px 0;padding:5px;background:var(--surface);border:var(--outline);border-radius:18px;box-shadow:0 4px #2b223329}.handtoggle .seg,.handtoggle .seg-active{display:flex;align-items:center;justify-content:center;gap:6px;height:38px;border-radius:13px;font-family:var(--body);font-weight:800;font-size:14px;color:var(--ink-2)}.seg-count{min-width:22px;height:22px;padding:0 5px;border-radius:11px;background:#f0ecf4;border:2px solid #DFD8E6;display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:12px;color:var(--ink-2)}.seg-active .seg-count,.seg.active .seg-count{background:#fff;border:2px solid var(--ink);color:var(--ink)}.hand-wrap{flex:0 0 auto;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:8px 12px 6px}.hand-wrap::-webkit-scrollbar{display:none}.hand{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.handlabel{flex:0 0 auto;writing-mode:vertical-rl;transform:rotate(180deg);font-family:var(--head);font-weight:800;font-size:11px;color:var(--ink-2);letter-spacing:1px;margin-right:2px}.rescard{position:relative;flex:0 0 auto;min-width:56px;width:56px;height:74px;border-radius:14px;border:var(--outline);background:#fff;box-shadow:0 4px #2b22332e;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:6px 4px;font-weight:800;color:var(--ink);overflow:visible;transition:transform .12s ease,box-shadow .12s ease}.rescard:hover{transform:translateY(-3px);box-shadow:0 7px #2b223333}.rescard.bump{animation:card-bump .45s ease}@keyframes card-bump{35%{transform:translateY(-6px) scale(1.08)}}.rescard b{font-family:var(--head);font-weight:800;font-size:18px;background:#fff;border:2.5px solid var(--ink);border-radius:10px;min-width:26px;text-align:center;line-height:1;padding:1px 5px}.rescard-top,.rescard .restop{width:100%;flex:1;display:flex;align-items:center;justify-content:center}.rescard-label,.rescard .reslabel{width:100%;text-align:center;font-weight:800;font-size:11px;color:var(--ink)}.rescard-count,.rescard .rescount{position:absolute;top:-8px;right:-8px;min-width:24px;height:24px;padding:0 4px;background:var(--coral);color:#fff;border-radius:var(--radius-pill);border:2.5px solid var(--ink);box-shadow:0 2px 0 var(--coral-sh);display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:13px}.rescard-dev{background:#fff}.rescard-dev-held{box-shadow:0 0 0 3px var(--grape),0 4px 0 var(--grape-sh)}.rescard-dev-greyed{opacity:.5}.res-wood{--tint: var(--t-forest)}.res-brick{--tint: var(--t-hills)}.res-sheep{--tint: var(--t-pasture)}.res-wheat{--tint: var(--t-fields)}.res-ore{--tint: var(--t-mountains)}.res-wood,.res-brick,.res-sheep,.res-wheat,.res-ore{background:linear-gradient(var(--tint),var(--tint)) top / 100% 58% no-repeat,#fff}.hand-extra{display:flex;gap:8px;align-items:center;margin-left:auto;color:var(--ink-2);font-weight:800;font-size:13px}.bottombar,.actionbar{flex:none;background:var(--surface);border-top:var(--outline);border-radius:24px 24px 0 0;box-shadow:0 -5px #2b22331a;padding:12px 12px calc(12px + var(--safe-bottom));display:flex;flex-direction:column;gap:8px}.actions{display:flex;gap:8px;flex-wrap:wrap;align-items:stretch}.actions .btn{flex:1 1 auto;min-width:0;padding:8px 12px;font-size:14px;white-space:nowrap;flex-direction:column;gap:3px;min-height:52px}.cost{display:inline-flex;align-items:center;gap:3px;font-family:var(--head);font-size:11px;font-weight:800;letter-spacing:.02em;background:#ffffff52;border-radius:var(--radius-pill);padding:1px 6px}.btn:not(.btn-primary):not(.btn-build):not(.btn-trade):not(.btn-dev):not(.btn-danger) .cost{background:#f3f0f6;color:var(--ink-2)}.cost-chip{display:inline-flex;align-items:center;gap:4px;border:2.5px solid var(--ink);border-radius:var(--radius-pill);padding:2px 9px 2px 3px;background:#fff;box-shadow:0 2px #2b223324;font-family:var(--head);font-weight:800;font-size:13px}.dice{display:flex;gap:6px;flex:0 0 auto;align-items:center}.die{width:38px;height:38px;background:#fff;border:var(--outline);border-radius:11px;box-shadow:0 4px #2b223333;display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:18px;color:var(--ink)}.die-rolled,.die.rolled{animation:die-tumble .55s cubic-bezier(.22,.9,.32,1.2) backwards}@keyframes die-tumble{0%{transform:translateY(-16px) rotate(-200deg) scale(.6);opacity:0}55%{transform:translateY(2px) rotate(10deg) scale(1.05);opacity:1}to{transform:none}}.drawer-toggle{position:absolute;right:10px;top:10px;z-index:6}.drawer{position:absolute;top:0;right:0;height:100%;width:min(94vw,360px);background:var(--surface);border-left:var(--outline);z-index:8;display:flex;flex-direction:column;padding:12px;gap:8px;box-shadow:-8px 0 #2b22331a}.drawer-tabs{display:flex;gap:6px}.drawer-tabs .btn{flex:1}.drawer .chatbox{flex:1;max-height:none;min-height:0}.drawer-footer{display:flex;gap:8px;justify-content:space-between;border-top:2.5px solid var(--hairline);padding-top:10px}.log-scroll{flex:1;overflow-y:auto;font-size:13px;font-weight:700;display:flex;flex-direction:column;gap:5px}.log-line{color:var(--ink-2)}.log-line b{color:var(--ink);font-family:var(--head);font-weight:800}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2b22338c;z-index:40;display:flex;align-items:center;justify-content:center;padding:16px}.modal{position:relative;background:var(--surface);border:var(--outline);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);width:min(94vw,460px);max-height:86vh;overflow-y:auto;padding:20px 22px 22px}.modal h3{font-family:var(--head);font-weight:800;font-size:21px;margin:4px 0 3px}.modal .sub,.modal-sub{color:var(--ink-2);font-weight:700;font-size:13px;margin:0 0 15px}.modal-ribbon{position:absolute;top:-16px;left:24px;background:var(--grape);color:#fff;border:var(--outline);border-radius:var(--radius-pill);padding:5px 16px;font-family:var(--head);font-weight:800;font-size:12px;box-shadow:0 4px #2b223340}.counter-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.counter-row .rescard{min-width:48px;width:48px;height:58px}.counter-row .btn{min-height:40px;width:40px;padding:0;font-size:20px}.count{font-family:var(--head);font-weight:800;font-size:20px;min-width:28px;text-align:center}.modal-actions{display:flex;gap:10px;margin-top:15px}.modal-actions .btn{flex:1}.steal-row,.offer-row{display:flex;align-items:center;gap:10px;background:var(--surface-soft);border:2.5px solid var(--ink);border-radius:var(--radius);padding:10px;margin-bottom:8px;box-shadow:var(--shadow-sm)}.trade-side{display:flex;gap:5px;flex-wrap:wrap;align-items:center}.trade-mini{border:2.5px solid var(--ink);border-radius:8px;padding:2px 8px;font-family:var(--head);font-size:12px;font-weight:800;color:var(--ink);background:#fff;display:inline-flex;align-items:center;gap:3px}.trade-mini.res-wood{box-shadow:inset 0 -6px #2e8b5780}.trade-mini.res-brick{box-shadow:inset 0 -6px #ff7a4d80}.trade-mini.res-sheep{box-shadow:inset 0 -6px #bde26a99}.trade-mini.res-wheat{box-shadow:inset 0 -6px #ffcb3a99}.trade-mini.res-ore{box-shadow:inset 0 -6px #9aa7b499}.devcard-grid{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin:6px 0}.devcard{display:flex;flex-direction:column;align-items:center;gap:6px}.devcard-frame{position:relative;width:96px}.devcard-art{width:100%;display:block;filter:drop-shadow(0 4px 0 rgba(43,34,51,.18));transition:transform .15s ease}.devcard-art:hover{transform:translateY(-4px) rotate(-1.2deg)}.count-badge{position:absolute;top:-8px;right:-8px;background:var(--coral);color:#fff;font-family:var(--head);font-weight:800;font-size:13px;border-radius:var(--radius-pill);padding:2px 9px;border:2.5px solid var(--ink);box-shadow:0 2px 0 var(--coral-sh)}.devcard-row{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface-soft);border:2.5px solid var(--ink);border-radius:var(--radius);padding:10px 12px;margin-bottom:8px;box-shadow:var(--shadow-sm)}.devcard-row .name{font-family:var(--head);font-weight:800;font-size:16px}.devcard-row .hint{font-size:12px;font-weight:700;color:var(--ink-2)}.picker-row{display:flex;gap:11px;margin-bottom:14px;flex-wrap:wrap}.picker{flex:1;min-width:76px;border:var(--outline);border-radius:var(--radius);padding:10px 6px 9px;text-align:center;background:var(--surface-soft);box-shadow:var(--shadow-sm);position:relative;cursor:pointer}.picker-sel,.picker.sel{background:#fff1c2;box-shadow:0 4px 0 var(--sunny)}.picker-ic,.picker .p-ic{width:48px;height:48px;margin:0 auto 5px;border:var(--outline);border-radius:13px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.picker-lbl,.picker .p-lbl{font-family:var(--head);font-weight:800;font-size:11px}.picker-cnt,.picker .p-cnt{position:absolute;top:-9px;right:-7px;width:26px;height:26px;border-radius:50%;background:var(--coral);color:#fff;border:2.5px solid var(--ink);font-family:var(--head);font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 0 var(--coral-sh)}.picker-cnt-zero,.picker .p-cnt.zero{background:#e7e1ec;color:#a99fb0;border-color:#c5bcd0;box-shadow:0 2px #d4cbdc}.winner-hero{position:relative;background:linear-gradient(165deg,#fff7e6,#ffeab8);border:var(--outline);border-radius:var(--radius-xl);box-shadow:var(--shadow);padding:14px 16px 18px;overflow:hidden;text-align:center}.winner-rays{position:absolute;top:42px;left:50%;width:300px;height:300px;transform:translate(-50%);z-index:0;pointer-events:none;animation:rays-spin 26s linear infinite;opacity:.55}@keyframes rays-spin{to{transform:translate(-50%) rotate(360deg)}}.winner-confetti{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.winner-confetti span{position:absolute;width:9px;height:13px;border:2px solid var(--ink);border-radius:3px;top:-16px;animation:confetti-fall linear infinite}@keyframes confetti-fall{0%{transform:translateY(-10px) rotate(0);opacity:0}12%{opacity:1}to{transform:translateY(150px) rotate(420deg);opacity:0}}.winner-crown{width:78px;height:46px;margin:0 auto 2px;display:block;position:relative;z-index:3}.winline{position:relative;z-index:3;font-family:var(--head);font-weight:800;font-size:32px;line-height:1.02;color:var(--ink);margin:2px 0 12px}.winline b{color:var(--p1);font-weight:800}.heroav{position:relative;width:108px;height:108px;margin:0 auto;z-index:3}.heroav-crown{position:absolute;top:-30px;left:50%;transform:translate(-50%);width:72px;height:48px;z-index:4;filter:drop-shadow(0 3px 0 rgba(43,34,51,.18))}.heroav .av{width:108px;height:108px;border-radius:50%;border:4px solid var(--ink);background:var(--p1);box-shadow:0 6px 0 var(--coral-sh),inset 0 -8px #0000001f;display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:52px;color:#fff;line-height:1}.vpbig{position:relative;z-index:3;display:inline-flex;align-items:center;gap:7px;margin-top:14px;background:var(--ink);color:#fff;border:var(--outline);border-radius:var(--radius-pill);padding:6px 16px 6px 12px;box-shadow:0 4px #2b223338;font-family:var(--head);font-weight:800}.vpbig .num{font-size:26px;line-height:1}.vpbig .lab{font-size:14px;color:var(--gold);letter-spacing:.5px}.standings{display:flex;flex-direction:column}.sectiontitle{display:flex;align-items:center;gap:8px;margin:18px 4px 9px;font-family:var(--head);font-weight:800;font-size:15px;letter-spacing:1px;color:var(--ink-2);text-transform:uppercase}.sectiontitle:before,.sectiontitle:after{content:"";flex:1;height:3px;border-radius:2px;background:#2b223329}.score-row{position:relative;display:flex;align-items:center;gap:10px;padding:9px 12px 9px 9px;background:var(--surface);border:var(--outline);border-radius:20px;box-shadow:0 4px #2b223329;margin-bottom:11px}.score-row-winner,.score-row.winner{background:linear-gradient(160deg,#fff7e6,#ffefcb);box-shadow:0 0 0 3px var(--gold),0 6px #2b223338}.rankbadge{flex:0 0 auto;width:34px;height:34px;border-radius:11px;border:var(--outline);display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:18px;color:#fff;box-shadow:0 3px #2b223333}.rank-1{background:var(--gold);color:var(--ink);box-shadow:0 3px 0 var(--gold-deep)}.rank-2{background:#c9d2dd;color:var(--ink);box-shadow:0 3px #9aa7b4}.rank-3{background:#d6a26a;color:var(--ink);box-shadow:0 3px #b07f49}.rank-4{background:var(--neutral);color:var(--ink);box-shadow:0 3px 0 var(--neutral-sh)}.ravwrap{position:relative;flex:0 0 auto}.ravatar{width:44px;height:44px;border-radius:50%;border:var(--outline);display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:20px;color:#fff;box-shadow:0 3px #2b223333,inset 0 -4px #0000001f}.score-mid{flex:1;min-width:0}.score-name{display:flex;align-items:center;gap:5px;font-weight:800;font-size:16px;color:var(--ink);line-height:1.1;white-space:nowrap}.breakdown{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.vchip{display:inline-flex;align-items:center;gap:3px;background:#f6f2fa;border:2px solid #E2DBEA;border-radius:9px;padding:1px 6px 1px 3px;font-weight:800;font-size:11px;color:var(--ink);line-height:1.3}.vchip b{font-family:var(--head);font-weight:800;color:var(--grass-sh)}.vchip-award{background:#f1e9fc;border-color:#dccaf6}.rvp{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;line-height:1;margin-left:2px}.rvp .n{font-family:var(--head);font-weight:800;font-size:30px;color:var(--ink);line-height:.9}.score-row-winner .rvp .n,.score-row.winner .rvp .n{color:var(--p1)}.rvp .u{font-size:9px;font-weight:800;color:var(--ink-2);letter-spacing:.5px;margin-top:2px}.stats-strip{display:flex;align-items:stretch;background:var(--surface);border:var(--outline);border-radius:18px;box-shadow:0 4px #2b223324;padding:9px 4px;margin-top:4px}.stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;padding:0 4px}.stat+.stat{border-left:2.5px solid var(--hairline)}.stat-value{display:flex;align-items:center;gap:4px;font-family:var(--head);font-weight:800;font-size:17px;color:var(--ink);line-height:1}.stat-label{font-size:9px;font-weight:800;color:var(--ink-2);letter-spacing:.4px;text-transform:uppercase;line-height:1.15}.winner-table{width:100%;border-collapse:collapse;margin:12px 0 4px}.winner-table td,.winner-table th{padding:9px 10px;text-align:left;border-bottom:2.5px solid var(--hairline);font-weight:700}.winner-table th{font-family:var(--head);font-weight:800;color:var(--ink-2);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.winner-table .crown{color:var(--gold-deep)}.hex{stroke:var(--ink);stroke-width:.12;stroke-linejoin:round}.hex-forest{fill:var(--t-forest)}.hex-hills{fill:var(--t-hills)}.hex-pasture{fill:var(--t-pasture)}.hex-fields{fill:var(--t-fields)}.hex-mountains{fill:var(--t-mountains)}.hex-desert{fill:var(--t-desert)}.terrain-motif{pointer-events:none}.token-disc{fill:var(--token-bg);stroke:var(--ink);stroke-width:.12}.token-num{font-family:var(--head);font-weight:800;fill:var(--ink);text-anchor:middle}.token-num-red,.token-num.red{fill:var(--redno)}.token-pip{fill:var(--ink)}.token-pip-red,.token-pip.red{fill:var(--redno)}.port-chip{fill:var(--token-bg);stroke:var(--ink);stroke-width:.12}.port-label{font-family:var(--head);font-weight:800;fill:var(--ink);text-anchor:middle;letter-spacing:.02em}.robber{transition:transform .6s cubic-bezier(.4,0,.2,1)}.robber-piece{fill:#41384c;stroke:var(--ink);stroke-width:.1;stroke-linejoin:round}.road-piece,.road-ink{stroke-linecap:round}.road-ink{stroke:var(--ink)}.road-new{stroke-dasharray:1;animation:road-draw .45s ease-out backwards}@keyframes road-draw{0%{stroke-dashoffset:1}to{stroke-dashoffset:0}}.building-piece,.building-ink{stroke:var(--ink);stroke-width:.14;stroke-linejoin:round;paint-order:stroke}.building-new{transform-box:fill-box;transform-origin:50% 85%;animation:piece-pop .4s cubic-bezier(.34,1.56,.64,1) backwards}@keyframes piece-pop{0%{transform:scale(0)}}.hex-hit{stroke:var(--sunny);stroke-width:.25;animation:hex-hit 1.9s ease-out forwards}@keyframes hex-hit{0%{fill:#ffc93c00;stroke-opacity:0}18%{fill:#ffc93c66;stroke-opacity:1}to{fill:#ffc93c00;stroke-opacity:0}}.hl,.hl-vertex,.hl-edge{fill:#ffc93c73;stroke:var(--ink);stroke-width:.12;cursor:pointer;animation:hl-pulse 1.4s ease-in-out infinite}.hl:hover,.hl-vertex:hover,.hl-edge:hover{fill:var(--sunny)}.hl-edge{fill:none;stroke:var(--sunny)}@keyframes hl-pulse{50%{stroke-opacity:.4}}@media(min-width:900px){body{font-size:16px}.lobby-grid{grid-template-columns:1.1fr 1fr 1fr;align-items:start}.lobby{padding-bottom:16px}.lobby-tabs{display:none}.lobby-grid>section{display:block}.lobby-startbar{position:static;background:none;padding:16px 0 0}.lobby-startbar .btn{flex:none;min-width:220px;margin:0 auto}.bottombar,.actionbar{flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap}.actions{flex:1 1 auto;flex-wrap:wrap}.actions .btn{flex:0 1 auto;flex-direction:row;min-height:46px}.hand{flex-wrap:nowrap}.rescard{width:62px;min-width:62px;height:84px}.die{width:44px;height:44px}.winline{font-size:38px}}@media(max-width:360px){.rescard{width:50px;min-width:50px;height:66px}.die{width:34px;height:34px;font-size:16px}.actions .btn{font-size:13px}}
