@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{font-family:Space Grotesk,Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#f2fbff;background-color:#010a1b;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;height:auto;background:radial-gradient(circle at top,rgba(32,78,255,.25),transparent 50%),radial-gradient(circle at 20% 20%,rgba(255,90,138,.25),transparent 40%),#020817;overflow:auto}#root{min-height:100vh;height:auto;min-height:0}a{color:inherit}button{font-family:inherit}.wheel-shell{position:relative;--wheel-max: min(80vw, 85vh);--wheel-size: clamp(520px, var(--wheel-max), 1000px);width:var(--wheel-size);aspect-ratio:1;margin-inline:auto;background:radial-gradient(circle at 30% 30%,#ffffff2e,#061432cc);padding:clamp(.5rem,1.2vmin,1rem);border-radius:50%;box-shadow:0 25px 60px #010918b3}.wheel{position:relative;--target-rotation: 0deg;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffffff4d,#091530f2);transform:rotate(var(--target-rotation));transition:transform 0s linear;overflow:hidden}.wheel--spinning{transition:transform 5s cubic-bezier(.19,1,.22,1)}@media(max-height:720px){.wheel-shell{--wheel-size: clamp(280px, 60vmin, 540px)}}@media(max-height:620px){.wheel-shell{--wheel-size: clamp(240px, 52vmin, 460px)}}.wheel svg{width:100%;height:100%;position:relative;z-index:2}.wheel__rim{position:absolute;inset:0;border-radius:50%;border:clamp(6px,1.1vmin,10px) solid rgba(255,255,255,.12);box-shadow:inset 0 0 50px #0000008c;z-index:1}.wheel__hub{position:absolute;inset:36%;border-radius:50%;background:radial-gradient(circle at 30% 20%,#ffffffe6,#1a419bcc);border:6px solid rgba(255,255,255,.4);z-index:3;display:grid;place-items:center;box-shadow:0 10px 25px #06102d99,inset 0 0 25px #ffffff73}.wheel__hub-inner{text-align:center;text-transform:uppercase;color:#06142d;letter-spacing:.25rem}.wheel__hub-inner span{display:block;font-size:.75rem;font-weight:600}.wheel__hub-inner strong{display:block;font-size:1.05rem;letter-spacing:.4rem}.wheel-pointer{position:absolute;top:clamp(-18px,-2.5vmin,-10px);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none}.wheel-pointer__base{width:clamp(32px,4vmin,48px);height:clamp(32px,4vmin,48px);border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#c9d7ff);box-shadow:0 8px 18px #03061459;border:3px solid rgba(255,255,255,.8)}.wheel-pointer__arrow{width:0;height:0;border-left:clamp(14px,2vmin,20px) solid transparent;border-right:clamp(14px,2vmin,20px) solid transparent;border-top:clamp(28px,4vmin,40px) solid #ffffff;filter:drop-shadow(0 8px 14px rgba(0,0,0,.35))}.wheel-segment__path{stroke:#0619384d;stroke-width:1.2}.wheel-segment__path--bucket{opacity:.9}.wheel-segment__path--glow{filter:drop-shadow(0 0 12px rgba(255,255,255,.8))}.wheel-avatar{width:100%;height:100%;display:grid;place-items:center}.wheel-avatar__shape{width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at 30% 30%,#ffffffe6,#ffd95cbf);border:3px solid rgba(255,255,255,.75);display:flex;align-items:center;justify-content:center;color:#082146;font-weight:800;font-size:1.15rem;text-shadow:0 2px 8px rgba(0,0,0,.4);transform-origin:center}@media(max-width:680px){.wheel-avatar__shape span{display:none}.wheel-avatar__shape{border-width:2px}}.wheel-avatar__shape--bucket{background:radial-gradient(circle at 30% 30%,#ffffffe0,#98c5ffd9);color:#082146}.wheel-empty{display:grid;place-items:center;width:100%;aspect-ratio:1 / 1;border-radius:50%;border:2px dashed rgba(255,255,255,.3);color:#ffffffb3;text-align:center;padding:2rem}.winner-panel{background:#030d1ccc;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:1.5rem;box-shadow:0 10px 40px #02122880;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);height:100%;min-height:0;display:flex;flex-direction:column}.winner-panel__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.winner-panel__header h3{margin:0;font-size:1.1rem;letter-spacing:.5px;text-transform:uppercase;color:#93b4ff}.winner-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.9rem;flex:1;overflow-y:auto}.winner-list__item{display:flex;gap:1rem;align-items:center;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.winner-list__item:last-of-type{border-bottom:none}.winner-list__row{display:flex;align-items:center;gap:.4rem}.winner-list__badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;background:#fff3;border-radius:999px;padding:.05rem .5rem;color:#fff}.winner-list__avatar{width:52px;height:52px;border-radius:50%;background:#ffffff1a;display:grid;place-items:center;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.15)}.winner-list__avatar img{width:100%;height:100%;object-fit:cover}.winner-list__avatar span{color:#fff;font-weight:700;font-size:1.2rem}.winner-list__name{margin:0;font-weight:600;letter-spacing:.3px}.winner-list__meta{margin:.1rem 0 0;color:#fff9;font-size:.85rem}.winner-list__empty{color:#ffffffb3;text-align:center;padding:1rem 0}@media(max-height:720px){.winner-panel{padding:1rem}.winner-panel__header h3{font-size:1rem}.winner-list__avatar{width:46px;height:46px}}@media(max-height:620px){.winner-list{gap:.6rem}.winner-list__item{padding:.4rem 0}}.countdown{display:flex;flex-direction:column;gap:.35rem}.countdown__label{font-size:.85rem;text-transform:uppercase;letter-spacing:.3rem;color:#ffffffbf;margin:0}.countdown__value{font-size:2.4rem;font-weight:700;color:#fff;letter-spacing:.2rem;margin:0}.countdown__hint{font-size:.95rem;color:#fffc;margin:0}@media(max-height:720px){.countdown{padding:.9rem 1rem}.countdown__value{font-size:1.45rem}}@media(max-height:620px){.countdown{padding:.75rem .9rem}.countdown__value{font-size:1.25rem}.countdown__hint{font-size:.75rem}}.app-shell{height:100vh;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-start;gap:1rem;padding:clamp(.3rem,.8vw,.7rem) clamp(.5rem,1.5vw,1.2rem);max-width:1900px;margin:0 auto}.main-grid{display:grid;grid-template-columns:minmax(0,3.5fr) minmax(320px,1.2fr);gap:clamp(.8rem,1.5vw,1.6rem);align-items:stretch;flex:1;min-height:0}.wheel-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:0;width:100%;padding:0}.pointer-card{width:100%;display:flex;gap:1rem;align-items:center;background:#020c20cc;padding:1rem 1.4rem;border-radius:22px;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 40px #040c1e73;position:relative}.pointer-card:before{content:"";position:absolute;left:-18px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:16px solid transparent;border-bottom:16px solid transparent;border-right:18px solid transparent;border-left:18px solid #ffffff;filter:drop-shadow(0 4px 8px rgba(0,0,0,.25));z-index:2}.pointer-card__avatar{width:64px;height:64px;border-radius:20px;background:linear-gradient(135deg,#ffdd80,#ffc247);display:grid;place-items:center;font-size:1.6rem;font-weight:700;color:#0c1e3c;text-transform:uppercase;box-shadow:inset 0 0 20px #fff6}.pointer-card__name{margin:0;font-size:1.4rem;font-weight:700;width:100%}.roster-card{display:none}.roster-card__header{display:flex;justify-content:space-between;align-items:center;font-size:.95rem}.roster-card__label{margin:0;letter-spacing:.12rem;text-transform:uppercase;color:#ffffffb3;font-size:.78rem}.roster-card__list{display:flex;flex-direction:column;gap:.3rem;overflow-y:auto;padding-right:.35rem}.roster-card__row{display:flex;align-items:center;gap:.6rem;padding:.35rem .25rem;border-bottom:1px solid rgba(255,255,255,.05)}.roster-card__row:last-of-type{border-bottom:none}.roster-card__initial{width:32px;height:32px;border-radius:10px;background:#ffffff1f;display:grid;place-items:center;font-weight:700}.roster-card__name{font-weight:600}.roster-card__empty{margin:0;color:#ffffffb3}.roster-trigger{border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#fff;border-radius:10px;padding:.5rem .85rem;cursor:pointer;width:100%;text-align:left}.roster-fab{border:1px solid rgba(255,255,255,.2);background:#020c20cc;color:#fff;border-radius:14px;padding:.55rem .9rem;cursor:pointer;box-shadow:0 10px 25px #00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.roster-fab-wrap{position:absolute;left:clamp(.6rem,2vw,1.1rem);bottom:clamp(.6rem,2vw,1.1rem);display:flex;flex-direction:column;gap:.3rem;align-items:flex-start}.roster-qr{width:64px;height:64px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;box-shadow:0 8px 18px #00000059;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.3rem;gap:0;overflow:hidden}.roster-qr img{width:48px;height:48px;border-radius:0}.roster-modal{position:fixed;inset:0;background:#000000bf;display:grid;place-items:center;padding:1rem;z-index:20}.roster-modal__card{background:#020c20f0;border:1px solid rgba(255,255,255,.1);border-radius:18px;width:min(520px,92vw);max-height:80vh;display:flex;flex-direction:column;gap:.8rem;padding:1.1rem 1.2rem;box-shadow:0 18px 60px #00000073}.roster-modal__header{display:flex;justify-content:space-between;align-items:center}.roster-modal__close{border:none;background:#ffffff1f;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.1rem}.roster-modal__list{overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.3rem}.roster-modal__row{display:flex;gap:.6rem;align-items:center;padding:.4rem .3rem;border-bottom:1px solid rgba(255,255,255,.08)}.roster-modal__row:last-of-type{border-bottom:none}.roster-modal__initial{width:34px;height:34px;border-radius:12px;background:#ffffff24;display:grid;place-items:center;font-weight:700}.roster-modal__name{font-weight:600}.roster-modal__empty{margin:0;color:#ffffffbf}.admin-shell{min-height:100vh;padding:clamp(1rem,3vw,2.5rem);display:flex;flex-direction:column;gap:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;background:#020c20d9;padding:1.5rem 2rem;border-radius:24px;border:1px solid rgba(255,255,255,.08);box-shadow:0 25px 60px #010918b3}.admin-header button{border:none;background:#ffffff26;color:#fff;padding:.6rem 1.2rem;border-radius:999px;cursor:pointer}.admin-shell{min-height:100vh;padding:clamp(1rem,3vw,2.5rem);display:flex;flex-direction:column;gap:1.5rem;overflow:hidden}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.admin-split{display:grid;grid-template-columns:minmax(200px,.55fr) minmax(0,1.45fr);gap:1.5rem;min-height:0;flex:1}.admin-triple{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:1.5rem}@media(max-width:1180px){.admin-triple{grid-template-columns:1fr}}.admin-card{background:#031024d9;border-radius:24px;border:1px solid rgba(255,255,255,.08);padding:1.5rem;display:flex;flex-direction:column;gap:1rem;min-height:0;overflow:hidden}.admin-card--games,.admin-card--detail{overflow-y:auto}.admin-loading{display:inline-flex;align-items:center;gap:.6rem;padding:.6rem .9rem;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff14;margin-bottom:1rem;color:#ffffffd9}.admin-loading__spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.4);border-top-color:transparent;animation:adminSpin .8s linear infinite}@keyframes adminSpin{to{transform:rotate(360deg)}}.admin-card--games{max-width:360px}.admin-card--panel{height:fit-content}.admin-card--roster{display:flex;flex-direction:column;gap:.8rem}.admin-tabs{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap}.admin-tab{border:1px solid rgba(255,255,255,.15);background:#ffffff0f;color:#fff;border-radius:999px;padding:.45rem .9rem;cursor:pointer;font-size:.9rem}.admin-tab--active{background:#fff3;border-color:#fff6}.admin-modal{position:fixed;inset:0;background:#030a1ab3;display:grid;place-items:center;z-index:40;padding:1rem}.admin-modal__card{width:min(520px,92vw);background:#031024f2;border-radius:20px;border:1px solid rgba(255,255,255,.12);box-shadow:0 30px 80px #00000073;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.admin-modal__message{margin:0;color:#ffffffd9}.winner-edit-list{display:flex;flex-direction:column;gap:.6rem;max-height:320px;overflow-y:auto}.winner-edit-row{display:grid;grid-template-columns:minmax(0,1fr) 160px;gap:.8rem;align-items:center;padding:.6rem .8rem;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0a}.winner-edit-info p{margin:0;font-weight:600}.winner-edit-info span{font-size:.78rem;color:#fff9}.winner-edit-input{border-radius:10px;border:1px solid rgba(255,255,255,.2);padding:.4rem .6rem;background:#ffffff0d;color:#fff;font:inherit}.winner-edit-empty{margin:0;color:#ffffffb3}.roster-table{border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;background:#ffffff05;max-height:360px;overflow-y:auto}.roster-table__row{display:grid;grid-template-columns:50px 1fr 40px;align-items:center;gap:.8rem;padding:.6rem .9rem;border-bottom:1px solid rgba(255,255,255,.05)}.roster-table__row--inactive{opacity:.6}.roster-table__row:last-of-type{border-bottom:none}.roster-table__index{color:#fff9;text-align:right}.roster-table__name-group{display:flex;gap:.5rem;align-items:center}.roster-table__name{font-weight:600}.roster-table__status{font-size:.75rem;padding:.1rem .5rem;border-radius:999px;border:1px solid rgba(255,255,255,.3);color:#fffc}.roster-table__delete{border:none;background:#ffffff1f;color:#fff;border-radius:50%;width:30px;height:30px;display:grid;place-items:center;cursor:pointer;font-size:1.1rem}.roster-table__empty{margin:0;padding:1rem;text-align:center;color:#ffffffb3}.admin-empty-state{display:grid;place-items:center;text-align:center;padding:3rem 1rem;color:#ffffffb3;gap:.8rem}.schedule-builder{border-radius:18px;border:1px solid rgba(255,255,255,.07);padding:1rem 1.2rem;background:#ffffff08;display:flex;flex-direction:column;gap:.8rem}.schedule-builder__label{margin:0;font-size:.85rem;text-transform:uppercase;letter-spacing:.2rem;color:#fff9}.schedule-builder__modes{display:flex;gap:1rem}.schedule-builder__modes label{display:inline-flex;gap:.4rem;align-items:center;font-size:.9rem}.schedule-builder__repeat,.schedule-builder__once{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem;width:100%}.schedule-builder__repeat label,.schedule-builder__once label{display:flex;flex-direction:column;font-size:.9rem;gap:.35rem}.schedule-builder__hint{grid-column:1 / -1;margin:0;font-size:.85rem;color:#fff9}.admin-form{display:flex;flex-direction:column;gap:.6rem}.admin-form__inline{display:flex;flex-direction:column;gap:1rem}.admin-form__button{border:none;border-radius:12px;padding:.6rem 1rem;background:#fff3;color:#fff;cursor:pointer;width:fit-content}.admin-form__inline--row{flex-direction:row;flex-wrap:wrap;align-items:center}.admin-form__button--danger{background:#ff5d5d4d;border:1px solid rgba(255,93,93,.5)}.checkbox-inline{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem}.admin-form__group{display:flex;flex-direction:column;gap:.4rem}.admin-form input,.admin-form select{border-radius:12px;border:1px solid rgba(255,255,255,.2);padding:.5rem .8rem;background:#ffffff0d;color:#fff;font:inherit}.admin-form input[type=date],.admin-form input[type=time]{color-scheme:dark;filter:invert(0) brightness(1.1)}.admin-form select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,rgba(255,255,255,.6) 50%),linear-gradient(135deg,rgba(255,255,255,.6) 50%,transparent 50%);background-position:calc(100% - 18px) 1rem,calc(100% - 12px) 1rem;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:2.2rem}.admin-form button{border:none;border-radius:12px;padding:.6rem 1rem;background:#fff3;color:#fff;cursor:pointer}.admin-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.admin-list__item{width:100%;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:#fff;border-radius:12px;padding:.6rem .9rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;cursor:pointer;transition:border-color .2s ease,background .2s ease}.admin-list__item--active{border-color:#fff6;background:#ffffff1f}.admin-list__tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;border-radius:999px;padding:.15rem .5rem;border:1px solid rgba(255,255,255,.35);color:#ffffffd9}.admin-login{max-width:420px;margin:4rem auto;background:#031024d9;padding:2rem;border-radius:24px;border:1px solid rgba(255,255,255,.08);box-shadow:0 25px 60px #010918b3}.side-stack{display:flex;flex-direction:column;gap:1.2rem;flex:1;min-height:0;justify-content:flex-start}.info-card__label{margin:0;font-size:.85rem;text-transform:uppercase;letter-spacing:.3rem;color:#ffffffb3}.info-card__meta{margin:0;font-size:.85rem;color:#ffffffa6}.status-text{color:#ffffffb8;font-size:.85rem;margin:0}.status-text--alert{color:#ffd7a0;text-align:center}.side-stack{display:flex;flex-direction:column;gap:1.2rem}.info-card{width:100%;background:#020c20cc;padding:1.2rem 1.4rem;border-radius:22px;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 40px #040c1e73;display:flex;flex-direction:column;gap:.6rem}.info-card__label{margin:0;font-size:.85rem;text-transform:uppercase;letter-spacing:.35rem;color:#ffffffb3}.info-card--waiting{align-items:center;justify-content:center;min-height:220px;text-align:center}.info-card--waiting h3{margin:.8rem 0 0;font-size:1.4rem;letter-spacing:.2rem}.celebration-overlay{position:fixed;inset:0;background:radial-gradient(circle at center,#030a1ae6,#02050ef5);display:flex;align-items:center;justify-content:center;z-index:20;animation:overlayFade .3s ease forwards}.celebration-card{text-align:center;padding:clamp(2rem,5vw,4rem);border-radius:32px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);box-shadow:0 30px 80px #00000073;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:pulseCard .5s ease}.celebration-card p{margin:0;text-transform:uppercase;letter-spacing:.5rem;color:#ffffffd9;font-size:clamp(.85rem,1.5vw,1rem)}.celebration-card h1{margin:1rem 0 0;font-size:clamp(2.2rem,6vw,4.2rem);letter-spacing:.2rem}.celebration-card--waiting h2{margin:.6rem 0 0;font-size:clamp(1.6rem,4vw,2.4rem);letter-spacing:.2rem}@keyframes overlayFade{0%{opacity:0}to{opacity:1}}@keyframes pulseCard{0%{transform:scale(.9)}to{transform:scale(1)}}@media(max-width:980px){.main-grid{grid-template-columns:1fr;align-items:stretch}.wheel-panel{order:2}.side-stack{order:1}.app-shell{height:auto;min-height:100vh}}@media(max-height:720px){.app-shell{gap:1rem;padding:clamp(.6rem,1.4vw,1rem) clamp(.8rem,2.3vw,1.4rem)}.status-text{font-size:.85rem}.winner-panel{padding:1.2rem}.winner-highlight{padding:1rem}.winner-highlight__avatar{width:60px;height:60px}.winner-highlight__name{font-size:1.2rem}}@media(max-height:620px){.app-shell{gap:.75rem}.main-grid{gap:.6rem}.winner-panel__header h3{font-size:1rem}}.admin-card__header{display:flex;align-items:center;justify-content:space-between}.admin-card__header button{border:none;background:#ffffff1f;padding:.35rem .8rem;border-radius:999px;color:#fff;cursor:pointer}.admin-card--detail textarea{border-radius:14px;border:1px solid rgba(255,255,255,.2);padding:.8rem;background:#ffffff0f;color:#fff;resize:vertical}
