@import"https://fonts.googleapis.com/css2?family=Manrope:wght@500;600;700;800&family=Sora:wght@600;700&display=swap";.login-page[data-v-f96c427b]{min-height:100vh;display:grid;place-items:center;padding:1.25rem}.login-card[data-v-f96c427b]{width:min(460px,100%)}.login-header[data-v-f96c427b]{margin-bottom:1rem}.login-form[data-v-f96c427b]{display:grid;gap:.85rem}.login-form label[data-v-f96c427b]{display:grid;gap:.35rem;font-weight:600}:root{--bg: #f4f7fb;--surface: #ffffff;--surface-soft: #f8fbff;--text: #14213d;--muted: #5c6983;--line: #d9e2ef;--accent: #1e6ff2;--accent-soft: #e7f0ff;--success-soft: #e9f9ef;--warn-soft: #fff4df;--radius: 14px;--radius-sm: 10px;--shadow-soft: 0 12px 32px rgba(20, 33, 61, .08);--shadow-focus: 0 0 0 3px rgba(30, 111, 242, .18);font-family:Manrope,Segoe UI,sans-serif;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--text);background:radial-gradient(circle at 4% 0%,rgba(30,111,242,.09),transparent 28%),radial-gradient(circle at 95% 100%,rgba(5,150,105,.08),transparent 24%),var(--bg)}h1,h2,h3,p{margin:0}h2,.page-title{font-family:Sora,Manrope,sans-serif;letter-spacing:-.02em}h3{font-size:1rem;margin-bottom:.85rem}.page{padding:1.35rem}.page-header{display:flex;justify-content:space-between;gap:.9rem;align-items:center;margin-bottom:1.05rem}.page-header-main{display:flex;align-items:center;gap:.75rem}.page-header-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:12px;background:var(--accent-soft);color:var(--accent)}.page-title{font-size:1.3rem;line-height:1.25}.page-subtitle,.muted{color:var(--muted);margin-top:.3rem}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(170deg,#13274c,#10213f),#13274c;color:#f1f5fb;padding:1.3rem 1rem;border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.95rem;z-index:20}.brand-wrap{display:flex;gap:.65rem;align-items:center}.brand-logo{display:inline-flex;width:38px;height:38px;border-radius:12px;align-items:center;justify-content:center;color:#dce8ff;background:#ffffff21}.brand{font-size:1rem;font-weight:700}.brand-subtitle{font-size:.8rem;color:#dce8ffc7;margin-top:.2rem}.nav-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#dce8ffb8}.nav{display:flex;flex-direction:column;gap:.4rem}.nav-link{color:#dce8ff;text-decoration:none;padding:.62rem .72rem;border-radius:11px;display:flex;align-items:center;gap:.55rem;transition:background-color .18s ease,transform .18s ease}.nav-link:hover{background:#ffffff14;transform:translate(2px)}.nav-link.router-link-active{color:#fff;background:linear-gradient(120deg,#1e6ff2f2,#1a90a7f2);box-shadow:inset 0 0 0 1px #fff3}.sidebar-footer{margin-top:auto;display:flex}.content{min-width:0}.topbar{min-height:70px;background:#ffffffe0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem 1.35rem;position:sticky;top:0;z-index:8}.topbar-left{display:flex;align-items:center;gap:.8rem}.breadcrumbs{display:flex;gap:.4rem;color:var(--muted);font-size:.88rem}.breadcrumbs strong{color:var(--text)}.menu-toggle{display:none;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text);padding:.4rem .65rem;cursor:pointer;align-items:center;gap:.4rem}.topbar-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem}.locale-label{font-size:.8rem;color:var(--muted)}.locale-select,.topbar-search,input,select{border:1px solid var(--line);border-radius:10px;padding:.52rem .64rem;background:#fff;color:var(--text);min-height:38px}.topbar-search{min-width:190px}input:focus,select:focus,textarea:focus,button:focus-visible,a:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow-soft)}.grid{display:grid;gap:1rem}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.mt-16{margin-top:1rem}.stat-card{min-height:102px}.stat-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.stat-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:10px;background:#ffffffbf;color:currentColor}.stat-accent-blue{background:linear-gradient(140deg,#eaf3ff,#fff);border-color:#c8dbfb;color:#22539e}.stat-accent-amber{background:linear-gradient(140deg,#fff4df,#fff);border-color:#f5d9a3;color:#8a5a00}.stat-accent-green{background:linear-gradient(140deg,#e9f9ef,#fff);border-color:#b7e5c6;color:#1f6a43}.stat-accent-indigo{background:linear-gradient(140deg,#edf0ff,#fff);border-color:#ccd4ff;color:#35469c}.stat-label{color:inherit;opacity:.88}.stat-value{font-size:1.35rem;font-weight:800;color:var(--text)}.form{display:flex;flex-direction:column;gap:1rem}.form-section{display:flex;flex-direction:column;gap:.85rem;padding:.85rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-soft)}.form-section-head{display:flex;flex-direction:column;gap:.25rem}.form-section-title{margin:0;font-size:.95rem}.form-actions{display:flex;justify-content:flex-end}.form-inline{display:flex;flex-wrap:wrap;align-items:end;gap:.75rem}label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:var(--text)}.field-label-row{display:inline-flex;align-items:center;gap:.35rem}.field-help{display:inline-flex;align-items:center;justify-content:center;width:1rem;height:1rem;border-radius:999px;border:1px solid var(--line);color:var(--muted);font-size:.7rem;line-height:1}.btn{border:0;border-radius:11px;background:linear-gradient(120deg,#1e6ff2,#1570aa);color:#fff;padding:.58rem .92rem;cursor:pointer;width:fit-content;text-decoration:none;display:inline-flex;align-items:center;gap:.45rem;font-weight:600}.btn:hover{filter:brightness(1.03)}.btn:disabled{opacity:.65;cursor:not-allowed}.btn-secondary{background:#edf2f9;color:#22314d}.notice{color:#0f766e;font-size:.9rem}.table-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:.8rem}.table-search,.table-select{border:1px solid var(--line);border-radius:10px;padding:.45rem .55rem;min-width:220px;min-height:38px}.table-count{margin-left:auto;color:var(--muted);font-size:.85rem}.sort-header-btn{display:inline-flex;align-items:center;gap:.35rem;border:none;background:transparent;color:inherit;font:inherit;cursor:pointer;padding:0}.sort-indicator{display:inline-flex;align-items:center;justify-content:center;min-width:1.3rem;border-radius:999px;border:1px solid #d2deef;background:#ebf1fb;color:#2f4464;font-size:.72rem;line-height:1;padding:.16rem .32rem}.quick-actions{display:flex;flex-wrap:wrap;gap:.55rem}.stats-inline{display:flex;flex-wrap:wrap;gap:.5rem}.report-chart{width:100%;min-height:230px}.chart-svg{width:100%;height:230px;display:block}.chart-axis{stroke:#aac0dd;stroke-width:.45}.chart-grid{stroke:#dbe6f4;stroke-width:.28;stroke-dasharray:1.2 1.2}.chart-bar{fill:var(--accent);opacity:.85}.chart-bar:hover{opacity:1}.chart-x-label,.chart-y-label{fill:var(--muted);font-size:2.7px}.chart-x-label{dominant-baseline:middle;text-anchor:middle}.chart-y-label{dominant-baseline:middle;text-anchor:end}.chart-bars{display:flex;flex-direction:column;gap:.6rem}.chart-row{display:grid;grid-template-columns:minmax(110px,1fr) minmax(160px,2.4fr) minmax(120px,1fr);align-items:center;gap:.5rem}.chart-label,.chart-value{margin:0;font-size:.84rem}.chart-label{color:var(--muted)}.chart-value{text-align:right}.chart-track{width:100%;height:.62rem;border-radius:999px;border:1px solid var(--line);background:var(--surface-soft);overflow:hidden}.chart-fill{display:block;height:100%;border-radius:999px;background:var(--accent)}.pill,.badge{border-radius:999px;background:#ebf1fb;color:#2f4464;padding:.3rem .66rem;font-size:.82rem;border:1px solid #d2deef}.pill-overdue{background:#ffe5e5;color:#b3261e;border-color:#f3b2ad}.pill-current{background:#e8f8ed;color:#1b6b40;border-color:#bee7cb}.pill-upcoming{background:#ebf1fb;color:#2f4464;border-color:#d2deef}.tabs{display:flex;gap:.5rem}.tab-btn{border:1px solid var(--line);background:#fff;color:var(--text);border-radius:10px;padding:.55rem .8rem;cursor:pointer}.tab-btn.active{background:var(--accent-soft);border-color:#b5cdf9;color:#1e4aa5}.checkbox-row{flex-direction:row;align-items:center;gap:.5rem}table{width:100%;border-collapse:separate;border-spacing:0;font-size:.9rem;overflow:hidden}th,td{text-align:left;border-bottom:1px solid #eaf0f7;padding:.65rem .45rem}th{font-weight:700;color:#385071;background:#f6f9fd}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f8fbff}.selected-row{background:#ebf2ff}.customer-detail-shell{background:radial-gradient(circle at top right,rgba(30,111,242,.09),transparent 36%),#fff}.customer-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;border:1px solid var(--line);border-radius:12px;padding:.85rem;background:var(--surface-soft)}.customer-title{font-size:1.08rem;margin-bottom:.2rem}ul{margin:0;padding-left:1rem}.sidebar-backdrop{display:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a142685;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:40}.modal-panel{width:min(780px,100%);max-height:92vh;overflow:auto}.modal-panel-lg{width:min(1200px,100%)}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}@media(max-width:1080px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:-300px;top:0;width:280px;transition:left .2s ease;padding-bottom:.75rem}.sidebar-open{left:0}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#08122380;z-index:10}.menu-toggle{display:inline-flex}.topbar{align-items:flex-start;flex-direction:column}.page-header{flex-direction:column;align-items:flex-start}.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.table-search,.table-select,.topbar-search{min-width:100%}.table-count{margin-left:0}.customer-header{flex-direction:column;align-items:flex-start}.modal-panel,.modal-panel-lg{width:100%;max-height:94vh}}
