:root{--bg: #050508;--surface: #0C0E14;--surface-2: #14161F;--surface-3: #1B1E2A;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--blue: #3A8FFF;--blue-bright: #60AFFF;--orange: #FF8C00;--gold: #FFB740;--gold-deep: #E09A2A;--green: #39FF14;--yellow: #FFCC33;--red: #FF4040;--text: #FFFFFF;--muted: #8A8FA0;--subtle: rgba(255, 255, 255, .55);--shadow-ambient: 0 30px 80px rgba(0, 0, 0, .5);--shadow-tile: 0 1px 0 rgba(255, 255, 255, .04), 0 10px 30px rgba(0, 0, 0, .35);--glow-blue: 0 0 0 1px rgba(58, 143, 255, .55), 0 0 24px rgba(58, 143, 255, .22);--glow-gold: 0 0 0 1px rgba(255, 183, 64, .65), 0 0 24px rgba(255, 183, 64, .18);--glow-green: 0 0 0 1px rgba(57, 255, 20, .45), 0 0 30px rgba(57, 255, 20, .18);--glow-yellow: 0 0 0 1px rgba(255, 204, 51, .6), 0 0 30px rgba(255, 204, 51, .25);--glow-red: 0 0 0 1.5px rgba(255, 64, 64, .8), 0 0 36px rgba(255, 64, 64, .32);--radius-tile: 16px;--radius-btn: 10px;--radius-sm: 8px;--f-display: "Orbitron", ui-sans-serif, system-ui, sans-serif;--f-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;--f-body: "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif}*,*:before,*:after{box-sizing:border-box}html,body{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--f-body);font-size:15px;line-height:1.4;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;overscroll-behavior:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}button{font-family:inherit;color:inherit;cursor:pointer}input{font-family:inherit}h1,h2,h3{margin:0;font-family:var(--f-display);font-weight:700;letter-spacing:.02em}#app{height:100vh;height:100dvh}.shell{position:relative;display:grid;grid-template-rows:auto auto 1fr;height:100%;min-height:0}.shell.cursor-hidden{cursor:none}.ambient{position:fixed;inset:0;pointer-events:none;background:radial-gradient(1200px 600px at 10% -10%,rgba(58,143,255,.1),transparent 60%),radial-gradient(900px 500px at 110% 10%,rgba(255,183,64,.06),transparent 55%),radial-gradient(1000px 700px at 50% 110%,rgba(58,143,255,.05),transparent 60%);z-index:0}.topbar{position:relative;z-index:3;background:linear-gradient(180deg,#0e1016f5,#0a0c11f5);border-bottom:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.topbar-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:12px 24px;min-height:60px}.brand{display:flex;align-items:center;gap:12px;min-width:0;justify-self:start}.brand-mark{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:var(--blue);background:#3a8fff14;border:1px solid rgba(58,143,255,.22)}.brand-mark svg{width:18px;height:18px}.brand-lounge{font-family:var(--f-display);font-weight:700;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-menu{justify-self:end;width:40px;height:40px;border-radius:10px}.topbar-menu svg{width:20px;height:20px}.tooltip{position:fixed;z-index:100;top:0;left:0;padding:6px 10px;font-family:var(--f-body);font-size:11.5px;line-height:1.3;color:var(--text);background:#080a10f5;border:1px solid rgba(255,255,255,.1);border-radius:7px;box-shadow:0 8px 22px #00000080;opacity:0;pointer-events:none;max-width:260px;white-space:normal;transform:translateY(4px);transition:opacity .14s ease,transform .14s ease;letter-spacing:.01em}.tooltip.is-open{opacity:1;transform:none}.tooltip.is-above:after,.tooltip.is-below:after{content:"";position:absolute;left:50%;transform:translate(-50%) rotate(45deg);width:6px;height:6px;background:#080a10f5;border:1px solid rgba(255,255,255,.1)}.tooltip.is-above:after{bottom:-4px;border-top:none;border-left:none}.tooltip.is-below:after{top:-4px;border-bottom:none;border-right:none}.welcome-card{position:relative;z-index:6;max-width:820px;margin:0 auto 18px;background:linear-gradient(180deg,#ffb74014,#ffb74003) border-box,var(--surface-2);border:1px solid rgba(255,183,64,.28);border-radius:16px;box-shadow:0 10px 30px #00000073,0 0 22px #ffb7400f;overflow:hidden;animation:welcomeIn .36s cubic-bezier(.16,1,.3,1)}.stage[data-view="3d"] .welcome-card{position:absolute;top:62px;left:50%;transform:translate(-50%);width:min(780px,calc(100% - 32px))}.welcome-card[hidden]{display:none}@keyframes welcomeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}.welcome-inner{padding:20px 24px;position:relative}.welcome-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:8px}.welcome-eyebrow{display:block;font-family:var(--f-display);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}.welcome-title{font-family:var(--f-display);font-size:18px;letter-spacing:.08em;text-transform:uppercase;color:var(--text);flex:1;margin:0}.welcome-close{width:32px;height:32px;border-radius:8px;flex-shrink:0;margin-left:auto}.welcome-lead{color:var(--subtle);margin:0 0 12px;font-size:14px;line-height:1.5}.welcome-steps{margin:0 0 16px;padding:0 0 0 22px;color:var(--text);font-size:13.5px;line-height:1.55;display:flex;flex-direction:column;gap:6px}.welcome-steps li strong{color:var(--gold);font-weight:600}.welcome-steps li em{color:var(--blue-bright);font-style:normal;font-weight:600}.welcome-actions{display:flex;gap:10px;justify-content:flex-end}.empty-state{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none}.empty-state[hidden]{display:none}.empty-state>*{pointer-events:auto}.empty-state{color:var(--subtle);text-align:center;padding:40px 24px}.empty-state-icon{width:72px;height:72px;display:grid;place-items:center;margin:0 auto 16px;color:var(--muted);background:#ffffff05;border:1px dashed rgba(255,255,255,.1);border-radius:16px}.empty-state-icon svg{width:34px;height:34px}.empty-state-title{font-family:var(--f-display);font-size:15px;letter-spacing:.14em;text-transform:uppercase;color:var(--text);margin:0 0 6px}.empty-state-body{margin:0 0 18px;font-size:13.5px;line-height:1.5;color:var(--subtle);max-width:360px}.empty-state strong{color:var(--gold);font-weight:600}.empty-state em{color:var(--blue-bright);font-style:normal;font-weight:600}.floor.is-empty .floor-grid{opacity:.5}.floor.is-empty .tiles{display:none}.help-popover{position:fixed;inset:0;z-index:70;background:#050508b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:grid;place-items:center;opacity:0;transition:opacity .16s ease;padding:16px}.help-popover.is-open{opacity:1}.help-popover-inner{width:min(440px,calc(100vw - 32px));background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);border-radius:16px;box-shadow:0 30px 60px #0009;padding:18px 22px 20px;transform:translateY(6px) scale(.98);transition:transform .2s cubic-bezier(.2,.9,.3,1)}.help-popover.is-open .help-popover-inner{transform:none}.help-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.help-head h3{font-family:var(--f-display);font-size:14px;letter-spacing:.18em;text-transform:uppercase}.help-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.help-list li{display:flex;align-items:center;gap:14px;padding:10px 12px;background:#ffffff05;border:1px solid var(--border);border-radius:10px;font-size:13px;color:var(--subtle)}.help-list li span{flex:1}.help-list kbd{font-family:var(--f-mono);font-size:12px;font-weight:700;min-width:36px;padding:3px 8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.18);border-bottom-width:2px;border-radius:6px;color:var(--text);text-align:center;flex-shrink:0}.btn{appearance:none;border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);padding:10px 16px;border-radius:var(--radius-btn);font-family:var(--f-display);font-weight:600;font-size:12px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;min-height:40px;transition:transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .2s ease,color .16s ease}.btn:hover{background:var(--surface-3);border-color:#ffffff3d}.btn:active{transform:translateY(1px)}.btn:focus-visible{outline:none;border-color:#3a8fff99;box-shadow:0 0 0 2px #3a8fff38}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}.btn.full{width:100%;display:block}.btn-ghost{background:transparent}.btn-ghost:hover{background:#ffffff0a}.btn-primary{background:linear-gradient(90deg,var(--blue),var(--gold));border-color:transparent;color:#000;box-shadow:0 6px 22px #3a8fff40,inset 0 1px #fff6}.btn-primary:hover{filter:brightness(1.08);box-shadow:0 10px 30px #3a8fff59,inset 0 1px #ffffff73}.btn-danger{background:linear-gradient(180deg,#ff40402e,#ff404014);border-color:#ff404080;color:#ffeaea}.btn-danger:hover{background:linear-gradient(180deg,#ff40404d,#ff404024);border-color:#ff4040b3}.icon-btn{appearance:none;background:transparent;border:1px solid var(--border-strong);color:var(--text);border-radius:10px;width:40px;height:40px;display:inline-grid;place-items:center;transition:background .16s ease,border-color .16s ease,transform .16s ease,box-shadow .16s ease;font-size:22px;line-height:1;cursor:pointer}.icon-btn:hover{background:#ffffff0d;border-color:#ffffff3d}.icon-btn:focus-visible{outline:none;border-color:#3a8fff8c;box-shadow:0 0 0 2px #3a8fff40}.icon-btn:active{transform:translateY(1px)}.icon-btn:disabled,.icon-btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}.icon-btn svg{width:18px;height:18px}.icon-btn-lg{width:44px;height:44px;border-radius:12px}.icon-btn-lg svg{width:20px;height:20px}.edit-toolbar{position:relative;z-index:2;background:linear-gradient(180deg,#ffb7401a,#ffb74005);border-bottom:1px solid rgba(255,183,64,.25);padding:10px 22px}.edit-toolbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}.edit-label{font-family:var(--f-display);font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:10px}.edit-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 12px var(--gold);animation:pulse-gold 1.6s ease-in-out infinite}@keyframes pulse-gold{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}.edit-actions{display:flex;gap:8px}.stage{position:relative;z-index:1;min-height:0;overflow:auto;padding:24px;scroll-behavior:smooth}.stage[data-view="3d"]{overflow:hidden;padding:0}.floor{--floor-w: 1000px;--floor-h: 620px;position:relative;width:var(--floor-w);min-height:var(--floor-h);height:var(--floor-h);margin:0 auto;border-radius:22px;background:linear-gradient(180deg,#ffffff05,#fff0) border-box,var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-ambient);overflow:hidden;opacity:1;transition:opacity .22s ease}.floor.is-loading .tiles{opacity:0}.floor .tiles{transition:opacity .22s ease}@media (prefers-reduced-motion: reduce){.floor,.floor .tiles{transition:none}}.floor-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),radial-gradient(circle at 50% 50%,rgba(58,143,255,.03),transparent 65%);background-size:40px 40px,40px 40px,100% 100%;pointer-events:none}.tiles{position:absolute;inset:0}.tile{position:absolute;border-radius:var(--radius-tile);background:linear-gradient(180deg,#ffffff08,#fff0) border-box,var(--surface-2);border:1px solid var(--border-strong);box-shadow:var(--shadow-tile);overflow:hidden;cursor:pointer;transition:transform .22s cubic-bezier(.2,.9,.3,1),border-color .22s ease,box-shadow .22s ease,background-color .22s ease;will-change:transform}.tile:hover{transform:translateY(-2px);border-color:#ffffff3d}.tile-inner{position:relative;display:flex;flex-direction:column;height:100%;padding:14px 16px}.tile-header{display:flex;align-items:center;gap:12px}.tile-icon{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:#ffffff0a;border:1px solid var(--border);color:var(--blue-bright);flex-shrink:0}.tile-icon svg{width:24px;height:24px}.tile-id{min-width:0;flex:1}.tile-name{font-family:var(--f-display);font-weight:700;font-size:14px;letter-spacing:.06em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase}.tile-status{display:inline-block;margin-top:2px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.tile-body{flex:1;min-height:0;display:flex;flex-direction:column;justify-content:center;padding-top:6px}.tile-available{font-family:var(--f-display);font-size:13px;font-weight:700;letter-spacing:.26em;color:var(--muted);text-align:center;padding-block:12px}.tile-token-badge{align-self:center;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:#ffb74014;border:1px solid rgba(255,183,64,.4);color:var(--gold);font-family:var(--f-display);font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase}.tile-token-badge span{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold)}.tile-timer{font-family:var(--f-mono);font-weight:700;font-size:clamp(28px,3.2vw,42px);color:var(--text);letter-spacing:.02em;font-variant-numeric:tabular-nums;line-height:1;text-align:center;text-shadow:0 0 26px rgba(58,143,255,.3)}.tile-sub{margin-top:6px;text-align:center;font-family:var(--f-display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);min-height:1em}.tile-meta{margin-top:8px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--subtle)}.tile-customer{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%;font-weight:500}.tile-paid{font-family:var(--f-mono);color:var(--gold);font-weight:600}.tile[data-status=idle]{border-color:#3a8fff38}.tile[data-status=idle]:hover{border-color:#3a8fff8c;box-shadow:var(--shadow-tile),var(--glow-blue)}.tile[data-status=idle].is-token{border-color:#ffb74047}.tile[data-status=idle].is-token:hover{border-color:#ffb74099;box-shadow:var(--shadow-tile),var(--glow-gold)}.tile[data-status=running]{border-color:#39ff1452;background:linear-gradient(180deg,#39ff140a,#39ff1400) border-box,var(--surface-2);box-shadow:var(--shadow-tile),var(--glow-green)}.tile[data-status=running] .tile-timer{color:#e9ffe4;text-shadow:0 0 24px rgba(57,255,20,.3)}.tile[data-status=running] .tile-status{color:#b8f3a8}.tile[data-status=running] .tile-icon{color:#c8ffb3}.tile[data-status=warning]{border-color:#ffcc3380;background:linear-gradient(180deg,#ffcc330d,#fc30) border-box,var(--surface-2);box-shadow:var(--shadow-tile),var(--glow-yellow)}.tile[data-status=warning] .tile-timer{color:#ffe790;text-shadow:0 0 26px rgba(255,204,51,.45)}.tile[data-status=warning] .tile-status,.tile[data-status=warning] .tile-icon{color:var(--yellow)}.tile[data-status=critical]{border-color:#ff4040a6;background:linear-gradient(180deg,#ff40400f,#ff404000) border-box,var(--surface-2);box-shadow:var(--shadow-tile),var(--glow-red);animation:gentle-pulse 1.4s ease-in-out infinite}.tile[data-status=critical] .tile-timer{color:#ffd3d3;text-shadow:0 0 30px rgba(255,64,64,.5)}.tile[data-status=critical] .tile-status,.tile[data-status=critical] .tile-icon{color:var(--red)}@keyframes gentle-pulse{0%,to{box-shadow:var(--shadow-tile),0 0 0 1.5px #ff4040a6,0 0 24px #ff40403d}50%{box-shadow:var(--shadow-tile),0 0 0 1.5px #ff4040e6,0 0 44px #ff40406b}}.tile[data-status=expired]{border-color:#ff4040d9;animation:expired-flash .85s ease-in-out infinite}.tile[data-status=expired] .tile-timer{color:#fff;text-shadow:0 0 22px rgba(255,64,64,.7)}.tile[data-status=expired] .tile-status,.tile[data-status=expired] .tile-icon{color:#fff}@keyframes expired-flash{0%,to{background-color:#ff404014;box-shadow:var(--shadow-tile),0 0 0 2px #ff4040e6,0 0 40px #ff404059}50%{background-color:#ff404052;box-shadow:var(--shadow-tile),0 0 0 2px #ff5a5a,0 0 62px #ff404099}}.tile[data-status=broken]{color:var(--muted);background:repeating-linear-gradient(45deg,#ffffff0a,#ffffff0a 8px,#ffffff04 8px 16px),var(--surface-2);border-color:#ffffff24;opacity:.82}.tile[data-status=broken] .tile-icon{color:var(--muted);background:#ffffff05}.tile[data-status=broken] .tile-name{color:var(--muted)}.tile-broken-badge{position:absolute;left:0;right:0;bottom:12px;text-align:center;font-family:var(--f-display);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}.tile.is-edit{cursor:grab}.tile.is-edit.is-dragging{cursor:grabbing;transition:none;box-shadow:0 24px 48px #0000008c,0 0 0 1px #ffb74099}.tile-delete{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;border:1px solid rgba(255,64,64,.6);background:#ff404024;color:#fff;font-size:18px;line-height:1;display:grid;place-items:center;cursor:pointer;z-index:3}.tile-delete:hover{background:#ff404047}.tile-resize{position:absolute;bottom:4px;right:4px;width:18px;height:18px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.6) 42%,transparent 44%),linear-gradient(135deg,transparent 60%,rgba(255,255,255,.8) 62%,transparent 64%);z-index:3;opacity:.8}.tile-edit-hint{position:absolute;left:16px;bottom:10px;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);opacity:.6}.shell.is-tv .topbar-row-primary .primary-actions,.shell.is-tv .topbar-row-primary .view-toggle,.shell.is-tv .topbar-row-secondary .action-group,.shell.is-tv .welcome-card{display:none}.shell.is-tv .topbar-row-secondary{border-top:none}.shell.is-tv .tile-timer{font-size:clamp(48px,5.4vw,76px)}.shell.is-tv .tile-status,.shell.is-tv .tile-meta,.shell.is-tv .tile-available{font-size:14px;letter-spacing:.3em}.shell.is-tv .tile{cursor:default;pointer-events:none}.shell.is-tv .topbar-row{padding:10px 22px}.shell.is-tv .brand-lounge{font-size:20px}.modal-backdrop,.settings-backdrop{position:fixed;inset:0;z-index:50;display:grid;place-items:center;background:#0505088c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;transition:opacity .2s ease}.modal-backdrop.is-open,.settings-backdrop.is-open{opacity:1}.modal-backdrop.is-closing{opacity:0}.modal{width:min(520px,calc(100vw - 32px));background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);border-radius:18px;box-shadow:0 40px 80px #0009,inset 0 1px #ffffff0f;overflow:hidden;transform:translateY(10px) scale(.98);transition:transform .24s cubic-bezier(.2,.9,.3,1)}.modal-backdrop.is-open .modal{transform:none}.modal-sm{width:min(420px,calc(100vw - 32px))}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 22px 8px}.modal-eyebrow{font-family:var(--f-display);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:6px}.modal-title{font-family:var(--f-display);font-size:20px;letter-spacing:.08em;text-transform:uppercase}.modal-body{padding:12px 22px 4px;display:flex;flex-direction:column;gap:10px}.modal-footer{padding:16px 22px 20px;display:flex;justify-content:flex-end;gap:10px}.field-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-family:var(--f-display);font-weight:600;margin-top:6px}.optional{color:#ffffff4d;font-weight:500;letter-spacing:.06em;font-family:var(--f-body);text-transform:none}.field-input{appearance:none;background:var(--surface);border:1px solid var(--border-strong);color:var(--text);border-radius:var(--radius-sm);padding:12px 14px;font-size:15px;outline:none;transition:border-color .16s ease,box-shadow .16s ease;width:100%}.field-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3a8fff33}.chip-row{display:flex;gap:8px;flex-wrap:wrap}.chip-row-wrap{flex-wrap:wrap;gap:8px}.chip{appearance:none;background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-radius:999px;padding:10px 16px;font-family:var(--f-display);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;transition:background .16s ease,border-color .16s ease,transform .14s ease,color .16s ease}.chip:hover{background:var(--surface-3);border-color:#ffffff4d}.chip.is-active{background:linear-gradient(90deg,#3a8fff38,#ffb74029);border-color:#3a8fff99;color:#fff;box-shadow:0 0 0 1px #3a8fff4d,0 0 14px #3a8fff2e}.chip-custom{display:inline-flex;align-items:center;gap:8px;background:var(--surface);padding:8px 12px;cursor:text}.chip-custom input{width:54px;background:transparent;border:none;color:var(--text);font-family:var(--f-mono);font-size:14px;font-weight:600;text-align:center;outline:none;padding:2px 0;border-bottom:1px solid rgba(255,255,255,.16)}.chip-custom .chip-unit{color:var(--muted);font-size:10px;letter-spacing:.12em}.chip-extend{border-color:#3a8fff59;color:var(--blue-bright)}.chip-extend:hover{background:#3a8fff14;border-color:#3a8fff8c}.chip-adjust{color:var(--muted)}.price-row{margin-top:10px;display:flex;align-items:baseline;justify-content:space-between;padding:14px 16px;border-radius:12px;background:#ffb74014;border:1px solid rgba(255,183,64,.25)}.price-label{font-family:var(--f-display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}.price-value{font-family:var(--f-mono);font-weight:700;font-size:28px;color:var(--gold);letter-spacing:.01em;text-shadow:0 0 22px rgba(255,183,64,.35)}.confirm-msg{color:var(--subtle);line-height:1.5;margin:4px 0 6px}.sheet{width:min(540px,calc(100vw - 32px));background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);border-radius:20px;box-shadow:0 40px 80px #0009,inset 0 1px #ffffff0d;overflow:hidden;transform:translateY(12px) scale(.98);transition:transform .24s cubic-bezier(.2,.9,.3,1)}.modal-backdrop.is-open .sheet{transform:none}.sheet-body{padding:6px 22px 10px;display:flex;flex-direction:column;gap:12px}.sheet-footer{padding:12px 22px 20px;display:flex;justify-content:space-between;gap:10px}.sheet-note{color:var(--subtle);margin:6px 0 0}.big-countdown{font-family:var(--f-mono);font-weight:700;font-size:56px;text-align:center;padding:16px 0 6px;color:#fff;letter-spacing:.02em;text-shadow:0 0 30px rgba(58,143,255,.35)}.session-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;padding:10px 12px;border-radius:12px;background:#ffffff05;border:1px solid var(--border)}.session-meta>div{display:flex;flex-direction:column}.meta-label{font-size:10px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;font-family:var(--f-display);font-weight:600}.session-meta strong{font-family:var(--f-mono);font-weight:600;font-size:16px;color:var(--text)}.section-label{font-family:var(--f-display);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:4px}.settings-backdrop{justify-content:flex-end;align-items:stretch}.settings-panel{width:min(420px,100vw);height:100%;background:linear-gradient(180deg,var(--surface-2),var(--surface));border-left:1px solid var(--border-strong);box-shadow:-30px 0 60px #00000080;display:flex;flex-direction:column;transform:translate(20px);transition:transform .24s cubic-bezier(.2,.9,.3,1)}.settings-backdrop.is-open .settings-panel{transform:none}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--border)}.settings-header h2{font-size:16px;letter-spacing:.14em;text-transform:uppercase}.settings-body{flex:1;overflow:auto;padding:16px 22px 28px;display:flex;flex-direction:column;gap:24px}.settings-section{display:flex;flex-direction:column;gap:10px}.settings-section h3{font-family:var(--f-display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:2px}.settings-section-header{appearance:none;display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:#ffffff05;border:1px solid var(--border);border-radius:12px;color:var(--text);cursor:pointer;font-family:var(--f-display);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;transition:background .16s ease,border-color .16s ease}.settings-section-header:hover{background:#ffffff09;border-color:#ffffff24}.settings-section-header:focus-visible{outline:none;border-color:#3a8fff8c;box-shadow:0 0 0 2px #3a8fff33}.settings-section-icon{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:8px;background:#3a8fff1a;border:1px solid rgba(58,143,255,.22);color:var(--blue-bright);flex-shrink:0}.settings-section-icon svg{width:16px;height:16px}.settings-section-title{flex:1;text-align:left;color:var(--text)}.settings-section-title .optional{font-family:var(--f-body);font-size:10px;letter-spacing:.04em;text-transform:none;color:var(--muted);font-weight:400;margin-left:4px}.settings-section-chevron{display:inline-grid;place-items:center;width:22px;height:22px;color:var(--muted);transition:transform .2s ease,color .16s ease}.settings-section-chevron svg{width:14px;height:14px}.settings-section[data-collapsed=true] .settings-section-chevron{transform:rotate(-90deg)}.settings-section-header:hover .settings-section-chevron{color:var(--text)}.settings-section-body{display:flex;flex-direction:column;gap:10px;padding:4px 2px 2px}.settings-section-body[hidden]{display:none}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#ffffff05;border:1px solid var(--border);border-radius:10px;cursor:pointer}.toggle-row input{display:none}.toggle-track{width:36px;height:20px;background:var(--surface-3);border-radius:999px;position:relative;transition:background .16s ease}.toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .16s ease}.toggle-row input:checked+.toggle-track{background:linear-gradient(90deg,var(--blue),var(--gold))}.toggle-row input:checked+.toggle-track .toggle-thumb{transform:translate(16px)}.num-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#ffffff05;border:1px solid var(--border);border-radius:10px}.num-row-stack{flex-direction:column;align-items:stretch;gap:8px}.num-row>span{font-size:13px;color:var(--subtle)}.num-input{display:inline-flex;align-items:center;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;overflow:hidden}.num-input span{padding:0 10px;color:var(--muted);font-family:var(--f-mono)}.num-input input{width:80px;background:transparent;border:none;color:var(--text);font-family:var(--f-mono);font-weight:600;text-align:right;padding:8px 10px 8px 0;outline:none}.btn-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.enable-sound{position:fixed;bottom:18px;left:50%;transform:translate(-50%);z-index:40;animation:rise .26s ease-out}.enable-sound-inner{display:inline-flex;align-items:center;gap:12px;padding:12px 20px;background:linear-gradient(90deg,var(--blue),var(--gold));border:none;border-radius:999px;color:#000;font-family:var(--f-display);font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:12px;box-shadow:0 18px 40px #00000073,0 0 40px #3a8fff4d}.enable-sound-inner:hover{filter:brightness(1.06)}.enable-sound-icon{display:inline-flex}.enable-sound-icon svg{width:16px;height:16px}@keyframes rise{0%{transform:translate(-50%,16px);opacity:0}to{transform:translate(-50%);opacity:1}}.toast-host{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column-reverse;gap:8px;z-index:60;pointer-events:none;max-width:min(380px,calc(100vw - 32px))}.toast{padding:12px 18px;background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);border-radius:12px;font-size:13px;color:var(--text);box-shadow:0 16px 40px #0000008c,inset 0 1px #ffffff0a;transform:translate(24px);opacity:0;transition:transform .22s cubic-bezier(.2,.9,.3,1),opacity .2s ease;pointer-events:auto;line-height:1.35}.toast.is-open{transform:none;opacity:1}.toast.is-leaving{transform:translate(24px);opacity:0}.toast-success{border-color:#39ff1466;box-shadow:0 16px 40px #0000008c,0 0 22px #39ff141f}.tile-grace{margin:6px auto 0;display:inline-flex;align-self:center;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#ffcc3324;border:1px solid rgba(255,204,51,.55);color:var(--yellow);font-family:var(--f-display);font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;box-shadow:0 0 16px #ffcc332e;animation:pulse-grace 1.4s ease-in-out infinite}.tile-grace[hidden]{display:none}.tile-grace [data-grace-time]{font-family:var(--f-mono);color:var(--yellow);font-weight:700;letter-spacing:.02em}@keyframes pulse-grace{0%,to{opacity:1}50%{opacity:.7}}.tile-tournament-badge{position:absolute;top:6px;left:50%;transform:translate(-50%);padding:3px 10px;border-radius:999px;background:#ffb74033;border:1px solid rgba(255,183,64,.7);color:var(--gold);font-family:var(--f-display);font-size:9px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;box-shadow:0 0 14px #ffb7404d;z-index:2;white-space:nowrap}.tile.is-edit .tile-tournament-badge{top:6px}.tournament-overlay{position:fixed;inset:0;z-index:55;background:#050508e0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);opacity:0;transition:opacity .24s ease;display:flex;flex-direction:column}.tournament-overlay.is-open{opacity:1}.tournament-overlay~.modal-backdrop{z-index:60}.tournament-shell{display:flex;flex-direction:column;flex:1;min-height:0}.tournament-topbar{display:flex;align-items:center;gap:20px;padding:16px 24px;background:linear-gradient(180deg,#14161ff0,#0c0e14f0);border-bottom:1px solid var(--border)}.tournament-title{display:flex;flex-direction:column;min-width:0}.tournament-eyebrow{font-family:var(--f-display);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}.tournament-title h2{font-family:var(--f-display);font-size:18px;letter-spacing:.12em;text-transform:uppercase;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tournament-meta{display:flex;gap:10px;margin-left:auto}.tournament-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:#ffffff08;border:1px solid var(--border);font-size:12px;color:var(--subtle)}.tournament-chip-label{font-family:var(--f-display);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}.tournament-chip strong{font-family:var(--f-mono);font-weight:600;color:var(--text)}.tournament-actions{display:flex;gap:8px}.tournament-body{flex:1;min-height:0;overflow:auto;padding:24px}.bracket-grid{display:inline-flex;gap:32px;min-height:100%;padding-bottom:24px}.bracket-col{display:flex;flex-direction:column;min-width:240px}.bracket-col-header{font-family:var(--f-display);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:16px;text-align:center;padding:8px 12px;border-radius:8px;background:#3a8fff14;border:1px solid rgba(58,143,255,.22)}.bracket-col-matches{display:flex;flex-direction:column;justify-content:space-around;gap:20px;flex:1}.match-box{background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);border-radius:14px;padding:12px;min-width:240px;box-shadow:var(--shadow-tile);position:relative}.match-box[data-state=running]{border-color:#39ff1480;box-shadow:var(--shadow-tile),var(--glow-green)}.match-box[data-state=done]{opacity:.85;border-color:#ffb74059}.match-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-family:var(--f-display);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}.match-num{color:var(--gold);font-weight:700}.match-station{color:var(--blue-bright);font-weight:600}.match-slot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;background:#ffffff05;border:1px solid var(--border);border-radius:8px;margin:4px 0;font-family:var(--f-display);font-size:13px;font-weight:600;letter-spacing:.06em;color:var(--text)}.match-slot-empty,.match-slot-bye{color:var(--muted);font-size:11px;letter-spacing:.22em;text-transform:uppercase;justify-content:center;font-weight:500}.match-slot-winner{border-color:#39ff148c;background:#39ff140d;color:#e9ffe4;box-shadow:0 0 14px #39ff142e}.match-slot-loser{color:var(--muted);opacity:.55;text-decoration:line-through;text-decoration-color:#ffffff4d}.match-slot-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.match-win-btn{appearance:none;padding:4px 10px;border-radius:999px;background:#ffb74029;border:1px solid rgba(255,183,64,.5);color:var(--gold);font-family:var(--f-display);font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:background .16s ease,border-color .16s ease;flex-shrink:0}.match-win-btn:hover{background:#ffb7404d;border-color:#ffb740cc}.match-sep{text-align:center;font-family:var(--f-display);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin:2px 0}.match-footer{margin-top:8px;font-size:11px;letter-spacing:.12em;color:var(--subtle);text-align:center}.match-footer-done{color:var(--gold);font-family:var(--f-display);font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:10px}.match-footer-running{color:var(--green);font-family:var(--f-display);letter-spacing:.14em;text-transform:uppercase;font-size:9px}.match-footer-muted{color:var(--muted);font-family:var(--f-display);letter-spacing:.2em;text-transform:uppercase;font-size:9px}.match-start-btn{width:100%;padding:8px 12px;font-size:11px}.tournament-players{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:280px;overflow:auto;padding:4px;border-radius:10px;background:#ffffff04;border:1px solid var(--border)}.tournament-player-row{display:flex;align-items:center;gap:8px}.tournament-player-idx{font-family:var(--f-display);font-size:10px;letter-spacing:.18em;color:var(--gold);min-width:32px;text-align:center}.tournament-player-row .field-input{padding:8px 10px;font-size:13px}.station-picker{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.station-pick{appearance:none;display:flex;flex-direction:column;gap:4px;align-items:flex-start;padding:12px 14px;border-radius:12px;background:#ffffff05;border:1px solid var(--border-strong);color:var(--text);cursor:pointer;transition:background .16s ease,border-color .16s ease;text-align:left}.station-pick:hover{background:#3a8fff14;border-color:#3a8fff80}.station-pick[disabled]{opacity:.4;cursor:not-allowed}.station-pick.is-busy{border-color:#ffcc3373}.station-pick-name{font-family:var(--f-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase}.station-pick-sub{font-size:10px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}.stat-champion{border-color:#ffb74073;background:#ffb7400d}.stat-champion .stat-value{color:var(--gold);font-family:var(--f-display);font-size:14px;letter-spacing:.1em;text-transform:uppercase}[data-revenue-host]{position:relative}.revenue-breakdown{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%) translateY(-4px);font-family:var(--f-body);font-size:11px;letter-spacing:.04em;color:var(--text);padding:8px 14px;background:var(--surface-3);border:1px solid rgba(255,183,64,.4);border-radius:10px;box-shadow:0 10px 30px #0000008c;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease;z-index:10}.revenue-breakdown:empty{display:none}[data-revenue-host]:hover .revenue-breakdown,[data-revenue-host]:focus-within .revenue-breakdown{opacity:1;transform:translate(-50%) translateY(0)}.field-select{appearance:none;background:var(--surface);border:1px solid var(--border-strong);color:var(--text);border-radius:var(--radius-sm);padding:10px 34px 10px 14px;font-size:14px;font-family:var(--f-body);width:100%;outline:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;transition:border-color .16s ease,box-shadow .16s ease}.field-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3a8fff33}.inline-row{display:flex;align-items:center;gap:8px}.inline-row .field-select,.inline-row .field-input{flex:1}.btn-compact{padding:9px 14px;font-size:11px}.field-label-sm{font-size:10px;margin-top:2px;color:var(--subtle)}.settings-help{font-size:12px;color:var(--subtle);line-height:1.5;margin:2px 0 4px}.settings-help code{background:#ffffff0d;border-radius:4px;padding:1px 5px;font-family:var(--f-mono);font-size:11px;color:var(--text)}.payment-methods{display:flex;flex-wrap:wrap;gap:6px;padding:6px;border-radius:10px;min-height:38px;background:#ffffff05;border:1px solid var(--border)}.payment-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:#3a8fff1a;border:1px solid rgba(58,143,255,.3);font-size:12px;font-family:var(--f-display);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-bright)}.payment-remove{appearance:none;background:transparent;border:none;color:var(--blue-bright);font-size:16px;line-height:1;cursor:pointer;padding:0 2px;opacity:.7}.payment-remove:hover{opacity:1;color:var(--red)}.sync-status{font-family:var(--f-display);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-left:auto;padding:6px 10px;border-radius:999px;background:#ffffff0a;border:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.sync-status[data-status=synced]{color:var(--green);border-color:#39ff1466;background:#39ff140d}.sync-status[data-status=connecting]{color:var(--yellow);border-color:#fc36}.sync-status[data-status^=error]{color:var(--red);border-color:#ff404080}@media (max-width: 1100px){.topbar-row{gap:14px;padding:10px 18px}.topbar-row-secondary{padding-bottom:12px}.stat{min-width:100px;padding:6px 12px}.stat-value{font-size:18px}.clock{display:none}}@media (max-width: 900px){.topbar-row{gap:12px;padding:10px 14px;flex-wrap:wrap}.topbar-row-primary .view-toggle{order:4;flex-basis:100%;justify-content:center}.brand{flex:1}.primary-actions{flex-shrink:0}.clock{display:none}.stats{gap:8px;width:100%}.stat{flex:1;min-width:0}.action-group{margin-left:0;flex-wrap:wrap;justify-content:flex-end;width:100%}.action-group .btn{flex:1;min-width:120px}.stage{padding:14px}}@media (max-width: 600px){.topbar-row{padding:8px 12px}.brand-lounge{font-size:13px}.brand-ops{font-size:14px}.stat{padding:6px 10px;min-width:0}.stat-label{font-size:9px;letter-spacing:.12em}.stat-value{font-size:15px}.btn{padding:8px 12px;font-size:11px;min-height:40px}.btn-pill{padding:8px 10px;font-size:10.5px}.icon-btn,.icon-btn-lg{width:40px;height:40px}.action-group{padding:3px;gap:4px}.action-group .btn{min-width:0;flex:1;letter-spacing:.06em}.overflow-panel{min-width:200px}.welcome-inner{padding:16px 18px}.welcome-title{font-size:16px}.welcome-steps{font-size:13px;padding-left:20px}.welcome-actions{flex-direction:column-reverse}.welcome-actions .btn{width:100%}.toast-host{bottom:14px;right:14px;left:14px;max-width:none}.room3d-dims-hud{top:10px;left:10px;font-size:10px;padding:6px 10px}}@media (max-width: 420px){.stat-champion,.action-group .btn span{display:none}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.12s!important}}.view-toggle{display:inline-flex;align-items:stretch;padding:3px;gap:0;background:#ffffff09;border:1px solid rgba(255,255,255,.06);border-radius:999px;justify-self:center}.view-toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;border:0;background:transparent;color:var(--muted);font-family:var(--f-body);font-weight:500;font-size:12.5px;letter-spacing:.01em;cursor:pointer;transition:color .18s ease,background .18s ease;white-space:nowrap;min-height:32px}.view-toggle-btn:hover{color:var(--text);background:#ffffff05}.view-toggle-btn.is-active{color:var(--text);background:#3a8fff1f;box-shadow:inset 0 0 0 1px #3a8fff59}.view-toggle-btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.view-toggle-label{font-family:var(--f-body);font-weight:500}.room3d{position:absolute;inset:0;overflow:hidden;background:radial-gradient(120% 90% at 50% 20%,rgba(58,143,255,.08),transparent 60%),radial-gradient(80% 60% at 50% 100%,rgba(255,183,64,.05),transparent 70%),linear-gradient(180deg,#14161f66,#050508 90%),var(--bg);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .24s ease}.room3d-canvas{display:block;width:100%;height:100%;touch-action:none}.room3d-labels{position:absolute;inset:0;pointer-events:none;z-index:2}.stage[data-view="2d"] .floor{opacity:1;visibility:visible;pointer-events:auto}.stage[data-view="2d"] .room3d,.stage[data-view="2d"] .venue3d,.stage[data-view="3d"] .floor{opacity:0;visibility:hidden;pointer-events:none}.stage[data-view="3d"] .room3d{opacity:1;visibility:visible;pointer-events:auto}.stage[data-view="3d"] .venue3d,.stage[data-view=venue] .floor,.stage[data-view=venue] .room3d{opacity:0;visibility:hidden;pointer-events:none}.stage[data-view=venue] .venue3d{opacity:1;visibility:visible;pointer-events:auto}.floor{transition:opacity .24s ease}.stage.is-switching .floor,.stage.is-switching .room3d,.stage.is-switching .venue3d{transition:opacity .26s ease}.room3d-hint{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:5;padding:8px 14px;background:#0c0e14d1;border:1px solid rgba(58,143,255,.35);border-radius:999px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text);font-family:var(--f-body);font-size:12px;font-weight:500;letter-spacing:.02em;box-shadow:0 6px 24px #00000073,0 0 18px #3a8fff2e;pointer-events:none}.room3d-label{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 10px 7px;background:#080a10e0;border:1px solid rgba(58,143,255,.28);border-radius:10px;color:var(--text);transform:translate(-50%,-100%);white-space:nowrap;pointer-events:none;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-shadow:0 4px 18px #00000080;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.room3d-label-name{font-family:var(--f-display);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text);line-height:1}.room3d-label-timer{font-family:var(--f-mono);font-size:13px;font-weight:600;letter-spacing:.04em;line-height:1;color:var(--subtle);font-variant-numeric:tabular-nums}.room3d-label[data-status=running]{border-color:#39ff1473;box-shadow:0 4px 18px #00000080,0 0 16px #39ff1438}.room3d-label[data-status=running] .room3d-label-timer{color:var(--green)}.room3d-label[data-status=warning]{border-color:#fc39;box-shadow:0 4px 18px #00000080,0 0 16px #ffcc3340}.room3d-label[data-status=warning] .room3d-label-timer{color:var(--yellow)}.room3d-label[data-status=critical]{border-color:#ff4040b3;box-shadow:0 4px 18px #00000080,0 0 18px #ff40404d}.room3d-label[data-status=critical] .room3d-label-timer{color:var(--red)}.room3d-label[data-status=expired]{border-color:#ff4040d9;background:#340a0ce6}.room3d-label[data-status=expired] .room3d-label-timer,.room3d-label[data-status=expired] .room3d-label-name{color:var(--red)}.room3d-label[data-status=broken]{border-color:#ffffff1f;background:#0c0e14bf}.room3d-label[data-status=broken] .room3d-label-name{color:var(--muted);letter-spacing:.14em}.room3d-label[data-status=tournament]{border-color:#ffb74099;box-shadow:0 4px 18px #00000080,0 0 18px #ffb74038}.room3d-label[data-status=tournament] .room3d-label-name{color:var(--gold)}.room3d-label[data-status=idle]{border-color:#3a8fff47}.shell.hide-names .room3d-label-name{display:none}.shell.hide-names .room3d-label[data-status=idle]{opacity:0;pointer-events:none}.shell.hide-names .room3d-label{padding:4px 8px;background:#050508e0}.shell.hide-names .tile-name{font-size:0;line-height:0;height:0;margin:0;overflow:hidden}.room3d-rotate-handle{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:linear-gradient(135deg,#3a8ffff2,#ffb740f2);border:1px solid rgba(255,255,255,.3);border-radius:999px;color:#050508;font-family:var(--f-display);font-weight:800;font-size:10px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;pointer-events:auto;user-select:none;transform:translate(-50%,-50%);box-shadow:0 8px 24px #00000080,0 0 18px #3a8fff59;transition:transform .12s ease,box-shadow .12s ease;white-space:nowrap}.room3d-rotate-handle:hover{transform:translate(-50%,-50%) scale(1.06);box-shadow:0 12px 28px #0000008c,0 0 22px #3a8fff80}.room3d-rotate-handle:active{transform:translate(-50%,-50%) scale(.96)}.room3d-rotate-handle svg{width:14px;height:14px;stroke:#050508;stroke-width:2.4;fill:none}.room3d-ruler{font-family:var(--f-mono);font-size:9.5px;font-weight:600;color:#ffb740d9;letter-spacing:.08em;background:#050508b3;border:1px solid rgba(255,183,64,.22);padding:2px 6px;border-radius:3px;white-space:nowrap;pointer-events:none;text-shadow:0 1px 0 rgba(0,0,0,.8);user-select:none;transform:translate(-50%,-50%)}.room3d-ruler.v{letter-spacing:.05em}.room3d-dims-hud{position:absolute;top:14px;left:14px;z-index:5;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#050508bf;border:1px solid rgba(255,183,64,.25);border-radius:999px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-family:var(--f-mono);font-size:11px;color:#fff;pointer-events:auto;cursor:pointer;letter-spacing:.04em;box-shadow:0 4px 18px #0006;transition:background .16s ease,border-color .16s ease,box-shadow .2s ease,padding .18s ease;outline:none}.room3d-dims-hud:hover:not(.is-editing){background:#0a0a10d9;border-color:#ffb74080;box-shadow:0 6px 22px #00000073,0 0 18px #ffb7402e}.room3d-dims-hud:focus-visible{border-color:#ffb740b3;box-shadow:0 6px 22px #00000073,0 0 0 3px #ffb74038}.room3d-dims-hud.is-editing{cursor:default;padding:8px 16px;background:#0a0a10eb;border-color:#ffb740b3;box-shadow:0 6px 24px #0000008c,inset 0 0 0 1px #ffb74033,inset 0 0 22px #ffb74026,0 0 22px #ffb74040}.room3d-dims-label{font-family:var(--f-display);font-size:9.5px;letter-spacing:.28em;font-weight:700;color:var(--gold);padding-right:4px;border-right:1px solid rgba(255,183,64,.2)}.room3d-dims-val{font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.room3d-dims-unit{font-size:9px;color:var(--muted);margin-left:2px;font-weight:500}.room3d-dims-x{color:#ffffff4d;font-weight:400}.room3d-dims-input-wrap{display:inline-flex;align-items:baseline;gap:2px;padding:2px 4px 2px 6px;border-radius:6px;background:#ffb74014;border:1px solid rgba(255,183,64,.3);transition:border-color .14s ease,background .14s ease}.room3d-dims-input-wrap:focus-within{border-color:#ffb740bf;background:#ffb74024;box-shadow:0 0 0 2px #ffb7402e}.room3d-dims-input-wrap input[type=number]{appearance:textfield;-moz-appearance:textfield;background:transparent;border:none;color:#fff;font-family:var(--f-mono);font-size:12px;font-weight:700;letter-spacing:.02em;width:44px;padding:0;text-align:right;outline:none;font-variant-numeric:tabular-nums;min-height:20px}.room3d-dims-input-wrap input[type=number]::-webkit-outer-spin-button,.room3d-dims-input-wrap input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.venue3d{position:absolute;inset:0;overflow:hidden;background:radial-gradient(140% 100% at 50% 20%,rgba(58,143,255,.08),transparent 62%),radial-gradient(80% 60% at 50% 105%,rgba(255,183,64,.05),transparent 70%),linear-gradient(180deg,#14161f66,#050508 90%),var(--bg);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .24s ease}.venue3d-canvas{display:block;width:100%;height:100%;touch-action:none}.venue3d-labels{position:absolute;inset:0;pointer-events:none;z-index:2}.venue3d-room-label{--accent: var(--blue);display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#06080ed9;border:1px solid color-mix(in srgb,var(--accent) 50%,rgba(255,255,255,.1));border-radius:999px;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:auto;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 8px 28px #0000008c,0 0 22px color-mix(in srgb,var(--accent) 28%,transparent);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.venue3d-room-label:hover{transform:translate(-50%,-50%) scale(1.03);box-shadow:0 10px 32px #0009,0 0 28px color-mix(in srgb,var(--accent) 45%,transparent);border-color:color-mix(in srgb,var(--accent) 80%,rgba(255,255,255,.1))}.venue3d-room-label-chip{width:10px;height:10px;border-radius:2px;background:var(--accent);box-shadow:0 0 10px color-mix(in srgb,var(--accent) 70%,transparent)}.venue3d-room-label-name{font-family:var(--f-display);font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--text)}.venue3d-chipstrip{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:6;display:flex;align-items:center;gap:8px;padding:6px;max-width:calc(100% - 24px);background:#080a10e0;border:1px solid var(--border);border-radius:999px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 12px 30px #0000008c;overflow-x:auto;scrollbar-width:none}.venue3d-chipstrip::-webkit-scrollbar{display:none}.venue3d-chip{--accent: var(--blue);display:inline-flex;align-items:center;gap:8px;padding:7px 13px 7px 10px;background:transparent;border:1px solid transparent;border-radius:999px;color:var(--subtle);font-family:var(--f-display);font-weight:700;font-size:11px;letter-spacing:.11em;text-transform:uppercase;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:color .14s ease,background .14s ease,border-color .14s ease,box-shadow .14s ease,transform .14s ease}.venue3d-chip:hover{color:var(--text);background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:color-mix(in srgb,var(--accent) 35%,transparent)}.venue3d-chip.is-active{color:var(--text);background:color-mix(in srgb,var(--accent) 18%,rgba(10,12,20,.85));border-color:color-mix(in srgb,var(--accent) 70%,transparent);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 50%,transparent),0 0 18px color-mix(in srgb,var(--accent) 28%,transparent)}.venue3d-chip:active{transform:scale(.97)}.venue3d-chip-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px color-mix(in srgb,var(--accent) 60%,transparent);flex-shrink:0}.venue3d-chip-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ffffff12;color:var(--muted);font-family:var(--f-mono);font-size:10px;font-weight:600;letter-spacing:0;font-variant-numeric:tabular-nums}.venue3d-chip.is-active .venue3d-chip-count{background:color-mix(in srgb,var(--accent) 25%,rgba(255,255,255,.08));color:var(--text)}.shell.hide-names .venue3d-chip-name,.shell.hide-names .venue3d-room-label-name{display:none}.shell.is-tv .venue3d-chipstrip{opacity:.55}.rooms-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.room-card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .14s ease,box-shadow .14s ease}.room-card:hover{border-color:var(--border-strong)}.room-card.is-expanded{border-color:#3a8fff59;box-shadow:0 0 18px #3a8fff1f}.room-card-summary{display:grid;grid-template-columns:22px 1fr 20px;align-items:center;gap:12px;width:100%;padding:12px 14px;background:transparent;border:0;color:var(--text);text-align:left;cursor:pointer}.room-card-swatch{width:18px;height:18px;border-radius:5px;border:1px solid rgba(255,255,255,.12);box-shadow:0 0 10px currentColor;flex-shrink:0}.room-card-main{display:flex;flex-direction:column;min-width:0;gap:2px}.room-card-name{font-family:var(--f-display);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text)}.room-card-meta{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}.room-card-chev{width:16px;height:16px;color:var(--muted);transition:transform .16s ease;display:inline-flex}.room-card.is-expanded .room-card-chev{transform:rotate(180deg)}.room-card-chev svg{width:100%;height:100%}.room-card-body{padding:4px 14px 14px;display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--border)}.num-row-compact{flex:1}.inline-row-color{align-items:center;gap:8px}.inline-row-color input[type=color]{width:36px;height:32px;padding:0;background:transparent;border:1px solid var(--border);border-radius:8px;cursor:pointer}.inline-row-color .field-input{flex:1;font-family:var(--f-mono)}.inline-row-end{justify-content:flex-end}.room-stations{display:flex;flex-direction:column;gap:6px;padding:10px;background:var(--surface);border:1px dashed var(--border);border-radius:10px}.room-stations-title{font-family:var(--f-display);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding-bottom:4px}.room-station-row{display:grid;grid-template-columns:1fr 140px;align-items:center;gap:10px}.room-station-name{font-size:12px;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-station-row .field-select{font-size:11px;padding:6px 8px}.camera-mode-hud{position:absolute;top:14px;right:14px;z-index:6;display:inline-flex;align-items:center;gap:2px;padding:4px;background:#050508c7;border:1px solid rgba(255,183,64,.25);border-radius:999px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);pointer-events:auto;box-shadow:0 4px 18px #00000073;font-family:var(--f-mono)}.camera-mode-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 11px 6px 9px;background:transparent;border:1px solid transparent;border-radius:999px;color:var(--subtle);font-family:var(--f-display);font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;white-space:nowrap;transition:color .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease,transform .12s ease}.camera-mode-btn:hover{color:var(--text);background:#ffb74014;border-color:#ffb74047}.camera-mode-btn.is-active{color:#050508;background:var(--gold);border-color:var(--gold);box-shadow:0 0 18px #ffb74059}.camera-mode-btn:active{transform:scale(.97)}.camera-mode-btn svg{width:14px;height:14px;flex-shrink:0}.camera-mode-btn-icon{padding:6px 8px;color:var(--muted)}.camera-mode-btn-icon:hover{color:var(--gold)}.walk-overlay{position:absolute;inset:0;z-index:7;display:flex;align-items:center;justify-content:center;background:#0505088c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);pointer-events:auto;cursor:pointer;transition:opacity .18s ease}.walk-overlay.is-hidden{opacity:0;pointer-events:none}.walk-overlay-card{display:flex;flex-direction:column;align-items:center;gap:14px;padding:22px 32px;background:#0a0c14eb;border:1px solid rgba(58,143,255,.35);border-radius:14px;box-shadow:0 12px 36px #0009,0 0 32px #3a8fff24;text-align:center;max-width:min(90%,520px)}.walk-overlay-title{font-family:var(--f-display);font-size:16px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--text)}.walk-overlay-body{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 14px;font-family:var(--f-mono);font-size:11px;color:var(--subtle);letter-spacing:.04em}.walk-overlay-body span{display:inline-flex;align-items:center;gap:4px}.walk-overlay-body kbd{display:inline-flex;align-items:center;justify-content:center;min-width:18px;padding:2px 6px;background:#3a8fff1f;border:1px solid rgba(58,143,255,.35);border-radius:4px;font-family:var(--f-mono);font-size:10px;font-weight:700;color:#fff;letter-spacing:0}.room3d.walk-mode:after,.venue3d.walk-mode:after{content:"";position:absolute;top:50%;left:50%;width:14px;height:14px;margin:-7px 0 0 -7px;pointer-events:none;z-index:5;background:linear-gradient(to right,transparent 0 6px,rgba(255,255,255,.8) 6px 8px,transparent 8px 14px),linear-gradient(to bottom,transparent 0 6px,rgba(255,255,255,.8) 6px 8px,transparent 8px 14px);filter:drop-shadow(0 0 3px rgba(0,0,0,.7))}.walk-joystick{position:absolute;bottom:20px;left:20px;width:110px;height:110px;border-radius:50%;background:#0505088c;border:2px solid rgba(255,183,64,.55);box-shadow:0 8px 24px #0000008c,0 0 22px #ffb7402e;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);touch-action:none;pointer-events:auto;z-index:6;user-select:none}.walk-joystick-ring{position:absolute;inset:10px;border-radius:50%;border:1px dashed rgba(255,183,64,.25)}.walk-joystick-thumb{position:absolute;top:50%;left:50%;width:44px;height:44px;margin:0;border-radius:50%;background:radial-gradient(circle at 30% 25%,rgba(120,180,255,.95),var(--blue) 70%);border:1px solid rgba(255,255,255,.25);box-shadow:0 6px 16px #0009,0 0 18px #3a8fff80;transform:translate(-50%,-50%);transition:transform 40ms linear;pointer-events:none}.room3d:not(.walk-mode) .walk-joystick,.venue3d:not(.walk-mode) .walk-joystick{display:none}.room3d.walk-mode .room3d-dims-hud{opacity:0;pointer-events:none}@media (max-width: 900px){.view-toggle-btn{padding:6px 10px;font-size:10px}.view-toggle-icon{width:13px;height:13px}.venue3d-chipstrip{top:8px;padding:4px;gap:4px}.venue3d-chip{padding:5px 10px;font-size:10px;gap:6px}.camera-mode-hud{top:10px;right:10px;padding:3px}.camera-mode-btn{padding:5px 9px 5px 7px;font-size:9.5px;gap:4px}.camera-mode-btn svg{width:12px;height:12px}}@media (max-width: 600px){.view-toggle{margin-right:0}.view-toggle-btn{padding:6px 9px;font-size:10px;letter-spacing:.06em}.view-toggle-icon{width:14px;height:14px}.view-toggle-label,.venue3d-chip-count{display:none}.room-station-row{grid-template-columns:1fr}.camera-mode-btn span{display:none}.walk-overlay-body{font-size:10px}}.side-panel-backdrop{position:fixed;inset:0;z-index:40;background:#04060a00;opacity:0;display:flex;justify-content:flex-end;pointer-events:none;transition:background .22s ease,opacity .22s ease}.side-panel-backdrop.is-open{background:#04060a8c;opacity:1;pointer-events:auto}.side-panel{position:relative;width:min(420px,100vw);height:100%;background:linear-gradient(180deg,var(--surface-2),var(--surface));border-left:1px solid var(--border-strong);box-shadow:-24px 0 60px #00000080;display:flex;flex-direction:column;transform:translate(16px);opacity:.9;transition:transform .26s cubic-bezier(.2,.9,.3,1),opacity .22s ease}.side-panel-backdrop.is-open .side-panel{transform:none;opacity:1}.side-panel-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px;border-bottom:1px solid var(--border)}.side-panel-title{font-family:var(--f-display);font-size:14px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text);margin:0}.side-panel-close{width:34px;height:34px;border-radius:8px}.side-panel-close svg{width:18px;height:18px}.side-panel-tabs{flex-shrink:0;display:grid;grid-template-columns:repeat(4,1fr);gap:2px;padding:10px 16px 12px;background:linear-gradient(180deg,rgba(14,16,22,.6),transparent);position:sticky;top:0;z-index:2}.side-panel-tab{appearance:none;background:transparent;border:0;color:var(--muted);font-family:var(--f-body);font-size:12.5px;font-weight:500;letter-spacing:.01em;padding:10px 8px;border-radius:8px;cursor:pointer;transition:color .16s ease,background .16s ease;min-height:40px}.side-panel-tab:hover{color:var(--text);background:#ffffff08}.side-panel-tab.is-active{color:var(--text);background:#3a8fff1f;box-shadow:inset 0 0 0 1px #3a8fff59}.side-panel-tab:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.side-panel-body{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;scrollbar-gutter:stable;padding:16px 20px 32px;display:flex;flex-direction:column;gap:20px}.panel-scroll::-webkit-scrollbar{width:10px}.panel-scroll::-webkit-scrollbar-track{background:#ffffff05}.panel-scroll::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:5px}.panel-scroll::-webkit-scrollbar-thumb:hover{background:#ffffff24}.sp-section{display:flex;flex-direction:column;gap:10px}.sp-section-head{display:flex;flex-direction:column;gap:2px}.sp-section h3{font-family:var(--f-display);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text);margin:0}.sp-section-sub{font-family:var(--f-body);font-size:12px;color:var(--muted);margin:0;line-height:1.45}.sp-advanced{margin-top:14px;padding:12px 14px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:10px}.sp-advanced>summary{cursor:pointer;font-family:var(--f-display);font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);list-style:none;user-select:none;padding:2px 0}.sp-advanced>summary::-webkit-details-marker{display:none}.sp-advanced>summary:before{content:"▸";display:inline-block;margin-right:8px;transition:transform .18s ease;color:var(--gold)}.sp-advanced[open]>summary:before{transform:rotate(90deg)}.sp-advanced[open]{border-color:#ffb7402e}.sp-advanced>*+*{margin-top:10px}.sp-section-collapsible .sp-section-toggle{appearance:none;background:#ffffff05;border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;align-items:center;gap:12px;width:100%;cursor:pointer;color:var(--text);transition:background .16s ease,border-color .16s ease}.sp-section-collapsible .sp-section-toggle:hover{background:#ffffff09;border-color:#ffffff24}.sp-section-collapsible .sp-section-toggle:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.sp-section-collapsible .sp-section-titles{flex:1;text-align:left;display:flex;flex-direction:column;gap:2px}.sp-section-collapsible h3{font-size:12.5px;letter-spacing:.1em}.sp-section-chevron{display:inline-grid;place-items:center;width:22px;height:22px;color:var(--muted);transition:transform .2s ease}.sp-section-chevron svg{width:14px;height:14px}.sp-section-collapsible[data-collapsed=true] .sp-section-chevron{transform:rotate(-90deg)}.sp-section-body{display:flex;flex-direction:column;gap:10px;padding:4px 2px 2px}.sp-section-body[hidden]{display:none}.sp-stat-card{display:flex;flex-direction:column;gap:12px;padding:18px 20px;background:linear-gradient(180deg,#3a8fff0a,#3a8fff03);border:1px solid rgba(58,143,255,.2);border-radius:12px}.sp-stat-big{display:flex;flex-direction:column;gap:4px}.sp-stat-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-top:8px;border-top:1px solid rgba(255,255,255,.05)}.sp-stat-cell{display:flex;flex-direction:column;gap:2px}.sp-stat-label{font-family:var(--f-body);font-size:11px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.sp-stat-value{font-family:var(--f-mono);font-weight:600;font-size:18px;color:var(--text);font-variant-numeric:tabular-nums}.sp-stat-value-big{font-size:32px;font-weight:700;color:var(--gold);text-shadow:0 0 14px rgba(255,183,64,.15)}.sp-breakdown{display:flex;flex-direction:column;gap:6px}.sp-breakdown-row{display:flex;justify-content:space-between;padding:10px 14px;background:#ffffff05;border:1px solid var(--border);border-radius:8px}.sp-breakdown-label{color:var(--subtle);font-size:13px}.sp-breakdown-value{font-family:var(--f-mono);font-weight:600;color:var(--text)}.sp-recent-list{display:flex;flex-direction:column;gap:4px}.sp-recent-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;background:#ffffff05;border:1px solid var(--border);border-radius:8px}.sp-recent-main{display:flex;flex-direction:column;gap:2px;min-width:0}.sp-recent-name{font-weight:600;color:var(--text);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-recent-sub{color:var(--muted);font-size:11.5px}.sp-recent-amount{font-family:var(--f-mono);font-weight:600;color:var(--gold);font-variant-numeric:tabular-nums}.sp-clock{display:flex;flex-direction:column;gap:2px;padding:14px 18px;border-radius:10px;background:#ffffff05;border:1px solid var(--border)}.sp-clock-time{font-family:var(--f-mono);font-weight:600;font-size:28px;color:var(--text);font-variant-numeric:tabular-nums}.sp-clock-date{font-family:var(--f-body);font-size:12px;color:var(--muted)}.sp-empty{font-size:12.5px;color:var(--muted);text-align:center;padding:16px;background:#ffffff05;border:1px dashed var(--border);border-radius:8px;margin:0}.sp-button-row{display:flex;gap:8px;flex-wrap:wrap}.sp-button-row>.btn{flex:1 1 auto;min-width:0}.sp-button-stack{display:flex;flex-direction:column;gap:10px}.sp-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#ffffff05;border:1px solid var(--border);border-radius:8px}.sp-row-stack{flex-direction:column;align-items:stretch;gap:6px}.sp-row>span{font-size:13px;color:var(--subtle)}.sp-input{width:100%;appearance:none;background:var(--surface);border:1px solid var(--border-strong);color:var(--text);border-radius:8px;padding:10px 12px;font-size:13.5px;font-family:var(--f-body);outline:none;transition:border-color .16s ease,box-shadow .16s ease}.sp-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3a8fff2e}.sp-input:focus-visible{outline:none}.sp-select{width:100%;appearance:none;background:var(--surface);border:1px solid var(--border-strong);color:var(--text);border-radius:8px;padding:10px 30px 10px 12px;font-family:var(--f-body);font-size:13.5px;outline:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%238A8FA0' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M4 6 L8 10 L12 6'/></svg>");background-repeat:no-repeat;background-position:right 10px center;background-size:14px;transition:border-color .16s ease,box-shadow .16s ease}.sp-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3a8fff2e}.sp-num{display:inline-flex;align-items:center;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;overflow:hidden;transition:border-color .16s ease,box-shadow .16s ease}.sp-num:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px #3a8fff2e}.sp-num>span{padding:0 10px;color:var(--muted);font-family:var(--f-mono);font-size:12.5px}.sp-num input{width:80px;background:transparent;border:none;color:var(--text);font-family:var(--f-mono);font-weight:500;text-align:right;padding:9px 10px 9px 0;outline:none;font-variant-numeric:tabular-nums}.sp-inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.sp-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:#ffffff05;border:1px solid var(--border);border-radius:8px;cursor:pointer}.sp-toggle input{display:none}.sp-toggle-label{display:flex;flex-direction:column;gap:2px;min-width:0}.sp-toggle-title{font-size:13.5px;color:var(--text);font-weight:500}.sp-toggle-sub{font-size:11.5px;color:var(--muted)}.sp-toggle-track{flex-shrink:0;width:36px;height:20px;background:var(--surface-3);border-radius:999px;position:relative;transition:background .16s ease}.sp-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .18s cubic-bezier(.2,.9,.3,1)}.sp-toggle input:checked+.sp-toggle-track{background:var(--blue)}.sp-toggle input:checked+.sp-toggle-track .sp-toggle-thumb{transform:translate(16px)}.sp-toggle:has(input:focus-visible){outline:2px solid var(--blue);outline-offset:2px}.sp-item-list{display:flex;flex-direction:column;gap:6px}.sp-item-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px;padding:10px 12px;background:#ffffff05;border:1px solid var(--border);border-radius:8px;transition:background .16s ease,border-color .16s ease}.sp-item-row:hover{background:#ffffff09;border-color:#ffffff24}.sp-item-row-fixture{grid-template-columns:1fr;gap:8px}.sp-item-main{display:flex;flex-direction:column;gap:2px;min-width:0}.sp-item-name{font-size:13.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-item-sub{font-size:11.5px;color:var(--muted)}.sp-item-name-input{width:100%;background:transparent;border:none;color:var(--text);font-size:13.5px;font-weight:500;padding:2px 0;outline:none;border-bottom:1px solid transparent;transition:border-color .14s ease}.sp-item-name-input:focus{border-bottom-color:var(--blue)}.sp-item-select{appearance:none;background:#ffffff05;border:1px solid var(--border);color:var(--text);border-radius:6px;padding:6px 22px 6px 8px;font-size:12px;outline:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%238A8FA0' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M4 6 L8 10 L12 6'/></svg>");background-repeat:no-repeat;background-position:right 6px center;background-size:12px;transition:border-color .16s ease}.sp-item-select:focus{border-color:var(--blue)}.sp-item-delete{appearance:none;background:transparent;border:1px solid transparent;color:var(--muted);width:32px;height:32px;border-radius:6px;cursor:pointer;display:inline-grid;place-items:center;transition:background .16s ease,color .16s ease,border-color .16s ease}.sp-item-delete svg{width:16px;height:16px}.sp-item-delete:hover{background:#ff40401a;border-color:#ff404059;color:var(--red)}.sp-item-delete:focus-visible{outline:2px solid var(--red);outline-offset:1px}.sp-item-delete:disabled{opacity:.4;cursor:not-allowed}.sp-item-fields{display:flex;gap:6px;flex-wrap:wrap}.sp-mini{display:inline-flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border-strong);border-radius:6px;overflow:hidden;padding:0 6px;transition:border-color .16s ease,box-shadow .16s ease}.sp-mini:focus-within{border-color:var(--blue);box-shadow:0 0 0 2px #3a8fff2e}.sp-mini>span{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.sp-mini input{width:58px;background:transparent;border:none;color:var(--text);font-family:var(--f-mono);font-size:12px;text-align:right;padding:6px 2px;outline:none;font-variant-numeric:tabular-nums}.sp-rooms-list{display:flex;flex-direction:column;gap:8px}.sp-room-card{display:flex;flex-direction:column;gap:10px;padding:12px 14px;background:#ffffff05;border:1px solid var(--border);border-radius:10px}.sp-room-head{display:flex;align-items:center;gap:10px}.sp-room-swatch{width:14px;height:14px;border-radius:4px;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}.sp-room-name{flex:1;background:transparent;border:none;color:var(--text);font-weight:500;font-size:13.5px;padding:2px 0;outline:none;border-bottom:1px solid transparent;transition:border-color .14s ease}.sp-room-name:focus{border-bottom-color:var(--blue)}.sp-room-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.sp-room-footer{display:flex;align-items:center;justify-content:space-between}.sp-room-color{width:32px;height:24px;border:1px solid var(--border);border-radius:6px;background:transparent;cursor:pointer;padding:0}.sp-payment-list{display:flex;flex-wrap:wrap;gap:6px;min-height:30px}.sp-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 8px 6px 12px;background:#3a8fff14;border:1px solid rgba(58,143,255,.25);border-radius:999px;color:var(--text);font-size:12.5px}.sp-chip-remove{appearance:none;background:transparent;border:none;color:var(--muted);padding:4px;width:22px;height:22px;border-radius:50%;cursor:pointer;display:inline-grid;place-items:center;transition:color .16s ease,background .16s ease}.sp-chip-remove svg{width:10px;height:10px}.sp-chip-remove:hover{background:#ff404029;color:var(--red)}.sp-diag{display:flex;flex-direction:column;gap:4px}.sp-diag-row{display:flex;justify-content:space-between;padding:8px 12px;background:#ffffff05;border:1px solid var(--border);border-radius:6px;font-size:12px}.sp-diag-row>span{color:var(--muted)}.sp-diag-row code{font-family:var(--f-mono);color:var(--text);font-size:11.5px}.sp-sync-status{font-family:var(--f-mono);font-size:11.5px;color:var(--muted);padding:4px 10px;background:#ffffff08;border-radius:999px;border:1px solid var(--border)}.fixture-picker-backdrop{position:fixed;inset:0;z-index:50;background:#04060a00;opacity:0;display:grid;place-items:center;pointer-events:none;transition:background .2s ease,opacity .2s ease}.fixture-picker-backdrop.is-open{background:#04060a8c;opacity:1;pointer-events:auto}.fixture-picker{width:min(420px,calc(100vw - 32px));background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);border-radius:12px;padding:20px 22px;box-shadow:0 30px 70px #0000008c;transform:translateY(10px) scale(.98);transition:transform .22s cubic-bezier(.2,.9,.3,1)}.fixture-picker-backdrop.is-open .fixture-picker{transform:none}.fixture-picker h3{font-family:var(--f-display);font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--text);margin:0 0 4px}.fixture-picker-sub{color:var(--muted);font-size:12px;margin:0 0 16px}.fixture-picker-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.fixture-pick{appearance:none;display:flex;flex-direction:column;gap:6px;align-items:flex-start;padding:14px 16px;background:#ffffff05;border:1px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;transition:background .16s ease,border-color .16s ease,transform .16s ease;text-align:left}.fixture-pick:hover{background:#3a8fff0f;border-color:#3a8fff59;transform:translateY(-1px)}.fixture-pick:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.fixture-pick-icon{width:36px;height:36px;border-radius:8px;background:#3a8fff1a;border:1px solid rgba(58,143,255,.25);display:grid;place-items:center;color:var(--blue-bright)}.fixture-pick-icon svg{width:18px;height:18px}.fixture-pick-name{font-weight:600;font-size:14px}.fixture-pick-sub{font-size:11.5px;color:var(--muted)}.fixture-picker-actions{display:flex;justify-content:flex-end}.room3d-action-cluster{display:inline-flex;gap:4px;padding:4px;background:#080a10eb;border:1px solid rgba(255,255,255,.12);border-radius:10px;box-shadow:0 6px 20px #00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transform:translate(-50%,-50%);pointer-events:auto}.room3d-action-btn{appearance:none;background:transparent;border:0;color:var(--text);width:30px;height:30px;border-radius:6px;cursor:pointer;display:inline-grid;place-items:center;transition:background .16s ease,color .16s ease}.room3d-action-btn svg{width:16px;height:16px}.room3d-action-btn:hover{background:#ffffff14}.room3d-action-btn-danger:hover{background:#ff404029;color:var(--red)}.room3d-action-btn:focus-visible{outline:2px solid var(--blue);outline-offset:1px}.tile{box-shadow:0 1px #ffffff0a,0 6px 18px #0000004d}.btn{font-family:var(--f-body);font-weight:500;font-size:13px;padding:10px 16px;border-radius:8px;letter-spacing:.01em;text-transform:none;transition:background .18s ease,border-color .18s ease,transform .14s ease,box-shadow .18s ease;min-height:40px}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.btn-primary{background:linear-gradient(180deg,#3a8fffe6,#3a8fffb3);border-color:#3a8fffb3;color:#fff;box-shadow:0 1px #ffffff1a inset}.btn-primary:hover{background:linear-gradient(180deg,#3a8fff,#3a8fffd9);border-color:var(--blue-bright)}.btn-ghost{background:#ffffff08;border-color:var(--border);color:var(--text)}.btn-ghost:hover{background:#ffffff0f;border-color:#ffffff2e}.btn-danger{background:#ff404026;border-color:#ff404073;color:#ffb8b8}.btn-danger:hover{background:#ff404038;border-color:#ff4040b3;color:#ffd4d4}.btn-danger.btn-outline{background:transparent;border-color:#ff404073;color:var(--red)}.btn-danger.btn-outline:hover{background:#ff404014}.btn-compact{padding:7px 12px;font-size:12px;min-height:34px}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;transform:none}.icon-btn{appearance:none;background:transparent;border:1px solid transparent;color:var(--text);width:36px;height:36px;border-radius:8px;cursor:pointer;display:inline-grid;place-items:center;transition:background .18s ease,border-color .18s ease,color .18s ease}.icon-btn:hover{background:#ffffff0d;border-color:#ffffff1a}.icon-btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.welcome-card{background:var(--surface-2);border-color:#ffffff14;box-shadow:0 10px 30px #00000059}.welcome-card .welcome-eyebrow{letter-spacing:.16em;font-size:10.5px}@media (max-width: 640px){.side-panel{width:100vw;border-left:none}.side-panel-tabs{grid-template-columns:repeat(4,1fr);padding:8px 12px 10px}.side-panel-body{padding:14px 16px 32px}.side-panel-tab{font-size:11.5px;padding:9px 4px}.topbar-inner{padding:10px 14px;gap:10px}.brand-lounge{font-size:12.5px}.view-toggle-btn{padding:7px 10px;font-size:12px}.view-toggle-label{display:inline}.sp-item-row{grid-template-columns:1fr auto}.sp-item-row .sp-item-select{grid-column:1 / -1}.sp-stat-value-big{font-size:28px}.sp-room-fields{grid-template-columns:1fr 1fr}}.pin-modal-backdrop{position:fixed;inset:0;z-index:90;background:#04060a00;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);opacity:0;display:grid;place-items:center;pointer-events:none;transition:background .22s ease,backdrop-filter .22s ease,opacity .22s ease}.pin-modal-backdrop.is-open{background:#04060ac7;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:1;pointer-events:auto}.pin-modal{position:relative;width:min(440px,calc(100vw - 32px));background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid rgba(255,183,64,.35);border-radius:16px;padding:28px 28px 22px;box-shadow:0 30px 80px #0009,0 0 0 1px #ffb74026 inset,0 0 60px #ffb74014;transform:translateY(14px) scale(.96);transition:transform .24s cubic-bezier(.2,.9,.3,1);text-align:center}.pin-modal-backdrop.is-open .pin-modal{transform:none}.pin-modal-glow{position:absolute;inset:-2px;border-radius:18px;background:radial-gradient(600px 200px at 50% 0%,rgba(255,183,64,.12),transparent 60%);pointer-events:none;z-index:0}.pin-modal>*{position:relative;z-index:1}.pin-modal-title{font-family:var(--f-display);font-size:20px;letter-spacing:.06em;text-transform:uppercase;color:var(--text);margin:0 0 8px}.pin-modal-sub{color:var(--muted);font-size:13.5px;line-height:1.5;margin:0 0 20px;max-width:360px;margin-inline:auto}.pin-stage{display:flex;flex-direction:column;gap:14px;margin-bottom:14px}.pin-row{display:flex;flex-direction:column;gap:6px;align-items:center}.pin-row-label{font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);font-weight:600}.pin-input-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;width:100%;max-width:340px;margin-inline:auto}.pin-input{appearance:none;width:100%;aspect-ratio:1 / 1.15;background:#ffffff08;border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-family:var(--f-mono);font-size:24px;font-weight:600;text-align:center;outline:none;caret-color:var(--gold);transition:border-color .14s ease,background .14s ease,box-shadow .14s ease,transform .14s ease}.pin-input::-webkit-outer-spin-button,.pin-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pin-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #ffb7402e,0 0 16px #ffb7402e;background:#ffb7400d}.pin-input.is-filled{border-color:#3a8fffa6;background:#3a8fff14;color:var(--blue-bright)}.pin-input:disabled{opacity:.55;cursor:not-allowed}.pin-msg{min-height:18px;font-size:13px;margin:8px 0 14px;color:var(--muted);transition:color .16s ease}.pin-msg.is-error{color:var(--red);font-weight:500}.pin-msg.is-locked{color:var(--gold);font-weight:500;font-family:var(--f-mono)}.pin-msg.is-success{color:var(--green);font-weight:500}.pin-actions{display:flex;gap:10px;justify-content:center;margin-bottom:12px}.pin-actions .btn{min-width:110px}.pin-hint{margin:6px 0 0;font-size:11.5px;color:var(--subtle);letter-spacing:.02em}.pin-form-fields{display:flex;flex-direction:column;gap:10px;margin-bottom:6px;text-align:left}.pin-text-input{font-family:var(--f-mono);letter-spacing:.4em;text-align:center;font-size:16px}@keyframes pin-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.pin-modal.is-shake{animation:pin-shake .36s ease}.sync-status-card{background:#ffffff06;border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.sync-status-card--pending{border-color:#ffb74059;background:#ffb7400a}.sync-status-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.sync-status-row--sub{padding-top:8px;border-top:1px solid var(--border);font-size:12.5px}.sync-status-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;box-shadow:0 0 #0000}.sync-status-dot--green{background:var(--green);box-shadow:0 0 12px #39ff148c;animation:sync-pulse 2.4s ease-in-out infinite}.sync-status-dot--gold{background:var(--gold);box-shadow:0 0 12px #ffb74080}.sync-status-dot--red{background:var(--red);box-shadow:0 0 12px #ff404080}@keyframes sync-pulse{0%,to{box-shadow:0 0 #39ff1480}50%{box-shadow:0 0 14px 2px #39ff14b3}}.sync-status-text{font-weight:600;font-size:14px;color:var(--text)}.sync-status-meta{margin-left:auto;color:var(--muted);font-size:12px;font-family:var(--f-mono)}.sync-status-label{color:var(--muted);font-size:12px;letter-spacing:.04em}.sync-status-code{margin-left:auto;font-family:var(--f-mono);font-size:12px;background:#ffffff0a;padding:3px 8px;border-radius:5px;color:var(--blue-bright)}.sync-status-pill{margin-left:auto;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:3px 8px;border-radius:999px;background:#39ff141f;color:var(--green);border:1px solid rgba(57,255,20,.4)}@media (prefers-reduced-motion: reduce){.side-panel-backdrop,.side-panel,.fixture-picker-backdrop,.fixture-picker,.pin-modal-backdrop,.pin-modal{transition:none}.pin-modal.is-shake,.sync-status-dot--green{animation:none}}@media (max-width: 480px){.pin-modal{padding:22px 18px 18px}.pin-modal-title{font-size:17px}.pin-input-row{gap:6px}.pin-input{font-size:20px;border-radius:8px}}.insights-section{display:flex;flex-direction:column;gap:14px}.insights-grid{display:grid;grid-template-columns:1fr;gap:14px}@media (min-width: 720px){.insights-grid{grid-template-columns:1fr 1fr}}.insight-card{position:relative;background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-tile);overflow:hidden}.insight-card:before{content:"";position:absolute;inset:0;border-radius:14px;pointer-events:none;border:1px solid transparent;background:linear-gradient(180deg,rgba(255,183,64,.14),transparent 60%) border-box;-webkit-mask:linear-gradient(#000 0 0) padding-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude}.insight-card-head{display:flex;flex-direction:column;gap:2px}.insight-card-title{margin:0;font-family:var(--f-display);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}.insight-card-sub{margin:0;font-family:var(--f-body);font-size:11px;color:var(--muted);line-height:1.35}.insight-canvas-wrap{position:relative}.insight-canvas{display:block;width:100%;height:140px}.insight-canvas-tall{height:180px}.insight-tooltip{position:absolute;pointer-events:none;z-index:5;background:#0a0c12f5;border:1px solid var(--border-strong);border-radius:8px;padding:8px 10px;font-family:var(--f-body);font-size:11px;line-height:1.35;color:var(--text);box-shadow:0 12px 28px #0000008c;min-width:140px;max-width:220px}.insight-tooltip-title{font-family:var(--f-display);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:2px}.insight-tooltip-row{font-family:var(--f-mono);color:var(--text)}.insight-stat-row{display:flex;gap:12px;flex-wrap:wrap}.insight-stat-row>*{flex:1 1 auto;font-family:var(--f-mono);font-size:11px;color:var(--muted)}.insight-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:18px 10px;color:var(--muted);border:1px dashed rgba(255,255,255,.1);border-radius:10px;background:#ffffff04;min-height:120px}.insight-empty-icon{display:inline-flex;width:28px;height:28px;color:#ffb7408c}.insight-empty-icon svg{width:100%;height:100%}.insight-empty-msg{font-size:12px;line-height:1.45;max-width:260px}.tournament-leaderboard{display:flex;flex-direction:column;gap:14px}.tournament-section-title{font-family:var(--f-display);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-bright);margin:0 0 6px}.tournament-history-list,.hall-of-fame-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.tournament-history-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:8px;background:#ffffff06;border:1px solid rgba(255,255,255,.04)}.tournament-history-main{display:flex;flex-direction:column;gap:2px;min-width:0}.tournament-history-date{font-family:var(--f-mono);font-size:10.5px;color:var(--muted);letter-spacing:.04em}.tournament-history-winner{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tournament-history-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-family:var(--f-mono);font-size:10.5px;color:var(--muted);white-space:nowrap}.tournament-history-prize{color:var(--gold);font-weight:600}.hall-of-fame-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:6px 10px;border-radius:8px;background:#ffffff05}.hall-of-fame-rank{font-family:var(--f-display);font-size:11px;font-weight:700;color:var(--gold);width:18px;height:18px;display:inline-grid;place-items:center;border:1px solid rgba(255,183,64,.4);border-radius:50%}.hall-of-fame-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hall-of-fame-wins{font-family:var(--f-mono);font-size:11px;color:var(--muted)}.hall-of-fame-empty{font-size:12px;color:var(--muted);font-style:italic;padding:4px 2px}.report-modal{width:min(680px,calc(100vw - 32px));max-height:calc(100vh - 64px);display:flex;flex-direction:column}.report-body{overflow-y:auto;padding:16px 22px 8px;display:flex;flex-direction:column;gap:18px}.report-footer{border-top:1px solid var(--border)}.report-summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media (min-width: 600px){.report-summary-grid{grid-template-columns:repeat(4,1fr)}}.report-summary-card{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:10px;background:#ffffff06;border:1px solid var(--border)}.report-summary-label{font-family:var(--f-display);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.report-summary-value{font-family:var(--f-mono);font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.01em}.report-summary-value-big{font-size:24px;color:var(--gold)}.report-summary-value-sm{font-size:13px;font-weight:600}.report-section{display:flex;flex-direction:column;gap:6px}.report-section-title{margin:0 0 4px;font-family:var(--f-display);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-bright)}.report-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.report-list li{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:8px 12px;background:#ffffff05;border:1px solid var(--border);border-radius:8px;font-size:13px}.report-list li>span:first-child{color:var(--text);font-weight:500}.report-list-meta{font-family:var(--f-mono);font-size:11px;color:var(--muted)}.report-list strong{font-family:var(--f-mono);color:var(--gold);font-size:13px;font-weight:700;justify-self:end}.report-empty{margin:0;padding:10px 12px;font-size:12px;color:var(--muted);background:#ffffff05;border:1px dashed rgba(255,255,255,.08);border-radius:8px}.report-footer-note{margin:0;font-size:11px;color:var(--muted);text-align:center;padding:4px 0 0}@media print{body>#app,.side-panel-backdrop,.modal-backdrop,.tournament-overlay,.pin-modal-backdrop{display:none!important}}body.is-free-board{overflow:hidden;cursor:default}body.is-free-board #app{height:100vh;height:100dvh}.free-board{position:relative;display:grid;grid-template-rows:auto 1fr auto;height:100%;width:100%;padding:clamp(16px,2vw,32px) clamp(16px,2.5vw,40px);gap:clamp(16px,2vw,28px);background:var(--bg);color:var(--text);overflow:hidden}.free-board-ambient{position:absolute;inset:0;pointer-events:none;z-index:0;background:radial-gradient(1400px 700px at 12% -10%,rgba(255,183,64,.14),transparent 60%),radial-gradient(1100px 600px at 110% 0%,rgba(58,143,255,.1),transparent 55%),radial-gradient(1200px 800px at 50% 120%,rgba(255,140,0,.08),transparent 60%)}.free-board>*{position:relative;z-index:1}.free-board-header{display:flex;align-items:center;justify-content:space-between;gap:24px}.free-board-brand{display:flex;align-items:center;gap:16px}.free-board-mark{width:clamp(48px,5vw,72px);height:clamp(48px,5vw,72px);display:grid;place-items:center;border-radius:50%;background:radial-gradient(circle at 35% 30%,#3a8fff59,#3a8fff0d 65%);border:1px solid rgba(58,143,255,.45);box-shadow:0 0 28px #3a8fff40;color:var(--blue-bright)}.free-board-mark svg{width:60%;height:60%}.free-board-titles{display:flex;flex-direction:column;gap:4px}.free-board-eyebrow{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:clamp(10px,.9vw,13px);letter-spacing:.32em;text-transform:uppercase;font-weight:700;color:var(--gold);position:relative;padding-left:14px}.free-board-eyebrow:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold);animation:free-board-pulse 1.6s ease-in-out infinite}@keyframes free-board-pulse{0%,to{opacity:1;transform:translateY(-50%) scale(1)}50%{opacity:.55;transform:translateY(-50%) scale(.85)}}.free-board-lounge{font-family:var(--f-display);font-size:clamp(28px,4vw,56px);font-weight:800;letter-spacing:.06em;line-height:1;color:var(--text)}.free-board-clock{font-family:var(--f-mono);font-size:clamp(22px,2.6vw,38px);font-weight:700;letter-spacing:.05em;color:var(--text);padding:10px 18px;border-radius:14px;background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);box-shadow:var(--shadow-tile);font-variant-numeric:tabular-nums}.free-board-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,28px);min-height:0}.free-board-col{display:grid;grid-template-rows:auto 1fr;min-height:0;padding:clamp(16px,1.6vw,24px);border-radius:22px;background:linear-gradient(180deg,#14161fd9,#0c0e14d9);border:1px solid var(--border-strong);box-shadow:var(--shadow-tile);backdrop-filter:blur(2px)}.free-board-col-free{border-color:#39ff1459;box-shadow:var(--shadow-tile),0 0 50px #39ff140f}.free-board-col-busy{border-color:#3a8fff52;box-shadow:var(--shadow-tile),0 0 50px #3a8fff0f}.free-board-col-head{display:flex;align-items:center;gap:12px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--border)}.free-board-col-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.free-board-col-dot.is-free{background:var(--green);box-shadow:0 0 14px #39ff14b3}.free-board-col-dot.is-busy{background:var(--blue);box-shadow:0 0 14px #3a8fffa6}.free-board-col-title{font-family:var(--f-display);font-size:clamp(18px,1.8vw,26px);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text);margin:0}.free-board-col-count{margin-left:auto;font-family:var(--f-mono);font-size:clamp(14px,1.4vw,18px);font-weight:700;color:var(--muted);padding:4px 12px;border-radius:999px;background:#ffffff0d;border:1px solid var(--border)}.free-board-col-body{overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.18) transparent;padding-right:4px;min-height:0}.free-board-col-body::-webkit-scrollbar{width:6px}.free-board-col-body::-webkit-scrollbar-thumb{background:#ffffff29;border-radius:4px}.free-board-group+.free-board-group{margin-top:clamp(14px,1.4vw,22px);padding-top:clamp(14px,1.4vw,22px);border-top:1px dashed var(--border)}.free-board-group-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.free-board-group-name{font-family:var(--f-display);font-size:clamp(14px,1.2vw,18px);font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}.free-board-group-pill{font-family:var(--f-mono);font-size:clamp(11px,.9vw,13px);font-weight:600;letter-spacing:.06em;color:var(--green);padding:3px 10px;border-radius:999px;background:#39ff141a;border:1px solid rgba(57,255,20,.35)}.free-board-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.free-board-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:clamp(10px,1vw,16px) clamp(12px,1.2vw,18px);border-radius:14px;background:#ffffff06;border:1px solid var(--border);transition:background .2s ease,border-color .2s ease}.free-board-row--free{border-color:#39ff142e}.free-board-row--free:hover{background:#39ff140a;border-color:#39ff1447}.free-board-row--busy{border-color:#3a8fff2e}.free-board-row--busy.is-warning{border-color:#ffcc3352;background:#ffcc3308}.free-board-row--busy.is-critical{border-color:#ff40406b;background:#ff40400d;animation:free-board-flash 1.6s ease-in-out infinite}.free-board-row--busy.is-expired{border-color:#ff40408c;background:#ff404012}@keyframes free-board-flash{0%,to{box-shadow:0 0 #ff404000}50%{box-shadow:0 0 0 1px #ff404066,0 0 18px #ff404026}}.free-board-row-name{display:flex;flex-direction:column;gap:2px;min-width:0;font-family:var(--f-display);font-size:clamp(15px,1.5vw,22px);font-weight:700;letter-spacing:.04em;color:var(--text)}.free-board-row-name-main{font-family:var(--f-display);font-size:clamp(15px,1.5vw,22px);font-weight:700;letter-spacing:.04em;color:var(--text)}.free-board-row-name-sub{font-family:var(--f-mono);font-size:clamp(10px,.85vw,12px);font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.free-board-row-status{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:clamp(11px,.9vw,13px);font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--green);padding:4px 12px;border-radius:999px;background:#39ff1414;border:1px solid rgba(57,255,20,.3)}.free-board-status-dot{width:8px;height:8px;border-radius:50%}.free-board-status-dot.is-free{background:var(--green);box-shadow:0 0 8px #39ff14b3}.free-board-row-time{flex-shrink:0;text-align:right}.free-board-time-pill{display:inline-flex;align-items:baseline;gap:6px;font-family:var(--f-mono);font-size:clamp(20px,2.2vw,32px);font-weight:700;letter-spacing:.04em;color:var(--text);font-variant-numeric:tabular-nums;padding:6px 14px;border-radius:12px;background:#3a8fff1f;border:1px solid rgba(58,143,255,.32)}.free-board-time-pill-sub{font-size:.45em;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}.is-warning .free-board-time-pill{background:#ffcc331a;border-color:#fc36;color:var(--yellow)}.is-critical .free-board-time-pill{background:#ff40401f;border-color:#ff404073;color:var(--red)}.free-board-time-pill.is-over,.is-expired .free-board-time-pill{background:#ff40402e;border-color:#ff40408c;color:var(--red);font-size:clamp(14px,1.4vw,18px);letter-spacing:.12em;text-transform:uppercase}.free-board-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;padding:24px 16px;color:var(--muted);height:100%;min-height:180px}.free-board-empty-icon{width:48px;height:48px;color:var(--muted);opacity:.6}.free-board-empty-title{font-family:var(--f-display);font-size:clamp(15px,1.4vw,20px);font-weight:700;color:var(--text);letter-spacing:.04em}.free-board-empty-sub{font-size:clamp(12px,1vw,14px);color:var(--muted)}.free-board-footer{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;padding:14px clamp(16px,1.6vw,24px);border-radius:18px;background:linear-gradient(180deg,#14161fb3,#0c0e14b3);border:1px solid var(--border-strong);box-shadow:var(--shadow-tile)}.free-board-foot-left,.free-board-foot-right{display:flex;flex-direction:column;gap:2px;min-width:0}.free-board-foot-right{text-align:right}.free-board-foot-center{display:flex;justify-content:center}.free-board-foot-label{font-family:var(--f-mono);font-size:clamp(10px,.85vw,12px);font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}.free-board-foot-value{font-family:var(--f-display);font-size:clamp(14px,1.2vw,17px);font-weight:700;color:var(--text);letter-spacing:.04em}.free-board-tournament-badge{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;border-radius:999px;background:linear-gradient(90deg,#ffb74029,#ff8c001a);border:1px solid rgba(255,183,64,.45);color:var(--gold);font-family:var(--f-display);font-size:clamp(12px,1.1vw,15px);font-weight:700;letter-spacing:.14em;text-transform:uppercase;box-shadow:0 0 22px #ffb7402e}.free-board-tournament-dot{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold);animation:free-board-pulse 1.6s ease-in-out infinite}@media (max-width: 880px){.free-board-grid{grid-template-columns:1fr}.free-board-footer{grid-template-columns:1fr;text-align:center;gap:10px}.free-board-foot-left,.free-board-foot-right{text-align:center}}@media (max-width: 540px){.free-board-header{flex-direction:column;align-items:flex-start;gap:14px}.free-board-clock{align-self:flex-end}}@media (prefers-reduced-motion: reduce){.free-board-eyebrow:before,.free-board-tournament-dot,.free-board-row--busy.is-critical{animation:none!important}}.toast-install{position:fixed;right:22px;bottom:22px;z-index:90;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px 16px;width:min(380px,calc(100vw - 32px));background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid rgba(255,183,64,.45);border-radius:14px;box-shadow:0 18px 44px #0000008c,0 0 28px #ffb74029,inset 0 1px #ffffff0d;transform:translate(20px,20px);opacity:0;pointer-events:none;transition:transform .25s cubic-bezier(.2,.9,.3,1),opacity .2s ease}.toast-install.is-open{transform:translate(0);opacity:1;pointer-events:auto}.toast-install.is-leaving{transform:translate(20px,20px);opacity:0}.toast-install-icon{width:36px;height:36px;display:grid;place-items:center;border-radius:10px;color:var(--gold);background:#ffb7401a;border:1px solid rgba(255,183,64,.35);flex-shrink:0}.toast-install-icon svg{width:60%;height:60%}.toast-install-body{display:flex;flex-direction:column;gap:2px;min-width:0}.toast-install-title{font-family:var(--f-display);font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--text)}.toast-install-sub{font-family:var(--f-mono);font-size:11px;color:var(--muted);letter-spacing:.02em}.toast-install-actions{display:flex;gap:6px;flex-shrink:0}.toast-install-btn{appearance:none;background:transparent;border:1px solid var(--border-strong);color:var(--text);font-family:var(--f-mono);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:7px 12px;border-radius:8px;cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease}.toast-install-btn-ghost:hover{background:#ffffff0d}.toast-install-btn-primary{background:linear-gradient(180deg,var(--gold),var(--gold-deep));border-color:var(--gold);color:#0b0d14;box-shadow:0 6px 18px #ffb7404d}.toast-install-btn-primary:hover{filter:brightness(1.08)}@media (max-width: 480px){.toast-install{right:12px;left:12px;bottom:12px;width:auto}}@media (prefers-reduced-motion: reduce){.toast-install{transition:opacity .16s ease}}
