.rest-timer{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1.5rem 1rem;width:100%}.rest-timer__ring-wrap{position:relative;width:200px;height:200px;flex-shrink:0}.rest-timer__svg{display:block;filter:drop-shadow(0 2px 12px rgba(139,92,246,.15))}.rest-timer__center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.rest-timer__time{font-size:2.5rem;font-weight:700;letter-spacing:-.04em;color:var(--sl-gray-900);line-height:1;font-variant-numeric:tabular-nums}.rest-timer__label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--sl-gray-400);margin-top:.25rem}.rest-timer__done-text{font-size:2.25rem;font-weight:800;color:#16a34a;letter-spacing:-.02em;animation:done-pulse .6s ease-in-out infinite alternate}@keyframes done-pulse{0%{transform:scale(1);opacity:1}to{transform:scale(1.08);opacity:.85}}.rest-timer--done .rest-timer__ring-wrap{animation:done-glow 1.2s ease-in-out infinite alternate}@keyframes done-glow{0%{filter:drop-shadow(0 0 8px rgba(22,163,74,.3))}to{filter:drop-shadow(0 0 20px rgba(22,163,74,.6))}}.rest-timer__presets{display:flex;gap:.375rem;flex-wrap:wrap;justify-content:center}.rest-timer__preset{padding:.375rem .75rem;border:1.5px solid var(--sl-gray-200);border-radius:20px;background:var(--sl-gray-50);font-size:.8125rem;font-weight:600;color:var(--sl-gray-600);cursor:pointer;transition:all .18s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent}.rest-timer__preset:hover{border-color:var(--sl-purple-400);color:var(--sl-purple-700);background:var(--sl-purple-50)}.rest-timer__preset--active{border-color:var(--sl-purple-500);background:var(--sl-purple-100);color:var(--sl-purple-700)}.rest-timer__custom{display:flex;flex-direction:column;align-items:center;gap:.75rem;background:var(--sl-gray-50);border:1px solid var(--sl-gray-200);border-radius:12px;padding:1rem 1.25rem;width:100%;max-width:320px}.rest-timer__custom-fields{display:flex;gap:1rem;align-items:center}.rest-timer__custom-field{display:flex;align-items:center;gap:.375rem}.rest-timer__custom-field input{width:3.5rem;padding:.5rem .625rem;border:1.5px solid var(--sl-gray-200);border-radius:8px;font-size:1rem;font-weight:600;text-align:center;color:var(--sl-gray-900);background:#fff;font-variant-numeric:tabular-nums}.rest-timer__custom-field input:focus-visible{border-color:var(--sl-purple-500);outline:2px solid var(--sl-purple-200, #ddd6fe);outline-offset:1px}.rest-timer__custom-field span{font-size:.75rem;font-weight:600;color:var(--sl-gray-400);text-transform:uppercase;letter-spacing:.05em}.rest-timer__custom-start{padding:.5rem 1.25rem;background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-700));color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .18s}.rest-timer__custom-start:hover:not(:disabled){opacity:.9}.rest-timer__custom-start:disabled{opacity:.45;cursor:not-allowed}.rest-timer__controls{display:flex;align-items:center;gap:.75rem}.rest-timer__btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .18s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent}.rest-timer__btn:disabled{opacity:.4;cursor:not-allowed}.rest-timer__btn--skip{padding:.5rem .875rem;background:var(--sl-gray-100);color:var(--sl-gray-600);font-size:.8125rem;border:1.5px solid var(--sl-gray-200)}.rest-timer__btn--skip:hover:not(:disabled){background:var(--sl-gray-200);color:var(--sl-gray-900)}.rest-timer__btn--main{padding:.75rem 1.75rem;font-size:1rem;background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-700));color:#fff;box-shadow:0 2px 8px #7c3aed40;min-width:9rem}.rest-timer__btn--main:hover:not(:disabled){background:linear-gradient(135deg,var(--sl-purple-500),var(--sl-purple-600));box-shadow:0 4px 14px #7c3aed59;transform:translateY(-1px)}.rest-timer__btn--main:active:not(:disabled){transform:translateY(0)}.rest-timer__btn--restart{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 2px 8px #16a34a40}.rest-timer__btn--restart:hover:not(:disabled){background:linear-gradient(135deg,#15803d,#166534);box-shadow:0 4px 14px #16a34a59}.rest-timer-mini{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--sl-gray-900);color:#fff;border-radius:24px;font-size:.875rem;font-weight:600;box-shadow:0 4px 16px #0000002e;font-variant-numeric:tabular-nums}.rest-timer-mini--running{background:linear-gradient(135deg,var(--sl-purple-700),var(--sl-purple-900));animation:mini-pulse 2s ease-in-out infinite}.rest-timer-mini--done{background:linear-gradient(135deg,#166534,#15803d);animation:mini-pulse .6s ease-in-out infinite alternate}@keyframes mini-pulse{0%,to{box-shadow:0 4px 16px #7c3aed40}50%{box-shadow:0 4px 24px #7c3aed73}}.rest-timer-mini__icon{font-size:.9rem;opacity:.8}.rest-timer-mini__time{min-width:3rem}.rest-timer-mini__toggle,.rest-timer-mini__close{background:#ffffff26;border:none;color:#fff;border-radius:50%;width:1.75rem;height:1.75rem;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.75rem;transition:background .15s;-webkit-tap-highlight-color:transparent}.rest-timer-mini__toggle:hover,.rest-timer-mini__close:hover{background:#ffffff40}@media(max-width:480px){.rest-timer__ring-wrap,.rest-timer__svg{width:160px;height:160px}.rest-timer__time{font-size:2rem}}.hang-timer{display:flex;flex-direction:column;align-items:center;gap:1.25rem;width:100%;padding:1rem .5rem}.hang-timer__protocols{display:grid;grid-template-columns:1fr 1fr;gap:.625rem;width:100%;max-width:480px}.hang-timer__protocol-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.875rem .75rem;background:#fff;border:2px solid var(--sl-gray-200);border-radius:12px;cursor:pointer;transition:all .18s cubic-bezier(.4,0,.2,1);text-align:center;-webkit-tap-highlight-color:transparent}.hang-timer__protocol-card:hover{border-color:var(--sl-purple-400);background:var(--sl-purple-50)}.hang-timer__protocol-card--active{border-color:var(--sl-purple-600);background:var(--sl-purple-50);box-shadow:0 0 0 3px #7c3aed1a}.hang-timer__protocol-icon{font-size:1.25rem;line-height:1}.hang-timer__protocol-name{font-weight:700;font-size:.875rem;color:var(--sl-gray-900)}.hang-timer__protocol-desc{font-size:.7rem;color:var(--sl-gray-500);line-height:1.3}.hang-timer__phase-display{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:340px;min-height:200px;border-radius:20px;padding:2rem 1.5rem;text-align:center;transition:background .4s ease,border-color .4s ease;position:relative;overflow:hidden}.hang-timer__phase-display:before{content:"";position:absolute;inset:0;border-radius:20px;opacity:.08;pointer-events:none}.hang-timer__phase--ready{background:var(--sl-gray-900);border:2px solid var(--sl-gray-700)}.hang-timer__phase--hang{background:#052e16;border:2px solid #16a34a;animation:hang-pulse .8s ease-in-out infinite alternate}.hang-timer__phase--rest{background:#0c1a3a;border:2px solid #3b82f6}.hang-timer__phase--done{background:#052e16;border:2px solid #16a34a}@keyframes hang-pulse{0%{box-shadow:0 0 20px #16a34a33}to{box-shadow:0 0 40px #16a34a80}}.hang-timer__phase-label{font-size:1.5rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.4)}.hang-timer__phase--hang .hang-timer__phase-label{color:#86efac;font-size:2rem}.hang-timer__phase--rest .hang-timer__phase-label{color:#93c5fd}.hang-timer__phase--done .hang-timer__phase-label{color:#86efac;font-size:2.5rem;animation:done-bounce .5s ease-in-out infinite alternate}@keyframes done-bounce{0%{transform:scale(1)}to{transform:scale(1.06)}}.hang-timer__phase-seconds{font-size:5rem;font-weight:900;letter-spacing:-.05em;color:#fff;line-height:1;margin-top:.25rem;font-variant-numeric:tabular-nums;text-shadow:0 2px 16px rgba(0,0,0,.5)}.hang-timer__phase--hang .hang-timer__phase-seconds{color:#4ade80;font-size:6rem}.hang-timer__phase--rest .hang-timer__phase-seconds{color:#60a5fa}.hang-timer__done-stats{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.hang-timer__done-stats span{font-size:1rem;color:#86efac;font-weight:600}.hang-timer__counters{display:flex;gap:2rem;align-items:center}.hang-timer__counter{display:flex;flex-direction:column;align-items:center;gap:.1rem}.hang-timer__counter-value{font-size:1.75rem;font-weight:800;color:var(--sl-gray-900);line-height:1;font-variant-numeric:tabular-nums}.hang-timer__counter-of{font-size:.875rem;color:var(--sl-gray-400);font-weight:500}.hang-timer__counter-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sl-gray-400);margin-top:.125rem}.hang-timer__progress-wrap{width:100%;max-width:340px;height:6px;background:var(--sl-gray-200);border-radius:9999px;overflow:hidden}.hang-timer__progress-bar{height:100%;background:linear-gradient(90deg,var(--sl-purple-600),#8b5cf6);border-radius:9999px;transition:width .5s ease;min-width:0}.hang-timer__config{width:100%;max-width:480px;background:var(--sl-gray-50);border:1px solid var(--sl-gray-200);border-radius:12px;padding:1.125rem 1.25rem}.hang-timer__config-title{font-size:.875rem;font-weight:700;color:var(--sl-gray-700);margin:0 0 .875rem;text-transform:uppercase;letter-spacing:.05em}.hang-timer__config-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.hang-timer__config-field{display:flex;flex-direction:column;gap:.25rem}.hang-timer__config-field span{font-size:.75rem;font-weight:600;color:var(--sl-gray-500)}.hang-timer__config-field input{padding:.4375rem .625rem;border:1.5px solid var(--sl-gray-200);border-radius:8px;font-size:.9375rem;font-weight:600;color:var(--sl-gray-900);font-variant-numeric:tabular-nums}.hang-timer__config-field input:focus-visible{border-color:var(--sl-purple-500);outline:2px solid var(--sl-purple-200, #ddd6fe);outline-offset:1px}.hang-timer__actions{display:flex;gap:.75rem;align-items:center}.hang-timer__btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.6875rem 1.5rem;border:none;border-radius:10px;font-size:.9375rem;font-weight:700;cursor:pointer;transition:all .18s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent}.hang-timer__btn--start{background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-700));color:#fff;box-shadow:0 2px 10px #7c3aed4d;min-width:10rem}.hang-timer__btn--start:hover{background:linear-gradient(135deg,var(--sl-purple-500),var(--sl-purple-600));box-shadow:0 4px 16px #7c3aed66;transform:translateY(-1px)}.hang-timer__btn--start:active{transform:translateY(0)}.hang-timer__btn--config{background:var(--sl-gray-100);color:var(--sl-gray-600);border:1.5px solid var(--sl-gray-200);font-size:.8125rem}.hang-timer__btn--config:hover{background:var(--sl-gray-200);color:var(--sl-gray-900)}.hang-timer__btn--skip{background:#f59e0b1f;color:#b45309;border:1.5px solid rgba(245,158,11,.3)}.hang-timer__btn--skip:hover{background:#f59e0b33}.hang-timer__btn--stop{background:#ef44441a;color:#dc2626;border:1.5px solid rgba(239,68,68,.25)}.hang-timer__btn--stop:hover{background:#ef44442e}.hang-timer__btn--log{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;font-weight:700}.hang-timer__btn--log:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #667eea59}@media(max-width:480px){.hang-timer__protocols{grid-template-columns:1fr 1fr;gap:.5rem}.hang-timer__phase-seconds{font-size:4rem}.hang-timer__phase--hang .hang-timer__phase-seconds{font-size:5rem}.hang-timer__config-grid{grid-template-columns:1fr}.hang-timer__counters{gap:1.25rem}}.workout-timer{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:1.5rem 1rem;width:100%}.workout-timer__display{display:flex;flex-direction:column;align-items:center;gap:.375rem}.workout-timer__elapsed{font-size:3.5rem;font-weight:800;letter-spacing:-.04em;color:var(--sl-gray-900);font-variant-numeric:tabular-nums;line-height:1}.workout-timer__label{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--sl-gray-400)}.workout-timer__controls{display:flex;gap:.75rem;align-items:center}.workout-timer__btn{display:inline-flex;align-items:center;gap:.375rem;padding:.6875rem 1.375rem;border:none;border-radius:10px;font-size:.9375rem;font-weight:700;cursor:pointer;transition:all .18s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent}.workout-timer__btn:disabled{opacity:.4;cursor:not-allowed}.workout-timer__btn--start{background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-700));color:#fff;box-shadow:0 2px 10px #7c3aed4d}.workout-timer__btn--start:hover{background:linear-gradient(135deg,var(--sl-purple-500),var(--sl-purple-600));box-shadow:0 4px 16px #7c3aed66;transform:translateY(-1px)}.workout-timer__btn--start:active{transform:translateY(0)}.workout-timer__btn--lap{background:var(--sl-gray-100);color:var(--sl-gray-700);border:1.5px solid var(--sl-gray-200)}.workout-timer__btn--lap:hover:not(:disabled){background:var(--sl-gray-200)}.workout-timer__btn--pause{background:#f59e0b1f;color:#b45309;border:1.5px solid rgba(245,158,11,.3)}.workout-timer__btn--pause:hover{background:#f59e0b33}.workout-timer__btn--resume{background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-700));color:#fff;box-shadow:0 2px 8px #7c3aed40}.workout-timer__btn--resume:hover{opacity:.92;transform:translateY(-1px)}.workout-timer__btn--stop{background:#ef44441a;color:#dc2626;border:1.5px solid rgba(239,68,68,.25)}.workout-timer__btn--stop:hover{background:#ef44442e}.workout-timer__laps{width:100%;max-width:360px}.workout-timer__laps-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--sl-gray-100);border:1px solid var(--sl-gray-200);border-radius:8px;font-size:.8125rem;font-weight:600;color:var(--sl-gray-600);cursor:pointer;transition:background .15s}.workout-timer__laps-toggle:hover{background:var(--sl-gray-200)}.workout-timer__laps-chevron{font-size:.625rem;color:var(--sl-gray-400)}.workout-timer__laps-list{list-style:none;padding:0;margin:.375rem 0 0;display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto}.workout-timer__lap-row{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#fff;border:1px solid var(--sl-gray-100);border-radius:6px;font-size:.8125rem}.workout-timer__lap-num{color:var(--sl-gray-500);flex-shrink:0;min-width:3.5rem;font-weight:500}.workout-timer__lap-time{font-weight:700;color:var(--sl-gray-900);font-variant-numeric:tabular-nums;flex:1}.workout-timer__lap-split{color:var(--sl-gray-400);font-size:.75rem;font-variant-numeric:tabular-nums}.workout-timer-bar{display:inline-flex;align-items:center;gap:.625rem;padding:.5rem .875rem;background:var(--sl-gray-900);color:#fff;border-radius:24px;font-size:.875rem;font-weight:600;box-shadow:0 2px 12px #00000026;font-variant-numeric:tabular-nums}.workout-timer-bar--running{background:linear-gradient(135deg,var(--sl-purple-800),var(--sl-purple-900));animation:bar-pulse 3s ease-in-out infinite}@keyframes bar-pulse{0%,to{box-shadow:0 2px 12px #7c3aed33}50%{box-shadow:0 2px 20px #7c3aed66}}.workout-timer-bar__icon{font-size:.9rem;opacity:.75}.workout-timer-bar__time{min-width:3.25rem;letter-spacing:.02em}.workout-timer-bar__lap,.workout-timer-bar__expand{background:#ffffff24;border:none;color:#fff;border-radius:6px;padding:.25rem .5rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}.workout-timer-bar__lap:hover:not(:disabled),.workout-timer-bar__expand:hover{background:#ffffff3d}.workout-timer-bar__lap:disabled{opacity:.4;cursor:not-allowed}.workout-timer-bar__lapcount{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border-radius:50%;background:#fff3;font-size:.7rem;font-weight:700}.timer-panel-backdrop{position:fixed;inset:0;background:#0000;z-index:800;pointer-events:auto;transition:background .3s}.timer-panel-backdrop--expanded{background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.timer-panel{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:520px;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 40px #0000001f,0 -1px 0 var(--sl-gray-200);z-index:810;display:flex;flex-direction:column;max-height:92dvh;transition:max-height .35s cubic-bezier(.4,0,.2,1),border-radius .35s cubic-bezier(.4,0,.2,1);overflow:hidden;animation:panel-slide-up .35s cubic-bezier(.4,0,.2,1) both}@keyframes panel-slide-up{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.timer-panel--expanded{max-height:100dvh;border-radius:0}.timer-panel__header{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem .5rem;border-bottom:1px solid var(--sl-gray-100);flex-shrink:0;position:relative}.timer-panel__drag-handle{position:absolute;top:.4rem;left:50%;transform:translate(-50%);width:2.5rem;height:4px;background:var(--sl-gray-300);border-radius:9999px}.timer-panel__tabs{display:flex;gap:.25rem;flex:1;margin-top:.75rem}.timer-panel__tab{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .875rem;border:none;background:transparent;border-radius:8px;font-size:.8125rem;font-weight:600;color:var(--sl-gray-500);cursor:pointer;transition:all .18s cubic-bezier(.4,0,.2,1);white-space:nowrap;-webkit-tap-highlight-color:transparent}.timer-panel__tab:hover{color:var(--sl-gray-900);background:var(--sl-gray-100)}.timer-panel__tab--active{background:var(--sl-purple-100);color:var(--sl-purple-700)}.timer-panel__header-actions{display:flex;align-items:center;gap:.25rem;margin-top:.75rem;flex-shrink:0}.timer-panel__icon-btn{display:inline-flex;align-items:center;justify-content:center;width:1.875rem;height:1.875rem;border:none;background:transparent;border-radius:6px;color:var(--sl-gray-500);font-size:.875rem;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.timer-panel__icon-btn:hover{background:var(--sl-gray-100);color:var(--sl-gray-900)}.timer-panel__icon-btn--close:hover{background:#ef44441a;color:#dc2626}.timer-panel__body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:.5rem 0 1.5rem}@media(max-width:540px){.timer-panel{max-width:100%;border-radius:16px 16px 0 0}.timer-panel--expanded{border-radius:0}.timer-panel__tab{padding:.375rem .625rem;font-size:.75rem}}.timer-fab{position:fixed;bottom:1.5rem;right:1.5rem;z-index:790;display:flex;align-items:center;justify-content:center;width:3.25rem;height:3.25rem;border-radius:50%;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-700));color:#fff;box-shadow:0 4px 18px #7c3aed66,0 1px 4px #00000026;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),background .2s}.timer-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #7c3aed80,0 2px 6px #00000026}.timer-fab:active{transform:scale(.95)}.timer-fab--open{background:linear-gradient(135deg,var(--sl-purple-700),var(--sl-purple-900));box-shadow:0 2px 12px #7c3aed59,0 1px 3px #00000026}.timer-fab--active{animation:fab-pulse 2s ease-in-out infinite}@keyframes fab-pulse{0%,to{box-shadow:0 4px 18px #7c3aed66,0 1px 4px #00000026}50%{box-shadow:0 4px 32px #7c3aedb3,0 1px 4px #00000026}}.timer-fab__icon{font-size:1.375rem;line-height:1;display:flex;align-items:center;justify-content:center}.timer-fab__indicator{position:absolute;top:.125rem;right:.125rem;width:.75rem;height:.75rem;background:#4ade80;border-radius:50%;border:2px solid #fff;animation:dot-blink 1.5s ease-in-out infinite}@keyframes dot-blink{0%,to{opacity:1}50%{opacity:.4}}@media(max-width:860px){.timer-fab{bottom:calc(1.25rem + env(safe-area-inset-bottom,0px));right:calc(1rem + env(safe-area-inset-right,0px));width:3rem;height:3rem}.timer-fab__icon{font-size:1.25rem}}@media(max-width:768px){.timer-fab{bottom:calc(5rem + env(safe-area-inset-bottom,0px))}}.scroll-locked{overflow:hidden}:root{--sl-purple-50: #f5f3ff;--sl-purple-100: #ede9fe;--sl-purple-200: #ddd6fe;--sl-purple-400: #a78bfa;--sl-purple-500: #8b5cf6;--sl-purple-600: #7c3aed;--sl-purple-700: #6d28d9;--sl-purple-800: #5b21b6;--sl-purple-900: #4c1d95;--sl-gray-50: #fafafa;--sl-gray-100: #f4f4f5;--sl-gray-200: #e4e4e7;--sl-gray-300: #d4d4d8;--sl-gray-400: #a1a1aa;--sl-gray-500: #71717a;--sl-gray-600: #52525b;--sl-gray-700: #3f3f46;--sl-gray-800: #27272a;--sl-gray-900: #18181b;--sl-danger-50: #fef2f2;--sl-danger-600: #dc2626;--sl-nav-height: 3.5rem;--sl-mobile-menu-width: 17rem;--sl-transition-fast: .18s cubic-bezier(.4, 0, .2, 1);--sl-transition-smooth: .3s cubic-bezier(.4, 0, .2, 1);--sl-surface: rgba(255, 255, 255, .82);--sl-surface-solid: #ffffff;--sl-border: var(--sl-gray-200)}.App{min-height:100vh;display:flex;flex-direction:column}.sl-nav{position:sticky;top:0;z-index:900;height:var(--sl-nav-height);background:var(--sl-surface-solid);border-bottom:1px solid var(--sl-border);transition:background var(--sl-transition-fast),box-shadow var(--sl-transition-fast)}.sl-nav--scrolled{background:var(--sl-surface);-webkit-backdrop-filter:blur(12px) saturate(1.4);backdrop-filter:blur(12px) saturate(1.4);box-shadow:0 1px 3px #0000000f,0 4px 12px #0000000a}.sl-nav__inner{max-width:1280px;height:100%;margin:0 auto;padding:0 1.25rem;display:flex;align-items:center;gap:1.5rem}.sl-nav__brand{display:flex;align-items:center;gap:.5rem;text-decoration:none;flex-shrink:0}.sl-nav__logo-icon{display:flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-800));color:#fff;border-radius:6px;font-size:.7rem;line-height:1}.sl-nav__logo-text{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:var(--sl-gray-900)}.sl-nav__logo-accent{color:var(--sl-purple-600)}.sl-nav__desktop{flex:1;display:flex;min-width:0}.sl-nav__links{display:flex;align-items:center;gap:.125rem;flex:1;flex-wrap:wrap}.sl-nav-group{display:flex;align-items:center;gap:.125rem;position:relative}.sl-nav-group+.sl-nav-group:before{content:"";display:block;width:1px;height:1rem;background:var(--sl-gray-200);margin:0 .5rem;flex-shrink:0}.sl-nav-group__label{display:none}.sl-nav-group__links{display:flex;align-items:center;gap:.125rem}.sl-nav__secondary{display:flex;align-items:center;gap:.125rem;margin-left:auto}.sl-nav__secondary:before{content:"";display:block;width:1px;height:1rem;background:var(--sl-gray-200);margin:0 .5rem;flex-shrink:0}.sl-nav-dropdown{position:relative;display:flex;align-items:center}.sl-nav-dropdown__trigger{display:flex;align-items:center;gap:.35rem;padding:.375rem .5rem;border-radius:6px;font-size:.8125rem;font-weight:500;color:var(--sl-gray-600);background:none;border:none;cursor:pointer;white-space:nowrap;transition:color var(--sl-transition-fast),background var(--sl-transition-fast)}.sl-nav-dropdown__trigger:hover,.sl-nav-dropdown--open .sl-nav-dropdown__trigger{color:var(--sl-gray-900);background:var(--sl-gray-100)}.sl-nav-dropdown__arrow{font-size:.625rem;margin-left:.125rem;opacity:.6;transition:transform var(--sl-transition-fast)}.sl-nav-dropdown--open .sl-nav-dropdown__arrow{transform:rotate(180deg)}.sl-nav-dropdown__menu{position:absolute;top:calc(100% + .375rem);left:0;min-width:10rem;max-height:min(70vh,20rem);overflow-y:auto;background:var(--sl-surface-solid);border:1px solid var(--sl-border);border-radius:8px;box-shadow:0 4px 16px #00000014,0 1px 3px #0000000f;padding:.375rem;z-index:1000;display:flex;flex-direction:column;gap:1px;animation:sl-dropdown-in .15s ease-out}.sl-nav__links>.sl-nav-dropdown:last-of-type .sl-nav-dropdown__menu{left:auto;right:0}@keyframes sl-dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sl-nav-dropdown__menu .sl-nav-link{width:100%;padding:.5rem .625rem;border-radius:6px;justify-content:flex-start;text-align:left}.sl-nav-dropdown__menu .sl-nav-link--active:after{display:none}.sl-nav-link{display:flex;align-items:center;gap:.35rem;padding:.375rem .5rem;border-radius:6px;font-size:.8125rem;font-weight:500;color:var(--sl-gray-600);text-decoration:none;white-space:nowrap;transition:color var(--sl-transition-fast),background var(--sl-transition-fast);position:relative}.sl-nav-link:hover{color:var(--sl-gray-900);background:var(--sl-gray-100)}.sl-nav-link--active{color:var(--sl-purple-700);background:var(--sl-purple-50)}.sl-nav-link--active:after{content:"";position:absolute;bottom:-.6875rem;left:.5rem;right:.5rem;height:2px;background:var(--sl-purple-600);border-radius:2px 2px 0 0}.sl-nav-link__icon{font-size:.875rem;line-height:1;opacity:.7;flex-shrink:0}.sl-nav-link--active .sl-nav-link__icon{opacity:1}.sl-nav-link__label{line-height:1}.sl-nav__actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0;margin-left:1.25rem}.sl-nav__beta-note{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--sl-gray-600, #64748b);white-space:nowrap}@media(max-width:640px){.sl-nav__beta-note{display:none}}.sl-avatar-menu{position:relative;display:flex;align-items:center}.sl-avatar-menu__trigger{display:flex;align-items:center;gap:.25rem;padding:.25rem .375rem .25rem .25rem;background:none;border:1px solid transparent;cursor:pointer;border-radius:9999px;transition:background var(--sl-transition-fast),border-color var(--sl-transition-fast)}.sl-avatar-menu__trigger .sl-nav-dropdown__arrow{font-size:.7rem;opacity:.8;color:var(--sl-gray-500)}.sl-avatar-menu__trigger:hover,.sl-avatar-menu--open .sl-avatar-menu__trigger{background:var(--sl-gray-100);border-color:var(--sl-gray-200)}.sl-avatar-menu__circle{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:9999px;background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-800));color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.02em;flex-shrink:0}.sl-avatar-menu__dropdown{position:absolute;top:calc(100% + .375rem);right:0;min-width:12rem;background:var(--sl-surface-solid);border:1px solid var(--sl-border);border-radius:8px;box-shadow:0 4px 16px #00000014,0 1px 3px #0000000f;padding:.375rem;z-index:1000;display:flex;flex-direction:column;gap:1px;animation:sl-dropdown-in .15s ease-out}.sl-avatar-menu__user-info{padding:.5rem .625rem .375rem}.sl-avatar-menu__name{font-size:.8125rem;font-weight:600;color:var(--sl-gray-900)}.sl-avatar-menu__divider{height:1px;background:var(--sl-gray-200);margin:.25rem 0}.sl-avatar-menu__item{display:block;width:100%;padding:.5rem .625rem;border-radius:6px;font-size:.8125rem;font-weight:500;color:var(--sl-gray-600);text-decoration:none;text-align:left;background:none;border:none;cursor:pointer;transition:color var(--sl-transition-fast),background var(--sl-transition-fast)}.sl-avatar-menu__item:hover{color:var(--sl-gray-900);background:var(--sl-gray-100)}.sl-avatar-menu__item--danger{color:var(--sl-danger-600)}.sl-avatar-menu__item--danger:hover{color:var(--sl-danger-600);background:var(--sl-danger-50)}.sl-btn{display:inline-flex;align-items:center;justify-content:center;padding:.4rem .875rem;border-radius:6px;font-size:.8125rem;font-weight:600;letter-spacing:-.005em;border:none;cursor:pointer;white-space:nowrap;transition:all var(--sl-transition-fast)}.sl-btn--ghost{background:transparent;color:var(--sl-gray-600)}.sl-btn--ghost:hover{background:var(--sl-gray-100);color:var(--sl-gray-900)}.sl-btn--primary{background:linear-gradient(135deg,var(--sl-purple-600),var(--sl-purple-700));color:#fff;box-shadow:0 1px 2px #7c3aed40}.sl-btn--primary:hover{background:linear-gradient(135deg,var(--sl-purple-700),var(--sl-purple-800));box-shadow:0 2px 6px #7c3aed59;transform:translateY(-.5px)}.sl-btn--primary:active{transform:translateY(0);box-shadow:0 1px 2px #7c3aed33}.sl-btn--full{width:100%}.sl-hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:2rem;height:2rem;padding:0;background:transparent;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.sl-hamburger__line{display:block;width:18px;height:2px;background:var(--sl-gray-700);border-radius:2px;transition:transform var(--sl-transition-smooth),opacity var(--sl-transition-fast);transform-origin:center}.sl-hamburger--open .sl-hamburger__line:nth-child(1){transform:translateY(6px) rotate(45deg)}.sl-hamburger--open .sl-hamburger__line:nth-child(2){opacity:0;transform:scaleX(0)}.sl-hamburger--open .sl-hamburger__line:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.sl-mobile-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:950;opacity:0;transition:opacity var(--sl-transition-smooth);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sl-mobile-overlay--open{opacity:1;pointer-events:auto}.sl-mobile-menu{display:none;position:fixed;top:0;right:0;bottom:0;width:var(--sl-mobile-menu-width);background:var(--sl-surface-solid);z-index:1000;transform:translate(100%);transition:transform var(--sl-transition-smooth);box-shadow:-4px 0 24px #00000014;overflow:hidden}.sl-mobile-menu--open{transform:translate(0)}.sl-mobile-menu__scroll{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:4.5rem 1.25rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.sl-mobile-menu__close{position:absolute;top:1rem;right:1rem;width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--sl-gray-200);border-radius:8px;font-size:1.25rem;color:var(--sl-gray-500);cursor:pointer;transition:background var(--sl-transition-fast),color var(--sl-transition-fast);z-index:1}.sl-mobile-menu__close:hover{background:var(--sl-gray-100);color:var(--sl-gray-800)}.sl-mobile-menu .sl-nav-group{flex-direction:column;align-items:stretch;gap:0}.sl-mobile-menu .sl-nav-group+.sl-nav-group:before{display:none}.sl-mobile-menu .sl-nav-group__label{display:block;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sl-gray-400);padding:0 .5rem;margin-bottom:.375rem}.sl-mobile-menu .sl-nav-group__links{flex-direction:column;align-items:stretch;gap:1px}.sl-mobile-menu .sl-nav-link{padding:.625rem .5rem;font-size:.875rem;border-radius:8px}.sl-mobile-menu .sl-nav-link--active:after{display:none}.sl-mobile-menu .sl-nav-link--active{background:var(--sl-purple-50);color:var(--sl-purple-700);font-weight:600}.sl-mobile-menu .sl-nav__secondary{display:contents;margin-left:0}.sl-mobile-menu .sl-nav__secondary:before{display:none}.sl-mobile-menu__auth{margin-top:auto;padding-top:1rem;border-top:1px solid var(--sl-gray-200)}.sl-mobile-menu__divider{height:1px;background:var(--sl-gray-200);margin:.25rem 0}.sl-mobile-menu__signout{margin-top:auto;padding-top:.5rem}.sl-btn--danger{color:var(--sl-danger-600)}.sl-btn--danger:hover{background:var(--sl-danger-50);color:var(--sl-danger-600)}.main-content{flex:1;max-width:1280px;width:100%;min-width:0;margin:0 auto;padding:2rem;overflow-x:hidden;box-sizing:border-box}.auth-page{display:flex;justify-content:center;padding:2rem 0}.loading{text-align:center;padding:2rem;color:var(--sl-gray-500)}.sl-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:var(--sl-gray-500)}.sl-spinner__ring{width:2rem;height:2rem;border:3px solid var(--sl-gray-200);border-top-color:var(--sl-purple-600);border-radius:50%;animation:sl-spin .7s linear infinite}@keyframes sl-spin{to{transform:rotate(360deg)}}.sl-error-banner{padding:.75rem 1rem;background:var(--sl-danger-50);border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:.875rem;line-height:1.5;margin-bottom:1rem}.history-delete-confirm{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;color:var(--sl-gray-600)}.history-delete-confirm__yes{padding:.2rem .5rem;border:none;background:#e53e3e;color:#fff;border-radius:4px;font-size:.7rem;font-weight:700;cursor:pointer}.history-delete-confirm__no{padding:.2rem .5rem;border:1px solid var(--sl-gray-300);background:#fff;color:var(--sl-gray-600);border-radius:4px;font-size:.7rem;font-weight:600;cursor:pointer}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--sl-purple-500);outline-offset:1px}button:focus-visible{outline:2px solid var(--sl-purple-500);outline-offset:2px}@media(max-width:860px){.sl-nav__desktop,.sl-nav__actions .sl-btn--ghost{display:none}.sl-hamburger{display:flex}.sl-mobile-overlay{display:block;pointer-events:none}.sl-mobile-overlay--open{pointer-events:auto}.sl-mobile-menu{display:flex}.main-content{padding:1.25rem}.sl-mobile-menu .sl-nav-link{min-height:44px;padding:.75rem .5rem;align-items:center}.sl-mobile-menu__close{min-width:44px;min-height:44px}}@media(min-width:861px)and (max-width:1099px){.sl-nav__links{gap:0}.sl-nav-link,.sl-nav-dropdown__trigger{padding:.375rem;font-size:.75rem}.sl-nav-group+.sl-nav-group:before{margin:0 .25rem}}@media(min-width:1100px){.sl-nav__inner{gap:2rem}.sl-nav__links{gap:.25rem}.sl-nav-group+.sl-nav-group:before{margin:0 .75rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
