:root{--c-plenty: #2ECC71;--c-warning: #F1C40F;--c-critical: #E74C3C;--time: var(--c-plenty);--font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}@font-face{font-family:"Baloo 2";font-style:normal;font-weight:400 700;font-display:swap;src:url(/fonts/baloo2-latin.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400 700;font-display:swap;src:url(/fonts/jetbrainsmono-latin.woff2) format("woff2")}body[data-font=system]{--font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}body[data-font=rounded]{--font: "Baloo 2", ui-rounded, "SF Pro Rounded", system-ui, sans-serif}body[data-font=serif]{--font: ui-serif, Georgia, "Times New Roman", serif}body[data-font=mono]{--font: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace}body[data-theme=dark]{--bg: #0F1115;--surface: #1A1D24;--text: #F5F7FA;--muted: #8A94A6}body[data-theme=light]{--bg: #FAFAFA;--surface: #FFFFFF;--text: #1A1D24;--muted: #5A6072}*{box-sizing:border-box}html,body{height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);overscroll-behavior:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}#app{position:relative;height:100dvh;overflow:hidden}[data-phase=plenty]{--time: var(--c-plenty)}[data-phase=warning]{--time: var(--c-warning)}[data-phase=critical],[data-phase=expired]{--time: var(--c-critical)}.timer-view{position:absolute;top:0;right:0;bottom:0;left:0}.stage{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;touch-action:manipulation;cursor:pointer}.digits{font-weight:700;font-variant-numeric:tabular-nums;font-size:clamp(4rem,22vw,12rem);line-height:1;color:var(--time)}.ring{position:relative;width:min(80vw,70vh);aspect-ratio:1;display:flex;align-items:center;justify-content:center}.ring svg{width:100%;height:100%}.ring-track{fill:none;stroke:var(--surface);stroke-width:6}.ring-arc{fill:none;stroke:var(--time);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .25s linear,stroke .3s}.ring-label{position:absolute;font-size:clamp(2.5rem,13vw,7rem)}.fill{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;display:flex;align-items:center;justify-content:center}.fill-liquid{position:absolute;left:0;right:0;bottom:0;height:100%;background:var(--time);opacity:.22;transition:height .25s linear,background .3s}.fill-label{position:relative;font-size:clamp(4rem,22vw,12rem);color:var(--time)}.player-name{display:none;position:absolute;top:max(16px,env(safe-area-inset-top));left:0;right:0;text-align:center;font-size:clamp(2rem,9vw,3.5rem);font-weight:700;color:var(--time);z-index:2;pointer-events:none}.timer-view.advanced .player-name{display:block}.flash{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--c-critical);opacity:0;pointer-events:none;z-index:1}.timer-view.alarm .flash{animation:flash .6s steps(1,end) infinite}@keyframes flash{0%,to{opacity:0}50%{opacity:.85}}.timer-view.expired .flash{opacity:1;animation:none}.timer-view.paused .stage{opacity:.5}.controls{position:absolute;left:0;right:0;bottom:max(24px,env(safe-area-inset-bottom));display:flex;justify-content:center;gap:16px;z-index:2}.btn{min-width:56px;min-height:56px;padding:0 16px;font-size:1.5rem;color:var(--text);background:var(--surface);border:none;border-radius:16px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.btn:active{transform:scale(.95)}.settings-view{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:10;overflow-y:auto;padding-bottom:32px}.settings-header{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:12px;padding:max(12px,env(safe-area-inset-top)) 16px 12px;background:var(--bg)}.settings-header h1{font-size:1.25rem;margin:0}.settings-body{padding:0 16px;display:flex;flex-direction:column;gap:28px}.settings-body section{display:flex;flex-direction:column;gap:10px}.settings-view:not(.adv) .adv-only{display:none}.settings-view.adv .simple-only{display:none}.hint{font-size:.8rem;color:var(--muted);margin:0}.players{display:flex;flex-direction:column;gap:8px;margin-top:8px}.prow{display:flex;align-items:center;gap:8px;background:var(--surface);border-radius:12px;padding:8px}.prow.dragging{opacity:.6}.phandle{flex:0 0 auto;width:36px;height:44px;border:none;background:transparent;color:var(--muted);font-size:1.4rem;cursor:grab;touch-action:none}.psw{width:38px;height:38px;flex:0 0 auto;border-radius:10px;position:relative;overflow:hidden}.psw input{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;width:140%;height:140%;opacity:0;border:none;padding:0;cursor:pointer}.pname{flex:1 1 auto;min-width:0;padding:10px;font-size:1rem;background:var(--bg);color:var(--text);border:none;border-radius:10px}.ptime{flex:0 0 auto;display:flex;align-items:center;gap:2px}.ptime .num{width:3rem;padding:8px;font-size:1rem}.field-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.row{display:flex;gap:10px;align-items:center}.row .select{flex:1}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip,.seg{padding:10px 14px;min-height:48px;background:var(--surface);color:var(--text);border:2px solid transparent;border-radius:12px;cursor:pointer;font-size:1rem}.chip.active,.seg.active{border-color:var(--c-plenty)}.segmented{display:flex;gap:8px}.segmented .seg{flex:1}.designs .seg{padding:8px;height:64px;color:var(--text)}.design-seg svg{width:44px;height:44px;display:block;margin:0 auto}.design-seg.active{color:var(--c-plenty)}.fonts{display:grid;grid-template-columns:1fr 1fr;gap:8px}.font-seg{display:flex;flex-direction:column;align-items:center;gap:4px;height:auto;padding:14px;font-size:1rem;color:var(--text)}.font-sample{font-size:1.7rem;font-weight:700}.font-seg.active{color:var(--c-plenty);border-color:var(--c-plenty)}.swatches{display:flex;gap:12px;flex-wrap:wrap}.swatch{width:48px;height:48px;border-radius:12px;border:3px solid transparent;background:var(--sw, var(--surface));cursor:pointer;padding:0}.swatch.active{border-color:var(--text)}.swatch.custom{position:relative;overflow:hidden;background:conic-gradient(red,orange,#ff0,#0f0,#0ff,#00f,#f0f,red)}.swatch.custom input{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;width:140%;height:140%;border:none;padding:0;background:none;cursor:pointer;opacity:0}.time-custom{display:flex;align-items:center;gap:8px;font-size:1.5rem}.apply-all{margin-left:auto;font-size:1rem;min-height:48px}.num{width:4rem;padding:10px;font-size:1.25rem;text-align:center;background:var(--surface);color:var(--text);border:none;border-radius:12px}.select{padding:12px;min-height:48px;font-size:1rem;background:var(--surface);color:var(--text);border:none;border-radius:12px}.range{width:100%;accent-color:var(--c-plenty);height:40px}
