@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");body,html{max-width:100%;overflow-x:hidden}:root{--ink:#111827;--ink2:#0f172a;--paper:#f8fafc;--surface:#fff;--border:#e5e7eb;--muted:#6b7280;--bg-primary:var(--paper);--bg-secondary:#f4f4f5;--surface-elevated:#fff;--text-primary:var(--ink);--text-secondary:var(--muted);--text-muted:#a1a1aa;--text-inverse:#fff;--border-light:var(--border);--border-default:#d4d4d8;--border-focus:var(--accent-purple);--accent-coral:#f97066;--accent-coral-hover:#f85849;--accent-coral-light:#fef2f2;--accent-purple:#8b5cf6;--accent-purple-hover:#7c3aed;--accent-purple-light:#f3e8ff;--accent-blue:#3b82f6;--accent-blue-hover:#2563eb;--accent-blue-light:#dbeafe;--accent-teal:#2dd4bf;--accent-teal-hover:#14b8a6;--accent-teal-light:#f0fdfa;--accent-yellow:#facc15;--accent-yellow-hover:#eab308;--accent-yellow-light:#fefce8;--accent-indigo:var(--accent-purple);--accent-indigo-hover:var(--accent-purple-hover);--accent-indigo-light:var(--accent-purple-light);--success:#22c55e;--success-light:#f0fdf4;--error:#ef4444;--error-light:#fef2f2;--warning:#f59e0b;--warning-light:#fffbeb;--hero-wash:linear-gradient(120deg,hsla(4,92%,69%,.16),rgba(139,92,246,.14),rgba(59,130,246,.14),rgba(45,212,191,.14));--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow-md:0 2px 8px rgba(0,0,0,.08);--shadow-lg:0 4px 16px rgba(0,0,0,.1);--sidebar-width:240px;--topbar-height:56px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{width:100%;max-width:800px;margin:0 auto;padding:2rem 1rem}.pageContainer{width:100%;max-width:100%;margin:0 auto;padding:16px;overflow-x:hidden}@media (min-width:768px){.pageContainer{padding:24px}}@media (min-width:1024px){.pageContainer{padding:32px}}#dashboardRoot{width:100%;max-width:100%}@media (min-width:1024px){#dashboardRoot{max-width:1400px;margin:0 auto}}.dashboard-layout{display:block;width:100%;max-width:100%;overflow-x:hidden}.dashboard-sidebar{width:100%}.dashboard-main{width:100%;min-width:0}@media (min-width:860px){.dashboard-layout{display:flex;gap:24px;align-items:flex-start}.dashboard-sidebar{width:320px;flex:0 0 320px;position:-webkit-sticky;position:sticky;top:16px}.dashboard-main{flex:1 1;min-width:0;width:auto}}.narrow-content{width:100%;max-width:680px;margin:0 auto}@media (min-width:768px){.narrow-content{max-width:720px}}@media (min-width:1024px){.narrow-content{max-width:760px}}.card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);margin-bottom:var(--space-md)}.form-group{margin-bottom:1rem}label{display:block;margin-bottom:var(--space-xs);font-weight:500;font-size:.875rem;color:var(--text-secondary)}input,select,textarea{width:100%;padding:var(--space-sm) .75rem;border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:1rem;background:var(--surface);color:var(--text-primary);transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-indigo);box-shadow:0 0 0 3px var(--accent-indigo-light)}button{padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .15s,transform .1s}button:active{transform:scale(.98)}.btn-primary{background-color:var(--accent-indigo);color:var(--text-inverse)}.btn-primary:hover{background-color:var(--accent-indigo-hover)}.btn-primary:disabled{background-color:var(--border-default);color:var(--text-muted);cursor:not-allowed}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-light)}.btn-secondary:hover{background-color:var(--border-light);color:var(--text-primary)}.btn-danger{background-color:var(--error);color:var(--text-inverse)}.btn-danger:hover{background-color:#dc2626}.btn-coral{background-color:var(--accent-coral);color:var(--text-inverse)}.btn-coral:hover{background-color:var(--accent-coral-hover)}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:6px}.error-message,.success-message{padding:.75rem;margin-bottom:1rem;font-size:.875rem}.success-message{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;border-radius:6px}.text-center{text-align:center}.text-muted{color:#6b7280;font-size:.875rem}a{color:#3b82f6;text-decoration:none}a:hover{text-decoration:underline}h1{font-size:1.5rem;margin-bottom:1.5rem}h1,h2{font-weight:600}h2{font-size:1.25rem;margin-bottom:1rem}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}@media (max-width:600px){.grid-2{grid-template-columns:1fr}}.person-card{border-left:4px solid #3b82f6}.birthday-soon{border-left-color:#f59e0b}.birthday-today{border-left-color:#10b981;background-color:#f0fdf4}.badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-warning{background-color:#fef3c7;color:#92400e}.badge-success{background-color:#dcfce7;color:#166534}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:#6b7280}@keyframes float-balloon{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}25%{transform:translateY(-30px) translateX(10px) rotate(5deg)}50%{transform:translateY(-15px) translateX(-10px) rotate(-3deg)}75%{transform:translateY(-40px) translateX(5px) rotate(3deg)}}@keyframes float-star{0%,to{transform:translateY(0) rotate(0deg) scale(1)}33%{transform:translateY(-20px) rotate(120deg) scale(1.1)}66%{transform:translateY(-10px) rotate(240deg) scale(.9)}}@keyframes float-confetti{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}25%{transform:translateY(-25px) translateX(15px) rotate(90deg)}50%{transform:translateY(-50px) translateX(-10px) rotate(180deg)}75%{transform:translateY(-25px) translateX(20px) rotate(270deg)}}@keyframes float-gift{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}@keyframes float-cake{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-15px) rotate(5deg)}}@keyframes pulse-glow{0%,to{opacity:.2;transform:scale(1)}50%{opacity:.4;transform:scale(1.1)}}@keyframes gradient-shift{0%,to{opacity:.5}50%{opacity:.3}}@media (prefers-reduced-motion:reduce){.floating-element,.glow-orb,.gradient-overlay,.mouse-glow{animation:none!important;transition:none!important}}.upload-overlay{opacity:0}:hover>.upload-overlay{opacity:1}.landing-page{min-height:100vh;position:relative;overflow-x:hidden;background:linear-gradient(135deg,#fefce8,#fff7ed 50%,#fef2f2)}.gradient-bg{background:radial-gradient(circle at 20% 20%,rgba(251,146,60,.08) 0,transparent 40%),radial-gradient(circle at 80% 80%,rgba(236,72,153,.06) 0,transparent 40%),radial-gradient(circle at 50% 50%,rgba(168,85,247,.04) 0,transparent 50%);z-index:0}.gradient-bg,.mouse-glow{position:fixed;inset:0;pointer-events:none}.mouse-glow{z-index:1;transition:background .3s ease}.landing-content{position:relative;z-index:10;max-width:1200px;margin:0 auto;padding:0 1.5rem}.landing-header{justify-content:space-between;padding:1.5rem 0}.landing-header,.logo{display:flex;align-items:center}.logo{gap:.75rem}.logo-icon{color:#f97316}.logo-text{font-size:1.25rem;font-weight:700;color:#1f2937}.landing-nav{display:flex;align-items:center;gap:1.5rem}.nav-link{color:#4b5563;font-weight:500;text-decoration:none;transition:color .2s}.nav-link:hover{color:#f97316;text-decoration:none}.nav-btn{background:#f97316;color:#fff;padding:.625rem 1.25rem;border-radius:8px;font-weight:600;text-decoration:none;transition:background .2s,transform .2s}.nav-btn:hover{background:#ea580c;transform:translateY(-1px);text-decoration:none}.hero-section{text-align:center;padding:4rem 0 3rem}.hero-badge{display:inline-block;background:rgba(251,146,60,.1);color:#ea580c;padding:.5rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:600;margin-bottom:1.5rem}.hero-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;line-height:1.1;color:#1f2937;margin-bottom:1.5rem}.gradient-text{background:linear-gradient(135deg,#f97316,#ec4899 50%,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;color:#6b7280;max-width:600px;margin:0 auto 2rem;line-height:1.7}.hero-cta{display:flex;flex-direction:column;align-items:center;gap:1rem}.cta-primary{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;padding:1rem 2rem;border-radius:12px;font-size:1.125rem;font-weight:600;text-decoration:none;box-shadow:0 4px 14px rgba(249,115,22,.4);transition:transform .2s,box-shadow .2s}.cta-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(249,115,22,.5);text-decoration:none}.cta-secondary{color:#6b7280;font-size:.875rem;text-decoration:none}.cta-secondary:hover{color:#f97316}.hero-stats{display:flex;justify-content:center;gap:2rem;margin-top:3rem;flex-wrap:wrap}.stat{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem}.stat-icon{color:#10b981}.features-section{padding:4rem 0}.section-title{text-align:center;font-size:1.75rem;font-weight:700;color:#1f2937;margin-bottom:3rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem}.feature-card{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 1px 3px rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.08)}.feature-icon{width:48px;height:48px;background:linear-gradient(135deg,rgba(251,146,60,.1),rgba(236,72,153,.1));border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:#f97316}.feature-icon svg{width:24px;height:24px}.feature-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.feature-description{color:#6b7280;font-size:.938rem;line-height:1.6}.cta-section{padding:3rem 0}.cta-card{background:linear-gradient(135deg,#1f2937,#374151);border-radius:24px;padding:3rem 2rem;text-align:center;color:#fff}.cta-card h2{font-size:1.75rem;font-weight:700;margin-bottom:.75rem}.cta-card p{color:#9ca3af;margin-bottom:1.5rem}.cta-card .cta-primary{background:#fff;color:#1f2937;box-shadow:none}.cta-card .cta-primary:hover{background:#f3f4f6}.landing-footer{text-align:center;padding:2rem 0;color:#9ca3af;font-size:.875rem}.floating-element{position:fixed;pointer-events:none;z-index:5;opacity:.6}.floating-icon{width:32px;height:32px}.floating-cake{color:#f97316;animation:float-cake 6s ease-in-out infinite}.floating-gift{color:#ec4899;animation:float-gift 5s ease-in-out infinite}.floating-star{color:#fbbf24;animation:float-star 7s ease-in-out infinite}.floating-heart{color:#ef4444;animation:float-balloon 8s ease-in-out infinite}.floating-balloon{color:#8b5cf6;animation:float-balloon 6s ease-in-out infinite}.loading-spinner{display:flex;justify-content:center;align-items:center;min-height:100vh}.spinner{width:40px;height:40px;border:3px solid #f3f4f6;border-top-color:#f97316;border-radius:50%;animation:spin .8s linear infinite}.spinner-small{width:16px;height:16px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.auth-page{overflow:hidden;background:linear-gradient(135deg,#fefce8,#fff7ed 50%,#fef2f2)}.auth-container,.auth-page{min-height:100vh;position:relative}.auth-container{z-index:10;display:grid;grid-template-columns:1fr 1fr}@media (max-width:900px){.auth-container{grid-template-columns:1fr}.auth-left{display:none}}.auth-left{display:flex;flex-direction:column;padding:2rem 3rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:#6b7280;text-decoration:none;font-size:.875rem;margin-bottom:3rem;transition:color .2s}.back-link:hover{color:#f97316;text-decoration:none}.auth-branding{flex:1 1;display:flex;flex-direction:column;justify-content:center}.auth-logo{color:#f97316;margin-bottom:1.5rem}.auth-title{font-size:2.5rem;font-weight:800;color:#1f2937;margin-bottom:1rem}.auth-subtitle{font-size:1.125rem;color:#6b7280;line-height:1.7;max-width:400px}.auth-features{margin-top:3rem;display:flex;flex-direction:column;gap:1rem}.auth-feature{display:flex;align-items:center;gap:.75rem;color:#4b5563;font-size:.938rem}.auth-feature svg{color:#10b981;flex-shrink:0}.auth-right{display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{background:#fff;border-radius:20px;padding:2.5rem;width:100%;max-width:420px;box-shadow:0 4px 24px rgba(0,0,0,.08)}.auth-card-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:1.5rem;text-align:center}.auth-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:8px}.auth-error,.auth-success{padding:.75rem 1rem;font-size:.875rem;margin-bottom:1rem}.auth-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;border-radius:8px}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-field label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-field input{width:100%;padding:.75rem 1rem;border:1px solid #e5e7eb;border-radius:10px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-field input:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 3px rgba(249,115,22,.1)}.auth-submit{width:100%;padding:.875rem;background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:transform .2s,box-shadow .2s}.auth-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(249,115,22,.4)}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-link{display:block;width:100%;background:none;border:none;color:#6b7280;font-size:.875rem;text-align:center;cursor:pointer;padding:.75rem 0;transition:color .2s}.auth-link:hover{color:#f97316}.auth-divider{display:flex;align-items:center;margin:1rem 0}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:#e5e7eb}.auth-divider span{padding:0 1rem;color:#9ca3af;font-size:.875rem}.auth-secondary-btn{display:block;width:100%;padding:.875rem;background:#f3f4f6;color:#374151;border:none;border-radius:10px;font-size:1rem;font-weight:600;text-align:center;text-decoration:none;transition:background .2s}.auth-secondary-btn:hover{background:#e5e7eb;text-decoration:none}.auth-description{color:#6b7280;font-size:.938rem;text-align:center;margin-bottom:1.5rem}@media (max-width:900px){.auth-right{padding:2rem 1rem}.auth-card{padding:2rem 1.5rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:2rem;overflow-y:auto}.modal-content{background:#fff;width:100%;border-radius:8px;padding:1.5rem}.app-shell{display:grid;grid-template-columns:1fr;grid-template-rows:var(--topbar-height) 1fr;min-height:100vh;background:var(--bg-primary)}.app-topbar{grid-column:1/-1;justify-content:space-between;padding:0 var(--space-lg);background:var(--surface);border-bottom:1px solid var(--border-light);height:var(--topbar-height);position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:var(--space-md)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.sidebar-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.topbar-right{display:flex;align-items:center;gap:var(--space-md)}.profile-menu-container{position:relative}.profile-button{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s}.profile-button:hover{background:var(--bg-secondary)}.profile-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--accent-indigo);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.profile-email{font-size:.875rem;color:var(--text-secondary);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:160px;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-xs);z-index:200}.profile-dropdown button{width:100%;text-align:left;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:background .15s,color .15s}.profile-dropdown button:hover{background:var(--bg-secondary);color:var(--text-primary)}.app-sidebar{grid-row:2;background:var(--surface);border-right:1px solid var(--border-light);padding:var(--space-md);display:flex;flex-direction:column;transition:width .2s;overflow:hidden}.app-sidebar.collapsed{width:64px;padding:var(--space-sm)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-xs);flex:1 1}.nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.nav-item:hover{background:var(--bg-secondary);color:var(--text-primary);text-decoration:none}.nav-item.active{background:var(--accent-indigo-light);color:var(--accent-indigo)}.nav-item.disabled{opacity:.5;cursor:not-allowed}.nav-item.disabled:hover{background:transparent;color:var(--text-secondary)}.nav-icon{font-size:1.1rem;width:24px;text-align:center}.nav-icon-svg{flex-shrink:0}.nav-label{white-space:nowrap}.sidebar-footer{padding-top:var(--space-md);border-top:1px solid var(--border-light);display:flex;justify-content:center;opacity:.3}.app-main{grid-row:2;padding:var(--space-xl);overflow-y:auto;max-height:calc(100vh - var(--topbar-height))}.overlay-close{position:fixed;inset:0;z-index:50}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center}.empty-state-icon{margin-bottom:var(--space-lg);opacity:.4}.empty-state-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.empty-state-description{color:var(--text-muted);font-size:.9rem;max-width:320px;margin-bottom:var(--space-lg)}.empty-state-action{margin-top:var(--space-sm)}.dashboardShell{width:100%;max-width:1400px;margin:0 auto;padding:0 24px}.dashboardLayout{display:block}@media (min-width:900px){.dashboardLayout{display:grid;grid-template-columns:340px 1fr;grid-gap:24px;gap:24px;align-items:start}.dashboardMain{min-width:0}}.page-header{display:flex;align-items:baseline;gap:var(--space-md)}.page-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.dashboard-content{width:100%;margin:0 auto;padding:16px}@media (min-width:768px){.dashboard-content{max-width:900px;padding:24px}}@media (min-width:1024px){.dashboard-content{max-width:1200px;padding:32px}}@media (min-width:1440px){.dashboard-content{max-width:1320px}}.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;opacity:1;transition:opacity .2s}.nav-drawer{position:fixed;top:0;left:0;bottom:0;width:280px;background:var(--surface);z-index:600;transform:translateX(-100%);transition:transform .25s ease-out;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.nav-drawer.open{transform:translateX(0)}.drawer-header{justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-light);min-height:var(--topbar-height)}.drawer-close,.drawer-header{display:flex;align-items:center}.drawer-close{justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.drawer-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.drawer-nav{flex:1 1;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.drawer-nav-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--text-secondary);background:transparent;border:none;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s;text-align:left;width:100%}.drawer-nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.drawer-nav-item.active{background:var(--accent-indigo-light);color:var(--accent-indigo)}.drawer-footer{padding:var(--space-md);border-top:1px solid var(--border-light)}.drawer-footer .logout-item{color:var(--error)}.drawer-footer .logout-item:hover{background:var(--error-light)}.drawer-brand{display:flex;justify-content:center;padding-top:var(--space-md);opacity:.3}.profile-dropdown a.dropdown-item{display:block;padding:var(--space-sm) var(--space-md);color:var(--text-secondary);text-decoration:none;font-size:.875rem;border-radius:var(--radius-sm);transition:background .15s,color .15s}.profile-dropdown a.dropdown-item:hover{background:var(--bg-secondary);color:var(--text-primary)}@media (max-width:768px){.app-sidebar,.profile-email{display:none}}.logged-out-layout{min-height:100vh;position:relative;overflow-x:hidden;background:var(--paper)}.hero-wash-bg{position:fixed;inset:0;background:var(--hero-wash);pointer-events:none;z-index:0}.logged-out-header{position:relative;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;max-width:1200px;margin:0 auto}.logo-link{text-decoration:none}.logged-out-nav{display:flex;align-items:center;gap:1.5rem}.nav-btn-primary{background:var(--accent-coral);color:#fff;padding:.625rem 1.25rem;border-radius:var(--radius-md);font-weight:600;text-decoration:none;transition:background .2s,transform .2s}.nav-btn-primary:hover{background:var(--accent-coral-hover);transform:translateY(-1px);text-decoration:none}.logged-out-main{position:relative;z-index:10;max-width:1200px;margin:0 auto;padding:0 2rem}.floating-shape{position:fixed;border-radius:50%;background:var(--shape-color);opacity:.15;filter:blur(1px);pointer-events:none;z-index:1;animation:floatShape 8s ease-in-out infinite}@keyframes floatShape{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(10deg)}}.recassion-hero{text-align:center;padding:4rem 0 3rem}.recassion-hero-badge{display:inline-block;background:rgba(139,92,246,.1);color:var(--accent-purple);padding:.5rem 1rem;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;margin-bottom:1.5rem}.recassion-hero-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;line-height:1.1;color:var(--ink);margin-bottom:1.5rem}.recassion-gradient-text{background:linear-gradient(135deg,var(--accent-coral) 0,var(--accent-purple) 50%,var(--accent-blue) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.recassion-hero-subtitle{font-size:1.2rem;color:var(--muted);max-width:600px;margin:0 auto 2rem;line-height:1.6}.recassion-hero-cta{display:flex;flex-direction:column;align-items:center;gap:1rem}.recassion-cta-primary{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent-coral);color:#fff;padding:.875rem 2rem;border-radius:var(--radius-md);font-weight:600;font-size:1.1rem;text-decoration:none;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 14px hsla(4,92%,69%,.3)}.recassion-cta-primary:hover{background:var(--accent-coral-hover);transform:translateY(-2px);box-shadow:0 6px 20px hsla(4,92%,69%,.4);text-decoration:none}.recassion-cta-secondary{color:var(--muted);font-weight:500;text-decoration:none;transition:color .2s}.recassion-cta-secondary:hover{color:var(--accent-purple);text-decoration:none}.recassion-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem;padding:3rem 0}.recassion-feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:transform .2s,box-shadow .2s}.recassion-feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.recassion-feature-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.recassion-feature-icon.coral{background:var(--accent-coral-light);color:var(--accent-coral)}.recassion-feature-icon.purple{background:var(--accent-purple-light);color:var(--accent-purple)}.recassion-feature-icon.blue{background:var(--accent-blue-light);color:var(--accent-blue)}.recassion-feature-icon.teal{background:var(--accent-teal-light);color:var(--accent-teal)}.recassion-feature-title{font-size:1.1rem;font-weight:600;color:var(--ink);margin-bottom:.5rem}.recassion-feature-description{font-size:.95rem;color:var(--muted);line-height:1.5}.recassion-auth-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 120px);padding:2rem 0}.recassion-auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.recassion-auth-header{text-align:center;margin-bottom:2rem}.recassion-auth-mark{margin-bottom:1rem}.recassion-auth-title{font-size:1.5rem;font-weight:700;color:var(--ink);margin-bottom:.5rem}.recassion-auth-subtitle{font-size:.95rem;color:var(--muted)}.recassion-auth-form{display:flex;flex-direction:column;gap:1rem}.recassion-input-group{display:flex;flex-direction:column;gap:.375rem}.recassion-input-label{font-size:.875rem;font-weight:500;color:var(--ink)}.recassion-input{padding:.75rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:1rem;transition:border-color .2s,box-shadow .2s}.recassion-input:focus{outline:none;border-color:var(--accent-purple);box-shadow:0 0 0 3px rgba(139,92,246,.1)}.recassion-btn-primary{background:var(--accent-coral);color:#fff;padding:.875rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,transform .2s}.recassion-btn-primary:hover:not(:disabled){background:var(--accent-coral-hover);transform:translateY(-1px)}.recassion-btn-primary:disabled{opacity:.6;cursor:not-allowed}.recassion-auth-footer{text-align:center;margin-top:1.5rem;font-size:.9rem;color:var(--muted)}.recassion-auth-footer a{color:var(--accent-purple);font-weight:500;text-decoration:none}.recassion-auth-footer a:hover{text-decoration:underline}.recassion-error{background:var(--error-light);color:var(--error)}.recassion-error,.recassion-success{padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.9rem;text-align:center}.recassion-success{background:var(--success-light);color:var(--success)}.recassion-link-btn{background:none;border:none;color:var(--accent-purple);font-size:.875rem;font-weight:500;cursor:pointer;padding:0;text-decoration:none}.recassion-link-btn:hover{text-decoration:underline}.recassion-back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.9rem;text-decoration:none;margin-bottom:1rem;transition:color .2s}.recassion-back-link:hover{color:var(--accent-purple)}.recassion-stats{display:flex;justify-content:center;gap:2rem;margin-top:2rem;flex-wrap:wrap}.recassion-stat{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.9rem}.recassion-stat-icon{color:var(--accent-teal)}@media (max-width:640px){.logged-out-header{padding:1rem}.logged-out-main{padding:0 1rem}.recassion-auth-card{padding:1.5rem;margin:0 1rem}}