.logo{display:flex;align-items:center;gap:12px}.logo-icon{position:relative;display:flex;align-items:center;justify-content:center}.logo-icon-small{width:32px;height:32px}.logo-icon-medium{width:48px;height:48px}.logo-icon-large{width:64px;height:64px}.logo-icon-hero{width:120px;height:120px}.logo-image{width:100%;height:100%;object-fit:contain}.logo-text{font-weight:600;color:var(--color-text)}.logo-text-small{font-size:1.125rem}.logo-text-medium{font-size:1.25rem}.logo-text-large{font-size:1.5rem}.logo-icon-only{display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.logo-icon-large{width:56px;height:56px}.logo-text-large{font-size:1.375rem}}@media (max-width: 480px){.logo-icon-large{width:48px;height:48px}.logo-text-large{font-size:1.25rem}}.footer{background:var(--color-surface);border-top:1px solid var(--color-border);padding:40px 20px 20px;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr 1fr;gap:40px;align-items:start}.footer-brand{display:flex;flex-direction:column;align-items:flex-start;gap:16px}.footer-tagline{color:var(--color-text-secondary);font-size:.9rem;line-height:1.4;margin:0}.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}.footer-section h4{color:var(--color-text);font-size:1rem;font-weight:600;margin:0 0 16px}.footer-section ul li{margin-bottom:8px}.footer-section ul li a{color:var(--color-text-secondary);text-decoration:none;font-size:.9rem;transition:color .2s ease}.footer-section ul li a:hover{color:var(--color-primary)}.footer-social{display:flex;flex-direction:column;align-items:flex-end;gap:16px}.footer-social a{color:var(--color-text-secondary);font-size:1.2rem;transition:color .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--color-surface-elevated);border:1px solid var(--color-border)}.footer-social a:hover{color:var(--color-primary);background:var(--color-surface-hover);transform:translateY(-1px)}.footer-bottom{max-width:1200px;margin:30px auto 0;padding-top:20px;border-top:1px solid var(--color-border);text-align:center}.footer-bottom p{color:var(--color-text-secondary);font-size:.85rem;margin:0;display:flex;align-items:center;justify-content:center;gap:6px}.heart-icon{color:var(--color-accent);font-size:.8rem}@media (max-width: 768px){.footer{display:none}}@media (max-width: 480px){.footer{display:none}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes gentleWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-2deg)}75%{transform:rotate(2deg)}}@keyframes emberFloat1{0%{opacity:0;transform:translate(0) scale(.4)}5%{opacity:.3;transform:translate(-.2px,-1px) scale(.45)}12%{opacity:.7;transform:translate(-.8px,-3px) scale(.55)}20%{opacity:1;transform:translate(-1.2px,-5px) scale(.65)}35%{opacity:1;transform:translate(-2px,-7px) scale(.75)}50%{opacity:.95;transform:translate(-3px,-9px) scale(.8)}65%{opacity:.8;transform:translate(-4px,-11px) scale(.85)}80%{opacity:.4;transform:translate(-5px,-13px) scale(.9)}90%{opacity:.2;transform:translate(-5.5px,-15px) scale(.7)}to{opacity:0;transform:translate(-6px,-16px) scale(.5)}}@keyframes emberFloat2{0%{opacity:0;transform:translate(0) scale(.4)}5%{opacity:.3;transform:translate(.2px,-1px) scale(.45)}12%{opacity:.7;transform:translate(.8px,-3px) scale(.55)}20%{opacity:1;transform:translate(1.2px,-5px) scale(.65)}35%{opacity:1;transform:translate(2px,-7px) scale(.75)}50%{opacity:.95;transform:translate(3px,-9px) scale(.8)}65%{opacity:.8;transform:translate(4px,-11px) scale(.85)}80%{opacity:.4;transform:translate(5px,-13px) scale(.9)}90%{opacity:.2;transform:translate(5.5px,-15px) scale(.7)}to{opacity:0;transform:translate(6px,-16px) scale(.5)}}@keyframes emberFloat3{0%{opacity:0;transform:translate(0) scale(.3)}8%{opacity:.4;transform:translateY(-2px) scale(.35)}18%{opacity:.8;transform:translateY(-5px) scale(.45)}30%{opacity:1;transform:translateY(-8px) scale(.55)}45%{opacity:1;transform:translateY(-11px) scale(.65)}60%{opacity:.9;transform:translateY(-14px) scale(.7)}75%{opacity:.6;transform:translateY(-16px) scale(.75)}85%{opacity:.3;transform:translateY(-18px) scale(.6)}95%{opacity:.1;transform:translateY(-19px) scale(.45)}to{opacity:0;transform:translateY(-20px) scale(.4)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes scale{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-pulse{animation:pulse 2s infinite}.animate-wiggle{animation:wiggle .3s ease-in-out}.animate-gentle-wiggle{animation:gentleWiggle .3s ease-in-out}.animate-scale{animation:scale .2s ease-in-out}.page-fade-base{opacity:0}.page-fade-in{opacity:0;animation:pageFadeIn .5s ease-in forwards}@keyframes pageFadeIn{to{opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes bounce{0%,20%,53%,80%,to{transform:translateZ(0)}40%,43%{transform:translate3d(0,-30px,0)}70%{transform:translate3d(0,-15px,0)}90%{transform:translate3d(0,-4px,0)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-10px)}20%,40%,60%,80%{transform:translate(10px)}}@keyframes glow{0%,to{box-shadow:0 0 5px rgba(var(--color-primary),.5)}50%{box-shadow:0 0 20px rgba(var(--color-primary),.8),0 0 30px rgba(var(--color-primary),.6)}}@keyframes sparkle{0%,to{opacity:0;transform:scale(0) rotate(0)}50%{opacity:1;transform:scale(1) rotate(180deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes wiggle{0%,7%{transform:rotate(0)}15%{transform:rotate(-15deg)}20%{transform:rotate(10deg)}25%{transform:rotate(-10deg)}30%{transform:rotate(6deg)}35%{transform:rotate(-4deg)}40%,to{transform:rotate(0)}}.fade-in{animation:fadeIn .5s ease-in}.slide-in{animation:slideIn .5s ease-out}.bounce{animation:bounce 1s ease-in-out}.shake{animation:shake .5s ease-in-out}.pulse{animation:pulse 2s infinite}.glow{animation:glow 2s infinite}.sparkle{animation:sparkle 1s ease-in-out}.float{animation:float 3s ease-in-out infinite}.slide-up{animation:slideUp .5s ease-out}.scale-in{animation:scaleIn .3s ease-out}.rotate{animation:rotate 2s linear infinite}.wiggle{animation:wiggle .5s ease-in-out}.hover-glow:hover{animation:glow 1s infinite}.hover-bounce:hover{animation:bounce .6s ease-in-out}.hover-pulse:hover{animation:pulse 1s infinite}.difficulty-easy{border-left:4px solid #4CAF50}.difficulty-medium{border-left:4px solid #FF9800}.difficulty-hard{border-left:4px solid #F44336}.streak-celebration{animation:scaleIn .5s ease-out,glow 2s infinite}.streak-icon{animation:pulse 1.5s infinite,float 3s ease-in-out infinite}.motivational-prompt{animation:slideUp .4s ease-out;transition:var(--transition)}.motivational-prompt:hover{transform:translateY(-2px);box-shadow:var(--shadow-elevated)}.template-option{transition:var(--transition)}.template-option:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.streak-celebration{animation:scaleIn .5s ease-out}.streak-celebration .streak-icon{animation:pulse 1.5s infinite,float 3s ease-in-out infinite}.template-option{transition:all .3s ease}.template-option:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.onboarding-step{animation:fadeIn .6s ease-in}.onboarding-progress{animation:slideUp .4s ease-out}.completion-feedback{animation:scaleIn .4s ease-out}.xp-popup{animation:bounce .8s ease-out,glow 1s infinite}.streak-multiplier{animation:wiggle .6s ease-in-out,pulse 1.5s infinite}.perfect-day-crown{animation:rotate 2s linear infinite,glow 2s infinite}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-color-scheme: dark){.glow{animation:glow 2s infinite}.difficulty-easy{border-left-color:#66bb6a}.difficulty-medium{border-left-color:#ffb74d}.difficulty-hard{border-left-color:#ef5350}}:root{--color-primary: #7aa2f7;--color-primary-rgb: 122, 162, 247;--color-secondary: #bb9af7;--color-secondary-rgb: 187, 154, 247;--color-accent: #7dcfff;--color-accent-rgb: 125, 207, 255;--color-success: #41a6b5;--color-success-rgb: 65, 166, 181;--color-warning: #e0af68;--color-warning-rgb: 224, 175, 104;--color-danger: #f7768e;--color-danger-rgb: 247, 118, 142;--color-text: #f7f7fa;--color-text-secondary: #a9b1d6;--color-text-muted: #7982a9;--color-background: #1a1b26;--color-surface: #24283b;--color-surface-elevated: #2a2e3f;--color-surface-hover: #2d3142;--color-border: #292e42;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #7aa2f7;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8);--border-radius: 12px;--border-radius-small: 8px;--border-radius-large: 16px;--border-radius-xl: 20px;--border-radius-xxl: 30px;--border-radius-circle: 50%;--transition: all .3s cubic-bezier(.25, .46, .45, .94);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace}[data-theme=light]{--color-primary: #3b82f6;--color-primary-rgb: 59, 130, 246;--color-secondary: #8b5cf6;--color-secondary-rgb: 139, 92, 246;--color-accent: #06b6d4;--color-accent-rgb: 6, 182, 212;--color-success: #059669;--color-success-rgb: 5, 150, 105;--color-warning: #d97706;--color-warning-rgb: 217, 119, 6;--color-danger: #dc2626;--color-danger-rgb: 220, 38, 38;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--color-background: #ffffff;--color-surface: #f9fafb;--color-surface-elevated: #ffffff;--color-surface-hover: #f3f4f6;--color-border: #e5e7eb;--color-border-light: rgba(0, 0, 0, .08);--color-border-focus: #3b82f6;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-light: 0 1px 3px rgba(0, 0, 0, .1);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .15)}[data-theme=dark]{--color-primary: #7aa2f7;--color-secondary: #bb9af7;--color-accent: #7dcfff;--color-success: #41a6b5;--color-warning: #e0af68;--color-danger: #f7768e;--color-text: #f7f7fa;--color-text-secondary: #a9b1d6;--color-text-muted: #7982a9;--color-background: #1a1b26;--color-surface: #24283b;--color-surface-elevated: #2a2e3f;--color-surface-hover: #2d3142;--color-border: #292e42;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #7aa2f7;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=ocean]{--color-primary: #0ea5e9;--color-secondary: #06b6d4;--color-accent: #22d3ee;--color-success: #14b8a6;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #f8fafc;--color-text-secondary: #cbd5e1;--color-text-muted: #94a3b8;--color-background: #0f172a;--color-surface: #1e293b;--color-surface-elevated: #334155;--color-surface-hover: #475569;--color-border: #334155;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #0ea5e9;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=forest]{--color-primary: #10b981;--color-secondary: #059669;--color-accent: #34d399;--color-success: #059669;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #f9fafb;--color-text-secondary: #d1d5db;--color-text-muted: #9ca3af;--color-background: #064e3b;--color-surface: #065f46;--color-surface-elevated: #047857;--color-surface-hover: #059669;--color-border: #047857;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #10b981;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=sunset]{--color-primary: #f97316;--color-secondary: #ec4899;--color-accent: #fb7185;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #fef2f2;--color-text-secondary: #fecaca;--color-text-muted: #fca5a5;--color-background: #7c2d12;--color-surface: #92400e;--color-surface-elevated: #b45309;--color-surface-hover: #d97706;--color-border: #b45309;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #f97316;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=purple]{--color-primary: #8b5cf6;--color-secondary: #a855f7;--color-accent: #c084fc;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #faf5ff;--color-text-secondary: #e9d5ff;--color-text-muted: #c4b5fd;--color-background: #2e1065;--color-surface: #4c1d95;--color-surface-elevated: #5b21b6;--color-surface-hover: #6d28d9;--color-border: #5b21b6;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #8b5cf6;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=monochrome]{--color-primary: #6b7280;--color-secondary: #9ca3af;--color-accent: #d1d5db;--color-success: #6b7280;--color-warning: #9ca3af;--color-danger: #ef4444;--color-text: #f9fafb;--color-text-secondary: #d1d5db;--color-text-muted: #9ca3af;--color-background: #111827;--color-surface: #1f2937;--color-surface-elevated: #374151;--color-surface-hover: #4b5563;--color-border: #374151;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #6b7280;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=rose]{--color-primary: #f43f5e;--color-secondary: #ec4899;--color-accent: #fb7185;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #fef2f2;--color-text-secondary: #fecaca;--color-text-muted: #fca5a5;--color-background: #4c0519;--color-surface: #7f1d1d;--color-surface-elevated: #991b1b;--color-surface-hover: #b91c1c;--color-border: #991b1b;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #f43f5e;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=amber]{--color-primary: #f59e0b;--color-secondary: #d97706;--color-accent: #fbbf24;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #fffbeb;--color-text-secondary: #fef3c7;--color-text-muted: #fde68a;--color-background: #451a03;--color-surface: #78350f;--color-surface-elevated: #92400e;--color-surface-hover: #b45309;--color-border: #92400e;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #f59e0b;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=emerald]{--color-primary: #10b981;--color-secondary: #059669;--color-accent: #34d399;--color-success: #059669;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #ecfdf5;--color-text-secondary: #d1fae5;--color-text-muted: #a7f3d0;--color-background: #064e3b;--color-surface: #065f46;--color-surface-elevated: #047857;--color-surface-hover: #059669;--color-border: #047857;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #10b981;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=indigo]{--color-primary: #6366f1;--color-secondary: #4f46e5;--color-accent: #818cf8;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #eef2ff;--color-text-secondary: #e0e7ff;--color-text-muted: #c7d2fe;--color-background: #1e1b4b;--color-surface: #312e81;--color-surface-elevated: #3730a3;--color-surface-hover: #4338ca;--color-border: #3730a3;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #6366f1;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=slate]{--color-primary: #64748b;--color-secondary: #475569;--color-accent: #94a3b8;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #f8fafc;--color-text-secondary: #e2e8f0;--color-text-muted: #cbd5e1;--color-background: #0f172a;--color-surface: #1e293b;--color-surface-elevated: #334155;--color-surface-hover: #475569;--color-border: #334155;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #64748b;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=zinc]{--color-primary: #71717a;--color-secondary: #52525b;--color-accent: #a1a1aa;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #fafafa;--color-text-secondary: #e4e4e7;--color-text-muted: #d4d4d8;--color-background: #18181b;--color-surface: #27272a;--color-surface-elevated: #3f3f46;--color-surface-hover: #52525b;--color-border: #3f3f46;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #71717a;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=stone]{--color-primary: #78716c;--color-secondary: #57534e;--color-accent: #a8a29e;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #fafaf9;--color-text-secondary: #f5f5f4;--color-text-muted: #e7e5e4;--color-background: #1c1917;--color-surface: #292524;--color-surface-elevated: #44403c;--color-surface-hover: #57534e;--color-border: #44403c;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #78716c;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=neutral]{--color-primary: #737373;--color-secondary: #525252;--color-accent: #a3a3a3;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-text: #fafafa;--color-text-secondary: #e5e5e5;--color-text-muted: #d4d4d4;--color-background: #171717;--color-surface: #262626;--color-surface-elevated: #404040;--color-surface-hover: #525252;--color-border: #404040;--color-border-light: rgba(255, 255, 255, .08);--color-border-focus: #737373;--shadow: 0 2px 8px rgba(0, 0, 0, .7);--shadow-light: 0 1px 3px rgba(0, 0, 0, .5);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .8)}[data-theme=instagram]{--color-primary: #e4405f;--color-secondary: #ff6b6b;--color-accent: #fd1d1d;--color-success: #00c851;--color-warning: #ff8800;--color-danger: #ff4444;--color-text: #262626;--color-text-secondary: #8e8e93;--color-text-muted: #c7c7cc;--color-background: linear-gradient(135deg, #e8ecff 0%, #d8e0ff 50%, #c8d4ff 100%);--color-surface: rgba(255, 255, 255, .75);--color-surface-elevated: rgba(255, 255, 255, .8);--color-surface-hover: rgba(255, 255, 255, .85);--color-border: rgba(219, 219, 219, .8);--color-border-light: rgba(0, 0, 0, .08);--color-border-focus: #e4405f;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-light: 0 1px 3px rgba(0, 0, 0, .1);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .15);--gradient-primary: linear-gradient(135deg, #e4405f 0%, #ff6b6b 100%);--gradient-secondary: linear-gradient(135deg, #ff6b6b 0%, #fd1d1d 100%);--gradient-accent: linear-gradient(135deg, #fd1d1d 0%, #f77737 100%);--gradient-success: linear-gradient(135deg, #00c851 0%, #00d4aa 100%);--gradient-warning: linear-gradient(135deg, #ff8800 0%, #ffb347 100%);--gradient-danger: linear-gradient(135deg, #ff4444 0%, #ff6b6b 100%);--gradient-background: linear-gradient(135deg, #e8ecff 0%, #d8e0ff 50%, #c8d4ff 100%);--gradient-surface: linear-gradient(135deg, rgba(255, 255, 255, .75) 0%, rgba(255, 255, 255, .8) 100%)}[data-theme=iphone]{--color-primary: #007aff;--color-primary-rgb: 0, 122, 255;--color-secondary: #5856d6;--color-secondary-rgb: 88, 86, 214;--color-accent: #ff3b30;--color-accent-rgb: 255, 59, 48;--color-success: #34c759;--color-success-rgb: 52, 199, 89;--color-warning: #ff9500;--color-warning-rgb: 255, 149, 0;--color-danger: #ff3b30;--color-danger-rgb: 255, 59, 48;--color-text: #000000;--color-text-secondary: #8e8e93;--color-text-muted: #c7c7cc;--color-background: #f2f2f7;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-surface-hover: #f2f2f7;--color-border: #c6c6cc;--color-border-light: rgba(0, 0, 0, .1);--color-border-focus: #007aff;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-light: 0 1px 3px rgba(0, 0, 0, .1);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .15)}[data-theme=iphone-dark]{--color-primary: #0a84ff;--color-primary-rgb: 10, 132, 255;--color-secondary: #5e5ce6;--color-secondary-rgb: 94, 92, 230;--color-accent: #ff453a;--color-accent-rgb: 255, 69, 58;--color-success: #30d158;--color-success-rgb: 48, 209, 88;--color-warning: #ff9f0a;--color-warning-rgb: 255, 159, 10;--color-danger: #ff453a;--color-danger-rgb: 255, 69, 58;--color-text: #ffffff;--color-text-secondary: #8e8e93;--color-text-muted: #48484a;--color-background: #000000;--color-surface: #1c1c1e;--color-surface-elevated: #2c2c2e;--color-surface-hover: #2c2c2e;--color-border: #38383a;--color-border-light: rgba(255, 255, 255, .1);--color-border-focus: #0a84ff;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-light: 0 1px 3px rgba(0, 0, 0, .2);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .4)}@media (prefers-color-scheme: light){:root:not([data-theme]){--color-primary: #3b82f6;--color-secondary: #8b5cf6;--color-accent: #06b6d4;--color-success: #059669;--color-warning: #d97706;--color-danger: #dc2626;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-text-muted: #9ca3af;--color-background: #ffffff;--color-surface: #f9fafb;--color-surface-elevated: #ffffff;--color-surface-hover: #f3f4f6;--color-border: #e5e7eb;--color-border-light: rgba(0, 0, 0, .08);--color-border-focus: #3b82f6;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-light: 0 1px 3px rgba(0, 0, 0, .1);--shadow-elevated: 0 4px 16px rgba(0, 0, 0, .15)}}*{box-sizing:border-box;margin:0;padding:0}body,h1,h2,h3,h4,h5,h6,.nav-item,.habit-card,.stat-card,.quest-card,.achievement-card,section,.btn,.nav-label,.habit-card__name,.habit-card__desc,.stat-card .stat-number,.stat-card .stat-label,.nav-icon,.habit-card__icon,.habit-card__streak,.habit-card__streak-number,.habit-card__streak-flame{font-family:var(--font-family)}body{font-family:var(--font-family);line-height:1.5;color:var(--color-text);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;min-height:100vh;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}body::-webkit-scrollbar{width:8px}.app-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--color-background);position:relative;max-width:none!important;margin:0!important;padding:0;transition:background-color .3s ease}.fade-enter{opacity:0;transform:scale(.98)}.fade-enter-active{opacity:1;transform:scale(1);transition:opacity .3s,transform .3s}.fade-exit{opacity:1;transform:scale(1)}.fade-exit-active{opacity:0;transform:scale(.98);transition:opacity .3s,transform .3s}.page-fade-wrapper{height:100%}.text-secondary{color:var(--color-text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}[data-theme=instagram]{background:var(--gradient-background)!important;background-attachment:fixed;.app-container{background:var(--gradient-background);background-attachment:fixed}.btn-primary,.btn-accent{background:var(--gradient-primary)!important;border:none;color:#fff;font-weight:600;box-shadow:0 4px 15px #e4405f4d}.btn-primary:hover,.btn-accent:hover{background:var(--gradient-secondary)!important;transform:translateY(-2px);box-shadow:0 6px 20px #e4405f66}.habit-card,.stat-card,.quest-card,.achievement-card{background:var(--gradient-surface);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.habit-card:hover,.stat-card:hover,.quest-card:hover,.achievement-card:hover{background:linear-gradient(135deg,#ffffffd9,#ffffffe6);transform:translateY(-4px);box-shadow:0 12px 40px #00000026}.nav-item.active{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 15px #e4405f4d}.habit-card__streak,.progress-bar{background:var(--gradient-success);box-shadow:0 2px 8px #00c8514d}.modal-content{background:var(--gradient-surface);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.3);box-shadow:0 20px 60px #0003}.form-input:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #e4405f1a}.notification{background:var(--gradient-surface);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.success{background:var(--gradient-success);color:#fff}.warning{background:var(--gradient-warning);color:#fff}.danger{background:var(--gradient-danger);color:#fff}.shadow-elevated{box-shadow:0 8px 32px #0000001f}*{transition:all .3s cubic-bezier(.25,.46,.45,.94)}}.greeting-card{background:var(--color-surface);border-radius:16px;border:none;padding:24px;margin-bottom:0;font-size:1.25rem;font-weight:600;color:var(--color-text);text-align:left;transition:all .2s ease;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.greeting-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.greeting-content{display:flex;align-items:center;gap:16px}.greeting-text{display:flex;flex-direction:column;gap:4px;flex:1}.greeting-text span{display:block}.greeting-text span:first-child{font-size:1.25rem;font-weight:600;color:var(--color-text)}.greeting-text span:last-child{font-size:1rem;font-weight:400;color:var(--color-text-secondary)}@media (max-width: 768px){.greeting-content{gap:12px}.greeting-text span:first-child{font-size:1.1rem}.greeting-text span:last-child{font-size:.9rem}}@media (max-width: 480px){.greeting-content{gap:8px}.greeting-text span:first-child{font-size:1rem}.greeting-text span:last-child{font-size:.85rem}}.achievements-section{margin-bottom:32px}.achievements-header{text-align:center;margin-bottom:32px}.achievements-section h2{font-size:1.8rem;font-weight:700;color:var(--color-text);margin-bottom:16px}.achievements-summary{display:flex;flex-direction:column;align-items:center;gap:8px}.achievements-progress{font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.achievements-progress-bar{width:200px;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.achievements-progress-fill{height:100%;background:var(--color-success);border-radius:3px;transition:width .5s ease}.achievements-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:24px}.achievement-card{background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border);padding:16px;display:flex;align-items:center;gap:12px;transition:var(--transition);position:relative;overflow:hidden}.achievement-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--color-primary);transform:scaleX(0);transition:transform .2s ease}.achievement-card.unlocked{border-color:var(--color-primary);background:#7dcfff14}.achievement-card.unlocked:before{transform:scaleX(1)}.achievement-card.locked{opacity:.6}.achievement-card:hover,.achievement-card:focus-within{border-color:var(--color-primary);transform:translateY(-1px)}.achievement-card.unlocked:hover{border-color:var(--color-primary);transform:translateY(-1px)}.achievement-icon{flex-shrink:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:var(--transition)}.achievement-card.unlocked .achievement-icon{background:var(--color-primary);color:#fff}.achievement-card.locked .achievement-icon{background:var(--color-border);color:var(--color-text-secondary)}.achievement-card:hover .achievement-icon{transform:scale(1.05)}.achievement-info{flex:1;min-width:0}.achievement-info h3{font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:4px;line-height:1.3}.achievement-info p{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:8px;line-height:1.3}.achievement-progress-info{display:flex;align-items:center;gap:6px}.achievement-unlocked{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;font-weight:500;color:var(--color-primary);background:#7aa2f71a;padding:4px 8px;border-radius:var(--border-radius-small);border:1px solid rgba(122,162,247,.2)}.achievement-progress-text{font-size:.8rem;color:var(--color-text-secondary);font-weight:500}.achievement-date{display:inline-block;font-size:.8rem;font-weight:500;color:var(--color-success);background:#22c55e1a;padding:4px 8px;border-radius:var(--border-radius-small);border:1px solid rgba(34,197,94,.2)}.achievement-progress{position:absolute;top:0;left:0;right:0;height:4px;background:var(--color-border);overflow:hidden}.achievement-progress-bar{height:100%;background:var(--color-primary);transition:width .3s ease}@media (max-width: 768px){.achievements-container{grid-template-columns:1fr;gap:12px}.achievement-card{padding:16px;gap:12px}.achievement-icon{width:40px;height:40px;font-size:1.2rem}.achievement-info h3{font-size:1rem}.achievement-info p{font-size:.85rem}.achievements-progress-bar{width:150px}}@media (max-width: 480px){.achievements-section h2{font-size:1.5rem;margin-bottom:20px}.achievement-card{padding:14px;gap:10px}.achievement-icon{width:36px;height:36px;font-size:1.1rem}.achievements-progress-bar{width:120px}}.stat-card,.main-content .stat-card{background:var(--color-surface);border-radius:16px;border:none;padding:20px;text-align:center;transition:all .2s ease;position:relative;overflow:hidden;margin-bottom:0;box-shadow:0 1px 3px #0000001a}.stat-card:hover,.stat-card:focus-within{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.stat-card .icon,.stat-card .stat-icon{font-size:1.5rem;color:var(--color-primary);margin-bottom:8px}.stat-card .stat-label,.stat-card .card-title{font-size:.8rem;color:var(--color-text-secondary);font-weight:500;margin-bottom:4px}.stat-card .stat-number{font-size:1.5rem;font-weight:600;color:var(--color-text);line-height:1}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border:none;border-radius:var(--border-radius-small);font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:var(--transition);background:var(--color-primary);color:#fff;min-height:44px}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary);filter:brightness(1.2);transform:translateY(-1px)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover{background:var(--color-success);filter:brightness(1.2);transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-primary);transform:translateY(-1px)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:var(--color-danger);filter:brightness(1.2);transform:translateY(-1px)}.btn-outline{background:var(--color-surface)!important;color:var(--color-text)!important;border:2px solid var(--color-border)!important;box-shadow:0 1px 3px #0000001a!important}.btn-outline:hover{background:var(--color-primary)!important;color:#fff!important;border-color:var(--color-primary)!important;box-shadow:0 2px 8px #00000026!important}.btn-large{padding:16px 32px;font-size:1.1rem}.features-section{margin-bottom:48px}.section-header{text-align:center;margin-bottom:40px}.section-title{font-size:2.5rem;font-weight:700;color:var(--color-text);margin-bottom:16px;line-height:1.2}.section-subtitle{font-size:1.1rem;color:var(--color-text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px;margin-bottom:48px}.feature-card{background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border);padding:32px;text-align:center;transition:var(--transition);position:relative;overflow:hidden}.feature-card:hover{transform:translateY(-4px)}.feature-icon{font-size:3rem;margin-bottom:16px}.feature-card h3{font-size:1.5rem;font-weight:600;margin-bottom:12px;color:var(--color-text)}.feature-card p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:16px}.feature-highlight{display:inline-block;background:var(--color-primary);color:#fff;padding:4px 12px;border-radius:var(--border-radius);font-size:.8rem;font-weight:500}.friend-card-row{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-surface);border-radius:var(--border-radius-small);border:1px solid var(--color-border);margin-bottom:8px}.friend-avatar{width:40px;height:40px;border-radius:var(--border-radius-circle);background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem}.friend-info{flex:1}.friend-name{font-weight:600;color:var(--color-text);margin-bottom:4px}.friend-email{font-size:.9rem;color:var(--color-text-secondary)}.account-page{width:100%;padding:0}.account-info-group{display:flex;flex-direction:column;gap:20px}.account-info-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:20px;transition:var(--transition)}.account-info-item:hover{border-color:var(--color-primary)}.account-info-label{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.account-icon{color:var(--color-primary);font-size:.8rem}.account-info-value{font-size:1.1rem;font-weight:500;color:var(--color-text)}.account-display-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.account-edit-row{display:flex;flex-direction:column;gap:12px}.account-edit-input{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:1rem;background:var(--color-surface);color:var(--color-text);transition:var(--transition)}.account-edit-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}.account-edit-actions{display:flex;gap:8px}.account-edit-btn{padding:8px 16px;font-size:.9rem;display:flex;align-items:center;gap:4px}.account-status{margin-top:16px;padding:12px 16px;border-radius:var(--border-radius-small);font-size:.9rem;font-weight:500}.account-status.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.2);color:var(--color-success)}.account-status.error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:var(--color-danger)}.account-actions{display:flex;flex-direction:column;gap:12px}.account-signout{padding:12px 20px;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:8px}.account-danger-zone{background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:var(--border-radius);padding:20px}.danger-zone-content h4{color:var(--color-danger);font-size:1.1rem;font-weight:600;margin-bottom:8px}.danger-zone-content p{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:16px;line-height:1.5}.danger-zone-content .btn{padding:12px 20px;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:8px}.auth-page-container{max-width:400px;margin:0 auto;padding:24px;background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border)}.auth-page-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:32px;color:var(--color-text)}.auth-page-toggle-row{display:flex;margin-bottom:24px}.auth-page-toggle-btn{flex:1;padding:12px;background:transparent;border:1px solid var(--color-border);cursor:pointer;transition:var(--transition)}.auth-page-toggle-btn:first-child{border-radius:var(--border-radius-small) 0 0 var(--border-radius-small)}.auth-page-toggle-btn:last-child{border-radius:0 var(--border-radius-small) var(--border-radius-small) 0}.auth-page-toggle-btn:focus{outline:none;border-color:var(--color-primary)}.auth-page-toggle-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.friend-search-form{margin-bottom:24px}.friend-search-row{display:flex;gap:8px}.friend-search-input{flex:1;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:1rem}.friend-search-input:focus{outline:none;border-color:var(--color-primary)}.friend-search-btn{padding:12px 24px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius-small);cursor:pointer}.friend-search-status.success{color:var(--color-success);margin-bottom:16px}.friend-search-status.error{color:var(--color-danger);margin-bottom:16px}.friend-search-status{margin-bottom:16px}.friend-search-results-title{font-size:1.2rem;font-weight:600;margin-bottom:16px}.friend-add-btn{padding:8px 16px;background:var(--color-success);color:#fff;border:none;border-radius:var(--border-radius-small);cursor:pointer}.empty-state{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:32px 24px;text-align:center;margin-bottom:24px}.empty-state-emoji{font-size:4rem;text-align:center;margin-bottom:16px}.empty-state-help{text-align:center;color:var(--color-text-secondary);font-size:1.1rem;line-height:1.6}.habits-list.empty-state{margin-top:16px}.empty-state-content{display:flex;flex-direction:column;align-items:center;gap:16px}.empty-state-content p{margin:0;font-size:1rem;color:var(--color-text-secondary)}.insights-minimal{display:flex;flex-direction:column;gap:12px}.insight-card{align-items:flex-start;gap:12px;padding:16px;border-radius:var(--border-radius-small);background:var(--color-surface);border:1px solid var(--color-border);transition:var(--transition)}.insight-card:hover{border-color:var(--color-primary)}.insight-card.warning{border-left:4px solid var(--color-warning)}.insight-card.info{border-left:4px solid var(--color-primary)}.insight-icon{font-size:1.5rem;flex-shrink:0}.insight-content h4{font-size:1rem;font-weight:600;margin-bottom:4px;color:var(--color-text)}.insight-content p{font-size:.9rem;color:var(--color-text-secondary);line-height:1.4;margin:0}.insights{margin-bottom:24px}.insights h2{font-size:1.5rem;font-weight:600;margin-bottom:16px;color:var(--color-text)}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.challenge-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.challenge-card-progress{margin-bottom:16px}.landing-app-preview-screen{background:var(--color-surface);border-radius:var(--border-radius-large);padding:24px}.landing-cta-title{font-size:2rem;font-weight:700;margin-bottom:16px}.hero-badge{display:inline-block;background:#7aa2f71a;color:var(--color-primary);padding:8px 16px;border-radius:var(--border-radius-xl);font-size:.9rem;font-weight:600;margin-bottom:16px}.hero-title{font-size:3.5rem;font-weight:700;margin-bottom:24px;line-height:1.2}.hero-subtitle{font-size:1.3rem;margin-bottom:40px;opacity:.9;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}@media (max-width: 600px){.greeting-card{padding:20px;font-size:1.1rem;border-radius:12px}.stat-card,.main-content .stat-card{padding:16px}.stat-card .stat-number,.stat-card .icon,.stat-card .stat-icon{font-size:1.3rem}.feature-card{padding:24px}.features-grid{grid-template-columns:1fr;gap:24px}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{flex-direction:column;gap:16px}.btn-large{padding:14px 28px;font-size:1rem}.stats-grid{grid-template-columns:1fr}.cta-buttons{flex-direction:column;gap:16px}.footer-content{grid-template-columns:1fr;gap:24px}.insights-grid{grid-template-columns:1fr}.notifications-container{inset:auto 8px 8px;max-width:95vw;width:auto;pointer-events:none;z-index:2000}.notification{padding:8px 10px;font-size:.85rem;min-width:0;max-width:100vw;border-radius:10px;box-shadow:0 2px 8px #0000001a;background:#24283bf2;pointer-events:auto}.notification-icon{font-size:1rem}}@media (max-width: 480px){.greeting-card{padding:12px;font-size:1.2rem;margin-bottom:16px}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-buttons{flex-direction:column;gap:12px}.btn-large{padding:12px 24px;font-size:.9rem}.cta-buttons{flex-direction:column;gap:12px}.footer-content{grid-template-columns:1fr;gap:20px}}.notifications-container{position:fixed;top:16px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:8px;max-width:320px;pointer-events:none}.notification{background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border);padding:12px 16px;box-shadow:0 4px 12px #00000026;font-size:.9rem;font-weight:500;line-height:1.4;color:var(--color-text);transition:all .3s ease;transform:translate(100%);opacity:0;pointer-events:auto;position:relative;overflow:hidden}.notification.show{transform:translate(0);opacity:1}.notification.hide{transform:translate(100%);opacity:0}.notification:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-primary);transform:scaleX(0);transition:transform .3s ease}.notification.show:before{transform:scaleX(1)}.notification.success{border-color:var(--color-success);background:color-mix(in srgb,var(--color-success) 8%,transparent)}.notification.success:before{background:var(--color-success)}.notification.error{border-color:var(--color-danger);background:color-mix(in srgb,var(--color-danger) 8%,transparent)}.notification.error:before{background:var(--color-danger)}.notification.warning{border-color:var(--color-warning);background:color-mix(in srgb,var(--color-warning) 8%,transparent)}.notification.warning:before{background:var(--color-warning)}.notification.info{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.notification.info:before{background:var(--color-primary)}.notification-content{display:flex;align-items:flex-start;gap:8px}.notification-icon{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:.8rem;margin-top:1px}.notification.success .notification-icon{color:var(--color-success)}.notification.error .notification-icon{color:var(--color-danger)}.notification.warning .notification-icon{color:var(--color-warning)}.notification.info .notification-icon{color:var(--color-primary)}.notification-message{flex:1;min-width:0}.notification-close{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;border-radius:50%;transition:var(--transition);font-size:.8rem;margin-top:1px}.notification-close:hover{background:#0000001a;color:var(--color-text)}.notification-progress{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--color-border);overflow:hidden}.notification-progress-bar{height:100%;background:var(--color-primary);transition:width linear}.notification.success .notification-progress-bar{background:var(--color-success)}.notification.error .notification-progress-bar{background:var(--color-danger)}.notification.warning .notification-progress-bar{background:var(--color-warning)}.notification.info .notification-progress-bar{background:var(--color-primary)}@keyframes notification-progress{0%{width:100%}to{width:0%}}@media (max-width: 900px){.notifications-container{top:8px;right:8px;left:auto;max-width:280px;width:auto;pointer-events:none;z-index:2000}.notification{padding:8px 12px;font-size:.8rem;min-width:0;max-width:280px;border-radius:8px;box-shadow:0 2px 8px #00000026;background:var(--color-surface);pointer-events:auto}.notification-icon{font-size:.9rem}}@media (max-width: 480px){.notifications-container{top:4px;right:4px;left:auto;max-width:240px}.notification{padding:6px 10px;font-size:.75rem;max-width:240px}}.settings-page{width:100%;padding:0}.setting-group{padding:24px;border-bottom:1px solid var(--color-border)}.setting-group:last-child{border-bottom:none}.setting-group h3{font-size:1.2rem;font-weight:600;color:var(--color-text);margin-bottom:16px;display:flex;align-items:center;gap:8px}.setting-group h3:before{content:"";width:4px;height:20px;background:var(--color-primary);border-radius:2px}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.05)}.setting-item:last-child{border-bottom:none}.setting-item label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:500;color:var(--color-text);flex:1}.setting-item input[type=checkbox]{appearance:none;width:44px;height:24px;background:var(--color-border);border-radius:12px;position:relative;cursor:pointer;transition:var(--transition);flex-shrink:0}.setting-item input[type=checkbox]:checked{background:var(--color-primary)}.setting-item input[type=checkbox]:before{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:var(--transition);box-shadow:0 2px 4px #0003}.setting-item input[type=checkbox]:checked:before{transform:translate(20px)}.setting-item input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px #7aa2f74d}.setting-description{font-size:.85rem;color:var(--color-text-secondary);margin-top:4px;line-height:1.4}.setting-actions{display:flex;flex-direction:column;gap:12px}.setting-actions .btn{width:100%;justify-content:center}.setting-actions .btn-group{display:flex;gap:8px}.setting-actions .btn-group .btn{flex:1}.setting-danger-zone{background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:var(--border-radius);padding:16px;margin-top:16px}.setting-danger-zone h4{color:var(--color-danger);font-size:1rem;font-weight:600;margin-bottom:8px}.setting-danger-zone p{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:12px;line-height:1.4}.setting-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--color-primary);font-size:.9rem}.setting-item:hover{background:#00000005;margin:0 -24px;padding:12px 24px;border-radius:0}.setting-item:hover .setting-icon{transform:scale(1.1)}@media (max-width: 768px){.settings-page section{padding:20px;margin-bottom:16px}.setting-group{padding:0}.setting-item{padding:10px 0}.setting-item:hover{margin:0 -20px;padding:10px 20px}.setting-actions .btn-group{flex-direction:column}}@media (max-width: 480px){.settings-page section{padding:16px;margin-bottom:12px}.setting-group{padding:0}.setting-item{padding:8px 0}.setting-item:hover{margin:0 -16px;padding:8px 16px}}.daily-recap-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#1e222c59;z-index:1000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.daily-recap-modal{background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border);max-width:400px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003;animation:recapSlideIn .3s ease-out}@keyframes recapSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.daily-recap-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,var(--color-primary) 0%,rgba(122,162,247,.8) 100%);color:#fff;border-radius:var(--border-radius) var(--border-radius) 0 0}.daily-recap-header h2{font-size:1.2rem;font-weight:600;margin:0}.daily-recap-close{background:none;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:50%;transition:var(--transition);display:flex;align-items:center;justify-content:center;font-size:.9rem}.daily-recap-close:hover{background:#fff3}.daily-recap-content{padding:20px}.recap-section{margin-bottom:20px}.recap-section:last-child{margin-bottom:0}.recap-section h3{font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:10px;display:flex;align-items:center;gap:6px}.recap-icon{color:var(--color-primary);font-size:.8rem}.recap-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.recap-stats-compact{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.recap-stat{background:#7aa2f70d;border:1px solid rgba(122,162,247,.1);border-radius:var(--border-radius-small);padding:12px;text-align:center}.recap-stat-compact{background:#7aa2f70d;border:1px solid rgba(122,162,247,.1);border-radius:var(--border-radius-small);padding:8px;text-align:center}.recap-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary);line-height:1;margin-bottom:4px}.recap-stat-compact .recap-stat-value{font-size:1.2rem;margin-bottom:2px}.recap-stat-label{font-size:.8rem;color:var(--color-text-secondary);font-weight:500}.recap-stat-compact .recap-stat-label{font-size:.7rem}.motivational-message{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border:1px solid rgba(34,197,94,.2);border-radius:var(--border-radius);padding:16px;display:flex;align-items:flex-start;gap:12px}.motivational-message-compact{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border:1px solid rgba(34,197,94,.2);border-radius:var(--border-radius);padding:12px;display:flex;align-items:center;gap:8px}.motivational-message .recap-icon{color:var(--color-success);margin-top:2px}.motivational-message-compact .recap-icon{color:var(--color-success)}.motivational-message p{margin:0;font-size:1rem;color:var(--color-text);line-height:1.4;font-weight:500}.motivational-message-compact p{margin:0;font-size:.9rem;color:var(--color-text);line-height:1.3;font-weight:500}.todays-goals p{margin-bottom:12px;color:var(--color-text);font-size:.9rem}.todays-goals-compact p{margin:0;color:var(--color-text);font-size:.9rem}.goals-list{display:flex;flex-direction:column;gap:8px}.goal-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-small);transition:var(--transition)}.goal-item:hover{border-color:var(--color-primary);background:#7aa2f705}.goal-name{font-size:.9rem;color:var(--color-text);font-weight:500}.goal-streak{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--color-primary);font-weight:500}.goal-streak svg{font-size:.7rem}.recap-cta{text-align:center;padding:16px;background:#7aa2f70d;border-radius:var(--border-radius);border:1px solid rgba(122,162,247,.1)}.recap-cta p{margin:0 0 12px;font-size:1rem;color:var(--color-text);font-weight:500}.recap-cta .btn{min-width:120px}@media (max-width: 768px){.daily-recap-overlay{padding:12px}.daily-recap-modal{max-height:95vh;max-width:350px}.daily-recap-header{padding:14px 16px}.daily-recap-header h2{font-size:1.1rem}.daily-recap-content{padding:16px}.recap-stats{grid-template-columns:1fr;gap:8px}.recap-stats-compact{grid-template-columns:repeat(3,1fr);gap:6px}.recap-stat{padding:10px}.recap-stat-compact{padding:6px}.recap-stat-value{font-size:1.3rem}.recap-stat-compact .recap-stat-value{font-size:1.1rem}}@media (max-width: 480px){.daily-recap-overlay{padding:8px}.daily-recap-modal{max-width:320px}.daily-recap-header{padding:12px 14px}.daily-recap-content{padding:14px}.recap-section{margin-bottom:16px}.motivational-message{padding:12px}.motivational-message-compact{padding:10px}.motivational-message p{font-size:.9rem}.motivational-message-compact p{font-size:.85rem}}.habit-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#1e222c59;z-index:2001;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.habit-modal{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 20px 40px #0003;max-width:400px;width:100%;max-height:90vh;overflow-y:auto;z-index:2002;animation:recapSlideIn .3s ease-out;border-radius:var(--border-radius);scrollbar-width:none;-ms-overflow-style:none}.habit-modal::-webkit-scrollbar{display:none}.habit-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,var(--color-primary) 0%,rgba(122,162,247,.8) 100%);color:#fff;border-radius:var(--border-radius) var(--border-radius) 0 0}.habit-modal-header h2{font-size:1.2rem;font-weight:600;color:#fff;margin:0}.habit-modal-close{background:none;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:50%;transition:var(--transition);display:flex;align-items:center;justify-content:center;font-size:.9rem}.habit-modal-close:hover{background:#fff3}.habit-modal-content,.modal-habits-list{max-width:100%;box-sizing:border-box;padding:20px;scrollbar-width:none;-ms-overflow-style:none}.modal-habits-list::-webkit-scrollbar{display:none}.habit-modal-tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:20px}.habit-tab{flex:1;padding:12px 16px;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:.95rem;font-weight:500;transition:var(--transition);border-bottom:2px solid transparent}.habit-tab:hover{color:var(--color-text);background:#7aa2f70d}.habit-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:#7aa2f71a}.habit-section{margin-bottom:20px}.habit-section:last-child{margin-bottom:0}.habit-section h3{display:flex;align-items:center;gap:6px;font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:10px}.habit-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.habit-stat{text-align:center;padding:16px 12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-small);transition:var(--transition)}.habit-stat:hover{border-color:var(--color-primary);background:#7aa2f70d}.habit-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary);margin-bottom:4px}.habit-stat-label{font-size:.8rem;color:var(--color-text-secondary);font-weight:500}.habit-creation-info{padding:12px 16px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:.95rem;color:var(--color-text);font-weight:500}.habit-section-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:8px 0;border-radius:var(--border-radius-small);transition:var(--transition);margin-bottom:10px}.habit-section-header:hover{background:#7aa2f70d;padding:8px 12px;margin:0 -12px 10px}.habit-section-header.clickable h3{margin-bottom:0;cursor:pointer}.habit-section-toggle{color:var(--color-primary);font-size:.8rem;transition:var(--transition);display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#7aa2f71a}.habit-section-header:hover .habit-section-toggle{background:#7aa2f733;transform:scale(1.1)}.habit-icon{color:var(--color-primary);font-size:.8rem}.habit-name-edit{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:.95rem;background:var(--color-surface);color:var(--color-text);transition:var(--transition)}.habit-name-edit:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}.habit-frequency-edit{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:.95rem;background:var(--color-surface);color:var(--color-text);transition:var(--transition);cursor:pointer}.habit-frequency-edit:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a}.group-progress{margin-bottom:12px}.group-progress-text{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:6px;font-weight:500}.group-progress-bar{width:100%;height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.group-progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.members-list{display:flex;flex-direction:column;gap:6px}.member-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--border-radius-small);transition:var(--transition)}.member-item:hover{background:var(--color-border)}.member-item.current-user{background:#667eea0d;border:1px solid rgba(102,126,234,.1)}.member-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;flex-shrink:0}.member-item:not(.current-user) .member-avatar{background:var(--color-border);color:var(--color-text-secondary)}.member-info{flex:1;min-width:0}.member-name{font-weight:600;font-size:.9rem;color:var(--color-text);margin-bottom:2px}.member-you{color:var(--color-primary);margin-left:6px;font-weight:500}.member-streak{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--color-text-secondary);font-weight:500}.member-streak svg{color:#f59e0b}.member-status{width:24px;height:24px;border-radius:50%;background:var(--color-border);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--color-text-secondary);flex-shrink:0}.member-status.completed{background:var(--color-success);color:#fff}.progress-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:16px}.progress-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--border-radius-small);padding:8px 4px;transition:var(--transition);position:relative}.progress-day:hover{border-color:var(--color-primary);transform:translateY(-1px)}.progress-day.completed{background:var(--color-success);border-color:var(--color-success);color:#fff}.progress-day.today{border-color:var(--color-primary);border-width:3px}.progress-day.today.completed{border-color:var(--color-success)}.progress-day-date{font-size:.7rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.progress-day.completed .progress-day-date{color:#ffffffe6}.progress-day-status{font-size:.9rem;margin-bottom:4px;display:flex;align-items:center;justify-content:center}.progress-day-number{font-size:.8rem;font-weight:600;color:var(--color-text)}.progress-day.completed .progress-day-number{color:#fff}.progress-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.progress-stat{display:flex;align-items:center;gap:12px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-small);transition:var(--transition)}.progress-stat:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.progress-stat-icon{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.progress-stat-content{flex:1;min-width:0}.progress-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.2;margin-bottom:2px}.progress-stat-label{font-size:.8rem;color:var(--color-text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.progress-section{margin-bottom:24px}.progress-section-title{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.progress-section-icon{color:var(--color-primary);font-size:.9rem}.progress-insights{margin-top:24px}.insights-content{display:flex;flex-direction:column;gap:8px}.insight-item{display:flex;align-items:center;gap:10px;padding:12px;border-radius:var(--border-radius-small);font-size:.9rem;transition:var(--transition)}.insight-item.positive{background:#22c55e1a;border:1px solid rgba(34,197,94,.2);color:var(--color-success)}.insight-item.neutral{background:#9ca3af1a;border:1px solid rgba(156,163,175,.2);color:var(--color-text-secondary)}.insight-icon{font-size:1rem;flex-shrink:0}.insight-item span{font-weight:500}@media (max-width: 768px){.progress-stats{grid-template-columns:1fr;gap:8px}.progress-stat{padding:12px}.progress-stat-icon{width:32px;height:32px;font-size:.9rem}.progress-stat-value{font-size:1.3rem}.progress-grid{gap:4px}.progress-day{padding:6px 2px}.progress-day-date{font-size:.6rem}.progress-day-status{font-size:.8rem}.progress-day-number{font-size:.7rem}}@media (max-width: 480px){.progress-stats{grid-template-columns:1fr}.progress-stat{padding:10px}.progress-stat-icon{width:28px;height:28px;font-size:.8rem}.progress-stat-value{font-size:1.2rem}.progress-stat-label{font-size:.7rem}.progress-grid{gap:2px}.progress-day{padding:4px 1px}.progress-day-date{font-size:.5rem}.progress-day-status{font-size:.7rem}.progress-day-number{font-size:.6rem}.insight-item{padding:10px;font-size:.8rem}}.habit-actions{display:flex;gap:10px;margin-top:20px}.habit-actions .btn{flex:1;padding:10px 16px;font-size:.95rem;font-weight:600;border-radius:var(--border-radius-small);transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:6px}.habit-actions .btn-danger{flex:0 0 auto;padding:10px 14px}@media (max-width: 768px){.habit-modal{max-width:350px;max-height:95vh}.habit-modal-header{padding:16px 20px 12px}.habit-modal-header h2{font-size:1.3rem}.habit-modal-content{padding:20px}.habit-section{margin-bottom:20px}.habit-section-header:hover{padding:6px 10px;margin:0 -10px 10px}.habit-actions{flex-direction:column}.habit-actions .btn-danger{flex:1}}@media (max-width: 480px){.habit-modal-overlay{padding:12px}.habit-modal{max-height:95vh}.habit-modal-header{padding:12px 16px 8px}.habit-modal-content{padding:16px}.habit-section h3{font-size:1rem}.habit-section-header:hover{padding:4px 8px;margin:0 -8px 10px}.member-item{padding:8px}.member-avatar{width:32px;height:32px;font-size:.8rem}.progress-grid{gap:2px}.progress-day{font-size:.7rem}}@media (max-width: 768px){.account-info-item{padding:16px}.account-display-row{flex-direction:column;align-items:flex-start;gap:8px}.account-edit-actions{flex-direction:column}.account-actions{gap:8px}.account-signout,.danger-zone-content .btn{padding:10px 16px;font-size:.9rem}}@media (max-width: 480px){.account-info-item{padding:12px}.account-info-label{font-size:.8rem}.account-info-value{font-size:1rem}.account-edit-input{padding:10px 12px;font-size:.9rem}.account-edit-btn{padding:6px 12px;font-size:.8rem}.account-signout{padding:8px 12px;font-size:.8rem}.danger-zone-content h4{font-size:1rem}.danger-zone-content p{font-size:.8rem}.danger-zone-content .btn{padding:8px 12px;font-size:.8rem}}.friend-dropdown-content,.frequency-dropdown-content,.dropdown-content{scrollbar-width:thin;scrollbar-color:var(--color-primary) #f1f5f9}.friend-dropdown-content::-webkit-scrollbar,.frequency-dropdown-content::-webkit-scrollbar,.dropdown-content::-webkit-scrollbar{width:6px;background:#f1f5f9}.friend-dropdown-content::-webkit-scrollbar-thumb,.frequency-dropdown-content::-webkit-scrollbar-thumb,.dropdown-content::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:6px}.friend-dropdown-content::-webkit-scrollbar-track,.frequency-dropdown-content::-webkit-scrollbar-track,.dropdown-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:6px}.streak-leaderboard{margin-top:32px;background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border);box-shadow:0 4px 16px #1e222c0a;padding:24px}.leaderboard{display:flex;flex-direction:column;gap:14px;margin-top:12px}.leaderboard-item{display:flex;justify-content:space-between;align-items:center;background:#7aa2f70f;border-radius:var(--border-radius-small);padding:14px 18px;transition:background .2s,box-shadow .2s;box-shadow:0 1px 4px #1e222c08}.leaderboard-item:hover{background:#7aa2f721;box-shadow:0 2px 8px #1e222c0f}.leaderboard-name{font-weight:600;color:var(--color-text);font-size:1rem;display:flex;align-items:center;gap:6px}.leaderboard-streak{display:flex;align-items:center;font-weight:700;color:var(--color-primary);font-size:1.1rem;gap:4px}.leaderboard-item .leaderboard-streak svg{color:var(--color-accent);font-size:1.1em}.leaderboard-item .leaderboard-name svg{color:var(--color-primary)}.leaderboard-item .leaderboard-name .fa-users{color:var(--color-primary)}.leaderboard-item .leaderboard-name .fa-fire{color:var(--color-accent)}.leaderboard-item .leaderboard-name .fa-users{margin-left:4px}.leaderboard-item .leaderboard-name .fa-fire{margin-left:2px}.leaderboard-item .leaderboard-name .fa-users{font-size:.9em}.leaderboard-item .leaderboard-name .fa-fire{font-size:1em}.leaderboard-item .leaderboard-streak{font-size:1.1rem}.leaderboard-item .leaderboard-streak svg{margin-left:2px}.leaderboard-item .leaderboard-streak{color:var(--color-primary)}.leaderboard-item .leaderboard-streak svg{color:var(--color-accent)}.leaderboard-item .leaderboard-name,.leaderboard-item .leaderboard-streak{transition:color .2s}.leaderboard-item .leaderboard-name[style*="#667eea"],.leaderboard-item .leaderboard-streak[style*="#667eea"]{color:var(--color-primary)!important;font-weight:700}@media (max-width: 600px){.streak-leaderboard{padding:14px}.leaderboard-item{padding:10px 8px;font-size:.95rem}}.drag-instruction{background:var(--color-surface);border-radius:var(--border-radius-small);border:1px solid var(--color-border);padding:16px 20px;margin-bottom:20px;color:var(--color-text-secondary);font-size:1rem;box-shadow:none;transition:var(--transition)}.drag-instruction-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;color:var(--color-text);font-size:1.05rem;font-weight:600}.drag-instruction-icon{font-size:1.2rem;color:var(--color-primary);display:flex;align-items:center}.drag-instruction-list{margin:0;padding-left:22px;font-size:.97rem;color:var(--color-text-secondary);list-style:disc inside}.drag-instruction-list li{margin-bottom:4px}@media (max-width: 600px){.drag-instruction{padding:12px 10px;font-size:.97rem}.drag-instruction-header{font-size:1rem}.drag-instruction-list{font-size:.93rem}}.habit-card__name-interactive:hover{color:var(--color-primary, #3b82f6);transition:color .15s}.apple-modal-link{color:var(--color-text, #fff);cursor:pointer;transition:color .18s;outline:none;font-size:1rem;font-weight:600}.apple-modal-link:hover,.apple-modal-link:focus{color:var(--color-primary, #3b82f6);text-decoration:none}.apple-modal-link:active{color:var(--color-primary-active, #2563eb)}.community-feed{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:1.5rem}.feed-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.feed-icon{color:var(--primary-color);font-size:1.2rem}.feed-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary);flex:1}.friend-count{background:var(--primary-color);color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.feed-content{min-height:120px}.feed-content.loading{display:flex;align-items:center;justify-content:center}.loading-placeholder{color:var(--text-secondary);font-style:italic}.feed-content.empty{display:flex;align-items:center;justify-content:center;text-align:center}.empty-state{color:var(--text-secondary)}.empty-icon{font-size:2rem;margin-bottom:.5rem;opacity:.5}.empty-state p{margin:.5rem 0 .25rem;font-weight:500}.empty-state small{opacity:.7;font-size:.85rem}.activities-list{display:flex;flex-direction:column;gap:.75rem}.activity-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px;transition:background-color .2s ease}.activity-item:hover{background:var(--hover-bg)}.activity-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0}.activity-content{flex:1;min-width:0}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.friend-name{font-weight:600;color:var(--text-primary);font-size:.9rem}.activity-time{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary);font-size:.75rem}.time-icon{font-size:.7rem}.activity-description{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem}.activity-icon{font-size:.8rem}.activity-icon.completed{color:var(--success-color)}.activity-icon.streak{color:var(--warning-color)}.activity-icon.level-up{color:var(--primary-color)}.activity-icon.created{color:var(--info-color, #3b82f6)}.activity-icon.achievement{color:var(--warning-color, #f59e0b)}.routine-habit-actions{display:flex;gap:4px;align-items:center}.routine-habit-remove{background:none;border:none;color:var(--color-warning, #f59e0b);cursor:pointer;padding:8px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.routine-habit-remove:hover{background:var(--color-warning, #f59e0b);color:#fff}.routine-habit-remove:disabled{opacity:.5;cursor:not-allowed}.routine-habit-delete{background:none;border:none;color:var(--color-danger, #e74c3c);cursor:pointer;padding:8px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.routine-habit-delete:hover{background:var(--color-danger, #e74c3c);color:#fff}.routine-habit-delete:disabled{opacity:.5;cursor:not-allowed}.no-activities{text-align:center;color:var(--text-secondary);padding:2rem 0}.no-activities-icon{font-size:2rem;margin-bottom:.5rem;opacity:.5}.no-activities p{margin:.5rem 0 .25rem;font-weight:500}.no-activities small{opacity:.7;font-size:.85rem}@media (max-width: 768px){.community-feed{padding:1rem}.activity-item{padding:.5rem}.activity-header{flex-direction:column;align-items:flex-start;gap:.25rem}.activity-time{font-size:.7rem}}.community-activities{margin-top:24px}.section-title{font-size:1.1rem;font-weight:600;color:var(--color-text);margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.community-activities .activities-list{display:flex;flex-direction:column;gap:12px}.community-activities .activity-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:12px;display:flex;align-items:flex-start;gap:12px;transition:var(--transition)}.community-activities .activity-item:hover{border-color:var(--color-primary);transform:translateY(-1px)}.community-activities .activity-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;flex-shrink:0}.community-activities .activity-content{flex:1;min-width:0}.community-activities .activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.community-activities .friend-name{font-weight:600;color:var(--color-text);font-size:.9rem}.community-activities .activity-time{font-size:.75rem;color:var(--color-text-secondary);display:flex;align-items:center;gap:4px}.community-activities .time-icon{font-size:.7rem}.community-activities .activity-description{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--color-text-secondary)}.community-activities .activity-icon{font-size:.9rem;color:var(--color-primary)}.community-activities .activity-icon.completed{color:var(--color-success)}.community-activities .activity-icon.streak{color:var(--color-warning)}.community-activities .activity-icon.level-up{color:var(--color-accent)}.community-activities .activity-icon.created{color:var(--color-primary)}.community-activities .activity-icon.achievement{color:var(--color-warning)}@media (max-width: 768px){.community-activities{margin-top:16px}.community-activities .activity-item{padding:10px}.community-activities .activity-header{flex-direction:column;align-items:flex-start;gap:4px}.community-activities .activity-time{font-size:.7rem}}.main-content{flex:1;padding:20px 0;max-width:none;margin:0;width:100%;background:var(--color-background);color:var(--color-text);min-height:calc(100vh - 120px)}.dashboard-page{background:var(--color-background);min-height:100vh;padding:0;position:relative}.dashboard-container{max-width:none;width:100%;margin:0 auto;padding:20px;position:relative}.dashboard-header{margin-bottom:24px;position:relative}.dashboard-grid,.dashboard-main,.dashboard-sidebar{display:flex;flex-direction:column;gap:20px}.dashboard-section{background:var(--color-surface);border-radius:16px;border:none;padding:24px;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;position:relative;overflow:hidden}.dashboard-section:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.habits-page,.friends-page,.settings-page,.analytics-page,.quests-page,.challenges-page,.account-page,.blog-page,.profile-page{background:var(--color-background);min-height:100vh;padding:0;position:relative}.habits-container,.friends-container,.settings-container,.analytics-container,.quests-container,.challenges-container,.account-container,.blog-container,.profile-container{max-width:none;width:100%;margin:0 auto;padding:20px;position:relative}.habits-container,.friends-container,.settings-container,.analytics-container,.quests-container,.challenges-container,.account-container,.blog-container,.profile-container{display:grid;grid-template-columns:1fr;gap:20px;align-items:start}.habits-main,.friends-main,.settings-main,.analytics-main,.quests-main,.challenges-main,.account-main,.blog-main,.profile-main{display:flex;flex-direction:column;gap:20px;flex:2}.habits-sidebar,.friends-sidebar,.settings-sidebar,.analytics-sidebar,.quests-sidebar,.challenges-sidebar,.account-sidebar,.blog-sidebar{display:flex;flex-direction:column;gap:20px}section{background:var(--color-surface);border-radius:16px;border:none;padding:24px;margin-bottom:20px;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;color:var(--color-text);position:relative}section:hover,section:focus-within{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}section h2{font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:16px;display:flex;align-items:center;gap:8px}.stats-grid,.main-content .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-grid,.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:24px}.stat-grid:hover,.features-grid:hover{transform:none}.quick-stats{margin-bottom:24px}.dynamic-greeting{margin-bottom:24px;color:var(--color-text-secondary)}section,.greeting-card,.completion-history,.habits-list,.todays-habits,.add-habit-section,.all-habits-section{margin-bottom:24px}.todays-habits,.add-habit-section{margin-bottom:24px}.all-habits-section{margin-top:0}.habits-row{display:flex;flex-direction:row;gap:10px;overflow-x:auto;padding-bottom:6px;margin-bottom:8px;scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-surface)}.habits-row::-webkit-scrollbar{height:8px;background:var(--color-surface)}.habits-row::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--border-radius-small)}.habits-list{display:flex;flex-direction:column;gap:10px;width:100%;margin-bottom:24px}.completion-history{background:var(--color-surface);padding:24px;border-radius:var(--border-radius);border:1.5px solid var(--color-border);box-shadow:none;margin-bottom:24px}.completion-chart{display:flex;justify-content:space-between;align-items:flex-end;height:fit-content;margin-top:24px;padding:12px 0;gap:12px;max-height:300px;overflow:hidden}.chart-column{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;max-height:100%}.chart-bar{width:24px;border-radius:2px;transition:height .3s ease,background-color .3s ease}.completion-count,.day-label{font-size:.8rem;color:var(--color-text-secondary);font-weight:500}.day-label.today{color:var(--color-primary);font-weight:600}.progress-bar{width:100%;height:8px;background:var(--color-border);border-radius:2px;overflow:hidden}.w-100{width:100%}.mr-8{margin-right:8px}@media (max-width: 600px){.main-content{padding:16px 0 100px}.dashboard-container{padding:16px}.dashboard-section{padding:20px;border-radius:12px}section{padding:20px;margin-bottom:16px;border-radius:12px}.stats-grid,.main-content .stats-grid{grid-template-columns:1fr;gap:12px}.stat-grid,.features-grid{grid-template-columns:1fr;gap:16px}.completion-chart{height:100px;gap:8px}.chart-bar{width:20px}.completion-count,.day-label{font-size:.7rem}}@media (min-width: 768px){.dashboard-container,.habits-container,.friends-container,.settings-container,.analytics-container,.quests-container,.challenges-container,.account-container,.blog-container,.profile-container{padding:24px}.dashboard-grid,.habits-container,.friends-container,.settings-container,.analytics-container,.quests-container,.challenges-container,.account-container,.blog-container,.profile-container{gap:24px}.dashboard-section{padding:24px}}@media (min-width: 1024px){.dashboard-container,.habits-container,.friends-container,.settings-container,.analytics-container,.quests-container,.challenges-container,.account-container,.blog-container,.profile-container{padding:28px}.dashboard-grid,.habits-container,.friends-container,.settings-container,.analytics-container,.quests-container,.challenges-container,.account-container,.blog-container,.profile-container{gap:28px}.dashboard-section{padding:28px}}@media (min-width: 1400px){.dashboard-container,.habits-container,.friends-container,.settings-container,.analytics-container,.quests-container,.challenges-container,.account-container,.blog-container,.profile-container{padding:32px}}.profile-main{display:flex;flex-direction:column;gap:20px;flex:2}.profile-sidebar{display:flex;flex-direction:column;gap:20px}@media (min-width: 768px){.dashboard-main,.habits-main,.friends-main,.settings-main,.analytics-main,.quests-main,.challenges-main,.account-main,.blog-main,.profile-main,.dashboard-sidebar,.habits-sidebar,.friends-sidebar,.settings-sidebar,.analytics-sidebar,.quests-sidebar,.challenges-sidebar,.account-sidebar,.blog-sidebar,.profile-sidebar{gap:24px}}@media (min-width: 1024px){.dashboard-main,.habits-main,.friends-main,.settings-main,.analytics-main,.quests-main,.challenges-main,.account-main,.blog-main,.profile-main,.dashboard-sidebar,.habits-sidebar,.friends-sidebar,.settings-sidebar,.analytics-sidebar,.quests-sidebar,.challenges-sidebar,.account-sidebar,.blog-sidebar,.profile-sidebar{gap:28px}}@media (min-width: 1400px){.dashboard-main,.habits-main,.friends-main,.settings-main,.analytics-main,.quests-main,.challenges-main,.account-main,.blog-main,.profile-main,.dashboard-sidebar,.habits-sidebar,.friends-sidebar,.settings-sidebar,.analytics-sidebar,.quests-sidebar,.challenges-sidebar,.account-sidebar,.blog-sidebar,.profile-sidebar{gap:32px}}@media (max-width: 600px){html,body{font-size:14px}#root{min-height:100vh;display:flex;flex-direction:column}body{-webkit-overflow-scrolling:touch}.habits-page section,.friends-page section,.settings-page section,.analytics-page section,.quests-page section,.challenges-page section,.account-page section,.blog-page section,.profile-page section{padding:16px;margin-bottom:16px;border-radius:var(--border-radius-small)}.navigation,.nav-container{padding:0}.nav-container{gap:4px}.nav-item{flex:1 1 0;min-width:0}.nav-item .nav-label{font-size:.65rem}.nav-item .nav-icon{margin-bottom:2px}.nav-icon svg{width:18px;height:18px}::-webkit-scrollbar{width:4px}.habit-card,.stat-card,.feature-card{padding:16px;margin-bottom:12px}.stat-card{padding:12px}.stat-card .stat-number{font-size:1rem}.habit-card{padding:12px}.habit-card__details{gap:3px}.habit-card__name{font-size:.95rem;line-height:1.2}.habit-card__desc,.habit-card__group-info{font-size:.8rem;line-height:1.2}.habit-card__streak{gap:4px;padding:3px 6px}.habit-card__icon{font-size:1.3rem;margin-right:8px}.habit-card__icon svg{width:20px;height:20px}.habit-card__group-progress-number{font-size:.75rem;padding:1px 4px}.stats-grid{grid-template-columns:1fr;gap:12px}.stat-grid,.features-grid{grid-template-columns:1fr;gap:16px}.features-grid{gap:24px}.btn-large{padding:14px 28px;font-size:1rem}.cta-buttons{flex-direction:column;gap:16px}.footer-content{grid-template-columns:1fr;gap:24px}.completion-chart{height:100px;gap:8px}.chart-bar{width:20px}.completion-count,.day-label{font-size:.7rem}}@media (max-width: 480px){.nav-item .nav-label{font-size:.6rem}.habit-card__desc,.habit-card__group-info{font-size:.75rem;line-height:1.2}.btn-large{padding:12px 24px;font-size:.9rem}.cta-buttons{gap:12px}.footer-content{gap:20px}}@media (max-width: 400px){.habit-card__desc,.habit-card__group-info{font-size:.7rem;line-height:1.2}}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{flex-direction:column;gap:16px}.hero-stats{gap:40px}.hero-section .container{padding:0 16px}.phone-mockup{transform:none}.phone-mockup:hover{transform:scale(1.02)}.section-title{font-size:2rem;text-align:center}.section-subtitle{font-size:1rem}.features-grid,.stats-section .stats-grid{grid-template-columns:1fr;gap:30px}.stats-section .stat-card{padding:30px}.stats-section .stat-card .stat-number{font-size:2.5rem}.stat-number,.cta-section h2{font-size:2rem}.footer-content{grid-template-columns:1fr;gap:30px}}.mobile-only{display:none}@media (max-width: 600px){.mobile-only{display:block}}body{-webkit-tap-highlight-color:transparent}.stat-card{min-height:80px}body{background:var(--color-background);color:var(--color-text)}.stat-card{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.theme-toggle-simple{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-small);padding:8px 12px;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;font-size:1rem;min-width:40px;height:40px}.theme-toggle-simple:hover{background:var(--color-surface-hover);border-color:var(--color-border-focus);color:var(--color-text);transform:translateY(-1px)}.theme-toggle-simple:active{transform:translateY(0)}.theme-toggle-dropdown{position:relative;display:inline-block}.theme-toggle-button{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-small);padding:8px 12px;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;font-size:1rem;min-width:40px;height:40px}.theme-toggle-button:hover{background:var(--color-surface-hover);border-color:var(--color-border-focus);color:var(--color-text);transform:translateY(-1px)}.theme-toggle-button:active{transform:translateY(0)}.theme-options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:20px}.theme-toggle-menu::-webkit-scrollbar{width:6px}.theme-toggle-menu::-webkit-scrollbar-track{background:var(--color-surface)}.theme-toggle-menu::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.theme-toggle-menu::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.theme-option{display:flex;align-items:center;gap:12px;width:100%;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-small);color:var(--color-text);cursor:pointer;transition:var(--transition);text-align:left;font-size:.9rem}.theme-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.theme-description{font-size:.75rem;color:var(--color-text-muted);opacity:.8;line-height:1.2}.theme-option:hover{background:var(--color-surface-hover);border-color:var(--color-primary);transform:translateY(-1px)}.theme-option.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.theme-option.active .theme-icon{opacity:1}.theme-icon{font-size:1rem;opacity:.8;transition:var(--transition)}.theme-label{font-weight:500}@keyframes themeModalSlideIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@media (max-width: 600px){.theme-options-grid{grid-template-columns:1fr;gap:8px}.theme-option{padding:12px;font-size:.85rem}.theme-icon{font-size:.9rem}.theme-description{font-size:.7rem}}.theme-toggle-simple:focus,.theme-toggle-button:focus,.theme-option:focus{outline:2px solid var(--color-border-focus);outline-offset:2px}@media (prefers-contrast: high){.theme-toggle-simple,.theme-toggle-button,.theme-option{border-width:2px}}.habit-form{margin-bottom:24px}.form-group{margin-bottom:16px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:1rem;font-family:var(--font-family);background:var(--color-surface);transition:var(--transition);box-sizing:border-box;color:var(--color-text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);color:var(--color-text);background:var(--color-surface)}.auth-form-container{max-width:400px;margin:0 auto;padding:32px;background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border)}.auth-form-input{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:1rem;margin-bottom:16px;transition:var(--transition);box-sizing:border-box}.auth-form-input:focus{outline:none;border-color:var(--color-primary)}.auth-form-password{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:1rem;margin-bottom:16px;transition:var(--transition);box-sizing:border-box}.auth-form-password:focus{outline:none;border-color:var(--color-primary)}.auth-form-button{width:100%;padding:12px;margin-bottom:16px}.auth-form-error{color:var(--color-danger);font-size:.9rem;margin-bottom:16px;text-align:center}.auth-form-divider{position:relative;text-align:center;margin:20px 0}.auth-form-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--color-border)}.auth-form-divider span{background:var(--color-surface);padding:0 16px;color:var(--color-text-secondary);font-size:.9rem;position:relative;z-index:1}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);animation:spin 1s ease-in-out infinite}.auth-page-container{max-width:400px;margin:0 auto;padding:32px;background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border)}.auth-page-title{font-size:1.8rem;font-weight:600;margin-bottom:24px;text-align:center}.auth-page-toggle-row{display:flex;margin-bottom:24px;justify-content:center;align-items:center;gap:8px;font-size:.9rem;color:var(--color-text-secondary)}.auth-page-toggle-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:.9rem;font-weight:500;padding:0;text-decoration:underline;transition:var(--transition)}.auth-page-toggle-btn:hover{color:var(--color-primary)}.auth-page-toggle-btn:focus{outline:none;color:var(--color-primary)}.auth-page-toggle-btn:disabled{opacity:.5;cursor:not-allowed;text-decoration:none}.mb-18{margin-bottom:18px}.mt-10{margin-top:10px}input,select,textarea{font-family:var(--font-family);font-size:1rem;line-height:1.5;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-small);padding:12px 16px;transition:var(--transition);box-sizing:border-box}button,input[type=button],input[type=submit],input[type=reset]{font-family:var(--font-family);font-size:1rem;line-height:1.5;cursor:pointer}input,select,textarea{width:100%;box-sizing:border-box}.form-group.error input,.form-group.error select,.form-group.error textarea{border-color:var(--color-danger)}.form-group.success input,.form-group.success select,.form-group.success textarea{border-color:var(--color-success)}.form-group .error-message{color:var(--color-danger);font-size:.85rem;margin-top:4px}.form-group .success-message{color:var(--color-success);font-size:.85rem;margin-top:4px}.form-group label{display:block;font-weight:500;color:var(--color-text);margin-bottom:6px;font-size:.9rem}.form-group .help-text{color:var(--color-text-secondary);font-size:.85rem;margin-top:4px;line-height:1.4}.form-actions{display:flex;gap:12px;margin-top:24px;align-items:center}.form-actions .btn{flex:1}.form-actions .btn-secondary{flex:0 0 auto}.form-row{display:flex;gap:16px;margin-bottom:16px}.form-row .form-group{flex:1;margin-bottom:0}.form-row .form-group:last-child{margin-bottom:0}.form-section{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--color-border)}.form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section-title{font-size:1.1rem;font-weight:600;color:var(--color-text);margin-bottom:16px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.form-grid .form-group{margin-bottom:0}.form-group.required label:after{content:" *";color:var(--color-danger)}.form-group .validation-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:1rem}.form-group.error .validation-icon{color:var(--color-danger)}.form-group.success .validation-icon{color:var(--color-success)}.form-group.loading input,.form-group.loading select,.form-group.loading textarea{background-image:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHZpZXdCb3g9IjAgMCAyMCAyMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEwIDNDMTMuODY2IDMgMTcgNi4xMzQwMSAxNyAxMEMxNyAxMy44NjYgMTMuODY2IDE3IDEwIDE3QzYuMTM0MDEgMTcgMyAxMy44NjYgMyAxMEMzIDYuMTM0MDEgNi4xMzQwMSAzIDEwIDNaIiBzdHJva2U9IiM5Q0E5Q0EiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIi8+Cjwvc3ZnPgo=);background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px}.form-group.disabled input,.form-group.disabled select,.form-group.disabled textarea{background-color:var(--color-background);color:var(--color-text-secondary);cursor:not-allowed}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-secondary);opacity:.7}.form-group input:focus::placeholder,.form-group textarea:focus::placeholder{opacity:.5}@media (max-width: 600px){.form-group input,.form-group select,.form-group textarea{padding:10px 14px;font-size:.95rem}.auth-form-container,.auth-page-container{margin:16px;padding:24px}.form-actions{flex-direction:column;gap:8px}.form-actions .btn{width:100%}.form-row{flex-direction:column;gap:12px}.form-grid{grid-template-columns:1fr;gap:12px}}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}.modal.open{animation:fadeIn .2s ease-out}.modal-content{background:var(--color-surface);border-radius:var(--border-radius-large);border:1px solid var(--color-border);box-shadow:none;max-width:90vw;max-height:90vh;overflow-y:auto;position:relative;padding:44px 36px 32px;min-width:380px;text-align:center;transition:border .15s,background .15s}@media (max-width: 600px){.modal-content{margin:20px;max-width:calc(100vw - 40px);max-height:calc(100vh - 40px)}}.modal-content h3{margin-bottom:18px;display:flex;align-items:center;justify-content:center;gap:10px}.habit-name-edit{text-align:center}.group-habit-indicator{font-size:1.2rem;margin-left:8px}.modal-header{color:var(--color-text)}.modal-body{color:var(--color-text-secondary)}.header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:12px 20px;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000001a}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto}.header-logo{display:flex;align-items:center;text-decoration:none;transition:transform .2s ease}.header-logo:hover{transform:scale(1.05)}.header-spacer{flex:1}@media (max-width: 768px){.header{padding:8px 16px}}@media (max-width: 480px){.header{padding:6px 12px}}.hero-section:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3}.hero-logo{margin-bottom:32px;display:flex;justify-content:center}.hero-logo-large .logo-icon{width:120px!important;height:120px!important}.hero-title{font-size:3.5rem;font-weight:700;margin-bottom:24px;line-height:1.2;color:var(--color-text);text-align:center;width:100%;display:block}.features-section .section-header{text-align:center;margin-bottom:60px;max-width:800px;margin-left:auto;margin-right:auto;padding:0 20px}.features-section .section-title{font-size:2.5rem;font-weight:700;color:var(--color-text);margin-bottom:20px;line-height:1.2;text-align:center}.cta-section{background:var(--color-surface);color:var(--color-text);padding:64px 0 56px;text-align:center;position:relative;box-shadow:none;border-radius:0}.cta-section:before,.cta-section:after{display:none!important}.cta-section .container{max-width:900px;margin:0 auto;padding:0 20px}.cta-content{max-width:600px;margin:0 auto}.cta-section h2,.landing-cta-title{font-size:2.2rem;font-weight:700;margin-bottom:18px;color:var(--color-text);background:none;-webkit-background-clip:unset;-webkit-text-fill-color:unset;background-clip:unset;width:100%;display:block}.cta-section p{font-size:1.15rem;margin-bottom:32px;opacity:.92;max-width:500px;margin-left:auto;margin-right:auto;line-height:1.6;font-weight:400;color:var(--color-text-secondary)}.cta-buttons{display:flex;gap:16px;justify-content:center!important;align-items:center;margin-bottom:28px;flex-wrap:wrap;width:100%}.cta-buttons .btn{min-width:140px;padding:12px 22px;font-size:1rem;font-weight:600;border-radius:var(--border-radius);box-shadow:none;border:none;transition:background .2s,color .2s}.cta-buttons .btn-primary{background:var(--color-primary);color:#fff}.cta-buttons .btn-primary:hover{background:var(--color-accent);color:#fff}.cta-buttons .btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.cta-buttons .btn-outline:hover{background:var(--color-primary);color:#fff}.cta-guarantee{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.98rem;opacity:.8;background:none;border:none;padding:0;border-radius:0;box-shadow:none;max-width:400px;margin:0 auto;color:var(--color-text-secondary)}.guarantee-icon{font-size:1.1rem;color:var(--color-success)}.landing-footer{background:var(--color-surface);color:var(--color-text-secondary);padding:48px 0 24px;text-align:center;border-top:1px solid var(--color-border);box-shadow:none}.footer-content{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin:0 auto 24px;max-width:1100px;background:none;border-radius:0;box-shadow:none;padding:0}.footer-section h4{font-size:1.05rem;font-weight:700;margin-bottom:12px;color:var(--color-primary);border:none;background:none;padding-bottom:0;display:block}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section ul li{margin-bottom:6px}.footer-section ul li a{color:var(--color-text-secondary);text-decoration:none;font-size:.98rem;padding:0;border-radius:0;background:none;transition:color .2s}.footer-section ul li a:hover{color:var(--color-primary);background:none}.footer-social{display:flex;gap:12px;margin-top:12px;justify-content:flex-start}.footer-social a{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border-radius:50%;color:var(--color-text-secondary);text-decoration:none;transition:color .2s;font-size:1.15rem}.footer-social a:hover{color:var(--color-primary);background:none}.footer-section p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:14px;font-size:.98rem}.footer-bottom{border-top:1px solid var(--color-border);padding-top:18px;margin-top:0;color:var(--color-text-secondary);font-size:.95rem;opacity:.8;background:none}@media (max-width: 1100px){.footer-content{grid-template-columns:1fr 1fr;max-width:700px;gap:24px}}@media (max-width: 700px){.footer-content{grid-template-columns:1fr;max-width:100%;gap:12px}.cta-buttons{flex-direction:column;gap:10px;margin-bottom:18px;align-items:center}}.landing-page{min-height:100vh;overflow-x:hidden;background:var(--color-background);color:var(--color-text)}.hero-section{background:var(--color-surface);color:#fff;padding:80px 0;text-align:center;position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:center}.hero-section:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3}.hero-background{position:absolute;inset:0;overflow:hidden}.floating-shapes{position:absolute;inset:0}.shape{position:absolute;border-radius:50%;background:#ffffff1a;animation:float 6s ease-in-out infinite}.shape-1{width:80px;height:80px;top:20%;left:10%;animation-delay:0s}.shape-2{width:120px;height:120px;top:60%;right:10%;animation-delay:2s}.shape-3{width:60px;height:60px;top:40%;left:80%;animation-delay:4s}.shape-4{width:100px;height:100px;bottom:20%;left:20%;animation-delay:1s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}.hero-content{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 20px}.hero-section .container{max-width:1200px;margin:0 auto;padding:0 20px;position:relative;z-index:1}.hero-title{font-size:3.5rem;font-weight:700;margin-bottom:24px;line-height:1.2;color:var(--color-text)}.gradient-text{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.3rem;margin-bottom:40px;opacity:.9;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6;color:var(--color-text-secondary)}.hero-buttons{display:flex;gap:20px;justify-content:center;margin-bottom:60px;flex-wrap:wrap}.btn-outline{background:transparent;color:#fff;border:2px solid white}.btn-outline:hover{background:#fff;color:var(--color-primary)}.btn-arrow{margin-left:8px;transition:transform .2s ease}.btn:hover .btn-arrow{transform:translate(4px)}.hero-stats{display:flex;justify-content:center;gap:60px;margin-top:60px;flex-wrap:wrap}.hero-stats .stat-item{text-align:center}.hero-stats .stat-number{font-size:2.5rem;font-weight:700;display:block;margin-bottom:8px;color:var(--color-text)}.hero-stats .stat-label{font-size:1rem;opacity:.8;color:var(--color-text-secondary)}.hero-visual{text-align:center;margin-top:60px}.phone-mockup{display:inline-block;background:var(--color-surface);border-radius:var(--border-radius-xxl);padding:20px;transform:perspective(1000px) rotateY(-15deg) rotateX(5deg);transition:transform .3s ease}.phone-mockup:hover{transform:perspective(1000px) rotateY(-10deg) rotateX(2deg) scale(1.05)}.phone-mockup .screen{width:280px;height:560px;background:#fff;border-radius:var(--border-radius-xl);overflow:hidden;position:relative}.phone-mockup .habit-card{margin:20px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:16px;display:flex;align-items:center;gap:12px}.phone-mockup .habit-info{flex:1;min-width:0}.phone-mockup .habit-name{font-size:.9rem;font-weight:600;color:var(--color-text);margin:0;line-height:1.3}.phone-mockup .habit-streak{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--color-text-secondary);font-weight:500}.features-section{padding:80px 0;background:var(--color-surface)}.features-section .section-header{text-align:center;margin-bottom:60px}.features-section .section-title{font-size:2.5rem;font-weight:700;color:var(--color-text);margin-bottom:20px;line-height:1.2}.features-section .section-subtitle{font-size:1.2rem;color:var(--color-text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:40px;max-width:1200px;margin:0 auto;padding:0 20px}.feature-card{background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border);padding:40px;text-align:center;transition:var(--transition);position:relative;overflow:hidden;color:var(--color-text)}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));transform:scaleX(0);transition:transform .3s ease}.feature-card:hover{transform:translateY(-8px)}.feature-card:hover:before{transform:scaleX(1)}.feature-icon{font-size:3.5rem;color:var(--color-primary);margin-bottom:24px}.feature-card h3{font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:16px}.feature-card p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:0}.stats-section{background:var(--color-background);padding:80px 0}.stats-section .container{max-width:1200px;margin:0 auto;padding:0 20px}.stats-section .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px;margin-bottom:60px}.stats-section .stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:40px;text-align:center;transition:var(--transition);position:relative;overflow:hidden;color:var(--color-text)}.stats-section .stat-card:before,.stats-section .stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-primary);opacity:0;transition:opacity .2s ease}.stats-section .stat-card .stat-label{font-size:1rem;color:var(--color-text-secondary);font-weight:500;margin-bottom:12px}.stats-section .stat-card .stat-number{font-size:3rem;font-weight:700;color:var(--color-text);line-height:1;margin-bottom:8px}.stats-section .stat-card .icon{font-size:2.5rem;color:var(--color-primary);margin-bottom:20px}.cta-section{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;padding:100px 0;text-align:center;position:relative;overflow:hidden}.cta-section:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.2}.cta-section:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.cta-section .container{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 20px}.cta-content{max-width:700px;margin:0 auto}.cta-section h2{font-size:3rem;font-weight:700;margin-bottom:24px;line-height:1.2;background:linear-gradient(135deg,#fff,#f0f8ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cta-section p{font-size:1.3rem;margin-bottom:48px;opacity:.95;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6;font-weight:400}.cta-buttons{display:flex;gap:24px;justify-content:center;margin-bottom:48px;flex-wrap:wrap}.cta-buttons .btn{min-width:200px;padding:16px 32px;font-size:1.1rem;font-weight:600;border-radius:var(--border-radius-large);transition:all .3s ease;box-shadow:0 4px 20px #00000026}.cta-buttons .btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #00000040}.cta-buttons .btn-primary{background:#fff;color:var(--color-primary);border:2px solid white}.cta-buttons .btn-primary:hover{background:#fffffff2;border-color:#fffffff2}.cta-buttons .btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.8)}.cta-buttons .btn-outline:hover{background:#ffffff1a;border-color:#fff;color:#fff}.cta-guarantee{display:flex;align-items:center;justify-content:center;gap:12px;font-size:1rem;opacity:.9;padding:16px 24px;background:#ffffff1a;border-radius:var(--border-radius-large);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);max-width:500px;margin:0 auto}.guarantee-icon{font-size:1.2rem;color:#4ade80}.landing-footer{background:var(--color-background);padding:60px 0 30px;text-align:center}.footer-content{background:var(--color-surface);border-radius:var(--border-radius-large);box-shadow:0 4px 24px #00000014;padding:48px 32px 32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px;margin:0 auto 32px;max-width:1200px;border:5px solid red!important}.footer-section h4{font-size:1.1rem;font-weight:700;margin-bottom:18px;color:var(--color-primary);border-bottom:2px solid var(--color-accent);display:inline-block;padding-bottom:4px}.footer-section ul li a{display:inline-block;padding:6px 14px;border-radius:var(--border-radius-medium);background:#ffffff0a;color:var(--color-primary);margin-bottom:6px;transition:background .2s,color .2s;font-size:1rem}.footer-section ul li a:hover{background:var(--color-primary);color:#fff}.footer-social{display:flex;gap:16px;margin-top:20px;justify-content:flex-start}.footer-social a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffff14;border-radius:50%;color:var(--color-primary);text-decoration:none;transition:background .2s,color .2s;font-size:1.3rem}.footer-social a:hover{background:var(--color-primary);color:#fff}.footer-section p{color:var(--color-text-secondary);line-height:1.7;margin-bottom:20px;font-size:1rem}.footer-bottom{border-top:1px solid var(--color-border);padding-top:24px;margin-top:0;color:var(--color-text-secondary);font-size:.98rem;opacity:.85}@media (max-width: 900px){.footer-content{grid-template-columns:1fr 1fr;padding:32px 12px 24px;gap:28px}}@media (max-width: 600px){.footer-content{grid-template-columns:1fr;padding:20px 4vw 16px;gap:18px}.footer-social{justify-content:center}}.landing-app-preview-screen{background:var(--color-surface);border-radius:var(--border-radius-large);padding:24px;box-shadow:0 8px 32px #0000001a}.landing-app-header{margin-bottom:16px}.landing-cta-title{font-size:2.2rem;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-badge{display:inline-block;background:#007aff1a;color:var(--color-primary);padding:8px 16px;border-radius:var(--border-radius-xl);font-size:.9rem;font-weight:600;margin-bottom:16px;border:1px solid rgba(0,122,255,.2);backdrop-filter:blur(10px)}@media (max-width: 768px){.hero-section{padding:60px 0;min-height:auto}.hero-content{padding:0 16px}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{flex-direction:column;gap:16px}.hero-stats{gap:40px}.phone-mockup{transform:none}.phone-mockup:hover{transform:scale(1.02)}.section-title{font-size:2rem}.section-subtitle{font-size:1rem}.features-grid,.stats-section .stats-grid{grid-template-columns:1fr;gap:30px}.stats-section .stat-card{padding:30px}.stats-section .stat-card .stat-number{font-size:2.5rem}.stat-number{font-size:2rem}.cta-section{padding:80px 0}.cta-section h2{font-size:2.5rem}.cta-section p{font-size:1.1rem;margin-bottom:40px}.cta-buttons{flex-direction:column;gap:16px;margin-bottom:40px}.cta-buttons .btn{min-width:auto;width:100%;max-width:300px}.cta-guarantee{flex-direction:column;gap:8px;text-align:center;padding:20px}.landing-footer{padding:60px 0 40px}.footer-content{grid-template-columns:1fr;gap:40px;margin-bottom:40px}.footer-section:first-child{max-width:none;text-align:center}.footer-section h4:after{left:50%;transform:translate(-50%)}.footer-section ul li a:hover{transform:translate(0)}.footer-social{justify-content:center;margin-top:24px}}@media (max-width: 480px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-buttons{flex-direction:column;gap:12px}.btn-large{padding:14px 28px;font-size:1rem}.stats-grid{grid-template-columns:1fr}.cta-section{padding:60px 0}.cta-section h2{font-size:2rem}.cta-section p{font-size:1rem;margin-bottom:32px}.cta-buttons{gap:12px;margin-bottom:32px}.cta-buttons .btn{padding:14px 24px;font-size:1rem}.cta-guarantee{font-size:.9rem;padding:16px}.landing-footer{padding:40px 0 30px}.footer-content{gap:30px;margin-bottom:30px}.footer-section h4{font-size:1.2rem;margin-bottom:20px}.footer-section p,.footer-section ul li a{font-size:.95rem}.footer-bottom{padding-top:20px;margin-top:30px;font-size:.9rem}}.header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:16px 20px;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between}.app-title{font-size:1.5rem;font-weight:600;color:var(--color-text);margin:0}.app-subtitle{font-size:.9rem;color:var(--color-text-secondary);margin-top:4px}.navigation{background:var(--color-surface);border:none;box-shadow:none;position:sticky;bottom:0;left:0;right:0;z-index:900;padding:8px 0;margin-top:auto;margin-bottom:0}.nav-container{display:flex;justify-content:space-between;align-items:center;width:100%;box-sizing:border-box;padding:0}.nav-item{display:flex;flex-direction:column;align-items:center;text-decoration:none;color:var(--color-text-secondary);padding:8px 12px;border-radius:var(--border-radius-small);transition:var(--transition);min-width:60px;position:relative}.nav-item i,.nav-item svg{font-size:1.2rem;transition:var(--transition)}.nav-item.active{color:var(--color-primary);background:#7aa2f71a}.nav-item:hover,.nav-item:focus{color:var(--color-primary);background:#7aa2f70d;transform:translateY(-1px)}.nav-item:hover i,.nav-item:hover svg,.nav-item:focus i,.nav-item:focus svg{transform:scale(1.1)}.nav-item:active{transform:translateY(0);background:#7aa2f726}.nav-logo .nav-icon{display:flex;align-items:center;justify-content:center}.nav-logo .nav-icon .logo{gap:0}.nav-label{font-size:.7rem;font-weight:500;text-align:center;line-height:1.2}.nav-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin-bottom:4px}.nav-icon svg{width:20px;height:20px}@media (max-width: 768px){.navigation{padding:6px 0}}@media (max-width: 600px){.navigation{padding:4px 0}.nav-container{padding:0}.nav-item{padding:6px 8px;flex:1 1 0;min-width:0}.nav-label{display:none}.nav-icon svg{width:18px;height:18px}}@media (max-width: 375px){.nav-icon svg{width:16px;height:16px}}@media (max-width: 600px){.nav-container{gap:4px}.nav-item{flex:1 1 0;max-width:none;min-width:0}}@media (max-width: 480px){.navigation{padding:2px 0}.nav-item .nav-label{font-size:.65rem}}@media (max-width: 480px){.nav-item .nav-icon{margin-bottom:2px}}.completion-animation{animation:completionPulse 1s ease;transform-origin:center}@keyframes completionPulse{0%{transform:scale(1);box-shadow:0 2px 8px #0000001a}25%{transform:scale(1.08);box-shadow:0 12px 32px #22c55e66}50%{transform:scale(1.05);box-shadow:0 8px 24px #22c55e4d}75%{transform:scale(1.02);box-shadow:0 4px 16px #22c55e33}to{transform:scale(1);box-shadow:0 2px 8px #0000001a}}.habit-card.completed:after{content:"✨";position:absolute;top:-10px;right:-10px;font-size:20px;animation:sparkle 2s ease-in-out infinite;z-index:10}@keyframes sparkle{0%,to{transform:scale(1) rotate(0);opacity:.8}50%{transform:scale(1.2) rotate(180deg);opacity:1}}.xp-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(45deg,gold,orange);color:#fff;padding:16px 24px;border-radius:20px;font-size:18px;font-weight:700;animation:xpModalFloat 2s ease-out forwards;z-index:1000;pointer-events:none;box-shadow:0 8px 32px #ffd70066;backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2)}@keyframes xpModalFloat{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}20%{transform:translate(-50%,-50%) scale(1.1);opacity:1}80%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(.9);opacity:0}}.streak-multiplier{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(45deg,#ff6b6b,#ff8e53);color:#fff;padding:12px 20px;border-radius:16px;font-size:16px;font-weight:700;animation:multiplierModalPulse 2s ease-in-out;z-index:1000;pointer-events:none;box-shadow:0 6px 24px #ff6b6b66;backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2)}@keyframes multiplierModalPulse{0%{transform:translate(-50%,-50%) scale(0);opacity:0}25%{transform:translate(-50%,-50%) scale(1.2);opacity:1}50%{transform:translate(-50%,-50%) scale(1);opacity:1}75%{transform:translate(-50%,-50%) scale(1.1);opacity:.8}to{transform:translate(-50%,-50%) scale(.9);opacity:0}}.perfect-day-crown{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;animation:crownModalGlow 3s ease-in-out infinite;z-index:1000;pointer-events:none;color:gold;text-shadow:0 0 20px rgba(255,215,0,.8);filter:drop-shadow(0 0 15px rgba(255,215,0,.6))}@keyframes crownModalGlow{0%,to{transform:translate(-50%,-50%) scale(1);filter:drop-shadow(0 0 15px rgba(255,215,0,.6))}50%{transform:translate(-50%,-50%) scale(1.2);filter:drop-shadow(0 0 25px rgba(255,215,0,1))}}.habit-card.completed{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border-color:var(--color-success);position:relative;overflow:hidden}.habit-card.completed:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(34,197,94,.2),transparent);animation:completionShine 1.5s ease}@keyframes completionShine{0%{left:-100%}to{left:100%}}.habit-card{background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border);padding:12px 16px;display:flex;align-items:center;gap:12px;transition:var(--transition);cursor:pointer;position:relative;overflow:hidden;color:var(--color-text)}.habit-card:active{transform:scale(.98);background:#7aa2f714;border-color:var(--color-primary)}.habit-card__name{flex:1;font-weight:600;color:var(--color-text);margin:0;display:flex;align-items:center;gap:8px;cursor:pointer}.habit-card__name:after{content:"›";color:var(--color-text-secondary);font-size:1.2rem;font-weight:400;opacity:.6;transition:var(--transition);margin-left:auto}.habit-card__name:active:after{transform:translate(2px)}.habit-card:hover,.habit-card:focus-within{border-color:var(--color-primary);transform:translateY(-1px)}.habit-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--color-primary);transform:scaleX(0);transition:transform .2s ease}.habit-card--group{background:#bb9af70d}.habit-card__icon{display:none!important}.habit-card__details{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;background:transparent}.habit-card__name{font-size:1rem;font-weight:600;color:var(--color-text);margin:0;line-height:1.3}.habit-card__desc,.habit-card__group-info{font-size:.85rem;color:var(--color-text-secondary);margin:0;line-height:1.3}.habit-card__next-due{font-size:.8rem;color:var(--color-text-secondary);margin:0;line-height:1.3;display:flex;align-items:center;opacity:.8}.habit-card__streak{display:flex;align-items:center;gap:6px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-small);transition:var(--transition);margin-left:auto}.habit-card__streak-number{font-size:.9rem;font-weight:600;color:var(--color-text-secondary);line-height:1}.habit-card__streak-flame{font-size:1.1rem;color:var(--color-text-secondary);animation:pulse 2s infinite;transition:var(--transition);filter:none}.habit-card:active .habit-card__streak-flame,.habit-card__streak:active .habit-card__streak-flame{animation:wiggle .3s ease-in-out;transform:scale(1.1)}.habit-card__streak:hover .habit-card__streak-flame{color:var(--color-primary)}.habit-card__streak:active,.habit-card__streak:active .habit-card__streak-number,.habit-card__streak:active .habit-card__streak-flame{transform:scale(.95)}.habit-card--completed .habit-card__streak,.habit-card--completed .habit-card__streak-number,.habit-card--completed .habit-card__streak-flame{color:var(--color-accent)}.habit-card--completed .habit-card__streak-flame{animation:none;color:var(--color-accent);position:relative;filter:drop-shadow(0 0 3px rgba(72,187,120,.4))}.habit-card--completed .habit-card__streak-flame:before,.habit-card--completed .habit-card__streak-flame:after{content:"";position:absolute;width:3px;height:3px;border-radius:50%;opacity:0;background:radial-gradient(circle,var(--color-accent) 0%,rgba(125,207,255,.8) 50%,rgba(125,207,255,.6) 100%);box-shadow:0 0 4px #7dcfff99;pointer-events:none;z-index:1;top:-2px}.habit-card--completed .habit-card__streak-flame:before{animation:emberFloat1 3s ease-in-out infinite;animation-delay:0s;left:2px}.habit-card--completed .habit-card__streak-flame:after{animation:emberFloat2 3s ease-in-out infinite;animation-delay:1s;right:2px}.habit-card--completed .ember-3{content:"";position:absolute;width:2px;height:2px;border-radius:50%;opacity:0;background:radial-gradient(circle,var(--color-accent) 0%,rgba(125,207,255,.8) 50%,rgba(125,207,255,.6) 100%);box-shadow:0 0 3px #7dcfff99;pointer-events:none;z-index:1;top:-1px;left:50%;transform:translate(-50%);animation:emberFloat3 3.5s ease-in-out infinite;animation-delay:.5s}.habit-card--completed{background:#7dcfff14;border-color:var(--color-accent)}.habit-card--completed .habit-card__name,.habit-card--completed .habit-card__desc{color:var(--color-text);text-decoration:none}.habit-card__progress-bar{width:100%;height:4px;background:var(--color-border);border-radius:2px;overflow:hidden;margin-top:8px}.habit-card__progress-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.habit-card__group-progress{margin-top:8px}.habit-icon{font-size:1.5rem;margin-right:12px;flex-shrink:0}.habit-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.habit-name{font-size:1rem;font-weight:600;color:var(--color-text);margin:0;line-height:1.3}.habit-streak{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.checkmark{width:38px;height:38px;border-radius:50%;border:2px solid var(--color-border);background:var(--color-surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);flex-shrink:0;margin-left:auto}.checkmark-btn i{width:auto!important;height:auto!important;font-size:1.3em;display:inline-block;line-height:1}.habit-card .checkmark-btn,.habit-card.pill .checkmark-btn,.habit-card.completed .checkmark-btn,.checkmark-btn{width:38px!important;height:38px!important;min-width:0!important;min-height:0!important;max-width:38px!important;max-height:38px!important;aspect-ratio:1 / 1!important;border-radius:50%!important;flex:0 0 38px!important;box-sizing:border-box!important;padding:0!important;overflow:hidden!important;display:flex!important;align-items:center!important;justify-content:center!important;margin-left:0!important;margin-right:0!important}.habit-card.completed .checkmark-btn{background:var(--color-accent)!important;color:var(--color-text)!important;border:2px solid var(--color-accent)!important}.habit-card__group-progress-number{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);background:#5856d61a;padding:2px 6px;border-radius:var(--border-radius-small);margin-left:4px}.habit-card__group-superscript{font-size:.7rem;font-weight:600;color:var(--color-text-secondary);background:#5856d61a;padding:1px 4px;border-radius:var(--border-radius-small);margin-left:4px;vertical-align:super;line-height:1}.habit-card__group-person,.habit-card__group-person--done{font-size:.9rem;color:var(--color-text-secondary);margin-right:2px}.habit-card__group-person{color:var(--color-text-secondary);background:transparent}.habit-card__group-person--done{color:var(--color-primary);background:transparent}.habit-card__group-person:first-child,.habit-card__group-person--done:first-child{margin-left:4px}.habit-card__name-row,.habit-card__name,.habit-card__name.card-title,.habit-card__name-row h3{display:flex;align-items:center;gap:8px}.habit-card__streak-flame:active{animation:wiggle .3s ease-in-out;transform:scale(1.1)}@media (max-width: 600px){.habit-card{padding:10px 12px;gap:8px}.habit-card__details{gap:4px}.habit-card__name{font-size:.9rem;line-height:1.2}.habit-card__desc,.habit-card__group-info{font-size:.75rem;line-height:1.2}.habit-card__streak{gap:3px;padding:2px 4px}}@media (max-width: 400px){.habit-card__desc,.habit-card__group-info{font-size:.75rem;line-height:1.2}}@media (max-width: 600px){.habit-card{padding:12px}.habit-card__icon{font-size:1.3rem;margin-right:8px}.habit-card__icon svg{width:20px;height:20px}.habit-card__group-progress-number{font-size:.75rem;padding:1px 4px}}@media (max-width: 600px){.habit-card .checkmark-btn,.habit-card.pill .checkmark-btn,.habit-card.completed .checkmark-btn,.checkmark-btn{width:32px!important;height:32px!important;max-width:32px!important;max-height:32px!important;flex:0 0 32px!important}}.habit-card__name-interactive{display:inline-flex;align-items:center;background:#7aa2f71f;border-radius:6px;cursor:pointer;transition:background .2s;padding:2px 8px}.habit-card__name-interactive:hover{background:#7aa2f738}.habit-card__name-text,.habit-card__group-superscript{background:none!important;border-radius:0;cursor:pointer;transition:none}@media (max-width: 335px){.habit-card__name-text{font-size:.5rem}}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;backdrop-filter:blur(8px);z-index:1000;animation:backdropFadeIn .3s ease-out}.congratulations-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-surface-elevated);color:var(--color-text);padding:32px;border-radius:var(--border-radius-xl);text-align:center;animation:congratulationsModalEnhanced .6s cubic-bezier(.175,.885,.32,1.275) forwards;z-index:1001;cursor:pointer;box-shadow:var(--shadow-elevated);border:1px solid var(--color-border);min-width:320px;max-width:90vw;transition:var(--transition)}.congratulations-popup:hover{transform:translate(-50%,-50%) scale(1.02);box-shadow:var(--shadow-elevated),0 0 0 1px var(--color-border-focus)}.congratulations-content{position:relative;z-index:2}.congratulations-icon{font-size:48px;color:var(--color-success);margin-bottom:16px;animation:iconBounce .8s ease-out}.congratulations-content h2{font-size:24px;font-weight:600;margin-bottom:12px;color:var(--color-text);animation:textSlideIn .6s ease-out .2s both}.congratulations-content p{font-size:16px;color:var(--color-text-secondary);margin:0 0 16px;font-weight:400;animation:textSlideIn .6s ease-out .4s both}.modal-hint{font-size:14px;color:var(--color-text-muted);font-style:italic;margin-top:12px;padding:8px 16px;background:var(--color-surface);border-radius:var(--border-radius-small);border:1px solid var(--color-border);animation:pulseHint 2s ease-in-out infinite;animation-delay:1s}.xp-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-surface-elevated);color:var(--color-text);padding:16px 24px;border-radius:var(--border-radius-large);font-size:18px;font-weight:600;animation:xpModalFloatEnhanced .8s cubic-bezier(.175,.885,.32,1.275) forwards;z-index:1001;cursor:pointer;box-shadow:var(--shadow-elevated);border:1px solid var(--color-border);transition:var(--transition);display:flex;align-items:center;gap:8px}.xp-popup svg{color:var(--color-warning);font-size:20px;animation:starTwinkle 1.2s ease-in-out infinite}.xp-popup:hover{transform:translate(-50%,-50%) scale(1.05);box-shadow:var(--shadow-elevated),0 0 0 1px var(--color-border-focus)}.streak-multiplier{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--color-surface-elevated);color:var(--color-text);padding:12px 20px;border-radius:var(--border-radius-large);font-size:16px;font-weight:600;animation:multiplierModalPulseEnhanced .7s cubic-bezier(.175,.885,.32,1.275);z-index:1001;cursor:pointer;box-shadow:var(--shadow-elevated);border:1px solid var(--color-border);transition:var(--transition);display:flex;align-items:center;gap:8px}.streak-multiplier svg{color:var(--color-danger);font-size:18px;animation:fireFlicker 1s ease-in-out infinite}.streak-multiplier:hover{transform:translate(-50%,-50%) scale(1.05);box-shadow:var(--shadow-elevated),0 0 0 1px var(--color-border-focus)}.perfect-day-crown{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;animation:crownModalGlowEnhanced 2.5s ease-in-out infinite;z-index:1001;cursor:pointer;color:var(--color-warning);transition:var(--transition)}.perfect-day-crown:hover{transform:translate(-50%,-50%) scale(1.1);color:var(--color-primary)}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}@keyframes congratulationsModalEnhanced{0%{opacity:0;transform:translate(-50%,-50%) scale(.8) translateY(20px)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.05) translateY(-5px)}to{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0)}}@keyframes xpModalFloatEnhanced{0%{opacity:0;transform:translate(-50%,-50%) scale(.6) translateY(30px)}60%{opacity:1;transform:translate(-50%,-50%) scale(1.1) translateY(-10px)}to{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0)}}@keyframes multiplierModalPulseEnhanced{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes crownModalGlowEnhanced{0%,to{transform:translate(-50%,-50%) scale(1);filter:drop-shadow(0 0 8px var(--color-warning))}50%{transform:translate(-50%,-50%) scale(1.05);filter:drop-shadow(0 0 16px var(--color-warning))}}@keyframes iconBounce{0%{transform:scale(0) rotate(-180deg)}50%{transform:scale(1.2) rotate(0)}to{transform:scale(1) rotate(0)}}@keyframes textSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes starTwinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes fireFlicker{0%,to{opacity:1;transform:scale(1)}25%{opacity:.8;transform:scale(1.05)}75%{opacity:.9;transform:scale(.95)}}@keyframes pulseHint{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.habit-card--easy{border-left:4px solid #1dbf73}.habit-card--medium{border-left:4px solid #fbbf24}.habit-card--hard{border-left:4px solid #ef4444}.habit-card__name-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.habit-card__name-text{font-size:1.1rem;font-weight:700;color:var(--color-text);margin:0;line-height:1.2;flex:1}.habit-card__meta-row{display:flex;align-items:center;gap:16px;font-size:.9rem;color:var(--color-text-secondary);margin-top:2px}.habit-card__next-due{font-size:.85em;color:var(--color-text-secondary);display:flex;align-items:center;gap:2px}.habit-card__desc{font-size:.85em;color:var(--color-text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.habit-card-container{position:relative;margin-bottom:var(--spacing-sm);transition:all .3s cubic-bezier(.25,.46,.45,.94);cursor:grab;user-select:none;padding-left:0}.habit-card-container:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000001a}.habit-card-container:active{cursor:grabbing}.habit-card-container .habit-card{cursor:inherit}.habit-card-container .habit-card__streak{cursor:pointer}.habit-card-container--dragging{opacity:.8;z-index:1000;box-shadow:0 8px 32px #0003;transition:none}.habit-card-container--drag-over{transform:translateY(16px);transition:all .4s cubic-bezier(.25,.46,.45,.94);margin-bottom:calc(var(--spacing-sm) + 16px)}.habit-card-container--drag-over:before{content:"";position:absolute;top:-8px;left:0;right:0;height:3px;background:var(--color-primary);border-radius:2px;opacity:.8;animation:dragOverPulse .6s ease-in-out}@keyframes dragOverPulse{0%,to{opacity:.4;transform:scaleX(.8)}50%{opacity:.8;transform:scaleX(1)}}.habit-card-container--drag-over .habit-card{border-color:var(--color-primary);box-shadow:0 4px 16px rgba(var(--color-primary-rgb),.2)}.habit-card-container--space-above{transform:translateY(-8px);transition:all .4s cubic-bezier(.25,.46,.45,.94)}.habit-card-container--space-below{transform:translateY(8px);transition:all .4s cubic-bezier(.25,.46,.45,.94)}.habit-card-container .habit-card{transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer}.habit-card-container--dragging .habit-card{background:#7aa2f714!important;border-color:var(--color-primary)!important}.habit-card-container .habit-card:active{transform:scale(.98)}.habit-card-container--dragging .habit-card:active{transform:none!important}.habit-card--dragging:active{transform:none!important;background:#7aa2f714!important;border-color:var(--color-primary)!important}.habit-card--dragging .habit-card__streak:active{transform:none!important}.habit-card--dragging .habit-card__streak:active .habit-card__streak-flame{transform:none!important;animation:none!important}.habit-card-container:hover .drag-indicator{opacity:.6;background:var(--color-primary)}.habit-card-container--dragging .drag-indicator{opacity:.8;background:var(--color-primary);transform:translateY(-50%) scale(1.2)}.habits-list{position:relative;min-height:100px}.habit-card--droppable{border:2px dashed var(--color-primary, #7aa2f7)!important;background:#7aa2f714!important;transform:scale(1.02);box-shadow:0 0 0 4px #7aa2f71a,0 4px 12px #7aa2f733;transition:all .2s ease}.habit-card--droppable:before{content:"Drop to create routine";position:absolute;top:-40px;left:50%;transform:translate(-50%);background:var(--color-primary, #7aa2f7);color:#fff;padding:6px 12px;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;z-index:1001;box-shadow:0 2px 8px #00000026}.habit-card--droppable[data-in-routine=true]:before{content:"Drop to move to this routine"}.habit-card--droppable[data-in-routine=false]:before{content:"Drop to make solo"}.habit-card--dragging{opacity:.9;transform:rotate(1deg) scale(1.02);z-index:1000;box-shadow:0 8px 24px #00000026,0 0 0 2px var(--color-primary, #7aa2f7)}.habit-card-container--dragging{z-index:1000;cursor:grabbing}.routine-card__container--droppable{border:2px dashed var(--color-primary, #7aa2f7);background:#7aa2f70d;box-shadow:0 0 0 4px #7aa2f71a,0 4px 16px #7aa2f726;transform:scale(1.01);transition:all .2s ease}.routine-card__container--droppable:before{content:"Drop habit here";position:absolute;top:-30px;left:50%;transform:translate(-50%);background:var(--color-primary, #7aa2f7);color:#fff;padding:4px 8px;border-radius:4px;font-size:.7rem;font-weight:600;white-space:nowrap;z-index:1001}.habit-card--dragging,.habit-card-container--dragging{z-index:1000}.habit-card-container--in-routine{margin-left:20px;border-left:2px solid var(--color-border);padding-left:12px}.routine-card{margin-bottom:16px}.routine-card__container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);overflow:hidden;box-shadow:0 2px 8px #0000001a}.routine-card__container:hover{box-shadow:0 4px 16px #00000026}.routine-card__header{background:var(--color-surface-elevated);border-bottom:1px solid var(--color-border);padding:16px;display:flex;align-items:center;position:relative}.routine-card__habits{padding:16px;background:var(--color-surface)}@media (max-width: 768px){.routine-card__header{padding:12px}.routine-card__habits,.habit-card-container--in-routine{margin-left:16px;padding-left:8px}}@media (prefers-color-scheme: dark){.habit-card--routine-target{background:rgba(var(--color-primary-rgb),.1)}.routine-card__header:hover{background:var(--color-surface)}}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 0 6px #7aa2f733,0 0 20px #7aa2f74d}50%{transform:scale(1.02);box-shadow:0 0 0 8px #7aa2f74d,0 0 25px #7aa2f766}to{transform:scale(1);box-shadow:0 0 0 6px #7aa2f733,0 0 20px #7aa2f74d}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}60%{transform:translateY(-2px)}}.habit-tree-item.dragging{opacity:.3;pointer-events:none}.routine-tree-item.dragging{opacity:.5;pointer-events:none}.drag-overlay{z-index:1000;pointer-events:none}.drag-overlay .habit-card,.drag-overlay .routine-card{box-shadow:0 8px 32px #0000004d}.habit-card,.routine-card{transform:none}.habit-completion-feedback{position:relative;width:100%;max-width:500px;margin:0 auto;padding:20px;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;overflow:hidden;min-height:400px}.particle-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.completion-message{position:relative;z-index:2;margin-bottom:30px}.completion-icon{font-size:48px;color:gold;margin-bottom:15px;animation:bounce .6s ease-in-out}.completion-title{font-size:24px;font-weight:700;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.habit-name{font-size:18px;opacity:.9;font-style:italic}.streak-bonus{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;background:#ffd70033;border:2px solid #FFD700;border-radius:15px;padding:15px;margin-bottom:20px;animation:slideInFromRight .5s ease-out}.bonus-icon{font-size:24px;color:gold;margin-right:15px}.bonus-content h3{margin:0 0 5px;font-size:18px;color:gold}.bonus-content p{margin:0;font-size:14px;opacity:.9}.perfect-day-celebration{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;background:linear-gradient(45deg,gold,orange);border-radius:15px;padding:20px;margin-bottom:20px;animation:pulse 2s infinite}.celebration-icon{font-size:32px;color:#fff;margin-right:15px}.celebration-content h3{margin:0 0 5px;font-size:20px;color:#fff}.celebration-content p{margin:0;font-size:14px;color:#fff;opacity:.9}.rewards-display{position:relative;z-index:2;margin-bottom:25px}.rewards-title{font-size:20px;margin-bottom:15px;color:gold;display:flex;align-items:center;justify-content:center;gap:8px}.rewards-list{display:flex;flex-direction:column;gap:10px}.reward-item{display:flex;align-items:center;background:#ffffff1a;border:2px solid;border-radius:10px;padding:12px;animation:slideInFromBottom .5s ease-out;backdrop-filter:blur(10px)}.reward-icon{font-size:20px;margin-right:12px;min-width:24px}.reward-content{flex:1;text-align:left}.reward-message{font-weight:700;margin-bottom:2px}.reward-rarity{font-size:12px;opacity:.8;font-weight:500}.progress-update{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:25px;background:#ffffff1a;border-radius:15px;padding:15px;backdrop-filter:blur(10px)}.progress-item{text-align:center}.progress-label{display:block;font-size:12px;opacity:.8;margin-bottom:5px}.progress-value{display:block;font-size:16px;font-weight:700;color:gold}.motivational-message{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:15px;padding:15px;margin-bottom:25px;backdrop-filter:blur(10px)}.message-icon{font-size:20px;color:#ff6b6b;margin-right:12px}.message-text{margin:0;font-size:14px;font-style:italic}.continue-section{position:relative;z-index:2}.continue-button{background:linear-gradient(45deg,gold,orange);color:#fff;border:none;border-radius:25px;padding:12px 30px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ffd7004d}.continue-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffd70066}.continue-button:active{transform:translateY(0)}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromBottom{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@media (max-width: 480px){.habit-completion-feedback{padding:15px;min-height:350px}.completion-title{font-size:20px}.habit-name{font-size:16px}.progress-update{grid-template-columns:1fr;gap:10px}.rewards-list{gap:8px}.reward-item{padding:10px}}@media (prefers-color-scheme: dark){.habit-completion-feedback{background:linear-gradient(135deg,#2c3e50,#34495e)}}.routine-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#1e222c59;z-index:2001;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.routine-modal{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:0 20px 40px #0003;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;z-index:2002;animation:recapSlideIn .3s ease-out;border-radius:var(--border-radius);scrollbar-width:none;-ms-overflow-style:none}.routine-modal::-webkit-scrollbar{display:none}.routine-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,var(--color-primary) 0%,rgba(122,162,247,.8) 100%);color:#fff;border-radius:var(--border-radius) var(--border-radius) 0 0}.routine-modal-header h2{font-size:1.2rem;font-weight:600;color:#fff;margin:0}.routine-modal-close{background:none;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:50%;transition:var(--transition);display:flex;align-items:center;justify-content:center;font-size:.9rem}.routine-modal-close:hover{background:#fff3}.routine-modal-close svg{width:14px;height:14px}.routine-modal-content{max-width:100%;box-sizing:border-box;padding:20px;scrollbar-width:none;-ms-overflow-style:none}.routine-modal-content::-webkit-scrollbar{display:none}.routine-section{margin-bottom:24px}.routine-section:last-child{margin-bottom:0}.routine-section h3{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.routine-icon{color:var(--color-primary);font-size:.9rem;width:16px;height:16px;flex-shrink:0}.routine-name-input-group{display:flex;flex-direction:column;gap:12px}.routine-name-edit{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--border-radius-small);font-size:.95rem;color:var(--color-text);background:var(--color-surface);transition:var(--transition);box-sizing:border-box}.routine-name-edit:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #7aa2f71a}.routine-name-display{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--border-radius-small);min-height:3rem;transition:var(--transition)}.routine-name-display:hover{border-color:var(--color-primary);background:#7aa2f70d}.routine-name-text{font-weight:500;color:var(--color-text);font-size:.95rem}.routine-edit-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:6px;border-radius:50%;transition:var(--transition);display:flex;align-items:center;justify-content:center;font-size:.8rem}.routine-edit-btn:hover{background:#7aa2f71a;color:var(--color-primary)}.routine-edit-btn svg{width:12px;height:12px}.routine-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}.routine-stat{display:flex;align-items:center;gap:12px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-small);transition:var(--transition)}.routine-stat:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.routine-stat-icon{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.routine-stat-icon svg{width:16px;height:16px}.routine-stat-content{flex:1;min-width:0}.routine-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.2;margin-bottom:2px}.routine-stat-label{font-size:.8rem;color:var(--color-text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.routine-habits-list{display:flex;flex-direction:column;gap:8px}.routine-habit-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--border-radius-small);transition:var(--transition);background:var(--color-surface);border:1px solid var(--color-border)}.routine-habit-item:hover{border-color:var(--color-primary);background:#7aa2f70d;transform:translate(2px)}.routine-habit-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;flex-shrink:0}.routine-habit-info{flex:1;min-width:0}.routine-habit-name{font-weight:600;font-size:.95rem;color:var(--color-text);margin-bottom:4px}.routine-habit-category{font-size:.75rem;color:var(--color-text-muted);background:var(--color-surface-elevated);padding:.25rem .5rem;border-radius:var(--border-radius-small);text-transform:capitalize;display:inline-block}.routine-habit-remove{background:none;border:none;color:var(--color-danger);cursor:pointer;padding:8px;border-radius:50%;transition:var(--transition);display:flex;align-items:center;justify-content:center;font-size:.8rem;opacity:.7}.routine-habit-remove:hover{background:#ef44441a;opacity:1;transform:scale(1.1)}.routine-habit-remove svg{width:12px;height:12px}.routine-empty-state{text-align:center;padding:32px 16px;color:var(--color-text-secondary)}.routine-empty-state-emoji{font-size:2rem;opacity:.6;width:32px;height:32px;margin:0 auto 12px;color:var(--color-text-secondary)}.routine-empty-state p{margin:8px 0;font-size:.9rem}.routine-empty-state-help{font-size:.8rem;opacity:.7;font-style:italic}.routine-actions{display:flex;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border)}.routine-actions .btn{flex:1;padding:10px 16px;border:none;border-radius:var(--border-radius-small);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);text-align:center;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:6px}.routine-actions .btn-primary{background:var(--color-primary);color:#fff}.routine-actions .btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #7aa2f74d}.routine-actions .btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.routine-actions .btn-secondary:hover{background:var(--color-surface-elevated);border-color:var(--color-primary);color:var(--color-primary)}.routine-actions .btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}@media (max-width: 768px){.routine-modal{max-width:95vw;margin:20px}.routine-modal-header{padding:14px 16px}.routine-modal-header h2{font-size:1.1rem}.routine-modal-content{padding:16px}.routine-section{margin-bottom:20px}.routine-stats{grid-template-columns:1fr;gap:8px}.routine-stat{padding:12px}.routine-stat-icon{width:32px;height:32px;font-size:.9rem}.routine-stat-icon svg{width:14px;height:14px}.routine-stat-value{font-size:1.2rem}.routine-actions{flex-direction:column}.routine-actions .btn{width:100%}}@media (max-width: 480px){.routine-modal-overlay{padding:10px}.routine-modal{max-width:100vw;margin:0;max-height:95vh}.routine-modal-header{padding:12px 16px}.routine-modal-header h2{font-size:1rem}.routine-modal-content{padding:12px}.routine-section h3{font-size:.9rem}.routine-habit-item{padding:10px}.routine-habit-avatar{width:32px;height:32px;font-size:.8rem}.routine-habit-name{font-size:.9rem}.routine-empty-state{padding:24px 12px}.routine-empty-state-emoji{font-size:1.5rem;width:24px;height:24px}}.profile-header{background:var(--color-surface);border-radius:16px;border:none;padding:24px;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;position:relative;overflow:hidden}.profile-header:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.profile-info{display:flex;align-items:flex-start;gap:24px}.profile-avatar{flex-shrink:0}.avatar-image{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--color-primary);box-shadow:0 4px 12px #0000001a}.avatar-placeholder{width:120px;height:120px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:48px;color:#fff;border:3px solid var(--color-primary);box-shadow:0 4px 12px #0000001a}.profile-details{flex:1;min-width:0}.profile-name{font-size:2rem;font-weight:700;color:var(--color-text);margin:0 0 8px;line-height:1.2}.profile-bio{font-size:1.1rem;color:var(--color-text-secondary);margin:0 0 16px;line-height:1.5}.profile-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--color-text-secondary)}.follow-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.follow-button:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.edit-profile-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.edit-profile-button:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-1px)}.profile-stats{background:var(--color-surface);border-radius:16px;border:none;padding:24px;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;position:relative;overflow:hidden}.profile-stats:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.stat-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:20px;text-align:center;transition:var(--transition)}.stat-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.stat-value{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:4px}.stat-label{font-size:.9rem;color:var(--color-text-secondary);font-weight:500}.habits-grid-section{background:var(--color-surface);border-radius:16px;border:none;padding:24px;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;position:relative;overflow:hidden}.habits-grid-section:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.habits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px}.profile-page .habit-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:20px;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.profile-page .habit-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.habit-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.habit-icon{font-size:2rem;margin-bottom:8px}.habit-privacy{font-size:.8rem;color:var(--color-text-secondary);opacity:.7}.habit-card-content{flex:1}.habit-name{font-size:1.2rem;font-weight:600;color:var(--color-text);margin:0 0 8px;line-height:1.3}.habit-description{font-size:.9rem;color:var(--color-text-secondary);margin:0 0 12px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.habit-stats{display:flex;flex-direction:column;gap:6px}.streak{font-size:.85rem;color:var(--color-primary);font-weight:500}.completion-rate{font-size:.85rem;color:var(--color-text-secondary)}.copy-habit-button{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:4px;padding:6px 12px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-size:.8rem;font-weight:500;cursor:pointer;transition:var(--transition);opacity:0}.profile-page .habit-card:hover .copy-habit-button{opacity:1}.copy-habit-button:hover{background:var(--color-primary-dark);transform:scale(1.05)}.empty-state{text-align:center;padding:40px 20px;color:var(--color-text-secondary)}.empty-state p{font-size:1.1rem;margin:0}@media (max-width: 768px){.profile-info{flex-direction:column;align-items:center;text-align:center}.profile-avatar,.avatar-placeholder{width:100px;height:100px}.profile-name{font-size:1.5rem}.habits-grid{grid-template-columns:1fr}.profile-meta{justify-content:center}}@media (max-width: 480px){.profile-header{padding:20px}.profile-stats,.habits-grid-section,.profile-page .habit-card{padding:16px}}.profile-edit-modal{max-width:500px;width:90%}.photo-upload-section{margin-bottom:24px}.photo-upload-section h3{font-size:1.1rem;font-weight:600;margin-bottom:12px;color:var(--color-text)}.photo-upload-area{display:flex;align-items:center;gap:16px}.current-photo{flex-shrink:0}.profile-photo-preview{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--color-primary)}.photo-placeholder{width:80px;height:80px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;border:2px solid var(--color-primary)}.upload-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.upload-button:hover:not(:disabled){background:var(--color-primary-dark)}.upload-button:disabled{opacity:.6;cursor:not-allowed}.form-section{margin-bottom:20px}.form-section label{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--color-text);margin-bottom:8px}.form-section input,.form-section textarea{width:100%;padding:12px;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:1rem;background:var(--color-background);color:var(--color-text);transition:var(--transition)}.form-section input:focus,.form-section textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #4f46e51a}.form-section textarea{resize:vertical;min-height:80px}.char-count{font-size:.8rem;color:var(--color-text-secondary);text-align:right;margin-top:4px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--color-border)}.btn-secondary{padding:10px 20px;background:var(--color-background);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-secondary:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-primary)}.btn-primary{padding:10px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.copy-habit-modal{max-width:600px;width:90%}.original-habit-section{margin-bottom:24px}.original-habit-section h3{font-size:1.1rem;font-weight:600;margin-bottom:12px;color:var(--color-text)}.habit-preview{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:16px}.habit-preview-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.habit-preview-content h4{font-size:1.1rem;font-weight:600;margin:0 0 8px;color:var(--color-text)}.habit-preview-content p{font-size:.9rem;color:var(--color-text-secondary);margin:0 0 12px;line-height:1.4}.customization-section h3{font-size:1.1rem;font-weight:600;margin-bottom:16px;color:var(--color-text)}.privacy-options{display:flex;flex-direction:column;gap:12px}.privacy-option{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px;border-radius:var(--border-radius);transition:var(--transition)}.privacy-option:hover{background:var(--color-surface)}.privacy-option input[type=radio]{width:18px;height:18px}.privacy-label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--color-text)}.privacy-label strong{font-weight:600}.habits-display{display:flex;flex-direction:column;gap:32px}.routines-section,.individual-habits-section{display:flex;flex-direction:column;gap:16px}.section-title{font-size:1.3rem;font-weight:600;color:var(--color-text);margin:0;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.routines-list{display:flex;flex-direction:column;gap:16px}.profile-routine-card{margin-bottom:16px}.profile-routine-card .routine-card{margin:0}@media (max-width: 768px){.habits-display{gap:24px}.routines-section,.individual-habits-section{gap:12px}.section-title{font-size:1.1rem}}.rotating-quests{margin-bottom:24px}#quests-section .rotating-quests,.rotating-quests-section .rotating-quests{margin-bottom:0}#quests-section .quest-section,.rotating-quests-section .quest-section{margin-bottom:12px}#quests-section .quest-section:last-child,.rotating-quests-section .quest-section:last-child{margin-bottom:0}#quests-section .quests-grid,.rotating-quests-section .quests-grid{grid-template-columns:1fr;gap:8px}#quests-section .quest-card,.rotating-quests-section .quest-card{padding:12px;font-size:.9rem}#quests-section .quest-section h3,.rotating-quests-section .quest-section h3{font-size:.9rem;margin-bottom:8px}#quests-section .quest-title h4,.rotating-quests-section .quest-title h4{font-size:.95rem;margin:0 0 2px}#quests-section .quest-description,.rotating-quests-section .quest-description{font-size:.8rem;margin:0 0 8px}#quests-section .quest-progress,.rotating-quests-section .quest-progress{margin-bottom:8px}#quests-section .progress-bar,.rotating-quests-section .progress-bar{height:6px;margin-bottom:4px}#quests-section .progress-text,.rotating-quests-section .progress-text,#quests-section .quest-footer,.rotating-quests-section .quest-footer{font-size:.75rem}#quests-section .quest-difficulty,.rotating-quests-section .quest-difficulty{font-size:.7rem}#quests-section .quest-reward,.rotating-quests-section .quest-reward{font-size:.8rem}.quest-section{margin-bottom:32px}.quest-section h3{display:flex;align-items:center;gap:8px;font-size:1.2rem;font-weight:600;color:var(--color-text);margin-bottom:16px}.section-icon{color:var(--color-primary);font-size:1rem}.quests-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.quest-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:20px;transition:var(--transition);position:relative;overflow:hidden}.quest-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-elevated)}.quest-card.completed{border-color:var(--color-success);background:linear-gradient(135deg,var(--color-surface) 0%,rgba(34,197,94,.05) 100%)}.quest-card.completed:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-success),var(--color-primary))}.quest-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.quest-title h4{font-size:1.1rem;font-weight:600;color:var(--color-text);margin:0 0 4px}.quest-difficulty{font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.quest-reward{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--color-primary);font-weight:500}.quest-description{color:var(--color-text-secondary);font-size:.9rem;line-height:1.4;margin:0 0 16px}.quest-progress{margin-bottom:16px}.progress-bar{width:100%;height:8px;background:var(--color-border);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:4px;transition:width .3s ease}.quest-card.completed .progress-fill{background:linear-gradient(90deg,var(--color-success),var(--color-primary))}.progress-text{font-size:.85rem;color:var(--color-text-secondary);text-align:center;font-weight:500}.quest-footer{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.quest-time{display:flex;align-items:center;gap:6px;color:var(--color-text-secondary)}.quest-completed{display:flex;align-items:center;gap:6px;color:var(--color-success);font-weight:500}.quests-loading,.quests-error,.quests-empty{text-align:center;padding:40px 20px;color:var(--color-text-secondary)}.quests-loading .loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.quests-error .error-icon{font-size:2rem;color:var(--color-danger);margin-bottom:16px}.quests-empty .empty-icon{font-size:3rem;color:var(--color-text-secondary);margin-bottom:16px}.quests-empty small{display:block;margin-top:8px;opacity:.7}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.quests-grid{grid-template-columns:1fr;gap:12px}.quest-card{padding:16px}.quest-header,.quest-footer{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 480px){.quest-section h3{font-size:1.1rem}.quest-title h4{font-size:1rem}.quest-description{font-size:.85rem}}.progress-visualizer{background:var(--color-surface);border-radius:var(--border-radius);padding:24px;margin-bottom:24px;box-shadow:0 4px 12px #0000001a}.level-progress-section{margin-bottom:32px}.level-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.level-title{font-size:1.5rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:8px}.level-stats{display:flex;gap:16px;font-size:.9rem}.xp-display,.streak-display{display:flex;align-items:center;gap:4px;color:var(--color-text-secondary);font-weight:500}.level-progress-bar{margin-bottom:16px}.progress-bar-container{position:relative;height:24px;background:var(--color-border);border-radius:12px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:12px;transition:width .8s cubic-bezier(.4,0,.2,1);position:relative}.progress-bar-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.8rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.progress-percentage{opacity:.8}.next-level-preview{background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:var(--border-radius);padding:16px;border:1px solid rgba(99,102,241,.2)}.preview-card h4{margin:0 0 12px;color:var(--color-primary);font-weight:600}.preview-card ul{margin:0;padding-left:20px;color:var(--color-text-secondary)}.preview-card li{margin-bottom:4px}.progress-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.progress-card{background:var(--color-surface);border-radius:var(--border-radius);padding:16px;border:1px solid var(--color-border);transition:transform .2s ease,box-shadow .2s ease}.progress-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.card-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-weight:600;color:var(--color-text)}.card-content{text-align:center}.progress-number,.streak-number,.rate-number{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:8px}.progress-bar-small{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill-small{height:100%;background:linear-gradient(90deg,var(--color-success),var(--color-primary));border-radius:4px;transition:width .6s ease}.completion-emoji,.streak-emoji{font-size:1.5rem;margin-bottom:8px}.streak-message,.rate-message{font-size:.8rem;color:var(--color-text-secondary);font-weight:500}.rate-bar{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden;margin-bottom:8px}.rate-fill{height:100%;background:linear-gradient(90deg,var(--color-warning),var(--color-success));border-radius:4px;transition:width .6s ease}.motivational-message{background:linear-gradient(135deg,#22c55e1a,#3b82f61a);border-radius:var(--border-radius);padding:16px;margin-bottom:24px;border:1px solid rgba(34,197,94,.2);animation:slideInUp .6s ease}.message-content{display:flex;align-items:center;gap:12px}.message-icon{color:var(--color-success);font-size:1.2rem}.social-proof{background:var(--color-surface);border-radius:var(--border-radius);padding:24px;margin-bottom:24px;box-shadow:0 4px 12px #0000001a}.fomo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}.active-friends{display:flex;align-items:center;gap:8px}.friends-icon{color:var(--color-primary);font-size:1.2rem}.active-count{font-weight:600;color:var(--color-text)}.fomo-message{font-size:.9rem;color:var(--color-warning);font-weight:500;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.notifications-toggle{position:relative;background:var(--color-primary);color:#fff;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease}.notifications-toggle:hover{transform:scale(1.1)}.notification-count{position:absolute;top:-5px;right:-5px;background:var(--color-error);color:#fff;border-radius:50%;width:20px;height:20px;font-size:.7rem;display:flex;align-items:center;justify-content:center;font-weight:600}.activity-feed{margin-bottom:24px}.feed-title{font-size:1.2rem;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{display:flex;align-items:center;gap:12px;padding:12px;background:#6366f10d;border-radius:var(--border-radius);border:1px solid rgba(99,102,241,.1);animation:slideInLeft .4s ease}.activity-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.activity-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem}.activity-content{flex:1}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.friend-name{font-weight:600;color:var(--color-text)}.activity-time{font-size:.8rem;color:var(--color-text-secondary)}.activity-message{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--color-text-secondary)}.action-icon{color:var(--color-primary)}.social-comparison{margin-bottom:24px}.comparison-title{font-size:1.2rem;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}.comparison-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.comparison-item{text-align:center;padding:16px;background:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border)}.stat-label{font-size:.8rem;color:var(--color-text-secondary);margin-bottom:8px}.stat-value{font-size:1.5rem;font-weight:700;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:4px}.streak-value{color:var(--color-warning)}.level-value{color:var(--color-primary)}.progress-value{color:var(--color-success)}.stat-comparison{font-size:.8rem;color:var(--color-text-secondary);font-weight:500}.motivational-section{background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:var(--border-radius);padding:20px;margin-bottom:24px;border:1px solid rgba(99,102,241,.2)}.motivational-title{font-size:1.1rem;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px;color:var(--color-primary)}.motivational-text{color:var(--color-text-secondary);margin-bottom:16px;line-height:1.5}.community-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.community-stat{text-align:center}.stat-number{display:block;font-size:1.5rem;font-weight:700;color:var(--color-primary)}.stat-label{font-size:.8rem;color:var(--color-text-secondary)}.social-cta{display:flex;gap:12px;justify-content:center}.cta-button{padding:12px 24px;border-radius:var(--border-radius);border:none;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:flex;align-items:center;gap:8px}.cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.cta-button.primary{background:var(--color-primary);color:#fff}.cta-button.secondary{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.habit-completion-feedback{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.particle-canvas{position:absolute;top:0;left:0;pointer-events:none;z-index:1}.completion-message{background:var(--color-surface);border-radius:var(--border-radius);padding:32px;text-align:center;max-width:400px;margin:0 auto;position:relative;z-index:2;animation:scaleIn .5s ease}.completion-icon{width:80px;height:80px;background:var(--color-success);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:2rem;color:#fff;animation:bounce 1s ease}.completion-title{font-size:1.5rem;font-weight:700;margin-bottom:8px;color:var(--color-text)}.habit-name{font-size:1.1rem;color:var(--color-primary);font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media (max-width: 768px){.progress-grid,.comparison-stats,.community-stats{grid-template-columns:1fr}.social-cta{flex-direction:column}.level-header{flex-direction:column;gap:12px;align-items:flex-start}.level-stats{width:100%;justify-content:space-between}}
