@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{background-color:var(--bg-app);color:var(--ink);min-height:100vh;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}ul,ol{list-style:none}img{max-width:100%;display:block}:root{--brand:#6d28d9;--brand-hover:#5b21b6;--brand-soft:#f1eafe;--brand-ring:#6d28d940;--bg-app:#f6f3fb;--bg-surface:#fff;--bg-glass:#ffffffc7;--bg-glass-strong:#ffffffeb;--bg-hover:#6d28d90f;--bg-active:#6d28d9;--bg-muted:#f8f7fc;--bg-input:#ffffffb3;--ink:#0f172a;--ink-secondary:#64748b;--ink-muted:#94a3b8;--ink-inverse:#fff;--border:#e7e2f3;--border-neutral:#e2e8f0;--border-focus:var(--brand);--success:#10b981;--success-soft:#d1fae5;--warning:#f59e0b;--warning-soft:#fef3c7;--danger:#f43f5e;--danger-soft:#ffe4e6;--info:#3b82f6;--info-soft:#dbeafe;--shadow-xs:0 1px 2px #0f172a0a;--shadow-sm:0 8px 24px #0f172a0f;--shadow-md:0 12px 36px #0f172a14;--shadow-lg:0 20px 60px #0f172a1a;--shadow-brand:0 8px 24px #6d28d92e;--radius-sm:12px;--radius-md:16px;--radius-lg:20px;--radius-xl:24px;--radius-full:9999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--text-xs:.6875rem;--text-sm:.8125rem;--text-base:.875rem;--text-md:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.5rem;--text-5xl:3.5rem;--tracking-tight:-.02em;--tracking-wide:.02em;--tracking-overline:.18em;--sidebar-width:260px;--header-height:64px;--max-width:1200px;--input-height:44px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--dur-fast:.15s;--dur-base:.25s;--dur-slow:.4s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes blobPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.75;transform:scale(1.05)}}.animate-fade-in{animation:fadeIn var(--dur-base) var(--ease-out) both}.animate-fade-in-up{animation:fadeInUp var(--dur-base) var(--ease-out) both}.animate-fade-in-down{animation:fadeInDown var(--dur-base) var(--ease-out) both}.animate-scale-in{animation:scaleIn var(--dur-base) var(--ease-spring) both}.animate-slide-in{animation:slideInRight var(--dur-base) var(--ease-out) both}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--ink-muted)}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overline{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-overline);color:var(--ink-secondary);font-weight:600}.mono{font-family:ui-monospace,SF Mono,Cascadia Code,monospace}.bg-blobs{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.bg-blobs:before,.bg-blobs:after{content:"";border-radius:50%;animation:12s ease-in-out infinite blobPulse;position:absolute}.bg-blobs:before{filter:blur(64px);background:radial-gradient(circle,#6d28d924 0%,#0000 70%);width:500px;height:500px;top:-120px;left:-120px}.bg-blobs:after{filter:blur(48px);background:radial-gradient(circle,#f1eafecc 0%,#0000 70%);width:400px;height:400px;animation-delay:4s;top:-60px;right:-80px}#root{z-index:1;min-height:100vh;position:relative}.btn{justify-content:center;align-items:center;gap:var(--space-2);height:var(--input-height);padding:0 var(--space-5);border-radius:var(--radius-md);font-weight:500;font-size:var(--text-base);transition:all var(--dur-fast) var(--ease-out);white-space:nowrap;display:inline-flex;position:relative}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--brand);color:var(--ink-inverse);box-shadow:var(--shadow-brand)}.btn-primary:hover:not(:disabled){background:var(--brand-hover);transform:translateY(-1px);box-shadow:0 12px 28px #6d28d93d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg-surface);color:var(--ink);border:1px solid var(--border);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--bg-muted);border-color:var(--border-neutral)}.btn-danger{background:var(--danger);color:var(--ink-inverse)}.btn-danger:hover:not(:disabled){background:#e11d48;transform:translateY(-1px)}.btn-ghost{color:var(--ink-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--brand)}.btn-sm{height:34px;padding:0 var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-sm)}.btn-lg{height:52px;padding:0 var(--space-8);font-size:var(--text-md);border-radius:var(--radius-lg)}.btn-icon{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--ink-secondary);padding:0}.btn-icon:hover{background:var(--bg-hover);color:var(--brand)}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.input-label{font-size:var(--text-sm);color:var(--ink-secondary);font-weight:500}.input{width:100%;height:var(--input-height);padding:0 var(--space-4);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--ink);font-size:var(--text-base);transition:all var(--dur-fast) var(--ease-out)}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ring);background:var(--bg-surface)}.input::placeholder{color:var(--ink-muted)}.input-error{border-color:var(--danger)!important}.input-error-message{font-size:var(--text-xs);color:var(--danger)}.select{width:100%;height:var(--input-height);padding:0 var(--space-4);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--ink);font-size:var(--text-base);transition:all var(--dur-fast) var(--ease-out);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-ring)}.card{background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--dur-fast) var(--ease-out)}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-md);color:var(--ink);letter-spacing:var(--tracking-tight);font-weight:600}.card-subtitle{font-size:var(--text-sm);color:var(--ink-secondary)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;padding:var(--space-4);animation:fadeIn var(--dur-fast) both;background:#0f172a4d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:480px;max-height:90vh;box-shadow:var(--shadow-lg);animation:scaleIn var(--dur-base) var(--ease-spring) both;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);letter-spacing:var(--tracking-tight);font-weight:700}.modal-close{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--ink-muted);transition:all var(--dur-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-muted);color:var(--ink)}.modal-body{gap:var(--space-4);flex-direction:column;display:flex}.modal-footer{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--border);display:flex}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);align-items:center;gap:4px;padding:3px 10px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-soft);color:#065f46}.badge-danger{background:var(--danger-soft);color:#9f1239}.badge-warning{background:var(--warning-soft);color:#92400e}.badge-info{background:var(--info-soft);color:#1e40af}.badge-brand{background:var(--brand-soft);color:var(--brand)}.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{width:56px;height:56px;color:var(--ink-muted);margin-bottom:var(--space-4);opacity:.4}.empty-state-title{font-size:var(--text-lg);color:var(--ink-secondary);margin-bottom:var(--space-2);font-weight:600}.empty-state-text{font-size:var(--text-base);color:var(--ink-muted);max-width:340px;margin-bottom:var(--space-6)}.spinner{border:2.5px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}.spinner-lg{border-width:3px;width:36px;height:36px}.loading-screen{justify-content:center;align-items:center;gap:var(--space-4);background:var(--bg-app);flex-direction:column;min-height:100vh;display:flex}.loading-screen-text{color:var(--ink-secondary);font-size:var(--text-base)}.skeleton{background:linear-gradient(90deg, var(--bg-muted) 25%, var(--border) 50%, var(--bg-muted) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.sidebar{width:var(--sidebar-width);background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-right:1px solid var(--border);z-index:100;height:100vh;transition:transform var(--dur-base) var(--ease-out);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-header{padding:var(--space-6);border-bottom:1px solid var(--border)}.sidebar-logo{align-items:center;gap:var(--space-3);display:flex}.sidebar-logo-icon{background:linear-gradient(135deg, var(--brand), #8b5cf6);border-radius:var(--radius-sm);color:#fff;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;font-weight:800;display:flex;box-shadow:0 4px 12px #6d28d940}.sidebar-logo-text{font-size:var(--text-lg);color:var(--ink);letter-spacing:var(--tracking-tight);font-weight:700}.sidebar-logo-text span{color:var(--brand)}.sidebar-nav{padding:var(--space-4);flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-link{align-items:center;gap:var(--space-3);padding:10px var(--space-4);border-radius:var(--radius-sm);color:var(--ink-secondary);font-size:var(--text-base);transition:all var(--dur-fast) var(--ease-out);font-weight:500;display:flex}.sidebar-link:hover{background:var(--brand-soft);color:var(--brand)}.sidebar-link.active{background:var(--brand);color:var(--ink-inverse);box-shadow:var(--shadow-brand)}.sidebar-link.active svg{color:var(--ink-inverse)}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border)}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--dur-fast);display:flex}.sidebar-user:hover{background:var(--bg-muted)}.sidebar-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--brand), #8b5cf6);width:36px;height:36px;font-weight:700;font-size:var(--text-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--text-sm);color:var(--ink);font-weight:600}.sidebar-user-email{font-size:var(--text-xs);color:var(--ink-muted)}.sidebar-mobile-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;animation:fadeIn var(--dur-fast);background:#0f172a40;position:fixed;inset:0}.sidebar-toggle{top:var(--space-4);left:var(--space-4);z-index:101;background:var(--bg-glass-strong);border:1px solid var(--border);border-radius:var(--radius-sm);width:42px;height:42px;color:var(--ink);box-shadow:var(--shadow-sm);display:none;position:fixed}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-toggle{justify-content:center;align-items:center;display:flex}}.app-shell{min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.app-content{padding:var(--space-8);max-width:var(--max-width);margin:0 auto}@media (width<=768px){.app-main{margin-left:0}.app-content{padding:var(--space-4);padding-top:72px}}.page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-title{font-size:var(--text-2xl);letter-spacing:var(--tracking-tight);color:var(--ink);font-weight:700}.page-subtitle{font-size:var(--text-base);color:var(--ink-secondary);margin-top:2px}.page-actions{gap:var(--space-3);display:flex}.table-container{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--text-xs);color:var(--ink-muted);text-transform:uppercase;letter-spacing:var(--tracking-overline);border-bottom:1px solid var(--border);background:var(--bg-muted);font-weight:600}.table td{padding:var(--space-3) var(--space-4);font-size:var(--text-base);border-bottom:1px solid var(--border);color:var(--ink)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--bg-hover)}.search-bar{position:relative}.search-bar-icon{color:var(--ink-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-bar .input{padding-left:42px}.confirm-dialog{text-align:center}.confirm-dialog-icon{width:48px;height:48px;margin:0 auto var(--space-4);color:var(--warning)}.confirm-dialog-title{font-size:var(--text-lg);margin-bottom:var(--space-2);letter-spacing:var(--tracking-tight);font-weight:700}.confirm-dialog-text{font-size:var(--text-base);color:var(--ink-secondary);margin-bottom:var(--space-6)}.confirm-dialog-actions{gap:var(--space-3);justify-content:center;display:flex}.stat-card{padding:var(--space-6)}.stat-label{font-size:var(--text-xs);color:var(--ink-muted);text-transform:uppercase;letter-spacing:var(--tracking-overline);margin-bottom:var(--space-3);align-items:center;gap:var(--space-2);font-weight:600;display:flex}.stat-value{font-size:var(--text-3xl);letter-spacing:var(--tracking-tight);color:var(--ink);font-weight:800;line-height:1.1}.stat-value.positive{color:var(--success)}.stat-value.negative{color:var(--danger)}.stat-change{font-size:var(--text-xs);margin-top:var(--space-3);border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-weight:600;display:inline-flex}.stat-change.up{color:#065f46;background:var(--success-soft)}.stat-change.down{color:#9f1239;background:var(--danger-soft)}.toast-container{bottom:var(--space-6);right:var(--space-6);z-index:2000;gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:var(--text-base);animation:fadeInUp var(--dur-base) both;min-width:280px;display:flex}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.grid-2{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.tabs{background:var(--bg-muted);border-radius:var(--radius-md);margin-bottom:var(--space-6);border:1px solid var(--border);gap:2px;padding:3px;display:flex}.tab{padding:var(--space-2) var(--space-4);font-size:var(--text-base);color:var(--ink-secondary);border-radius:var(--radius-sm);transition:all var(--dur-fast);text-align:center;flex:1;font-weight:500}.tab:hover{color:var(--ink)}.tab.active{background:var(--bg-surface);color:var(--brand);box-shadow:var(--shadow-xs);font-weight:600}.landing{background:var(--bg-app);min-height:100vh;position:relative;overflow-x:hidden}.landing-nav{padding:var(--space-4) var(--space-8);justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.landing-nav-logo{align-items:center;gap:var(--space-3);font-size:var(--text-xl);color:var(--ink);letter-spacing:var(--tracking-tight);font-weight:700;display:flex}.landing-nav-logo span{color:var(--brand)}.landing-nav-actions{gap:var(--space-3);display:flex}.landing-hero{text-align:center;padding:var(--space-16) var(--space-8);max-width:800px;margin:0 auto;position:relative}.landing-badge{align-items:center;gap:var(--space-2);background:var(--brand-soft);color:var(--brand);border-radius:var(--radius-full);font-size:var(--text-xs);margin-bottom:var(--space-6);animation:fadeInDown var(--dur-base) both;padding:6px 18px;font-weight:600;display:inline-flex}.landing-hero h1{letter-spacing:-.03em;margin-bottom:var(--space-6);color:var(--ink);animation:fadeInUp var(--dur-base) .1s both;font-size:clamp(2.5rem,6vw,3.75rem);font-weight:800;line-height:1.08}.landing-hero h1 .gradient-text{background:linear-gradient(135deg, var(--brand), #8b5cf6, #a855f7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-hero p{font-size:var(--text-lg);color:var(--ink-secondary);max-width:520px;margin:0 auto var(--space-8);animation:fadeInUp var(--dur-base) .2s both;line-height:1.7}.landing-hero-actions{gap:var(--space-4);animation:fadeInUp var(--dur-base) .3s both;justify-content:center;display:flex}.landing-features{padding:var(--space-16) var(--space-8);max-width:1200px;margin:0 auto}.landing-features-title{text-align:center;font-size:var(--text-2xl);margin-bottom:var(--space-12);color:var(--ink);letter-spacing:var(--tracking-tight);font-weight:700}.landing-features-grid{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.landing-feature-card{padding:var(--space-8);background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--dur-base) var(--ease-out);box-shadow:var(--shadow-xs)}.landing-feature-card:hover{border-color:var(--brand-soft);box-shadow:var(--shadow-md);transform:translateY(-4px)}.landing-feature-icon{border-radius:var(--radius-sm);width:48px;height:48px;margin-bottom:var(--space-4);justify-content:center;align-items:center;font-size:22px;display:flex}.landing-feature-card h3{font-size:var(--text-md);margin-bottom:var(--space-2);color:var(--ink);font-weight:600}.landing-feature-card p{font-size:var(--text-base);color:var(--ink-secondary);line-height:1.6}.landing-footer{text-align:center;padding:var(--space-8);border-top:1px solid var(--border);color:var(--ink-muted);font-size:var(--text-sm)}@media (width<=768px){.landing-features-grid{grid-template-columns:1fr}.landing-hero-actions{flex-direction:column;align-items:center}}.auth-page{min-height:100vh;padding:var(--space-8);background:var(--bg-app);justify-content:center;align-items:center;display:flex;position:relative}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:var(--space-10);box-shadow:var(--shadow-lg);animation:scaleIn var(--dur-base) var(--ease-spring) both}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{justify-content:center;align-items:center;gap:var(--space-3);font-size:var(--text-xl);margin-bottom:var(--space-5);color:var(--ink);font-weight:700;display:flex}.auth-logo span{color:var(--brand)}.auth-title{font-size:var(--text-2xl);margin-bottom:var(--space-1);color:var(--ink);letter-spacing:var(--tracking-tight);font-weight:700}.auth-subtitle{color:var(--ink-secondary);font-size:var(--text-base)}.auth-form{gap:var(--space-4);flex-direction:column;display:flex}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-base);color:var(--ink-secondary)}.auth-footer a{color:var(--brand);font-weight:600}.auth-footer a:hover{color:var(--brand-hover)}.auth-error{padding:var(--space-3) var(--space-4);background:var(--danger-soft);color:#9f1239;border-radius:var(--radius-sm);font-size:var(--text-sm);text-align:center;font-weight:500}.auth-success{padding:var(--space-3) var(--space-4);background:var(--success-soft);color:#065f46;border-radius:var(--radius-sm);font-size:var(--text-sm);text-align:center;font-weight:500}.dashboard-stats{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(3,1fr);display:grid}.dashboard-charts{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:2fr 1fr;display:grid}.dashboard-chart-card{background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.chart-title{font-size:var(--text-md);margin-bottom:var(--space-4);color:var(--ink);font-weight:600}.recent-list{flex-direction:column;display:flex}.recent-item{padding:var(--space-3) 0;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.recent-item:last-child{border-bottom:none}.recent-item-left{align-items:center;gap:var(--space-3);display:flex}.recent-item-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;display:flex}.recent-item-info h4{font-size:var(--text-base);color:var(--ink);font-weight:500}.recent-item-info p{font-size:var(--text-xs);color:var(--ink-muted)}.recent-item-amount{font-weight:700;font-size:var(--text-base)}@media (width<=1024px){.dashboard-stats,.dashboard-charts{grid-template-columns:1fr}}.transactions-toolbar{gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.transactions-toolbar .search-bar{flex:1;min-width:200px}.tx-type{font-weight:600;font-size:var(--text-xs);align-items:center;gap:4px;display:inline-flex}.tx-type.income{color:var(--success)}.tx-type.expense{color:var(--danger)}.tx-amount{font-variant-numeric:tabular-nums;font-weight:700}.tx-actions{gap:4px;display:flex}.categories-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.category-card{padding:var(--space-8) var(--space-4);background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;transition:all var(--dur-fast) var(--ease-out);box-shadow:var(--shadow-xs);flex-direction:column;align-items:center;display:flex;position:relative}.category-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.category-card-icon{border-radius:var(--radius-md);width:56px;height:56px;margin-bottom:var(--space-3);justify-content:center;align-items:center;font-size:28px;display:flex}.category-card-name{font-weight:600;font-size:var(--text-base);margin-bottom:var(--space-1);color:var(--ink)}.category-card-count{font-size:var(--text-xs);color:var(--ink-muted)}.category-card-actions{top:var(--space-2);right:var(--space-2);opacity:0;transition:opacity var(--dur-fast);gap:2px;display:flex;position:absolute}.category-card:hover .category-card-actions{opacity:1}.category-add-card{padding:var(--space-8);border:2px dashed var(--border);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--dur-fast);color:var(--ink-muted);justify-content:center;align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.category-add-card:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}.agenda-layout{gap:var(--space-6);flex-direction:column;display:flex}.agenda-month-nav{justify-content:center;align-items:center;gap:var(--space-4);display:flex}.agenda-month-label{font-size:var(--text-xl);text-align:center;min-width:200px;color:var(--ink);letter-spacing:var(--tracking-tight);font-weight:700}.agenda-calendar{background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.agenda-cal-header{padding:var(--space-3);text-align:center;font-size:var(--text-xs);color:var(--ink-muted);text-transform:uppercase;letter-spacing:var(--tracking-overline);background:var(--bg-muted);font-weight:600}.agenda-cal-day{min-height:80px;padding:var(--space-1);background:var(--bg-surface);cursor:pointer;transition:all var(--dur-fast);border:1px solid #0000}.agenda-cal-day:hover{background:var(--brand-soft)}.agenda-cal-day.other-month{opacity:.3}.agenda-cal-day.today{border-color:var(--brand);background:var(--brand-soft)}.agenda-cal-day-num{font-size:var(--text-xs);color:var(--ink-secondary);margin-bottom:4px;font-weight:500}.agenda-cal-day.today .agenda-cal-day-num{color:var(--brand);font-weight:700}.agenda-cal-dot{border-radius:50%;width:6px;height:6px;margin:1px;display:inline-block}.agenda-list{gap:var(--space-3);flex-direction:column;display:flex}.agenda-item{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--dur-fast);box-shadow:var(--shadow-xs);display:flex}.agenda-item:hover{box-shadow:var(--shadow-sm)}.agenda-item.overdue{border-left:3px solid var(--danger)}.agenda-item.paid{opacity:.55}.agenda-item-date{text-align:center;min-width:50px}.agenda-item-date-day{font-size:var(--text-2xl);color:var(--ink);font-weight:700;line-height:1}.agenda-item-date-month{font-size:var(--text-xs);color:var(--ink-muted);text-transform:uppercase}.agenda-item-info{flex:1}.agenda-item-title{font-weight:600;font-size:var(--text-base);align-items:center;gap:var(--space-2);color:var(--ink);display:flex}.agenda-item-meta{font-size:var(--text-xs);color:var(--ink-muted);gap:var(--space-3);margin-top:2px;display:flex}.agenda-item-amount{font-weight:700;font-size:var(--text-md);white-space:nowrap}.agenda-item-actions{gap:var(--space-1);display:flex}@media (width<=768px){.agenda-calendar{display:none}}.settings-layout{gap:var(--space-6);flex-direction:column;display:flex}.settings-section{background:var(--bg-glass-strong);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-sm)}.settings-section-title{font-size:var(--text-lg);margin-bottom:var(--space-1);color:var(--ink);letter-spacing:var(--tracking-tight);font-weight:700}.settings-section-desc{font-size:var(--text-base);color:var(--ink-secondary);margin-bottom:var(--space-6)}.settings-row{padding:var(--space-4) 0;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.settings-row:last-child{border-bottom:none}.settings-row-label{font-size:var(--text-base);color:var(--ink);font-weight:500}.settings-row-value{font-size:var(--text-base);color:var(--ink-secondary)}.whatsapp-status{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-muted);border-radius:var(--radius-md);margin-bottom:var(--space-4);border:1px solid var(--border);display:flex}.whatsapp-status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.whatsapp-status-dot.connected{background:var(--success);box-shadow:0 0 8px var(--success)}.whatsapp-status-dot.pending{background:var(--warning);animation:1.5s infinite pulse}.whatsapp-status-dot.disconnected,.whatsapp-status-dot.not_connected{background:var(--ink-muted)}
