@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&display=swap";:root{--font-heading: "Bricolage Grotesque", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--brutal-border: 3px;--brutal-radius: 6px;--brutal-shadow: 4px 4px 0 0;--brutal-shadow-sm: 2px 2px 0 0;--primary: #2563EB;--primary-hover: #1d4ed8;--primary-light: #EFF6FF;--secondary: #0ea5e9;--bg-color: #FFFBF5;--surface: #ffffff;--text-main: #0f172a;--text-muted: #475569;--border: #0f172a;--success: #059669;--danger: #dc2626;--accent: #f59e0b;--radius-sm: 6px;--radius-md: 6px;--radius-lg: 8px;--shadow-sm: 2px 2px 0 0 var(--border);--shadow-md: 4px 4px 0 0 var(--border);--shadow-lg: 6px 6px 0 0 var(--border);--glass-bg: #ffffff;--glass-border: var(--border)}.theme-light{--primary: #2563EB;--primary-hover: #1d4ed8;--primary-light: #EFF6FF;--bg-color: #FFFBF5;--surface: #ffffff;--text-main: #0f172a;--text-muted: #475569;--border: #0f172a;--glass-bg: #ffffff}.theme-midnight{--primary: #818cf8;--primary-hover: #6366f1;--primary-light: #312e81;--bg-color: #0f172a;--surface: #1e293b;--text-main: #f8fafc;--text-muted: #94a3b8;--border: #f8fafc;--glass-bg: #1e293b}.theme-nord{--primary: #88c0d0;--primary-hover: #81a1c1;--primary-light: #3b4252;--bg-color: #2e3440;--surface: #3b4252;--text-main: #eceff4;--text-muted: #d8dee9;--border: #eceff4;--glass-bg: #3b4252}.theme-cyberpunk{--primary: #f43f5e;--primary-hover: #e11d48;--primary-light: #4c1d1d;--bg-color: #0a0a0a;--surface: #1a1a1a;--text-main: #ffffff;--text-muted: #a1a1aa;--border: #f43f5e;--glass-bg: #1a1a1a}.theme-forest{--primary: #059669;--primary-hover: #047857;--primary-light: #d1fae5;--bg-color: #f0fdf4;--surface: #ffffff;--text-main: #064e3b;--text-muted: #047857;--border: #064e3b;--glass-bg: #ffffff}*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background-color:var(--bg-color);color:var(--text-main);line-height:1.6;overflow-x:hidden;min-height:100vh;transition:background-color .3s ease,color .3s ease;font-size:16px}.app{min-height:100vh;background:var(--bg-color)}.container{max-width:1400px;margin:0 auto;padding:0 2rem}.header{background:var(--glass-bg);border-bottom:var(--brutal-border) solid var(--border);padding:1rem 0;position:sticky;top:0;z-index:100;transition:all .3s ease}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:.75rem}.logo img{width:40px;height:40px;border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius)}.brand-name{font-family:var(--font-heading);font-weight:800;font-size:1.5rem;letter-spacing:-.03em;color:var(--text-main)}.nav{display:flex;align-items:center;gap:1.5rem}.theme-quick-switch{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem;background:var(--surface);border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);box-shadow:var(--brutal-shadow-sm) var(--border)}.theme-dot{width:20px;height:20px;border-radius:4px;cursor:pointer;border:2px solid var(--border);transition:transform .15s}.theme-dot:hover{transform:scale(1.2)}.theme-dot.active{border-width:3px;transform:scale(1.1)}.theme-dot.theme-light{background-color:#6366f1}.theme-dot.theme-midnight{background-color:#8b5cf6}.theme-dot.theme-nord{background-color:#88c0d0}.theme-dot.theme-cyberpunk{background-color:#f43f5e}.theme-dot.theme-forest{background-color:#10b981}.user-profile{display:flex;align-items:center;gap:.75rem;font-weight:600;color:var(--text-main)}.user-profile img{width:36px;height:36px;border-radius:var(--brutal-radius);object-fit:cover;border:2px solid var(--border)}.user-name{font-size:.95rem}.tab-switcher{display:flex;background:var(--surface);padding:.35rem;border-radius:var(--brutal-radius);gap:.25rem;border:var(--brutal-border) solid var(--border);box-shadow:var(--brutal-shadow-sm) var(--border)}.tab-btn{font-family:var(--font-heading);padding:.5rem 1.25rem;border-radius:4px;border:none;font-size:.9rem;font-weight:700;color:var(--text-muted);background:transparent;cursor:pointer;transition:all .15s}.tab-btn.active{background:var(--primary);color:#fff;border:2px solid var(--border);box-shadow:var(--brutal-shadow-sm) var(--border)}.settings-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:var(--brutal-radius);background:var(--surface);border:var(--brutal-border) solid var(--border);cursor:pointer;color:var(--text-main);transition:all .15s;box-shadow:var(--brutal-shadow-sm) var(--border)}.settings-btn:hover{color:var(--primary);background:var(--primary-light);transform:translate(-1px,-1px);box-shadow:3px 3px 0 0 var(--border)}.settings-btn:active{transform:translate(2px,2px);box-shadow:none}.dashboard{padding:2rem 0 3rem}.calendar-header{display:flex;align-items:center;justify-content:center;gap:2.5rem;margin-bottom:3rem}.calendar-header h2{font-family:var(--font-heading);font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--text-main)}.nav-icon{padding:.6rem;border-radius:var(--brutal-radius);background:var(--surface);border:var(--brutal-border) solid var(--border);transition:all .15s;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--brutal-shadow-sm) var(--border)}.nav-icon:hover{background:var(--primary);color:#fff;transform:translate(-2px,-2px);box-shadow:4px 4px 0 0 var(--border)}.nav-icon:active{transform:translate(2px,2px);box-shadow:none}.habits-table-container{background:var(--surface);border-radius:var(--brutal-radius);border:var(--brutal-border) solid var(--border);box-shadow:var(--brutal-shadow) var(--border);overflow-x:auto;margin-bottom:2.5rem}.habits-table{width:100%;border-collapse:separate;border-spacing:0}.habits-table th{font-family:var(--font-heading);background:var(--bg-color);color:var(--text-main);font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;padding:1rem .75rem;border-bottom:var(--brutal-border) solid var(--border)}.habits-table td{padding:.875rem .5rem;border-bottom:2px solid var(--border);text-align:center;background:var(--surface)}.habit-name-col{text-align:left!important;padding-left:3rem!important;min-width:240px}.monthly-table th{padding:.5rem 2px!important;font-size:.65rem!important}.monthly-table td{padding:.5rem 2px!important}.monthly-table .check-box{width:20px!important;height:20px!important}.monthly-table .habit-name-col,.monthly-table .habit-name{min-width:160px!important;font-size:.875rem!important;padding-left:3rem!important}.monthly-table .stat-col{min-width:40px!important;font-size:.75rem!important}.monthly-table .stat-val{font-size:.8rem}.habit-name{text-align:left!important;padding-left:3rem!important;font-weight:600;font-size:.95rem;color:var(--text-main);background:var(--surface);position:sticky;left:0;z-index:10}.habit-row-info{display:flex;align-items:center;justify-content:space-between;gap:1rem}.delete-habit-icon{color:var(--text-muted);opacity:0;transition:opacity .2s;cursor:pointer}.habit-name:hover .delete-habit-icon{opacity:.5}.delete-habit-icon:hover{opacity:1!important;color:var(--danger)}.check-box{width:26px;height:26px;border-radius:4px;border:var(--brutal-border) solid var(--border);margin:0 auto;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;background:var(--surface)}.check-box:hover{background:var(--primary-light)}.check-box.active{background:var(--primary);border-color:var(--border);box-shadow:var(--brutal-shadow-sm) var(--border)}.stat-col{background:var(--bg-color);min-width:80px}.stat-val{font-weight:700;color:var(--text-main)}.achieved{color:var(--primary)!important;background:var(--primary-light)}.category-row{background:var(--bg-color)!important}.monthly-table .category-cell{padding:1rem 1.5rem 1rem 3rem!important;font-size:1rem!important;text-align:left!important;border-bottom:2px solid var(--border)!important}.category-cell strong{color:var(--text-main);margin-right:.75rem}.category-count-monthly{color:var(--text-muted);font-size:.875rem;font-weight:400}.add-habit-btn{font-family:var(--font-heading);display:flex;align-items:center;gap:.5rem;background:var(--surface);border:var(--brutal-border) dashed var(--border);color:var(--text-muted);padding:1rem 2rem;border-radius:var(--brutal-radius);width:100%;justify-content:center;font-weight:700;transition:all .15s;cursor:pointer}.add-habit-btn:hover{border-style:solid;color:var(--primary);background:var(--primary-light);box-shadow:var(--brutal-shadow-sm) var(--border)}.daily-view{max-width:800px;margin:0 auto}.daily-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.daily-greeting{font-family:var(--font-heading);font-size:1.875rem;font-weight:800;margin:0 0 .25rem;letter-spacing:-.02em}.daily-date{color:var(--text-muted);font-size:1rem}.daily-focus-total{font-family:var(--font-heading);display:flex;flex-direction:column;align-items:center;padding:.75rem 1.5rem;background:var(--primary);border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);color:#fff;box-shadow:var(--brutal-shadow-sm) var(--border)}.daily-focus-total span{font-weight:700;font-size:1.25rem}.daily-focus-total small{font-size:.75rem;opacity:.8}.daily-subtabs{display:flex;gap:0;margin-bottom:2rem;border-bottom:var(--brutal-border) solid var(--border)}.daily-subtab{font-family:var(--font-heading);padding:.75rem 1.5rem;background:none;border:none;font-weight:700;font-size:.95rem;color:var(--text-muted);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-3px;transition:all .15s}.daily-subtab:hover{color:var(--text-main)}.daily-subtab.active{color:var(--primary);border-bottom-color:var(--primary)}.timeline-view{min-height:200px}.timeline-list{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;align-items:center;gap:1rem;padding:1rem 0;position:relative}.timeline-dot{width:14px;height:14px;border-radius:4px;border:2px solid var(--border);background:var(--primary);flex-shrink:0;z-index:1}.timeline-line{position:absolute;left:5px;top:32px;bottom:-1rem;width:3px;background:var(--border)}.timeline-content{display:flex;justify-content:space-between;align-items:center;flex:1}.timeline-duration{font-family:var(--font-heading);color:var(--primary);font-weight:700}.empty-state{font-family:var(--font-body);text-align:center;color:var(--text-muted);padding:3rem;font-size:1rem}.daily-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:800;margin-bottom:2rem;text-align:center}.daily-habits-list{display:flex;flex-direction:column;gap:1rem}.daily-habit-item{background:var(--surface);padding:1.25rem 1.5rem;border-radius:var(--brutal-radius);border:var(--brutal-border) solid var(--border);display:flex;gap:1rem;align-items:center;transition:all .15s;box-shadow:var(--brutal-shadow-sm) var(--border)}.daily-habit-item:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 0 var(--border)}.daily-habit-info{flex:1}.daily-habit-info h4{font-family:var(--font-heading);font-size:1.125rem;font-weight:700}.daily-habit-info p{font-size:.875rem;color:var(--text-muted)}.daily-habit-item .check-box{margin-left:auto}.daily-habit-item.skipped{opacity:.6}.habit-duration{color:var(--primary)}.habit-actions{display:flex;align-items:center;gap:.5rem}.habit-action-btn{padding:.35rem!important}.focus-timer{display:flex;align-items:center;gap:.5rem}.focus-timer-icon{color:var(--text-muted)}.focus-timer-display{font-family:var(--font-heading);font-weight:700;min-width:4ch}.priority-toggle{display:flex;gap:.5rem}.priority-btn{font-family:var(--font-heading);flex:1;padding:.75rem;border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);background:var(--surface);cursor:pointer;font-weight:700;transition:all .15s}.priority-btn:hover{background:var(--primary-light)}.priority-btn.active{background:var(--primary);color:#fff}.category-priority-breakdown{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.category-section{margin-bottom:2.5rem}.category-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:var(--brutal-border) solid var(--border)}.category-header h3{font-family:var(--font-heading);font-size:1.25rem;font-weight:800;color:var(--text-main);margin:0}.category-badge{font-family:var(--font-heading);background:var(--primary);color:#fff;padding:.3rem .75rem;border-radius:var(--brutal-radius);font-size:.75rem;font-weight:700;border:2px solid var(--border)}.category-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);margin-top:.35rem;max-height:200px;overflow-y:auto;box-shadow:var(--brutal-shadow) var(--border);z-index:10}.category-suggestion-item{padding:.75rem 1rem;cursor:pointer;transition:background .2s;color:var(--text-main)}.category-suggestion-item:hover{background:var(--primary-light)}.category-list{display:flex;flex-direction:column;gap:.75rem}.category-item-manage{background:var(--surface);border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);padding:1rem;box-shadow:var(--brutal-shadow-sm) var(--border)}.category-info-row{display:flex;justify-content:space-between;align-items:center}.category-info-row strong{font-family:var(--font-heading);font-size:1rem;font-weight:700;color:var(--text-main);margin-right:.5rem}.category-count{font-size:.875rem;color:var(--text-muted);margin-left:.5rem}.category-actions{display:flex;gap:.5rem}.icon-btn{background:var(--surface);border:var(--brutal-border) solid var(--border);padding:.5rem;border-radius:var(--brutal-radius);cursor:pointer;color:var(--text-main);transition:all .15s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.icon-btn.danger:hover{background:#ef44441a;border-color:var(--danger);color:var(--danger)}.category-edit-row{display:flex;gap:.5rem;align-items:center}.category-edit-row .custom-input{flex:1}.settings-overlay{position:fixed;inset:0;background:#0f172a99;z-index:1000;display:flex;align-items:center;justify-content:center;overflow-y:auto;padding:2rem}.settings-modal{background:var(--surface);width:100%;max-width:500px;max-height:calc(100vh - 4rem);border-radius:var(--brutal-radius);padding:2rem;box-shadow:8px 8px 0 0 var(--border);display:flex;flex-direction:column;gap:2rem;border:var(--brutal-border) solid var(--border);color:var(--text-main);overflow-y:auto;margin:auto}.settings-header{display:flex;justify-content:space-between;align-items:center}.settings-header h3{font-family:var(--font-heading);font-size:1.25rem;font-weight:800}.clickable{cursor:pointer;padding:.35rem;border-radius:var(--brutal-radius);border:var(--brutal-border) solid transparent;transition:all .15s}.clickable:hover{background:var(--primary-light);border-color:var(--border)}.settings-section h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.theme-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.theme-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:var(--brutal-radius);border:var(--brutal-border) solid var(--border);cursor:pointer;transition:all .15s;background:var(--surface);color:var(--text-main)}.theme-item:hover{background:var(--primary-light)}.theme-item.active{background:var(--primary);color:#fff}.theme-pill{width:24px;height:24px;border-radius:4px;border:2px solid var(--border)}.theme-item span{font-size:.875rem;font-weight:600}.drag-handle{cursor:grab;color:var(--text-muted);padding:1rem;display:flex;align-items:center;touch-action:none}.drag-handle:active{cursor:grabbing;color:var(--primary)}.daily-habit-item.dragging{opacity:.5;background:var(--bg-color);border:var(--brutal-border) dashed var(--border);box-shadow:none}.daily-habit-item.drag-overlay{background:var(--surface);border:var(--brutal-border) solid var(--primary);box-shadow:6px 6px 0 0 var(--border);transform:scale(1.02);cursor:grabbing;z-index:9999}@media(max-width:1024px){.habits-table-container{cursor:ew-resize}}@media(max-width:640px){.features-grid{grid-template-columns:1fr;gap:1rem}.landing-content{padding:2rem 1.5rem}.logo-large h1{font-size:2.25rem}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-muted)}.custom-input{padding:.75rem 1rem;border-radius:var(--brutal-radius);border:var(--brutal-border) solid var(--border);background:var(--surface);color:var(--text-main);font-family:var(--font-body);font-size:1rem;outline:none;transition:all .15s}.custom-input:focus{box-shadow:0 0 0 3px var(--primary-light)}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}.primary-btn{font-family:var(--font-heading);background:var(--primary);color:#fff;padding:.75rem 1.5rem;border-radius:var(--brutal-radius);border:var(--brutal-border) solid var(--border);font-weight:700;cursor:pointer;transition:all .15s;box-shadow:var(--brutal-shadow-sm) var(--border)}.primary-btn:hover{background:var(--primary-hover);transform:translate(-2px,-2px);box-shadow:4px 4px 0 0 var(--border)}.primary-btn:active{transform:translate(2px,2px);box-shadow:none}.secondary-btn{font-family:var(--font-heading);background:var(--surface);color:var(--text-main);padding:.75rem 1.5rem;border-radius:var(--brutal-radius);border:var(--brutal-border) solid var(--border);font-weight:700;cursor:pointer;transition:all .15s;box-shadow:var(--brutal-shadow-sm) var(--border)}.secondary-btn:hover{background:var(--primary-light);transform:translate(-2px,-2px);box-shadow:4px 4px 0 0 var(--border)}.landing-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-color)}.landing-content{max-width:560px;width:100%;text-align:center;background:var(--surface);padding:3rem;border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);box-shadow:8px 8px 0 0 var(--border)}.logo-large{margin-bottom:2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.landing-logo{width:80px;height:80px;border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);box-shadow:var(--brutal-shadow-sm) var(--border)}.logo-large h1{font-family:var(--font-heading);font-size:2.75rem;font-weight:800;letter-spacing:-.04em;color:var(--text-main);line-height:1.1}.landing-subtitle{font-family:var(--font-body);font-size:1.125rem;color:var(--text-muted);line-height:1.7;margin-bottom:2.5rem;font-weight:500}.login-btn{font-family:var(--font-heading);width:100%;max-width:320px;margin:0 auto 2.5rem;display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:1.125rem;font-weight:700;padding:1rem 2rem;border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);box-shadow:var(--brutal-shadow) var(--border)}.login-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--border)}.login-btn:active{transform:translate(2px,2px);box-shadow:none}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding-top:2rem;border-top:var(--brutal-border) solid var(--border)}.feature-item{font-family:var(--font-heading);display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem 1rem;background:var(--surface);border:var(--brutal-border) solid var(--border);border-radius:var(--brutal-radius);font-size:.85rem;font-weight:700;color:var(--text-main);box-shadow:var(--brutal-shadow-sm) var(--border);transition:all .15s}.feature-item:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 0 var(--border)}
