*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:Space Grotesk,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0e0b0d;color:#faf5f7}a{color:inherit;text-decoration:none}button{font-family:inherit}img,video{display:block;max-width:100%}::selection{background:#ff3c8e;color:#fff}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#2a2228;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#3a2f34}.g-shell{height:100vh;display:flex;flex-direction:column;background:#0e0b0d;color:#faf5f7;font-family:Space Grotesk,sans-serif;overflow:hidden}.g-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:52px;min-height:52px;border-bottom:1px solid #2a2228;background:#0e0b0d;flex-shrink:0}.g-header-l{display:flex;align-items:center;gap:1rem}.g-logo{font-family:Syne,sans-serif;font-size:.9375rem;font-weight:800;letter-spacing:-.02em;margin:0;color:#faf5f7}.g-logo-accent{color:#ff3c8e}.g-pill{font-family:Space Mono,monospace;font-size:.75rem;display:inline-flex;align-items:baseline;gap:2px;background:#171315;padding:.25rem .625rem;border-radius:20px;border:1px solid #2a2228}.g-pill-n{color:#ff3c8e;font-weight:700}.g-pill-s{color:#5c4f55}.g-pill-t{color:#8c7a83}.g-ctrls{display:flex;gap:.375rem}.g-btn{font-family:Space Mono,monospace;font-size:.6875rem;letter-spacing:.04em;text-transform:uppercase;padding:.4rem .875rem;border-radius:8px;border:1px solid #2a2228;background:transparent;color:#8c7a83;cursor:pointer;transition:all .15s;text-decoration:none;white-space:nowrap;display:inline-flex;align-items:center}.g-btn:hover{border-color:#5c4f55;color:#faf5f7}.g-btn--start{border-color:#ff3c8e;color:#ff3c8e}.g-btn--start:hover{background:#ff3c8e;color:#fff}.g-btn--play{background:#ff3c8e;border-color:#ff3c8e;color:#fff;font-weight:700}.g-btn--play:hover{opacity:.85}.g-btn--pause{border-color:#f59e0b;color:#f59e0b}.g-btn--pause:hover{background:#f59e0b;color:#000}.g-btn--reset{border-color:#ef444459;color:#ef4444}.g-btn--reset:hover{background:#ef4444;border-color:#ef4444;color:#fff}.g-body{flex:1 1 0%;display:flex;flex-direction:row;min-height:0;overflow:hidden}.g-history{width:180px;min-width:180px;max-width:180px;border-right:1px solid #2a2228;display:flex;flex-direction:column;background:#0e0b0d}.g-history-head{padding:1rem 1rem .5rem;font-family:Space Mono,monospace;font-size:.625rem;letter-spacing:.15em;text-transform:uppercase;color:#5c4f55}.g-history-list{flex:1 1 0%;overflow-y:auto;padding:0 .5rem .5rem;min-height:0}.g-hitem{display:flex;align-items:center;gap:.5rem;padding:.375rem .625rem;border-radius:8px;margin-bottom:2px}.g-hitem--latest{background:#ff3c8e1f;border:1px solid rgba(255,60,142,.3)}.g-hitem-ord{font-family:Space Mono,monospace;font-size:.625rem;color:#5c4f55;width:20px;text-align:right;flex-shrink:0}.g-hitem-num{font-family:Syne,sans-serif;font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:#faf5f7}.g-hitem--latest .g-hitem-num{color:#ff3c8e}.g-qr{padding:.75rem;border-top:1px solid #2a2228;display:flex;flex-direction:column;align-items:center;gap:.5rem;flex-shrink:0}.g-qr-canvas{width:100px;height:100px;border-radius:8px;display:block}.g-qr-hint{font-family:Space Mono,monospace;font-size:.5625rem;letter-spacing:.08em;text-transform:uppercase;color:#5c4f55}.g-stage{flex:1 1 0%;display:flex;align-items:center;justify-content:center;position:relative;background:#080608;overflow:hidden;min-width:0}.g-reveal{position:absolute;top:1.25rem;left:1.25rem;z-index:10;width:72px;height:72px;background:#ff3c8e;border-radius:16px;display:flex;align-items:center;justify-content:center;animation:g-pop .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 32px #ff3c8e59}.g-reveal-n{font-family:Syne,sans-serif;font-size:2.25rem;font-weight:800;color:#fff;letter-spacing:-.04em}.g-video{max-height:100%;max-width:100%;object-fit:contain;display:block}.g-video--v{height:100%}.g-novid{display:flex;flex-direction:column;align-items:center;gap:.5rem}.g-novid-n{font-family:Syne,sans-serif;font-size:12rem;font-weight:800;line-height:1;letter-spacing:-.05em;color:#ff3c8e;opacity:.12}.g-novid-l{font-family:Space Mono,monospace;font-size:.75rem;color:#5c4f55;text-transform:uppercase;letter-spacing:.1em}.g-idle{display:flex;flex-direction:column;align-items:center;gap:.75rem}.g-idle-big{font-family:Syne,sans-serif;font-size:8rem;font-weight:800;letter-spacing:-.04em;color:#faf5f7;opacity:.05;line-height:1}.g-idle-sub{font-family:Space Mono,monospace;font-size:.8125rem;color:#5c4f55;letter-spacing:.04em}.g-board{width:240px;min-width:240px;max-width:240px;border-left:1px solid #2a2228;display:flex;flex-direction:column;background:#0e0b0d;padding:1rem}.g-board-head{font-family:Space Mono,monospace;font-size:.625rem;letter-spacing:.15em;text-transform:uppercase;color:#5c4f55;margin-bottom:.75rem}.g-board-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:3px}.g-cell{aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;font-family:Space Mono,monospace;font-size:.6875rem;font-weight:700;border-radius:6px;background:#171315;color:#5c4f55;transition:all .2s}.g-cell--on{background:#ff3c8e;color:#fff}.g-cell--cur{box-shadow:0 0 0 2px #ff3c8e,0 0 16px #ff3c8e66;animation:g-glow 1.5s ease-in-out infinite}@keyframes g-pop{0%{transform:scale(0) rotate(-12deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}@keyframes g-glow{0%,to{box-shadow:0 0 0 2px #ff3c8e,0 0 16px #ff3c8e66}50%{box-shadow:0 0 0 2px #ff3c8e,0 0 24px #ff3c8e99}}@media(max-width:768px){.g-shell{height:100vh;height:100dvh}.g-header{padding:0 1rem;height:44px;min-height:44px}.g-logo{font-size:.8125rem}.g-pill{font-size:.6875rem;padding:.2rem .5rem}.g-ctrls{display:none}.g-body{flex-direction:column}.g-history,.g-board{display:none}.g-stage{flex:none;height:auto;min-height:0;flex-shrink:1;flex-grow:1}.g-reveal{top:.75rem;left:.75rem;width:56px;height:56px;border-radius:12px}.g-reveal-n{font-size:1.75rem}.g-novid-n{font-size:6rem}.g-idle-big{font-size:4rem}.g-mob-current{display:flex;flex-direction:column;align-items:center;padding:1rem 1rem .75rem;background:#0e0b0d;border-bottom:1px solid #2a2228;flex-shrink:0}.g-mob-num{font-family:Syne,sans-serif;font-size:5rem;font-weight:800;line-height:1;letter-spacing:-.04em;color:#ff3c8e}.g-mob-label{font-family:Space Mono,monospace;font-size:.625rem;letter-spacing:.12em;text-transform:uppercase;color:#5c4f55;margin-top:.25rem}.g-mob-board{display:block;padding:.75rem;background:#0e0b0d;border-top:1px solid #2a2228;flex-shrink:0;overflow-y:auto}.g-mob-board-label{font-family:Space Mono,monospace;font-size:.5625rem;letter-spacing:.12em;text-transform:uppercase;color:#5c4f55;margin-bottom:.5rem}.g-mob-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:3px}.g-mob-cell{aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;font-family:Space Mono,monospace;font-size:.5625rem;font-weight:700;border-radius:4px;background:#171315;color:#5c4f55}.g-mob-cell--on{background:#ff3c8e;color:#fff}.g-mob-cell--cur{box-shadow:0 0 0 1px #ff3c8e,0 0 8px #ff3c8e66}.g-mob-history{display:flex;gap:6px;padding:.5rem .75rem;overflow-x:auto;background:#0e0b0d;border-top:1px solid #2a2228;flex-shrink:0;-webkit-overflow-scrolling:touch}.g-mob-history::-webkit-scrollbar{display:none}.g-mob-hitem{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-family:Syne,sans-serif;font-size:.875rem;font-weight:700;border-radius:8px;background:#171315;color:#8c7a83}.g-mob-hitem--latest{background:#ff3c8e26;color:#ff3c8e;border:1px solid rgba(255,60,142,.3)}}@media(min-width:769px){.g-mob-current,.g-mob-board,.g-mob-history{display:none}}.dash-shell{min-height:100vh;background:#0e0b0d;color:#faf5f7;font-family:Space Grotesk,sans-serif}.dash-header{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:56px;border-bottom:1px solid #2a2228;position:sticky;top:0;background:#0e0b0d;z-index:40}.dash-header-left{display:flex;align-items:center;gap:.75rem}.dash-logo{font-family:Syne,sans-serif;font-weight:700;font-size:.875rem;letter-spacing:-.02em;color:#faf5f7}.dash-divider{color:#5c4f55;font-weight:300}.dash-section{color:#8c7a83;font-size:.8125rem}.dash-header-right{display:flex;gap:.5rem}.btn-accent-sm{display:inline-flex;align-items:center;background:#ff3c8e;color:#fff;font-family:Space Grotesk,sans-serif;font-weight:600;font-size:.75rem;padding:.5rem 1rem;border-radius:8px;border:none;cursor:pointer;text-decoration:none;transition:opacity .15s,transform .15s}.btn-accent-sm:hover{opacity:.85;transform:translateY(-1px)}.btn-ghost-sm{background:transparent;color:#8c7a83;font-family:Space Grotesk,sans-serif;font-size:.75rem;padding:.5rem 1rem;border:1px solid #2a2228;border-radius:8px;cursor:pointer;transition:color .15s,border-color .15s}.btn-ghost-sm:hover{color:#faf5f7;border-color:#5c4f55}.dash-main{max-width:1200px;margin:0 auto;padding:2rem}.stats-strip{display:flex;gap:1px;background:#2a2228;border-radius:14px;overflow:hidden;margin-bottom:2rem}.stat-block{flex:1;background:#171315;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.25rem}.stat-value{font-family:Syne,sans-serif;font-size:2rem;font-weight:700;letter-spacing:-.03em;color:#ff6faa}.stat-label{font-family:Space Mono,monospace;font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:#8c7a83}.stat-progress-block{flex:2;justify-content:center;gap:.75rem}.stat-progress-bar{width:100%;height:6px;background:#2a2228;border-radius:3px;overflow:hidden}.stat-progress-fill{height:100%;background:#ff3c8e;border-radius:3px;transition:width .4s ease}.number-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:6px}.num-cell{position:relative;aspect-ratio:1 / 1;background:#171315;border:1px solid #221e20;border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .15s}.num-cell:hover{border-color:#ff3c8e;transform:translateY(-2px)}.num-cell.uploaded{border-color:#34d3994d;background:#34d3990a}.num-face{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.num-value{font-family:Syne,sans-serif;font-size:1.375rem;font-weight:700;letter-spacing:-.02em;color:#faf5f7}.num-badge{font-size:.625rem;color:#34d399}.num-overlay{position:absolute;inset:0;background:#0e0b0de0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;opacity:0;transition:opacity .15s;border-radius:10px}.num-cell:hover .num-overlay{opacity:1}.num-action{font-family:Space Mono,monospace;font-size:.625rem;letter-spacing:.05em;text-transform:uppercase;padding:.375rem .625rem;border-radius:6px;cursor:pointer;border:none;transition:opacity .15s}.num-action:hover{opacity:.8}.num-action.upload{background:#ff3c8e;color:#fff;font-weight:700}.num-action.delete{background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.upload-overlay{position:fixed;inset:0;background:#0e0b0dbf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:50}.upload-card{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-spinner{width:48px;height:48px;border:3px solid #2a2228;border-top-color:#ff3c8e;border-radius:50%;animation:dash-spin .8s linear infinite}.upload-num{font-family:Syne,sans-serif;font-size:3rem;font-weight:800;color:#ff3c8e}.upload-text{font-family:Space Mono,monospace;font-size:.75rem;color:#8c7a83;letter-spacing:.08em;text-transform:uppercase}@keyframes dash-spin{to{transform:rotate(360deg)}}@media(max-width:768px){.number-grid{grid-template-columns:repeat(5,1fr)}.stats-strip{flex-direction:column}}.login-shell{min-height:100vh;background:#0e0b0d;color:#faf5f7;font-family:Space Grotesk,sans-serif}.login-grid{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.login-brand{background:#171315;border-right:1px solid #2a2228;display:flex;flex-direction:column;justify-content:center;padding:4rem;position:relative;overflow:hidden}.brand-inner{position:relative;z-index:2}.brand-tag{font-family:Space Mono,monospace;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:#ff3c8e;display:block;margin-bottom:1.5rem}.brand-title{font-family:Syne,sans-serif;font-size:clamp(3rem,6vw,5.5rem);font-weight:800;line-height:.9;letter-spacing:-.03em;color:#faf5f7;margin:0}.brand-highlight{color:#ff3c8e}.brand-line{width:64px;height:3px;background:#ff3c8e;margin:2rem 0;border-radius:2px}.brand-sub{font-size:1.125rem;color:#8c7a83;line-height:1.6;max-width:320px}.brand-blobs{position:absolute;inset:0;z-index:0;pointer-events:none}.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.12}.blob-1{width:400px;height:400px;background:#ff3c8e;top:-100px;right:-100px}.blob-2{width:300px;height:300px;background:#c47aff;bottom:-50px;left:-50px}.brand-numbers{position:absolute;inset:0;display:flex;flex-wrap:wrap;align-content:center;justify-content:center;gap:12px;opacity:.035;z-index:1;pointer-events:none}.brand-num{font-family:Syne,sans-serif;font-size:3rem;font-weight:800;color:#faf5f7}.login-form-area{display:flex;align-items:center;justify-content:center;padding:2rem}.form-card{width:100%;max-width:380px}.form-icon{font-size:1.5rem;color:#ff3c8e;margin-bottom:1.25rem}.form-title{font-family:Syne,sans-serif;font-size:2rem;font-weight:700;margin:0 0 .25rem}.form-subtitle{color:#8c7a83;font-size:.875rem;margin:0 0 2rem}.form-error{background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#fca5a5;padding:.75rem 1rem;border-radius:10px;font-size:.8125rem;margin-bottom:1.5rem}.form-fields{display:flex;flex-direction:column;gap:1.25rem}.field{display:flex;flex-direction:column;gap:.375rem}.field-label{font-family:Space Mono,monospace;font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;color:#8c7a83}.field-input{background:#171315;border:1px solid #2a2228;border-radius:10px;padding:.875rem 1rem;font-family:Space Grotesk,sans-serif;font-size:.9375rem;color:#faf5f7;outline:none;transition:border-color .2s,box-shadow .2s}.field-input:focus{border-color:#ff3c8e;box-shadow:0 0 0 3px #ff3c8e26}.btn-primary{background:#ff3c8e;color:#fff;font-family:Space Grotesk,sans-serif;font-weight:600;font-size:.9375rem;padding:.875rem;border:none;border-radius:10px;cursor:pointer;transition:opacity .2s,transform .15s;margin-top:.5rem}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;color:#8c7a83;font-family:Space Grotesk,sans-serif;font-weight:500;font-size:.875rem;padding:.75rem;border:1px solid #2a2228;border-radius:10px;cursor:pointer;transition:border-color .2s,color .2s}.btn-ghost:hover{border-color:#ff3c8e;color:#ff6faa}.btn-ghost:disabled{opacity:.4;cursor:not-allowed}@media(max-width:768px){.login-grid{grid-template-columns:1fr}.login-brand{display:none}}
