@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary-50:#ecfdf5;--color-primary-100:#d1fae5;--color-primary-200:#a7f3d0;--color-primary-300:#6ee7b7;--color-primary-400:#34d399;--color-primary-500:#10b981;--color-primary-600:#059669;--color-primary-700:#047857;--color-primary-800:#065f46;--color-primary-900:#064e3b;--color-accent-50:#f5f3ff;--color-accent-100:#ede9fe;--color-accent-200:#ddd6fe;--color-accent-300:#c4b5fd;--color-accent-400:#a78bfa;--color-accent-500:#8b5cf6;--color-accent-600:#7c3aed;--color-accent-700:#6d28d9;--color-gray-50:#f8fafc;--color-gray-100:#f1f5f9;--color-gray-200:#e2e8f0;--color-gray-300:#cbd5e1;--color-gray-400:#94a3b8;--color-gray-500:#64748b;--color-gray-600:#475569;--color-gray-700:#334155;--color-gray-800:#1e293b;--color-gray-900:#0f172a;--color-gray-950:#020617;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-info:#3b82f6;--bg-primary:#fff;--bg-secondary:var(--color-gray-50);--bg-tertiary:var(--color-gray-100);--surface-card:#fff;--surface-elevated:#fff;--surface-overlay:#00000080;--text-primary:var(--color-gray-900);--text-secondary:var(--color-gray-600);--text-tertiary:var(--color-gray-400);--text-inverse:#fff;--text-link:var(--color-primary-600);--border-color:var(--color-gray-200);--border-color-hover:var(--color-gray-300);--border-color-focus:var(--color-primary-500);--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Space Grotesk", "Inter", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--leading-tight:1.2;--leading-normal:1.5;--leading-relaxed:1.75;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--shadow-glow:0 0 20px #10b9814d;--shadow-glow-accent:0 0 20px #8b5cf64d;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-tooltip:1070;--z-toast:1090;--header-height:64px;--sidebar-width:280px;--max-content-width:1200px}[data-theme=dark]{--bg-primary:var(--color-gray-950);--bg-secondary:var(--color-gray-900);--bg-tertiary:var(--color-gray-800);--surface-card:var(--color-gray-900);--surface-elevated:var(--color-gray-800);--surface-overlay:#000000b3;--text-primary:var(--color-gray-50);--text-secondary:var(--color-gray-400);--text-tertiary:var(--color-gray-500);--text-link:var(--color-primary-400);--border-color:var(--color-gray-800);--border-color-hover:var(--color-gray-700);--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 6px -1px #0006;--shadow-lg:0 10px 15px -3px #0006;--shadow-xl:0 20px 25px -5px #00000080}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh;transition:background-color var(--transition-base), color var(--transition-base)}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--text-link);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-500)}img{max-width:100%;height:auto;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:var(--leading-tight);color:var(--text-primary);font-weight:700}h1{font-size:var(--text-5xl)}h2{font-size:var(--text-4xl)}h3{font-size:var(--text-3xl)}h4{font-size:var(--text-2xl)}h5{font-size:var(--text-xl)}h6{font-size:var(--text-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:.5s ease-out fadeIn}.animate-fade-in-up{animation:.6s ease-out fadeInUp}.animate-fade-in-down{animation:.6s ease-out fadeInDown}.animate-slide-in-right{animation:.5s ease-out slideInRight}.animate-scale-in{animation:.4s ease-out scaleIn}.animate-float{animation:3s ease-in-out infinite float}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-spin{animation:1s linear infinite spin}.stagger-1{animation-delay:.1s;animation-fill-mode:both}.stagger-2{animation-delay:.2s;animation-fill-mode:both}.stagger-3{animation-delay:.3s;animation-fill-mode:both}.stagger-4{animation-delay:.4s;animation-fill-mode:both}.stagger-5{animation-delay:.5s;animation-fill-mode:both}.glass{-webkit-backdrop-filter:blur(12px);background:#ffffff1a;border:1px solid #ffffff26}[data-theme=dark] .glass{background:#ffffff0d;border-color:#ffffff14}.gradient-text{background:linear-gradient(135deg, var(--color-primary-400), var(--color-accent-500));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.container{width:100%;max-width:var(--max-content-width);padding:0 var(--space-6);margin:0 auto}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--color-gray-700)}::selection{background:var(--color-primary-200);color:var(--color-primary-900)}[data-theme=dark] ::selection{background:var(--color-primary-800);color:var(--color-primary-100)}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.header{height:var(--header-height);padding:0 var(--space-6);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);z-index:var(--z-sticky);transition:all var(--transition-base);background:#ffffffd9;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}[data-theme=dark] .header{background:#020617d9}.header-logo{align-items:center;gap:var(--space-2);color:var(--text-primary);text-decoration:none;display:flex}.header-logo-icon{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--color-primary-500), var(--color-accent-500));color:#fff;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.header-logo-text{font-family:var(--font-display);font-size:var(--text-xl);letter-spacing:-.5px;font-weight:800}.header-nav{align-items:center;gap:var(--space-1);display:flex}.header-nav-link{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);font-weight:500;text-decoration:none}.header-nav-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}.header-nav-link.active{color:var(--color-primary-600);background:var(--color-primary-50)}[data-theme=dark] .header-nav-link.active{color:var(--color-primary-400);background:#10b9811a}.header-actions{align-items:center;gap:var(--space-3);display:flex}.header-user-menu{position:relative}.header-user-btn{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);transition:all var(--transition-fast);cursor:pointer;display:flex}.header-user-btn:hover{background:var(--bg-tertiary)}.header-user-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.header-mobile-toggle{border-radius:var(--radius-lg);width:40px;height:40px;color:var(--text-primary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:none}.header-mobile-toggle:hover{background:var(--bg-tertiary)}@media (width<=768px){.header-nav{display:none}.header-mobile-toggle{display:flex}.header-user-name{display:none}}.app-layout{padding-top:var(--header-height);min-height:100vh}.app-content{max-width:var(--max-content-width);padding:var(--space-8) var(--space-6);margin:0 auto}.page-header{margin-bottom:var(--space-8)}.page-header-top{justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-title{font-size:var(--text-3xl);font-weight:800;font-family:var(--font-display);letter-spacing:-.5px}.page-subtitle{color:var(--text-secondary);font-size:var(--text-base);margin-top:var(--space-2)}.dropdown-menu{background:var(--surface-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);min-width:200px;box-shadow:var(--shadow-xl);padding:var(--space-2);z-index:var(--z-dropdown);animation:.2s ease-out fadeInDown;position:absolute;top:calc(100% + 8px);right:0}.dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;text-align:left;width:100%;display:flex}.dropdown-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.dropdown-item-danger{color:var(--color-danger)}.dropdown-item-danger:hover{color:var(--color-danger);background:#ef44441a}.dropdown-divider{background:var(--border-color);height:1px;margin:var(--space-2) 0}.landing{overflow-x:hidden}.hero{min-height:calc(100vh - var(--header-height));padding:var(--space-16) var(--space-6);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero-bg{z-index:0;position:absolute;inset:0;overflow:hidden}.hero-bg:before{content:"";filter:blur(60px);background:radial-gradient(#10b98126,#0000 70%);width:80%;height:80%;animation:8s ease-in-out infinite float;position:absolute;top:-40%;right:-20%}.hero-bg:after{content:"";filter:blur(60px);background:radial-gradient(#8b5cf61f,#0000 70%);width:60%;height:60%;animation:10s ease-in-out infinite reverse float;position:absolute;bottom:-30%;left:-10%}.hero-grid{background-image:linear-gradient(#94a3b80d 1px,#0000 1px),linear-gradient(90deg,#94a3b80d 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(60% 60%,#000 40%,#0000 100%);mask-image:radial-gradient(60% 60%,#000 40%,#0000 100%)}.hero-content{z-index:1;text-align:center;max-width:800px;position:relative}.hero-badge{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-primary-600);margin-bottom:var(--space-8);background:#10b9811a;border:1px solid #10b98133;font-weight:500;animation:.6s ease-out fadeInDown;display:inline-flex}[data-theme=dark] .hero-badge{color:var(--color-primary-400)}.hero-badge-dot{background:var(--color-primary-500);border-radius:var(--radius-full);width:6px;height:6px;animation:2s ease-in-out infinite pulse}.hero-title{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;font-family:var(--font-display);letter-spacing:-2px;margin-bottom:var(--space-6);line-height:1.1;animation:.7s ease-out .1s both fadeInUp}.hero-description{color:var(--text-secondary);font-size:clamp(1rem,2vw,1.25rem);line-height:var(--leading-relaxed);max-width:600px;margin:0 auto var(--space-10);animation:.7s ease-out .2s both fadeInUp}.hero-cta{justify-content:center;align-items:center;gap:var(--space-4);flex-wrap:wrap;animation:.7s ease-out .3s both fadeInUp;display:flex}.hero-stats{justify-content:center;align-items:center;gap:var(--space-10);margin-top:var(--space-16);animation:.7s ease-out .5s both fadeInUp;display:flex}.hero-stat{text-align:center}.hero-stat-value{font-size:var(--text-3xl);font-weight:800;font-family:var(--font-display);background:linear-gradient(135deg, var(--color-primary-400), var(--color-accent-500));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-stat-label{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:var(--space-1)}.features{padding:var(--space-24) var(--space-6);background:var(--bg-secondary)}.features-header{text-align:center;max-width:600px;margin:0 auto var(--space-16)}.features-label{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:2px;color:var(--color-primary-500);margin-bottom:var(--space-4);font-weight:600}.features-title{font-size:var(--text-4xl);margin-bottom:var(--space-4);letter-spacing:-1px;font-weight:800}.features-subtitle{color:var(--text-secondary);font-size:var(--text-lg)}.features-grid{gap:var(--space-8);max-width:var(--max-content-width);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;display:grid}.feature-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--space-8);transition:all var(--transition-base);position:relative;overflow:hidden}.feature-card:before{content:"";background:linear-gradient(90deg, var(--color-primary-400), var(--color-accent-500));opacity:0;height:3px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.feature-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-xl);transform:translateY(-4px)}.feature-card:hover:before{opacity:1}[data-theme=dark] .feature-card:hover{border-color:var(--color-primary-700)}.feature-icon{border-radius:var(--radius-xl);width:52px;height:52px;margin-bottom:var(--space-5);justify-content:center;align-items:center;font-size:24px;display:flex}.feature-icon-green{color:var(--color-primary-500);background:#10b9811f}.feature-icon-violet{color:var(--color-accent-500);background:#8b5cf61f}.feature-icon-blue{color:var(--color-info);background:#3b82f61f}.feature-icon-amber{color:var(--color-warning);background:#f59e0b1f}.feature-icon-pink{color:#ec4899;background:#ec48991f}.feature-icon-teal{color:#14b8a6;background:#14b8a61f}.feature-title{font-size:var(--text-xl);margin-bottom:var(--space-3);font-weight:700;font-family:var(--font-display)}.feature-text{color:var(--text-secondary);line-height:var(--leading-relaxed);font-size:var(--text-sm)}.how-it-works{padding:var(--space-24) var(--space-6)}.how-it-works-header{text-align:center;max-width:600px;margin:0 auto var(--space-16)}.steps-container{gap:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));max-width:900px;margin:0 auto;display:grid}.step-card{text-align:center;padding:var(--space-6);position:relative}.step-number{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary-500), var(--color-accent-500));color:#fff;width:56px;height:56px;font-family:var(--font-display);font-weight:800;font-size:var(--text-xl);margin:0 auto var(--space-5);box-shadow:var(--shadow-glow);justify-content:center;align-items:center;display:flex}.step-title{font-size:var(--text-lg);margin-bottom:var(--space-2);font-weight:700;font-family:var(--font-display)}.step-text{color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.cta-section{padding:var(--space-24) var(--space-6);background:var(--bg-secondary)}.cta-card{text-align:center;max-width:800px;padding:var(--space-16) var(--space-8);background:linear-gradient(135deg, var(--color-gray-900), var(--color-gray-800));border-radius:var(--radius-2xl);margin:0 auto;position:relative;overflow:hidden}.cta-card:before{content:"";filter:blur(40px);background:radial-gradient(#10b98133,#0000 70%);width:60%;height:100%;position:absolute;top:-50%;right:-30%}.cta-card:after{content:"";filter:blur(40px);background:radial-gradient(#8b5cf626,#0000 70%);width:50%;height:100%;position:absolute;bottom:-50%;left:-20%}.cta-content{z-index:1;position:relative}.cta-title{font-size:var(--text-4xl);color:#fff;margin-bottom:var(--space-4);letter-spacing:-1px;font-weight:800}.cta-text{color:#ffffffb3;font-size:var(--text-lg);margin-bottom:var(--space-8);max-width:500px;margin-left:auto;margin-right:auto}.footer{padding:var(--space-8) var(--space-6);border-top:1px solid var(--border-color);text-align:center}.footer-content{max-width:var(--max-content-width);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;margin:0 auto;display:flex}.footer-text{color:var(--text-tertiary);font-size:var(--text-sm)}.footer-links{gap:var(--space-6);display:flex}.footer-link{color:var(--text-secondary);font-size:var(--text-sm);transition:color var(--transition-fast)}.footer-link:hover{color:var(--text-primary)}@media (width<=768px){.hero{padding:var(--space-8) var(--space-4)}.hero-stats{gap:var(--space-6);flex-wrap:wrap}.hero-cta{flex-direction:column}.features-grid,.steps-container{grid-template-columns:1fr}.cta-card{padding:var(--space-10) var(--space-6)}.cta-title{font-size:var(--text-3xl)}.footer-content{text-align:center;flex-direction:column}}.auth-page{min-height:calc(100vh - var(--header-height));padding:var(--space-8) var(--space-6);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";filter:blur(60px);background:radial-gradient(#10b9811a,#0000 70%);width:60%;height:60%;position:absolute;top:-30%;right:-20%}.auth-page:after{content:"";filter:blur(60px);background:radial-gradient(#8b5cf614,#0000 70%);width:40%;height:40%;position:absolute;bottom:-20%;left:-10%}.auth-card{z-index:1;background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);width:100%;max-width:420px;padding:var(--space-10);box-shadow:var(--shadow-xl);animation:.4s ease-out scaleIn;position:relative}.auth-logo{justify-content:center;align-items:center;gap:var(--space-2);margin-bottom:var(--space-8);color:var(--text-primary);text-decoration:none;display:flex}.auth-logo-icon{border-radius:var(--radius-xl);background:linear-gradient(135deg, var(--color-primary-500), var(--color-accent-500));color:#fff;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.auth-logo-text{font-family:var(--font-display);font-size:var(--text-2xl);letter-spacing:-.5px;font-weight:800}.auth-title{font-size:var(--text-2xl);text-align:center;margin-bottom:var(--space-2);font-weight:700}.auth-subtitle{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-8)}.auth-form{gap:var(--space-5);flex-direction:column;display:flex}.auth-form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm);color:var(--text-secondary)}.auth-footer a{color:var(--color-primary-600);font-weight:600}[data-theme=dark] .auth-footer a{color:var(--color-primary-400)}.auth-social{gap:var(--space-3);flex-direction:column;display:flex}.auth-social-btn{justify-content:center;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);font-weight:500;display:flex}.auth-social-btn:hover{background:var(--bg-tertiary);border-color:var(--border-color-hover)}.dashboard-stats{gap:var(--space-6);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.stat-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);align-items:flex-start;gap:var(--space-4);transition:all var(--transition-base);display:flex}.stat-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-md)}[data-theme=dark] .stat-card:hover{border-color:var(--color-primary-700)}.stat-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-icon-green{color:var(--color-primary-500);background:#10b9811f}.stat-icon-red{color:var(--color-danger);background:#ef44441f}.stat-icon-blue{color:var(--color-info);background:#3b82f61f}.stat-icon-violet{color:var(--color-accent-500);background:#8b5cf61f}.stat-info{flex:1;min-width:0}.stat-label{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1)}.stat-value{font-size:var(--text-2xl);font-weight:800;font-family:var(--font-display)}.stat-value-positive{color:var(--color-success)}.stat-value-negative{color:var(--color-danger)}.groups-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.group-card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);cursor:pointer;transition:all var(--transition-base);color:inherit;text-decoration:none;display:block}.group-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-lg);transform:translateY(-2px)}[data-theme=dark] .group-card:hover{border-color:var(--color-primary-700)}.group-card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.group-card-icon{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--color-primary-500), var(--color-accent-500));color:#fff;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.group-card-name{font-size:var(--text-lg);font-weight:700;font-family:var(--font-display);margin-bottom:var(--space-1)}.group-card-desc{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-4);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.group-card-footer{padding-top:var(--space-4);border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.group-card-members{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);display:flex}.group-card-balance{font-size:var(--text-sm);font-weight:600}.create-group-card{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-xl);padding:var(--space-8);justify-content:center;align-items:center;gap:var(--space-3);cursor:pointer;transition:all var(--transition-base);min-height:200px;color:var(--text-secondary);flex-direction:column;text-decoration:none;display:flex}.create-group-card:hover{border-color:var(--color-primary-400);color:var(--color-primary-600);background:var(--color-primary-50)}[data-theme=dark] .create-group-card:hover{color:var(--color-primary-400);background:#10b9810d}.create-group-icon{border-radius:var(--radius-full);border:2px dashed var(--border-color);width:56px;height:56px;transition:all var(--transition-base);justify-content:center;align-items:center;display:flex}.create-group-card:hover .create-group-icon{border-color:var(--color-primary-400)}.create-group-text{font-weight:600;font-size:var(--text-base)}.group-detail-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-8);flex-wrap:wrap;display:flex}.group-detail-info{flex:1}.group-detail-meta{align-items:center;gap:var(--space-4);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.group-detail-meta-item{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);display:flex}.group-detail-actions{gap:var(--space-3);display:flex}.tabs{gap:var(--space-1);border-bottom:1px solid var(--border-color);margin-bottom:var(--space-6);display:flex;overflow-x:auto}.tab{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-500)}[data-theme=dark] .tab.active{color:var(--color-primary-400)}.expense-list{gap:var(--space-3);flex-direction:column;display:flex}.expense-item{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast);display:flex}.expense-item:hover{border-color:var(--border-color-hover);box-shadow:var(--shadow-sm)}.expense-category-icon{border-radius:var(--radius-lg);background:var(--bg-tertiary);width:40px;height:40px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.expense-info{flex:1;min-width:0}.expense-description{font-weight:600;font-size:var(--text-base);margin-bottom:var(--space-1)}.expense-meta{font-size:var(--text-xs);color:var(--text-secondary)}.expense-amount{text-align:right;flex-shrink:0}.expense-amount-value{font-weight:700;font-size:var(--text-lg);font-family:var(--font-display)}.expense-amount-label{font-size:var(--text-xs);color:var(--text-secondary)}.balances-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.balance-card{align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex}.balance-arrow{color:var(--color-primary-500);flex-shrink:0}.balance-info{flex:1;min-width:0}.balance-names{font-size:var(--text-sm)}.balance-from{color:var(--color-danger);font-weight:600}.balance-to{color:var(--color-success);font-weight:600}.balance-amount{font-weight:800;font-size:var(--text-lg);font-family:var(--font-display);color:var(--text-primary);flex-shrink:0}.expense-form{gap:var(--space-5);flex-direction:column;max-width:500px;display:flex}.expense-form-split{gap:var(--space-3);flex-direction:column;display:flex}.split-option{align-items:center;gap:var(--space-3);padding:var(--space-4);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);display:flex}.split-option:hover{border-color:var(--border-color-hover)}.split-option.active{border-color:var(--color-primary-500);background:var(--color-primary-50)}[data-theme=dark] .split-option.active{background:#10b98114}.split-option-radio{border-radius:var(--radius-full);border:2px solid var(--border-color);width:20px;height:20px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.split-option.active .split-option-radio{border-color:var(--color-primary-500)}.split-option.active .split-option-radio:after{content:"";border-radius:var(--radius-full);background:var(--color-primary-500);width:10px;height:10px}.split-option-info{flex:1}.split-option-title{font-weight:600;font-size:var(--text-sm)}.split-option-desc{font-size:var(--text-xs);color:var(--text-secondary)}@media (width<=768px){.dashboard-stats{grid-template-columns:1fr 1fr}.groups-grid{grid-template-columns:1fr}.group-detail-header{flex-direction:column}.group-detail-actions{width:100%}.group-detail-actions .btn{flex:1}.auth-form-row{grid-template-columns:1fr}}.btn{justify-content:center;align-items:center;gap:var(--space-2);font-family:var(--font-sans);border-radius:var(--radius-lg);transition:all var(--transition-base);cursor:pointer;white-space:nowrap;border:none;outline:none;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(#fff3,#0000);position:absolute;inset:0}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);height:36px}.btn-md{padding:var(--space-3) var(--space-6);font-size:var(--text-base);height:44px}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-lg);height:52px}.btn-primary{background:linear-gradient(135deg, var(--color-primary-500), var(--color-primary-600));color:#fff;box-shadow:var(--shadow-md), 0 0 0 0 #10b98166}.btn-primary:hover{background:linear-gradient(135deg, var(--color-primary-400), var(--color-primary-500));box-shadow:var(--shadow-lg), 0 0 20px #10b9814d;transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color);border-color:var(--border-color-hover);transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background:linear-gradient(135deg, var(--color-danger), #dc2626);color:#fff}.btn-danger:hover{box-shadow:var(--shadow-lg), 0 0 20px #ef44444d;transform:translateY(-1px)}.btn-accent{background:linear-gradient(135deg, var(--color-accent-500), var(--color-accent-600));color:#fff;box-shadow:var(--shadow-md)}.btn-accent:hover{box-shadow:var(--shadow-lg), var(--shadow-glow-accent);transform:translateY(-1px)}.btn-outline{color:var(--color-primary-600);border:2px solid var(--color-primary-500);background:0 0}.btn-outline:hover{background:var(--color-primary-50)}[data-theme=dark] .btn-outline:hover{background:#10b9811a}.btn-full{width:100%}.btn-loading{pointer-events:none;opacity:.7}.btn-loading .btn-spinner{animation:.8s linear infinite spin}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn:disabled:after{display:none}.btn-icon{padding:var(--space-2);border-radius:var(--radius-lg);width:40px;height:40px}.input-wrapper{gap:var(--space-2);flex-direction:column;display:flex}.input-label{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.input-field-wrapper{align-items:center;display:flex;position:relative}.input-field{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base);font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-base);outline:none;height:44px}.input-field:hover{border-color:var(--border-color-hover)}.input-field:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #10b98126}.input-field::placeholder{color:var(--text-tertiary)}.input-field.input-error{border-color:var(--color-danger)}.input-field.input-error:focus{box-shadow:0 0 0 3px #ef444426}.input-icon-left{left:var(--space-3);color:var(--text-tertiary);pointer-events:none;position:absolute}.input-field.has-icon-left{padding-left:var(--space-10)}.input-icon-right{right:var(--space-3);color:var(--text-tertiary);cursor:pointer;position:absolute}.input-error-text{font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-1)}.input-hint{font-size:var(--text-xs);color:var(--text-tertiary)}.textarea-field{resize:vertical;height:auto;min-height:100px}.select-field{appearance:none;padding-right:var(--space-10);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px}.card{background:var(--surface-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-base)}.card-hover:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-lg);transform:translateY(-2px)}[data-theme=dark] .card-hover:hover{border-color:var(--color-primary-700)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-lg);font-weight:700;font-family:var(--font-display)}.card-body{color:var(--text-secondary)}.card-footer{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.card-glass{-webkit-backdrop-filter:blur(16px);background:#ffffff14;border:1px solid #ffffff1f}.modal-overlay{background:var(--surface-overlay);z-index:var(--z-modal-backdrop);padding:var(--space-4);justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface-elevated);border-radius:var(--radius-2xl);padding:var(--space-8);width:100%;max-width:480px;max-height:90vh;z-index:var(--z-modal);box-shadow:var(--shadow-xl);border:1px solid var(--border-color);animation:.3s ease-out scaleIn;overflow-y:auto}.modal-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-xl);font-weight:700;font-family:var(--font-display)}.modal-close{border-radius:var(--radius-lg);width:36px;height:36px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{margin-bottom:var(--space-6)}.modal-footer{gap:var(--space-3);justify-content:flex-end;display:flex}.avatar{border-radius:var(--radius-full);font-weight:700;font-family:var(--font-display);color:#fff;background:linear-gradient(135deg, var(--color-primary-400), var(--color-accent-500));flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-md{width:40px;height:40px;font-size:var(--text-sm)}.avatar-lg{width:48px;height:48px;font-size:var(--text-base)}.avatar-xl{width:64px;height:64px;font-size:var(--text-xl)}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-group{display:flex}.avatar-group .avatar{border:2px solid var(--bg-primary);margin-left:-8px}.avatar-group .avatar:first-child{margin-left:0}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);font-weight:600;display:inline-flex}.badge-success{background:var(--color-primary-100);color:var(--color-primary-800)}[data-theme=dark] .badge-success{color:var(--color-primary-400);background:#10b98126}.badge-danger{color:#991b1b;background:#fef2f2}[data-theme=dark] .badge-danger{color:#fca5a5;background:#ef444426}.badge-warning{color:#92400e;background:#fffbeb}[data-theme=dark] .badge-warning{color:#fbbf24;background:#f59e0b26}.badge-info{color:#1e40af;background:#eff6ff}[data-theme=dark] .badge-info{color:#93c5fd;background:#3b82f626}.spinner-wrapper{padding:var(--space-8);justify-content:center;align-items:center;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--color-primary-500);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.spinner-sm{border-width:2px;width:20px;height:20px}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{border-radius:var(--radius-2xl);background:var(--bg-tertiary);width:64px;height:64px;margin-bottom:var(--space-4);color:var(--text-tertiary);justify-content:center;align-items:center;display:flex}.empty-state-title{font-size:var(--text-lg);margin-bottom:var(--space-2);font-weight:600}.empty-state-text{color:var(--text-secondary);font-size:var(--text-sm);max-width:360px;margin-bottom:var(--space-6)}.divider{align-items:center;gap:var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm);display:flex}.divider:before,.divider:after{content:"";background:var(--border-color);flex:1;height:1px}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--border-color) 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-title{width:60%;height:24px;margin-bottom:var(--space-3)}.skeleton-avatar{border-radius:var(--radius-full);width:40px;height:40px}.toast-container{top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-sm);align-items:center;gap:var(--space-3);min-width:300px;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid;font-weight:500;animation:.3s ease-out slideInRight;display:flex}.toast-success{background:var(--color-primary-50);color:var(--color-primary-800);border-color:var(--color-primary-200)}.toast-error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.toast-info{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}[data-theme=dark] .toast-success{color:var(--color-primary-300);background:#10b9811f;border-color:#10b98140}[data-theme=dark] .toast-error{color:#fca5a5;background:#ef44441f;border-color:#ef444440}[data-theme=dark] .toast-info{color:#93c5fd;background:#3b82f61f;border-color:#3b82f640}
