@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}:root{--bg:#42301c;--surface:#54402a;--surface2:#655034;--border:#917050;--accent:#f0b840;--accent-hover:#ffd060;--text:#faf3e8;--text-muted:#ccaa78;--danger:#e05050;--success:#6ab85a;--radius:12px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html{height:100%}body{background:var(--bg);color:var(--text);font-family:"Segoe UI",system-ui,-apple-system,sans-serif;min-height:100%;font-size:16px;line-height:1.5}#app{width:100%;max-width:560px;margin:0 auto;padding:16px 14px 96px}.header{margin-bottom:28px;padding-top:8px}.header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.btn-header,input[type=text]{background:var(--surface2);border:1.5px solid var(--border);color:var(--text);border-radius:8px;-webkit-appearance:none}.btn-header{padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;transition:border-color .15s;white-space:nowrap}.btn-header:hover{border-color:var(--accent)}.logo{font-size:26px;font-weight:900;color:var(--accent);letter-spacing:-.5px;line-height:1.1}.tagline{font-size:12px;color:var(--text-muted);font-style:italic;letter-spacing:.5px;text-transform:lowercase}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:14px}.card-title{font-size:17px;font-weight:700;margin-bottom:14px;color:var(--accent)}.card-subtitle,label{font-size:13px;color:var(--text-muted);margin-bottom:18px}label{display:block;font-size:12px;margin-bottom:7px;font-weight:700;text-transform:uppercase;letter-spacing:.6px}input[type=text]{width:100%;padding:13px 16px;font-size:16px;outline:0;transition:border-color .2s;margin-bottom:16px}input[type=datetime-local]:focus,input[type=text]:focus,textarea:focus{border-color:var(--accent)}textarea{font-family:inherit;resize:vertical}.btn,input[type=datetime-local],textarea{border-radius:8px;font-size:16px;width:100%;-webkit-appearance:none}input[type=datetime-local],textarea{background:var(--surface2);border:1.5px solid var(--border);color:var(--text);padding:13px 16px;outline:0;transition:border-color .2s;margin-bottom:16px}input[type=datetime-local]{color-scheme:dark}.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:15px 22px;border:0;font-weight:700;cursor:pointer;transition:background .15s,opacity .15s;min-height:52px}.btn:active{opacity:.8}.btn-primary{background:var(--accent);color:#1c1007}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface2);color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover{border-color:var(--accent)}.btn-ghost,.btn-spectator{background:0 0;color:var(--text-muted)}.btn-spectator{border:0;font-size:.8rem;min-height:unset;padding:6px 12px;margin-top:8px;text-decoration:underline;text-underline-offset:3px}.btn-spectator:hover{color:var(--text)}.btn-ghost{border:1.5px solid var(--border);font-size:14px;padding:10px 16px;min-height:40px}.btn+.btn{margin-top:10px}.submit-sticky{position:fixed;bottom:0;left:0;right:0;padding:12px 14px 20px;background:linear-gradient(to top,var(--bg) 60%,transparent);z-index:10}.submit-sticky .btn{max-width:560px;margin:0 auto}.event-list-item{padding:16px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s;border-radius:4px}.event-list-item:last-child{border-bottom:none}.dual-slider-wrap .slider-user,.event-list-item:active,input[type=range]{background:var(--surface2)}.event-list-name{font-size:17px;font-weight:700;margin-bottom:5px}.event-list-meta{font-size:13px;color:var(--text-muted);display:flex;gap:10px;flex-wrap:wrap}.event-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge-open{background:rgba(90,154,80,.2);color:var(--success);border:1px solid var(--success)}.badge-started{background:rgba(200,146,42,.2);color:var(--accent);border:1px solid var(--accent)}.badge-done,.drink-card{border:1px solid var(--border)}.badge-done{background:rgba(90,90,90,.2);color:var(--text-muted)}.drink-card{background:var(--surface2);border-radius:var(--radius);padding:20px;margin-bottom:14px}.drink-number{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:5px;font-weight:700}.drink-name{font-size:26px;font-weight:900;line-height:1.15;margin-bottom:8px}.drink-desc{font-size:14px;color:var(--text-muted);line-height:1.6}.drink-img-placeholder{width:64px;height:64px;background:var(--surface);border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.drink-header{display:flex;gap:16px;align-items:flex-start}.drink-info{flex:1;min-width:0}.slider-section{padding-bottom:8px}.slider-row{margin-bottom:28px}.slider-label{display:block;font-size:13px;font-weight:700;text-transform:capitalize;letter-spacing:.3px;color:var(--text-muted);margin-bottom:10px}.slider-scale-row{display:flex;align-items:center;gap:10px}.slider-scale-row input[type=range]{flex:1}.slider-scale-hi,.slider-scale-lo{font-size:11px;color:var(--text-muted);white-space:nowrap;min-width:28px}.slider-scale-lo{text-align:right}.slider-scale-hi{text-align:left}input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;outline:0;cursor:pointer;touch-action:pan-y}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:36px;height:36px;border-radius:50%;background:var(--accent);cursor:pointer;border:3px solid var(--bg);box-shadow:0 2px 10px rgba(0,0,0,.5);transition:transform .1s}input[type=range]::-webkit-slider-thumb:active{transform:scale(1.2)}input[type=range]::-moz-range-thumb{width:36px;height:36px;border-radius:50%;background:var(--accent);cursor:pointer;border:3px solid var(--bg);box-shadow:0 2px 10px rgba(0,0,0,.5)}input[type=range].slider-readonly{cursor:default;pointer-events:none}input[type=range].slider-readonly::-webkit-slider-thumb{cursor:default;transform:none!important}input[type=range].slider-readonly::-moz-range-thumb{cursor:default}.dual-slider-wrap{position:relative;height:36px;flex:1}.dual-slider-wrap input[type=range]{position:absolute;width:100%;top:50%;transform:translateY(-50%);margin:0;background:0 0}.dual-slider-wrap .slider-avg::-webkit-slider-thumb{background:#5b9bd5}.dual-slider-wrap .slider-avg::-moz-range-thumb{background:#5b9bd5}.slider-legend{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-bottom:16px}.legend-dot{display:inline-block;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg)}.legend-dot-user{background:var(--accent);margin-left:4px}.legend-dot-avg{background:#5b9bd5;margin-left:10px}.drink-nav-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.drink-nav-center{flex:1;min-width:0;text-align:center}.nav-btn{width:48px;height:48px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .12s,border-color .12s;-webkit-appearance:none;line-height:1}.nav-btn:hover{border-color:var(--accent);background:var(--surface2)}.nav-btn:active{transform:scale(.94)}.participants{display:flex;flex-wrap:wrap;gap:8px}.participant-chip{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:20px;font-size:14px;font-weight:600;background:var(--surface2);border:1.5px solid var(--border)}.participant-chip.rated{border-color:var(--success);color:var(--success)}.participant-chip.waiting{border-color:var(--text-muted);color:var(--text-muted)}.participant-chip.is-admin::after{content:" ★";font-size:11px;color:var(--accent)}.participant-chip.expired{opacity:.4;text-decoration:line-through;border-style:dashed}.kick-btn{background:0 0;border:0;color:var(--text-muted);cursor:pointer;font-size:12px;padding:0 0 0 5px;line-height:1;opacity:.6;transition:color .15s,opacity .15s;-webkit-appearance:none}.kick-btn:hover{color:var(--danger);opacity:1}.spectator-count{margin-top:10px;font-size:.8rem;color:var(--text-muted)}.progress-bar{background:var(--surface2);border-radius:4px;height:8px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .5s ease}.progress-label{font-size:13px;color:var(--text-muted);text-align:right}.status-icon{font-size:52px;text-align:center;margin-bottom:12px;line-height:1}.status-title{font-size:22px;font-weight:800;text-align:center;margin-bottom:8px}.status-sub{font-size:15px;color:var(--text-muted);text-align:center;line-height:1.6}.score-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.score-cell{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 8px;text-align:center}.score-cell-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:700}.score-cell-val{font-size:26px;font-weight:900;color:var(--accent);line-height:1}.drink-list-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.drink-list-item:last-child{border-bottom:none}.drink-list-num,.url-box{display:flex;align-items:center;background:var(--surface2);font-size:13px}.drink-list-num{width:30px;height:30px;border-radius:50%;justify-content:center;font-weight:800;color:var(--accent);flex-shrink:0}.url-box{gap:10px;border:1.5px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:16px;word-break:break-all}.copy-btn{flex-shrink:0;padding:7px 14px;font-size:13px;width:auto;min-height:36px}.error-msg{background:rgba(200,64,64,.12);border:1px solid var(--danger);color:#ff8a8a;border-radius:8px;padding:11px 14px;font-size:14px;margin-bottom:14px}.waiting-dots::after{content:"";animation:dots 1.5s steps(4,end) infinite}.poll-dot{position:fixed;bottom:14px;right:14px;width:10px;height:10px;border-radius:50%;background:var(--success);animation:pulse 2.5s ease infinite;z-index:20}body.present-mode{overflow:hidden;height:100vh}body.present-mode #app{max-width:100%;padding:0;height:100vh;display:flex;flex-direction:column}.present-join-link.copied .present-join-copy,body.present-mode .header{display:none}body.present-mode .poll-dot{display:none!important}body.present-mode #view{flex:1;display:flex;flex-direction:column;overflow:hidden}.present-dashboard{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:clamp(20px,3vw,52px) clamp(20px,4vw,64px);gap:clamp(18px,3vh,40px);background:var(--bg)}.present-db-header{text-align:center}.present-db-event-name{font-size:clamp(14px,2vw,22px);font-weight:700;color:var(--text-muted);margin-bottom:4px}.present-db-status{font-size:clamp(22px,3.5vw,42px);font-weight:800;color:var(--text)}.present-db-counter{font-size:clamp(12px,1.4vw,16px);color:var(--text-muted);text-transform:uppercase;letter-spacing:3px;font-weight:700}.present-db-live{display:flex;flex-direction:column;align-items:center;gap:clamp(12px,2vh,22px);text-align:center}.present-current-name{font-size:clamp(28px,6vw,100px);font-weight:900;color:var(--accent);line-height:1.05;letter-spacing:-1px;overflow-wrap:break-word;word-break:break-word;max-width:100%}.present-current-desc{font-size:clamp(14px,1.8vw,20px);color:var(--text-muted);max-width:700px;line-height:1.6}.present-progress-wrap{width:100%;max-width:600px}.present-progress-bar{background:var(--surface2);border-radius:6px;height:12px;overflow:hidden;margin-bottom:8px}.present-progress-fill{height:100%;background:var(--accent);border-radius:6px;transition:width .6s ease}.present-progress-label{font-size:clamp(16px,2vw,26px);font-weight:800;color:var(--text)}.present-db-participants{display:flex;flex-wrap:wrap;gap:clamp(8px,1.2vw,16px);justify-content:center}.present-chip{font-size:clamp(13px,1.6vw,20px);font-weight:700;padding:clamp(7px,.9vw,12px) clamp(14px,1.8vw,24px);border-radius:40px;border:2px solid var(--border);transition:border-color .4s,color .4s,background .4s}.present-chip-waiting{color:var(--text-muted);border-color:var(--border)}.present-chip-rated{color:var(--success);border-color:var(--success);background:rgba(90,154,80,.1)}.present-chip-joined{color:var(--text);border-color:var(--accent)}.present-qr,.present-qr-content{display:flex;flex-direction:column;align-items:center;gap:clamp(8px,1vh,14px)}.present-qr-content{gap:clamp(4px,.8vh,10px)}.present-qr-toggle{font-size:clamp(12px,1.2vw,16px);width:clamp(100px,15vw,200px)}.present-qr-img{width:clamp(200px,30vw,400px);height:clamp(200px,30vw,400px);border-radius:12px;image-rendering:pixelated}.present-join-link{cursor:pointer;display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:8px;background:var(--surface);transition:background .15s}.present-join-link:hover{background:var(--surface-hover, #333)}.present-join-url{font-size:clamp(12px,1.4vw,18px);color:var(--accent);font-family:"SF Mono","Fira Code","Consolas",monospace;word-break:break-all}.present-join-copied,.present-join-copy{font-size:clamp(10px,1.2vw,14px);font-weight:700;text-transform:uppercase;letter-spacing:1px;white-space:nowrap}.present-join-copy{color:var(--text-muted)}.present-join-copied{color:var(--accent);display:none}.present-join-link.copied .present-join-copied{display:inline}.present-stats-section{width:100%}.present-section-label{font-size:clamp(10px,1.1vw,13px);color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;font-weight:700;margin-bottom:clamp(10px,1.5vh,18px);text-align:center}.present-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(10px,1.5vw,18px)}.present-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:clamp(14px,1.8vw,22px)}.present-stat-label{font-size:clamp(10px,.9vw,12px);color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:3px}.present-stat-name{font-size:clamp(14px,2.2vw,26px);font-weight:900;color:var(--accent);margin-bottom:clamp(10px,1.4vh,16px);overflow-wrap:break-word;word-break:break-word}.present-bar-chart{display:flex;flex-direction:column;gap:clamp(5px,.8vh,9px)}.present-bar-row{display:grid;grid-template-columns:76px 1fr 38px;align-items:center;gap:8px}.present-bar-label{font-size:clamp(10px,.9vw,12px);color:var(--text-muted);text-transform:capitalize;font-weight:600;text-align:right}.present-bar-track{background:var(--surface2);border-radius:3px;height:clamp(5px,.7vw,9px);overflow:hidden}.present-bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .6s ease}.present-bar-val{font-size:clamp(11px,1vw,13px);color:var(--text);font-weight:700}.home-hero{text-align:center;padding:32px 20px}.home-icon{font-size:52px;margin-bottom:12px;line-height:1}.home-title{font-size:24px;font-weight:800;margin-bottom:6px}.home-sub{font-size:14px;color:var(--text-muted);margin-bottom:20px}.code-input{font-size:32px!important;font-weight:900;text-align:center;letter-spacing:12px;padding:16px 20px!important;font-family:"SF Mono","Fira Code","Consolas",monospace;max-width:280px;margin-left:auto;margin-right:auto}.home-or{display:flex;align-items:center;gap:12px;margin:6px 0;padding:0 20px}.home-or-line{flex:1;height:1px;background:var(--border)}.home-or-text{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:700}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;width:100%;max-width:400px;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:12px;right:14px;background:0 0;border:0;color:var(--text-muted);font-size:24px;cursor:pointer;padding:4px;line-height:1;-webkit-appearance:none}.auth-tab:hover,.modal-close:hover{color:var(--text)}.auth-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid var(--border)}.auth-tab{flex:1;background:0 0;border:0;color:var(--text-muted);font-size:15px;font-weight:700;padding:10px 0;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;-webkit-appearance:none}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-social-divider{display:flex;align-items:center;gap:12px;margin:16px 0}.btn-social{text-decoration:none;text-align:center;font-size:14px;min-height:44px;border:1.5px solid var(--border);border-radius:8px;color:var(--text);background:var(--surface2)}.btn-social:hover{border-color:var(--accent)}.admin-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.btn-back{background:0 0;border:0;color:var(--text-muted);font-size:15px;cursor:pointer;padding:4px 0;-webkit-appearance:none}.btn-back:hover{color:var(--text)}.event-admin-card.event-ended{opacity:.6}.event-admin-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.event-code-display{text-align:center;flex-shrink:0}.event-code-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:2px}.event-code-value{font-size:24px;font-weight:900;color:var(--accent);letter-spacing:4px;font-family:"SF Mono","Fira Code","Consolas",monospace}.code-share-card{text-align:center;padding:28px 20px}.code-share-label{font-size:13px;color:var(--text-muted);margin-bottom:12px}.code-share-value{font-size:48px;font-weight:900;color:var(--accent);letter-spacing:10px;font-family:"SF Mono","Fira Code","Consolas",monospace;margin-bottom:16px}.admin-drink-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);transition:opacity .15s,background .15s}.admin-drink-row:last-of-type{border-bottom:none}.admin-drink-row.dragging{opacity:.3}.admin-drink-row.drag-over{background:var(--surface2);border-radius:6px}.drag-handle{cursor:grab;color:var(--text-muted);font-size:16px;padding:4px;user-select:none;line-height:1}.drag-handle:active{cursor:grabbing}.admin-drink-info{flex:1;min-width:0}.btn-icon{background:0 0;border:0;color:var(--text-muted);font-size:20px;cursor:pointer;padding:4px 8px;line-height:1;border-radius:4px;transition:color .15s,background .15s;-webkit-appearance:none}.btn-icon:hover{color:var(--danger);background:rgba(200,64,64,.1)}.admin-add-drink{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}@media (min-width:600px){#app{padding:24px 20px 96px}.card{padding:24px}.drink-name{font-size:28px}.slider-value{font-size:36px}.score-grid{grid-template-columns:repeat(3,1fr);gap:10px}}@media (min-width:900px){.score-grid{grid-template-columns:repeat(6,1fr)}}.app-version{text-align:center;font-size:11px;color:var(--text-muted);padding:20px 0 10px;opacity:.6}