body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app-container{align-items:flex-start;display:flex;justify-content:center;min-height:100vh;overflow-y:auto;padding:80px 20px 20px;position:relative}.app-container:before{background-image:url(/static/media/background.e770583a2133f02449c4.png);background-image:var(--bg-image,url(/static/media/background.e770583a2133f02449c4.png));background-position:50%;background-repeat:no-repeat;background-size:cover;z-index:-2}.app-container:after,.app-container:before{bottom:0;content:"";left:0;position:fixed;right:0;top:0}.app-container:after{background:linear-gradient(135deg,#667eea4d,#764ba24d 50%,#06b6d44d);z-index:-1}.main-content{flex-direction:column;gap:24px;max-width:750px;padding-bottom:40px;width:100%}.info-button,.main-content{align-items:center;display:flex}.info-button{background:#ffffffe6;border:none;border-radius:50%;box-shadow:0 4px 12px #00000026;color:#6366f1;cursor:pointer;height:48px;justify-content:center;left:20px;position:fixed;top:20px;transition:all .2s ease;width:48px;z-index:100}.info-button:hover{background:#fff;box-shadow:0 6px 16px #0003;transform:translateY(-2px)}.info-button:active{transform:translateY(0)}.info-button svg{height:24px;width:24px}.settings-button{align-items:center;background:#ffffffe6;border:none;border-radius:50%;box-shadow:0 4px 12px #00000026;color:#6366f1;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:20px;top:20px;transition:all .2s ease;width:48px;z-index:100}.settings-button:hover{background:#fff;box-shadow:0 6px 16px #0003;transform:translateY(-2px)}.settings-button:active{transform:translateY(0)}.settings-button svg{height:24px;width:24px}.wake-lock-indicator{align-items:center;animation:slideInRight .3s ease;background:#10b981f2;border-radius:24px;box-shadow:0 4px 12px #10b9814d;color:#fff;display:flex;font-size:.875rem;font-weight:600;gap:8px;height:48px;padding:8px 16px;position:fixed;right:80px;top:20px;z-index:100}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.wake-lock-indicator svg{flex-shrink:0;height:16px;width:16px}.timer-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff40;border-radius:24px;box-shadow:0 20px 60px #0000004d;max-width:500px;padding:48px 32px;text-align:center;transition:background .3s ease;width:100%}.timer-card.completed-state{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#fffc}.app-title{color:#1f2937;font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin-bottom:32px}.timer-display{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:16px;margin:40px 0;padding:32px;transition:all .3s ease}.timer-display.paused{background:linear-gradient(135deg,#f59e0b,#ef4444)}.timer-display.transitioning{animation:pulse .5s ease}@keyframes pulse{0%,to{box-shadow:0 0 0 0 #6366f1b3;transform:scale(1)}50%{box-shadow:0 0 30px 10px #6366f166;transform:scale(1.05)}}.timer-label{color:#ffffffe6;font-size:1.25rem;font-weight:600;letter-spacing:2px;margin-bottom:16px;text-transform:uppercase}.timer-countdown{font-feature-settings:"tnum";color:#fff;font-size:5rem;font-variant-numeric:tabular-nums;font-weight:700;letter-spacing:4px;line-height:1}.paused-indicator{animation:blink 1s infinite;color:#ffffffe6;font-size:1rem;font-weight:600;letter-spacing:2px;margin-top:16px}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.progress-indicators{display:flex;gap:12px;justify-content:center;margin:32px 0}.progress-dot{border-radius:50%;height:16px;transition:all .3s ease;width:16px}.progress-dot.completed{background:#10b981;box-shadow:0 0 8px #10b98180}.progress-dot.active{animation:pulse-dot 1s infinite;background:#6366f1;box-shadow:0 0 12px #6366f199}.progress-dot.pending{background:#d1d5db}@keyframes pulse-dot{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.controls{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin:32px 0}.btn{border:none;border-radius:12px;box-shadow:0 4px 12px #0000001a;cursor:pointer;font-size:1.125rem;font-weight:600;letter-spacing:1px;min-height:44px;min-width:120px;padding:14px 32px;text-transform:uppercase;transition:all .2s ease}.btn,.btn-icon{align-items:center;display:flex;justify-content:center}.btn-icon{border-radius:50%;height:60px;min-width:60px;padding:0;width:60px}.btn-icon svg{display:block}.btn:hover{box-shadow:0 6px 16px #00000026;transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn:focus-visible{outline:3px solid #6366f1;outline-offset:3px}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.btn-secondary{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff}.btn-secondary:hover{background:linear-gradient(135deg,#d97706,#ea580c)}.btn-info{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff}.btn-info:hover{background:linear-gradient(135deg,#0891b2,#0e7490)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-large{font-size:1.25rem;min-width:200px;padding:18px 48px}.btn-large.btn-icon{height:80px;min-width:80px;padding:0;width:80px}.btn-large.btn-icon svg{height:40px;width:40px}.keyboard-hints{color:#6b7280;display:flex;font-size:.875rem;gap:24px;justify-content:center;margin-top:24px}.keyboard-hints span{background:#f3f4f6;border-radius:6px;font-family:Courier New,monospace;padding:6px 12px}.completion-screen{animation:fadeIn .5s ease;flex-direction:column;padding:32px 0}.completion-icon,.completion-screen{align-items:center;display:flex;justify-content:center}.completion-icon{animation:scaleIn .5s ease;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:50%;color:#10b981;font-size:5rem;height:120px;margin:0 auto 32px;width:120px}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.completion-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:1.75rem;font-weight:700;line-height:1.4;margin-bottom:24px}.completion-time{color:#6b7280;font-size:1.25rem;font-weight:500;margin-bottom:32px}@media (max-width:640px){.info-button{height:44px;left:16px;top:16px;width:44px}.info-button svg{height:22px;width:22px}.settings-button{height:44px;right:16px;top:16px;width:44px}.settings-button svg{height:22px;width:22px}.wake-lock-indicator{font-size:.75rem;gap:6px;height:44px;padding:6px 12px;right:72px;top:16px}.wake-lock-indicator svg{height:14px;width:14px}.timer-card{padding:32px 20px}.app-title{font-size:1.25rem}.timer-countdown{font-size:4rem}.btn,.timer-label{font-size:1rem}.btn{min-width:100px;padding:12px 24px}.btn-large{font-size:1.125rem;min-width:160px;padding:16px 36px}.controls{gap:12px}.keyboard-hints{flex-direction:column;font-size:.75rem;gap:8px}.completion-title{font-size:1.5rem}.completion-icon{font-size:4rem;height:100px;width:100px}}@media (max-width:380px){.timer-countdown{font-size:3rem}.completion-title{font-size:1.25rem}}@media (prefers-contrast:high){.timer-card{background:#fff}.btn,.timer-card{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.completion-icon,.completion-screen,.paused-indicator,.progress-dot.active,.timer-display.transitioning{animation:none}.btn:hover{transform:none}}.settings-modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-modal{animation:slideUp .3s ease;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0006;max-height:90vh;max-width:550px;overflow-y:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px 32px}.modal-header h2{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;transition:all .2s ease;width:32px}.close-button:hover{background:#f3f4f6;color:#1f2937}.modal-content{padding:32px}.upload-section{margin-bottom:32px}.upload-section h3{color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 16px}.file-upload-label{cursor:pointer;display:block}.file-input{display:none}.upload-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;box-shadow:0 4px 12px #6366f14d;color:#fff;display:inline-block;font-size:1rem;font-weight:600;padding:12px 32px;transition:all .2s ease}.upload-button:hover{box-shadow:0 6px 16px #6366f166;transform:translateY(-2px)}.hint{color:#6b7280;font-size:.875rem;margin:12px 0 0}.storage-info{color:#9ca3af;font-family:Courier New,monospace;font-size:.75rem;margin:8px 0 0}.divider{margin:32px 0;position:relative;text-align:center}.divider:before{background:#e5e7eb;content:"";height:1px;left:0;position:absolute;right:0;top:50%;z-index:0}.divider span{background:#fff;color:#9ca3af;font-size:.875rem;font-weight:600;padding:0 16px;position:relative;z-index:1}.preset-section h3{color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 16px}.preset-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.preset-item{background:#f9fafb;border:3px solid #0000;border-radius:12px;cursor:pointer;overflow:hidden;position:relative;transition:all .2s ease}.preset-item:hover{border-color:#6366f1;box-shadow:0 4px 12px #6366f133;transform:translateY(-2px)}.preset-item.selected{border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.preset-thumbnail{display:block;height:120px;object-fit:cover;width:100%}.preset-label{background:#fff;color:#374151;display:block;font-size:.875rem;font-weight:500;padding:8px;text-align:center}.selected-badge{align-items:center;background:#6366f1;border-radius:50%;box-shadow:0 2px 8px #0003;color:#fff;display:flex;font-size:1rem;font-weight:700;height:28px;justify-content:center;position:absolute;right:8px;top:8px;width:28px}.message{border-radius:8px;font-size:.875rem;line-height:1.5;margin-top:16px;padding:12px 16px}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.warning-message{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;padding:24px 32px}.reset-button{background:#f3f4f6;border:none;border-radius:10px;color:#374151;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;padding:12px 24px;transition:all .2s ease}.reset-button:hover{background:#e5e7eb}.reset-button:disabled{cursor:not-allowed;opacity:.5}.close-action-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;color:#fff;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;padding:12px 24px;transition:all .2s ease}.close-action-button:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.modal-credits{border-top:1px solid #f3f4f6;padding:12px 24px 20px;text-align:center}.modal-credits a{color:#9ca3af;font-size:.75rem;text-decoration:none;transition:color .2s ease}.modal-credits a:hover{color:#6366f1;text-decoration:underline}@media (max-width:768px){.settings-modal{border-radius:0;display:flex;flex-direction:column;height:100%;max-height:100vh;max-width:100%;width:100%}.modal-header{padding:20px}.modal-header h2{font-size:1.25rem}.modal-content{flex:1 1;overflow-y:auto;padding:24px 20px}.preset-grid{gap:12px;grid-template-columns:1fr}.preset-thumbnail{height:200px}.modal-actions{flex-direction:column;padding:16px 20px}.close-action-button,.reset-button{width:100%}}@media (max-width:480px){.preset-section h3,.upload-section h3{font-size:1rem}.upload-button{text-align:center;width:100%}.preset-thumbnail{height:180px}}.instructions-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.instructions-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow:auto;position:relative}.instructions-close-btn{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:12px;top:12px;transition:background .2s ease;width:36px;z-index:10}.instructions-close-btn:hover{background:#000c}.instructions-image{border-radius:12px;display:block;height:auto;width:100%}@media (max-width:640px){.instructions-overlay{padding:12px}.instructions-modal{border-radius:8px;max-width:100%}.instructions-close-btn{height:32px;right:8px;top:8px;width:32px}.instructions-image{border-radius:8px}}.mandala-container{margin:0 auto;max-width:750px;padding:24px 16px;width:100%}.mandala-title{color:#1f2937;font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin-bottom:4px;text-align:center}.mandala-progress{margin-bottom:12px}.mandala-tracker-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff40;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:20px;padding:20px 16px 16px}.mandala-svg{-webkit-tap-highlight-color:transparent;display:block;height:auto;margin:0 auto;max-width:100%;touch-action:manipulation}.mandala-petal{fill:#f3f4f6e6;stroke:#9ca3af;stroke-width:1.5;cursor:pointer;transition:all .25s ease}.mandala-petal:hover{fill:#e5e7eb}.mandala-petal.filled{fill:#a78bfa;stroke:#7c3aed}.mandala-petal.filled:hover{fill:#8b5cf6}.mandala-center-circle{fill:#f3f4f6e6;stroke:#9ca3af;stroke-width:2;cursor:pointer;transition:all .25s ease}.mandala-center-circle:hover{fill:#e5e7eb}.mandala-center-circle.filled{fill:#a78bfa;stroke:#7c3aed}.mandala-center-circle.filled:hover{fill:#8b5cf6}.mandala-day-number{font-size:10px}.mandala-center-text,.mandala-day-number{fill:#1f2937;text-anchor:middle;font-family:inherit;font-weight:700;pointer-events:none}.mandala-center-text{dominant-baseline:central;font-size:14px}.mandala-habit-name-display{fill:#6b7280;text-anchor:middle;font-family:inherit;font-size:11px;font-style:italic;pointer-events:none}.mandala-progress{color:#6b7280;font-size:1rem;margin-top:16px;text-align:center}.mandala-progress-number{color:#7c3aed;font-size:1.25rem;font-weight:700}.mandala-controls{display:flex;gap:12px;justify-content:center}.mandala-btn{background:#ffffffe6;border:2px solid #6366f166;border-radius:8px;color:#374151;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;letter-spacing:.3px;padding:10px 24px;transition:all .25s ease}@media (hover:hover){.mandala-btn:hover{background:#6366f1;border-color:#6366f1;box-shadow:0 4px 12px #6366f14d;color:#fff;transform:translateY(-2px)}}.mandala-btn:active{transform:translateY(0)}@media (max-width:640px){.mandala-container{padding:20px 12px}.mandala-title{font-size:1.25rem}.mandala-subtitle{font-size:.9rem}.mandala-habit-input input{font-size:.9rem;padding:8px 12px}.mandala-tracker-wrapper{padding:16px 12px}.mandala-day-number{font-size:8px}.mandala-center-text{font-size:12px}.mandala-habit-name-display{font-size:9px}.mandala-btn{font-size:.85rem;padding:8px 20px}}@media (max-width:380px){.mandala-day-number{font-size:7px}.mandala-center-text{font-size:11px}}@media (hover:none) and (pointer:coarse){.mandala-center-circle,.mandala-petal{touch-action:manipulation}.mandala-petal:active{fill:#c4b5fd}.mandala-petal.filled:active{fill:#7c3aed}.mandala-center-circle:active{fill:#c4b5fd}.mandala-center-circle.filled:active{fill:#7c3aed}}@media (prefers-reduced-motion:reduce){.mandala-btn,.mandala-center-circle,.mandala-petal{transition:none}.mandala-btn:hover{transform:none}}
/*# sourceMappingURL=main.ce8f9f97.css.map*/