:root{--bg-base: #050d1a;--bg-surface: #0d1b2e;--bg-card: #111f33;--bg-hover: #172640;--bg-input: #0a1628;--border: #1e3050;--border-light: #243d60;--blue: #3b82f6;--blue-dim: #1d4ed8;--blue-glow: rgba(59, 130, 246, .15);--green: #10b981;--green-dim: rgba(16, 185, 129, .15);--amber: #f59e0b;--amber-dim: rgba(245, 158, 11, .15);--red: #ef4444;--red-dim: rgba(239, 68, 68, .15);--purple: #8b5cf6;--cyan: #06b6d4;--text-primary: #f0f6ff;--text-secondary: #8ba3c7;--text-muted: #4d6a8a;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--sidebar-w: 240px;--header-h: 60px;--chart-1: #3b82f6;--chart-2: #10b981;--chart-3: #f59e0b;--chart-4: #8b5cf6;--chart-5: #ef4444;--chart-6: #06b6d4;--chart-7: #f97316;--chart-8: #ec4899}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-base);color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}input,textarea,select,button{font-family:inherit;font-size:inherit}button{cursor:pointer}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.app-shell{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;margin-left:var(--sidebar-w)}.page-body{flex:1;overflow-y:auto;padding:28px 32px}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100}.sidebar-logo{height:var(--header-h);display:flex;align-items:center;gap:10px;padding:0 20px;border-bottom:1px solid var(--border);font-weight:700;font-size:16px;color:var(--text-primary)}.sidebar-logo .logo-icon{width:28px;height:28px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:900;color:#fff}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13.5px;font-weight:500;transition:background .15s,color .15s;text-decoration:none;cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary);text-decoration:none}.nav-item.active{background:var(--blue-glow);color:var(--blue)}.nav-item .nav-icon{font-size:17px;width:20px;text-align:center;flex-shrink:0}.nav-section-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:12px 12px 4px}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border)}.header{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.header-title{font-size:16px;font-weight:600;color:var(--text-primary)}.header-right{display:flex;align-items:center;gap:16px}.header-user{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary)}.avatar{width:32px;height:32px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;flex-shrink:0}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card-sm{padding:14px 16px}.card-lg{padding:28px}.card-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px}.card-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1.2}.card-sub{font-size:12px;color:var(--text-secondary);margin-top:4px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;border:none;transition:background .15s,opacity .15s;white-space:nowrap}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:var(--blue-dim)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-light)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444440}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:11px 22px;font-size:15px}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11.5px;font-weight:600}.badge-green{background:var(--green-dim);color:var(--green)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-blue{background:var(--blue-glow);color:var(--blue)}.badge-purple{background:#8b5cf626;color:var(--purple)}.badge-cyan{background:#06b6d426;color:var(--cyan)}.progress-track{height:8px;background:var(--bg-base);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .4s ease}.progress-green{background:var(--green)}.progress-blue{background:var(--blue)}.progress-amber{background:var(--amber)}.progress-red{background:var(--red)}.form-group{display:flex;flex-direction:column;gap:6px}label{font-size:12.5px;font-weight:500;color:var(--text-secondary)}.input,.select,textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:9px 12px;transition:border-color .15s;width:100%}.input:focus,.select:focus,textarea:focus{outline:none;border-color:var(--blue)}.input::placeholder{color:var(--text-muted)}select.select option{background:var(--bg-card)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#050d1acc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:600}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px 20px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}.modal-close{background:none;border:none;color:var(--text-muted);font-size:20px;line-height:1;cursor:pointer}.modal-close:hover{color:var(--text-primary)}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}table{width:100%;border-collapse:collapse}thead th{background:var(--bg-surface);padding:11px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap}tbody td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-primary);font-size:13.5px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--bg-hover)}.upload-zone{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:48px 32px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--blue);background:var(--blue-glow)}.upload-icon{font-size:40px;margin-bottom:12px}.upload-title{font-size:16px;font-weight:600;margin-bottom:6px}.upload-sub{color:var(--text-secondary);font-size:13px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-title{font-size:22px;font-weight:700}.page-subtitle{font-size:13px;color:var(--text-secondary);margin-top:2px}.chart-wrap{width:100%}.expenses-page .stat-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.expenses-toolbar{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.expenses-toolbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.expenses-section-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.expense-table-desktop{display:block}.expense-cards-mobile{display:none}.analysis-table-desktop{display:block}.analysis-cards-mobile{display:none;flex-direction:column;gap:10px}.expense-card{border:1px solid var(--border);border-radius:var(--radius);padding:12px;background:var(--bg-surface);display:flex;flex-direction:column;gap:10px}.expense-card-head{display:flex;justify-content:space-between;align-items:center;gap:10px}.expense-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.expenses-records-list{display:flex;flex-direction:column;gap:10px}.expenses-record-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface)}.custom-tooltip{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px}.custom-tooltip .label{color:var(--text-secondary);margin-bottom:4px;font-size:11px;text-transform:uppercase;font-weight:600}.alert{border-radius:var(--radius);padding:14px 16px;display:flex;gap:12px;align-items:flex-start;font-size:13.5px}.alert-red{background:var(--red-dim);border:1px solid rgba(239,68,68,.3)}.alert-amber{background:var(--amber-dim);border:1px solid rgba(245,158,11,.3)}.alert-green{background:var(--green-dim);border:1px solid rgba(16,185,129,.3)}.alert-blue{background:var(--blue-glow);border:1px solid rgba(59,130,246,.3)}.alert-icon{font-size:18px;flex-shrink:0}.alert-body .alert-title{font-weight:600;margin-bottom:2px}.alert-body .alert-msg{color:var(--text-secondary);font-size:13px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 900px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}.expense-table-desktop{display:none}.expense-cards-mobile{display:flex;flex-direction:column;gap:10px}.analysis-table-desktop{display:none}.analysis-cards-mobile{display:flex}.expenses-record-row{flex-direction:column;align-items:flex-start}.expenses-toolbar-actions{margin-left:0;width:100%}}@media (max-width: 600px){.grid-2,.grid-3,.grid-4,.form-grid{grid-template-columns:1fr}.page-body{padding:16px}.expenses-toolbar{align-items:stretch}.expenses-toolbar .form-group{width:100%;min-width:0!important}.expenses-toolbar-actions{width:100%}.expense-card-grid{grid-template-columns:1fr}}.public-shell{min-height:100vh;background:radial-gradient(1000px 500px at 20% -10%,rgba(59,130,246,.22),transparent 60%),radial-gradient(900px 450px at 100% 0%,rgba(16,185,129,.12),transparent 58%),var(--bg-base)}.public-container{width:min(1140px,92vw);margin:0 auto}.public-header{position:sticky;top:0;z-index:40;border-bottom:1px solid var(--border);background:#07101ee0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.public-header-inner{height:64px;display:flex;align-items:center;justify-content:space-between;gap:12px}.public-brand{display:inline-flex;align-items:center;gap:10px;font-weight:700;color:var(--text-primary)}.public-brand:hover{text-decoration:none}.public-brand-icon{width:30px;height:30px;border-radius:9px;background:var(--blue);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:900}.public-nav{display:flex;align-items:center;gap:16px}.public-nav a{color:var(--text-secondary);font-size:13px}.public-nav a:hover{color:var(--text-primary);text-decoration:none}.public-nav .public-login-link{padding:7px 12px;border-radius:8px;border:1px solid var(--border-light);color:var(--text-primary)}.public-hero{padding:70px 0 34px}.public-hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:26px;align-items:stretch}.public-kicker{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;border:1px solid rgba(59,130,246,.36);background:var(--blue-glow);color:var(--blue);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.public-hero-title{font-size:clamp(30px,5.1vw,50px);line-height:1.08;margin-top:14px}.public-hero-sub{margin-top:14px;color:var(--text-secondary);max-width:58ch;font-size:16px}.public-hero-cta{margin-top:20px;display:flex;gap:10px;flex-wrap:wrap}.public-hero-card{border:1px solid var(--border-light);background:linear-gradient(170deg,#142641f2,#0d1b2ef2);border-radius:16px;padding:18px}.public-bullet-list{list-style:none;margin-top:6px;display:grid;gap:10px;color:var(--text-secondary)}.public-bullet-list li{position:relative;padding-left:16px}.public-bullet-list li:before{content:"";position:absolute;left:0;top:8px;width:7px;height:7px;border-radius:50%;background:var(--blue)}.public-section{padding:24px 0 36px}.public-section-tight{padding-top:4px}.public-section-head{margin-bottom:12px}.public-section-head h2{font-size:22px;margin-bottom:4px}.public-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.public-feature-card{border:1px solid var(--border);border-radius:12px;padding:16px;background:#111f33d6}.public-feature-card h3{font-size:16px;margin-bottom:6px}.public-feature-card p{color:var(--text-secondary);font-size:14px}.public-roadmap-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.public-roadmap-card{border:1px solid var(--border);border-radius:12px;padding:16px;background:#0d1b2ee6;display:flex;flex-direction:column;gap:10px}.public-roadmap-card h3{font-size:15px}.public-roadmap-card p{color:var(--text-secondary);font-size:13.5px}.public-links-row{display:flex;flex-wrap:wrap;gap:12px 20px}.public-links-row a{font-size:13px}.public-footer{border-top:1px solid var(--border);margin-top:20px;padding:20px 0 28px}.public-footer-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}.public-footer-brand{font-weight:700;margin-bottom:4px}.public-footer-links{display:flex;flex-wrap:wrap;gap:10px 16px}.public-footer-links a{color:var(--text-secondary);font-size:12.5px}.public-doc{border:1px solid var(--border);border-radius:14px;padding:20px;background:#111f33e6}.public-doc h1{font-size:30px;line-height:1.15;margin-bottom:6px}.public-doc h2{font-size:16px;margin-top:18px;margin-bottom:6px}.public-doc p{color:var(--text-secondary);font-size:14px}.public-hero-image{position:relative;border-radius:18px;border:1px solid var(--border-light);overflow:hidden;min-height:340px;background:linear-gradient(160deg,#09172df2,#0f2a4ce0)}.public-hero-image-glow{position:absolute;inset:-120px auto auto -100px;width:280px;height:280px;border-radius:50%;background:#06b6d44d;filter:blur(40px)}.public-hero-image-frame{position:relative;padding:20px;display:grid;gap:14px;min-height:100%}.public-hero-image-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.public-hero-sparkline{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));align-items:end;gap:8px;height:120px;padding:14px;border:1px solid rgba(59,130,246,.25);border-radius:12px;background:#07101eb8}.public-hero-sparkline span{border-radius:8px 8px 2px 2px;background:linear-gradient(180deg,#06b6d4e6,#3b82f6a6)}.public-hero-image-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.public-hero-image-metrics article{border-radius:12px;border:1px solid var(--border);background:#050d1abf;padding:12px}.public-stock-banner{display:grid;grid-template-columns:1.1fr 1fr;gap:20px;border:1px solid var(--border-light);border-radius:18px;padding:22px;background:linear-gradient(140deg,#0d1b2ef2,#091426f2)}.public-stock-banner-copy h2{font-size:clamp(24px,4vw,34px);margin-top:10px;margin-bottom:8px}.public-stock-banner-copy p{color:var(--text-secondary);font-size:15px}.public-stock-banner-visual{border-radius:14px;border:1px solid var(--border);background:radial-gradient(circle at top right,rgba(59,130,246,.22),transparent 50%),#060e1cdb;padding:18px;display:grid;align-content:center;gap:10px;position:relative;overflow:hidden}.public-agent-orb{position:absolute;width:180px;height:180px;right:-35px;top:-60px;border-radius:50%;background:#10b98133;filter:blur(14px)}.public-agent-card{position:relative;border:1px solid rgba(59,130,246,.35);border-radius:11px;padding:10px 12px;background:#0b1e34d9;font-size:13px;color:var(--text-primary)}.public-mobile-apps{margin-top:14px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.public-mobile-card{border:1px solid var(--border);border-radius:12px;background:#0a1628d1;padding:14px;display:flex;align-items:center;gap:12px}.public-mobile-card h3{font-size:15px}.public-mobile-card p{color:var(--text-secondary);font-size:13px}.public-mobile-logo{width:28px;height:28px;color:#d4e7ff;flex-shrink:0}.public-page-hero{padding:54px 0 14px}.public-page-hero-inner{border:1px solid var(--border-light);border-radius:18px;padding:28px;background:linear-gradient(165deg,#12223aeb,#0a1423eb)}.public-page-hero-inner h1{margin-top:12px;font-size:clamp(34px,5vw,48px);line-height:1.06}.public-page-hero-inner p{color:var(--text-secondary);margin-top:10px;font-size:15px;max-width:72ch}.public-doc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.public-doc-card{border:1px solid var(--border);border-radius:14px;padding:18px;background:#111f33e6;min-height:168px}.public-doc-card h2{font-size:19px;margin-bottom:7px}.public-doc-card p{color:var(--text-secondary);font-size:14px}.public-doc-list{margin:4px 0 0;padding-left:18px;color:var(--text-secondary);font-size:14px;display:grid;gap:6px}@media (max-width: 900px){.public-hero-grid{grid-template-columns:1fr}.public-feature-grid,.public-roadmap-grid{grid-template-columns:1fr 1fr}.public-stock-banner,.public-doc-grid{grid-template-columns:1fr}}@media (max-width: 600px){.public-header-inner{height:auto;padding:12px 0;align-items:flex-start;flex-direction:column}.public-nav{width:100%;justify-content:space-between;gap:10px;flex-wrap:wrap}.public-nav .public-login-link{width:100%;text-align:center}.public-hero{padding-top:28px}.public-feature-grid,.public-roadmap-grid{grid-template-columns:1fr}.public-doc{padding:14px}.public-doc h1{font-size:24px}.public-page-hero-inner{padding:18px}.public-page-hero-inner h1{font-size:30px}.public-stock-banner{padding:16px}.public-hero-image-metrics,.public-mobile-apps{grid-template-columns:1fr}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top left,#0d2444 0%,var(--bg-base) 60%)}.login-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:400px}.login-logo{text-align:center;margin-bottom:28px}.login-logo .logo-big{width:52px;height:52px;background:var(--blue);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;color:#fff;margin-bottom:12px}.login-logo h1{font-size:22px;font-weight:700}.login-logo p{color:var(--text-secondary);font-size:13px}@media (max-width: 600px){.login-card{padding:24px 18px;max-width:92vw}}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-amber{color:var(--amber)}.text-blue{color:var(--blue)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-sm{font-size:12.5px}.text-xs{font-size:11px}.font-bold{font-weight:700}.font-semibold{font-weight:600}.loading-spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border-light);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 24px;color:var(--text-secondary)}.empty-state .empty-icon{font-size:36px;margin-bottom:12px}.empty-state p{font-size:13.5px}
