:root{color:#f8fafc;--navy:#0f172a;--navy-2:#111c34;--blue:#2563eb;--blue-dark:#1d4ed8;--green:#10b981;--green-dark:#059669;--red:#dc2626;--muted:#64748b;--text:#334155;--card:#fff;--border:#e2e8f0;--soft:#f8fafc;--blue-soft:#dbeafe;--green-soft:#d1fae5;--dark-muted:#cbd5e1;--shadow:0 18px 45px #0f172a2e;background:#0f172a;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-height:100vh;color:var(--soft);background:radial-gradient(circle at 15% 5%,#2563eb5c,#0000 28rem),radial-gradient(circle at 88% 18%,#10b98133,#0000 24rem),linear-gradient(#0f172a 0%,#111c34 56%,#0f172a 100%);margin:0}body.menu-open{overflow:hidden}a{color:inherit;cursor:pointer;text-decoration:none}button,input,select{font:inherit}button{touch-action:manipulation}button:disabled{opacity:.58;cursor:not-allowed;transform:none!important}.nav,.app-header{z-index:20;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);color:var(--navy);background:#f8fafcf0;border-bottom:1px solid #e2e8f0eb;position:sticky;top:0}.nav{justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 5vw;display:flex}.brand{align-items:center;gap:.75rem;min-width:0;display:flex}.brand b{color:var(--navy);font-size:1.05rem;display:block}.brand p{color:var(--muted);margin:.08rem 0 0;font-size:.82rem}.logo-mark{background:linear-gradient(135deg, var(--navy), var(--blue) 58%, var(--green));color:#fff;letter-spacing:-.03em;border-radius:.85rem;flex:none;place-items:center;width:2.35rem;height:2.35rem;font-size:.82rem;font-weight:900;display:inline-grid;box-shadow:0 12px 26px #2563eb47}.nav nav{align-items:center;gap:.7rem;display:flex}.app-header-top{grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;max-width:1220px;margin:0 auto;display:grid}.page-title{min-width:0}.page-title h1{color:var(--navy);margin:0;font-size:1.1rem;line-height:1.15}.page-title p{color:var(--muted);margin:.1rem 0 0;font-size:.82rem}.header-actions{align-items:center;gap:.55rem;display:flex}.menu-trigger{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:.9rem;flex-direction:column;justify-content:center;gap:4px;width:2.55rem;height:2.55rem;display:inline-flex;box-shadow:0 10px 20px #0f172a12}.menu-trigger span{background:var(--navy);border-radius:999px;width:1.05rem;height:2px;margin:0 auto;display:block}.drawer-backdrop{z-index:50;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0f172a94;position:fixed;inset:0}.side-drawer{width:min(360px,100vw - 2rem);height:100%;color:var(--text);background:#f8fafc;padding:1.1rem;animation:.18s ease-out drawerIn;overflow-y:auto;box-shadow:24px 0 70px #00000042}@keyframes drawerIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.drawer-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:1rem;display:flex}.drawer-close{color:var(--navy);cursor:pointer;background:0 0;border:0;padding:.25rem .45rem;font-size:1.8rem;line-height:1}.drawer-nav{gap:1rem;padding:1rem 0;display:grid}.drawer-section{gap:.42rem;display:grid}.drawer-main,.drawer-subitems button{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:1px solid #0000;border-radius:.85rem}.drawer-main{padding:.78rem .9rem;font-size:1rem;font-weight:850}.drawer-main.active{color:#fff;background:linear-gradient(135deg, var(--navy), var(--blue));box-shadow:0 14px 26px #2563eb38}.drawer-subitems{border-left:2px solid var(--border);gap:.25rem;margin-left:.55rem;padding-left:.75rem;display:grid}.drawer-subitems button{padding:.56rem .72rem;font-size:.92rem}.btn{background:linear-gradient(135deg, var(--blue), var(--blue-dark));color:#fff;cursor:pointer;border:0;border-radius:.85rem;padding:.72rem 1rem;font-weight:800;box-shadow:0 12px 24px #2563eb3d}.btn:hover{transform:translateY(-1px)}.btn.outline{color:var(--text);border:1px solid var(--border);box-shadow:none;background:#fff}.btn.ghost{color:var(--text);box-shadow:none;background:0 0}.btn.danger{background:var(--red)}main{padding:3rem 5vw}.hero{grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);align-items:center;gap:3rem;max-width:1220px;min-height:72vh;margin:0 auto;display:grid}.hero h1{color:#fff;letter-spacing:-.06em;margin:.65rem 0;font-size:clamp(2.5rem,6vw,5.7rem);line-height:.94}.hero h1 span{color:var(--green)}.hero p,.landing section>p{color:var(--dark-muted);max-width:760px;font-size:1.13rem;line-height:1.65}.pill,.tag{background:var(--green-soft);color:#065f46;border-radius:999px;padding:.45rem .8rem;font-weight:850;display:inline-flex}.actions{flex-wrap:wrap;gap:1rem;display:flex}.hero-card{color:#fff;background:linear-gradient(145deg,#ffffff24,#2563eb2e);border:1px solid #e2e8f038;border-radius:2rem;padding:2rem;box-shadow:0 26px 80px #00000038}.hero-card p{color:#dbeafe}.mini-chart,.chart{background:linear-gradient(135deg,#ffffff4d,#ffffff14);border-radius:1.2rem;height:180px;position:relative;overflow:hidden}.mini-chart:after{content:"";background:linear-gradient(135deg, transparent 48%, #fff 49%, #fff 52%, transparent 53%), radial-gradient(circle at 82% 28%, var(--green) 0 8px, transparent 9px);opacity:.9;position:absolute;inset:28px 20px}.landing section:not(.hero){max-width:1220px;margin:0 auto 3rem}.landing h2{letter-spacing:-.04em;color:#fff;font-size:clamp(1.8rem,3.3vw,3rem)}.grid{gap:1rem;display:grid}.features{grid-template-columns:repeat(3,minmax(0,1fr))}.plans,.stats{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.two{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:var(--card);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:1.2rem;padding:1.3rem}.card h2,.card h3{color:var(--navy)}.icon{background:var(--blue-soft);width:2.2rem;height:2.2rem;color:var(--blue-dark);border-radius:.9rem;place-items:center;display:inline-grid}.why,.cta{text-align:center;color:#fff;background:#ffffff14;border:1px solid #e2e8f029;border-radius:2rem;margin:3rem auto;padding:3rem}.why h2,.cta h2{color:#fff}.why p,.cta p{color:var(--dark-muted);margin-left:auto;margin-right:auto}.cta{background:linear-gradient(135deg, var(--blue), var(--green));border:0}footer{color:var(--dark-muted);border-top:1px solid #e2e8f029;flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;padding:2rem;display:flex}.auth-shell{background:radial-gradient(circle at top, #2563eb59, var(--navy) 52%);place-items:center;min-height:100vh;padding:2rem;display:grid}.auth-card{width:min(430px,92vw)}.center{text-align:center}.center .brand{justify-content:center}.tabs{background:#f1f5f9;border-radius:.85rem;gap:.25rem;margin:1rem 0;padding:.25rem;display:flex;overflow-x:auto}.tabs button{cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:.65rem;flex:1;padding:.65rem}.tabs .active,.monthbar .active,.seg .active{color:var(--blue);background:#fff;box-shadow:0 6px 18px #0f172a12}.tabs-scroll button{flex:none}form{gap:1rem;display:grid}label{color:var(--text);gap:.35rem;font-weight:750;display:grid}input,select,.search{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:.8rem;padding:.82rem}.link{color:var(--blue);cursor:pointer;background:0 0;border:0}.app-main{align-content:start;gap:1.15rem;max-width:1220px;margin:0 auto;padding-top:1.25rem;display:grid}.app-main>*{min-width:0;margin:0}.app-main>h2,.app-main>p{color:#fff}.action-bar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.55rem;margin:0 0 1rem;display:flex}.action-bar .btn{padding:.58rem .78rem;font-size:.9rem}.monthbar,.row,.seg,.inline-form{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.spread{justify-content:space-between}.monthbar{color:#fff;justify-content:center;margin-bottom:1rem}.monthbar button,.seg button{border:1px solid var(--border);cursor:pointer;color:var(--text);background:#fff;border-radius:.7rem;padding:.55rem .75rem}.stat small{color:var(--muted)}.stat strong{color:var(--navy);margin-top:.35rem;font-size:1.5rem;display:block}.positive{color:var(--green-dark)!important}.negative{color:var(--red)!important}.empty{text-align:center;color:var(--text);padding:2rem}.chart{background:#eef6ff;align-items:end;gap:1rem;padding:1rem;display:flex}.chart span,.bar-chart i{background:linear-gradient(var(--blue), var(--green));border-radius:.6rem .6rem 0 0;flex:1;display:block}.chart span:first-child{height:35%}.chart span:nth-child(2){height:52%}.chart span:nth-child(3){height:45%}.chart span:nth-child(4){height:68%}.chart span:nth-child(5){height:88%}.donut{background:conic-gradient(var(--blue) 0 45%, var(--green) 45% 75%, #f59e0b 75%);border-radius:50%;width:180px;height:180px;margin:auto}.bar-chart{align-items:end;gap:.6rem;height:120px;display:flex}.bar-chart i:first-child{height:40%}.bar-chart i:nth-child(2){height:70%}.bar-chart i:nth-child(3){height:55%}.bar-chart i:nth-child(4){height:85%}.bar-chart i:nth-child(5){height:65%}.table-wrap{width:100%;overflow:auto}table{border-collapse:collapse;width:100%;min-width:760px;margin-top:1rem}th,td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:.8rem}th{color:#475569;font-size:.85rem}.plan{text-align:left;cursor:pointer;border:1px solid var(--border);transition:all .18s}.plan:hover{border-color:#bfdbfe;transform:translateY(-2px)}.plan.selected{border-color:var(--blue);outline:3px solid #2563eb33}.plan strong{color:var(--navy);font-size:2rem}.plan ul{color:#475569;padding-left:1rem}.plan em{color:var(--blue);margin-top:1rem;font-style:normal;font-weight:850;display:block}.check{align-items:center;gap:.5rem;display:flex}.check input{width:auto}.narrow{max-width:850px}.notice{color:var(--muted);margin-top:.5rem;line-height:1.45;display:block}.status-card{border:1px solid var(--border);color:var(--text);background:#f8fafc;border-radius:1rem;margin:1rem 0 1.15rem;padding:.95rem 1rem}.status-card.is-ok{background:#f0fdf4;border-color:#10b98159}.status-card.is-warn{background:#eff6ff;border-color:#2563eb40}.status-card.is-danger{background:#fef2f2;border-color:#dc262640}.status-card-head{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.45rem;display:flex}.status-card-head strong{color:var(--navy);display:block}.status-card-head small{color:var(--muted);word-break:break-word;margin-top:.2rem;display:block}.status-card p{color:var(--text);margin:0;line-height:1.5}.status-card .btn{white-space:nowrap}.event-badge{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;min-height:1.8rem;padding:.25rem .6rem;font-size:.78rem;font-weight:850;display:inline-flex}.event-success{color:#065f46;background:#d1fae5}.event-warning{color:#92400e;background:#fef3c7}.event-danger{color:#991b1b;background:#fee2e2}.event-muted{color:#475569;background:#e2e8f0}.event-info{color:#1e40af;background:#dbeafe}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end}.form-grid .btn{align-self:end}.inline-form{align-items:end;margin:.8rem 0 1rem}.inline-form input,.inline-form select{flex:150px}.inline-form .btn{flex:none}.insights{flex-wrap:wrap;gap:.75rem;margin-top:.8rem;display:flex}.insights span{color:var(--text);background:#f1f5f9;border-radius:.8rem;align-items:center;gap:.35rem;padding:.55rem .7rem;display:inline-flex}.budget-list{gap:.85rem;margin-top:1rem;display:grid}.budget-row{gap:.35rem;display:grid}.budget-row div{justify-content:space-between;align-items:baseline;gap:.75rem;display:flex}.budget-row small{color:var(--muted)}progress{background:#e2e8f0;border:0;border-radius:999px;width:100%;height:.7rem;overflow:hidden}progress::-webkit-progress-bar{background:#e2e8f0}progress::-webkit-progress-value{background:linear-gradient(90deg, var(--blue), var(--green));border-radius:999px}progress::-moz-progress-bar{background:linear-gradient(90deg, var(--blue), var(--green))}.category-limit-card p{color:var(--muted);margin:.25rem 0 0}.category-limit-list{gap:.85rem;margin-top:1rem;display:grid}.category-limit-row{border:1px solid var(--border);background:#f8fafc;border-radius:.85rem;gap:.45rem;padding:.85rem;display:grid}.category-limit-head,.category-limit-foot{justify-content:space-between;align-items:baseline;gap:.75rem;display:flex}.category-limit-head small,.category-limit-foot small,.muted-copy{color:var(--muted)}.category-limit-head span{white-space:nowrap;border-radius:999px;align-items:center;min-height:1.8rem;padding:.22rem .55rem;font-size:.78rem;font-weight:800;display:inline-flex}.category-limit-row.status-ok .category-limit-head span{color:#065f46;background:#d1fae5}.category-limit-row.status-warning .category-limit-head span{color:#92400e;background:#fef3c7}.category-limit-row.status-exceeded .category-limit-head span{color:#991b1b;background:#fee2e2}.category-limit-row.status-no_limit .category-limit-head span{color:#475569;background:#e2e8f0}.category-limit-row.status-warning progress::-webkit-progress-value{background:#f59e0b}.category-limit-row.status-exceeded progress::-webkit-progress-value{background:var(--red)}.category-limit-row.status-no_limit progress::-webkit-progress-value{background:#94a3b8}.category-limit-row.status-warning progress::-moz-progress-bar{background:#f59e0b}.category-limit-row.status-exceeded progress::-moz-progress-bar{background:var(--red)}.category-limit-row.status-no_limit progress::-moz-progress-bar{background:#94a3b8}.compact-empty{margin-top:.85rem;padding:.85rem}.category-settings{grid-column:1/-1}.category-settings-grid{grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:1rem;margin-top:.8rem;display:grid}.category-list,.category-rule-list{gap:.65rem;margin-top:.65rem;display:grid}.category-row,.category-rule-row{border:1px solid var(--border);background:#fff;border-radius:.75rem;justify-content:space-between;align-items:center;gap:.75rem;padding:.65rem .75rem;display:flex}.category-row select{max-width:150px;min-height:2.25rem}.toggle-line{align-items:center;gap:.55rem;min-width:0;margin:0;font-weight:800;display:inline-flex}.toggle-line input{width:auto;min-height:auto}.toggle-line span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.category-rule-group{border:1px solid var(--border);background:#f8fafc;border-radius:.8rem;gap:.45rem;padding:.7rem;display:grid}.danger-link{color:var(--red);font-weight:800}.file-btn{border:1px solid var(--border);width:auto;min-height:2.7rem;color:var(--text);cursor:pointer;box-shadow:none;background:#fff;border-radius:.85rem;justify-content:center;align-items:center;padding:.58rem .78rem;font-size:.9rem;font-weight:800;display:inline-flex}.file-btn input{display:none}.import-menu{align-items:stretch}.import-dropdown{position:relative}.import-dropdown-menu{z-index:20;border:1px solid var(--border);min-width:190px;box-shadow:var(--shadow);background:#fff;border-radius:.8rem;padding:.35rem;display:none;position:absolute;top:calc(100% + .35rem);right:0}.import-dropdown:hover .import-dropdown-menu,.import-dropdown:focus-within .import-dropdown-menu{gap:.25rem;display:grid}.import-dropdown-menu button{text-align:left;color:var(--text);cursor:pointer;background:0 0;border:0;border-radius:.6rem;padding:.65rem .7rem;font-weight:800}.import-dropdown-menu button:hover{background:#f1f5f9}.import-backdrop{z-index:80;background:#0f172a75;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.import-modal{width:min(1120px,100%);max-height:min(86vh,820px);color:var(--text);box-shadow:var(--shadow);background:#fff;border-radius:1rem;padding:1.15rem;overflow:auto}.import-modal h2{color:var(--navy);margin:0}.import-modal p{color:var(--muted);margin:.25rem 0 0}.import-upload{cursor:pointer;background:#eff6ff;border:1px dashed #93c5fd;border-radius:.85rem;justify-content:space-between;align-items:center;gap:1rem;margin:1rem 0;padding:.9rem;font-weight:800;display:flex}.import-upload input{display:none}.import-state,.import-alert,.import-summary{border-radius:.8rem;margin:.75rem 0;padding:.8rem .9rem;line-height:1.45}.import-state{border:1px solid var(--border);background:#f8fafc}.import-alert{color:#991b1b;background:#fef2f2;border:1px solid #dc262640}.import-summary{background:#f0fdf4;border:1px solid #10b98159}.import-preview-wrap{width:100%;margin-top:.75rem;overflow:auto}.import-preview-table{min-width:980px;margin-top:0}.import-preview-table input{border-radius:.55rem;min-height:2.2rem;padding:.45rem .55rem}.import-preview-table small{color:var(--muted);margin-top:.25rem;display:block}.import-preview-table .needs-review{background:#fff7ed}.import-preview-table .duplicate-row{background:#eff6ff}.import-preview-table .ignored-row{opacity:.58;text-decoration:line-through}.review-check{color:var(--text);align-items:center;gap:.35rem;margin-bottom:.35rem;font-size:.85rem;display:flex}.review-check input{width:auto}.import-actions{margin-top:1rem}.code-block{color:#dbeafe;background:#0f172a;border-radius:.9rem;margin-top:.8rem;padding:.9rem;overflow:auto}.code-block pre{margin:0;font-size:.85rem;line-height:1.5}.privacy-top .btn.ghost{justify-self:end}@media (width<=700px){.form-grid{grid-template-columns:1fr}.inline-form .btn{width:100%}.status-card-head,.category-limit-head,.category-limit-foot{flex-direction:column;align-items:flex-start}.status-card .btn{width:100%}.category-settings-grid{grid-template-columns:1fr}.category-row,.category-rule-row{flex-direction:column;align-items:flex-start}.category-row select{width:100%;max-width:none}}@media (width<=900px){.hero,.features,.two{grid-template-columns:1fr}.hero{min-height:auto}.hero-card{display:none}.app-header-top{grid-template-columns:auto 1fr auto}.action-bar{justify-content:flex-start}.action-bar .btn{flex:155px}.nav{align-items:flex-start}.nav nav{flex-wrap:wrap;justify-content:flex-end}}@media (width<=560px){main{padding:1.35rem}.nav,.app-header{padding-left:1rem;padding-right:1rem}.brand p{display:none}.hero h1{font-size:2.7rem}.btn{width:auto}.actions .btn{flex:100%}.monthbar{flex-wrap:nowrap;justify-content:flex-start;padding-bottom:.4rem;overflow-x:auto}.monthbar b{white-space:nowrap}.card{border-radius:1.35rem;padding:1rem}.why,.cta{border-radius:1.4rem;padding:2rem 1.2rem}.app-main{gap:1rem;padding-top:1rem}.stats{gap:.85rem}.two{gap:1rem}.page-title h1{font-size:1rem}.page-title p{font-size:.78rem}footer{font-size:.9rem}}.app-header-top{grid-template-columns:auto minmax(0,1fr) auto}.app-header-top>.brand{justify-self:end}.app-header-top>.menu-trigger{justify-self:start}.header-actions{display:none}.drawer-footer{border-top:1px solid var(--border);padding-top:1rem}.drawer-footer .btn{width:100%}@media (width<=560px){.app-header-top{grid-template-columns:auto 1fr auto;gap:.65rem}.app-header-top>.brand b{font-size:.98rem}.page-title{display:none}}@media (width<=600px){.app-header .brand b{display:none}}.notice.error-notice{color:var(--danger);border-left:3px solid var(--danger);background:#ef44441a}.notice.success-notice{color:#047857;background:#10b9811a;border-left:3px solid #10b981}.onboarding-card{border-left:4px solid var(--brand)}.onboarding-head{margin-bottom:1.5rem}.progress-bar-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:4px;height:8px;margin-top:.5rem;position:relative;overflow:hidden}.progress-bar-fill{background:var(--brand);height:100%;transition:width .3s}.progress-bar-wrap small{color:var(--text-muted);font-size:.75rem;position:absolute;top:-20px;right:0}.checklist{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;padding:0;list-style:none;display:grid}.checklist li{border-radius:8px;align-items:center;gap:.75rem;padding:.5rem;transition:background .2s;display:flex}.checklist li.done{color:var(--text-muted)}.checklist .checkbox{border:2px solid var(--border);color:#fff;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;font-size:.8rem;transition:all .2s;display:flex}.checklist li.done .checkbox{background:var(--brand);border-color:var(--brand)}.form-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=600px){.form-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-grid .row{grid-column:1/-1}}.form-grid label{flex-direction:column;gap:.4rem;font-size:.9rem;font-weight:500;display:flex}.feedback-card{border:1px dashed var(--brand);background:linear-gradient(135deg,#eff6ff 0%,#fff 100%)}.feedback-form{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.feedback-form textarea{border:1px solid var(--border);resize:vertical;border-radius:8px;width:100%;padding:.75rem;font-family:inherit}.feedback-form select{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;padding:.75rem;font-family:inherit}.feedback-card h3{color:var(--brand);margin-bottom:.5rem}.feedback-widget{z-index:9999;position:fixed;bottom:2rem;right:2rem}.feedback-trigger{background:var(--brand);color:#fff;cursor:pointer;text-align:center;border:none;border-radius:999px;justify-content:center;align-items:center;min-width:220px;min-height:48px;padding:.75rem 1rem;font-size:.95rem;font-weight:900;transition:transform .2s;display:flex;box-shadow:0 4px 12px #00000026}.feedback-trigger:hover{transform:scale(1.05)}.feedback-popover{width:320px;margin:0;position:absolute;bottom:70px;right:0;box-shadow:0 8px 32px #0003}.charts-card{padding:1.5rem}.chart-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.chart-tabs,.period-selector{background:#f1f5f9;border-radius:8px;gap:2px;padding:4px;display:flex}.chart-tabs button,.period-selector button{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:6px;padding:6px 12px;font-size:.85rem;font-weight:500}.chart-tabs button.active,.period-selector button.active{color:var(--brand);background:#fff;box-shadow:0 2px 4px #0000000d}.chart-container{width:100%;height:200px}.simple-line-chart{width:100%;height:160px;overflow:visible}.chart-axis{color:#94a3b8;justify-content:space-between;margin-top:.5rem;font-size:.75rem;display:flex}.modal-overlay{z-index:10000;background:#0f172acc;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{width:100%;max-width:600px;animation:.3s ease-out slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content textarea{border:1px solid var(--border);border-radius:8px;width:100%;margin:1rem 0;padding:1rem;font-family:monospace;font-size:.85rem}:root{--brand:#0b5cff;--danger:#ef4444;--premium-bg:#081327;--premium-surface:#0d1e46bd;--premium-surface-2:#102553db;--premium-line:#95aedd38;--premium-text:#f4f7ff;--premium-muted:#9fb0d0}body{color:var(--premium-text);background:radial-gradient(circle at 12% 0,#0b5cff57,#0000 30rem),radial-gradient(circle at 82% 12%,#17c96424,#0000 26rem),linear-gradient(#071226 0%,#0b1630 48%,#060b18 100%)}.nav,.app-header{width:100%;color:var(--premium-text);border-bottom:1px solid var(--premium-line);background:#071226f0;left:0;right:0;box-shadow:0 14px 38px #00000038}.nav{padding:.86rem clamp(1rem,4vw,3.5rem)}.app-header{padding:0}.app-header-top{grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:1rem;width:100%;max-width:1220px;min-height:68px;padding:.62rem clamp(1rem,4vw,3.5rem);display:grid}.app-header .brand b,.nav .brand b,.page-title h1,.card h2,.card h3{color:var(--premium-text)}.app-header .brand p,.nav .brand p,.page-title p{color:var(--premium-muted)}.desktop-favorites{justify-content:center;align-items:center;gap:.45rem;min-width:0;display:flex}.desktop-favorites button,.import-top-dropdown>button{min-height:2.45rem;color:var(--premium-muted);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:.48rem;padding:.55rem .82rem;font-weight:850;display:inline-flex}.desktop-favorites button:hover,.desktop-favorites button.active,.import-top-dropdown:hover>button,.import-top-dropdown:focus-within>button{color:#fff;background:#0b5cff2e;border-color:#0b5cff57}.import-top-dropdown{position:relative}.import-top-menu{z-index:40;border:1px solid var(--premium-line);background:#09142bfa;border-radius:.9rem;min-width:220px;padding:.38rem;display:none;position:absolute;top:calc(100% + .5rem);right:0;box-shadow:0 20px 55px #00000061}.import-top-dropdown:hover .import-top-menu,.import-top-dropdown:focus-within .import-top-menu{gap:.25rem;display:grid}.import-top-menu button{width:100%;color:var(--premium-text);border-radius:.65rem;justify-content:flex-start}.menu-trigger{border:1px solid var(--premium-line);width:2.55rem;height:2.55rem;color:var(--premium-text);box-shadow:none;background:#ffffff0f;border-radius:.85rem;justify-content:center;align-items:center;display:none}.menu-trigger span{display:none}.side-drawer{color:var(--premium-text);border-right:1px solid var(--premium-line);background:#09162e}.drawer-head{border-color:var(--premium-line)}.drawer-close{color:var(--premium-text);place-items:center;display:inline-grid}.drawer-main{color:var(--premium-text);align-items:center;gap:.6rem;display:flex}.drawer-main:hover,.drawer-subitems button:hover{background:#0b5cff29}.drawer-main.active{background:linear-gradient(135deg,#0b5cff,#17c964)}.drawer-section b{color:var(--premium-muted);text-transform:uppercase;letter-spacing:.08em;padding:.4rem .85rem 0;font-size:.78rem}.drawer-subitems{border-color:var(--premium-line)}.drawer-subitems button{color:var(--premium-text)}.drawer-footer{border-color:var(--premium-line)}.card{color:var(--premium-text);background:var(--premium-surface);border:1px solid var(--premium-line);border-radius:.95rem;box-shadow:0 20px 60px #00000038}.card p,.card small,.muted-copy,.stat small,.category-limit-card p,.budget-row small,.import-modal p{color:var(--premium-muted)}.clickable-card{cursor:pointer;transition:transform .18s,border-color .18s,background .18s}.clickable-card:hover{background:var(--premium-surface-2);border-color:#0b5cff85;transform:translateY(-2px)}.stat strong{color:var(--premium-text);font-size:1.45rem}.dashboard-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.dashboard-charts{grid-template-columns:minmax(0,1.45fr) minmax(320px,.85fr);align-items:stretch;gap:1rem;display:grid}.premium-chart-card{min-height:368px;padding:1.1rem}.chart-card-head{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.55rem;display:flex}.chart-card-head small{color:#17c964;margin-bottom:.24rem;font-weight:850;display:block}.chart-card-head h2{margin:0;font-size:1.05rem}.chart-card-head svg{color:#7da2ff}.grana-chart{border-radius:.8rem;outline:none;width:100%;height:292px;min-height:292px;overflow:hidden}.grana-chart:focus-visible,.clickable-card:focus-visible{box-shadow:0 0 0 3px #0b5cff6b}.grana-chart-canvas{width:100%;height:100%}.chart-empty{align-content:center;place-items:center;min-height:292px;display:grid}.icon{color:#bcd1ff;background:#0b5cff2e;border:1px solid #0b5cff47}input,select,.search,.file-btn,.import-modal,.category-row,.category-rule-row,.category-rule-group,.category-limit-row,.status-card,.insights span{color:var(--text);background:#fff}.tabs,.chart-tabs,.period-selector{background:#ffffff14}.tabs .active,.monthbar .active,.seg .active{color:#fff;background:#0b5cff73}.monthbar button,.seg button{color:var(--premium-text);border-color:var(--premium-line);background:#ffffff0f}.success-card{background:#0c4a328f;border-color:#17c9646b}.warning-card{background:#713f1261;border-color:#f59e0b5c}.product-preview{min-height:360px}.mini-chart{background:linear-gradient(#0b5cff33,#0b5cff00),#081327b8;border:1px solid #95aedd3d}.mini-chart:after{opacity:1;background:linear-gradient(135deg,#0000 46%,#7da2ff 47% 49%,#0000 50%),radial-gradient(circle at 72% 31%,#17c964 0 7px,#0000 8px)}@media (width<=900px){.app-header-top{grid-template-columns:auto minmax(0,1fr) auto}.desktop-favorites{display:none}.menu-trigger{display:inline-flex}.page-title{text-align:right;justify-self:end}.dashboard-charts,.dashboard-stats{grid-template-columns:1fr}}@media (width<=560px){.app-header-top{min-height:62px;padding-left:1rem;padding-right:1rem}.app-header-top>.brand b{font-size:.98rem;display:block}.page-title{display:none}.premium-chart-card{min-height:330px}.grana-chart,.chart-empty{height:250px;min-height:250px}}
