*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0c0c0f;--bg2:#131316;--bg3:#1c1c21;--surface:#17171c;--surface-hover:#212127;--surface-border:#28282f;--text:#f0f0f3;--text2:#9d9da5;--text3:#6b6b74;--text-muted:#44444c;--accent:#7c5cfc;--accent-muted:#6248d4;--accent-soft:#7c5cfc1f;--success:#32d74b;--success-muted:#32d74b26;--warning:#ffd60a;--warning-muted:#ffd60a26;--error:#ff453a;--error-muted:#ff453a26;--hm0:#17171c;--hm1:#1e1a2e;--hm2:#2d2550;--hm3:#453b78;--hm4:#6248d4;--hm5:#7c5cfc;--safe:#32d74b;--rough:#ff453a;--sidebar-w:260px;--radius-sm:6px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--transition:.2s cubic-bezier(.4, 0, .2, 1)}html.light{--bg:#f5f5f8;--bg2:#ebebef;--bg3:#e0e0e6;--surface:#fff;--surface-hover:#f0f0f4;--surface-border:#d4d4da;--text:#18181b;--text2:#5c5c66;--text3:#8c8c96;--text-muted:#c4c4cc;--accent:#6b4ed6;--accent-muted:#7c5cfc;--accent-soft:#6b4ed614;--success:#248a3d;--success-muted:#248a3d1f;--warning:#b25000;--warning-muted:#b250001f;--error:#d70015;--error-muted:#d700151f;--hm0:#e0e0e6;--hm1:#e8e4f5;--hm2:#d0c4f0;--hm3:#b0a0e4;--hm4:#8b74d8;--hm5:#6b4ed6;--safe:#248a3d;--rough:#d70015}html{font-size:15px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(110vh)rotate(720deg)}}.app-layout{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;display:grid}.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--surface-border);z-index:100;height:100vh;transition:transform var(--transition);flex-direction:column;padding:24px 16px;display:flex;position:fixed;top:0;left:0}.sidebar-logo{border-bottom:1px solid var(--surface-border);align-items:center;gap:10px;margin-bottom:24px;padding:0 8px 24px;display:flex}.logo-icon{background:var(--accent);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;font-weight:800;display:flex}.logo-text{letter-spacing:1.5px;text-transform:uppercase;color:var(--text);font-size:18px;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.nav-item{border-radius:var(--radius-md);cursor:pointer;color:var(--text2);transition:all var(--transition);-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;display:flex}.nav-item:hover{background:var(--surface-hover);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--accent)}.nav-item.active .nav-icon{color:var(--accent)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:16px;display:flex}.sidebar-shortcuts{flex-direction:column;gap:4px;margin-top:auto;padding:8px 16px;display:flex}.sidebar-shortcut-pill{border-radius:var(--radius-md);color:var(--text3);cursor:pointer;transition:all var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:500;display:flex}.sidebar-shortcut-pill:hover{background:var(--surface-hover);color:var(--text)}.sidebar-profile{border-top:1px solid var(--surface-border);padding-top:16px}.profile-card{border-radius:var(--radius-md);align-items:center;gap:12px;padding:10px 8px;display:flex}.profile-avatar{background:var(--accent-soft);width:36px;height:36px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.profile-info{flex:1;min-width:0}.profile-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.profile-level{color:var(--text3);margin-top:2px;font-size:11px}.xp-bar-container{background:var(--surface-border);border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.xp-bar-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .5s}.sidebar-logout{color:var(--text3);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);text-align:center;margin-top:12px;padding:8px 12px;font-size:12px}.sidebar-logout:hover{color:var(--error);background:var(--error-muted)}.mobile-toggle{z-index:200;background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-sm);cursor:pointer;width:40px;height:40px;color:var(--text);justify-content:center;align-items:center;font-size:20px;display:none;position:fixed;top:16px;left:16px}.sidebar-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}.main-content{grid-column:2;width:100%;max-width:1400px;padding:32px 40px}.topbar{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.topbar-left h1{color:var(--text);margin-bottom:4px;font-size:24px;font-weight:700}.topbar-left .date-line{color:var(--text3);font-size:13px}.topbar-right{align-items:center;gap:8px;display:flex}.admin-sidebar .logo-icon.admin-logo-icon{background:var(--error)}.admin-sidebar .nav-item.admin-active{background:var(--error-muted);color:var(--error)}.admin-sidebar .nav-item.admin-active .nav-icon{color:var(--error)}@media (width<=1024px){.stats-row{grid-template-columns:repeat(2,1fr)}.content-grid{grid-template-columns:1fr}}@media (width<=768px){.app-layout{grid-template-columns:1fr}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay.open{display:block}.mobile-toggle{display:flex}.main-content{grid-column:1;padding:64px 16px 24px}.stats-row{grid-template-columns:1fr 1fr}.topbar{flex-direction:column;gap:12px}.bar-chart{height:120px}.heatmap{grid-template-rows:repeat(7,11px);grid-auto-columns:11px;gap:2px}.heatmap-cell{width:11px;height:11px}}@media (width<=480px){.stats-row{grid-template-columns:1fr}.main-content{padding:64px 12px 16px}}.topbar-icon-btn{border:1px solid var(--surface-border);background:var(--surface);width:36px;height:36px;color:var(--text2);cursor:pointer;transition:all var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex}.topbar-icon-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--accent)}.topbar-icon-btn.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);transition:all var(--transition);padding:20px}.card:hover{border-color:var(--text-muted)}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text);font-size:14px;font-weight:600}.card-subtitle{color:var(--text3);font-size:12px}.stats-row{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);transition:all var(--transition);padding:20px;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--text-muted);transform:translateY(-2px)}.stat-card:after{content:"";background:var(--accent);opacity:0;height:2px;transition:opacity var(--transition);position:absolute;top:0;left:0;right:0}.stat-card:hover:after{opacity:1}.stat-label{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:500}.stat-value{color:var(--text);font-size:28px;font-weight:800;line-height:1.1}.stat-sub{color:var(--text3);margin-top:4px;font-size:12px}.stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex;position:absolute;top:16px;right:16px}.stat-icon.streak{background:var(--warning-muted);color:var(--warning)}.stat-icon.best{background:var(--success-muted);color:var(--success)}.stat-icon.rate,.stat-icon.level{background:var(--accent-soft);color:var(--accent)}.stat-icon.freeze{color:#64b4ff;background:#64b4ff26}.content-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px;display:grid}.content-grid.full{grid-template-columns:1fr}.habit-list{flex-direction:column;gap:6px;display:flex}.habit-item{border-radius:var(--radius-md);background:var(--bg2);transition:all var(--transition);cursor:default;border:1px solid #0000;align-items:center;gap:12px;padding:12px 14px;display:flex}.habit-item:hover{background:var(--surface-hover);border-color:var(--surface-border)}.habit-check{border:2px solid var(--surface-border);width:22px;height:22px;transition:all var(--transition);cursor:pointer;color:#0000;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.habit-check:hover{border-color:var(--accent)}.habit-check.checked{background:var(--accent);border-color:var(--accent);color:#fff}.habit-check.quit-checked{background:var(--success);border-color:var(--success);color:#fff}.habit-info{flex:1;min-width:0}.habit-name{color:var(--text);cursor:pointer;font-size:14px;font-weight:500}.habit-name:hover{color:var(--accent)}.habit-meta{color:var(--text3);margin-top:2px;font-size:11px}.habit-actions-inline{flex-shrink:0;align-items:center;gap:4px;display:flex}.habit-actions-inline .btn-icon{width:26px;height:26px;color:var(--text3);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:13px;display:flex}.habit-actions-inline .btn-icon:hover{background:var(--surface-hover);color:var(--text)}.time-group-header{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;padding:8px 0 4px;font-size:12px;font-weight:600;display:flex}.time-group-header:not(:first-child){margin-top:12px}.quote-banner{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);margin-bottom:24px;padding:16px 20px}.quote-banner .quote-text{color:var(--text);font-size:14px;font-style:italic;line-height:1.6}.quote-banner .quote-author{color:var(--text3);margin-top:6px;font-size:12px}.quote-banner .quote-category{text-transform:uppercase;letter-spacing:.5px;background:var(--accent-soft);color:var(--accent);border-radius:4px;margin-top:8px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.todo-input-row{gap:8px;margin-bottom:12px;display:flex}.todo-input-row input{background:var(--bg);border:1px solid var(--surface-border);border-radius:var(--radius-sm);color:var(--text);transition:border-color var(--transition);outline:none;flex:1;padding:8px 12px;font-family:inherit;font-size:13px}.todo-input-row input:focus{border-color:var(--accent)}.todo-item{border-radius:var(--radius-sm);transition:background var(--transition);align-items:center;gap:10px;padding:8px 10px;display:flex}.todo-item:hover{background:var(--surface-hover)}.todo-item.completed .todo-text{color:var(--text3);text-decoration:line-through}.todo-text{color:var(--text);flex:1;font-size:13px}.todo-delete{width:22px;height:22px;color:var(--text3);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:14px;display:flex}.todo-delete:hover{color:var(--error);background:var(--error-muted)}.table-action-btn{border:1px solid var(--surface-border);color:var(--text2);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:4px;margin-right:4px;padding:4px 10px;font-size:11px;font-weight:500}.table-action-btn:hover{border-color:var(--accent);color:var(--accent)}.table-action-btn.danger:hover{border-color:var(--error);color:var(--error)}.reorder-btn{color:var(--text3);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:3px;padding:2px 6px;font-size:12px}.reorder-btn:hover{background:var(--surface-hover);color:var(--text)}.sparkline-container{margin-top:10px}.sparkline-container svg{display:block}.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:16px;margin-bottom:32px;display:grid}.achievement-card{background:var(--surface);border:2px solid var(--surface-border);border-radius:var(--radius-md);text-align:center;transition:all var(--transition);padding:16px}.achievement-card.earned{border-color:var(--accent)}.achievement-card.locked{opacity:.4}.achievement-icon{margin-bottom:8px;font-size:32px}.achievement-title{color:var(--text);font-size:13px;font-weight:600}.achievement-msg{color:var(--text3);margin-top:4px;font-size:11px}.achievement-days{color:var(--accent);margin-top:4px;font-size:11px;font-weight:600}.mini-heatmap{grid-template-rows:repeat(7,10px);grid-auto-columns:10px;grid-auto-flow:column;gap:2px;margin-top:12px;display:grid}.mini-heatmap-cell{border-radius:2px;width:10px;height:10px}.day-chip{border:1px solid var(--surface-border);width:32px;height:32px;color:var(--text2);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.day-chip:hover{border-color:var(--text3)}.day-chip.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.sync-status{color:var(--text3);min-height:18px;margin-top:8px;font-size:12px}.btn-success{background:var(--success-muted);color:var(--success)}.btn-success:hover{opacity:.8}.habit-streak{color:var(--warning);flex-shrink:0;align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.habit-type-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:600}.badge-daily{background:var(--accent-soft);color:var(--accent)}.badge-numeric{background:var(--warning-muted);color:var(--warning)}.badge-quit{background:var(--error-muted);color:var(--error)}.bar-chart{align-items:flex-end;gap:8px;height:160px;padding-top:8px;display:flex}.bar-wrapper{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:6px;height:100%;display:flex}.bar{background:var(--accent);width:100%;max-width:48px;transition:height .5s ease, opacity var(--transition);opacity:.7;border-radius:6px 6px 2px 2px;min-height:2px;position:relative}.bar:hover{opacity:1}.bar-label{color:var(--text3);font-size:11px;font-weight:500}.bar-value{color:var(--text2);font-size:11px;font-weight:600}.timeline{flex-direction:column;gap:0;display:flex}.timeline-item{gap:14px;padding:12px 0;display:flex;position:relative}.timeline-item:not(:last-child):after{content:"";background:var(--surface-border);width:1px;position:absolute;top:36px;bottom:-2px;left:11px}.timeline-dot{z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;display:flex}.timeline-dot.completed{background:var(--success-muted);color:var(--success)}.timeline-dot.slip{background:var(--error-muted);color:var(--error)}.timeline-content{flex:1}.timeline-text{color:var(--text);font-size:13px}.timeline-text strong{font-weight:600}.timeline-time{color:var(--text3);margin-top:2px;font-size:11px}.table-controls{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.filter-btn{border:1px solid var(--surface-border);border-radius:var(--radius-sm);color:var(--text2);cursor:pointer;transition:all var(--transition);background:0 0;padding:6px 14px;font-size:12px;font-weight:500}.filter-btn:hover{border-color:var(--text3);color:var(--text)}.filter-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.habits-table{border-collapse:separate;border-spacing:0;width:100%}.habits-table th{text-align:left;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--surface-border);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:600}.habits-table th:hover{color:var(--text)}.habits-table th.sorted{color:var(--accent)}.habits-table th .sort-arrow{opacity:.5;margin-left:4px;font-size:10px}.habits-table th.sorted .sort-arrow{opacity:1}.habits-table td{color:var(--text);border-bottom:1px solid var(--surface-border);transition:background var(--transition);padding:12px 14px;font-size:13px}.habits-table tr:hover td{background:var(--surface-hover)}.habits-table .status-active{color:var(--success)}.habits-table .status-archived{color:var(--text3)}.heatmap-container{padding-bottom:8px;overflow-x:auto}.heatmap{grid-template-rows:repeat(7,14px);grid-auto-columns:14px;grid-auto-flow:column;gap:3px;display:grid}.heatmap-cell{width:14px;height:14px;transition:all var(--transition);cursor:default;border-radius:3px;position:relative}.heatmap-cell:hover{z-index:1;transform:scale(1.3)}.heatmap-legend{justify-content:flex-end;align-items:center;gap:4px;margin-top:12px;display:flex}.heatmap-legend-label{color:var(--text3);margin-right:4px;font-size:11px}.heatmap-legend-cell{border-radius:2px;width:12px;height:12px}.tooltip{background:var(--bg2);border:1px solid var(--surface-border);border-radius:var(--radius-sm);color:var(--text);pointer-events:none;z-index:1000;white-space:nowrap;padding:6px 10px;font-size:12px;display:none;position:fixed;box-shadow:0 4px 12px #0000004d}.tooltip.visible{display:block}.monthly-chart{align-items:flex-end;gap:6px;height:180px;display:flex}.monthly-bar-wrapper{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:6px;height:100%;display:flex}.monthly-bar{width:100%;max-width:40px;transition:height .5s ease, opacity var(--transition);opacity:.75;border-radius:4px 4px 2px 2px;min-height:2px}.monthly-bar:hover{opacity:1}.breakdown-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.breakdown-card{background:var(--bg2);border:1px solid var(--surface-border);border-radius:var(--radius-md);transition:all var(--transition);cursor:pointer;padding:16px}.breakdown-card:hover{border-color:var(--text-muted)}.breakdown-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.breakdown-name{font-size:14px;font-weight:600}.breakdown-rate{color:var(--accent);font-size:20px;font-weight:800}.mini-bar-track{background:var(--surface-border);border-radius:3px;height:6px;margin-top:8px;overflow:hidden}.mini-bar-fill{border-radius:3px;height:100%;transition:width .5s}.breakdown-stats{color:var(--text3);gap:16px;margin-top:10px;font-size:12px;display:flex}.settings-section{margin-bottom:32px}.settings-section h3{color:var(--text);margin-bottom:16px;font-size:16px;font-weight:600}.setting-row{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-md);transition:all var(--transition);justify-content:space-between;align-items:center;margin-bottom:8px;padding:14px 16px;display:flex}.setting-row:hover{border-color:var(--text-muted)}.setting-label{font-size:14px;font-weight:500}.setting-desc{color:var(--text3);margin-top:2px;font-size:12px}.setting-value{color:var(--text2);align-items:center;gap:8px;font-size:13px;display:flex}.toggle{background:var(--surface-border);cursor:pointer;width:44px;height:24px;transition:background var(--transition);border-radius:12px;position:relative}.toggle.on{background:var(--accent)}.toggle:after{content:"";width:20px;height:20px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px}.toggle.on:after{transform:translate(20px)}.text-input{background:var(--bg);border:1px solid var(--surface-border);border-radius:var(--radius-sm);color:var(--text);transition:border-color var(--transition);outline:none;padding:8px 12px;font-family:inherit;font-size:13px}.text-input:focus{border-color:var(--accent)}textarea.text-input{resize:vertical;width:100%;min-height:150px;font-family:SF Mono,Fira Code,monospace;font-size:12px;line-height:1.5}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:6px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-muted);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{color:var(--text2);border:1px solid var(--surface-border);background:0 0}.btn-ghost:hover{border-color:var(--text3);color:var(--text)}.btn-danger{background:var(--error-muted);color:var(--error)}.btn-danger:hover{opacity:.8}.btn-sm{padding:5px 12px;font-size:12px}.auth-screen{justify-content:center;align-items:center;min-height:100vh;padding:40px;display:flex}.auth-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-xl);width:100%;max-width:440px;padding:48px}.auth-card .logo-icon{width:56px;height:56px;margin:0 auto 20px;font-size:24px}.auth-card h1{text-align:center;margin-bottom:6px;font-size:24px;font-weight:700}.auth-card .auth-subtitle{color:var(--text2);text-align:center;margin-bottom:28px;font-size:14px}.auth-field{margin-bottom:16px}.auth-field label{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.auth-field input{background:var(--bg);border:1px solid var(--surface-border);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:border-color var(--transition);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.auth-field input:focus{border-color:var(--accent)}.auth-error{background:var(--error-muted);color:var(--error);border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 14px;font-size:13px;display:none}.auth-actions{flex-direction:column;gap:10px;margin-top:8px;display:flex}.auth-actions .btn{justify-content:center;width:100%;padding:12px}.auth-toggle{text-align:center;color:var(--text3);margin-top:20px;font-size:13px}.auth-toggle a{color:var(--accent);cursor:pointer;font-weight:600;text-decoration:none}.auth-toggle a:hover{text-decoration:underline}.auth-divider{color:var(--text3);align-items:center;gap:12px;margin:20px 0;font-size:12px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--surface-border);flex:1;height:1px}.spinner{border:2px solid var(--surface-border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}.loading-overlay{min-height:100vh;color:var(--text3);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:14px;display:flex}.modal-overlay{z-index:500;background:#0009;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}#confirm-modal{z-index:600}.modal{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-xl);width:90%;max-width:480px;max-height:90vh;padding:32px;overflow-y:auto}.modal h2{margin-bottom:20px;font-size:18px;font-weight:700}.modal .auth-field{margin-bottom:14px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.modal.wide{max-width:600px}.chip-group{flex-wrap:wrap;gap:6px;display:flex}.chip{border:1px solid var(--surface-border);color:var(--text2);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:500}.chip:hover{border-color:var(--text3)}.chip.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.view-section{animation:.25s fadeIn;display:none}.view-section.active{display:block}.empty-state{text-align:center;color:var(--text3);padding:24px 16px}.empty-state h3{color:var(--text2);margin-bottom:4px;font-size:14px;font-weight:500}.empty-state p{margin-bottom:0;font-size:12px}.section-title{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;font-size:14px;font-weight:600}.auth-field select{background:var(--bg);border:1px solid var(--surface-border);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:border-color var(--transition);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.auth-field select:focus{border-color:var(--accent)}.mode-badge{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.mode-badge:hover{opacity:.8}.mode-sabr{background:var(--success-muted);color:var(--safe)}.mode-mujahada{background:var(--error-muted);color:var(--rough)}.divider{background:var(--surface-border);height:1px;margin:24px 0}.fade-text{color:var(--text3)}.prayer-banner{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);justify-content:space-between;align-items:center;margin-bottom:16px;padding:14px 20px;display:flex}.prayer-banner:hover{border-color:var(--text-muted)}.prayer-banner-left{align-items:center;gap:12px;display:flex}.prayer-banner-icon{font-size:20px}.prayer-banner-name{color:var(--text);font-size:14px;font-weight:600}.prayer-banner-time{color:var(--text2);font-size:13px}.prayer-banner-countdown{color:var(--accent);font-size:13px;font-weight:600}.prayer-times-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:16px;display:grid}.prayer-time-item{background:var(--bg2);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.prayer-time-item.next-prayer{background:var(--accent-soft);border:1px solid var(--accent)}.prayer-time-name{color:var(--text);font-size:13px;font-weight:600}.prayer-time-value{color:var(--text2);font-size:13px}.dua-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);margin-bottom:16px;padding:16px 20px}.dua-card:hover{border-color:var(--text-muted)}.dua-card-header{justify-content:space-between;align-items:center;display:flex}.dua-card-title{color:var(--text);font-size:13px;font-weight:600}.dua-card-source{color:var(--text3);font-size:11px}.dua-card-toggle{color:var(--text3);transition:transform var(--transition);font-size:14px}.dua-card-toggle.open{transform:rotate(180deg)}.dua-card-body{margin-top:16px;display:none}.dua-card-body.open{display:block}.dua-arabic{text-align:center;color:var(--text);direction:rtl;margin-bottom:12px;font-family:Traditional Arabic,Amiri,serif;font-size:22px;line-height:2}.dua-transliteration{color:var(--text2);margin-bottom:8px;font-size:13px;font-style:italic;line-height:1.6}.dua-translation{color:var(--text);margin-bottom:8px;font-size:13px;line-height:1.6}.dua-source-badge{text-transform:uppercase;letter-spacing:.5px;background:var(--accent-soft);color:var(--accent);border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.ramadan-banner{background:linear-gradient(135deg, var(--accent-soft), #ffd60a14);border:1px solid var(--accent);border-radius:var(--radius-lg);margin-bottom:16px;padding:20px}.ramadan-banner-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.ramadan-banner-title{color:var(--text);font-size:16px;font-weight:700}.ramadan-banner-day{color:var(--accent);font-size:13px;font-weight:600}.ramadan-progress-bar{background:var(--surface-border);border-radius:3px;height:6px;margin-bottom:10px;overflow:hidden}.ramadan-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .5s}.ramadan-banner-msg{color:var(--text2);margin-bottom:12px;font-size:13px;line-height:1.5}.ramadan-iftar{color:var(--warning);margin-bottom:8px;font-size:12px;font-weight:600}.onboarding-overlay{background:var(--bg);z-index:600;flex-direction:column;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.onboarding-overlay.open{display:flex}.onboarding-dots{justify-content:center;gap:8px;margin-bottom:32px;display:flex}.onboarding-dot{background:var(--surface-border);width:8px;height:8px;transition:all var(--transition);border-radius:50%}.onboarding-dot.active{background:var(--accent);width:24px}.onboarding-step{text-align:center;width:90%;max-width:500px;padding:20px;display:none}.onboarding-step.active{display:block}.onboarding-bismillah{color:var(--accent);margin-bottom:24px;font-size:22px;font-weight:600}.onboarding-title{color:var(--text);margin-bottom:8px;font-size:28px;font-weight:700}.onboarding-subtitle{color:var(--text2);margin-bottom:24px;font-size:15px;line-height:1.5}.onboarding-input{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-md);width:100%;color:var(--text);transition:border-color var(--transition);outline:none;margin-bottom:24px;padding:12px 16px;font-family:inherit;font-size:16px}.onboarding-input:focus{border-color:var(--accent)}.onboarding-btn{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;width:100%;transition:all var(--transition);border:none;padding:14px;font-family:inherit;font-size:16px;font-weight:600}.onboarding-btn:hover{background:var(--accent-muted)}.onboarding-btn:disabled{opacity:.4;cursor:not-allowed}.mode-cards{gap:16px;margin-bottom:24px;display:flex}.mode-card{background:var(--surface);border:2px solid var(--surface-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);text-align:center;flex:1;padding:20px}.mode-card:hover{border-color:var(--text-muted)}.mode-card.selected{border-color:var(--accent)}.mode-card-icon{margin-bottom:8px;font-size:28px}.mode-card-label{color:var(--text);margin-bottom:4px;font-size:16px;font-weight:700}.mode-card-desc{color:var(--text2);font-size:12px;line-height:1.5}.pack-grid{text-align:center;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:24px;display:grid}.pack-card{background:var(--surface);border:2px solid var(--surface-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);padding:16px 10px}.pack-card:hover{border-color:var(--text-muted)}.pack-card.selected{border-color:var(--accent)}.pack-card-icon{margin-bottom:6px;font-size:24px}.pack-card-name{color:var(--text);margin-bottom:2px;font-size:13px;font-weight:600}.pack-card-count{color:var(--text3);font-size:11px}.onboarding-skip{color:var(--text2);cursor:pointer;background:0 0;border:none;margin-top:12px;font-family:inherit;font-size:14px;font-weight:500}.onboarding-skip:hover{color:var(--text)}.template-tags{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.template-tag-chip{border:1px solid var(--surface-border);color:var(--text2);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:500}.template-tag-chip:hover{border-color:var(--text3)}.template-tag-chip.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.template-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;max-height:50vh;display:grid;overflow-y:auto}.template-pack-card{background:var(--bg2);border:1px solid var(--surface-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);padding:16px;position:relative;overflow:hidden}.template-pack-card:hover{border-color:var(--text-muted)}.template-pack-card:after{content:"";background:0 0;height:3px;transition:background .2s;position:absolute;top:0;left:0;right:0}.template-pack-card:hover:after{background:var(--accent)}.template-pack-name{color:var(--text);margin-bottom:4px;font-size:14px;font-weight:600}.template-pack-desc{color:var(--text3);margin-bottom:8px;font-size:12px;line-height:1.4}.template-pack-meta{align-items:center;gap:8px;display:flex}.template-pack-badge{text-transform:uppercase;letter-spacing:.5px;background:var(--accent-soft);color:var(--accent);border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.template-pack-habits{color:var(--text3);font-size:11px}.template-detail-list{margin:16px 0;padding:0;list-style:none}.template-detail-list li{background:var(--bg2);border-radius:var(--radius-sm);color:var(--text);justify-content:space-between;margin-bottom:6px;padding:8px 12px;font-size:13px;display:flex}.template-detail-list li span{color:var(--text3);font-size:11px}.template-icon-circle{background:var(--accent-soft);border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:10px;font-size:20px;display:flex}.template-search{margin-bottom:12px}.template-search input{background:var(--bg2);border:1px solid var(--surface-border);border-radius:var(--radius-md);width:100%;color:var(--text);outline:none;padding:8px 12px;font-family:inherit;font-size:13px}.template-search input:focus{border-color:var(--accent)}.template-install-warning{color:var(--warning);background:var(--warning-muted);border-radius:var(--radius-sm);margin-bottom:8px;padding:8px 12px;font-size:12px}.habit-type-icon{align-items:center;gap:4px;display:inline-flex}.quotes-tabs{background:var(--bg2);border-radius:var(--radius-md);gap:2px;margin-bottom:16px;padding:3px;display:flex}.quotes-tab{border-radius:var(--radius-sm);cursor:pointer;color:var(--text3);transition:all var(--transition);flex:1;justify-content:center;align-items:center;gap:4px;padding:8px;font-size:13px;font-weight:600;display:flex}.quotes-tab.active{background:var(--surface);color:var(--text)}.quotes-tab.active .quotes-tab-icon{color:var(--accent)}.quotes-search{background:var(--surface);border-radius:var(--radius-lg);align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;display:flex}.quotes-search input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:14px}.quotes-category-chips{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.quote-card-item{background:var(--surface);border-radius:var(--radius-md);transition:all var(--transition);align-items:flex-start;gap:12px;margin-bottom:8px;padding:14px;display:flex}.quote-card-item:hover{background:var(--surface-hover)}.quote-card-body{flex:1}.quote-card-text{color:var(--text);font-size:14px;font-weight:500;line-height:1.5}.quote-card-author{color:var(--text3);margin-top:4px;font-size:12px}.quote-fav-btn{cursor:pointer;color:var(--text3);transition:color var(--transition);background:0 0;border:none;flex-shrink:0;padding:4px;font-size:16px}.quote-fav-btn.active{color:var(--accent)}.quotes-write-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px}.quotes-write-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:6px;font-size:11px;font-weight:600}.quotes-write-input{background:var(--bg2);border:1px solid var(--surface-border);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:border-color var(--transition);outline:none;margin-bottom:12px;padding:10px 12px;font-family:inherit;font-size:14px}.quotes-write-input:focus{border-color:var(--accent)}textarea.quotes-write-input{resize:vertical;min-height:80px}.quotes-modal-scroll{max-height:55vh;padding-right:4px;overflow-y:auto}.quotes-tabs-bar{border-bottom:1px solid var(--surface-border);gap:0;margin-bottom:16px;display:flex}.quotes-tab-btn{color:var(--text3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 0;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.quotes-tab-btn:hover{color:var(--text2)}.quotes-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.quote-border-quran{border-left:3px solid #50c878;padding-left:12px}.quote-border-hadith{border-left:3px solid #6bc5d2;padding-left:12px}.quote-border-general{border-left:3px solid var(--surface-border);padding-left:12px}.quote-empty-hint{text-align:center;color:var(--text-muted);padding:24px;font-size:13px;line-height:1.5}.quote-pin-btn{border:1px solid var(--accent);color:var(--accent);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;background:0 0;padding:3px 10px;font-family:inherit;font-size:10px;font-weight:600;transition:all .2s}.quote-pin-btn:hover{background:var(--accent);color:#fff}.reflection-entry{background:var(--surface);border-radius:var(--radius-md);margin-bottom:8px;padding:12px 14px}.reflection-entry-header{justify-content:space-between;align-items:center;display:flex}.reflection-entry-date{color:var(--text);align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.reflection-entry-date .check-icon{color:var(--accent);font-size:14px}.reflection-entry-value{color:var(--text3);font-size:11px}.reflection-edit-btn{cursor:pointer;color:var(--accent);background:0 0;border:none;padding:2px;font-size:16px}.reflection-note{color:var(--text2);margin-top:8px;font-size:13px;line-height:1.5}.reflection-edit-area{background:var(--bg2);border:1px solid var(--surface-border);border-radius:var(--radius-sm);width:100%;min-height:60px;color:var(--text);resize:vertical;outline:none;margin-top:8px;padding:10px;font-family:inherit;font-size:13px}.reflection-edit-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.share-preview{text-align:center;margin:16px 0}.share-preview canvas{border-radius:var(--radius-md);max-width:100%}.btn-icon-journal{width:26px;height:26px;color:var(--text3);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:13px;display:flex}.btn-icon-journal:hover{background:var(--surface-hover);color:var(--accent)}.streak-risk-banner{background:var(--warning-muted);border:1px solid var(--warning);border-radius:var(--radius-lg);color:var(--warning);align-items:center;gap:12px;margin-bottom:16px;padding:14px 20px;font-size:14px;font-weight:500;display:flex}.streak-risk-banner-icon{flex-shrink:0;font-size:20px}.streak-risk-banner-text{flex:1}.confetti-container{pointer-events:none;z-index:9999;width:100vw;height:100vh;position:fixed;top:0;left:0;overflow:hidden}.confetti-piece{border-radius:2px;width:10px;height:10px;animation:3s ease-in forwards confettiFall;position:absolute;top:-20px}.milestone-modal-content{text-align:center;padding:16px 0}.milestone-icon{margin-bottom:16px;font-size:56px}.milestone-title{color:var(--text);margin-bottom:8px;font-size:24px;font-weight:800}.milestone-message{color:var(--text2);margin-bottom:24px;font-size:15px;line-height:1.6}.about-section{text-align:center;border-top:1px solid var(--surface-border);margin-top:16px;padding:32px 16px}.about-app-name{color:var(--text);letter-spacing:1.5px;text-transform:uppercase;font-size:16px;font-weight:700}.about-version{color:var(--text3);margin-top:4px;font-size:12px}.about-desc{color:var(--text2);margin-top:8px;font-size:13px}.about-tagline{color:var(--text-muted);margin-top:12px;font-size:11px;font-style:italic}.activity-ring-container{justify-content:center;align-items:center;padding:20px 0;display:flex}.activity-ring-svg{transform:rotate(-90deg)}.activity-ring-text{fill:var(--text);dominant-baseline:central;text-anchor:middle;transform-origin:50%;font-size:32px;font-weight:800;transform:rotate(90deg)}.activity-ring-label{fill:var(--text3);dominant-baseline:central;text-anchor:middle;transform-origin:50%;font-size:12px;transform:rotate(90deg)}.viz-toggle{background:var(--bg2);border-radius:20px;gap:2px;padding:3px;display:flex}.viz-toggle-btn{color:var(--text3);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:18px;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:500}.viz-toggle-btn:hover{color:var(--text2)}.viz-toggle-btn.active{background:var(--accent-soft);color:var(--accent)}.weekly-review-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.weekly-review-mood{font-size:28px}.weekly-review-stats{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:16px;display:grid}.weekly-review-stat{text-align:center}.weekly-review-stat-value{color:var(--text);font-size:20px;font-weight:800}.weekly-review-stat-label{color:var(--text3);margin-top:2px;font-size:11px}.weekly-review-days{align-items:flex-end;gap:6px;height:80px;padding-top:8px;display:flex}.weekly-review-day{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;height:100%;display:flex}.weekly-review-day-bar{background:var(--accent);opacity:.75;border-radius:4px 4px 2px 2px;width:100%;max-width:36px;min-height:2px;transition:height .5s}.weekly-review-day-label{color:var(--text3);font-size:11px;font-weight:500}.weekly-review-day-count{color:var(--text2);font-size:10px;font-weight:600}.weekly-review-habit-row{justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;display:flex}.weekly-review-habit-row+.weekly-review-habit-row{border-top:1px solid var(--surface-border)}.weekly-review-habit-name{color:var(--text);font-weight:500}.weekly-review-habit-pct{font-weight:700}.groups-list{flex-direction:column;gap:10px;display:flex}.group-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);justify-content:space-between;align-items:center;gap:14px;padding:16px 20px;display:flex}.group-card:hover{border-color:var(--text-muted);transform:translateY(-1px)}.group-card-info{flex:1;min-width:0}.group-card-name{color:var(--text);margin-bottom:2px;font-size:15px;font-weight:600}.group-card-desc{color:var(--text3);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.group-card-members{color:var(--text3);white-space:nowrap;align-items:center;gap:4px;font-size:12px;display:flex}.group-card-code{color:var(--text-muted);letter-spacing:1px;margin-top:2px;font-family:monospace;font-size:10px}.group-card-avatar{background:var(--accent-soft);width:40px;height:40px;color:var(--accent);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.group-detail-header{margin-bottom:20px}.group-detail-name{color:var(--text);margin-bottom:4px;font-size:20px;font-weight:700}.group-detail-desc{color:var(--text2);margin-bottom:8px;font-size:13px}.group-detail-meta{color:var(--text3);gap:16px;margin-bottom:16px;font-size:12px;display:flex}.invite-code-box{background:var(--bg2);border:1px solid var(--surface-border);border-radius:var(--radius-sm);align-items:center;gap:8px;margin-bottom:20px;padding:8px 12px;display:flex}.invite-code-value{color:var(--accent);flex:1;font-family:SF Mono,Fira Code,monospace;font-size:14px;font-weight:600}.invite-code-copy{border:1px solid var(--surface-border);color:var(--text2);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:4px;padding:4px 10px;font-size:11px;font-weight:500}.invite-code-copy:hover{border-color:var(--accent);color:var(--accent)}.leaderboard-table{border-collapse:separate;border-spacing:0;width:100%;margin-bottom:20px}.leaderboard-table th{text-align:left;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--surface-border);padding:8px 12px;font-size:11px;font-weight:600}.leaderboard-table td{color:var(--text);border-bottom:1px solid var(--surface-border);padding:10px 12px;font-size:13px}.leaderboard-table tr:hover td{background:var(--surface-hover)}.leaderboard-rank{color:var(--accent);font-weight:800}.group-actions{gap:8px;margin-top:8px;display:flex}.groups-empty-cta{justify-content:center;gap:10px;margin-top:20px;display:flex}.groups-empty-stat{color:var(--accent);margin-top:12px;font-size:13px;font-weight:500}.goals-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;margin-bottom:12px;display:flex}.goals-section-header:hover .goals-chevron{color:var(--text)}.goals-section-title{color:var(--text);font-size:14px;font-weight:600}.goals-count-badge{background:var(--accent-soft);color:var(--accent);text-align:center;border-radius:10px;min-width:20px;padding:1px 8px;font-size:11px;font-weight:700}.goals-chevron{color:var(--text3);transition:transform var(--transition), color var(--transition);margin-left:auto;font-size:12px}.goals-chevron.collapsed{transform:rotate(-90deg)}.goals-add-btn{border:1px solid var(--surface-border);color:var(--text2);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:600}.goals-add-btn:hover{border-color:var(--accent);color:var(--accent)}.goals-list{flex-direction:column;gap:6px;display:flex}.goal-card{border-radius:var(--radius-md);background:var(--bg2);transition:all var(--transition);cursor:pointer;border:1px solid #0000;align-items:center;gap:12px;padding:12px 14px;display:flex}.goal-card:hover{background:var(--surface-hover);border-color:var(--surface-border)}.goal-card-info{flex:1;min-width:0}.goal-card-title{color:var(--text);font-size:14px;font-weight:500}.goal-card-meta{align-items:center;gap:8px;margin-top:4px;display:flex}.goal-badge{text-transform:uppercase;letter-spacing:.5px;background:var(--accent-soft);color:var(--accent);border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.goal-days-left{color:var(--text3);font-size:11px}.goal-progress-track{background:var(--surface-border);border-radius:2px;flex-shrink:0;width:100%;height:4px;margin-top:8px;overflow:hidden}.goal-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .4s}.goal-progress-fill.complete{background:var(--success)}.goal-detail-header{margin-bottom:16px}.goal-detail-title{color:var(--text);margin-bottom:4px;font-size:18px;font-weight:700}.goal-detail-desc{color:var(--text2);margin-bottom:10px;font-size:13px;line-height:1.5}.goal-detail-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.goal-detail-dates{color:var(--text3);font-size:12px}.goal-detail-progress-section{margin-bottom:20px}.goal-detail-progress-label{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:600}.goal-detail-progress-track{background:var(--surface-border);border-radius:4px;height:8px;margin-bottom:4px;overflow:hidden}.goal-detail-progress-fill{border-radius:4px;height:100%;transition:width .4s}.goal-detail-progress-pct{color:var(--text2);text-align:right;font-size:12px}.goal-progress-btns{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.goal-progress-btn{border:1px solid var(--surface-border);border-radius:var(--radius-sm);color:var(--text2);cursor:pointer;transition:all var(--transition);background:0 0;padding:6px 14px;font-size:12px;font-weight:500}.goal-progress-btn:hover{border-color:var(--accent);color:var(--accent)}.goal-progress-btn.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.goal-checklist{margin-top:16px}.goal-checklist-title{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:12px;font-weight:600}.goal-checklist-item{border-radius:var(--radius-sm);transition:background var(--transition);align-items:center;gap:10px;padding:8px 10px;display:flex}.goal-checklist-item:hover{background:var(--surface-hover)}.goal-checklist-item.completed .goal-checklist-text{color:var(--text3);text-decoration:line-through}.goal-checklist-text{color:var(--text);flex:1;font-size:13px}.goal-checklist-remove{width:22px;height:22px;color:var(--text3);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:14px;display:flex}.goal-checklist-remove:hover{color:var(--error);background:var(--error-muted)}.goal-checklist-add{gap:8px;margin-top:8px;display:flex}.goal-checklist-add input{background:var(--bg);border:1px solid var(--surface-border);border-radius:var(--radius-sm);color:var(--text);transition:border-color var(--transition);outline:none;flex:1;padding:8px 12px;font-family:inherit;font-size:13px}.goal-checklist-add input:focus{border-color:var(--accent)}.goal-detail-actions{gap:8px;margin-top:20px;display:flex}.compact-info-bar{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);align-items:center;gap:20px;margin-bottom:24px;padding:14px 20px;display:flex}.compact-info-item{color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.compact-info-icon{font-size:18px}.compact-info-label{color:var(--text3);margin-left:2px;font-size:12px;font-weight:500}.compact-info-sep{background:var(--surface-border);width:1px;height:24px}.compact-progress-ring{flex-shrink:0}.admin-error{background:var(--error-muted);color:var(--error);border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 14px;font-size:13px}.admin-empty{text-align:center;color:var(--text3);padding:24px;font-size:13px}.admin-toolbar{margin-bottom:16px}.admin-search-row{gap:8px;display:flex}.admin-search-input{flex:1;max-width:360px}.admin-table-card{overflow-x:auto}.admin-table{border-collapse:separate;border-spacing:0;width:100%}.admin-table th{text-align:left;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--surface-border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:600}.admin-table td{color:var(--text);border-bottom:1px solid var(--surface-border);transition:background var(--transition);padding:12px 14px;font-size:13px}.admin-table tr:hover td{background:var(--surface-hover)}.admin-user-cell{flex-direction:column;gap:2px;display:flex}.admin-user-name{color:var(--text);font-size:13px;font-weight:600}.admin-user-email{color:var(--text3);font-size:11px}.admin-role-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.role-user{background:var(--accent-soft);color:var(--accent)}.role-admin{background:var(--warning-muted);color:var(--warning)}.role-superadmin{background:var(--error-muted);color:var(--error)}.admin-status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.admin-status-badge.status-active{background:var(--success-muted);color:var(--success)}.admin-status-badge.status-inactive{background:var(--error-muted);color:var(--error)}.admin-action-badge{text-transform:capitalize;background:var(--accent-soft);color:var(--accent);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.admin-target-info{color:var(--text2);font-family:SF Mono,Fira Code,monospace;font-size:12px}.admin-details-text{color:var(--text3);font-family:SF Mono,Fira Code,monospace;font-size:11px}.admin-pagination{border-top:1px solid var(--surface-border);justify-content:center;align-items:center;gap:12px;padding:16px;display:flex}.admin-page-info{color:var(--text3);font-size:12px}.admin-form{flex-direction:column;gap:12px;display:flex}.admin-form-row{flex-direction:column;gap:4px;display:flex}.admin-form-row label{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.admin-form-row .text-input{width:100%}.admin-form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.admin-form-actions{gap:8px;margin-top:4px;display:flex}.admin-plans-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.admin-plan-card{position:relative}.admin-plan-card.admin-plan-inactive{opacity:.6}.admin-plan-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.admin-plan-name{color:var(--text);font-size:18px;font-weight:700}.admin-plan-price{color:var(--accent);font-size:24px;font-weight:800}.admin-plan-price span{color:var(--text3);font-size:12px;font-weight:500}.admin-plan-desc{color:var(--text2);margin-bottom:12px;font-size:13px}.admin-plan-limits{color:var(--text3);flex-wrap:wrap;gap:8px;margin-bottom:12px;font-size:12px;display:flex}.admin-plan-limits span{background:var(--bg2);border-radius:4px;padding:2px 8px}.admin-plan-actions{gap:8px;margin-top:8px;display:flex}.admin-inactive-badge{text-transform:uppercase;background:var(--error-muted);color:var(--error);border-radius:4px;margin-bottom:8px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.admin-quick-stats{flex-direction:column;gap:8px;display:flex}.admin-quick-stat-row{border-bottom:1px solid var(--surface-border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.admin-quick-stat-row:last-child{border-bottom:none}.admin-quick-label{color:var(--text2);font-size:13px}.admin-quick-value{color:var(--text);font-size:16px;font-weight:700}.admin-stat-icon{background:var(--error-muted)!important;color:var(--error)!important}.admin-audit-list{flex-direction:column;gap:4px;display:flex}.admin-audit-item{border-radius:var(--radius-sm);transition:background var(--transition);padding:8px 10px}.admin-audit-item:hover{background:var(--surface-hover)}.admin-audit-action{color:var(--text);text-transform:capitalize;font-size:13px;font-weight:500}.admin-audit-meta{color:var(--text3);margin-top:2px;font-size:11px}.admin-chart-container{overflow-x:auto}.admin-dau-svg{width:100%;min-width:600px;height:auto;display:block}.admin-popular-list{flex-direction:column;gap:8px;display:flex}.admin-popular-item{align-items:center;gap:12px;padding:8px 0;display:flex}.admin-popular-rank{color:var(--text3);flex-shrink:0;width:28px;font-size:12px;font-weight:700}.admin-popular-info{flex:1;min-width:0}.admin-popular-name{color:var(--text);text-transform:capitalize;margin-bottom:4px;font-size:13px;font-weight:500}.admin-popular-bar-track{background:var(--surface-border);border-radius:3px;height:6px;overflow:hidden}.admin-popular-bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .5s}.admin-popular-count{color:var(--text2);flex-shrink:0;font-size:13px;font-weight:700}.admin-templates-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.admin-template-card.admin-plan-inactive{opacity:.6}.admin-template-header{align-items:center;gap:10px;margin-bottom:8px;display:flex}.admin-template-icon{font-size:24px}.admin-template-name{color:var(--text);font-size:16px;font-weight:700}.admin-template-cat{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.admin-template-desc{color:var(--text2);margin-bottom:8px;font-size:13px}.admin-template-meta{color:var(--text3);flex-wrap:wrap;gap:8px;margin-bottom:8px;font-size:12px;display:flex}.admin-featured-badge{background:var(--warning-muted);color:var(--warning);text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.admin-tag-badge{background:var(--accent-soft);color:var(--accent);text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.admin-template-actions{gap:8px;margin-top:8px;display:flex}.sub-badge{border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;background:var(--surface-hover);color:var(--text2);padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.sub-badge[data-plan=plan_pro]{background:var(--accent-soft);color:var(--accent)}.sub-plans-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px;display:grid}.sub-plan-card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-lg);transition:all var(--transition);flex-direction:column;padding:24px 20px;display:flex}.sub-plan-card:hover{border-color:var(--text-muted)}.sub-plan-card.highlighted{border-color:var(--accent);position:relative}.sub-plan-card.highlighted:before{content:"Most Popular";background:var(--accent);color:var(--bg);text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-sm);padding:2px 10px;font-size:10px;font-weight:700;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.sub-plan-card.current{border-color:var(--accent);background:var(--accent-soft)}.sub-plan-header{margin-bottom:16px}.sub-plan-name{color:var(--text);font-size:16px;font-weight:700}.sub-plan-price{color:var(--text);margin-top:4px;font-size:24px;font-weight:800}.sub-plan-features{flex:1;margin:0 0 20px;padding:0;list-style:none}.sub-plan-features li{color:var(--text2);padding:4px 0 4px 18px;font-size:13px;position:relative}.sub-plan-features li:before{content:"✓";color:var(--accent);font-size:12px;font-weight:700;position:absolute;left:0}.btn-accent{background:var(--accent)!important;color:var(--bg)!important;border-color:var(--accent)!important}.btn-accent:hover{opacity:.9}.sub-plan-interval{color:var(--text3);font-size:14px;font-weight:500}.sub-trial-bar{background:var(--surface-hover);border-radius:3px;width:100%;height:6px;margin-top:8px;overflow:hidden}.sub-trial-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .4s}@media (width<=768px){.sub-plans-grid{grid-template-columns:1fr}}
