:root{--color-primary:#6200ea;--color-primary-dark:#4b00b5;--color-primary-light:#bb86fc;--color-secondary:#1976d2;--color-accent:#f57c00;--color-success:#2e7d32;--color-warning:#f9a825;--color-danger:#d32f2f;--color-bg:#f5f7fa;--color-surface:#fff;--color-surface-muted:#f5f5f5;--color-surface-elevated:#fff;--color-border:#e0e0e0;--color-border-strong:#c7c7c7;--color-text-primary:#1f2933;--color-text-secondary:#5f6c80;--color-text-muted:#97a0b3;--color-text-inverse:#fff;--color-surface-success-light:#dcfce7;--color-surface-danger-light:#fef2f2;--color-surface-warning-light:#fef9c3;--color-surface-info-light:#f0f9ff;--color-text-success:#065f46;--color-text-danger:#991b1b;--color-text-warning:#92400e;--color-backdrop:#00000080;--color-overlay:#fffffff2;--color-input-bg:#fff;--color-input-border:#e0e6ed;--color-input-disabled-bg:#f8f9fa;--font-family-base:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-family-mono:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--card-padding:24px;--card-gap:20px;--shadow-soft:0 1px 2px #0f172a14;--shadow-card:0 10px 25px #0f172a14;--shadow-elevated:0 20px 45px #0f172a1f;--gradient-brand:linear-gradient(135deg,#6366f1,#8b5cf6 50%,#d946ef);--gradient-surface:linear-gradient(135deg,#f8fafc,#e2e8f0)}[data-theme=dark]{--color-primary:#bb86fc;--color-primary-dark:#9b59f7;--color-primary-light:#d4b5ff;--color-secondary:#64b5f6;--color-accent:#ffb74d;--color-success:#66bb6a;--color-warning:#ffd54f;--color-danger:#ef5350;--color-bg:#121218;--color-surface:#1e1e2e;--color-surface-muted:#272736;--color-surface-elevated:#2a2a3e;--color-border:#3a3a4e;--color-border-strong:#505068;--color-text-primary:#e4e4ed;--color-text-secondary:#a1a1b5;--color-text-muted:#6b6b80;--color-text-inverse:#1e1e2e;--color-surface-success-light:#1a2e1d;--color-surface-danger-light:#2e1a1a;--color-surface-warning-light:#2e2c1a;--color-surface-info-light:#1a222e;--color-text-success:#86efac;--color-text-danger:#fca5a5;--color-text-warning:#fcd34d;--color-backdrop:#000000b3;--color-overlay:#1e1e2ef2;--color-input-bg:#272736;--color-input-border:#3a3a4e;--color-input-disabled-bg:#1e1e2e;--shadow-soft:0 1px 2px #0000004d;--shadow-card:0 10px 25px #0000004d;--shadow-elevated:0 20px 45px #0006;--gradient-brand:linear-gradient(135deg,#7c3aed,#a855f7 50%,#d946ef);--gradient-surface:linear-gradient(135deg,#1a1a28,#121218)}@media (max-width:768px){:root{--spacing-md:14px;--spacing-lg:20px;--spacing-xl:24px;--card-padding:18px;--card-gap:16px}}@media (max-width:480px){:root{--spacing-sm:6px;--spacing-md:12px;--spacing-lg:16px;--spacing-xl:20px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--card-padding:14px;--card-gap:12px}}*{box-sizing:border-box}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg);color:var(--color-text-primary);font-family:var(--font-family-base);margin:0;min-height:100%;padding:0;scroll-behavior:smooth;transition:background-color .3s ease,color .3s ease}#root,body,html{max-width:100vw;overflow-x:hidden;width:100%}#root{min-height:100vh}img,svg{display:block;max-width:100%}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit}.visually-hidden{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.text-muted{color:var(--color-text-muted)}.surface-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-soft)}.error-message{background:#d32f2f14;border:1px solid #d32f2f59;color:var(--color-danger);font-size:.95rem;line-height:1.4;padding:12px 16px}.retry-btn{background:var(--color-danger);box-shadow:0 6px 16px #d32f2f40;font-weight:600;transition:transform .2s ease,box-shadow .2s ease}.retry-btn:hover{box-shadow:0 10px 22px #d32f2f4d;transform:translateY(-1px)}.empty-state{border:1px solid #6366f11f;box-shadow:var(--shadow-card);padding:48px 32px}.empty-icon{color:var(--color-primary);font-size:3.5rem;margin-bottom:16px;opacity:.75}.app-loading,.loading{align-items:center;background:var(--gradient-surface);display:flex;justify-content:center;min-height:100vh}.loading-container{background:var(--color-surface);border-radius:8px;box-shadow:var(--shadow-card);padding:32px 40px;text-align:center}.loading-logo{color:var(--color-primary);font-size:1.5rem;font-weight:700;margin-bottom:16px}.loading-text{color:var(--color-text-secondary);font-size:.95rem}@media (max-width:768px){body{font-size:.95rem}.completion-note-response,.empty-state,.goal-card,.goal-card-modern,.info-card,.loading-container,.modal-body,.modal-content,.responsive-card,.subgoal-card,.surface-card,.todo-detail-hero,.todo-detail-hero__actions,.todo-edit-form,.todo-section,.todo-stats-section,.todo-timeline-section,.todo-view-card{border-radius:var(--radius-md);padding:var(--card-padding)!important}.empty-state,.goal-card,.goal-card-modern,.subgoal-card,.todo-detail-hero,.todo-section{margin-bottom:var(--spacing-md)}.action-btn,.action-button,.completion-btn,.hero-action-btn{gap:6px;min-height:38px;padding:8px 12px}.cards-grid,.goal-card-list,.goal-grid,.responsive-grid,.subgoal-card-list,.todo-card-list{gap:var(--card-gap);grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.todo-action-bar{left:20px;right:20px;width:calc(100% - 40px)}.goal-title,.section-label,.todo-detail-title{font-size:1.1rem}}@media (max-width:480px){body{font-size:.9rem}.completion-note-response,.empty-state,.goal-card,.goal-card-modern,.info-card,.loading-container,.modal-body,.modal-content,.responsive-card,.subgoal-card,.surface-card,.todo-detail-hero,.todo-edit-form,.todo-section,.todo-stats-section,.todo-timeline-section,.todo-view-card{border-radius:var(--radius-md);box-shadow:var(--shadow-soft);padding:calc(var(--card-padding) - 2px)!important}.action-button,.completion-btn,.hero-action-btn{width:100%}.goal-title,.todo-detail-title{font-size:1rem}.todo-action-bar{bottom:12px;left:16px;right:16px;width:calc(100% - 32px)}.cards-grid,.goal-card-list,.goal-grid,.responsive-grid,.subgoal-card-list,.todo-card-list{grid-template-columns:1fr}}code{font-family:var(--font-family-mono)}.loading-container{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;padding:20px;width:100%}.loading-container--fullpage{min-height:60vh;padding:60px 20px}.loading-spinner{margin:0 auto 16px}.loading-spinner,.loading-spinner-2{animation:loading-spin 1s linear infinite;border-radius:50%;display:block}.loading-spinner--small{border:2px solid #0000;height:20px;margin:0 auto 8px;width:20px}.loading-spinner--medium{border:4px solid #0000;height:40px;margin:0 auto 16px;width:40px}.loading-spinner--large{border:6px solid #0000;height:60px;margin:0 auto 20px;width:60px}.loading-spinner--primary{border-color:#667eea #667eea4d #667eea4d}.loading-spinner--secondary{border-color:var(--color-surface-muted);border-top-color:var(--color-text-secondary)}.loading-spinner--white{border-color:#fff #ffffff4d #ffffff4d}.loading-message{color:var(--color-text-secondary);font-size:16px;margin:0;text-align:center}.loading-container--fullpage .loading-message{color:var(--color-text-secondary);font-size:18px}@keyframes loading-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.btn-loading{align-items:center;display:inline-flex;gap:8px}.btn-loading .loading-container{display:contents}.btn-loading .loading-spinner{margin:0}.btn-loading .loading-spinner--small{border:2px solid #0000;height:16px;width:16px}@media (max-width:768px){.loading-container{padding:16px}.loading-container--fullpage{min-height:50vh;padding:40px 16px}.loading-message{font-size:14px}.loading-container--fullpage .loading-message{font-size:16px}}.loading-inline{align-items:center;display:inline-flex;gap:8px;padding:0}.loading-overlay{background:var(--color-overlay);bottom:0;left:0;position:absolute;right:0;top:0;z-index:10}.loading-modal{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:var(--color-backdrop);bottom:0;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-page{align-items:center;display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;justify-content:center;min-height:100vh}.loading-page--default{background:var(--color-surface-muted)}.loading-page--gradient{background:linear-gradient(135deg,var(--color-surface-muted) 0,var(--color-border) 100%)}.loading-page--transparent{background:#0000}.loading-page-content{align-items:center;background:var(--color-surface);border-radius:8px;box-shadow:0 10px 30px #0000001a;display:flex;flex-direction:column;justify-content:center;max-width:400px;min-height:300px;padding:40px;text-align:center;width:90%}.loading-page--transparent .loading-page-content{background:#0000;box-shadow:none;padding:20px}.loading-logo{align-items:center;animation:loading-logo-pulse 2s ease-in-out infinite;display:flex;flex-direction:column;justify-content:center;margin-bottom:30px}.logo-icon{display:block;font-size:3rem;margin-bottom:16px}.loading-logo h2{color:var(--color-text-primary);font-size:1.5rem;font-weight:600;letter-spacing:.5px;margin:0}@keyframes loading-logo-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@media (max-width:768px){.loading-page-content{max-width:320px;padding:30px 20px}.logo-icon{font-size:2.5rem}.loading-logo h2{font-size:1.3rem}}.confirm-dialog-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:var(--color-backdrop);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.confirm-dialog{animation:confirmDialogAppear .3s ease-out;background:var(--color-surface);border-radius:8px;box-shadow:0 20px 40px #0000004d;max-width:420px;overflow:hidden;padding:0;width:90%}@keyframes confirmDialogAppear{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-dialog-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:12px;padding:24px 24px 16px}.confirm-dialog-icon{flex-shrink:0;font-size:1.8rem}.confirm-dialog-title{color:var(--color-text-primary);font-size:1.3rem;font-weight:600;margin:0}.confirm-dialog-danger .confirm-dialog-title{color:#dc3545}.confirm-dialog-warning .confirm-dialog-title{color:#ffc107}.confirm-dialog-info .confirm-dialog-title{color:#17a2b8}.confirm-dialog-body{padding:16px 24px 24px}.confirm-dialog-message{color:var(--color-text-secondary);font-size:1rem;line-height:1.6;margin:0}.confirm-dialog-actions{background:var(--color-surface);border-radius:0 0 8px 8px;border-top:1px solid #f0f0f0;display:flex;gap:0;overflow:hidden;padding:0}.confirm-dialog-actions button{align-items:center;border:none;border-radius:0;cursor:pointer;display:flex;flex:1 1;font-size:.85rem;font-weight:500;justify-content:center;min-height:46px;min-width:80px;padding:.625rem 1rem;transition:all .2s ease}.btn-confirm{align-items:center;display:inline-flex;font-weight:600;gap:6px;justify-content:center}.btn-confirm-danger{background:#fef2f2;color:#dc2626}.btn-confirm-danger:hover{background:#fee2e2}.btn-confirm-warning{background:#fffbeb;color:#d97706}.btn-confirm-warning:hover{background:#fef3c7}.btn-confirm-info{background:#eff6ff;color:#1d4ed8}.btn-confirm-info:hover{background:#dbeafe}.btn-cancel:disabled,.btn-confirm:disabled{cursor:not-allowed;opacity:.6}.btn-confirm .loading-container{display:contents}.btn-confirm .loading-spinner{border-width:2px;height:14px;margin:0;width:14px}@media (max-width:768px){.confirm-dialog{margin:20px;max-width:none;width:calc(100% - 40px)}.confirm-dialog-header{padding:20px 20px 16px}.confirm-dialog-body{padding:16px 20px 20px}.confirm-dialog-actions{border-radius:0 0 8px 8px;flex-direction:column;overflow:hidden}.confirm-dialog-actions button{font-size:.9rem;padding:12px 16px;width:100%}.btn-cancel{border-bottom:1px solid var(--color-border);border-right:none}.btn-confirm{order:-1}}.subgoal-card{background:var(--color-surface);border:1px solid var(--color-border);display:flex;flex-direction:column;margin-bottom:16px;width:100%}.subgoal-card:hover{box-shadow:0 4px 16px #0000001f}.subgoal-card.clickable:hover{border-color:#007bff;border-color:var(--primary-color,#007bff)}.subgoal-card.completed{background:linear-gradient(135deg,#f8fff8,#e8f5e8);border-color:#28a745;border-color:var(--success-color,#28a745)}.subgoal-card-header{gap:16px;width:100%}.subgoal-card-title{font-size:1.2rem;min-width:0;word-break:break-word}.subgoal-card.completed .subgoal-card-title{color:#28a745;color:var(--success-color,#28a745);text-decoration:line-through}.subgoal-card-actions{align-items:center;gap:8px}.subgoal-action-btn{background:#0000;font-size:.9rem;min-height:36px;padding:8px 12px;white-space:nowrap}.subgoal-action-btn:hover{background:var(--color-surface-muted)}.manage-todos-btn,.subgoal-action-btn:hover{border-color:#007bff;border-color:var(--primary-color,#007bff)}.manage-todos-btn{color:#007bff;color:var(--primary-color,#007bff)}.manage-todos-btn:hover{background:#007bff;background:var(--primary-color,#007bff);color:#fff}.completion-btn{border-color:var(--warning-color,#ffc107);color:#ffc107;color:var(--warning-color,#ffc107)}.completion-btn.completed{border-color:var(--success-color,#28a745);color:#28a745;color:var(--success-color,#28a745)}.completion-btn:hover{background:#ffc107;background:var(--warning-color,#ffc107);color:#fff}.completion-btn.completed:hover{background:#28a745;background:var(--success-color,#28a745);color:#fff}.edit-btn{background:#409cff!important;background:var(--primary-color,#409cff)!important;border-color:#007bff;border-color:var(--primary-color,#007bff);color:#007bff;color:var(--primary-color,#007bff);justify-content:center;min-width:40px}.edit-btn:hover{background:#007bff!important;background:var(--primary-color,#007bff)!important;color:#fff}.todo-count{font-weight:600}.subgoal-icon{font-size:1rem}.completion-text{font-size:.85rem;font-weight:500}.subgoal-card-content{align-items:flex-start;display:flex;flex-direction:row;gap:20px;width:100%}.subgoal-card-info{flex:1 1;min-width:0;width:100%}.subgoal-card-description{margin:8px 0 16px;word-break:break-word}.subgoal-card-progress{padding-top:8px}.progress-info,.sg-progress-info{align-items:center;display:flex;justify-content:flex-start;margin-bottom:8px}.progress-label,.sg-progress-label{color:var(--color-text-secondary);font-size:.85rem;font-weight:500}.progress-percentage,.sg-progress-percentage{background:var(--color-surface);color:var(--color-text-secondary);display:block;font-size:.75rem;font-weight:600;padding:2px 6px;text-align:right;width:100%}.progress-text,.sg-progress-text{color:var(--color-text-secondary);display:block;font-size:.85rem;margin-top:4px}.progress-bar,.sg-progress-bar{background:var(--color-border);border-radius:8px;height:8px;margin-bottom:8px;overflow:hidden;position:relative;width:100%}.progress-fill,.sg-progress-fill{border-radius:8px;height:100%;transition:width .3s ease}.progress-fill,.sg-progress-fill,.subgoal-card.completed .progress-fill,.subgoal-card.completed .sg-progress-fill{background:linear-gradient(90deg,#28a745,#20c997)}.subgoal-todos-summary{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-top:12px}.todos-stats{flex-wrap:nowrap}.todos-stats .stat{background:var(--color-surface-muted);border-radius:8px;font-size:.85rem;padding:4px 8px;white-space:nowrap}.subgoal-card .stat-icon{font-size:24px!important;height:24px!important;width:24px!important}.subgoal-card-meta{align-items:center;display:flex;flex-shrink:0;gap:16px;min-width:200px}@media (max-width:1024px){.subgoal-card-content{flex-direction:column;gap:16px}.subgoal-card-meta{min-width:auto;width:100%}}@media (max-width:768px){.subgoal-card{margin-bottom:0;padding:16px}.subgoal-card-header{align-items:flex-start;flex-direction:column;gap:12px}.subgoal-card-actions{grid-gap:8px;align-items:stretch;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);justify-content:normal;width:100%}.subgoal-action-btn{border-radius:8px;flex:0 0 auto;justify-content:center;padding:10px 12px}.completion-text{display:none}.subgoal-card-title{font-size:1.1rem;margin-bottom:2px}.subgoal-card-content{gap:6px}.todos-stats{justify-content:space-between;width:100%}}@media (max-width:480px){.subgoal-card-title{font-size:1rem}.subgoal-action-btn{font-size:.8rem;padding:6px 8px}.manage-todos-btn .todo-count{display:none}.todo-count{font-size:.75rem}.todos-stats{gap:8px}.todos-stats .stat{font-size:.8rem;padding:3px 6px}}.modal-backdrop{align-items:center;animation:modalBackdropFadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}@keyframes modalBackdropFadeIn{0%{opacity:0}to{opacity:1}}.add-todo-modal{animation:modalSlideIn .3s ease-out;background:var(--color-surface);border-radius:8px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:650px;overflow:hidden;width:100%}.modal-header h3,.modal-title{align-items:center;color:#fff;display:flex;font-size:1.3rem;font-weight:600;gap:8px;margin:0}.modal-icon{font-size:1.2rem}.modal-close-btn:hover:not(:disabled){background:#ffffff4d;color:#fff}.modal-close-btn:disabled{cursor:not-allowed;opacity:.5}.modal-form{max-height:calc(90vh - 120px);overflow-y:auto}.form-group:last-of-type{margin-bottom:24px}.form-group label{color:var(--color-text-primary);font-size:.9rem;font-weight:500;margin-bottom:8px}.description-input-group{position:relative}.description-input-wrapper{display:flex;flex-direction:column;gap:12px}.description-input-wrapper .form-textarea,.description-input-wrapper .re-container{width:100%}.description-input-wrapper .re-content{max-height:250px;min-height:100px}.ai-button-container{align-items:flex-end;display:flex;flex-direction:column;gap:6px}.ai-suggest-button{align-items:center;align-self:flex-end;background:linear-gradient(135deg,#8b9bff,#9ca8ff);border:none;border-radius:8px;box-shadow:0 3px 12px #8b9bff33;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:6px;height:36px;justify-content:center;min-width:140px;overflow:hidden;padding:8px 16px;position:relative;transition:all .3s ease}.ai-suggest-button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.ai-suggest-button:hover:not(:disabled):before{left:100%}.ai-suggest-button:hover:not(:disabled){box-shadow:0 6px 20px #8b9bff59;transform:translateY(-1px)}.ai-suggest-button:active:not(:disabled){transform:translateY(0)}.ai-suggest-button:disabled{background:linear-gradient(135deg,var(--color-border) 0,var(--color-border) 100%);box-shadow:0 1px 6px #00000014;color:var(--color-text-secondary);cursor:not-allowed;transform:none}.ai-suggest-button .ai-icon{animation:bounce 3s infinite;font-size:1rem}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-2px)}60%{transform:translateY(-1px)}}.ai-suggest-button:disabled .ai-icon{animation:none}.ai-suggest-button .button-text{display:block;font-weight:600;letter-spacing:.3px}.ai-error-message{align-items:center;animation:slideIn .3s ease-out;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:8px;color:#dc2626;display:flex;font-size:.85rem;gap:8px;margin-top:8px;padding:12px 16px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.ai-error-message:before{content:"⚠️";font-size:1rem}.ai-helper-text{align-items:center;color:var(--color-text-secondary);display:flex;font-size:.75rem;font-style:italic;gap:4px;text-align:right}.ai-helper-text:before{content:"💡";font-size:.8rem}.form-input,.form-select,.form-textarea{background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:8px;font-family:inherit;font-size:.95rem;padding:12px 16px;transition:all .2s ease;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--color-surface-muted);color:var(--color-text-secondary);cursor:not-allowed}.form-textarea{line-height:1.5;min-height:80px}.form-select{cursor:pointer}.form-select:disabled{cursor:not-allowed}.modal-actions{border-top:1px solid var(--color-border);gap:12px;justify-content:flex-end;padding-top:16px}.action-buttons-group{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 1px 3px #0000000f;display:flex;overflow:hidden}.add-todo-modal .action-buttons-group .action-button{align-items:center;border:none;border-radius:0;border-right:1px solid var(--color-border);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.375rem;justify-content:center;margin:0;min-width:90px;padding:.625rem 1rem;transition:all .2s ease}.add-todo-modal .action-buttons-group .action-button:last-child{border-right:none}.add-todo-modal .action-buttons-group .action-button:hover{background:var(--color-surface-muted);transform:none}.add-todo-modal .action-buttons-group .action-button:disabled{background:var(--color-surface-muted)!important;color:var(--color-text-secondary)!important;cursor:not-allowed;opacity:.6}.add-todo-modal .action-buttons-group .cancel-button{background:#fef2f2;border-color:#fecaca;color:#dc2626;flex:1 1}.add-todo-modal .action-buttons-group .cancel-button:hover{background:#fee2e2}.add-todo-modal .action-buttons-group .submit-button{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8;flex:1 1}.add-todo-modal .action-buttons-group .submit-button:hover:not(:disabled){background:#dbeafe}.add-todo-modal .action-buttons-group .submit-button:disabled{background:var(--color-surface-muted)!important;color:var(--color-text-secondary)!important}.add-todo-modal .cancel-button,.add-todo-modal .submit-button{align-items:center;border-radius:8px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;min-width:90px;padding:8px 20px;transition:all .2s ease}.add-todo-modal .cancel-button:not(.action-button){background:var(--color-surface-muted);border:1px solid var(--color-border);color:var(--color-text-secondary)}.add-todo-modal .cancel-button:not(.action-button):hover:not(:disabled){background:var(--color-border);color:var(--color-text-primary)}.add-todo-modal .submit-button:not(.action-button){background:linear-gradient(135deg,#667eea,#764ba2);border:1px solid #667eea;color:#fff}.add-todo-modal .submit-button:not(.action-button):hover:not(:disabled){box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.add-todo-modal .submit-button:not(.action-button):disabled{background:var(--color-border);border-color:var(--color-border);box-shadow:none;color:var(--color-text-muted);cursor:not-allowed;transform:none}.add-todo-modal .action-button .loading-container,.add-todo-modal .submit-button .loading-container{display:contents}.add-todo-modal .action-button .loading-spinner,.add-todo-modal .submit-button .loading-spinner{border-width:2px;height:14px;margin:0;width:14px}.add-icon{font-size:1.1rem;font-weight:700}.form-select option[value=high]{color:#dc3545}.form-select option[value=medium]{color:#ffc107}.form-select option[value=low]{color:#28a745}@media (max-width:768px){.modal-backdrop{align-items:center;padding:16px}.add-todo-modal{border-radius:12px;margin:0;max-height:85vh;max-width:500px;width:calc(100% - 32px)}.modal-header{border-radius:12px 12px 0 0;padding:18px 18px 14px}.modal-header h3{font-size:1.15rem}.modal-icon{font-size:1.1rem}.modal-close-btn{font-size:14px;height:30px;width:30px}.modal-form{max-height:calc(85vh - 70px);padding:18px}.form-group{margin-bottom:16px}.form-group:last-of-type{margin-bottom:20px}.form-group label{font-size:.85rem;margin-bottom:6px}.form-input,.form-select,.form-textarea{border-radius:10px;font-size:.9rem;padding:11px 14px}.form-textarea{min-height:70px}.modal-actions{padding-top:14px}.action-buttons-group{border-radius:8px;flex-direction:column;gap:0;overflow:hidden;width:100%}.add-todo-modal .action-buttons-group .action-button{border-bottom:1px solid var(--color-border);border-radius:0;border-right:none;font-size:.9rem;gap:8px;min-width:auto;padding:14px 16px;width:100%}.add-todo-modal .action-buttons-group .action-button:last-child{border-bottom:none}.add-todo-modal .action-buttons-group .submit-button{order:1}.add-todo-modal .action-buttons-group .cancel-button{order:2}.description-input-wrapper{flex-direction:column;gap:10px}.ai-button-container{align-items:stretch;width:100%}.ai-suggest-button{align-self:stretch;border-radius:10px;font-size:.9rem;height:42px;min-width:auto;width:100%}.ai-helper-text{font-size:.7rem;text-align:center}.ai-error-message{border-radius:10px;font-size:.8rem;padding:10px 12px}}@media (max-width:480px){.modal-backdrop{padding:12px}.add-todo-modal{border-radius:12px;max-height:90vh;width:calc(100% - 24px)}.modal-header{border-radius:12px 12px 0 0;padding:16px 16px 12px}.modal-header h3{font-size:1.1rem}.modal-form{max-height:calc(90vh - 60px);padding:16px}.form-group{margin-bottom:14px}.form-input,.form-select,.form-textarea{font-size:.875rem;padding:10px 12px}.add-todo-modal .action-buttons-group .action-button{font-size:.85rem;padding:12px 14px}.ai-suggest-button{font-size:.85rem;height:40px}}.ai-preview-modal{animation:modalSlideIn .3s ease-out;background:var(--color-surface);border-radius:8px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:100%}.ai-preview-modal .modal-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid var(--color-border);color:#fff;flex-shrink:0;padding:24px 24px 16px}.ai-preview-modal .modal-header h3{align-items:center;display:flex;font-size:1.3rem;font-weight:600;gap:8px;margin:0}.ai-preview-modal .modal-close-btn{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.ai-preview-modal .modal-close-btn:hover:not(:disabled){background:#ffffff4d}.ai-preview-modal .modal-close-btn:disabled{cursor:not-allowed;opacity:.5}.ai-preview-modal .ai-modal-content{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:scroll;padding:20px!important}.loading-container-2{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;min-height:250px;padding:40px 20px;text-align:center}.loading-message{color:var(--color-text-primary);font-size:1.1rem;font-weight:500;margin:0 0 8px}.loading-submessage{color:var(--color-text-secondary);font-size:.9rem;margin:0}.original-message{background:var(--color-surface-muted);border-left:4px solid #667eea;border-radius:8px;margin-bottom:24px;padding:16px}.original-message label{color:#4b5563;display:block;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.message-content{color:#1f2937;font-size:.95rem;font-style:italic;line-height:1.5}.ai-suggestion{flex:1 1;margin-bottom:20px}.ai-content-wrapper{display:flex;flex:1 1;flex-direction:column}.suggestion-section{margin-bottom:20px}.suggestion-section:last-child{margin-bottom:0}.suggestion-section label{color:#4b5563;display:block;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.suggestion-title{background:#eff6ff;border-left:4px solid #3b82f6;border-radius:8px;color:#1f2937;font-size:1.1rem;font-weight:600;padding:12px 16px}.suggestion-description{background:#f0f9ff;border-left:4px solid #0ea5e9;border-radius:8px;padding:16px}.description-line{color:#1f2937;font-size:.95rem;line-height:1.6;margin-bottom:8px}.description-line:last-child{margin-bottom:0}.description-line:empty{margin-bottom:4px}.ai-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:flex;font-size:.8rem;font-weight:500;gap:6px;justify-content:center;margin-left:auto;margin-right:auto;margin-top:16px;padding:8px 16px;width:-webkit-fit-content;width:fit-content}.ai-icon{font-size:.9rem}.ai-preview-modal .modal-actions{border-top:1px solid #f0f2f5;flex-shrink:0;margin-top:16px;padding:16px 24px 24px}.ai-preview-modal .action-buttons-group,.ai-preview-modal .action-buttons-group-2{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 1px 3px #0000000f;display:flex;overflow:hidden}.ai-preview-modal .action-button{align-items:center;border:none;border-radius:8px;border-right:1px solid var(--color-border);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.375rem;justify-content:center;margin:0;min-width:90px;padding:.625rem 1rem;transition:all .2s ease}.ai-preview-modal .action-button:last-child{border-right:none}.ai-preview-modal .action-button:hover{background:var(--color-surface-muted)}.ai-preview-modal .cancel-button{background:#fef2f2;border-color:#fecaca;color:#dc2626;flex:1 1;font-size:.85rem;min-width:90px;padding:.625rem 1rem}.ai-preview-modal .cancel-button:hover{background:#fee2e2}.ai-preview-modal .accept-button{background:#f0f9ff;border-color:#bae6fd;color:#0369a1;flex:1 1;font-size:.85rem;min-width:90px;padding:.625rem 1rem}.ai-preview-modal .accept-button:hover{background:#e0f2fe}@media (max-width:768px){.ai-preview-modal{margin:0 16px;max-width:none;width:100%}.ai-preview-modal .ai-modal-content{padding:20px}.ai-preview-modal .modal-actions{padding:16px 20px 20px}.ai-preview-modal .action-buttons-group{border-radius:8px;flex-direction:column;overflow:hidden}.ai-preview-modal .action-button{border-bottom:1px solid var(--color-border);border-radius:0;border-right:none;font-size:.9rem;min-width:auto;padding:12px 16px;width:100%}.ai-preview-modal .action-button:last-child{border-bottom:none}.ai-preview-modal .accept-button{order:-1}}@media (max-width:480px){.ai-preview-modal{margin:2.5vh 16px;max-height:95vh}.ai-preview-modal .ai-modal-content{padding:16px}.ai-preview-modal .modal-actions{padding:12px 16px 16px}.original-message,.suggestion-description{padding:12px}.suggestion-title{font-size:1rem;padding:10px 12px}}.re-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .2s}.re-container:focus-within{border-color:var(--color-primary)}.re-container--disabled{opacity:.6;pointer-events:none}.re-toolbar{align-items:center;background:var(--color-surface-muted);border-bottom:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:2px;padding:var(--spacing-xs) var(--spacing-sm)}.re-toolbar__btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-xs);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-size:13px;height:30px;justify-content:center;padding:0;transition:background .15s,color .15s;width:30px}.re-toolbar__btn:hover{background:var(--color-border);color:var(--color-text-primary)}.re-toolbar__btn.active{background:var(--color-primary);color:#fff}.re-toolbar__sep{background:var(--color-border);height:20px;margin:0 4px;width:1px}.re-content{max-height:400px;min-height:120px;overflow-y:auto}.re-content .tiptap{color:var(--color-text-primary);font-family:var(--font-family-base);font-size:14px;line-height:1.6;outline:none;padding:var(--spacing-sm) var(--spacing-md)}.re-content .tiptap p.is-editor-empty:first-child:before{color:var(--color-text-muted);content:attr(data-placeholder);float:left;height:0;pointer-events:none}.re-content .tiptap h2{font-size:1.3em;font-weight:600;margin:1em 0 .4em}.re-content .tiptap h3{font-size:1.1em;font-weight:600;margin:.8em 0 .3em}.re-content .tiptap p{margin:.4em 0}.re-content .tiptap strong{font-weight:600}.re-content .tiptap a{color:var(--color-secondary);text-decoration:underline}.re-content .tiptap ol,.re-content .tiptap ul{margin:.4em 0;padding-left:1.4em}.re-content .tiptap li{margin:.2em 0}.re-content .tiptap ul[data-type=taskList]{list-style:none;padding-left:0}.re-content .tiptap ul[data-type=taskList] li{align-items:flex-start;display:flex;gap:6px}.re-content .tiptap ul[data-type=taskList] li label{flex-shrink:0;margin-top:3px}.re-content .tiptap ul[data-type=taskList] li input[type=checkbox]{accent-color:var(--color-primary)}.re-content .tiptap blockquote{border-left:3px solid var(--color-primary-light);color:var(--color-text-secondary);margin:.6em 0;padding-left:1em}.re-content .tiptap code{background:var(--color-surface-muted);border-radius:var(--radius-xs);font-family:var(--font-family-mono);font-size:.9em;padding:2px 5px}.re-content .tiptap pre{background:#1e293b;border-radius:var(--radius-sm);color:#e2e8f0;margin:.6em 0;overflow-x:auto;padding:var(--spacing-sm) var(--spacing-md)}.re-content .tiptap pre code{background:none;color:inherit;padding:0}.re-content .tiptap hr{border:none;border-top:1px solid var(--color-border);margin:1em 0}.re-content .tiptap img{border-radius:var(--radius-sm);height:auto;max-width:100%}.re-content .tiptap table{border-collapse:collapse;margin:.6em 0;width:100%}.re-content .tiptap td,.re-content .tiptap th{border:1px solid var(--color-border);font-size:13px;padding:6px 10px;text-align:left}.re-content .tiptap th{background:var(--color-surface-muted);font-weight:600}@media (max-width:768px){.re-toolbar{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.re-content{max-height:300px;min-height:100px}.re-content .tiptap{font-size:13px}}@media (max-height:600px){.fullscreen-center{gap:2vh}}.base-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));width:100%}.base-stat-card{align-items:center;background:var(--color-surface);border-radius:8px;box-shadow:0 2px 10px #0000001a;display:flex;gap:16px;padding:24px;text-align:left;transition:transform .3s ease}.base-stat-icon{color:#0f766e;filter:drop-shadow(0 6px 14px rgba(15,118,110,.25));font-size:2.5rem}.base-stat-card.primary .base-stat-icon{color:#0f766e}.base-stat-card.success .base-stat-icon{color:#15803d}.base-stat-card.warning .base-stat-icon{color:#d97706}.base-stat-card.info .base-stat-icon{color:#2563eb}.base-stat-content h3{color:var(--color-text-primary);font-size:2rem;font-weight:700;margin:0}.base-stat-content p{color:var(--color-text-secondary);font-size:.9rem;font-weight:400;margin:4px 0 0}@media (max-width:1024px){.base-stats{gap:16px}}@media (max-width:768px){.base-stat-card{border-radius:8px;padding:16px 18px}.base-stat-icon{font-size:2rem}.base-stat-content h3{font-size:1.6rem}.base-stat-content p{font-size:.85rem}}@media (max-width:480px){.base-stats{display:flex;flex-direction:row;gap:6px;justify-content:space-between}.base-stat-card{align-items:center;border-radius:6px;box-shadow:0 1px 3px #0000000f;flex:1 1;flex-direction:column;gap:4px;justify-content:center;padding:8px 6px;text-align:center}.base-stat-icon{font-size:1.1rem}.base-stat-content{display:flex;flex-direction:column;gap:1px}.base-stat-content h3{font-size:.85rem;font-weight:700}.base-stat-content p{font-size:.6rem;font-weight:500;letter-spacing:.01em;opacity:.65;text-transform:uppercase}}.actions-column .action-buttons-group .action-button{align-items:center;border:none;border-radius:8px;border-right:1px solid var(--color-border);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.3rem;justify-content:center;margin:0;min-width:100px;padding:.5rem 1rem;transition:all .2s ease}.actions-column .action-buttons-group .action-button:last-child{border-right:none}.actions-column .action-buttons-group .move-button{background:var(--color-surface-muted);color:#6366f1}.actions-column .action-buttons-group .move-button:hover{background:#6366f11a}.actions-column .action-buttons-group .start-button{background:var(--color-surface-muted);color:var(--color-text-primary)}.actions-column .action-buttons-group .start-button:hover{background:var(--color-border)}.actions-column .action-buttons-group .toggle-button{background:#ecfdf5;color:#059669}.actions-column .action-buttons-group .toggle-button:hover{background:#d1fae5}.actions-column .action-buttons-group .edit-button{background:#eff6ff;color:#2563eb}.actions-column .action-buttons-group .edit-button:hover{background:#dbeafe}.actions-column .action-buttons-group .delete-button{min-width:100px}.todo-item-table{grid-gap:1rem;align-items:center;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:grid;gap:1rem;grid-template-columns:40px 120px 1fr 300px;min-height:48px;padding:.6rem 1rem;transition:all .2s ease}.todo-item-table:first-child{border-top:1px solid var(--color-border)}.todo-item-table:hover{background:var(--color-surface-muted);border-bottom-color:#667eea}.todo-item-table.completed{background:var(--color-surface-muted);border-color:#d4edda;opacity:.8}.todo-item-table.completed .todo-title{color:var(--color-text-secondary);text-decoration:line-through}.todo-item-table.completed .todo-description{color:var(--color-text-secondary)}.todo-column{align-items:center;display:flex}.drag-column,.drag-handle-wrapper,.todo-column{justify-content:center}.drag-handle-wrapper{align-items:center;color:var(--color-text-muted);cursor:grab;display:flex;height:24px;transition:color .2s ease;width:24px}.drag-handle-wrapper:hover{color:#667eea}.drag-handle-wrapper:active{cursor:grabbing}.checkbox-column{justify-content:center}.todo-checkbox{background:none;border:none;cursor:pointer;padding:0}.checkbox,.todo-checkbox{align-items:center;display:flex;justify-content:center}.checkbox{border:2px solid var(--color-border);border-radius:8px;color:#fff;font-size:11px;font-weight:700;height:18px;transition:all .2s ease;width:18px}.checkbox.checked,.checkbox:hover{border-color:#667eea}.checkbox.checked{background:#667eea}.priority-column{justify-content:center}.priority{align-items:center;border-radius:8px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.25rem;letter-spacing:.5px;padding:.25rem .5rem;text-transform:uppercase;white-space:nowrap}.priority.high{background:#ffebee;border:1px solid #ffcdd2;color:#c62828}.priority.medium{background:#fff8e1;border:1px solid #ffecb3;color:#f57c00}.priority.low{background:#e8f5e8;border:1px solid #c8e6c9;color:#2e7d32}.priority-icon{font-size:.8rem}.priority-text{font-size:.7rem}.content-column{align-items:flex-start;justify-content:flex-start}.todo-content-wrapper{align-items:center;display:flex;gap:.75rem;width:100%}.timely-toggle-wrapper{align-items:center;display:flex;flex-shrink:0;gap:.5rem;margin-right:.25rem;min-width:24px}.timely-clock-icon{color:#667eea;font-size:1rem;opacity:.7;transition:all .3s ease}.timely-clock-icon.timely-active{color:#10b981;opacity:1}.timely-clock-icon:hover{opacity:1}.timely-switch{cursor:pointer;display:inline-block;height:20px;position:relative;width:40px}.timely-switch input{height:0;opacity:0;width:0}.timely-slider{background-color:var(--color-border);border-radius:20px;bottom:0;left:0;position:absolute;right:0;top:0;transition:.3s}.timely-slider:before{background-color:var(--color-surface);border-radius:50%;bottom:3px;content:"";height:14px;left:3px;position:absolute;transition:.3s;width:14px}.timely-switch input:checked+.timely-slider{background-color:#667eea}.timely-switch input:checked+.timely-slider:before{transform:translateX(20px)}.timely-switch:hover .timely-slider{opacity:.9}.timely-switch:hover .timely-clock-icon{opacity:1}.todo-title{--todo-title-margin:0;--todo-title-font-size:0.85rem;--todo-title-color:var(--color-text-primary);--todo-title-line-height:1.3;align-items:center;display:flex;gap:.5rem}.detail-icon{border-radius:8px;cursor:pointer;font-size:.85rem;opacity:.6;padding:.2rem;transition:opacity .2s ease}.detail-icon:hover{background:#667eea1a;opacity:1}.todo-description{color:var(--color-text-secondary);font-size:.8rem;line-height:1.4;margin:0}.actions-column{justify-content:flex-end;opacity:1;transition:opacity .2s ease}.actions-column .action-buttons-group{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 1px 3px #0000000f;display:flex;overflow:hidden}.todo-item-table .actions-column .button-icon{font-size:.9rem}.todo-item-table .actions-column .button-text{font-size:.85rem}@media (max-width:768px){.todo-item-table{font-size:.9rem;gap:.5rem;grid-template-columns:28px auto 1fr auto;padding:.5rem}.complete-todo-button,.delete-todo-button,.detail-todo-button,.start-button,.stop-button{font-size:.75rem;gap:.3rem;padding:.3rem .5rem}.button-text,.timely-switch{display:none}.actions-column .action-buttons-group .action-button{border-right:none;min-width:auto;padding:.35rem .5rem}.actions-column .action-buttons-group{border-radius:8px;gap:4px;padding:2px}.todo-title{--todo-title-font-size:0.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.todo-description{font-size:.8rem}.actions-column{opacity:1}.priority-text{display:none}.priority{background:#0000;border:none;padding:0}.priority-icon{font-size:1rem}}@media (max-width:480px){.todo-item-table{gap:.35rem;grid-template-columns:24px auto 1fr auto;padding:.45rem}.drag-handle-wrapper{height:20px;width:20px}.complete-todo-button,.delete-todo-button,.detail-todo-button,.start-button,.stop-button{font-size:.72rem;gap:.2rem;padding:.3rem .4rem}.actions-column{gap:.2rem}.todo-title{line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;white-space:normal}.priority-icon{font-size:.95rem}}.error-boundary{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:center;min-height:100vh;padding:2rem}.error-boundary-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;max-width:500px;padding:3rem;text-align:center}.error-boundary-content h2{font-size:2rem;margin:0 0 1rem}.error-boundary-content p{font-size:1.1rem;margin:0 0 2rem;opacity:.9}.error-details{margin:2rem 0;text-align:left}.error-details summary{cursor:pointer;font-weight:600;margin-bottom:1rem}.error-details pre{background:#0000004d;border-radius:8px;font-size:.8rem;max-height:200px;overflow:auto;padding:1rem}.reload-button{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:1rem 2rem;transition:all .2s ease}.reload-button:hover{background:#ffffff4d;transform:translateY(-2px)}.app-footer{background:var(--gradient-surface);border-top:1px solid var(--color-border);color:var(--color-text-secondary);font-size:.875rem;margin-top:48px;padding:24px 0}.footer-content{margin:0 auto;max-width:1200px;padding:0 20px}.footer-main{margin-bottom:24px;text-align:center}.footer-brand{align-items:center;display:flex;gap:8px;justify-content:center;margin-bottom:8px}.footer-logo{font-size:1.25rem}.footer-title{color:var(--color-text-primary);font-size:1rem;font-weight:600}.footer-description{color:var(--color-text-secondary);font-size:.875rem;line-height:1.5;margin:0 auto;max-width:400px}.footer-bottom{border-top:1px solid var(--color-border);flex-direction:column;gap:12px;padding-top:20px}.copyright,.footer-bottom{align-items:center;display:flex}.copyright{color:var(--color-text-secondary);flex-wrap:wrap;font-size:.8rem;gap:8px;justify-content:center}.copyright .version-info{color:var(--color-primary);font-weight:500}.footer-links{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.footer-link{color:var(--color-text-secondary);cursor:pointer;font-size:.8rem;transition:color .2s ease}.footer-link:hover{color:var(--color-text-primary)}.footer-separator{color:var(--color-border);font-size:.8rem}@media (max-width:768px){.app-footer{margin-top:32px;padding:24px 0 20px}.footer-content{padding:0 16px}.footer-main{margin-bottom:20px}.footer-brand{flex-direction:column;gap:4px}.footer-title{font-size:.9rem}.footer-description{font-size:.8rem}.footer-bottom{gap:8px}.footer-links{gap:6px}.copyright,.footer-link{font-size:.75rem}}@media (max-width:480px){.footer-links{flex-direction:column;gap:4px}.footer-separator{display:none}}.language-switcher{display:inline-block;position:relative}.language-switcher-button{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;justify-content:space-between;min-width:80px;padding:.5rem .75rem;transition:all .2s ease}.language-switcher-button:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-1px)}.language-switcher-button:focus{box-shadow:0 0 0 3px #fff3;outline:none}.language-flag{font-size:1.1rem;line-height:1}.language-code{font-weight:600;letter-spacing:.5px}.dropdown-arrow{font-size:.75rem;opacity:.7;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.language-dropdown{animation:languageDropdownSlide .15s ease-out;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;left:0;margin-top:.25rem;min-width:120px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}@keyframes languageDropdownSlide{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.language-option{align-items:center;background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.75rem;text-align:left;transition:background-color .15s ease;width:100%}.language-option:hover{background-color:var(--color-surface-muted)}.language-option.active{background-color:#f0f9ff;color:#0369a1}.language-option:not(:last-child){border-bottom:1px solid var(--color-border)}.language-name{flex:1 1;font-weight:500}.checkmark{color:#059669;font-size:.875rem;font-weight:700}@media (max-width:768px){.language-switcher-button{font-size:.8rem;min-width:60px;padding:.375rem .5rem}.language-code{display:none}.language-dropdown{left:auto;min-width:140px;right:0}}.language-switcher.promo-variant .promo-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border:1px solid #ffffff1f;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:var(--muted);font-size:.9rem;font-weight:600;padding:10px 14px;transition:all .2s ease}.language-switcher.promo-variant .promo-button:hover{background:#ffffff26;border-color:#ffffff40;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.language-switcher.promo-variant .promo-button:focus{box-shadow:0 0 0 3px #fff3,0 4px 12px #00000026;outline:none}.language-switcher.promo-variant .language-dropdown{border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;margin-top:8px}@media (max-width:900px){.language-switcher.promo-variant .promo-button{font-size:.85rem;min-width:70px;padding:8px 12px}.language-switcher.promo-variant .language-code{display:inline}}.desktop-header-container{background:var(--color-surface);border-bottom:1px solid var(--color-border);left:0;position:fixed;right:0;top:0;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%;z-index:1000}.desktop-header-container.scrolled{box-shadow:0 4px 20px #00000014}.desktop-header{background:#6879e1;color:#fff;padding:16px 24px}.desktop-header-content{align-items:center;display:flex;gap:24px;justify-content:space-between;margin:0 auto;max-width:1200px}.desktop-header-left{flex:0 0 auto}.desktop-brand{align-items:center;display:flex;gap:12px}.desktop-brand .beta-badge{background:#ffffff26;border:1px solid #fff3;border-radius:8px;color:#fffc;font-size:10px;font-weight:600;letter-spacing:.5px;margin-left:-4px;padding:2px 6px}.desktop-logo{flex-shrink:0}.desktop-title{color:#fff;font-size:24px;font-weight:700;margin:0;text-shadow:0 2px 4px #0000001a}.desktop-header-center{display:flex;flex:1 1;justify-content:center}.desktop-stats{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:8px;padding:8px 16px}.desktop-stat{color:#fff;font-size:14px;font-weight:500}.desktop-header-right{align-items:center;display:flex;flex:0 0 auto;gap:16px}.desktop-profile-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:30px;cursor:pointer;display:flex;gap:10px;padding:6px 14px 6px 6px;transition:all .2s ease}.desktop-profile-btn:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.desktop-profile-avatar{align-items:center;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;box-shadow:0 2px 8px #fbbf2466;color:#fff;display:flex;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}.desktop-user-info{align-items:flex-start;display:flex;flex-direction:column;gap:1px}.desktop-user-greeting{color:#fffc;font-size:12px;opacity:.9}.desktop-user-name{color:#fff;font-size:14px;font-weight:600}.desktop-theme-toggle{align-items:center;background:#ffffff1f;border:1px solid #fff3;border-radius:50%;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .3s ease;width:36px}.desktop-theme-toggle:hover{background:#ffffff40;transform:scale(1.1)}.desktop-theme-toggle .theme-toggle-icon{font-size:18px;line-height:1;transition:transform .3s ease}.desktop-theme-toggle:hover .theme-toggle-icon{transform:rotate(20deg)}.desktop-logout-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.desktop-logout-btn:hover{background:#ffffff40;transform:translateY(-1px)}.desktop-logout-icon{font-size:16px}.desktop-logout-text{font-size:14px;font-weight:700}.desktop-navigation{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 24px}.desktop-nav-content{align-items:center;display:flex;gap:24px;justify-content:space-between;margin:0 auto;max-width:1200px}.desktop-nav-tabs{align-items:center;display:flex;gap:4px}.desktop-nav-tab{align-items:center;background:#0000;border:none;border-radius:8px 8px 0 0;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;font-weight:700;gap:8px;padding:16px 20px;position:relative;transition:all .2s ease}.desktop-nav-tab:hover{background:var(--color-surface-muted);color:var(--color-text-primary)}.desktop-nav-tab.active{background:var(--color-surface-info-light);border-bottom:3px solid var(--color-secondary);color:var(--color-secondary)}.desktop-nav-tab.active:after{background:var(--color-secondary);border-radius:8px 8px 0 0;bottom:-1px;content:"";height:3px;left:0;position:absolute;right:0}.desktop-nav-icon{font-size:16px}.desktop-add-goal-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.desktop-add-goal-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.desktop-add-goal-icon{font-size:16px}.desktop-add-goal-text{font-size:14px}@media (max-width:1024px){.desktop-header{padding:12px 20px}.desktop-navigation{padding:0 20px}.desktop-nav-tab{padding:14px 16px}.desktop-add-goal-btn{padding:10px 16px}}.mobile-header-container{background:#0000;border-bottom:1px solid var(--color-border);left:0;position:fixed;right:0;top:0;transition:all .3s ease;width:100%;z-index:1000}.mobile-header-container.scrolled{box-shadow:0 2px 10px #0000001a}.mobile-header{background:#6879e1;color:#fff;padding-top:env(safe-area-inset-top,0)}.mobile-header-content{align-items:center;display:flex;justify-content:space-between;min-height:60px;padding:12px 16px}.mobile-brand{align-items:center;display:flex;flex:1 1;gap:10px}.mobile-brand .beta-badge{background:#ffffff26;border:1px solid #fff3;border-radius:8px;color:#fffc;font-size:9px;font-weight:600;letter-spacing:.5px;margin-left:-2px;padding:2px 5px}.mobile-header-center{flex:0 0 auto;gap:8px;margin:0 8px}.mobile-header-center,.mobile-theme-toggle{align-items:center;display:flex;justify-content:center}.mobile-theme-toggle{background:#ffffff1f;border:1px solid #fff3;border-radius:50%;cursor:pointer;height:32px;transition:all .3s ease;width:32px}.mobile-theme-toggle:hover{background:#ffffff40}.mobile-theme-toggle .theme-toggle-icon{font-size:16px;line-height:1}.mobile-logo{flex-shrink:0}.mobile-title{color:#fff;font-size:18px;font-weight:700;margin:0;text-shadow:0 1px 3px #0000001a}.mobile-menu-btn{background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;height:30px;justify-content:space-around;padding:4px;transition:background-color .2s ease;width:30px}.mobile-menu-btn:hover{background:#ffffff1a}.hamburger-line{background:#fff;height:2px;transform-origin:center;transition:all .3s ease;width:100%}.mobile-menu-btn.open .hamburger-line:first-child{transform:rotate(45deg) translate(5px,5px)}.mobile-menu-btn.open .hamburger-line:nth-child(2){opacity:0}.mobile-menu-btn.open .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.mobile-progress-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-top:1px solid #ffffff1a;padding:8px 16px}.mobile-progress-info{display:flex;justify-content:center}.mobile-progress-text{color:#ffffffe6;font-size:12px;font-weight:500;text-align:center}.mobile-menu-overlay{animation:fadeIn .3s ease;z-index:2000}.mobile-side-menu{background:var(--color-surface);box-shadow:-5px 0 25px #00000026;height:100vh;overflow-y:auto;position:fixed;right:-100vw;top:0;transition:right .3s cubic-bezier(.4,0,.2,1);width:min(320px,85vw);z-index:2001}.mobile-side-menu.open{right:0}.mobile-menu-content{display:flex;flex-direction:column;height:100%;padding:20px 0}.mobile-user-section{background:var(--gradient-surface);border-bottom:1px solid var(--color-border);margin-bottom:8px;padding:0}.mobile-user-profile-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:12px;padding:20px 24px;text-align:left;transition:background .2s ease;width:100%}.mobile-user-profile-btn:hover{background:#00000008}.mobile-user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.mobile-user-initial{color:#fff;font-size:18px;font-weight:700}.mobile-user-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.mobile-profile-hint{color:#6366f1;font-size:12px;font-weight:500;margin-top:2px}.mobile-user-greeting{color:var(--color-text-secondary);font-size:12px;font-weight:500}.mobile-user-name{color:var(--color-text-primary);font-size:16px;font-weight:600}.mobile-nav-section{flex:1 1;padding:0 16px}.mobile-nav-title{color:var(--color-text-secondary);font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;padding:16px 8px 8px;text-transform:uppercase}.mobile-nav-list{display:flex;flex-direction:column;gap:2px}.mobile-nav-item{background:#0000;border-radius:8px;gap:12px;padding:16px;position:relative;transition:all .2s ease}.mobile-nav-item:hover{background:var(--color-surface-muted);transform:translateX(4px)}.mobile-nav-item.active{background:var(--color-surface-info-light);color:var(--color-secondary);font-weight:600}.mobile-nav-item.active:before{background:var(--color-secondary);border-radius:0 8px 8px 0;content:"";height:24px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.mobile-nav-icon{flex-shrink:0;font-size:18px;text-align:center;width:20px}.mobile-nav-text{color:var(--color-text-primary);flex:1 1;font-size:15px;font-weight:500}.mobile-nav-item.active .mobile-nav-text{color:var(--color-secondary)}.mobile-nav-arrow{color:var(--color-text-muted);font-size:16px;transition:transform .2s ease}.mobile-nav-item:hover .mobile-nav-arrow{transform:translateX(4px)}.mobile-actions-section{border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:12px;padding:16px 24px 24px}.mobile-add-goal-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:10px;justify-content:center;padding:14px 20px;transition:all .2s ease}.mobile-add-goal-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.mobile-logout-btn{align-items:center;background:var(--color-surface-danger-light);border:1px solid var(--color-danger);border-radius:8px;color:var(--color-danger);cursor:pointer;display:flex;font-weight:600;gap:10px;justify-content:center;padding:14px 20px;transition:all .2s ease}.mobile-logout-btn:hover{background:#fee2e2;transform:translateY(-1px)}.mobile-action-icon{font-size:16px}.mobile-action-text{font-size:14px}@supports (padding:max(0px)){.mobile-header-content{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.mobile-side-menu{padding-bottom:env(safe-area-inset-bottom);padding-top:env(safe-area-inset-top)}}.mobile-header-container.scrolled{background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed}.suggestion-backdrop{z-index:1100}.suggestion-modal{animation:modalSlideIn .3s ease-out;background:linear-gradient(135deg,var(--color-surface) 0,var(--color-surface-muted) 100%);border-radius:20px;box-shadow:0 25px 60px #00000026,0 0 0 1px #0000000d;max-height:90vh;max-width:520px;overflow-y:auto;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.suggestion-modal__header{align-items:flex-start;border-bottom:1px solid #00000014;display:flex;justify-content:space-between;padding:24px 24px 16px}.suggestion-modal__title-group{align-items:flex-start;display:flex;gap:16px}.suggestion-modal__icon{animation:float 3s ease-in-out infinite;font-size:2.5rem}.suggestion-modal__title-group h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#8b5cf6);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin:0 0 4px}.suggestion-modal__subtitle{color:var(--color-text-secondary);font-size:.875rem;margin:0}.suggestion-modal__close{align-items:center;background:var(--color-surface-muted);border:none;border-radius:10px;color:var(--color-text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.suggestion-modal__close:hover{background:var(--color-border);color:var(--color-text-primary);transform:rotate(90deg)}.suggestion-modal__close:disabled{cursor:not-allowed;opacity:.5}.suggestion-modal__form{padding:24px}.form-group{position:relative}.form-group label{color:var(--color-text-secondary);display:block;font-size:.875rem;font-weight:600;margin-bottom:10px}.type-selector{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr)}.type-option{align-items:center;border:2px solid var(--color-border);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:14px 8px;transition:all .2s ease}.type-option,.type-option:hover{background:var(--color-surface-muted)}.type-option:hover{border-color:var(--color-text-muted);transform:translateY(-2px)}.type-option.active{background:linear-gradient(135deg,color-mix(in srgb,var(--type-color) 10%,#fff),color-mix(in srgb,var(--type-color) 5%,#fff));border-color:var(--type-color);box-shadow:0 4px 20px color-mix(in srgb,var(--type-color) 25%,#0000)}.type-option__icon{font-size:1.5rem;transition:transform .2s ease}.type-option.active .type-option__icon{transform:scale(1.1)}.type-option__label{color:var(--color-text-secondary);font-size:.75rem;font-weight:600;text-align:center}.form-input,.form-textarea,.type-option.active .type-option__label{color:var(--color-text-primary)}.form-input,.form-textarea{background:var(--color-surface);border-radius:12px;box-sizing:border-box;font-size:.95rem;padding:14px 16px}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input:focus,.form-textarea:focus{background:var(--color-surface);border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a}.form-textarea{min-height:140px;resize:vertical}.char-count{bottom:-20px;color:var(--color-text-muted);font-size:.75rem;position:absolute;right:12px}.suggestion-error{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;display:flex;gap:10px;margin-bottom:20px;padding:12px 16px}.suggestion-error svg{color:#ef4444;flex-shrink:0}.suggestion-error span{color:#dc2626;font-size:.875rem}.suggestion-modal__actions{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 1px 3px #0000000f;display:flex;gap:0;margin-top:24px;overflow:hidden}.btn-cancel,.btn-submit{align-items:center;border:none;border-radius:0;cursor:pointer;display:flex;flex:1 1;font-size:.85rem;font-weight:600;gap:8px;justify-content:center;min-height:46px;padding:.625rem 1rem;transition:all .2s ease}.btn-submit:disabled{opacity:.5}.suggestion-modal__helper{color:var(--color-text-muted);font-size:.8rem;margin:16px 0 0;text-align:center}.suggestion-modal__success{padding:60px 24px;text-align:center}.success-animation{margin-bottom:24px}.success-checkmark{align-items:center;animation:successPop .5s ease-out;background:linear-gradient(135deg,#10b981,#34d399);border-radius:50%;box-shadow:0 10px 40px #10b9814d;display:flex;height:80px;justify-content:center;margin:0 auto;width:80px}.success-checkmark svg{color:#fff;height:40px;width:40px}@keyframes successPop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.suggestion-modal__success h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#10b981,#34d399);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;margin:0 0 8px}.suggestion-modal__success p{color:var(--color-text-secondary);font-size:.95rem;margin:0}@media (max-width:768px){.suggestion-modal{margin:20px;width:95%}.suggestion-modal__header{padding:20px}.suggestion-modal__icon{font-size:2rem}.suggestion-modal__title-group h2{font-size:1.25rem}.type-selector{grid-template-columns:repeat(2,1fr)}.type-option{padding:12px 8px}.suggestion-modal__form{padding:20px}.suggestion-modal__actions{border-radius:8px;flex-direction:column;overflow:hidden}.btn-cancel{border-bottom:1px solid var(--color-border);border-right:none}.btn-cancel,.btn-submit{font-size:.9rem;padding:12px 16px}.btn-submit{order:-1}}.page-transition{min-height:0;width:100%}.page-transition.page-slide-in-right{animation:slideInFromRight .28s cubic-bezier(.4,0,.2,1) both}.page-transition.page-slide-in-left{animation:slideInFromLeft .28s cubic-bezier(.4,0,.2,1) both}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(60px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translateX(-60px)}to{opacity:1;transform:translateX(0)}}@media (prefers-reduced-motion:reduce){.page-transition.page-slide-in-left,.page-transition.page-slide-in-right{animation:pageFadeIn .15s ease both}@keyframes pageFadeIn{0%{opacity:0}to{opacity:1}}}.app{display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}html{scroll-behavior:smooth}.app-header-container{left:0;overflow-x:hidden;position:fixed;right:0;top:0;transition:all .3s ease;width:100%;z-index:1000}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;padding:1rem 0;transition:all .3s ease}.app-header-container.scrolled .app-header{box-shadow:0 4px 20px #00000026;padding:0}.app-header-container.scrolled .app-header,.navigation{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navigation{background:var(--color-surface);background:var(--color-overlay);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-soft);padding:.4rem 0;transition:all .3s ease}.header-title{align-items:center;display:flex;gap:1rem}.header-title h1{font-size:1.8rem;font-weight:600;margin:0;transition:font-size .3s ease}.header-logo{transition:all .3s ease}.app-header-container.scrolled .header-title h1{font-size:1.8rem}.header-center{display:flex;flex:1 1;justify-content:center}.header-stats{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:8px;padding:.5rem 1rem}.stat{font-size:.9rem;font-weight:500}.header-user{align-items:center;display:flex;gap:1rem}.user-info{align-items:flex-end;display:flex;flex-direction:column;gap:.2rem}.user-greeting{font-size:.8rem;opacity:.8}.user-name{font-size:1rem;font-weight:600}.logout-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.logout-btn:hover{background:#fff3;transform:translateY(-2px)}.app-header-container.scrolled .user-name{font-size:1rem}.app-header-container.scrolled .user-greeting{font-size:.8rem}.app-header-container.scrolled .logout-btn{font-size:.9rem;padding:.4rem .8rem}.app-header-container.scrolled .header-stats{padding:.4rem .8rem}.app-header-container.scrolled .stat{font-size:.9rem}.nav-content{box-sizing:border-box;gap:1rem;margin:0 auto;max-width:1200px;overflow-x:hidden;padding:0 2rem;width:100%}.nav-content,.nav-tab{align-items:center;display:flex}.nav-tab{background:#0000;border:none;border-radius:8px;color:var(--color-text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease}.nav-tab:hover{background:var(--color-surface-muted);color:var(--color-text-primary)}.nav-tab.active{background:#667eea;color:#fff}.contact-tab{margin-left:auto;margin-right:1rem}.add-goal-nav-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 10px #667eea4d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.add-goal-nav-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.add-goal-icon{font-size:1.1rem}.main-content{box-sizing:border-box;flex:1 1;margin:145px auto 0;max-width:1200px;overflow-x:hidden;padding:0 2rem 2rem;transition:margin-top .3s ease;width:100%}@media (max-width:768px){.header-title{align-items:center!important;display:flex!important;flex:1 1!important;gap:.5rem!important;min-width:0!important;order:1!important}.header-title h1{color:#fff;font-size:1.2rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-center,.header-user.desktop-only{display:none!important}.mobile-menu-toggle{align-items:center!important;background:#ffffff26!important;border:2px solid #ffffff4d!important;border-radius:8px!important;cursor:pointer!important;display:flex!important;flex:0 0 auto!important;justify-content:center!important;min-height:44px!important;min-width:44px!important;order:3!important;padding:10px!important;transition:background-color .2s ease!important}.mobile-menu-toggle:hover{background-color:#fff3}.hamburger{display:flex;flex-direction:column;height:18px;justify-content:space-between;position:relative;width:24px}.hamburger span{background-color:#fff;border-radius:8px;box-shadow:0 1px 2px #0000001a;display:block;height:3px;transition:all .3s ease;width:100%}.hamburger.open span:first-child{transform:rotate(45deg) translate(6px,6px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.nav-content.desktop-only,.navigation{display:none!important}.mobile-nav-menu{background:var(--color-surface);box-shadow:-2px 0 10px #0000001a;height:100vh;overflow-y:auto;position:fixed;right:-320px;top:0;transition:right .3s ease;width:320px;z-index:1000}.mobile-nav-menu.open{right:0}.mobile-nav-content{display:flex;flex-direction:column;height:100%;padding:80px 0 20px}.mobile-user-info{border-bottom:1px solid var(--color-border);color:#fff;padding:20px 24px}.mobile-user-greeting{display:flex;flex-direction:column;gap:4px}.mobile-user-greeting span{font-size:.9rem;opacity:.9}.mobile-user-greeting strong{font-size:1.1rem;font-weight:600}.mobile-nav-items{flex:1 1;padding:20px 0}.mobile-nav-item{align-items:center;background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:1rem;gap:16px;padding:16px 24px;text-align:left;transition:background-color .2s ease;width:100%}.mobile-nav-item:hover{background-color:var(--color-surface-muted)}.mobile-nav-item.active{background-color:#ede9fe;border-right:3px solid #7c3aed;color:#7c3aed}.mobile-nav-item .nav-icon{font-size:1.2rem;text-align:center;width:24px}.mobile-nav-divider{background-color:var(--color-border);height:1px;margin:12px 24px}.mobile-nav-item.add-goal-mobile{color:var(--color-success);font-weight:500}.mobile-nav-item.add-goal-mobile:hover{background-color:var(--color-surface-success-light)}.mobile-nav-item.logout-mobile{color:var(--color-danger);font-weight:500;margin-top:auto}.mobile-nav-item.logout-mobile:hover{background-color:var(--color-surface-danger-light)}.mobile-menu-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:var(--color-backdrop);height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:999}.main-content{box-sizing:border-box;margin-top:85px;max-width:100vw;padding:1rem}.app-header,.main-content{overflow-x:hidden;width:100%}.app-header{padding:.4rem 0}.app-header-container.scrolled .app-header{padding:.25rem 0}.app-header-container.scrolled .header-title h1{font-size:1.1rem}}.desktop-only{display:block}.mobile-only{display:none}.mobile-menu-toggle{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;cursor:pointer;display:none;padding:12px;transition:background-color .2s ease;z-index:1001}.mobile-menu-toggle:hover{background-color:#fff3}.hamburger{display:flex;flex-direction:column;height:18px;justify-content:space-between;position:relative;width:24px}.hamburger span{background-color:#fff;border-radius:8px;box-shadow:0 1px 2px #0000001a;display:block;height:3px;transition:all .3s ease;width:100%}.hamburger.open span:first-child{transform:rotate(45deg) translate(6px,6px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media (max-width:768px){.desktop-only{display:none!important}.mobile-only{display:block!important}.mobile-menu-toggle.mobile-only{align-items:center;display:flex!important;justify-content:center}}.mobile-nav-menu{background:var(--color-surface);box-shadow:-2px 0 10px #0000001a;height:100vh;overflow-y:auto;position:fixed;right:-320px;top:0;transition:right .3s ease;width:320px;z-index:1000}.mobile-nav-menu.open{right:0}.mobile-nav-content{display:flex;flex-direction:column;height:100%;padding:80px 0 20px}.mobile-user-info{border-bottom:1px solid var(--color-border);color:#fff;padding:20px 24px}.mobile-user-greeting{display:flex;flex-direction:column;gap:4px}.mobile-user-greeting span{font-size:.9rem;opacity:.9}.mobile-user-greeting strong{font-size:1.1rem;font-weight:600}.mobile-nav-items{flex:1 1;padding:20px 0}.mobile-nav-item{align-items:center;background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:1rem;gap:16px;padding:16px 24px;text-align:left;transition:background-color .2s ease;width:100%}.mobile-nav-item:hover{background-color:var(--color-surface-muted)}.mobile-nav-item.active{background-color:#ede9fe;border-right:3px solid #7c3aed;color:#7c3aed}.mobile-nav-item .nav-icon{font-size:1.2rem;text-align:center;width:24px}.mobile-nav-divider{background-color:var(--color-border);height:1px;margin:12px 24px}.mobile-nav-item.add-goal-mobile{color:var(--color-success);font-weight:500}.mobile-nav-item.add-goal-mobile:hover{background-color:var(--color-surface-success-light)}.mobile-nav-item.logout-mobile{color:var(--color-danger);font-weight:500;margin-top:auto}.mobile-nav-item.logout-mobile:hover{background-color:var(--color-surface-danger-light)}.mobile-menu-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:var(--color-backdrop);height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:999}.markdown-view{word-wrap:break-word;color:var(--color-text-primary);font-size:.95rem;line-height:1.7;overflow-wrap:break-word}.markdown-view h1,.markdown-view h2,.markdown-view h3{color:var(--color-text-primary);font-weight:700;line-height:1.3;margin:.8em 0 .4em}.markdown-view h1{font-size:1.3em}.markdown-view h2{font-size:1.15em}.markdown-view h3{font-size:1.05em}.markdown-view p{margin:0 0 .6em}.markdown-view p:last-child{margin-bottom:0}.markdown-view strong{font-weight:700}.markdown-view em{font-style:italic}.markdown-view del{color:var(--color-text-muted);text-decoration:line-through}.markdown-view a{border-bottom:1px solid #0000;color:#6366f1;text-decoration:none;transition:border-color .15s ease}.markdown-view a:hover{border-bottom-color:#6366f1}.markdown-view ol,.markdown-view ul{margin:.4em 0 .6em;padding-left:1.6em}.markdown-view li{margin-bottom:.2em}.markdown-view li>p{margin:0}.markdown-view ul:has(>li>input[type=checkbox]){list-style:none;padding-left:.4em}.markdown-view li>input[type=checkbox]{accent-color:#6366f1;margin-right:.5em;pointer-events:none}.markdown-view code{background:var(--color-surface-muted);border-radius:4px;color:#e11d48;font-family:SF Mono,Monaco,Consolas,Courier New,monospace;font-size:.85em;padding:.15em .4em}.markdown-view pre{-webkit-overflow-scrolling:touch;background:#1e293b;border-radius:8px;margin:.6em 0;overflow-x:auto;padding:12px 16px}.markdown-view pre code{background:none;color:#e2e8f0;font-size:.85em;line-height:1.5;padding:0}.markdown-view blockquote{background:var(--color-surface-muted);border-left:3px solid #6366f1;border-radius:0 6px 6px 0;color:var(--color-text-secondary);margin:.6em 0;padding:.4em 0 .4em 1em}.markdown-view blockquote p{margin:0}.markdown-view hr{border:none;border-top:1px solid var(--color-border);margin:1em 0}.markdown-view table{border-collapse:collapse;font-size:.875em;margin:.6em 0;width:100%}.markdown-view td,.markdown-view th{border:1px solid var(--color-border);padding:8px 12px;text-align:left}.markdown-view th{color:var(--color-text-primary);font-weight:600}.markdown-view th,.markdown-view tr:hover td{background:var(--color-surface-muted)}.markdown-view img{border-radius:8px;height:auto;margin:.4em 0;max-width:100%}@media (max-width:768px){.markdown-view{font-size:.9rem}.markdown-view pre{padding:10px 12px}.markdown-view table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}}.todo-summary-card{background:linear-gradient(135deg,var(--color-surface-muted) 0,var(--color-surface) 100%);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 8px #0000000a;margin-top:12px;max-width:100%;padding:16px;transition:all .3s ease;width:100%}.todo-summary-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-1px)}.todo-summary-container .todo-summary-card{margin-top:0;max-width:100%;width:100%}.todo-summary-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.todo-count-badge{align-items:center;background:linear-gradient(135deg,#4285f4,#34a853);border-radius:8px;box-shadow:0 2px 6px #4285f44d;color:#fff;display:flex;font-size:.7rem;font-weight:600;gap:6px;padding:6px 10px}.todo-icon{font-size:.8rem}.todo-count{align-items:center;display:flex;gap:2px}.completed-count{color:#fff;font-weight:700}.separator{color:#fffc;margin:0 2px}.total-count{color:#ffffffe6;font-weight:500}.todo-label{color:#fffffff2;font-size:.65rem;margin-left:3px}.progress-circle,.progress-indicator{position:relative}.progress-circle{align-items:center;display:flex;height:28px;justify-content:center;width:28px}.progress-circle svg{color:#e9ecef;height:100%;position:absolute;width:100%}.progress-bg{opacity:.3}.progress-fill{color:#34a853;opacity:.9}.progress-text{font-size:.6rem;font-weight:600;position:absolute}.todo-items-container{display:flex;flex-direction:column;gap:4px}.todo-summary-card .todo-item{background:#0000;border:none;border-radius:8px;box-shadow:none;gap:6px;justify-content:flex-start;margin-bottom:0;padding:4px 6px;width:100%}.todo-summary-card .todo-item.clickable{cursor:pointer;transition:all .2s ease}.todo-summary-card .todo-item.clickable:hover{background:#4285f40a;border-color:#0000;box-shadow:none;transform:none}.todo-summary-card .todo-item.clickable:active{transform:scale(.98)}.todo-summary-card .todo-item:disabled{cursor:default}.todo-summary-card .todo-item:not(.clickable):hover{background:#0000}.todo-summary-card .todo-item.completed{background:#34a8530f;border-color:#0000;opacity:1}.todo-summary-card .todo-item.completed:hover{background:#34a8531a}.todo-summary-card .todo-item.more-items{background:#6c757d0d;font-style:italic}.todo-summary-card .todo-item.more-items:hover{background:#6c757d1a}.todo-status{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:16px;justify-content:center;width:16px}.status-icon{font-size:.7rem;font-weight:600}.completed-icon{background:#34a8531a;border-radius:50%;color:#34a853;padding:2px}.pending-icon{align-items:center;border:2px solid var(--color-border);border-radius:50%;display:flex;font-size:.6rem;height:12px;justify-content:center;width:12px}.more-icon,.pending-icon{color:var(--color-text-muted)}.more-icon{font-size:.9rem}.todo-summary-card .todo-title{--todo-title-font-size:0.9rem;--todo-title-line-height:1.3;--todo-title-font-weight:500;flex:0 1 auto;max-width:-webkit-fit-content;max-width:fit-content}.todo-summary-card .todo-item.completed .todo-title{opacity:.8}.todo-summary-card .todo-item.more-items .todo-title{font-weight:400}.todo-summary-card .todo-content{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:2px}.todo-summary-card .todo-title-row{align-items:center;display:flex;gap:6px;width:100%}.todo-summary-card .todo-priority{align-items:center;display:inline-flex;flex-shrink:0;font-size:.8rem;font-weight:500;height:16px;justify-content:center;width:16px}.todo-summary-card .todo-priority.priority-high{background:#f4433626;color:#d32f2f}.todo-summary-card .todo-priority.priority-medium{background:#ff980026;color:#f57c00}.todo-summary-card .todo-priority.priority-low{background:#4caf5026;color:#388e3c}.todo-summary-card .todo-item.priority-high{border-left:3px solid #f44336}.todo-summary-card .todo-item.priority-medium{border-left:3px solid #ff9800}.todo-summary-card .todo-item.priority-low{border-left:3px solid #4caf50}.remaining-priorities{display:flex;gap:2px;margin-top:2px}.mini-priority{font-size:.6rem;opacity:.8}.header-right{align-items:center;display:flex;gap:12px}.priority-summary{align-items:center;display:flex;gap:6px}.priority-count{background:var(--color-surface);border-radius:8px;color:var(--color-text-primary);font-size:.65rem;font-weight:600;padding:2px 4px}.priority-count.high{background:#f443361a;color:#d32f2f}.priority-count.medium{background:#ff98001a;color:#f57c00}.priority-count.low{background:#4caf501a;color:#388e3c}@media (max-width:768px){.todo-summary-card{margin-top:8px;padding:10px}.todo-summary-header{align-items:stretch;flex-direction:column;gap:8px;text-align:center}.todo-count-badge{font-size:.65rem;justify-content:center;padding:5px 8px}.progress-indicator{align-self:center}.todo-summary-card .todo-item{gap:6px;padding:4px 6px}.todo-summary-card .todo-title{--todo-title-font-size:0.85rem}}.add-subgoal-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.add-subgoal-modal{animation:slideInUp .3s ease-out;background:var(--color-surface);border-radius:8px;box-shadow:0 20px 60px #0003;box-sizing:border-box;max-height:90vh;max-width:min(500px,95vw);overflow-y:auto;position:relative;width:100%}.modal-header{background:linear-gradient(135deg,#6366f1,#8b5cf6 50%,#d946ef);border-bottom:1px solid var(--color-border);justify-content:space-between;margin-bottom:0;padding:24px 24px 16px}.modal-header,.modal-title{align-items:center;color:#fff;display:flex}.modal-title{font-size:1.3rem;font-weight:600;gap:8px;margin:0}.modal-icon{font-size:22px}.modal-subtitle{color:#fffc;font-size:.9rem;margin:4px 0 0}.modal-subtitle strong{color:#fff;font-weight:600}.modal-close-btn{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.modal-close-btn:hover{background:#ffffff4d;color:#fff}.modal-form{padding:24px}.form-group{margin-bottom:20px}.form-label{color:var(--color-text-secondary);display:block;font-size:14px;font-weight:500;margin-bottom:6px}.form-input,.form-textarea{border:2px solid var(--color-border);border-radius:8px;font-family:inherit;font-size:14px;padding:12px 16px;resize:vertical;transition:all .2s ease;width:100%}.form-input:focus,.form-textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.form-input.error,.form-textarea.error{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c1a}.error-message{color:#e74c3c;font-weight:500}.character-count,.error-message{display:block;font-size:12px;margin-top:4px}.character-count{color:#6c757d;text-align:right}.modal-actions{background:var(--color-surface);display:flex;gap:0;margin-top:16px;overflow:hidden}.modal-actions .btn-cancel,.modal-actions .btn-submit{align-items:center;border:none;border-radius:0;cursor:pointer;display:flex;flex:1 1;font-size:.85rem;font-weight:500;gap:6px;justify-content:center;min-height:46px;padding:.625rem 1rem;transition:all .2s ease}.btn-cancel{background:#fef2f2;border-right:1px solid var(--color-border);color:#dc2626}.btn-cancel:hover{background:#fee2e2}.btn-submit{background:#eff6ff;color:#1d4ed8;flex:0 0 140px;justify-content:center;min-width:140px;overflow:hidden;white-space:nowrap;width:140px}.btn-submit:hover:not(:disabled){background:#dbeafe}.btn-submit:disabled{background:var(--color-border);box-shadow:none;color:#6c757d;cursor:not-allowed;transform:none}.btn-icon{font-size:12px}.btn-spinner{animation:btn-spin .8s linear infinite;border:2px solid #1d4ed84d;border-radius:50%;border-top-color:#1d4ed8;height:16px;width:16px}@keyframes btn-spin{to{transform:rotate(1turn)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:768px){.add-subgoal-modal-overlay{padding:16px}.add-subgoal-modal{border-radius:8px;max-width:100%}.modal-header{margin-bottom:20px;padding:20px 20px 0}.modal-form{padding:0 20px 20px}.modal-title{font-size:18px}.modal-actions{border-radius:8px;flex-direction:column;overflow:hidden}.btn-cancel,.btn-submit{border-right:none;font-size:.9rem;justify-content:center;padding:12px 16px;width:100%}.btn-cancel{border-bottom:1px solid var(--color-border);border-right:none}.btn-submit{order:-1}}.add-subgoal-modal:focus{outline:none}.goal-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;overflow:hidden;padding:24px;position:relative;transition:all .3s ease}.goal-card:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}.goal-card.completed{background:var(--color-surface-muted);opacity:.8}.goal-header{margin-bottom:16px}.goal-title-section{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.goal-title{color:var(--color-text-primary);flex:1 1;font-size:1.4rem;font-weight:600;margin:0}.goal-actions{display:flex;gap:8px;margin-left:16px}.action-btn{background:none;border:none;cursor:pointer;display:flex;height:32px;justify-content:center;padding:8px;width:32px}.action-btn,.completion-btn{align-items:center;border-radius:8px;transition:all .2s ease}.completion-btn{border:2px solid #0000;display:flex!important;font-size:.85rem;font-weight:500;gap:6px;height:auto!important;min-width:auto!important;padding:8px 12px!important;width:auto!important}.completion-btn.completed{background:linear-gradient(135deg,#d4edda,#c3e6cb)!important;color:#155724!important}.completion-btn:not(.completed){background:linear-gradient(135deg,#fff3cd,#ffeaa7)!important;border-color:#ffc107;color:#856404!important}.completion-btn:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.completion-btn.completed:hover{background:linear-gradient(135deg,#c3e6cb,#b1dfbb)!important;border-color:#20c997}.completion-btn:not(.completed):hover{background:linear-gradient(135deg,#ffeaa7,#fdcb6e)!important;border-color:#e17055}.completion-icon{font-size:1rem;line-height:1}.completion-text{font-size:.8rem;font-weight:600;white-space:nowrap}.edit-btn{background:#007bff;color:#fff}.save-btn{background:#28a745;color:#fff}.cancel-btn{background:#6c757d;color:#fff}.action-btn-modern.delete,.delete-btn,.delete-btn-improved,.delete-subgoal-btn{background:var(--danger-button-bg);border:1px solid var(--danger-button-border);box-shadow:var(--danger-button-shadow);color:var(--danger-button-color);transition:transform .2s ease,box-shadow .2s ease}.action-btn-modern.delete:hover,.delete-btn-improved:hover,.delete-btn:hover,.delete-subgoal-btn:hover{background:var(--danger-button-hover-bg);border-color:var(--danger-button-hover-border);box-shadow:var(--danger-button-hover-shadow);color:#fff;transform:translateY(-1px)}.action-btn-modern.delete:disabled,.delete-btn-improved:disabled,.delete-btn:disabled,.delete-subgoal-btn:disabled{background:var(--danger-button-disabled-bg);border-color:var(--danger-button-border);box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.add-subgoal-btn{background:#17a2b8;color:#fff}.action-btn:hover{transform:scale(1.1)}.edit-form{margin-top:16px}.edit-input{border:1px solid var(--color-input-border);border-radius:8px;font-size:14px;margin-bottom:12px;padding:10px;width:100%}.title-input{font-size:1.2rem;font-weight:600}.description-input{min-height:80px;resize:vertical}.edit-row{display:flex;gap:12px}.date-input{flex:1 1}.goal-description{color:var(--color-text-secondary);line-height:1.5;margin-bottom:16px}.goal-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px}.goal-due-date{color:var(--color-text-secondary);font-size:.9rem}.progress-section{margin-bottom:20px;padding-top:20px}.progress-bar{height:8px;margin-bottom:8px;position:relative}.progress-fill{background:linear-gradient(90deg,#28a745,#20c997)}.progress-percentage{background:var(--color-surface);color:var(--color-text-secondary);display:block;font-size:.75rem;padding:2px 6px;text-align:right;width:100%;z-index:10}.progress-text{color:var(--color-text-secondary);font-size:.85rem}.subgoals-section{border-top:1px solid var(--color-border);padding-top:20px}.subgoals-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.subgoals-header h4{color:var(--color-text-secondary);font-size:1.1rem;margin:0}.add-subgoal-form{background:var(--color-surface-muted);border-radius:8px;margin-bottom:16px;padding:16px}.subgoal-input{border:1px solid var(--color-input-border);border-radius:8px;font-size:14px;margin-bottom:12px;padding:8px 12px;width:100%}.subgoal-actions{gap:8px}.btn-primary{background:#007bff}.btn-primary,.btn-secondary{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px}.btn-secondary{background:#6c757d}.subgoals-list{display:flex;flex-direction:column;gap:12px}.subgoal-item{align-items:flex-start;background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:8px;display:flex;justify-content:space-between;padding:12px;transition:all .2s ease}.subgoal-item.completed{background:#d4edda;border-color:#c3e6cb}.completed-subgoals-accordion{border-top:1px solid var(--color-border);margin-top:8px;padding-top:8px}.completed-subgoals-toggle{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:8px;margin-bottom:8px;padding:8px 10px;transition:background .2s ease;width:100%}.completed-subgoals-toggle:hover{background:var(--color-surface-muted)}.completed-subgoals-toggle .completed-indicator{color:#16a34a;font-size:.85rem}.completed-subgoals-toggle .toggle-icon{color:var(--color-text-muted);font-size:.8rem;margin-left:auto;transition:transform .2s ease}.subgoal-content{flex:1 1}.subgoal-title{color:var(--color-text-primary);font-size:1rem;font-weight:500;margin:0 0 6px}.subgoal-description{color:var(--color-text-secondary);font-size:.9rem;line-height:1.4;margin:0}.subgoal-actions{display:flex;gap:4px;margin-left:8px}.todo-summary-container{align-items:center;display:flex;justify-content:center;margin-top:8px;padding:0 8px;width:100%}.subgoal-content .todo-summary-container{margin-left:0;margin-right:0}.goal-card-list{margin-bottom:12px;padding:16px 16px 24px;position:relative}.goal-list-content{align-items:center;display:flex;gap:16px;justify-content:space-between}.goal-list-main{align-items:center;display:flex;flex:1 1;gap:12px}.subgoal-action-btn.completion-btn{min-width:90px}.goal-list-actions{align-items:center;display:flex;flex-shrink:0;gap:8px;margin-left:16px}.goal-list-actions .completion-btn{align-items:center;border:2px solid #0000;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex!important;font-size:.8rem;font-weight:600;gap:6px;height:auto!important;min-width:auto!important;padding:8px 12px!important;text-decoration:none;transition:all .3s ease;white-space:nowrap;width:auto!important}.goal-list-actions .completion-btn.completed{background:linear-gradient(135deg,#d4edda,#c3e6cb)!important;border-color:#28a745;box-shadow:0 2px 4px #28a74533;color:#155724!important}.goal-list-actions .completion-btn:not(.completed){background:linear-gradient(135deg,#fff3cd,#ffeaa7)!important;border-color:#ffc107;box-shadow:0 2px 4px #ffc10733;color:#856404!important}.goal-list-actions .completion-btn:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.goal-list-actions .completion-btn.completed:hover{background:linear-gradient(135deg,#c3e6cb,#b1dfbb)!important;border-color:#20c997;box-shadow:0 4px 12px #28a7454d}.goal-list-actions .completion-btn:not(.completed):hover{background:linear-gradient(135deg,#ffeaa7,#fdcb6e)!important;border-color:#e17055;box-shadow:0 4px 12px #ffc1074d}.goal-list-actions .completion-btn:active{transform:translateY(0)}.btn-add-subgoal{align-items:center;background:linear-gradient(135deg,#17a2b8,#20c997);border:none;border-radius:8px;box-shadow:0 2px 4px #17a2b833;color:#fff;cursor:pointer;display:flex;font-size:.8rem;font-weight:600;gap:6px;padding:8px 12px;text-decoration:none;transition:all .3s ease;white-space:nowrap}.btn-add-subgoal:hover{background:linear-gradient(135deg,#138496,#1e7e34);box-shadow:0 4px 12px #17a2b84d;transform:translateY(-2px)}.btn-add-subgoal:active{box-shadow:0 2px 4px #17a2b833;transform:translateY(0)}.btn-delete-subtle{align-items:center;background:linear-gradient(135deg,var(--color-surface-muted),var(--color-border));border:1px solid var(--color-border);border-radius:8px;color:#6c757d;cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:6px;padding:8px 12px;text-decoration:none;transition:all .3s ease;white-space:nowrap}.btn-delete-subtle:hover{background:linear-gradient(135deg,#fff5f5,#ffe0e0);border-color:#f5c6cb;box-shadow:0 4px 12px #dc354526;color:#dc3545;transform:translateY(-2px)}.btn-delete-subtle:active{box-shadow:0 2px 4px #dc35451a;transform:translateY(0)}.delete-icon{font-size:.9rem;transition:transform .2s ease}.btn-delete-subtle:hover .delete-icon{transform:scale(1.1)}.delete-text{font-weight:600}.btn-favorite{align-items:center;background:#0000;border:1px solid #ffc107;border-radius:8px;cursor:pointer;display:flex;height:40px;justify-content:center;min-width:40px;padding:8px;transition:all .3s ease}.btn-favorite:hover{background:#fff3cd;border-color:#ffb302;box-shadow:0 2px 8px #ffc1074d;transform:translateY(-1px)}.btn-favorite.active{background:linear-gradient(135deg,#ffc107,#ffb302);border-color:#ffb302;color:#fff}.btn-favorite.active:hover{background:linear-gradient(135deg,#ffb302,#ffa000);box-shadow:0 3px 12px #ffc10766;transform:translateY(-1px)}.favorite-icon{font-size:1.2rem;transition:transform .2s ease}.btn-favorite:hover .favorite-icon{transform:scale(1.1)}.goal-card-modern{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 8px #00000014;overflow:hidden;padding:24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.goal-card-modern:hover{border-color:#007bff;box-shadow:0 8px 25px #0000001f}.goal-card-modern.completed{background:linear-gradient(135deg,#f8fff9,#f0f8f0);border-color:#28a745}.goal-card-header{margin-bottom:16px}.goal-title-row{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:12px}.goal-title-modern{color:var(--color-text-primary);flex:1 1;font-size:1.25rem;font-weight:600;line-height:1.3;margin:0}.goal-status-badge{flex-shrink:0}.goal-status-row{align-items:center;display:flex;flex-shrink:0;gap:8px}.action-btn-modern.favorite-header{background:#0000;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-secondary);font-size:.9rem;height:auto;padding:4px 8px;transition:all .2s ease;width:auto}.action-btn-modern.favorite-header.active{background:linear-gradient(135deg,#ffc107,#e0a800);border-color:#ffc107;color:#fff}.action-btn-modern.favorite-header:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.favorite-display{color:#ffc107;font-size:.9rem;padding:4px 8px}.status-completed{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:1px solid #28a745;border-radius:8px;color:#155724}.status-completed,.status-progress{font-size:.75rem;font-weight:500;padding:4px 12px}.status-progress{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #ffc107;border-radius:8px;color:#856404}.goal-meta-row{display:flex;flex-wrap:wrap;gap:12px}.goal-due-date-tag{background:#e3f2fd;border:1px solid #bbdefb;border-radius:8px;color:#1976d2;font-size:.75rem;font-weight:500;padding:4px 10px}.goal-description-section{margin-bottom:16px}.goal-description-modern{color:var(--color-text-secondary);font-size:.9rem;line-height:1.5;margin:0}.goal-progress-section{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:8px;margin-bottom:20px;padding:16px}.progress-label{font-weight:600}.progress-stats{color:var(--color-text-secondary);font-size:.8rem;font-weight:500}.progress-bar-modern{background-color:var(--color-border);border-radius:8px;height:8px;overflow:hidden;width:100%}.progress-fill-modern{background:linear-gradient(90deg,#007bff,#0056b3);border-radius:8px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.goal-card-modern.completed .progress-fill-modern{background:linear-gradient(90deg,#28a745,#20c997)}.goal-actions-section{align-items:center;display:flex;gap:12px;justify-content:space-between}.primary-actions{display:flex;flex:1 1;gap:8px}.secondary-actions{display:flex;gap:6px}.action-btn-modern{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:4px;justify-content:center;padding:8px 16px;transition:all .2s ease}.action-btn-modern.completion.completed{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.action-btn-modern.completion.pending{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.action-btn-modern.add-subgoal{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff}.action-btn-modern.favorite{background:var(--color-surface-muted);border:1px solid var(--color-border);color:var(--color-text-secondary);height:36px;padding:8px;width:36px}.action-btn-modern.favorite.active{background:linear-gradient(135deg,#ffc107,#e0a800);border-color:#ffc107;color:#fff}.action-btn-modern.delete{height:36px;padding:8px;width:36px}.action-btn-modern:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.add-subgoal-form-modern{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:8px;margin-top:20px;padding:20px}.form-group{margin-bottom:12px}.form-input-modern,.form-textarea-modern{background:var(--color-surface);border:1px solid var(--color-input-border);border-radius:8px;font-size:.9rem;padding:12px;transition:border-color .2s ease;width:100%}.form-input-modern:focus,.form-textarea-modern:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.form-actions{display:flex;gap:8px;justify-content:flex-end}.form-btn-primary{background:linear-gradient(135deg,#007bff,#0056b3)}.form-btn-primary,.form-btn-secondary{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:8px 16px;transition:all .2s ease}.form-btn-secondary{background:#6c757d}.form-btn-primary:hover,.form-btn-secondary:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.goal-card-loading-overlay{align-items:center;background:var(--color-overlay);border-radius:8px;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.goal-card-modern.loading,.goal-card.loading{pointer-events:none}@media (max-width:768px){.goal-card,.goal-card-modern{margin-bottom:12px;padding:12px}.goal-card-list{margin-bottom:8px;padding:12px 12px 16px}.goal-header{margin-bottom:12px}.goal-title-row,.goal-title-section{gap:8px;margin-bottom:8px}.subgoals-section{padding-top:12px}.subgoal-item{padding:8px}.subgoal-content{margin-right:8px}.add-subgoal-form,.add-subgoal-form-modern{margin-bottom:10px;padding:10px}.progress-section{margin-bottom:12px;padding-top:12px}.goal-progress-section{margin-bottom:12px;padding:10px}.todo-summary-container{margin-top:8px;padding:0 8px}.goal-actions{gap:6px;margin-left:8px}.goal-actions-section{align-items:center;flex-direction:row;flex-wrap:nowrap;gap:6px}.primary-actions,.secondary-actions{display:flex;flex:0 0 auto;gap:6px;width:auto}.action-btn-modern{flex:0 0 auto;padding:6px 12px}.edit-input,.form-input-modern,.form-textarea-modern{padding:10px}.goal-meta,.goal-meta-row{gap:8px;margin-bottom:12px}}.welcome-section{margin-bottom:15px;width:100%}.favorite-goals-section{border-top:1px solid var(--color-border);margin-top:15px;padding-top:15px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-title-icon{color:#fbbf24;margin-right:8px}.section-header h3{align-items:center;color:var(--color-text-primary);display:flex;font-size:1.5rem;font-weight:600;gap:8px;margin:0}.favorite-count{background:linear-gradient(135deg,#ffc107,#e0a800);border-radius:12px;color:#fff;font-size:.75rem;font-weight:500;margin-left:8px;padding:2px 10px}.view-all-goals-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:4px;padding:6px 10px;transition:background .2s ease;white-space:nowrap}.view-all-goals-btn:hover{background:var(--color-surface-muted)}.view-all-goals-btn svg{height:14px;width:14px}.favorite-goals-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.no-favorites-section{background:linear-gradient(135deg,#fefce8,#fef9c3);border:1px solid #fbbf2433;border-radius:20px;margin-top:24px;overflow:hidden;padding:40px 32px;position:relative}.no-favorites-section:before{background:linear-gradient(90deg,#fbbf24,#f59e0b,#d97706);content:"";height:3px;left:0;position:absolute;right:0;top:0}.no-favorites-content{align-items:center;display:flex;flex-direction:column;text-align:center}.no-favorites-icon{align-items:center;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;box-shadow:0 8px 24px #fbbf244d;display:flex;height:72px;justify-content:center;margin-bottom:20px;width:72px}.no-favorites-icon .star-icon{color:#fff;font-size:2rem}.no-favorites-title{color:#92400e;font-size:1.3rem;font-weight:700;margin:0 0 10px}.no-favorites-description{color:#a16207;font-size:1rem;line-height:1.5;margin:0 0 20px;max-width:350px}.no-favorites-tip{align-items:center;background:#fff9;border-radius:12px;color:#78350f;display:flex;font-size:.9rem;gap:8px;margin-bottom:24px;padding:12px 20px}.no-favorites-tip .tip-icon{color:#f59e0b;font-size:1.1rem}.no-favorites-cta{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:12px;box-shadow:0 4px 16px #f59e0b59;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:10px;padding:14px 28px;transition:all .3s ease}.no-favorites-cta:hover{box-shadow:0 8px 24px #f59e0b73;transform:translateY(-2px)}.no-favorites-cta .cta-icon{font-size:1.1rem}.home-empty-state{background:linear-gradient(135deg,var(--color-surface) 0,var(--color-surface-muted) 100%);border:1px solid #6366f11f;border-radius:24px;box-shadow:0 25px 60px #6366f11a,0 10px 30px #0000000d;margin-top:24px;overflow:hidden;padding:60px 40px;position:relative}.home-empty-state:before{background:linear-gradient(90deg,#6366f1,#8b5cf6 50%,#10b981);content:"";height:4px;left:0;position:absolute;right:0;top:0}.home-empty-state:after{background:radial-gradient(circle,#10b9810f 0,#0000 70%);bottom:-80px;content:"";height:250px;left:-80px;pointer-events:none;position:absolute;width:250px}.home-empty-content{align-items:center;display:flex;flex-direction:column;position:relative;text-align:center;z-index:1}.home-empty-visual{height:140px;margin-bottom:32px;position:relative;width:140px}.home-empty-visual .visual-backdrop{animation:pulse 3s ease-in-out infinite;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border-radius:50%;inset:0;position:absolute}.home-empty-visual .visual-icon-wrapper{align-items:center;background:var(--color-surface);border-radius:50%;box-shadow:0 8px 32px #6366f133;display:flex;inset:20px;justify-content:center;position:absolute}.home-empty-visual .visual-logo{filter:drop-shadow(0 2px 8px rgba(99,102,241,.3))}.home-empty-visual .visual-sparkle{animation:sparkle 2s ease-in-out infinite;color:#fbbf24;font-size:1rem;position:absolute}.home-empty-visual .sparkle-1{animation-delay:0s;right:15px;top:10px}.home-empty-visual .sparkle-2{animation-delay:.7s;left:5px;top:50%}.home-empty-visual .sparkle-3{animation-delay:1.4s;bottom:20px;right:10px}.home-empty-title{color:var(--color-text-primary);font-size:1.8rem;font-weight:700;margin:0 0 12px}.home-empty-description{color:var(--color-text-secondary);font-size:1.05rem;line-height:1.6;margin:0 0 36px;max-width:380px}.home-empty-features{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-bottom:40px}.home-empty-features .feature-item{align-items:center;background:linear-gradient(135deg,#6366f114,#8b5cf60d);border:1px solid #6366f11a;border-radius:12px;color:var(--color-text-secondary);display:flex;font-size:.95rem;font-weight:500;gap:10px;padding:12px 20px;transition:all .2s ease}.home-empty-features .feature-item:hover{background:linear-gradient(135deg,#6366f11f,#8b5cf614);box-shadow:0 4px 12px #6366f11f;transform:translateY(-2px)}.home-empty-features .feature-icon{color:#6366f1;font-size:1.1rem}.home-empty-buttons{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.home-empty-cta{align-items:center;border:none;border-radius:14px;color:#fff;cursor:pointer;display:inline-flex;font-size:1.05rem;font-weight:700;gap:10px;overflow:hidden;padding:16px 28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.home-empty-cta:before{background:linear-gradient(90deg,#0000,#ffffff40,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s;width:100%}.home-empty-cta:hover:before{left:100%}.home-empty-cta.cta-ai{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 8px 24px #6366f159,0 4px 8px #0000001a}.home-empty-cta.cta-ai:hover{box-shadow:0 12px 32px #6366f173,0 6px 12px #00000026;transform:translateY(-3px) scale(1.02)}.home-empty-cta.cta-manual{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 24px #10b98159,0 4px 8px #0000001a}.home-empty-cta.cta-manual:hover{box-shadow:0 12px 32px #10b98173,0 6px 12px #00000026;transform:translateY(-3px) scale(1.02)}.home-empty-cta .cta-icon{font-size:1.1rem}.home-empty-cta:hover{box-shadow:0 12px 32px #10b98173,0 6px 12px #00000026;transform:translateY(-3px) scale(1.02)}.cta-icon{font-size:1.2rem}@media (max-width:768px){.favorite-goals-grid{gap:0;grid-template-columns:1fr}.section-header{align-items:flex-start;flex-direction:row;gap:8px}.home-empty-state{border-radius:20px;margin-top:16px;padding:40px 24px}.home-empty-visual{height:110px;margin-bottom:24px;width:110px}.home-empty-visual .visual-icon-wrapper{inset:18px}.home-empty-title{font-size:1.4rem}.home-empty-description{font-size:.95rem;margin-bottom:28px}.home-empty-features{flex-direction:column;gap:10px;margin-bottom:32px}.home-empty-features .feature-item{font-size:.85rem;padding:10px 16px}.home-empty-buttons{flex-direction:column;gap:12px;width:100%}.home-empty-cta{font-size:.95rem;justify-content:center;padding:14px 24px;width:100%}.no-favorites-section{margin-top:16px;padding:32px 24px}.no-favorites-icon{height:60px;margin-bottom:16px;width:60px}.no-favorites-icon .star-icon{font-size:1.6rem}.no-favorites-title{font-size:1.15rem}.no-favorites-description{font-size:.9rem;margin-bottom:16px}.no-favorites-tip{font-size:.85rem;margin-bottom:20px;padding:10px 16px}.no-favorites-cta{font-size:.95rem;justify-content:center;padding:12px 24px;width:100%}}.goals-section{width:100%}.add-goal-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;box-shadow:0 4px 12px #6366f14d,0 2px 4px #0000001a;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:10px;overflow:hidden;padding:14px 24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.add-goal-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.add-goal-btn:hover:before{left:100%}.add-goal-btn:hover{box-shadow:0 8px 20px #6366f166,0 4px 8px #00000026;transform:translateY(-2px) scale(1.02)}.add-goal-btn.primary{background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;box-shadow:0 6px 16px #10b9814d,0 2px 4px #0000001a;font-size:1.2rem;font-weight:700;padding:18px 32px}.add-goal-btn.primary:hover{box-shadow:0 12px 24px #10b98166,0 6px 12px #00000026;transform:translateY(-3px) scale(1.03)}.goals-list{display:flex;flex-direction:column;gap:16px}.goals-empty-state{background:linear-gradient(135deg,var(--color-surface) 0,var(--color-surface-muted) 100%);border:1px solid #6366f11f;border-radius:24px;box-shadow:0 25px 60px #6366f11a,0 10px 30px #0000000d;overflow:hidden;padding:60px 40px;position:relative}.goals-empty-state:before{background:linear-gradient(90deg,#6366f1,#8b5cf6 50%,#10b981);content:"";height:4px;left:0;position:absolute;right:0;top:0}.goals-empty-content{align-items:center;display:flex;flex-direction:column;position:relative;text-align:center;z-index:1}.goals-empty-visual{height:140px;margin-bottom:32px;position:relative;width:140px}.visual-backdrop{animation:pulse 3s ease-in-out infinite;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border-radius:50%;inset:0;position:absolute}.visual-icon-wrapper{align-items:center;background:var(--color-surface);border-radius:50%;box-shadow:0 8px 32px #6366f133;display:flex;inset:20px;justify-content:center;position:absolute}.visual-logo{filter:drop-shadow(0 2px 8px rgba(99,102,241,.3))}.visual-sparkle{animation:sparkle 2s ease-in-out infinite;color:#fbbf24;font-size:1rem;position:absolute}.sparkle-1{animation-delay:0s;right:15px;top:10px}.sparkle-2{animation-delay:.7s;left:5px;top:50%}.sparkle-3{animation-delay:1.4s;bottom:20px;right:10px}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.goals-empty-title{color:var(--color-text-primary);font-size:1.8rem;font-weight:700;margin:0 0 12px}.goals-empty-description{color:var(--color-text-secondary);font-size:1.05rem;line-height:1.6;margin:0 0 36px;max-width:380px}.goals-empty-features{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-bottom:40px}.goals-empty-features .feature-item{align-items:center;background:linear-gradient(135deg,#6366f114,#8b5cf60d);border:1px solid #6366f11a;border-radius:12px;color:var(--color-text-secondary);display:flex;font-size:.95rem;font-weight:500;gap:10px;padding:12px 20px;transition:all .2s ease}.goals-empty-features .feature-item:hover{background:linear-gradient(135deg,#6366f11f,#8b5cf614);box-shadow:0 4px 12px #6366f11f;transform:translateY(-2px)}.goals-empty-features .feature-icon{color:#6366f1;font-size:1.1rem}.goals-empty-buttons{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.goals-empty-cta{align-items:center;border:none;border-radius:14px;color:#fff;cursor:pointer;display:inline-flex;font-size:1.05rem;font-weight:700;gap:10px;overflow:hidden;padding:16px 28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.goals-empty-cta:before{background:linear-gradient(90deg,#0000,#ffffff40,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s;width:100%}.goals-empty-cta:hover:before{left:100%}.goals-empty-cta.cta-ai{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 8px 24px #6366f159,0 4px 8px #0000001a}.goals-empty-cta.cta-ai:hover{box-shadow:0 12px 32px #6366f173,0 6px 12px #00000026;transform:translateY(-3px) scale(1.02)}.goals-empty-cta.cta-manual{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 8px 24px #10b98159,0 4px 8px #0000001a}.goals-empty-cta.cta-manual:hover{box-shadow:0 12px 32px #10b98173,0 6px 12px #00000026;transform:translateY(-3px) scale(1.02)}.goals-empty-cta .cta-icon{font-size:1.1rem}.empty-state{background:var(--gradient-surface);border:1px solid #6366f11a;border-radius:8px;box-shadow:0 20px 40px #0000000d,inset 0 1px 0 #ffffffe6;overflow:hidden;padding:80px 40px;position:relative;text-align:center}.empty-state:before{animation:rotate 20s linear infinite;background:radial-gradient(circle at 50% 50%,#6366f108 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}.empty-icon{animation:float 3s ease-in-out infinite;display:block;filter:drop-shadow(0 4px 12px rgba(99,102,241,.2));font-size:5rem;margin-bottom:32px;position:relative;z-index:2}.empty-state h3{color:var(--color-text-primary);font-size:1.8rem;font-weight:700;margin-bottom:16px;position:relative;z-index:2}.empty-state p{color:var(--color-text-secondary);font-size:1.2rem;line-height:1.6;margin-bottom:32px;position:relative;z-index:2}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;margin-bottom:20px;padding:16px}.retry-btn{background:#dc3545;border:none;border-radius:8px;color:#fff;cursor:pointer;margin-top:12px;padding:8px 16px;transition:all .3s ease}.retry-btn:hover{background:#c82333}.goals-with-subgoals-layout{display:flex;flex-direction:column;gap:32px}.goal-section{display:flex;flex-direction:column;gap:16px}.subgoals-grid-header{margin-bottom:16px}.subgoals-grid-header h4{align-items:center;color:var(--color-text-secondary);display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin:0}.subgoals-grid-header h4:before{content:"📋";font-size:1.2rem}.subgoals-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}@media (max-width:768px){.subgoals-cards{grid-template-columns:1fr}.subgoals-grid{margin-top:12px}.goals-empty-state{border-radius:20px;padding:40px 24px}.goals-empty-visual{height:110px;margin-bottom:24px;width:110px}.visual-icon-wrapper{inset:18px}.goals-empty-title{font-size:1.4rem}.goals-empty-description{font-size:.95rem;margin-bottom:28px}.goals-empty-features{flex-direction:column;gap:10px;margin-bottom:32px}.goals-empty-features .feature-item{font-size:.85rem;padding:10px 16px}.goals-empty-buttons{flex-direction:column;gap:12px;width:100%}.goals-empty-cta{font-size:.95rem;justify-content:center;padding:14px 24px;width:100%}}.subgoal-card{background:linear-gradient(135deg,var(--color-surface-muted) 0,var(--color-surface) 100%);border:2px solid var(--color-border);border-radius:8px;box-shadow:0 2px 8px #00000014;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.subgoal-card:before{background:linear-gradient(90deg,#007bff,#17a2b8);content:"";height:4px;left:0;opacity:.8;position:absolute;right:0;top:0}.subgoal-card.completed{background:linear-gradient(135deg,#d4edda,#f0f8f0);border-color:#c3e6cb}.subgoal-card.completed:before{background:linear-gradient(90deg,#28a745,#20c997)}.subgoal-card:hover{border-color:#007bff;box-shadow:0 6px 20px #00000026}.subgoal-card.clickable:hover{cursor:pointer}.subgoal-card.completed:hover{border-color:#28a745}.subgoal-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.subgoal-card-title{color:var(--color-text-primary);flex:1 1;font-size:1.1rem;font-weight:600;line-height:1.3;margin:0}.subgoal-card.completed .subgoal-card-title{color:#155724}.subgoal-card-actions{display:flex;flex-shrink:0;gap:6px}.subgoal-action-btn{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;display:flex;font-size:.85rem;gap:4px;justify-content:center;min-width:32px;padding:6px 8px;transition:all .2s ease}.subgoal-action-btn:hover{box-shadow:0 2px 8px #0000001a;transform:scale(1.05)}.manage-todos-btn{background:#e3f2fd;border-color:#90caf9;color:#1565c0}.manage-todos-btn:hover{background:#bbdefb;border-color:#42a5f5}.completion-btn{background:#fff3cd;border-color:#ffc107;color:#856404}.completion-btn.completed{background:#d4edda;border-color:#28a745;color:#155724}.completion-btn:hover{background:#ffeaa7}.completion-btn.completed:hover{background:#c3e6cb}.delete-btn{justify-content:center;min-width:40px}.todo-count{font-weight:500}.subgoal-card-description{color:var(--color-text-secondary);font-size:.9rem;line-height:1.4;margin:0 0 6px}.subgoal-card-progress{margin-bottom:0}.progress-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.progress-label{color:var(--color-text-secondary);font-size:.85rem;font-weight:500}.progress-percentage{color:var(--color-text-primary);font-size:.9rem;font-weight:600}.progress-bar{background:var(--color-border);border-radius:8px;height:6px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#007bff,#17a2b8);border-radius:8px;height:100%;transition:width .3s ease}.subgoal-card.completed .progress-fill{background:linear-gradient(90deg,#28a745,#20c997)}.subgoal-todos-summary{border-top:1px solid var(--color-border);padding-top:12px}.todos-stats{display:flex;gap:16px;justify-content:center}.todos-stats .stat{align-items:center;color:var(--color-text-secondary);display:flex;font-size:.8rem;font-weight:500;gap:4px}.subgoal-action-btn.completion-btn{align-items:center;border:2px solid #0000;border-radius:8px;display:flex!important;font-size:.75rem;font-weight:500;gap:4px;justify-content:center;min-width:85px;padding:6px 10px!important;transition:all .2s ease}.subgoal-action-btn.completion-btn.completed{background:linear-gradient(135deg,#d4edda,#c3e6cb)!important;border-color:#28a745;color:#155724!important}.subgoal-action-btn.completion-btn:not(.completed){background:linear-gradient(135deg,#fff3cd,#ffeaa7)!important;border-color:#ffc107;color:#856404!important}.subgoal-action-btn.completion-btn:hover{box-shadow:0 2px 6px #0000001f;transform:translateY(-1px)}.subgoal-action-btn.completion-btn.completed:hover{background:linear-gradient(135deg,#c3e6cb,#b1dfbb)!important;border-color:#20c997}.subgoal-action-btn.completion-btn:not(.completed):hover{background:linear-gradient(135deg,#ffeaa7,#fdcb6e)!important;border-color:#e17055}.goals-simple-layout{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.goal-card-wrapper{display:contents}@media (max-width:576px){.subgoal-card-header{align-items:stretch;flex-direction:column;gap:8px}.subgoal-card-actions{justify-content:flex-end}.todos-stats{flex-direction:row;gap:8px}}@media (max-width:768px){.subgoal-action-btn.completion-btn{min-width:32px;padding:6px!important}.subgoal-action-btn .completion-text{display:none}.goals-simple-layout{gap:8px;grid-template-columns:1fr}.empty-state{padding:60px 24px}.empty-icon{font-size:4rem}}@media (max-width:480px){.empty-state{padding:48px 20px}.empty-icon{font-size:3.5rem}.empty-state h3{font-size:1.5rem}.empty-state p{font-size:1.1rem}}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.fullscreen-modal{align-items:center;animation:fadeIn .5s ease-out;background:linear-gradient(135deg,#0f0f23,#1a1a3a 50%,#2d1b69);display:flex;height:100vh;justify-content:center;left:0;overflow:hidden;position:fixed;top:0;width:100vw;z-index:1000}body:has(.fullscreen-modal){height:100vh;overflow:hidden}.fullscreen-modal:before{animation:backgroundFloat 20s ease-in-out infinite;background:radial-gradient(circle at 20% 80%,#7877c64d 0,#0000 50%),radial-gradient(circle at 80% 20%,#ff77c633 0,#0000 50%),radial-gradient(circle at 40% 40%,#78dbff1a 0,#0000 50%);content:"";height:100%;left:0;position:absolute;top:0;width:100%}.fullscreen-content{box-sizing:border-box;flex-direction:column;height:100vh;margin:0;overflow:hidden;padding:0;position:relative;text-align:center;width:100vw;z-index:2}.close-fullscreen-btn,.fullscreen-content{align-items:center;color:#fff;display:flex;justify-content:center}.close-fullscreen-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:50%;cursor:pointer;font-size:1.5rem;height:50px;position:fixed;right:20px;top:20px;transition:all .3s ease;width:50px;z-index:1001}.close-fullscreen-btn:hover{background:#fff3;transform:scale(1.1)}.fullscreen-center{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;gap:6vh;height:100vh;justify-content:center;padding:20px;width:100%}.time-display{flex-shrink:0;text-align:center}.current-time{animation:timeGlow 2s ease-in-out infinite alternate;color:#fff;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif;font-size:clamp(2.5rem,6vw,5rem);font-weight:300;letter-spacing:-2px;line-height:1;margin:0;text-shadow:0 4px 20px #00000080}.current-date{color:#fffc;font-size:clamp(.9rem,2.5vw,1.2rem);font-weight:400;margin:10px 0 0;text-transform:capitalize}.quote-section{flex-shrink:0;max-width:90%;text-align:center}.quote-icon{font-size:clamp(1.5rem,4vw,2.5rem);margin-bottom:15px}.inspirational-quote{color:#fff;font-size:clamp(1rem,3vw,1.8rem);font-style:italic;font-weight:400;letter-spacing:.3px;line-height:1.3;margin:0;text-shadow:0 2px 10px #0000004d}.goals-summary{text-align:center}.summary-title{color:#fff;font-size:1.8rem;font-weight:600;margin-bottom:30px;text-shadow:0 2px 10px #0000004d}.summary-stats{display:flex;gap:40px;justify-content:center}.summary-item{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;min-width:120px;padding:25px 30px;text-align:center;transition:all .3s ease}.summary-item:hover{background:#ffffff26;box-shadow:0 10px 30px #0003;transform:translateY(-5px)}.summary-number{color:#fff;display:block;font-size:2.5rem;font-weight:700;margin-bottom:8px;text-shadow:0 2px 10px #0000004d}.summary-label{color:#fffc;display:block;font-size:1rem;font-weight:500;letter-spacing:1px;text-transform:uppercase}.active-goals{max-width:500px;text-align:center;width:100%}.active-goals-title{color:#fff;font-size:1.5rem;font-weight:600;margin-bottom:25px;text-shadow:0 2px 10px #0000004d}.active-goals-list{display:flex;flex-direction:column;gap:15px}.active-goal-item{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff14;border:1px solid #ffffff1a;border-radius:8px;display:flex;gap:15px;padding:15px 20px;transition:all .3s ease}.active-goal-item:hover{background:#ffffff1f;transform:translateX(10px)}.goal-emoji{font-size:1.5rem}.goal-title{color:#fff;font-size:1.1rem;font-weight:500;text-align:left}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes backgroundFloat{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(5deg)}}@keyframes timeGlow{0%{text-shadow:0 4px 20px #00000080}to{text-shadow:0 4px 20px #00000080,0 0 30px #ffffff4d}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width:768px){.fullscreen-center{gap:4vh;padding:15px}.close-fullscreen-btn{font-size:1.3rem;height:45px;right:15px;top:15px;width:45px}}@media (max-width:480px){.fullscreen-center{gap:3vh;padding:10px}.close-fullscreen-btn{font-size:1.2rem;height:40px;right:10px;top:10px;width:40px}}@media (max-height:600px){.fullscreen-center{gap:2vh}.quote-icon{margin-bottom:8px}}@media (max-height:500px){.fullscreen-center{gap:1vh}}.app-shell{background:var(--gradient-surface);color:var(--color-text-primary);display:flex;flex-direction:column;isolation:isolate;min-height:100vh}.app-shell:before{background:var(--gradient-brand);opacity:.08;z-index:-1}.app-shell:after,.app-shell:before{content:"";inset:0;pointer-events:none;position:fixed}.app-shell:after{background:radial-gradient(circle at 15% 20%,#6200ea14,#0000 45%),radial-gradient(circle at 80% 0,#1890ff14,#0000 40%),radial-gradient(circle at 20% 80%,#10b9810f,#0000 45%);z-index:-2}.app-shell main{flex:1 1;overflow-x:hidden;width:100%}.app-shell .main-content{-webkit-padding-after:var(--spacing-xl);margin-inline:auto;padding-block-end:var(--spacing-xl);padding-inline:var(--spacing-xl);transition:padding .3s ease;width:min(1200px,100%)}.app-shell .main-content.nav-fixed{padding-inline:var(--spacing-xl)}@media (max-width:768px){.app-shell .main-content,.app-shell .main-content.nav-fixed{-webkit-padding-after:var(--spacing-lg);padding-block-end:var(--spacing-lg);padding-inline:var(--spacing-lg)}}@media (max-width:480px){.app-shell .main-content,.app-shell .main-content.nav-fixed{-webkit-padding-after:var(--spacing-md);padding-block-end:var(--spacing-md);padding-inline:var(--spacing-md)}}:root{--todo-title-font-size:1rem;--todo-title-line-height:1.4;--todo-title-font-weight:600;--todo-title-color:var(--color-text-primary,#212529);--todo-title-margin:0 0 8px 0;--danger-button-bg:linear-gradient(135deg,#ff8989,#ff9595);--danger-button-hover-bg:linear-gradient(135deg,#ef4444,#b91c1c);--danger-button-border:#e76464;--danger-button-hover-border:#ea7a7a;--danger-button-color:#fff;--danger-button-shadow:0 10px 24px #dc262640;--danger-button-hover-shadow:0 14px 32px #b91c1c59;--danger-button-disabled-bg:linear-gradient(135deg,#fca5a5,#f87171)}.todo-title{color:#212529;color:var(--todo-title-color,var(--color-text-primary,#212529));font-size:1rem;font-size:var(--todo-title-font-size,1rem);font-weight:600;font-weight:var(--todo-title-font-weight,600);line-height:1.4;line-height:var(--todo-title-line-height,1.4);margin:0 0 8px;margin:var(--todo-title-margin,0 0 8px 0)}.action-btn-modern.delete,.action-btn.delete-btn-improved,.action-btn.delete-subgoal-btn,.danger-button,.delete-btn,.delete-btn-improved,.delete-button,.delete-subgoal-btn,.subgoal-action-btn.delete-btn{background:linear-gradient(135deg,#ff8989,#ff9595);background:var(--danger-button-bg);border:1px solid #e76464;border:1px solid var(--danger-button-border);box-shadow:0 10px 24px #dc262640;box-shadow:var(--danger-button-shadow);color:#fff;color:var(--danger-button-color);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.action-btn-modern.delete:hover,.action-btn.delete-btn-improved:hover,.action-btn.delete-subgoal-btn:hover,.danger-button:hover,.delete-btn-improved:hover,.delete-btn:hover,.delete-button:hover,.delete-subgoal-btn:hover,.subgoal-action-btn.delete-btn:hover{background:linear-gradient(135deg,#ef4444,#b91c1c);background:var(--danger-button-hover-bg);border-color:#ea7a7a;border-color:var(--danger-button-hover-border);box-shadow:0 14px 32px #b91c1c59;box-shadow:var(--danger-button-hover-shadow);color:#fff;transform:translateY(-1px)}.action-btn-modern.delete:disabled,.action-btn.delete-btn-improved:disabled,.action-btn.delete-subgoal-btn:disabled,.danger-button:disabled,.delete-btn-improved:disabled,.delete-btn:disabled,.delete-button:disabled,.delete-subgoal-btn:disabled,.subgoal-action-btn.delete-btn:disabled{background:linear-gradient(135deg,#fca5a5,#f87171);background:var(--danger-button-disabled-bg);border-color:#e76464;border-color:var(--danger-button-border);box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}
/*# sourceMappingURL=main.1abfaffa.css.map*/