:root{--bg:#1a1a2e;--surface:#16213e;--surface2:#0f3460;--accent:#e94560;--accent2:#f5a623;--text:#eaeaea;--text-muted:#8a8a9a;--radius:12px;--transition:.2s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{flex-direction:column;min-height:100dvh;display:flex}button{cursor:pointer;font-family:inherit;font-size:inherit;transition:opacity var(--transition), transform var(--transition);border:none}button:active{opacity:.85;transform:scale(.96)}input,select{font-family:inherit}.home{padding:max(24px, env(safe-area-inset-top)) 16px 80px;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:480px;margin:0 auto;display:flex}.home-header{text-align:center;padding-top:8px}.home-title{color:var(--accent);margin-bottom:4px;font-size:2rem;font-weight:700}.home-subtitle{color:var(--text-muted);font-size:.9rem}.banner{background:var(--surface2);border-radius:var(--radius);flex-direction:column;gap:12px;width:100%;padding:16px;display:flex}.banner-text{color:var(--text);font-size:.9rem}.banner-text.error{color:var(--accent)}.alarm-list{flex-direction:column;gap:12px;width:100%;display:flex}.empty-text{color:var(--text-muted);text-align:center;padding:24px 0}.alarm-card{background:var(--surface);border-radius:var(--radius);transition:opacity var(--transition);justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.alarm-card.inactive{opacity:.5}.alarm-card-main{flex-direction:column;gap:4px;display:flex}.alarm-time{letter-spacing:-1px;color:var(--text);font-size:2rem;font-weight:700}.alarm-meta{color:var(--text-muted);font-size:.8rem}.alarm-card-actions{align-items:center;gap:8px;display:flex}.toggle-btn{border-radius:20px;padding:6px 14px;font-size:.85rem;font-weight:600}.toggle-btn.on{background:var(--accent);color:#fff}.toggle-btn.off{background:var(--surface2);color:var(--text-muted)}.delete-btn{color:var(--text-muted);background:0 0;border-radius:8px;padding:4px 8px;font-size:1.4rem}.delete-btn:hover{color:var(--accent)}.form-card{background:var(--surface);border-radius:var(--radius);flex-direction:column;gap:20px;width:100%;padding:20px;display:flex}.form-title{color:var(--text);font-size:1.1rem}.form-label{color:var(--text-muted);flex-direction:column;gap:8px;font-size:.85rem;display:flex}.form-input{background:var(--surface2);color:var(--text);box-sizing:border-box;appearance:none;border:1px solid #0000;border-radius:8px;outline:none;width:100%;max-width:100%;padding:10px 12px;font-size:1.2rem}.form-input:focus{border-color:var(--accent)}.form-range{width:100%;accent-color:var(--accent)}.day-picker{flex-wrap:wrap;gap:6px;display:flex}.day-btn{background:var(--surface2);width:38px;height:38px;color:var(--text-muted);border-radius:50%;font-size:.85rem;font-weight:600}.day-btn.selected{background:var(--accent);color:#fff}.form-actions{justify-content:flex-end;gap:12px;display:flex}.btn-primary{background:var(--accent);color:#fff;border-radius:10px;padding:12px 24px;font-size:.95rem;font-weight:600}.btn-secondary{background:var(--surface2);color:var(--text);border-radius:10px;padding:12px 24px;font-size:.95rem}.btn-add{background:var(--surface);color:var(--accent);border-radius:var(--radius);border:2px dashed var(--accent);width:100%;padding:16px;font-size:1rem;font-weight:600}.btn-ghost{color:var(--text-muted);background:0 0;padding:4px 8px;font-size:.8rem}.footer{flex-direction:column;align-items:center;gap:8px;margin-top:auto;display:flex}.status-syncing{color:var(--text-muted);font-size:.8rem}.status-ok{color:#4caf50;font-size:.8rem}.status-error{color:var(--accent);font-size:.8rem}.alarm-screen{background:var(--bg);z-index:1000;padding:max(24px, env(safe-area-inset-top)) 24px max(24px, env(safe-area-inset-bottom));text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:24px;display:flex;position:fixed;inset:0}.alarm-screen.tap{background:#1a1a2e}.tap-btn{background:var(--accent);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:16px;width:220px;height:220px;animation:1.5s ease-in-out infinite pulse;display:flex;box-shadow:0 0 0 20px #e9456026,0 0 0 40px #e9456012}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.tap-icon{font-size:3rem}.tap-label{color:#fff;font-size:1rem;font-weight:700}.tap-hint{color:var(--text-muted);font-size:.85rem}.alarm-screen.exercising{gap:32px}.exercise-instruction{color:var(--text);font-size:1.5rem;font-weight:700;line-height:1.4}.rep-counter{width:220px;height:220px;position:relative}.progress-ring{width:100%;height:100%;transform:rotate(-90deg)}.progress-track{stroke:var(--surface2)}.progress-fill{stroke:var(--accent);transition:stroke-dashoffset .3s}.rep-numbers{justify-content:center;align-items:center;gap:4px;display:flex;position:absolute;inset:0}.rep-current{color:var(--accent);font-size:3.5rem;font-weight:700}.rep-slash{color:var(--text-muted);font-size:2rem}.rep-target{color:var(--text-muted);font-size:2rem;font-weight:600}.rep-remain{color:var(--text-muted);font-size:1.1rem}.btn-debug{background:var(--surface2);color:var(--text-muted);border-radius:8px;padding:8px 16px;font-size:.8rem}.alarm-screen.done{background:linear-gradient(135deg,#1a1a2e 0%,#0f3460 100%)}.done-content{flex-direction:column;align-items:center;gap:16px;display:flex}.done-icon{color:#4caf50;font-size:5rem}.done-title{color:var(--text);font-size:2.5rem;font-weight:800}.done-sub{color:var(--text-muted);font-size:1rem}.btn-dismiss{background:var(--surface);color:var(--text);border-radius:10px;margin-top:24px;padding:14px 32px;font-size:1rem}.alarm-screen.error .error-content{flex-direction:column;gap:16px;display:flex}.alarm-screen.error h2{color:var(--accent);font-size:1.5rem}.alarm-screen.error p{color:var(--text-muted);font-size:.9rem;line-height:1.6}
