*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #f8f9fc;--surface: #ffffff;--text: #1e293b;--text-secondary: #64748b;--border: #e2e8f0;--primary: #6366f1;--danger: #ef4444;--radius: 12px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;-webkit-tap-highlight-color:transparent}#root{min-height:100dvh;display:flex;flex-direction:column}.app{max-width:480px;width:100%;margin:0 auto;padding:16px 16px 0;flex:1;display:flex;flex-direction:column;overflow:hidden}.header{text-align:center;padding:24px 0 16px;flex-shrink:0}.logo{font-size:1.5rem;font-weight:800;color:var(--text)}.subtitle{color:var(--text-secondary);font-size:.875rem;margin-top:4px}.task-header{display:flex;align-items:center;gap:12px;text-align:left;padding:16px 0}.project-title,.page-title{font-size:1.25rem;font-weight:700}.btn-primary{background:var(--primary);color:#fff;border:none;padding:12px 24px;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-primary:active{opacity:.85}.btn-secondary{background:var(--border);color:var(--text);border:none;padding:12px 24px;border-radius:var(--radius);font-size:1rem;font-weight:500;cursor:pointer}.btn-back{background:none;border:none;font-size:1rem;color:var(--text-secondary);cursor:pointer;padding:8px 0;font-weight:500}.btn-icon{background:none;border:none;font-size:1rem;cursor:pointer;padding:4px 6px;border-radius:6px;transition:background .15s}.btn-icon:active{background:var(--border)}.add-project-btn{width:100%}.overall-progress,.task-progress{margin-bottom:20px;flex-shrink:0}.progress-label{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--text-secondary);margin-bottom:8px}.progress-pct{font-weight:700;color:var(--text)}.progress-bar{height:10px;background:var(--border);border-radius:99px;overflow:hidden}.progress-bar.small{height:6px}.progress-fill{height:100%;border-radius:99px;transition:width .3s ease}.overall-fill{background:linear-gradient(90deg,#6366f1,#a855f7)}.celebration-banner{text-align:center;padding:12px;border-radius:var(--radius);font-weight:600;font-size:1rem;margin:12px 0;background:linear-gradient(135deg,#ede9fe,#fce7f3);color:var(--primary);animation:celebrate .4s ease;flex-shrink:0}@keyframes celebrate{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.scrollable-area{flex:1;overflow-y:auto;min-height:0}.project-list{display:flex;flex-direction:column;gap:12px;padding-bottom:8px}.project-card{background:var(--surface);border-radius:var(--radius);padding:16px;border:1.5px solid var(--border);cursor:pointer;transition:transform .15s,box-shadow .15s}.project-card:active{transform:scale(.98)}.project-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.project-name{font-size:1.05rem;font-weight:700}.project-actions{display:flex;gap:4px}.project-meta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-secondary);margin-bottom:8px}.streak-badge{font-weight:600;font-size:.75rem}.new-project-form{background:var(--surface);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.input{width:100%;padding:12px 14px;border:2px solid var(--border);border-radius:10px;font-size:1rem;outline:none;transition:border-color .15s;background:var(--bg);color:var(--text)}.input:focus{border-color:var(--primary)}.task-textarea{resize:none;font-family:inherit;line-height:1.4;min-height:42px;max-height:120px;overflow-y:auto}.color-picker{display:flex;gap:10px;margin:14px 0;flex-wrap:wrap}.color-dot{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s}.color-dot.selected{border-color:var(--text);transform:scale(1.15)}.project-color-picker{margin:8px 0 4px;gap:8px}.project-color-picker .color-dot{width:26px;height:26px}.form-actions{display:flex;gap:10px;margin-top:12px}.form-actions .btn-primary,.form-actions .btn-secondary{flex:1}.task-list{display:flex;flex-direction:column;gap:4px;padding-bottom:8px}.task-item{display:flex;align-items:flex-start;gap:10px;padding:14px 12px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;transition:opacity .2s,transform .15s,box-shadow .15s;cursor:default}.task-item.dragging{opacity:.4;transform:scale(.97)}.drag-handle{cursor:grab;color:var(--text-secondary);font-size:1.1rem;line-height:1;-webkit-user-select:none;user-select:none;opacity:.45;flex-shrink:0;letter-spacing:-1px;padding-top:2px;touch-action:none}.drag-handle:active{cursor:grabbing}.task-item:hover .drag-handle{opacity:.8}@media (hover: none){.drag-handle{opacity:.6}}.task-item.done{opacity:.55}.task-item.done .task-name{text-decoration:line-through}.task-check{display:flex;align-items:center;cursor:pointer;flex-shrink:0;padding-top:1px}.task-check input{display:none}.checkmark{width:24px;height:24px;border-radius:7px;border:2.5px solid;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;transition:background .15s,transform .15s}.task-check input:checked+.checkmark{transform:scale(1.1)}.task-name{flex:1;font-size:.95rem;cursor:pointer;padding:2px 0;word-break:break-word;white-space:pre-wrap}.btn-delete-task{opacity:0;transition:opacity .15s;font-size:.85rem;flex-shrink:0;margin-left:auto}.task-item:hover .btn-delete-task{opacity:1}@media (pointer: coarse){.btn-delete-task{opacity:.6}}.edit-form{flex:1}.edit-input{width:100%;padding:6px 10px;border:2px solid var(--primary);border-radius:8px;font-size:.95rem;outline:none;background:var(--bg);color:var(--text);font-family:inherit;line-height:1.4}.bottom-bar{flex-shrink:0;padding:12px 0;padding-bottom:max(12px,env(safe-area-inset-bottom));background:var(--bg);border-top:1px solid var(--border)}.add-task-bar{display:flex;gap:10px}.btn-add-task{padding:12px 20px;flex-shrink:0;align-self:flex-end}.btn-about{display:inline;background:none;border:none;font-size:.85rem;cursor:pointer;opacity:.4;transition:opacity .15s;padding:0;margin-left:2px;vertical-align:middle;color:var(--text-secondary)}.btn-about:hover{opacity:1}.about-header{text-align:center;position:relative}.about-header .btn-back{position:absolute;left:0}.about-header .page-title{width:100%;margin-top:16px}.about-content{padding:8px 0 24px}.about-logo{font-size:1.5rem;text-align:center;margin-bottom:4px}.about-tagline{text-align:center;color:var(--text-secondary);font-size:.95rem;margin-bottom:24px}.about-section{margin-bottom:20px}.about-section h3{font-size:1rem;margin-bottom:8px;color:var(--text)}.about-section p{font-size:.9rem;line-height:1.6;color:var(--text-secondary)}.about-list{list-style:none;padding:0;margin:0}.about-list li{font-size:.9rem;line-height:1.6;color:var(--text-secondary);padding-left:16px;position:relative}.about-list li:before{content:"•";position:absolute;left:0;color:var(--primary)}.about-links{display:flex;flex-direction:column;gap:10px;margin-top:24px}.about-link{display:block;text-align:center;padding:12px;border-radius:12px;background:var(--card);border:1px solid var(--border);color:var(--primary);text-decoration:none;font-size:.95rem;font-weight:600;transition:background .15s}.about-link:hover{background:var(--border)}.landing-content{padding:32px 8px 16px}.landing-hero{text-align:center;margin-bottom:36px}.landing-icon{width:72px;height:72px;margin-bottom:12px}.landing-title{font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:6px}.landing-subtitle{font-size:.95rem;color:var(--text-secondary)}.landing-features{display:flex;flex-direction:column;gap:16px}.landing-feature{display:flex;align-items:flex-start;gap:14px;padding:14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius)}.landing-feature-icon{font-size:1.5rem;flex-shrink:0;line-height:1;padding-top:2px}.landing-feature strong{display:block;font-size:.95rem;margin-bottom:2px}.landing-feature p{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.landing-feature-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.landing-feature-clickable:active{transform:scale(.97)}.login-content{text-align:center;padding:48px 16px}.login-icon{width:64px;height:64px;margin-bottom:16px}.login-title{font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:8px}.login-subtitle{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin-bottom:32px}.login-error{color:var(--danger);font-size:.85rem;margin-bottom:16px}.login-google-btn{width:100%;padding:14px;font-size:1.05rem;border-radius:14px}.login-google-btn:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:20px;padding:32px 24px;max-width:340px;width:100%;text-align:center;animation:modalSlideUp .35s ease;box-shadow:0 20px 60px #00000040}@keyframes modalSlideUp{0%{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.new-day-emoji{font-size:3.5rem;margin-bottom:12px;animation:emojiPop .5s ease .2s both}@keyframes emojiPop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.new-day-title{font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:8px}.new-day-subtitle{font-size:.95rem;color:var(--text-secondary);line-height:1.5;margin-bottom:24px}.new-day-btn{width:100%;padding:14px;font-size:1.05rem;border-radius:14px;background:linear-gradient(135deg,#6366f1,#a855f7)}.btn-notif-toggle{display:block;width:100%;margin-top:12px;padding:12px 20px;border-radius:var(--radius);border:2px solid var(--border);background:var(--bg);color:var(--text-secondary);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-notif-toggle:active{transform:scale(.97)}.btn-notif-toggle.active{border-color:#10b981;background:#ecfdf5;color:#059669}.install-banner{display:flex;align-items:center;gap:12px;padding:14px;margin-bottom:16px;background:linear-gradient(135deg,#ede9fe,#e0e7ff);border:1.5px solid var(--primary);border-radius:var(--radius);animation:celebrate .4s ease}.install-banner-text{flex:1}.install-banner-text strong{display:block;font-size:.95rem;color:var(--text)}.install-banner-text p{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.install-banner-btn{padding:8px 16px;font-size:.85rem;flex-shrink:0}.loading-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.loading-icon{width:72px;height:72px;animation:emojiPop .5s ease both}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-secondary);padding:48px 16px;font-size:.95rem;line-height:1.6}@media (min-width: 600px){body{display:flex;align-items:center;justify-content:center;background:#e2e8f0}#root{width:390px;min-height:750px;max-height:85vh;overflow:hidden;background:var(--bg);border-radius:40px;border:8px solid #1e293b;box-shadow:0 0 0 2px #475569,0 20px 60px #0000004d;position:relative}#root:before{content:"";position:sticky;top:0;left:50%;transform:translate(-50%);width:120px;height:28px;background:#1e293b;border-radius:0 0 18px 18px;display:block;z-index:10;margin:0 auto}.app{padding:8px 20px 0}.header{padding:12px 0 16px}.logo{font-size:1.35rem}.bottom-bar{padding:12px 0 20px}}
