:root{--color-work: #ff0000;--color-rest: #00ff00;--color-paused: #ffaa00;--color-bg: #000000;--color-home: #0088ff;--color-text: currentColor;--color-text-white: #ffffff;--color-text-gray: #808080;--color-text-dimmed: #666666;--current-color: var(--color-work);--glow: none;--font-timer: ui-monospace, "SF Mono", Consolas, "Liberation Mono", Menlo, monospace;--font-ui: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--size-timer: clamp(6rem, 15vw, 20rem);--size-exercise: clamp(2rem, 5vw, 6rem);--size-preview: clamp(1.5rem, 3vw, 4rem);--size-round: clamp(2rem, 4vw, 5rem)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-ui);background:var(--color-bg);color:var(--current-color);min-height:100vh;min-height:100dvh;overflow-x:hidden}#app{padding-bottom:clamp(70px,15vh,100px)}.led-glow{color:var(--current-color);text-shadow:var(--glow)}.led-glow-box{box-shadow:var(--glow)}#home-screen{display:flex;flex-direction:column;align-items:stretch;border:3px solid var(--color-home);border-radius:12px;margin:1rem;margin-bottom:0;min-height:calc(100dvh - clamp(70px,15vh,100px) - 2rem);max-height:calc(100dvh - clamp(70px,15vh,100px));overflow:hidden}#home-screen.hidden{display:none}.tab-bar{display:flex;flex-shrink:0;border-bottom:1px solid var(--color-text-dimmed)}.tab{flex:1;padding:.75rem .5rem;min-height:48px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-gray);font-family:var(--font-ui);font-size:clamp(.875rem,2.5vw,1.125rem);cursor:pointer;transition:color .2s,border-color .2s;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent}.tab.active{color:var(--color-home);border-bottom-color:var(--color-home)}.tab-panels{flex:1;overflow:hidden;position:relative}.tab-panel{display:none;padding:1rem;overflow-y:auto;height:100%}.tab-panel.active{display:flex;flex-direction:column;gap:.75rem}#workout-selector{min-width:280px;min-height:50px;padding:.75rem 2.5rem .75rem 1rem;font-family:var(--font-ui);font-size:clamp(1rem,3vw,1.5rem);background:var(--color-bg);color:var(--color-text-white);border:2px solid var(--color-text-gray);border-radius:8px;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23808080' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.5rem}#workout-selector:focus{outline:none;border-color:var(--color-home)}#workout-selector option{background:var(--color-bg);color:var(--color-text-white);padding:.5rem}.slot-cards{display:grid;grid-template-columns:1fr;gap:.75rem;width:100%}@media(min-width:900px){.slot-cards{grid-template-columns:repeat(3,1fr);gap:1rem}}.slot-card{background:#ffffff0d;border:2px solid rgba(255,255,255,.2);border-radius:8px;padding:1rem;min-height:100px;display:flex;flex-direction:column;transition:border-color .3s,box-shadow .3s}.slot-card.slot-empty{border-color:#ffffff1a;opacity:.5;cursor:not-allowed}.slot-card.slot-empty .slot-workout-name{color:#fff6;font-style:italic}.slot-card.slot-ready{border-color:var(--color-rest);box-shadow:0 0 10px var(--color-rest);cursor:pointer}.slot-card.slot-ready:active{transform:scale(.98);box-shadow:0 0 20px var(--color-rest),0 0 40px var(--color-rest);transition:transform .05s ease-out,box-shadow .05s ease-out}.slot-card.slot-ready .slot-workout-name{color:var(--color-rest);text-shadow:0 0 10px var(--color-rest);font-weight:700}.slot-number{font-size:.9rem;color:#fff9;margin-bottom:.5rem}.slot-workout-name{font-size:clamp(1rem,2.5vw,1.4rem);margin-bottom:.25rem}.slot-updated-time{font-size:.8rem;color:#ffffff80}.slots-loading,.slots-error{text-align:center;padding:1rem;color:var(--color-text-white)}.slots-error{color:var(--color-work)}#slots-error-message{display:block;margin-bottom:.5rem}#btn-retry-slots{background:transparent;border:2px solid var(--color-work);color:var(--color-work);padding:.5rem 1rem;border-radius:4px;cursor:pointer;margin-left:.5rem;min-width:50px;min-height:48px;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent}#btn-retry-slots:hover,#btn-retry-slots:focus{box-shadow:0 0 10px var(--color-work);outline:none}#workout-preview{margin-top:2rem;text-align:center;min-height:6rem}#workout-title{font-family:var(--font-ui);font-size:clamp(1.5rem,4vw,2.5rem);font-weight:500;color:var(--color-home);margin-bottom:.5rem}#workout-info{font-family:var(--font-ui);font-size:clamp(1rem,2.5vw,1.5rem);color:var(--color-text-gray)}#workout-info.error{color:var(--color-work)}#timer-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem 2rem;border:3px solid var(--current-color);border-radius:12px;margin:1rem;margin-bottom:0;min-height:calc(100vh - clamp(70px,15vh,100px) - 2rem);max-height:85vh;overflow-y:auto}#timer-countdown{font-family:var(--font-timer);font-size:var(--size-timer);font-weight:700;color:var(--current-color);letter-spacing:.05em;font-variant-numeric:tabular-nums;text-shadow:var(--glow)}#exercise-name{font-family:var(--font-ui);font-size:var(--size-exercise);font-weight:500;color:var(--color-text-white);margin-bottom:1rem;text-align:center;max-width:90vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#up-next{text-align:right;font-family:var(--font-ui);font-size:clamp(1.25rem,3vw,2rem);font-weight:400;color:var(--color-text-gray);flex:1;min-width:0}#up-next.hidden{display:none}.up-next-label{opacity:.7}#up-next-exercise{color:var(--color-text-white);display:inline;max-width:60vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#control-dock{position:fixed;bottom:0;left:0;right:0;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:clamp(.5rem,2vw,1rem);padding:.5rem 1rem;padding-bottom:max(.5rem,env(safe-area-inset-bottom));background:#000000f2;border-top:1px solid var(--color-text-dimmed);max-height:clamp(70px,15vh,100px);overflow:hidden}#progress-bar-track{position:absolute;top:0;left:0;right:0;width:100%;height:5px;background:#ffffff14}#progress-bar-fill{height:100%;width:0%;background:#0af;transition:width .25s linear}#loop-label{position:absolute;top:8px;right:6px;font-family:var(--font-ui);font-size:.6rem;color:#0af;line-height:1;letter-spacing:.05em}#dock-controls{display:flex;align-items:center;justify-content:center;gap:1rem}.control-btn{min-width:50px;min-height:50px;padding:.5rem 1rem;font-family:var(--font-ui);font-size:clamp(.875rem,2.5vw,1.25rem);border:2px solid var(--color-text-white);background:transparent;color:var(--color-text-white);border-radius:8px;cursor:pointer;transition:opacity .1s;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;line-height:1;display:inline-flex;align-items:center;justify-content:center}.control-btn:active{opacity:.7}.control-btn.hidden{display:none}#session-summary{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-bg);z-index:100;overflow-y:auto}#session-summary.hidden{display:none}#session-summary .summary-content{text-align:center;padding:2rem}#summary-message{font-family:var(--font-ui);font-size:clamp(2rem,8vw,4rem);margin-bottom:2rem;color:var(--color-rest)}#summary-workout-name{font-family:var(--font-ui);font-size:clamp(1.5rem,5vw,2.5rem);margin-bottom:3rem;color:var(--color-rest)}.summary-stats{margin-bottom:3rem}.stat-row{display:flex;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:1rem;font-family:var(--font-ui);font-size:clamp(1.25rem,4vw,2rem)}.stat-label{color:var(--color-text-dimmed)}#summary-duration,#summary-blocks{color:var(--color-rest)}#summary-retention{margin-top:1rem}#summary-retention.hidden{display:none}.retention-title{font-family:var(--font-ui);font-size:clamp(1rem,3vw,1.5rem);color:var(--color-text-gray);margin-bottom:.75rem}.retention-time{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:.5rem;font-family:var(--font-ui);font-size:clamp(1rem,3vw,1.5rem)}.retention-label{color:var(--color-text-dimmed)}.retention-value{color:var(--color-rest);font-family:var(--font-timer);font-variant-numeric:tabular-nums}#session-summary .control-btn{min-width:80px;min-height:80px;padding:1.5rem 3rem;border-color:var(--color-rest);color:var(--color-rest)}.star-rating{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:clamp(.5rem,2vw,1rem);margin:1.5rem 0}.star{font-size:clamp(2.5rem,8vw,4rem);min-width:50px;min-height:50px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s ease-out,color .1s ease-out;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.star:active{transform:scale(.9)}.star-empty{color:var(--color-text-dimmed)}.star-filled{color:var(--color-rest);text-shadow:0 0 10px var(--color-rest),0 0 20px var(--color-rest)}.star:focus{outline:2px solid var(--color-rest);outline-offset:4px;border-radius:4px}.rating-label{font-family:var(--font-ui);font-size:clamp(1rem,3vw,1.5rem);color:var(--color-text-gray);text-align:center;margin-bottom:.5rem}.rating-section{margin:2rem 0;text-align:center}#session-summary .summary-stats{margin-bottom:1rem}@media(max-width:400px)and (max-height:900px){.rating-section{margin:1rem 0}.rating-label{font-size:clamp(.875rem,2.5vw,1.25rem)}}#breathe-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem 2rem;color:var(--color-rest);font-family:var(--font-ui);border:3px solid var(--color-rest);border-radius:12px;margin:1rem;margin-bottom:0;min-height:calc(100vh - clamp(70px,15vh,100px) - 2rem);max-height:85vh;overflow:hidden}#breathe-display.hidden{display:none}#breathe-exercise-name{font-family:var(--font-ui);font-size:var(--size-exercise);font-weight:500;color:var(--color-text-white);margin-bottom:2rem;text-align:center}#breathe-circle-container{display:flex;align-items:center;justify-content:center;width:clamp(150px,30vw,300px);height:clamp(150px,30vw,300px)}#breathe-circle{width:40%;height:40%;border-radius:50%;background:var(--color-rest);box-shadow:0 0 30px var(--color-rest),0 0 60px var(--color-rest);animation:breath-cycle 3.4s linear infinite}@keyframes breath-cycle{0%{transform:scale(1);opacity:.6}26.5%{transform:scale(1.7);opacity:.85}52.9%{transform:scale(2.2);opacity:1}58.8%{transform:scale(2.2);opacity:1}79.4%{transform:scale(1.5);opacity:.75}to{transform:scale(1);opacity:.6}}#breathe-counter{font-family:var(--font-timer);font-size:var(--size-round);font-weight:700;color:var(--color-rest);margin-top:2rem}#chrono-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem 2rem;border:3px solid var(--color-rest);border-radius:12px;margin:1rem;margin-bottom:0;min-height:calc(100vh - clamp(70px,15vh,100px) - 2rem);max-height:85vh;overflow:hidden;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}#chrono-display.hidden{display:none}#chrono-display>*{pointer-events:none}#chrono-exercise-name{font-family:var(--font-ui);font-size:var(--size-exercise);font-weight:500;color:var(--color-text-white);margin-bottom:1rem;text-align:center}#chrono-timer{font-family:var(--font-timer);font-size:var(--size-timer);font-weight:700;color:var(--color-rest);letter-spacing:.05em;font-variant-numeric:tabular-nums}#manual-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem 2rem;color:var(--color-rest);font-family:var(--font-ui);border:3px solid var(--color-rest);border-radius:12px;margin:1rem;margin-bottom:0;min-height:calc(100vh - clamp(70px,15vh,100px) - 2rem);max-height:85vh;overflow-y:auto;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}#manual-display.hidden{display:none}#round-counter{font-family:var(--font-ui);font-size:var(--size-round);font-weight:700;margin-bottom:2rem;color:var(--color-rest)}#exercise-list{list-style:none;padding:0;margin:0;font-family:var(--font-ui);font-size:clamp(2rem,5vw,5rem);width:80%;max-width:1200px;display:flex;flex-direction:column;gap:1rem;text-align:center}#exercise-list.exercise-list-two-column{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 3rem;text-align:left}.exercise-item{padding:.5rem 0;color:var(--color-rest)}.hidden{display:none!important}#flash-overlay{position:fixed;inset:0;pointer-events:none;opacity:0;z-index:9999;background-color:transparent}@keyframes tap-flash{0%{opacity:0;background-color:var(--color-rest)}50%{opacity:.3;background-color:var(--color-text-white)}to{opacity:0;background-color:var(--color-rest)}}#flash-overlay.active{animation:tap-flash .2s ease-in-out}#elapsed-time{font-family:var(--font-timer);font-size:clamp(1.25rem,3vw,2rem);font-weight:400;color:var(--color-text-gray);text-align:left;flex:1;min-width:4em;font-variant-numeric:tabular-nums;-webkit-font-feature-settings:"tnum";font-feature-settings:"tnum"}.tap-hint{font-family:var(--font-ui);font-size:clamp(.875rem,2vw,1.125rem);color:var(--color-text-dimmed);text-align:center;margin-top:2rem}@media(max-width:767px),(max-height:500px){.tap-hint{display:none}}@media(orientation:portrait){#timer-display,#manual-display,#breathe-display,#chrono-display{padding:2rem 1.5rem 1.5rem;margin:.5rem;margin-bottom:0}#control-dock{padding:.75rem 1rem}#exercise-list.exercise-list-two-column{grid-template-columns:1fr}}@media(max-width:400px)and (max-height:900px){#exercise-list{font-size:clamp(1.5rem,4vw,3rem);gap:.5rem}.exercise-item{padding:.25rem 0}#round-counter{font-size:clamp(1.75rem,3.5vw,3.5rem);margin-bottom:1.5rem}#manual-display{padding:2rem 1.5rem 1.5rem}#session-summary .summary-content{padding:1rem}#summary-message{font-size:clamp(1.5rem,6vw,3rem);margin-bottom:1rem}#summary-workout-name{font-size:clamp(1.25rem,4vw,2rem);margin-bottom:1.5rem}.summary-stats{margin-bottom:1.5rem}.stat-row{margin-bottom:.75rem;font-size:clamp(1rem,3.5vw,1.75rem);gap:1rem}#session-summary .control-btn{min-width:60px;min-height:60px;padding:1rem 2rem}}.favorites-loading,.favorites-error{font-family:var(--font-ui);font-size:clamp(.875rem,2vw,1.125rem);color:var(--color-text-dimmed);padding:1rem;text-align:center}.favorites-error{color:var(--color-work);display:flex;flex-direction:column;gap:.5rem;align-items:center}.favorites-list{display:flex;flex-direction:column;gap:.75rem}.favorites-empty{text-align:center;padding:2rem 1rem;color:var(--color-home);opacity:.5}.empty-message{font-size:clamp(1rem,2.5vw,1.5rem);font-family:var(--font-ui);margin-bottom:.5rem;color:var(--color-home)}.empty-hint{font-size:clamp(.875rem,2vw,1.125rem);font-family:var(--font-ui);opacity:.6;color:var(--color-rest)}.favorite-card{display:flex;justify-content:space-between;align-items:center;background-color:#0088ff1a;border:2px solid var(--color-home);border-radius:8px;padding:1rem;min-height:60px;cursor:pointer;transition:all .2s ease}.favorite-card:hover{background-color:#08f3;box-shadow:0 0 10px var(--color-home)}.favorite-name{font-family:var(--font-ui);font-size:clamp(1rem,2.5vw,1.5rem);color:var(--color-text-white);font-weight:700;flex:1}.favorite-remove-btn{background:transparent;border:2px solid var(--color-work);color:var(--color-work);font-size:clamp(1.25rem,3vw,1.75rem);width:48px;height:48px;min-width:48px;min-height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;line-height:1}.favorite-remove-btn:hover{background-color:#f003;box-shadow:0 0 10px var(--color-work)}.favorite-remove-btn:disabled{opacity:.5;cursor:not-allowed}.favorite-card.loading{opacity:.6;pointer-events:none;animation:pulse-loading 1s infinite}.favorite-card.loading .favorite-name:after{content:" - Loading...";font-size:.8em;color:var(--color-paused)}@keyframes pulse-loading{0%,to{opacity:.6}50%{opacity:.8}}.btn-add-favorite{background-color:transparent;border:2px solid var(--color-rest);color:var(--color-rest);padding:12px 24px;font-size:clamp(1rem,2vw,1.5rem);font-family:var(--font-ui);cursor:pointer;margin:16px 0;min-height:48px;min-width:200px;text-align:center;border-radius:8px;transition:all .2s ease;display:block}.btn-add-favorite:hover{background-color:#00ff001a;box-shadow:0 0 10px var(--color-rest)}.btn-add-favorite:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-add-favorite.adding{border-color:var(--color-paused);color:var(--color-paused);animation:pulse 1s infinite}.btn-add-favorite.favorited{border-color:var(--color-rest);background-color:#0f03;color:var(--color-rest);box-shadow:0 0 15px var(--color-rest)}.btn-add-favorite.error{border-color:var(--color-work);color:var(--color-work);background-color:#ff00001a;font-size:clamp(.9rem,1.8vw,1.3rem)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.btn-voice-fab{position:fixed;bottom:calc(clamp(70px,15vh,100px) + 16px);right:16px;width:56px;height:56px;min-width:56px;min-height:56px;border-radius:50%;background:var(--color-home);color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 0 15px var(--color-home),0 4px 12px #00000080;z-index:100;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent}.btn-voice-fab:active{transform:scale(.92);box-shadow:0 0 25px var(--color-home),0 2px 8px #00000080}.btn-voice-fab.hidden{display:none}#btn-play.play-ready{border-color:var(--color-home);color:var(--color-home);box-shadow:0 0 10px var(--color-home)}.card-selected{border:3px solid var(--color-home)!important;box-shadow:0 0 12px var(--color-home)!important}.slot-fav-btn{align-self:flex-end;background:transparent;border:1px solid var(--color-home);color:var(--color-home);font-size:1.25rem;width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;margin-top:.5rem;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent}.slot-fav-btn:active{background-color:#08f3;box-shadow:0 0 10px var(--color-home)}.slot-fav-btn.favorited{background-color:#0088ff4d;color:#fff}.slot-fav-btn.hidden,#control-dock.dock-home-mode .up-next-label{display:none}.voice-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.voice-modal-overlay{position:absolute;inset:0;background:#000000e6}.voice-modal-content{position:relative;background:var(--color-bg);border:2px solid var(--color-home);border-radius:16px;padding:2rem;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.voice-status{text-align:center}.microphone-icon{font-size:4rem;display:block;margin-bottom:1rem}.microphone-icon.pulsing{animation:mic-pulse 1.5s ease-in-out infinite}@keyframes mic-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}}#voice-status-text{font-family:var(--font-ui);font-size:clamp(1rem,2.5vw,1.5rem);color:var(--color-home);margin:0}.transcript-display{width:100%;min-height:100px;max-height:200px;overflow-y:auto;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:1rem}#transcript-text{font-family:var(--font-ui);font-size:clamp(1rem,2.5vw,1.25rem);color:var(--color-text-white);margin:0;line-height:1.5;white-space:pre-wrap;word-break:break-word;width:100%;min-height:80px;max-height:180px;resize:vertical;background:transparent;border:none;outline:none;overflow-y:auto}.transcript-length{font-family:var(--font-ui);font-size:clamp(.75rem,1.5vw,.875rem);color:var(--color-paused);text-align:right;margin-top:.5rem}.transcript-length.hidden{display:none}.transcript-length.over-limit{color:var(--color-work);font-weight:700}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.voice-error{width:100%;padding:1rem;background:#ff00001a;border:1px solid var(--color-work);border-radius:8px;color:var(--color-work);font-family:var(--font-ui);font-size:clamp(.875rem,2vw,1rem);text-align:center}.voice-error.hidden{display:none}.voice-error ul{text-align:left;margin-top:8px;padding-left:20px}.voice-error li{font-style:italic;color:#aaa;margin:4px 0}.voice-controls{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;width:100%}.voice-controls button{min-width:120px;min-height:48px;padding:12px 24px;font-family:var(--font-ui);font-size:clamp(.875rem,2vw,1.125rem);border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;appearance:none}.voice-controls .btn-primary{background:var(--color-home);border:2px solid var(--color-home);color:var(--color-bg)}.voice-controls .btn-primary:hover{box-shadow:0 0 15px var(--color-home)}.voice-controls .btn-secondary{background:transparent;border:2px solid var(--color-text-gray);color:var(--color-text-white)}.voice-controls .btn-secondary:hover{border-color:var(--color-text-white)}.voice-controls button:disabled{opacity:.5;cursor:not-allowed}.voice-controls button.hidden{display:none}.voice-loading{position:absolute;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:16px}.voice-loading.hidden{display:none}.loading-content{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;padding:2rem}.loading-icon{font-size:48px;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.voice-loading .spinner{border:4px solid rgba(255,255,255,.3);border-top:4px solid var(--color-home);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#loading-message{font-family:var(--font-ui);font-size:clamp(1rem,2.5vw,1.25rem);color:var(--color-text-white);margin:0}.loading-hint{font-family:var(--font-ui);font-size:clamp(.75rem,1.5vw,.875rem);color:var(--color-text-dimmed);margin:0}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background:var(--color-rest);color:var(--color-bg);padding:16px 24px;border-radius:8px;font-family:var(--font-ui);font-size:clamp(1rem,2vw,1.25rem);z-index:2000;animation:slideDown .3s ease-out;box-shadow:0 0 20px var(--color-rest)}.toast.hidden{display:none}@keyframes slideDown{0%{transform:translate(-50%,-100%);opacity:0}to{transform:translate(-50%);opacity:1}}.voice-success-celebration{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease-out}.voice-success-celebration .success-content{text-align:center;color:#fff}.voice-success-celebration .success-icon{font-size:72px;display:block;animation:celebrateBounce .5s ease-out}.voice-success-celebration h2{font-family:var(--font-ui);font-size:clamp(1.5rem,4vw,2rem);margin:16px 0 8px;color:var(--color-text-white)}.voice-success-celebration p{font-family:var(--font-ui);font-size:clamp(1rem,2.5vw,1.25rem);color:var(--color-rest)}.voice-success-celebration.fade-out{animation:fadeOut .3s ease-out forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes celebrateBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes slotHighlight{0%,to{transform:scale(1);box-shadow:0 0 10px var(--color-rest)}50%{transform:scale(1.05);box-shadow:0 0 30px var(--color-rest),0 0 60px var(--color-rest)}}.slot-card.slot-updated{animation:slotHighlight .6s ease-in-out}
