@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-card:#111827b3;--bg-card-hover:#1f2937cc;--bg-glass:#ffffff08;--bg-glass-hover:#ffffff0f;--bg-input:#ffffff0d;--border-color:#ffffff14;--border-light:#ffffff1f;--border-accent:#8b5cf64d;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-accent:#a78bfa;--accent-purple:#8b5cf6;--accent-cyan:#06b6d4;--accent-pink:#ec4899;--accent-green:#10b981;--accent-yellow:#f59e0b;--accent-red:#ef4444;--accent-blue:#3b82f6;--accent-orange:#f97316;--gradient-primary:linear-gradient(135deg,#8b5cf6,#06b6d4);--gradient-secondary:linear-gradient(135deg,#ec4899,#8b5cf6);--gradient-success:linear-gradient(135deg,#10b981,#06b6d4);--gradient-warm:linear-gradient(135deg,#f59e0b,#ef4444);--gradient-cool:linear-gradient(135deg,#3b82f6,#8b5cf6);--gradient-card:linear-gradient(135deg,#8b5cf61a,#06b6d40d);--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #8b5cf626;--shadow-glow-cyan:0 0 20px #06b6d426;--sidebar-width:260px;--sidebar-collapsed:70px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}a{color:var(--text-accent);text-decoration:none}img{max-width:100%}.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);transition:margin-left var(--transition-base);background:var(--bg-primary);flex:1;min-height:100vh;padding:32px}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:100;transition:all var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.sidebar-brand{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:24px 20px;display:flex}.sidebar-brand-icon{border-radius:var(--radius-md);background:var(--gradient-primary);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.sidebar-brand h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;white-space:nowrap;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700}.sidebar-brand p{color:var(--text-muted);white-space:nowrap;font-size:11px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:16px 12px 8px;font-size:10px;font-weight:600}.sidebar-link{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;display:flex;position:relative;overflow:hidden}.sidebar-link:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.sidebar-link.active{color:var(--text-accent);background:#8b5cf61f}.sidebar-link.active:before{content:"";background:var(--gradient-primary);border-radius:0 4px 4px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link-icon{text-align:center;flex-shrink:0;width:24px;font-size:18px}.sidebar-link-label{white-space:nowrap}.mobile-toggle{z-index:200;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);width:44px;height:44px;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:20px;display:none;position:fixed;top:16px;left:16px}.mobile-toggle:hover{background:var(--bg-card-hover)}.sidebar-overlay{z-index:99;background:#0009;display:none;position:fixed;inset:0}.page-header{margin-bottom:32px}.page-header h1{margin-bottom:4px;font-size:28px;font-weight:700}.page-header p{color:var(--text-secondary);font-size:15px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-base)}.card:hover{border-color:var(--border-light)}.card-glow{box-shadow:var(--shadow-glow)}.card-gradient{background:var(--gradient-card);border:1px solid var(--border-accent)}.card-padding{padding:24px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-base);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:flex-start;gap:16px;padding:20px;display:flex;overflow:hidden}.stat-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.stat-info{min-width:0;overflow:hidden}.stat-info h3{word-break:break-word;font-size:clamp(16px,2.5vw,28px);font-weight:700;line-height:1.2}.stat-info p{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:13px;overflow:hidden}.grid-2{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.mb-4{margin-bottom:16px}.mt-4{margin-top:16px}.gap-3{gap:12px}.gap-4{gap:16px}.rounded{border-radius:4px}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;display:inline-flex}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #8b5cf64d}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px #8b5cf666}.btn-secondary{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-glass-hover);color:var(--text-primary);border-color:var(--border-light)}.btn-danger{color:var(--accent-red);background:#ef444426;border:1px solid #ef444433}.btn-danger:hover{background:#ef444440}.btn-success{color:var(--accent-green);background:#10b98126;border:1px solid #10b98133}.btn-success:hover{background:#10b98140}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:14px 28px;font-size:16px}.btn-icon{border-radius:var(--radius-sm);width:36px;height:36px;padding:0;font-size:16px}.btn-icon.sm{width:28px;height:28px;font-size:14px}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input,.form-select,.form-textarea{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-input);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:10px 14px;font-family:inherit;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent-purple);box-shadow:0 0 0 3px #8b5cf61a}.form-textarea{resize:vertical;min-height:100px}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-row{gap:12px;display:flex}.form-row>*{flex:1}.form-inline{align-items:flex-end;gap:8px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;animation:.3s slideUp;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{font-size:18px;font-weight:600}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.badge{border-radius:var(--radius-full);letter-spacing:.3px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-purple{color:var(--accent-purple);background:#8b5cf626}.badge-green{color:var(--accent-green);background:#10b98126}.badge-red{color:var(--accent-red);background:#ef444426}.badge-yellow{color:var(--accent-yellow);background:#f59e0b26}.badge-blue{color:var(--accent-blue);background:#3b82f626}.badge-cyan{color:var(--accent-cyan);background:#06b6d426}.badge-pink{color:var(--accent-pink);background:#ec489926}.progress-bar{border-radius:var(--radius-full);background:#ffffff0f;width:100%;height:8px;overflow:hidden}.progress-fill{border-radius:var(--radius-full);background:var(--gradient-primary);height:100%;transition:width var(--transition-slow)}.progress-fill.green{background:var(--gradient-success)}.progress-fill.warm{background:var(--gradient-warm)}.tabs{background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-color);gap:4px;margin-bottom:20px;padding:4px;display:flex}.tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--accent-purple);color:#fff;box-shadow:var(--shadow-sm)}.list-item{border-radius:var(--radius-sm);transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:12px;padding:12px 16px;display:flex}.list-item:hover{background:var(--bg-glass);border-color:var(--border-color)}.list-item+.list-item{margin-top:4px}.checkbox{border:2px solid var(--border-light);cursor:pointer;width:22px;height:22px;transition:all var(--transition-fast);color:#0000;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.checkbox:hover{border-color:var(--accent-purple)}.checkbox.checked{background:var(--gradient-primary);border-color:var(--accent-purple);color:#fff}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state-icon{opacity:.5;margin-bottom:16px;font-size:48px}.empty-state h3{color:var(--text-secondary);margin-bottom:8px;font-size:18px;font-weight:600}.empty-state p{color:var(--text-muted);max-width:300px;font-size:14px}.kanban-board{grid-template-columns:repeat(3,1fr);gap:16px;min-height:400px;display:grid}.kanban-column{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-lg);min-height:300px;padding:16px}.kanban-column-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;display:flex}.kanban-column-title{align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.kanban-count{border-radius:var(--radius-full);background:var(--bg-card);width:22px;height:22px;color:var(--text-muted);justify-content:center;align-items:center;font-size:11px;display:flex}.kanban-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-bottom:8px;padding:14px}.kanban-card:hover{border-color:var(--border-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.kanban-card-title{margin-bottom:8px;font-size:14px;font-weight:500}.kanban-card-meta{color:var(--text-muted);align-items:center;gap:8px;font-size:12px;display:flex}.timer-circle{background:var(--bg-glass);border:3px solid var(--border-color);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:280px;height:280px;margin:0 auto;display:flex;position:relative}.timer-circle.active{border-color:var(--accent-purple);box-shadow:var(--shadow-glow),inset 0 0 30px #8b5cf60d}.timer-circle.break-time{border-color:var(--accent-green);box-shadow:var(--shadow-glow-cyan),inset 0 0 30px #10b9810d}.timer-time{letter-spacing:2px;font-variant-numeric:tabular-nums;font-size:52px;font-weight:700}.timer-label{color:var(--text-secondary);margin-top:4px;font-size:14px}.timer-controls{justify-content:center;gap:12px;margin-top:24px;display:flex}.calendar-layout{grid-template-columns:1fr 360px;gap:20px;display:grid}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-day-header{text-align:center;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 0;font-size:12px;font-weight:600}.calendar-day{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:14px;display:flex;position:relative}.calendar-day:hover{background:var(--bg-glass-hover)}.calendar-day.today{color:var(--accent-purple);background:#8b5cf626;font-weight:600}.calendar-day.selected{background:var(--accent-purple);color:#fff}.calendar-day.other-month{opacity:.3}.calendar-day .event-dot{border-radius:50%;width:5px;height:5px;position:absolute;bottom:6px}.mood-selector{gap:8px;display:flex}.mood-btn{border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-glass);cursor:pointer;width:44px;height:44px;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:22px;display:flex}.mood-btn:hover{border-color:var(--border-light);transform:scale(1.1)}.mood-btn.selected{border-color:var(--accent-purple);background:#8b5cf626;transform:scale(1.15)}.water-cups{flex-wrap:wrap;gap:8px;display:flex}.water-cup{border:2px solid var(--border-color);background:var(--bg-glass);cursor:pointer;width:40px;height:48px;transition:all var(--transition-fast);border-radius:4px 4px 8px 8px;justify-content:center;align-items:center;font-size:16px;display:flex}.water-cup:hover{border-color:var(--accent-cyan)}.water-cup.filled{border-color:var(--accent-cyan);background:#06b6d433}.star-rating{gap:4px;display:flex}.star{cursor:pointer;transition:transform var(--transition-fast);filter:grayscale()opacity(.3);font-size:20px}.star:hover{transform:scale(1.2)}.star.filled{filter:none}.pie-chart-container{align-items:center;gap:24px;display:flex}.pie-chart{flex-shrink:0;width:160px;height:160px}.pie-legend{flex-direction:column;flex:1;gap:8px;display:flex}.pie-legend-item{align-items:center;gap:8px;font-size:13px;display:flex}.pie-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.pie-legend-label{color:var(--text-secondary);flex:1}.pie-legend-value{font-weight:600}.heatmap-row{gap:4px;margin-bottom:4px;display:flex}.heatmap-cell{background:var(--bg-glass);border:1px solid var(--border-color);width:32px;height:32px;transition:all var(--transition-fast);border-radius:6px;justify-content:center;align-items:center;font-size:12px;display:flex}.heatmap-cell.completed{color:var(--accent-green);background:#10b98133;border-color:#10b9814d}.quote-card{background:var(--gradient-card);border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:24px;position:relative;overflow:hidden}.quote-card:before{content:"\"";color:#8b5cf61a;font-family:Georgia,serif;font-size:80px;line-height:1;position:absolute;top:-10px;left:16px}.quote-text{color:var(--text-primary);z-index:1;margin-bottom:12px;font-size:16px;font-style:italic;line-height:1.7;position:relative}.quote-author{color:var(--text-accent);font-size:13px;font-weight:500}.activity-item{border-bottom:1px solid var(--border-color);gap:12px;padding:10px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{border-radius:var(--radius-sm);background:var(--bg-glass);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.activity-text{color:var(--text-secondary);font-size:13px;line-height:1.5}.activity-text strong{color:var(--text-primary);font-weight:500}.activity-time{color:var(--text-muted);margin-top:2px;font-size:11px}.transaction-item{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:12px 0;display:flex}.transaction-item:last-child{border-bottom:none}.transaction-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.transaction-info{flex:1}.transaction-info h4{font-size:14px;font-weight:500}.transaction-info p{color:var(--text-muted);font-size:12px}.transaction-amount{font-variant-numeric:tabular-nums;font-size:15px;font-weight:600}.transaction-amount.income{color:var(--accent-green)}.transaction-amount.expense{color:var(--accent-red)}.book-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-base);gap:16px;padding:16px;display:flex}.book-card:hover{border-color:var(--border-light);transform:translateY(-2px)}.book-cover{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:60px;height:80px;font-size:24px;display:flex}.book-info{flex:1;min-width:0}.book-info h3{white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:15px;font-weight:600;overflow:hidden}.book-info p{color:var(--text-secondary);font-size:13px}.workout-item{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;gap:16px;margin-bottom:8px;padding:12px 16px;display:flex}.workout-name{flex:1;font-size:14px;font-weight:500}.workout-detail{color:var(--text-secondary);gap:12px;font-size:13px;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}@media (max-width:1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.grid-2,.grid-3,.kanban-board{grid-template-columns:1fr}.mobile-toggle{display:flex}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay.show{display:block}.main-content{margin-left:0;padding:72px 16px 20px;overflow-x:hidden}.page-header{margin-bottom:20px}.page-header h1{font-size:22px}.page-header p{font-size:13px}.flex.justify-between{flex-wrap:wrap;gap:12px}.dashboard-level-badge{padding:6px 10px;font-size:12px}.dashboard-level-badge span:first-child{font-size:14px!important}.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.stat-card{gap:10px;min-width:0;padding:16px;overflow:hidden}.stat-info h3{word-break:break-word;font-size:18px!important}.stat-info p{font-size:12px}.pie-chart-container,.form-row{flex-direction:column}.grid-auto,.calendar-layout{grid-template-columns:1fr}.roast-card{font-size:14px}.modal{max-height:85vh;overflow-y:auto;width:95vw!important;max-width:95vw!important}.tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{white-space:nowrap;flex-shrink:0}}@media (max-width:480px){.main-content{padding:64px 12px 16px}.page-header h1{font-size:20px}.stats-grid{grid-template-columns:1fr;gap:10px}.stat-info h3{font-size:16px!important}.stat-icon{width:36px;height:36px;font-size:18px}.tabs{overflow-x:auto}.timer-circle{width:220px;height:220px}.timer-time{font-size:40px}.dashboard-level-badge{border-radius:var(--radius-md);padding:4px 8px}.card-padding{padding:16px}.flex.gap-1.items-center{flex-wrap:wrap}.level-grid{grid-template-columns:repeat(2,1fr)!important}.btn{min-height:40px;font-size:13px}.btn-primary{white-space:nowrap}.card{overflow:hidden}.roast-card{padding:12px 16px;font-size:13px}.xp-toast{padding:8px 14px;font-size:12px;top:70px;right:12px}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-pulse{animation:2s infinite pulse}.animate-bounce{animation:1s infinite bounce}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--text-accent)}.text-green{color:var(--accent-green)}.text-red{color:var(--accent-red)}.text-yellow{color:var(--accent-yellow)}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-lg{font-size:18px}.text-xl{font-size:24px}.font-semibold{font-weight:600}.font-bold{font-weight:700}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.gap-1{gap:8px}.gap-2{gap:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.w-full{width:100%}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.relative{position:relative}.hidden{display:none}.login-page{background:var(--bg-primary);background-image:radial-gradient(at 20%,#8b5cf614 0%,#0000 50%),radial-gradient(at 80%,#06b6d40f 0%,#0000 50%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-container{text-align:center;width:100%;max-width:440px}.login-hero{margin-bottom:36px}.login-brand-icon{border-radius:var(--radius-xl);background:var(--gradient-primary);justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:16px;font-size:36px;animation:3s ease-in-out infinite float;display:inline-flex;box-shadow:0 8px 32px #8b5cf64d}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.login-title{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:36px;font-weight:800}.login-subtitle{color:var(--text-secondary);font-size:15px}.login-tabs{background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-color);gap:8px;margin-bottom:24px;padding:6px;display:flex}.login-tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:center;background:0 0;border:none;flex:1;padding:10px;font-size:13px;font-weight:500}.login-tab:hover{color:var(--text-primary);background:var(--bg-glass-hover)}.login-tab.active{background:var(--accent-purple);color:#fff;box-shadow:var(--shadow-sm)}.login-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);text-align:left;padding:28px}.login-section{margin-bottom:20px}.login-label{color:var(--text-primary);margin-bottom:10px;font-size:14px;font-weight:600;display:block}.login-input{border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--bg-input);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:14px 18px;font-family:inherit;font-size:16px}.login-input:focus{border-color:var(--accent-purple);box-shadow:0 0 0 4px #8b5cf626}.login-input::placeholder{color:var(--text-muted)}.avatar-grid{grid-template-columns:repeat(8,1fr);gap:6px;display:grid}.avatar-btn{aspect-ratio:1;border-radius:var(--radius-sm);border:2px solid var(--border-color);background:var(--bg-glass);cursor:pointer;width:100%;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:20px;display:flex}.avatar-btn:hover{border-color:var(--border-light);transform:scale(1.1)}.avatar-btn.selected{border-color:var(--accent-purple);background:#8b5cf626;transform:scale(1.15);box-shadow:0 0 12px #8b5cf64d}.login-submit{border-radius:var(--radius-md);background:var(--gradient-primary);color:#fff;cursor:pointer;width:100%;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:10px;padding:14px 24px;font-family:inherit;font-size:16px;font-weight:600;display:flex;box-shadow:0 4px 16px #8b5cf64d}.login-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #8b5cf666}.login-submit:disabled{opacity:.5;cursor:not-allowed}.login-switch-btn{width:100%;color:var(--text-accent);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;margin-top:16px;padding:12px;font-family:inherit;font-size:14px;display:block}.login-switch-btn:hover{color:var(--accent-purple)}.login-footer{margin-top:24px}.login-footer p{color:var(--text-muted);font-size:13px}.login-loading{text-align:center}.login-loading-icon{font-size:48px;animation:1.5s infinite pulse}.login-loading p{color:var(--text-secondary);margin-top:12px}.existing-users{flex-direction:column;gap:8px;display:flex}.existing-user-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;color:var(--text-primary);align-items:center;gap:14px;width:100%;padding:14px 16px;font-family:inherit;display:flex}.existing-user-card:hover{border-color:var(--accent-purple);background:var(--bg-card-hover);transform:translate(4px)}.existing-user-avatar{font-size:32px}.existing-user-info{flex-direction:column;flex:1;display:flex}.existing-user-name{font-size:16px;font-weight:600}.existing-user-date{color:var(--text-muted);font-size:12px}.existing-user-arrow{color:var(--text-muted);font-size:18px}.sidebar-user{border-top:1px solid var(--border-color);margin-top:auto;padding:12px}.sidebar-user-btn{border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-color);cursor:pointer;width:100%;transition:all var(--transition-fast);color:var(--text-primary);text-align:left;align-items:center;gap:10px;padding:10px 12px;font-family:inherit;display:flex}.sidebar-user-btn:hover{background:var(--bg-glass-hover);border-color:var(--border-light)}.sidebar-user-avatar{background:#ffffff0d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;display:flex;overflow:hidden}.sidebar-user-info{flex-direction:column;flex:1;min-width:0;display:flex}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.sidebar-user-status{color:var(--accent-green);align-items:center;gap:4px;font-size:11px;display:flex}.sidebar-user-status:before{content:"";width:6px;height:6px;box-shadow:0 0 8px var(--accent-green);background:currentColor;border-radius:50%;display:block}.sidebar-user-more{color:var(--text-muted);font-size:10px}.sidebar-user-menu{margin-top:6px}.sidebar-user-menu-item{border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-family:inherit;font-size:13px;display:flex}.sidebar-user-menu-item:hover{color:var(--accent-red);background:#ef44441a}.notif-permission-banner{background:var(--gradient-card);border:1px solid var(--border-accent);border-radius:var(--radius-lg);margin-bottom:24px;padding:24px;animation:.3s slideUp}.notif-permission-content{align-items:center;gap:20px;display:flex}.notif-permission-icon{flex-shrink:0;font-size:40px;animation:1.5s infinite bounce}.notif-permission-content h3{margin-bottom:4px;font-size:16px;font-weight:600}.notif-permission-content p{color:var(--text-secondary);font-size:14px;line-height:1.5}.reminder-list{flex-direction:column;gap:4px;display:flex}.reminder-item{border-radius:var(--radius-md);transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:14px;padding:14px 16px;display:flex}.reminder-item:hover{background:var(--bg-glass);border-color:var(--border-color)}.reminder-item.disabled{opacity:.45}.reminder-icon{border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--border-color);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:24px;display:flex}.reminder-info{flex:1;min-width:0}.reminder-info h4{margin-bottom:4px;font-size:14px;font-weight:600}.reminder-meta{color:var(--text-muted);gap:12px;font-size:12px;display:flex}.reminder-time{color:var(--text-accent);font-weight:500}.reminder-body{color:var(--text-secondary);margin-top:4px;font-size:12px;line-height:1.4}.reminder-actions{align-items:center;gap:8px;display:flex}.toggle-switch{border:1px solid var(--border-color);cursor:pointer;width:44px;height:24px;transition:all var(--transition-fast);background:#ffffff1a;border-radius:12px;padding:0;position:relative}.toggle-switch.on{background:var(--accent-purple);border-color:var(--accent-purple)}.toggle-knob{width:18px;height:18px;transition:transform var(--transition-fast);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000004d}.toggle-switch.on .toggle-knob{transform:translate(20px)}.day-picker{gap:6px;display:flex}.day-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-glass);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-family:inherit;font-size:12px;font-weight:600}.day-btn:hover{border-color:var(--border-light)}.day-btn.active{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.template-card{transition:all var(--transition-base)}.template-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}@media (max-width:768px){.avatar-grid{grid-template-columns:repeat(8,1fr);gap:4px}.avatar-btn{font-size:16px}.notif-permission-content{text-align:center;flex-direction:column}.day-picker{flex-wrap:wrap}}.confetti-container{pointer-events:none;z-index:10002;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.confetti-piece{animation:linear forwards confettiFall;position:absolute;top:-20px}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)translate(0)rotate(0)}to{transform:translateY(100vh)translateX(var(--fall-x,30px))rotate(var(--fall-rotation,720deg));opacity:0}}.xp-bar-container{padding:6px 0}.xp-bar-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.xp-level-badge{border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:10px;font-weight:700;display:flex}.xp-level-title{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.xp-bar-track{background:var(--bg-glass);border-radius:3px;width:100%;height:6px;overflow:hidden}.xp-bar-fill{border-radius:3px;height:100%;transition:width .5s}.xp-bar-footer{color:var(--text-muted);justify-content:space-between;margin-top:3px;font-size:10px;display:flex}.level-grid{grid-template-columns:repeat(5,1fr);gap:10px;display:grid}.level-item{border-radius:var(--radius-md);transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:4px;padding:10px 4px;display:flex}.level-item.unlocked{background:var(--bg-glass)}.level-item.locked{opacity:.4}.level-item-badge{border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.level-item-title{text-align:center;font-size:11px;font-weight:600;line-height:1.2}.levelup-icon-sm{border:3px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;font-size:16px;font-weight:800;display:flex}.achievement-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-base);padding:20px;position:relative;overflow:hidden}.achievement-card.unlocked{border-color:#8b5cf64d}.achievement-card.unlocked:after{content:"";background:linear-gradient(45deg,#0000 30%,#8b5cf608 50%,#0000 70%);width:200%;height:200%;animation:3s ease-in-out infinite achievementShine;position:absolute;top:-50%;left:-50%}@keyframes achievementShine{0%{transform:translate(-100%)rotate(45deg)}to{transform:translate(100%)rotate(45deg)}}.achievement-card.locked{opacity:.4;filter:grayscale(.5)}.achievement-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.achievement-icon{margin-bottom:8px;font-size:36px}.achievement-card h4{margin-bottom:4px;font-size:14px;font-weight:700}.achievement-card p{color:var(--text-secondary);font-size:12px}.achievement-badge{color:var(--accent-green);margin-top:8px;font-size:11px;font-weight:600}.levelup-modal{background:var(--bg-secondary);border:1px solid var(--border-accent);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:400px;padding:48px 40px;animation:.5s levelUpBounce;position:relative;overflow:hidden}@keyframes levelUpBounce{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.levelup-glow{background:var(--glow-color,#8b5cf6);opacity:.08;border-radius:50%;width:300px;height:300px;animation:2s ease-in-out infinite levelupPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes levelupPulse{0%,to{opacity:.08;transform:translate(-50%,-50%)scale(1)}50%{opacity:.15;transform:translate(-50%,-50%)scale(1.3)}}.levelup-icon{z-index:1;font-size:64px;animation:1s ease-in-out infinite levelupBounceIcon;position:relative}@keyframes levelupBounceIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.levelup-title{background:var(--gradient-primary);-webkit-text-fill-color:transparent;z-index:1;-webkit-background-clip:text;background-clip:text;margin:12px 0 8px;font-size:32px;font-weight:900;position:relative}.levelup-level{z-index:1;font-size:22px;font-weight:700;position:relative}.levelup-desc{color:var(--text-secondary);z-index:1;margin-top:8px;font-size:14px;position:relative}.streak-death-overlay{z-index:10000;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ef444426;justify-content:center;align-items:center;width:100%;height:100%;animation:.5s streakDeathFlash;display:flex;position:fixed;top:0;left:0}@keyframes streakDeathFlash{0%{background:#ef444499}25%{background:#ef44441a}50%{background:#ef444466}75%{background:#ef44441a}to{background:#ef444426}}.streak-death-content{text-align:center;animation:.5s streakDeathShake}@keyframes streakDeathShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-8px)}20%,40%,60%,80%{transform:translate(8px)}}.streak-death-skull{font-size:80px;animation:1s ease-in-out infinite skullPulse}@keyframes skullPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.streak-death-text{color:var(--accent-red);max-width:400px;margin-top:16px;font-size:20px;font-weight:700;line-height:1.5}.streak-death-sub{color:var(--text-muted);margin-top:16px;font-size:13px}.roast-card{border-radius:var(--radius-lg);border:1px solid;align-items:center;gap:14px;padding:16px 20px;animation:.3s roastSlideIn;display:flex}@keyframes roastSlideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.roast-icon{flex-shrink:0;font-size:28px}.roast-text{font-size:14px;font-weight:500;line-height:1.5}.achievement-unlock-banner{background:var(--gradient-card);border-radius:var(--radius-lg);border:1px solid #8b5cf64d;padding:20px;animation:.3s slideUp}.achievement-unlock-banner h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:10px;font-size:16px;font-weight:700}.achievement-unlock-item{background:var(--bg-glass);border-radius:var(--radius-md);border:1px solid var(--border-color);align-items:center;gap:8px;padding:8px 14px;display:flex}.dashboard-level-badge{border-radius:var(--radius-lg);background:var(--bg-glass);border:2px solid;flex-direction:column;align-items:center;padding:8px 16px;display:flex}.report-grade-card{background:var(--bg-card);border-radius:var(--radius-xl);border:2px solid;align-items:center;gap:20px;padding:24px;display:flex}.report-grade-big{font-size:56px;font-weight:900;line-height:1}.report-grade-sm{border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:800;display:flex}.xp-gain-badge{color:var(--accent-purple);border-radius:var(--radius-full);background:#8b5cf626;padding:4px 10px;font-size:12px;font-weight:700}@media (max-width:768px){.level-grid{grid-template-columns:repeat(3,1fr)}}.book-card{min-width:0}.book-card .flex.items-center.gap-1{flex-wrap:wrap}.star-rating{flex-wrap:wrap!important;gap:2px!important;display:flex!important}.xp-toast{color:#fff;border-radius:var(--radius-full);z-index:10003;pointer-events:none;background:#8b5cf6f2;padding:10px 20px;font-size:14px;font-weight:700;animation:2s forwards xpToastAnim;position:fixed;top:20px;right:20px;box-shadow:0 4px 20px #8b5cf666}@keyframes xpToastAnim{0%{opacity:0;transform:translateY(20px)scale(.8)}15%{opacity:1;transform:translateY(0)scale(1)}75%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-20px)scale(.8)}}.settings-card{background:var(--bg-glass);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast);align-items:center;gap:14px;padding:16px;display:flex}.settings-card:hover{border-color:var(--border-accent)}.storage-bar{background:var(--bg-glass);border-radius:4px;width:100%;height:8px;overflow:hidden}.storage-bar-fill{background:var(--gradient-primary);border-radius:4px;height:100%;transition:width .3s}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}
