: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;display:flex;flex-direction:column;gap:0;background:linear-gradient(180deg,#14161feb,#0c0e14eb);border-bottom:1px solid var(--border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.topbar-row{display:flex;align-items:center;gap:20px;padding:12px 22px}.topbar-row-primary{justify-content:space-between}.topbar-row-secondary{padding-top:4px;padding-bottom:14px;border-top:1px solid rgba(255,255,255,.05);gap:18px}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{width:34px;height:34px;border-radius:9px;background:radial-gradient(circle at 35% 30%,var(--blue-bright),var(--blue) 55%,#0F3E82 100%);box-shadow:0 0 0 1px #ffffff14,inset 0 1px #ffffff4d,0 0 22px #3a8fff59;position:relative}.brand-mark:before{content:"8";position:absolute;inset:0;display:grid;place-items:center;font-family:var(--f-display);font-weight:900;font-size:14px;color:var(--gold)}.brand-text{display:flex;align-items:baseline;gap:8px;font-family:var(--f-display);font-weight:800;letter-spacing:.12em}.brand-lounge{font-size:16px;color:var(--text);text-transform:uppercase;white-space:nowrap}.brand-sep{color:var(--muted);font-weight:500}.brand-ops{font-size:16px;background:linear-gradient(90deg,var(--gold),var(--blue-bright));-webkit-background-clip:text;background-clip:text;color:transparent}.stats{display:flex;gap:10px;flex:1 1 auto;min-width:0;flex-wrap:wrap}.stat{padding:8px 14px;border-radius:10px;background:#ffffff05;border:1px solid var(--border);min-width:112px;text-align:left;transition:background .2s ease,border-color .2s ease,transform .16s ease;position:relative}.stat:hover{background:#ffffff09;border-color:#ffffff24}.stat-label{display:block;font-size:10px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin-bottom:2px}.stat-value{display:block;font-family:var(--f-mono);font-weight:700;font-size:20px;letter-spacing:-.01em;color:var(--text);font-variant-numeric:tabular-nums}.stat-rev .stat-value{color:var(--gold);text-shadow:0 0 18px rgba(255,183,64,.35)}.primary-actions{display:flex;align-items:center;gap:8px}.clock{display:flex;flex-direction:column;align-items:flex-start;line-height:1;gap:2px;padding:4px 12px;border-radius:8px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);min-width:86px}.clock-time{font-family:var(--f-mono);font-weight:600;font-size:14px;color:var(--text);letter-spacing:.02em;font-variant-numeric:tabular-nums}.clock-date{font-family:var(--f-display);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}.action-group{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:auto;padding:4px;border-radius:12px;background:#ffffff05;border:1px solid rgba(255,255,255,.04)}.action-group .btn{transition:background .16s ease,color .16s ease,border-color .16s ease}.action-group .btn.is-active{background:linear-gradient(180deg,#3a8fff2e,#3a8fff0f);border-color:#3a8fff80;color:var(--text);box-shadow:inset 0 0 0 1px #3a8fff40,0 0 12px #3a8fff1f}.btn-pill{border-radius:9px;padding:8px 14px;font-size:11px}.overflow-menu{position:relative;display:inline-flex}.overflow-btn{width:36px;height:36px;border-radius:9px}.overflow-btn svg{width:16px;height:16px}.overflow-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:6;min-width:240px;padding:6px;background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--border-strong);border-radius:12px;box-shadow:0 20px 50px #0000008c,0 0 0 1px #ffffff05;display:flex;flex-direction:column;gap:2px;animation:overflowIn .16s ease}@keyframes overflowIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.overflow-item{appearance:none;background:transparent;border:none;color:var(--text);font-family:var(--f-body);font-size:13px;text-align:left;padding:10px 12px;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:2px;line-height:1.25;transition:background .14s ease;min-height:44px;justify-content:center}.overflow-item:hover{background:#ffffff0a}.overflow-item:focus-visible{background:#3a8fff1a;outline:1px solid rgba(58,143,255,.45)}.overflow-item-label{font-family:var(--f-display);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.overflow-item-hint{font-size:11px;color:var(--muted);letter-spacing:.02em}.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}.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:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;margin-right:0;flex-shrink:0}.view-toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:9px;border:0;background:transparent;color:var(--subtle);font-family:var(--f-display);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:color .14s ease,background .14s ease,box-shadow .14s ease;position:relative;white-space:nowrap}.view-toggle-btn:hover{color:var(--text)}.view-toggle-btn.is-active{color:var(--text);background:linear-gradient(180deg,#3a8fff29,#3a8fff0f);box-shadow:inset 0 0 0 1px #3a8fff73,0 0 12px #3a8fff2e}.view-toggle-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;color:currentColor}.view-toggle-icon svg{width:100%;height:100%}.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="3d"] .floor{opacity:0;visibility:hidden;pointer-events:none}.stage[data-view="3d"] .room3d{opacity:1;visibility:visible;pointer-events:auto}.floor{transition:opacity .24s ease}.stage.is-switching .floor,.stage.is-switching .room3d{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}@media (max-width: 900px){.view-toggle-btn{padding:6px 10px;font-size:10px}.view-toggle-icon{width:13px;height:13px}}@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}}
