:root{--app-bg-base:#f3f4f6;--app-glow-1:#3b82f614;--app-glow-2:#667eea0f;--surface-primary:#fff;--surface-secondary:#f9fafb;--surface-accent:#eef2ff;--text-primary:#111827;--text-secondary:#374151;--text-muted:#6b7280;--accent-primary:#4caf50;--accent-primary-hover:#43a047;--accent-secondary:#667eea;--success:#16a34a;--warning:#f59e0b;--danger:#ef4444;--border-subtle:#e5e7eb;--shadow-soft:0 4px 20px #0000000a;--shadow-medium:0 8px 30px #00000014;--shadow-large:0 12px 40px #0000001f;--radius-large:16px;--radius-medium:12px;--radius-small:8px;--transition:.25s ease;--color-surface:var(--surface-primary);--color-surface-elevated:var(--surface-secondary);--color-bg:var(--app-bg-base);--bg-primary:var(--surface-primary);--bg-secondary:var(--surface-secondary);--color-text:var(--text-primary);--color-text-secondary:var(--text-secondary);--color-text-muted:var(--text-muted);--color-primary:var(--accent-primary);--color-primary-hover:var(--accent-primary-hover);--color-secondary:var(--accent-secondary);--color-danger:var(--danger);--color-success:var(--success);--color-warning:var(--warning);--color-border:var(--border-subtle);--border-color:var(--border-subtle);--shadow-sm:var(--shadow-soft);--shadow-md:var(--shadow-medium);--shadow-lg:var(--shadow-large)}[data-theme=dark]{--app-bg-base:#0f172a;--app-glow-1:#3b82f62e;--app-glow-2:#667eea24;--surface-primary:#1e293b;--surface-secondary:#273549;--surface-accent:#1e293b;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--accent-primary:#3b82f6;--accent-primary-hover:#2563eb;--accent-secondary:#6366f1;--success:#22c55e;--warning:#fbbf24;--danger:#f87171;--border-subtle:#ffffff14;--shadow-soft:0 4px 20px #0006;--shadow-medium:0 8px 30px #0009;--shadow-large:0 12px 40px #000000b3;--color-surface:var(--surface-primary);--color-surface-elevated:var(--surface-secondary);--color-bg:var(--app-bg-base);--bg-primary:var(--surface-primary);--bg-secondary:var(--surface-secondary);--color-text:var(--text-primary);--color-text-secondary:var(--text-secondary);--color-text-muted:var(--text-muted);--color-primary:var(--accent-primary);--color-primary-hover:var(--accent-primary-hover);--color-secondary:var(--accent-secondary);--color-danger:var(--danger);--color-success:var(--success);--color-warning:var(--warning);--color-border:var(--border-subtle);--border-color:var(--border-subtle);--shadow-sm:var(--shadow-soft);--shadow-md:var(--shadow-medium);--shadow-lg:var(--shadow-large)}.splash-container{z-index:99999;background:linear-gradient(135deg,#0f172a 0%,#1a2744 30%,#0d3320 70%,#0f172a 100%);justify-content:center;align-items:center;transition:opacity .7s;display:flex;position:fixed;inset:0;overflow:hidden}.splash-container.fade-out{opacity:0;pointer-events:none}.splash-orb{filter:blur(80px);opacity:.5;border-radius:50%;animation:6s ease-in-out infinite orbFloat;position:absolute}.orb-1{background:radial-gradient(circle,#4caf5066,#0000 70%);width:400px;height:400px;animation-delay:0s;top:-10%;left:-10%}.orb-2{background:radial-gradient(circle,#667eea66,#0000 70%);width:350px;height:350px;animation-delay:-2s;bottom:-10%;right:-10%}.orb-3{background:radial-gradient(circle,#3b82f64d,#0000 70%);width:250px;height:250px;animation-delay:-4s;top:40%;left:50%;transform:translate(-50%)}@keyframes orbFloat{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-30px)scale(1.08)}}.splash-content{z-index:2;flex-direction:column;align-items:center;gap:28px;display:flex;position:relative}.splash-logo{opacity:0;width:120px;height:120px;transition:all .8s cubic-bezier(.34,1.56,.64,1);transform:scale(.5)}.splash-logo.visible{opacity:1;transform:scale(1)}.splash-logo img{object-fit:contain;filter:drop-shadow(0 8px 30px #4caf5066);width:100%;height:100%}.splash-text{text-align:center;opacity:0;transition:all .6s cubic-bezier(.22,1,.36,1);transform:translateY(16px)}.splash-text.visible{opacity:1;transform:translateY(0)}.splash-text h1{letter-spacing:-.5px;background:linear-gradient(135deg,#4caf50,#60a5fa,#667eea);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 8px;font-size:36px;font-weight:800}.splash-text p{color:#fff9;letter-spacing:.5px;margin:0;font-size:16px;font-weight:500}@media (max-width:480px){.splash-logo{width:90px;height:90px}.splash-text h1{font-size:28px}.splash-text p{font-size:14px}.orb-1{width:250px;height:250px}.orb-2{width:200px;height:200px}.orb-3{width:150px;height:150px}}.auth-screen{justify-content:center;align-items:center;width:100%;display:flex}.auth-card{border-radius:var(--radius-large);-webkit-backdrop-filter:blur(20px);width:100%;max-width:440px;box-shadow:var(--shadow-medium);background:#ffffffd9;border:1px solid #fff3;padding:48px 40px;transition:background .3s,border .3s;animation:.5s forwards fadeInUp}[data-theme=dark] .auth-card{background:#1e293bd9;border:1px solid #ffffff0f}.auth-logo{justify-content:center;margin-bottom:20px;display:flex}.auth-logo img{object-fit:contain;filter:drop-shadow(0 4px 16px #d4a8304d);width:80px;height:80px;animation:3s ease-in-out infinite logoFloat}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.auth-card h1{color:var(--text-primary);text-align:center;margin-bottom:10px;font-size:34px;font-weight:700}.auth-card .subtitle{color:var(--text-secondary);text-align:center;margin-bottom:32px;font-size:15px;line-height:1.6}.auth-card .form-group{margin-bottom:22px}.auth-card .form-group label{color:var(--text-secondary);letter-spacing:.5px;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.auth-card .form-group input{border-radius:var(--radius-medium);background:var(--surface-primary);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);padding:14px 16px;font-family:inherit;font-size:15px;transition:all .2s}.auth-card .form-group input::placeholder{color:var(--text-muted)}.auth-card .form-group input:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #4caf5026}.auth-card .form-group input:disabled{opacity:.6;cursor:not-allowed}.auth-button{background:linear-gradient(135deg, var(--accent-secondary), var(--accent-primary));color:#fff;cursor:pointer;width:100%;box-shadow:var(--shadow-soft);border:none;border-radius:14px;margin-top:10px;padding:15px;font-family:inherit;font-size:16px;font-weight:600;transition:all .15s}.auth-button:hover:not(:disabled){box-shadow:var(--shadow-medium);transform:translateY(-2px)}.auth-button:active:not(:disabled){transform:scale(.98)}.auth-button:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.toggle-auth-mode{border-radius:var(--radius-medium);border:1px solid var(--border-subtle);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;margin-top:18px;padding:12px;font-family:inherit;font-size:14px;transition:all .2s}.toggle-auth-mode:hover:not(:disabled){border-color:var(--accent-primary);color:var(--text-primary)}.toggle-auth-mode:disabled{opacity:.5}.forgot-password{text-align:right;color:var(--accent-primary);cursor:pointer;margin-top:-14px;margin-bottom:16px;font-size:13px;text-decoration:none;transition:color .2s;display:block}.forgot-password:hover{color:var(--accent-secondary);text-decoration:underline}.password-strength{margin-top:8px}.strength-bar-track{background:var(--border-subtle);border-radius:100px;width:100%;height:4px;overflow:hidden}.strength-bar-fill{border-radius:100px;height:100%;transition:width .3s,background .3s}.strength-bar-fill.weak{background:var(--danger);width:25%}.strength-bar-fill.fair{background:var(--warning);width:50%}.strength-bar-fill.good{background:#60a5fa;width:75%}.strength-bar-fill.strong{background:var(--success);width:100%}.strength-label{letter-spacing:.3px;margin-top:4px;font-size:11px;font-weight:600;display:block}.strength-label.weak{color:var(--danger)}.strength-label.fair{color:var(--warning)}.strength-label.good{color:#60a5fa}.strength-label.strong{color:var(--success)}.auth-switch{color:var(--text-secondary);text-align:center;margin-top:26px;font-size:14px}.auth-switch a{color:var(--accent-primary);font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.input-hint{color:var(--text-muted);margin-top:6px;font-size:12px;display:block}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.auth-card{padding:32px 24px}.auth-card h1{font-size:26px}}.slide-track-container{text-align:center;-webkit-user-select:none;user-select:none;padding:24px 0}.slide-emoji{margin-bottom:8px;font-size:48px;animation:.4s slideEmojiBounce}@keyframes slideEmojiBounce{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}.slide-value-display{color:var(--accent-secondary);margin-bottom:20px;font-size:44px;font-weight:800;line-height:1}.slide-value-unit{color:var(--text-muted);font-size:18px;font-weight:500}.slide-labels{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;margin-bottom:10px;font-size:12px;font-weight:600;display:flex}.slide-track{background:var(--surface-secondary);border:1px solid var(--border-subtle);cursor:pointer;touch-action:none;border-radius:100px;width:100%;height:52px;transition:box-shadow .2s;position:relative;overflow:hidden}.slide-track.active{box-shadow:0 0 0 3px #667eea26}.slide-fill{pointer-events:none;background:linear-gradient(90deg,#4caf5026,#667eea33);border-radius:100px;height:100%;transition:width 50ms linear;position:absolute;top:0;left:0}.slide-track-hint{pointer-events:none;justify-content:center;align-items:center;gap:8px;animation:2s ease-in-out infinite hintShimmer;display:flex;position:absolute;inset:0}.hint-chevrons{color:var(--accent-secondary);opacity:.4;letter-spacing:2px;font-size:18px;font-weight:700;animation:1.5s ease-in-out infinite chevronSlide}.hint-text{color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;opacity:.5;font-size:14px;font-weight:600}@keyframes hintShimmer{0%,to{opacity:.6}50%{opacity:1}}@keyframes chevronSlide{0%{opacity:.3;transform:translate(-4px)}50%{opacity:.6;transform:translate(4px)}to{opacity:.3;transform:translate(-4px)}}.slide-thumb{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));cursor:grab;z-index:2;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;transition:box-shadow .2s,transform .1s;display:flex;position:absolute;top:3px;box-shadow:0 2px 10px #667eea66,0 0 0 4px #667eea1a}.slide-thumb.grabbing{cursor:grabbing;transform:scale(1.08);box-shadow:0 4px 16px #667eea80,0 0 0 8px #667eea26}.thumb-inner{justify-content:center;align-items:center;display:flex}.thumb-chevrons{color:#fff;letter-spacing:1px;text-shadow:0 1px 3px #0003;font-size:16px;font-weight:700}@media (max-width:480px){.slide-track{height:48px}.slide-thumb{width:42px;height:42px}.slide-value-display{font-size:38px}}.onboarding{max-width:720px;color:var(--text-primary);margin:0 auto;padding:90px 24px 60px;position:relative}.back-to-habits-button{background:var(--surface-secondary);color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-medium);cursor:pointer;transition:var(--transition);padding:8px 16px;font-family:inherit;font-size:13px;position:absolute;top:28px;left:28px}.back-to-habits-button:hover{background:var(--surface-accent);color:var(--accent-primary);border-color:var(--accent-primary)}.progress-bar{background:var(--border-subtle);border-radius:var(--radius-small);width:100%;height:6px;margin-bottom:18px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent-secondary), var(--accent-primary));border-radius:var(--radius-small);height:100%;transition:width .4s}.step-indicator{color:var(--text-muted);text-align:center;margin-bottom:40px;font-size:14px}.onboarding-content{flex-direction:column;align-items:center;display:flex}.onboarding-card{background:var(--surface-primary);box-shadow:var(--shadow-medium);border:1px solid var(--border-subtle);width:100%;min-height:500px;transition:background var(--transition), border var(--transition);border-radius:26px;flex-direction:column;justify-content:space-between;margin-bottom:35px;padding:55px 45px;display:flex}.step h2{color:var(--text-primary);margin-bottom:12px;font-size:30px;font-weight:700}.onboarding .subtitle{color:var(--text-muted);margin-bottom:40px;font-size:15px}.focus-grid{grid-template-columns:repeat(2,minmax(150px,1fr));gap:22px;margin:30px 0 10px;display:grid}.focus-option{background:var(--surface-secondary);color:var(--text-secondary);border:1px solid var(--border-subtle);cursor:pointer;border-radius:18px;justify-content:center;align-items:center;gap:10px;padding:20px;font-family:inherit;font-size:15px;font-weight:500;transition:all .25s;display:flex}.focus-option:hover{background:var(--surface-accent);transform:translateY(-2px)}.focus-option.selected{background:var(--surface-accent);border-color:var(--accent-secondary);color:var(--accent-secondary);transform:translateY(-2px);box-shadow:0 8px 20px #667eea33}.focus-emoji{font-size:18px}.slider-container{text-align:center;padding:24px 0}.slider-emoji{margin-bottom:8px;font-size:48px;transition:all .3s;animation:.4s sliderEmojiBounce}@keyframes sliderEmojiBounce{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}.slider-value-large{color:var(--accent-secondary);margin-bottom:20px;font-size:44px;font-weight:800;line-height:1}.slider-unit{color:var(--text-muted);font-size:18px;font-weight:500}.slider-labels{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;margin-bottom:8px;font-size:12px;font-weight:600;display:flex}.slider{appearance:none;background:var(--border-subtle);cursor:pointer;border-radius:100px;outline:none;width:100%;height:10px;transition:background .1s}.slider::-webkit-slider-thumb{appearance:none;background:var(--accent-secondary);border:3px solid var(--surface-primary);cursor:grab;border-radius:50%;width:28px;height:28px;transition:box-shadow .2s,transform .2s;box-shadow:0 2px 8px #667eea66,0 0 0 6px #667eea1f}.slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15);box-shadow:0 2px 12px #667eea80,0 0 0 10px #667eea26}.slider::-moz-range-thumb{background:var(--accent-secondary);border:3px solid var(--surface-primary);cursor:grab;border-radius:50%;width:28px;height:28px;box-shadow:0 2px 8px #667eea66,0 0 0 6px #667eea1f}.slider::-moz-range-thumb:active{cursor:grabbing;transform:scale(1.15)}.slider-hint{color:var(--text-muted);opacity:.7;letter-spacing:1px;margin-top:12px;font-size:12px;animation:2s ease-in-out infinite hintPulse}@keyframes hintPulse{0%,to{opacity:.5}50%{opacity:.9}}.slider-value{color:var(--accent-secondary);margin-top:24px;font-size:28px;font-weight:700}.goal-input-container{position:relative}.goal-textarea{border-radius:var(--radius-medium);background:var(--surface-secondary);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);resize:vertical;transition:border var(--transition);padding:16px;font-family:inherit;font-size:15px}.goal-textarea::placeholder{color:var(--text-muted)}.goal-textarea:focus{border-color:var(--accent-secondary);outline:none;box-shadow:0 0 0 3px #667eea26}.micro-copy{border-radius:var(--radius-large);background:var(--surface-accent);border:1px solid var(--border-subtle);color:var(--accent-secondary);text-align:center;justify-content:center;align-items:center;min-height:54px;margin-top:24px;padding:14px 18px;font-size:14px;font-weight:500;line-height:1.5;display:flex}.next-button{background:linear-gradient(135deg, var(--accent-secondary), var(--accent-primary));color:#fff;cursor:pointer;border:none;border-radius:18px;padding:16px 42px;font-family:inherit;font-size:16px;font-weight:600;transition:all .2s;box-shadow:0 12px 30px #667eea59}.next-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 16px 36px #667eea73}.next-button:active:not(:disabled){transform:scale(.98)}.next-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.secondary-button{color:var(--text-muted);border:1px solid var(--border-subtle);border-radius:var(--radius-large);cursor:pointer;transition:var(--transition);background:0 0;margin-top:16px;padding:12px 30px;font-family:inherit;font-size:14px}.secondary-button:hover{color:var(--text-primary);border-color:var(--text-secondary)}@media (max-width:600px){.onboarding{padding:70px 16px 40px}.onboarding-card{min-height:400px;padding:36px 24px}.step h2{font-size:24px}.focus-grid{grid-template-columns:1fr;gap:14px}.back-to-habits-button{top:16px;left:16px}}.sleekbot-fab-wrapper{z-index:9990;position:fixed;bottom:24px;right:24px}.sleekbot-tooltip{background:var(--surface-primary);width:220px;color:var(--text-primary);border-radius:var(--radius-medium);border:1px solid var(--border-subtle);box-shadow:var(--shadow-medium);pointer-events:none;padding:12px 16px;font-size:13px;font-weight:500;line-height:1.5;animation:.4s forwards tooltipFadeIn;position:absolute;bottom:70px;right:0}.tooltip-arrow{background:var(--surface-primary);border-right:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);width:12px;height:12px;position:absolute;bottom:-6px;right:22px;transform:rotate(45deg)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sleekbot-float{cursor:pointer;background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;animation:3.5s ease-in-out infinite sleekbot-breathe;display:flex;position:relative;box-shadow:0 4px 14px #4caf5059,0 2px 6px #0000001f}.sleekbot-float:hover{box-shadow:0 6px 20px #4caf5073,0 4px 10px #00000026;transform:scale(1.08)!important}.sleekbot-float:active{transform:scale(.95)!important}.sleekbot-float.active{background:var(--surface-secondary);color:var(--text-primary);box-shadow:var(--shadow-soft);border:1px solid var(--border-subtle);animation:none}@keyframes sleekbot-breathe{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.fab-icon{justify-content:center;align-items:center;font-size:26px;line-height:1;transition:transform .3s cubic-bezier(.34,1.56,.64,1);display:flex}.fab-icon.rotated{font-size:20px;transform:rotate(90deg)}.sleekbot-badge{color:#fff;border:2.5px solid var(--surface-primary,#fff);background:#ff3b30;border-radius:50px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-size:11px;font-weight:700;line-height:1;animation:.3s cubic-bezier(.34,1.56,.64,1) badgePop;display:flex;position:absolute;top:-4px;right:-4px}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.sleekbot-panel{background:var(--surface-primary);border-radius:var(--radius-large);border:1px solid var(--border-subtle);z-index:9995;flex-direction:column;width:380px;max-height:540px;animation:.3s cubic-bezier(.22,1,.36,1) panelSlideUp;display:flex;position:fixed;bottom:96px;right:24px;overflow:hidden;box-shadow:0 16px 50px #00000024,0 6px 16px #0000000f}@keyframes panelSlideUp{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-header{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.chat-header-left{align-items:center;gap:10px;min-width:0;display:flex}.bot-avatar-sm{background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;display:flex}.chat-header-info{flex-direction:column;min-width:0;display:flex}.chat-header-name{letter-spacing:.3px;font-size:15px;font-weight:700}.chat-header-context{opacity:.8;white-space:nowrap;text-overflow:ellipsis;max-width:220px;font-size:11px;overflow:hidden}.chat-close-btn{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:background .2s;display:flex}.chat-close-btn:hover{background:#ffffff4d}.chat-messages{scrollbar-width:thin;scrollbar-color:var(--border-subtle) transparent;flex-direction:column;flex:1;gap:6px;min-height:180px;max-height:320px;padding:16px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:5px}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:100px}.chat-welcome{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;margin:auto;padding:30px 20px;animation:.5s forwards welcomeFade;display:flex}@keyframes welcomeFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.bot-avatar-lg{background:var(--surface-accent);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:4px;font-size:28px;display:flex}.welcome-title{color:var(--text-primary);margin:0;font-size:17px;font-weight:700}.welcome-sub{color:var(--text-muted);max-width:260px;margin:0;font-size:13px;line-height:1.5}.welcome-dots{gap:5px;margin-top:8px;display:flex}.welcome-dots span{background:var(--accent-primary);opacity:.4;border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite welcomeBounce}.welcome-dots span:nth-child(2){animation-delay:.2s}.welcome-dots span:nth-child(3){animation-delay:.4s}@keyframes welcomeBounce{0%,80%,to{opacity:.3;transform:scale(.6)}40%{opacity:.6;transform:scale(1)}}.chat-row{align-items:flex-end;gap:8px;animation:.25s forwards bubbleFade;display:flex}.chat-row.ai{align-self:flex-start}.chat-row.user{flex-direction:row-reverse;align-self:flex-end}@keyframes bubbleFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.bot-avatar-msg{background:var(--surface-accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.chat-bubble{word-wrap:break-word;border-radius:16px;max-width:78%;padding:10px 14px;font-size:14px;line-height:1.5}.chat-bubble.ai{background:var(--surface-secondary);color:var(--text-primary);border:1px solid var(--border-subtle);border-bottom-left-radius:4px}.chat-bubble.user{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border-bottom-right-radius:4px}.typing-indicator{background:var(--surface-secondary);border:1px solid var(--border-subtle);border-radius:16px 16px 16px 4px;gap:5px;padding:12px 16px;display:flex}.typing-indicator span{background:var(--accent-primary);opacity:.5;border-radius:50%;width:7px;height:7px;animation:1.4s ease-in-out infinite typingBounce;display:inline-block}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{opacity:.3;transform:scale(.6)}40%{opacity:.7;transform:scale(1)}}.quick-replies{border-top:1px solid var(--border-subtle);background:var(--surface-primary);flex-wrap:wrap;flex-shrink:0;gap:6px;padding:8px 16px 12px;display:flex}.quick-reply-btn{color:var(--accent-secondary);background:var(--surface-accent);border:1px solid var(--border-subtle);cursor:pointer;white-space:nowrap;border-radius:50px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s}.quick-reply-btn:hover{background:var(--accent-secondary);color:#fff;border-color:var(--accent-secondary);transform:translateY(-1px)}.quick-reply-btn:active{transform:scale(.96)}.chat-error{cursor:pointer;background:#ef44440f;border-top:1px solid #ef444426;flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;transition:background .2s;display:flex}.chat-error:hover{background:#ef44441a}.error-icon{flex-shrink:0;font-size:14px}.error-text{color:var(--danger);flex:1;font-size:13px}.error-retry{color:var(--danger);border:1px solid var(--danger);cursor:pointer;background:0 0;border-radius:50px;flex-shrink:0;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s}.error-retry:hover{background:var(--danger);color:#fff}.chat-paywall{text-align:center;background:linear-gradient(135deg,#d4af3714 0%,#d4af370a 100%);border-top:1px solid #d4af3740;flex-direction:column;flex-shrink:0;align-items:center;gap:8px;padding:20px 20px 16px;display:flex}.paywall-icon{font-size:28px;line-height:1}.paywall-title{color:var(--text-primary);margin:0;font-size:14px;font-weight:700}.paywall-sub{color:var(--text-secondary);margin:0;font-size:12px;line-height:1.5}.paywall-upgrade-btn{color:#000;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#d4af37 0%,#f5e083 50%,#d4af37 100%);border:none;border-radius:50px;margin-top:4px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:700;transition:opacity .2s,transform .15s}.paywall-upgrade-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.paywall-upgrade-btn:disabled{opacity:.6;cursor:not-allowed}.paywall-error{color:var(--danger);text-align:center;margin:0;font-size:12px}.chat-input-form{border-top:1px solid var(--border-subtle);background:var(--surface-primary);flex-shrink:0;align-items:center;display:flex}.chat-input-form input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:14px 16px;font-family:inherit;font-size:14px}.chat-input-form input::placeholder{color:var(--text-muted)}.chat-input-form input:disabled{opacity:.5}.chat-input-form button{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;margin-right:6px;transition:all .2s;display:flex}.chat-input-form button:hover:not(:disabled){background:var(--accent-primary-hover,#43a047);transform:scale(1.05)}.chat-input-form button:disabled{opacity:.3;cursor:not-allowed;transform:none}.chat-input-form button svg{width:18px;height:18px}@media (max-width:768px){.sleekbot-fab-wrapper{bottom:16px;right:16px}.sleekbot-float{width:54px;height:54px}.fab-icon{font-size:24px}.sleekbot-tooltip{width:200px;bottom:62px;right:-4px}.sleekbot-panel{border-radius:var(--radius-medium);width:calc(100vw - 32px);max-height:65vh;bottom:82px;right:16px}.chat-messages{max-height:45vh}.quick-replies{padding:6px 12px 10px}.quick-reply-btn{padding:5px 10px;font-size:11px}}@media (max-width:380px){.sleekbot-panel{width:calc(100vw - 16px);right:8px}}.habit-screen{max-width:600px;margin:0 auto;padding:20px}.habit-topbar{justify-content:space-between;align-items:center;gap:10px;margin-bottom:30px;display:flex}.back-to-list{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;white-space:nowrap;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.back-to-list:hover{border-color:var(--color-primary);color:var(--color-primary)}.logout-button{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:14px;transition:all .2s}.logout-button:hover{border-color:var(--color-danger);color:var(--color-danger)}.streak-badge{color:var(--color-danger);background:#ef44441f;border-radius:20px;padding:10px 20px;font-size:16px;font-weight:600}.habit-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);border-radius:16px;padding:40px}.habit-card h1{color:var(--color-text);text-align:center;margin-bottom:30px;font-size:24px}.habit-action{background:var(--color-surface-elevated);border-radius:12px;align-items:center;gap:15px;margin-bottom:20px;padding:20px;display:flex}.habit-action p{color:var(--color-text);margin:0;font-size:18px;font-weight:500}.habit-meta{justify-content:center;gap:20px;margin-top:10px;display:flex}.meta-item{color:var(--color-text-secondary);font-size:15px}.complete-button{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;margin-top:30px;padding:18px;font-size:18px;font-weight:600;transition:all .2s}.complete-button:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-sm)}.complete-button:disabled{opacity:.5;cursor:not-allowed}.completion-section{text-align:center;margin-top:30px}.checkmark{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;margin:0 auto 20px;font-size:36px;animation:.4s scaleIn;display:flex}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.motivation-message{color:var(--color-text-secondary);margin:15px 0;font-size:16px}.xp-notification{color:#f59e0b;background:#f59e0b1f;border-radius:20px;margin-bottom:20px;padding:10px 18px;font-weight:600;display:inline-block}.reminder-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;margin-top:25px;padding:20px}.reminder-section h3{color:var(--color-text);margin-bottom:12px;font-size:16px}.reminder-controls{flex-wrap:wrap;gap:10px;display:flex}.reminder-controls input[type=time]{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:8px;padding:10px 14px}.reminder-save-btn{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 16px}.reminder-delete-btn{color:var(--color-danger);border:1px solid var(--color-danger);cursor:pointer;background:0 0;border-radius:8px;padding:10px 16px}.reminder-status{color:var(--color-text-secondary);margin-top:8px;font-size:13px}.restart-button{color:var(--color-text-secondary);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:8px;margin-top:30px;padding:12px 24px;transition:all .2s}.restart-button:hover{border-color:var(--color-primary);color:var(--color-primary)}.reminder-section{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);border-radius:14px;margin-top:20px;padding:24px}.reminder-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.reminder-icon{font-size:22px}.reminder-header h3{color:var(--color-text);margin:0;font-size:16px;font-weight:700}.reminder-description{color:var(--color-text-secondary);margin-bottom:16px;font-size:14px;line-height:1.5}.reminder-active{text-align:center}.reminder-time-display{justify-content:center;align-items:center;gap:10px;margin-bottom:8px;display:flex}.reminder-clock{font-size:20px}.reminder-time-text{color:var(--color-primary);font-size:28px;font-weight:800}.reminder-status-dot{background:var(--color-success,#16a34a);border-radius:50%;width:10px;height:10px;animation:2s ease-in-out infinite dotPulse}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.reminder-note{color:var(--color-text-muted);margin-bottom:16px;font-size:13px}.reminder-set-row,.reminder-edit-row{align-items:center;gap:10px;display:flex}.reminder-time-input{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:10px;outline:none;flex:1;padding:12px 16px;font-family:inherit;font-size:16px;transition:border-color .2s}.reminder-time-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4caf501f}.reminder-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.reminder-btn.save,.reminder-btn.update{background:var(--color-primary);color:#fff}.reminder-btn.save:hover:not(:disabled),.reminder-btn.update:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.reminder-btn.remove{color:var(--color-danger);border:1px solid var(--color-danger);background:0 0;width:100%;margin-top:10px;padding:10px}.reminder-btn.remove:hover:not(:disabled){background:var(--color-danger);color:#fff}.reminder-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.reminder-actions{margin-top:12px}@media (max-width:768px){.habit-card{padding:24px}.complete-button{font-size:16px}.habit-meta{flex-direction:column;align-items:center;gap:8px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.reveal-screen{background:radial-gradient(circle at 20% 20%, var(--app-glow-1), transparent 40%), radial-gradient(circle at 80% 70%, var(--app-glow-2), transparent 40%), var(--app-bg-base);justify-content:center;align-items:center;min-height:100vh;padding:40px;animation:.6s revealFadeIn;display:flex}.analyzing-state{text-align:center;max-width:420px}.pulse-ring{background:radial-gradient(circle, var(--accent-secondary) 0%, transparent 70%);border-radius:50%;width:90px;height:90px;margin:0 auto 30px;animation:2s infinite revealPulse}.analyzing-state h2{color:var(--text-primary);margin-bottom:10px;font-size:22px;font-weight:600}.analyzing-state p{color:var(--text-muted);font-size:15px}.reveal-card{background:var(--surface-primary);text-align:center;border:1px solid var(--border-subtle);width:100%;max-width:650px;box-shadow:var(--shadow-large);border-radius:30px;padding:65px 55px;animation:.7s revealLiftIn}.blueprint-badge{border-radius:var(--radius-medium);background:var(--surface-accent);color:var(--accent-secondary);letter-spacing:1.5px;margin-bottom:25px;padding:6px 16px;font-size:12px;font-weight:700;display:inline-block}.reveal-card .habit-title{color:var(--text-primary);min-height:48px;margin-bottom:35px;font-size:34px;font-weight:700;line-height:1.3}.habit-details{color:var(--text-secondary);margin-bottom:30px;font-size:15px;line-height:2}.identity-anchor{color:var(--accent-secondary);letter-spacing:.5px;margin:20px 0;font-size:14px;font-weight:700}.reveal-microcopy{color:var(--text-secondary);margin:25px 0 35px;font-size:15px;font-style:italic;line-height:1.6}.start-button{background:linear-gradient(135deg, var(--accent-secondary), var(--accent-primary));color:#fff;cursor:pointer;border:none;border-radius:20px;padding:16px 46px;font-family:inherit;font-size:16px;font-weight:600;transition:all .25s;box-shadow:0 14px 35px #667eea59}.start-button:hover{transform:translateY(-3px);box-shadow:0 20px 45px #667eea73}.start-button:active{transform:scale(.98)}@keyframes revealPulse{0%{opacity:.7;transform:scale(1)}50%{opacity:.3;transform:scale(1.2)}to{opacity:.7;transform:scale(1)}}@keyframes revealLiftIn{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes revealFadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:600px){.reveal-screen{padding:24px 16px}.reveal-card{border-radius:22px;padding:40px 28px}.reveal-card .habit-title{font-size:24px}}.habit-list-screen{max-width:1100px;margin:0 auto;padding:0 0 40px}.brand-header{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border-radius:0 0 24px 24px;margin-bottom:24px;padding:24px 20px}.brand-header-content{justify-content:space-between;align-items:center;gap:16px;max-width:1100px;margin:0 auto;display:flex}.brand-header h1{color:#fff;margin-bottom:2px;font-size:30px;font-weight:700;line-height:1.1}.brand-subtitle{color:#fffc;margin:0;font-size:13px}.brand-header .header-actions{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;gap:8px;display:flex}.header-btn{border-radius:var(--radius-small);color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1a;border:1.5px solid #fff6;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.header-btn:hover{background:#ffffff40;border-color:#fff}@media (max-width:520px){.brand-header{padding:20px 16px 16px}.brand-header-content{flex-direction:column;align-items:flex-start;gap:14px}.brand-header h1{font-size:26px}.brand-header .header-actions{grid-template-columns:repeat(3,1fr);gap:8px;width:100%;display:grid}.header-btn{text-align:center;padding:8px 6px;font-size:12px}}.habit-list-screen>:not(.brand-header){padding-left:20px;padding-right:20px}.notif-prompt{background:var(--surface-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-medium);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;padding:14px 16px;font-size:14px;display:flex}.notif-enable-btn{background:var(--accent-primary);color:#fff;border-radius:var(--radius-small);cursor:pointer;border:none;padding:8px 14px;font-size:13px;font-weight:600}.notif-dismiss-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:13px}.empty-state{text-align:center;background:var(--surface-primary);border-radius:var(--radius-large);border:1px solid var(--border-subtle);box-shadow:var(--shadow-soft);margin:0 20px;padding:60px 20px}.empty-icon{margin-bottom:14px;font-size:52px}.empty-state h2{color:var(--text-primary);margin-bottom:8px;font-size:24px}.empty-state p{color:var(--text-secondary);margin-bottom:24px}.habits-container{flex-direction:column;gap:24px;display:flex}.habits-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}@media (max-width:520px){.habits-grid{grid-template-columns:1fr}}.habit-card{background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-large);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-soft);padding:20px;position:relative}.habit-card:hover{box-shadow:var(--shadow-medium);transform:translateY(-3px)}.delete-habit-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px;line-height:1;position:absolute;top:10px;right:12px}.delete-habit-btn:hover{color:var(--danger)}.habit-icon{margin-bottom:10px;font-size:26px}.habit-card h3{color:var(--text-primary);margin-bottom:12px;padding-right:20px;font-size:16px;line-height:1.4}.habit-meta{color:var(--text-secondary);justify-content:space-between;margin-bottom:8px;font-size:13px;display:flex}.habit-trigger{color:var(--text-muted);font-size:13px}.create-buttons-row{flex-wrap:wrap;gap:12px;display:flex}.create-button{border-radius:var(--radius-medium);background:var(--accent-primary);color:#fff;cursor:pointer;transition:var(--transition);border:none;padding:12px 20px;font-size:14px;font-weight:600}.create-button:hover{transform:translateY(-2px)}.create-button.secondary{background:var(--surface-secondary);color:var(--text-primary);border:1px solid var(--border-subtle)}@media (max-width:520px){.create-buttons-row{flex-direction:column}.create-button{text-align:center;width:100%}}.custom-habit-form{background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-large);box-shadow:var(--shadow-soft);margin-bottom:24px;padding:24px 20px}.custom-habit-form h3{color:var(--text-primary);margin-bottom:18px;font-size:18px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-group input,.form-group select{border-radius:var(--radius-small);border:1px solid var(--border-subtle);background:var(--surface-secondary);width:100%;color:var(--text-primary);box-sizing:border-box;padding:10px 12px;font-size:15px}.form-row{gap:16px;display:flex}@media (max-width:520px){.form-row{flex-direction:column}}.form-actions{gap:12px;margin-top:16px;display:flex}.cancel-button{border:1px solid var(--border-subtle);color:var(--text-secondary);border-radius:var(--radius-medium);cursor:pointer;background:0 0;padding:12px 18px;font-size:14px}.loading{text-align:center;color:var(--text-secondary);padding:60px 20px;font-size:18px}.confirm-overlay{-webkit-backdrop-filter:blur(4px);z-index:9999;background:#0000008c;justify-content:center;align-items:center;padding:1.5rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.confirm-modal{background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-large);width:100%;max-width:320px;box-shadow:var(--shadow-large);padding:1.75rem 1.5rem 1.5rem;animation:.2s slideUp}.confirm-message{color:var(--text-primary);text-align:center;margin:0 0 1.5rem;font-size:1rem;line-height:1.5}.confirm-actions{gap:.75rem;display:flex}.confirm-btn{border-radius:var(--radius-medium);cursor:pointer;transition:var(--transition);border:none;flex:1;padding:.75rem;font-size:.95rem;font-weight:600}.confirm-cancel{background:var(--surface-secondary);color:var(--text-secondary);border:1px solid var(--border-subtle)}.confirm-cancel:hover{background:var(--surface-accent)}.confirm-ok{background:var(--danger);color:#fff}.confirm-ok:hover{opacity:.88}.analytics-screen{max-width:1100px;color:var(--text-primary);margin:0 auto;padding:0 0 60px}.analytics-brand-header{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border-radius:0 0 24px 24px;margin-bottom:32px;padding:24px 20px}.analytics-brand-content{justify-content:space-between;align-items:center;gap:16px;max-width:1100px;margin:0 auto;display:flex}.analytics-brand-header h1{letter-spacing:-.5px;color:#fff;margin-bottom:4px;font-size:28px;font-weight:800;line-height:1.1}.analytics-brand-header p{color:#fffc;margin:0;font-size:13px}.header-btn-light{border-radius:var(--radius-small);color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1a;border:1.5px solid #fff6;flex-shrink:0;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.header-btn-light:hover{background:#ffffff40;border-color:#fff}@media (max-width:520px){.analytics-brand-header{padding:20px 16px 16px}.analytics-brand-content{flex-direction:column;align-items:flex-start;gap:14px}.analytics-brand-header h1{font-size:24px}.header-btn-light{align-self:flex-start}}.analytics-screen>:not(.analytics-brand-header){padding-left:16px;padding-right:16px}@media (max-width:520px){.stats-grid{grid-template-columns:1fr 1fr;gap:12px}}.stat-card{background:var(--surface-primary);border:1px solid var(--border-subtle);box-shadow:var(--shadow-soft);border-radius:14px;padding:20px;transition:all .25s}.stat-label{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:8px;font-size:10px;display:block}.stat-value{font-size:36px;font-weight:800;line-height:1.05;display:block}@media (max-width:520px){.stat-card{padding:16px 14px}.stat-value{font-size:28px}}.stat-card.emphasis{border:2px solid var(--accent-primary)}.stat-card.emphasis .stat-value{color:var(--accent-primary)}.stat-card.motivational{background:var(--surface-secondary)}.stat-message{font-size:16px;font-weight:600}.habits-breakdown{background:var(--surface-primary);box-shadow:var(--shadow-soft);border:1px solid var(--border-subtle);border-radius:18px;margin-bottom:24px;padding:24px 20px}.habits-breakdown h2{margin-bottom:20px;font-size:20px}.breakdown-list{flex-direction:column;gap:12px;display:flex}.breakdown-item{border-radius:var(--radius-medium);background:var(--surface-secondary);border:1px solid var(--border-subtle);transition:var(--transition);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.breakdown-item:hover{border-color:var(--accent-primary)}@media (max-width:520px){.breakdown-item{flex-direction:column;align-items:flex-start;gap:8px}}.breakdown-name{font-size:14px;font-weight:600}.breakdown-stats{align-items:center;gap:10px;display:flex}.breakdown-streak{color:var(--accent-primary);font-size:13px;font-weight:600}.breakdown-difficulty{color:var(--text-muted);text-transform:capitalize;font-size:12px}.insights-section{background:var(--surface-primary);box-shadow:var(--shadow-soft);border:1px solid var(--border-subtle);border-radius:18px;padding:24px 20px}.insights-section h2{margin-bottom:20px;font-size:20px}.insights-grid{gap:16px;display:grid}.insight-card{background:var(--surface-secondary);border:1px solid var(--border-subtle);transition:var(--transition);border-radius:14px;padding:18px}.insight-card:hover{border-color:var(--accent-primary)}.insight-card h3{margin-bottom:6px;font-size:15px}.insight-card p{color:var(--text-secondary);font-size:14px;line-height:1.6}.feedback-screen{background:var(--app-bg-base);min-height:100vh;padding-bottom:60px}.feedback-header{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border-radius:0 0 24px 24px;padding:28px 0}.header-content{justify-content:space-between;align-items:center;max-width:900px;margin:0 auto;padding:0 24px;display:flex}.feedback-header h1{margin-bottom:4px;font-size:34px}.feedback-header .subtitle{color:#fffc;font-size:14px}.header-btn-white{border-radius:var(--radius-small);color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1a;border:1.5px solid #fff6;padding:9px 18px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.header-btn-white:hover{background:#ffffff40;border-color:#fff}.feedback-container{max-width:900px;margin:-20px auto 0;padding:0 24px}.feedback-tabs{background:var(--surface-primary);border-radius:var(--radius-large) var(--radius-large) 0 0;border:1px solid var(--border-subtle);gap:8px;padding:8px;display:flex}.tab{border-radius:var(--radius-small);cursor:pointer;color:var(--text-secondary);transition:var(--transition);background:0 0;border:none;flex:1;padding:12px;font-weight:600}.tab.active{background:var(--accent-primary);color:#fff}.feedback-form-section,.feedback-history{background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:0 0 var(--radius-large) var(--radius-large);box-shadow:var(--shadow-soft);padding:32px}.beta-notice{background:var(--surface-secondary);border-left:4px solid var(--warning);border-radius:var(--radius-medium);align-items:center;gap:16px;margin-bottom:32px;padding:20px;display:flex}.beta-badge{background:var(--warning);color:#fff;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:700}.feedback-form .form-group{margin-bottom:24px}.feedback-form label{color:var(--text-primary);margin-bottom:6px;font-weight:600;display:block}.feedback-type-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.type-option{border-radius:var(--radius-medium);border:1px solid var(--border-subtle);background:var(--surface-secondary);cursor:pointer;transition:var(--transition);padding:16px}.type-option:hover{border-color:var(--accent-primary)}.type-option.selected{border:2px solid var(--accent-primary);background:var(--surface-accent)}.type-label{color:var(--text-primary);margin-bottom:4px;font-weight:600}.type-description{color:var(--text-secondary);font-size:14px}.feedback-form input,.feedback-form textarea{border-radius:var(--radius-small);border:1px solid var(--border-subtle);background:var(--surface-secondary);width:100%;color:var(--text-primary);transition:var(--transition);padding:12px;font-size:15px}.feedback-form input:focus,.feedback-form textarea:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #4caf5026}.char-count{text-align:right;color:var(--text-muted);margin-top:4px;font-size:12px}.rating-selector{align-items:center;gap:6px;display:flex}.star{cursor:pointer;opacity:.4;transition:var(--transition);background:0 0;border:none;font-size:28px}.star.selected{opacity:1;transform:scale(1.1)}.submit-button{border-radius:var(--radius-medium);background:var(--accent-primary);color:#fff;cursor:pointer;width:100%;transition:var(--transition);border:none;padding:14px;font-weight:600}.submit-button:hover:not(:disabled){transform:translateY(-2px)}.feedback-item{background:var(--surface-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-medium);padding:20px}.feedback-item h4{color:var(--text-primary)}.feedback-message{color:var(--text-secondary);margin-top:6px}.feedback-date{color:var(--text-muted);font-size:13px}@media (max-width:768px){.feedback-type-grid{grid-template-columns:1fr}.feedback-form-section,.feedback-history{padding:20px}}.loading-state,.error-state{color:var(--text-muted);justify-content:center;align-items:center;padding:60px 20px;font-size:18px;display:flex}.error-state{color:var(--danger)}.stats-header,.analytics-header,.logs-header,.users-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.stats-header h2,.analytics-header h2,.logs-header h2,.users-header h2{color:var(--text-primary);margin:0;font-size:24px}.refresh-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s}.refresh-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--surface-primary);box-shadow:var(--shadow-soft);border-left:4px solid;border-radius:12px;align-items:center;gap:16px;padding:24px;transition:all .3s;display:flex}.stat-card:hover{box-shadow:var(--shadow-medium);transform:translateY(-2px)}.stat-icon{border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.stat-content{flex:1}.stat-label{color:var(--text-muted);margin-bottom:4px;font-size:14px}.stat-value{color:var(--text-primary);font-size:28px;font-weight:700}.users-by-role{background:var(--surface-secondary);border-radius:12px;margin-top:24px;padding:24px}.users-by-role h3{color:var(--text-primary);margin:0 0 16px;font-size:18px}.role-breakdown{gap:16px;display:flex}.role-item{background:var(--surface-primary);border-radius:8px;flex:1;justify-content:space-between;align-items:center;padding:16px;display:flex}.role-name{text-transform:capitalize;color:var(--accent-secondary);font-weight:600}.role-count{color:var(--text-primary);font-size:20px;font-weight:700}.users-layout{grid-template-columns:1fr;gap:24px;display:grid}.users-list{overflow-x:auto}.users-table,.logs-table{border-collapse:collapse;background:var(--surface-primary);width:100%}.users-table th,.users-table td,.logs-table th,.logs-table td{text-align:left;border-bottom:1px solid var(--border-subtle);padding:12px}.users-table th,.logs-table th{background:var(--surface-secondary);color:var(--text-primary);font-weight:600}.users-table tr.selected{background:var(--surface-accent)}.users-table tr:hover,.logs-table tr:hover{background:var(--surface-secondary)}.role-badge{text-transform:uppercase;border-radius:12px;padding:4px 12px;font-size:12px;font-weight:600}.role-badge.admin{color:#c53030;background:#fed7d7}.role-badge.user{color:#2c5282;background:#bee3f8}.action-button{cursor:pointer;border:none;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:600;transition:all .2s}.action-button.view{color:#fff;background:#667eea}.action-button.view:hover{background:#5568d3}.action-button.promote{color:#fff;background:#48bb78}.action-button.demote{color:#fff;background:#ed8936}.action-button.delete{color:#fff;background:#f56565}.pagination{justify-content:center;align-items:center;gap:16px;margin-top:24px;display:flex}.pagination button{background:var(--surface-primary);border:2px solid var(--border-subtle);cursor:pointer;border-radius:8px;padding:8px 16px;font-weight:600;transition:all .2s}.pagination button:hover:not(:disabled){border-color:var(--accent-secondary);color:var(--accent-secondary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.user-details{background:var(--surface-secondary);border-radius:12px;padding:24px;position:sticky;top:24px}.details-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.details-header h3{color:var(--text-primary);margin:0;font-size:20px}.close-button{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:24px;transition:all .2s;display:flex}.close-button:hover{background:var(--border-subtle);color:var(--text-primary)}.detail-group{border-bottom:1px solid var(--border-subtle);margin-bottom:16px;padding-bottom:16px}.detail-group label{color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:12px;font-weight:600;display:block}.detail-group span{color:var(--text-primary);font-size:16px}.habits-section,.actions-section{margin-top:24px}.habits-section h4,.actions-section h4{color:var(--text-primary);margin:0 0 12px;font-size:16px}.habit-item{background:var(--surface-primary);border-radius:8px;margin-bottom:8px;padding:12px}.habit-stats{color:var(--text-muted);gap:16px;margin-top:8px;font-size:13px;display:flex}.action-buttons{flex-direction:column;gap:8px;display:flex}.analytics-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;display:grid}.analytics-card{background:var(--surface-primary);border:2px solid var(--border-subtle);border-radius:12px;padding:24px}.analytics-card h3{color:var(--text-primary);margin:0 0 20px;font-size:18px}.popular-habit-item{background:var(--surface-secondary);border-radius:8px;align-items:center;gap:12px;margin-bottom:8px;padding:12px;display:flex}.habit-rank{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.habit-info{flex:1}.habit-name{color:var(--text-primary);margin-bottom:4px;font-weight:600}.habit-metrics{color:var(--text-muted);gap:16px;font-size:13px;display:flex}.trend-chart{align-items:flex-end;gap:4px;height:200px;padding:20px 0;display:flex}.trend-bar-container{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;display:flex}.trend-bar{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:4px 4px 0 0;width:100%;min-height:4px;transition:all .3s}.trend-bar:hover{opacity:.8}.trend-label{color:var(--text-muted);margin-top:4px;font-size:10px}.difficulty-breakdown,.streak-breakdown{flex-direction:column;gap:12px;display:flex}.difficulty-item,.streak-item{align-items:center;gap:12px;display:flex}.difficulty-badge{text-transform:capitalize;text-align:center;border-radius:12px;min-width:80px;padding:6px 14px;font-size:13px;font-weight:600}.difficulty-badge.easy{color:#22543d;background:#c6f6d5}.difficulty-badge.medium{color:#7c2d12;background:#feebc8}.difficulty-badge.hard{color:#742a2a;background:#fed7d7}.difficulty-bar-container{flex:1;align-items:center;gap:8px;display:flex}.difficulty-bar{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:4px;height:24px;transition:width .5s}.difficulty-count,.streak-value{color:var(--text-primary);font-weight:600}.logs-table-container{margin-bottom:16px;overflow-x:auto}.logs-table tr.failed{background:#ef44440a}.timestamp{color:var(--text-muted);font-size:13px}.user-email{font-weight:500}.action-badge{background:var(--border-subtle);border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600}.status-badge{border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600}.status-badge.success{color:#22543d;background:#c6f6d5}.status-badge.failure{color:#742a2a;background:#fed7d7}.error{color:var(--danger);font-size:13px}.total-count{color:var(--text-muted);font-size:14px;font-weight:600}.header-actions{align-items:center;gap:16px;display:flex}@media (max-width:1024px){.users-layout{grid-template-columns:1fr}.user-details{position:static}.analytics-grid{grid-template-columns:1fr}}@media (max-width:768px){.stats-grid{grid-template-columns:1fr}.role-breakdown{flex-direction:column}.users-table,.logs-table{font-size:13px}.users-table th,.users-table td,.logs-table th,.logs-table td{padding:8px 6px}}.feedback-viewer{padding:0}.feedback-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.feedback-filters{align-items:center;gap:12px;margin-bottom:24px;display:flex}.filter-select{border:2px solid var(--border-subtle);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.filter-select:focus{border-color:var(--accent-secondary);outline:none}.feedback-layout{grid-template-columns:1fr;gap:24px;display:grid}.feedback-list-admin{overflow-x:auto}.feedback-table{border-collapse:collapse;width:100%}.feedback-table th,.feedback-table td{text-align:left;border-bottom:1px solid var(--border-subtle);padding:12px}.feedback-table th{background:var(--surface-secondary);color:var(--text-primary);font-weight:600}.feedback-table tr:hover{background:var(--surface-secondary)}.feedback-table tr.selected{background:var(--surface-accent)}.type-badge-sm{font-size:20px}.subject-cell{text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-weight:500;overflow:hidden}.date-cell{color:var(--text-muted);font-size:13px}.status-indicator{color:#fff;text-transform:capitalize;border-radius:12px;padding:4px 10px;font-size:11px;font-weight:600}.feedback-details-panel{background:var(--surface-secondary);border-radius:12px;max-height:calc(100vh - 200px);padding:24px;position:sticky;top:24px;overflow-y:auto}.feedback-detail-message{background:var(--surface-primary);color:var(--text-primary);border-radius:8px;padding:12px;line-height:1.6}.update-section{border-top:2px solid var(--border-subtle);margin-top:24px;padding-top:24px}.update-section h4{color:var(--text-primary);margin:0 0 16px;font-size:16px}.status-select{border:2px solid var(--border-subtle);border-radius:8px;width:100%;padding:10px;font-size:14px;font-weight:600}.update-section textarea{border:2px solid var(--border-subtle);resize:vertical;box-sizing:border-box;border-radius:8px;width:100%;padding:10px;font-family:inherit}.update-section textarea:focus{border-color:var(--accent-secondary);outline:none}@media (max-width:1024px){.feedback-layout{grid-template-columns:1fr}.feedback-details-panel{max-height:none;position:static}}.admin-dashboard{background:var(--app-bg-base);min-height:100vh}.admin-header{background:linear-gradient(135deg, var(--accent-secondary), #764ba2);color:#fff;box-shadow:var(--shadow-soft);padding:24px 0}.admin-header-content{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:0 24px;display:flex}.admin-header h1{margin:0;font-size:32px}.admin-header-actions{gap:12px;display:flex}.back-to-app-button,.admin-dashboard .logout-button{border-radius:var(--radius-small);cursor:pointer;border:2px solid #fff;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .3s}.back-to-app-button{color:#fff;background:0 0}.back-to-app-button:hover{color:var(--accent-secondary);background:#fff}.admin-dashboard .logout-button{color:#fff;background:#fff3}.admin-dashboard .logout-button:hover{background:#ffffff4d}.admin-container{max-width:1400px;margin:0 auto;padding:24px}.admin-tabs{background:var(--surface-primary);border-radius:var(--radius-medium);box-shadow:var(--shadow-soft);border:1px solid var(--border-subtle);gap:8px;margin-bottom:24px;padding:8px;display:flex}.admin-tab{color:var(--text-muted);border-radius:var(--radius-small);cursor:pointer;background:0 0;border:none;flex:1;padding:14px 24px;font-family:inherit;font-size:16px;font-weight:600;transition:all .3s}.admin-tab:hover{background:var(--surface-secondary);color:var(--text-primary)}.admin-tab.active{background:linear-gradient(135deg, var(--accent-secondary), #764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.admin-content{background:var(--surface-primary);border-radius:var(--radius-medium);box-shadow:var(--shadow-soft);border:1px solid var(--border-subtle);min-height:500px;padding:32px}@media (max-width:768px){.admin-header-content{text-align:center;flex-direction:column;gap:16px}.admin-header h1{font-size:24px}.admin-tabs{flex-direction:column}.admin-tab{text-align:center}.admin-content{padding:20px}}.theme-toggle-float{z-index:9989;border:1px solid var(--border-subtle);background:var(--surface-primary);cursor:pointer;width:44px;height:44px;box-shadow:var(--shadow-soft);border-radius:50%;justify-content:center;align-items:center;transition:transform .2s,box-shadow .2s,background .2s;display:flex;position:fixed;bottom:24px;left:24px}.theme-toggle-float:hover{box-shadow:var(--shadow-medium);transform:scale(1.1)}.theme-toggle-float:active{transform:scale(.95)}.theme-icon{font-size:20px;line-height:1;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.theme-icon.sun,.theme-icon.moon{transform:rotate(0)}@media (max-width:768px){.theme-toggle-float{width:40px;height:40px;bottom:16px;left:16px}.theme-icon{font-size:18px}}.animated-bg-canvas{z-index:0;pointer-events:none;opacity:.8;position:fixed;inset:0}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--app-bg-base);color:var(--text-primary);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;transition:background .4s,color .3s}.App{z-index:1;background:radial-gradient(circle at 20% 20%, var(--app-glow-1), transparent 40%), radial-gradient(circle at 80% 70%, var(--app-glow-2), transparent 40%);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;transition:background .4s;animation:.6s forwards appFade;display:flex;position:relative}.route-loading{min-height:100vh;color:var(--text-primary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.route-loading p{color:var(--text-muted);font-size:15px}.spinner{border:4px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#00000073;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.loading-screen{text-align:center;background:var(--surface-primary);border-radius:var(--radius-large);border:1px solid var(--border-subtle);box-shadow:var(--shadow-medium);color:var(--text-primary);padding:40px}.loading-screen p{color:var(--text-secondary);margin-top:16px;font-size:15px}@keyframes appFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.App{align-items:flex-start;padding:10px}}.error-boundary{background:linear-gradient(135deg, var(--accent-secondary), #764ba2);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.error-container{background:var(--surface-primary);border-radius:var(--radius-large);text-align:center;max-width:600px;box-shadow:var(--shadow-large);padding:60px 40px;animation:.5s slideIn}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.error-icon{margin-bottom:20px;font-size:80px}.error-container h1{color:var(--text-primary);margin:0 0 15px;font-size:28px}.error-message{color:var(--text-secondary);margin:0 0 30px;font-size:16px;line-height:1.6}.error-details{background:var(--surface-secondary);border-radius:var(--radius-small);text-align:left;border:1px solid var(--border-subtle);margin:20px 0;padding:20px}.error-details h3{color:var(--danger);margin:0 0 10px;font-size:14px}.error-stack{color:var(--text-muted);white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,monospace;font-size:12px;overflow-x:auto}.reset-button{background:var(--accent-primary);color:#fff;border-radius:var(--radius-medium);cursor:pointer;border:none;margin:20px 0;padding:16px 32px;font-size:18px;font-weight:700;transition:all .3s}.reset-button:hover{background:var(--accent-primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.error-help{color:var(--text-muted);text-align:left;margin-top:30px;font-size:14px}.error-help ul{margin:10px 0 0;padding-left:20px}.error-help li{margin:5px 0}
