:root{--navy-900:#102a40;--navy-800:#143553;--navy:#1b4d7a;--navy-600:#226199;--navy-100:#e7f0f7;--navy-50:#f1f6fb;--red-700:#84212f;--red:#a4283a;--red-500:#c23445;--red-100:#fbe9ec;--bg:#f4f6fa;--surface:#fff;--surface-2:#f8fafc;--border:#e4e9f0;--border-strong:#d3dbe6;--text:#1f2a37;--text-soft:#5b6776;--text-muted:#8a96a5;--green:#1f9d63;--green-bg:#e6f6ee;--amber:#c98a00;--amber-bg:#fdf3df;--blue:#2f72c4;--blue-bg:#e7f0fb;--gray-bg:#eef1f5;--radius:12px;--radius-sm:8px;--radius-lg:18px;--shadow-sm:0 1px 2px #102a400f, 0 1px 3px #102a400a;--shadow:0 4px 16px #102a4014;--shadow-lg:0 20px 50px #102a402e;--sidebar-w:260px;--topbar-h:64px;--sans:"Inter", system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;font-family:var(--sans);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.5}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4{color:var(--navy-900);letter-spacing:-.01em;margin:0;font-weight:700}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{color:var(--text);font-family:inherit;font-size:14px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cdd6e2 padding-box padding-box;border:2px solid #0000;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#b6c2d2 padding-box padding-box}.btn{border-radius:var(--radius-sm);white-space:nowrap;background:var(--surface);color:var(--text);border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:9px 16px;font-size:14px;font-weight:600;line-height:1;transition:all .16s;display:inline-flex}.btn svg{width:16px;height:16px}.btn-primary{background:var(--navy);color:#fff;border-color:var(--navy)}.btn-primary:hover{background:var(--navy-800);border-color:var(--navy-800)}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover{background:var(--red-700)}.btn-success{background:var(--green);color:#fff;border-color:var(--green)}.btn-success:hover{filter:brightness(.95)}.btn-ghost{color:var(--text-soft);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--gray-bg);color:var(--text)}.btn-outline{background:var(--surface);border-color:var(--border-strong);color:var(--text)}.btn-outline:hover{border-color:var(--navy);color:var(--navy)}.btn-sm{padding:6px 11px;font-size:13px}.btn-block{width:100%}.btn:disabled{opacity:.55;cursor:not-allowed}.field{flex-direction:column;gap:6px;display:flex}.field label,.label{color:var(--text-soft);font-size:12.5px;font-weight:600}.input,.select,.textarea{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);outline:none;width:100%;padding:9px 12px;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--navy-600);box-shadow:0 0 0 3px #2261991f}.textarea{resize:vertical;min-height:70px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-pad{padding:20px}.badge{border-radius:100px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;line-height:1.4;display:inline-flex}.badge:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.badge-gray{background:var(--gray-bg);color:var(--text-soft)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-green{background:var(--green-bg);color:var(--green)}.badge-amber{background:var(--amber-bg);color:var(--amber)}.badge-red{background:var(--red-100);color:var(--red)}.account-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}@media (width<=920px){.account-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=560px){.account-grid{grid-template-columns:1fr}}.account-card{text-align:left;cursor:pointer;border:2px solid #0000;padding:16px;transition:border-color .15s,box-shadow .15s}.account-card:hover{border-color:var(--border)}.account-card-head{align-items:center;gap:10px;margin-bottom:10px;display:flex}.account-card-icon{background:var(--navy-100,#e7f0f7);width:36px;height:36px;color:var(--navy,#1b4d7a);border-radius:10px;justify-content:center;align-items:center;display:flex}.account-card-name{color:var(--navy-900,#15324f);font-size:13px;font-weight:700;line-height:1.3}.account-card-balance{margin-bottom:8px;font-size:22px;font-weight:800}.account-card-meta{justify-content:space-between;gap:8px;font-size:12px;font-weight:600;display:flex}.table{border-collapse:collapse;width:100%}.table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap;padding:12px 16px;font-size:11.5px;font-weight:700}.table td{border-bottom:1px solid var(--border);padding:13px 16px;font-size:14px}.table tbody tr:last-child td{border-bottom:none}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.mono{font-variant-numeric:tabular-nums}.row{align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.spacer{flex:1}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state svg{opacity:.4;width:46px;height:46px;margin-bottom:12px}:root{--bg:#eef2f7;--radius:14px;--radius-sm:10px;--shadow-sm:0 1px 2px #102a400d, 0 2px 8px #102a400a;--shadow:0 8px 24px #102a4014;--topbar-h:68px}body{background:var(--bg)}.app-shell .sidebar{background:linear-gradient(185deg,#0f2a40 0%,#0a1c2b 100%);border-right:1px solid #ffffff0f;box-shadow:4px 0 24px #0a1c2b1f}.app-shell .sidebar-logo{background:0 0;border-bottom:1px solid #ffffff14;justify-content:center;align-items:center;padding:18px 20px 12px;display:flex}.app-shell .sidebar-logo img{object-fit:contain;object-position:center;width:100%;max-width:100%;height:auto;max-height:48px;box-shadow:none;filter:brightness(0)invert();background:0 0;border:none;border-radius:0;padding:0;display:block}.app-shell .sidebar-nav{padding:12px 10px}.app-shell .sidebar .nav-item{color:#ffffffd1;border-radius:var(--radius-sm);margin-bottom:3px;padding:11px 12px;font-size:14px;font-weight:600}.app-shell .sidebar .nav-item svg{color:currentColor;stroke:currentColor;opacity:1;flex-shrink:0}.app-shell .sidebar .nav-item:hover{color:#fff;background:#ffffff1a}.app-shell .sidebar .nav-item.active{color:#fff;box-shadow:inset 3px 0 0 0 var(--red);background:#ffffff24}.app-shell .sidebar .nav-item.active svg{color:#fff;stroke:#fff;opacity:1}.app-shell .sidebar-foot{background:#00000038;border-top:1px solid #ffffff1a;padding:12px 12px 16px}.app-shell .sidebar .sidebar-profile-card{background:#ffffff0f;border-color:#ffffff1f}.app-shell .sidebar .sidebar-profile-name{color:#fff}.app-shell .sidebar .sidebar-profile-dot{color:#fff6}.app-shell .sidebar .sidebar-profile-role{color:#ffffff8c}.app-shell .sidebar .sidebar-profile-email{color:#ffffffb8;background:#00000038;border-color:#ffffff1a}.app-shell .sidebar .sidebar-profile-signout{color:#ffb4a8;background:#ffffff0f;border-color:#ffffff24;align-self:center;height:36px;min-height:0}.app-shell .sidebar .sidebar-profile-signout:hover{color:#fff;background:#c0392b61;border-color:#ffa09666}.topbar{height:var(--topbar-h);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#ffffffeb;gap:20px;padding:0 32px}.topbar-title{min-width:0}.topbar h1{letter-spacing:-.03em;font-size:1.25rem;font-weight:800;line-height:1.2}.topbar-desc{color:var(--text-muted);margin:2px 0 0;font-size:13px;font-weight:500}.topbar-status{background:var(--green-bg);color:var(--green);border:1px solid #1f9d6333;padding:6px 12px;font-size:11.5px;font-weight:600}.topbar-status:before{background:var(--green);animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.45}}.content{background:radial-gradient(ellipse 90% 60% at 100% -10%, #1b4d7a0d, transparent 55%), radial-gradient(ellipse 70% 50% at 0% 100%, #a4283a08, transparent 50%), var(--bg);max-width:1320px;padding:28px 32px 48px}.page-head{border-bottom:1px solid var(--border);align-items:center;margin-bottom:28px;padding-bottom:22px}.page-head .titles h2{letter-spacing:-.035em;font-size:1.65rem;font-weight:800;line-height:1.2}.page-head .titles p,.page-lead{color:var(--text-soft);max-width:52ch;margin-top:6px;font-size:14.5px;line-height:1.5}.card{border-radius:var(--radius);border-color:var(--border);box-shadow:var(--shadow-sm);transition:box-shadow .2s,border-color .2s}.card:hover{box-shadow:var(--shadow-sm)}.card.stat{border-left:3px solid var(--border);padding:20px 22px;transition:transform .2s,box-shadow .2s}.card.stat:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.card.stat:has(.ico-navy){border-left-color:var(--navy)}.card.stat:has(.ico-green){border-left-color:var(--green)}.card.stat:has(.ico-red){border-left-color:var(--red)}.card.stat:has(.ico-amber){border-left-color:var(--amber)}.stat .stat-ico{border-radius:12px;width:42px;height:42px}.stat .stat-value{letter-spacing:-.03em;font-size:1.65rem;font-weight:800}.section-title{background:linear-gradient(180deg, var(--surface-2) 0%, var(--surface) 100%);padding:18px 22px}.section-title h3{letter-spacing:-.02em;font-size:15px;font-weight:700}.table th{letter-spacing:.06em;background:var(--surface-2);border-bottom:1px solid var(--border-strong);padding:14px 18px;font-size:11px}.table td{vertical-align:middle;padding:14px 18px;font-size:14px}.table tbody tr{transition:background .12s}.table tbody tr:hover{background:var(--navy-50)}.q-number{color:var(--navy);font-variant-numeric:tabular-nums;font-weight:700}.cust-cell strong{color:var(--navy-900);font-weight:600}.cust-cell span{color:var(--text-muted);margin-top:2px;font-size:12.5px;display:block}.toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:14px 16px}.search-box .input{background:var(--surface-2);border-radius:var(--radius-sm);border-color:#0000;padding:10px 12px 10px 38px;font-size:14px}.search-box .input:focus{background:var(--surface);border-color:var(--navy-600)}.tabs{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);border-bottom:none;flex-wrap:wrap;gap:4px;margin-bottom:24px;padding:5px;display:inline-flex}.tab{border-radius:var(--radius-sm);color:var(--text-soft);border:none;margin-bottom:0;padding:10px 18px;font-size:13.5px;font-weight:600}.tab.active{background:var(--navy);color:#fff;box-shadow:0 2px 8px #1b4d7a40}.input,.select,.textarea{border-radius:var(--radius-sm);padding:10px 13px;font-size:14px}.field label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:12px}.btn{border-radius:var(--radius-sm);padding:10px 18px;font-weight:600;box-shadow:0 1px 2px #102a400a}.btn-primary{box-shadow:0 2px 8px #1b4d7a47}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #1b4d7a52}.btn-primary:active{transform:translateY(0)}.empty-state{padding:48px 24px}.empty-state svg{color:var(--navy-600);opacity:.35;margin-bottom:16px}.empty-state p{color:var(--text-soft);max-width:36ch;margin:0 auto;font-size:14.5px;line-height:1.55}.kpi-strip .card.stat{border-left-width:3px}.account-card{border-radius:var(--radius);transition:transform .2s,box-shadow .2s,border-color .2s}.account-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.account-card.selected{border-color:var(--navy);box-shadow:0 0 0 3px #1b4d7a1f}.editor-head{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:22px;padding:16px 20px}@media (width<=960px){.app-shell .sidebar.open{background:linear-gradient(185deg,#0f2a40 0%,#0a1c2b 100%)}.app-shell .sidebar-logo img{max-height:42px}.content{padding:20px 16px 32px}.topbar{padding:0 16px}.page-head .titles h2{font-size:1.35rem}}.login-wrap{background:radial-gradient(1200px 600px at 100% 0%, #a4283a14, transparent 60%), radial-gradient(1000px 500px at 0% 100%, #1b4d7a1a, transparent 55%), var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:920px;box-shadow:var(--shadow-lg);grid-template-columns:1.05fr 1fr;display:grid;overflow:hidden}.login-brand{color:#fff;background:linear-gradient(150deg, var(--navy) 0%, var(--navy-900) 60%, #0b1f30 100%);flex-direction:column;justify-content:space-between;padding:40px 36px;display:flex;position:relative;overflow:hidden}.login-brand:before{content:"";background:radial-gradient(circle,#a4283a73,#0000 70%);border-radius:50%;width:280px;height:280px;position:absolute;top:-90px;right:-90px}.login-brand-inner{z-index:1;position:relative}.login-logo-badge{background:#fff;border-radius:12px;margin-bottom:26px;padding:14px 16px;display:inline-block;box-shadow:0 10px 24px #0000002e}.login-logo-badge img{width:210px;max-width:100%;height:auto;display:block}.login-brand h2{color:#fff;margin-bottom:12px;font-size:24px;line-height:1.25}.login-brand p{color:#ffffffd1;max-width:330px;font-size:14.5px;line-height:1.55}.login-points{flex-direction:column;gap:12px;margin:26px 0 0;padding:0;list-style:none;display:flex}.login-points li{color:#ffffffeb;align-items:center;gap:10px;font-size:14px;display:flex}.login-points svg{color:#fff;background:#ffffff2e;border-radius:50%;width:24px;height:24px;padding:4px}.login-brand-foot{z-index:1;letter-spacing:.12em;text-transform:uppercase;color:#fff9;margin-top:30px;font-size:12px;position:relative}.login-form-side{flex-direction:column;padding:44px 40px;display:flex}.login-mobile-logo{width:180px;height:auto;margin:0 auto 22px;display:none}.login-form-head h1{font-size:26px}.login-form-head p{color:var(--text-soft);margin-top:6px;font-size:14px}.login-form{flex-direction:column;flex:1;gap:16px;margin-top:26px;display:flex}.pass-wrap{position:relative}.pass-wrap .input{padding-right:44px}.pass-toggle{width:32px;height:32px;color:var(--text-muted);background:0 0;border:none;border-radius:7px;place-items:center;display:grid;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.pass-toggle:hover{background:var(--surface-2);color:var(--navy)}.login-error{background:var(--red-100);color:var(--red);border-radius:var(--radius-sm);border:1px solid #a4283a40;align-items:center;gap:8px;padding:10px 12px;font-size:13.5px;font-weight:600;display:flex}.login-submit{margin-top:4px;padding:12px;font-size:15px}.login-hint{color:var(--text-muted);background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:7px;padding:9px;font-size:12.5px;display:flex}.login-foot{text-align:center;color:var(--text-muted);margin-top:22px;font-size:12px}@media (width<=760px){.login-card{grid-template-columns:1fr;max-width:440px}.login-brand{display:none}.login-mobile-logo{display:block}.login-form-side{padding:32px 24px}}.sidebar-profile-card{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);overflow:hidden}.sidebar-profile{align-items:stretch;gap:10px;min-height:52px;padding:10px 10px 10px 12px;display:flex}.sidebar-profile-avatar{background:linear-gradient(135deg, var(--navy), var(--red));color:#fff;border-radius:9px;flex-shrink:0;align-self:center;place-items:center;width:36px;height:36px;font-size:11px;font-weight:800;display:grid}.sidebar-profile-body{flex-direction:column;flex:1;justify-content:center;gap:5px;min-width:0;display:flex}.sidebar-profile-row{align-items:baseline;gap:4px;min-width:0;line-height:1.2;display:flex}.sidebar-profile-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:12.5px;font-weight:700;overflow:hidden}.sidebar-profile-dot{color:var(--text-muted);flex-shrink:0;font-size:11px}.sidebar-profile-role{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:11px;font-weight:600;overflow:hidden}.sidebar-profile-email{box-sizing:border-box;width:100%;color:var(--text-soft);white-space:nowrap;text-overflow:ellipsis;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:11px;font-weight:500;line-height:1.3;display:block;overflow:hidden}.sidebar-profile-signout{border:1px solid var(--border);background:var(--surface-2);width:36px;min-height:36px;color:var(--red);border-radius:9px;flex-shrink:0;align-self:stretch;place-items:center;padding:0;transition:background .14s,border-color .14s,color .14s;display:grid}.sidebar-profile-signout:hover{background:var(--red-100);color:var(--red);border-color:#c0392b59}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;height:100vh;display:flex;position:sticky;top:0}.sidebar-logo{border-bottom:1px solid var(--border);padding:18px 22px 12px;position:relative}.sidebar-logo img{width:100%;height:auto;display:block}.sidebar-close{background:var(--surface-2);width:34px;height:34px;color:var(--text-soft);z-index:2;border:none;border-radius:8px;place-items:center;display:none;position:absolute;top:14px;right:12px}.sidebar-close:hover{background:var(--red-100);color:var(--red)}.hamburger{border:1px solid var(--border);background:var(--surface);width:40px;height:40px;color:var(--navy);border-radius:10px;place-items:center;margin-right:4px;display:none}.sidebar-overlay{display:none}.sidebar-nav{flex:1;padding:14px}.nav-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:0 10px 10px;font-size:11px;font-weight:700}.nav-item{border-radius:var(--radius-sm);color:var(--text-soft);align-items:center;gap:12px;margin-bottom:4px;padding:10px 12px;font-size:14.5px;font-weight:600;transition:all .14s;display:flex;position:relative}.nav-item:hover{background:var(--navy-50);color:var(--navy)}.nav-item.active{background:var(--navy);color:#fff;box-shadow:0 6px 16px #1b4d7a47}.sidebar-foot{border-top:1px solid var(--border);padding:12px 12px 16px}.avatar{background:linear-gradient(135deg, var(--navy), var(--red));color:#fff;letter-spacing:.5px;border-radius:10px;place-items:center;width:38px;height:38px;font-size:13px;font-weight:800;display:grid}.main{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{height:var(--topbar-h);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);z-index:20;background:#ffffffd9;align-items:center;gap:16px;padding:0 28px;display:flex;position:sticky;top:0}.topbar h1{font-size:19px}.content{width:100%;max-width:1280px;margin:0 auto;padding:28px}.notif{position:relative}.notif-btn{border:1px solid var(--border);background:var(--surface);width:40px;height:40px;color:var(--text-soft);border-radius:10px;place-items:center;transition:all .14s;display:grid;position:relative}.notif-btn:hover{background:var(--navy-50);color:var(--navy);border-color:var(--navy-100)}.notif-btn.has-alerts{color:var(--navy)}.notif-dot{background:var(--red);color:#fff;border:2px solid var(--surface);border-radius:100px;place-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;line-height:1;display:grid;position:absolute;top:-5px;right:-5px}.notif-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:360px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-lg);z-index:60;animation:.16s pop;position:absolute;top:calc(100% + 12px);right:0;overflow:hidden}.notif-head{border-bottom:1px solid var(--border);color:var(--navy-900);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-list{max-height:380px;overflow-y:auto}.notif-group{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);padding:9px 16px;font-size:11px;font-weight:700}.notif-item{text-align:left;border:none;border-bottom:1px solid var(--border);background:var(--surface);align-items:flex-start;gap:10px;width:100%;padding:12px 16px;transition:background .12s;display:flex}.notif-ic{background:var(--navy-50);width:26px;height:26px;color:var(--navy);border-radius:7px;flex-shrink:0;place-items:center;display:grid}.notif-item:hover{background:var(--navy-50)}.notif-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.notif-meta{color:var(--text-muted);align-items:center;gap:5px;margin-top:3px;font-size:12.5px;display:flex}.notif-late{color:var(--red);background:var(--red-100);white-space:nowrap;border-radius:100px;flex-shrink:0;padding:3px 8px;font-size:11.5px;font-weight:700}.notif-empty{text-align:center;color:var(--text-muted);padding:34px 20px}.notif-empty svg{color:var(--green);margin-bottom:8px}.notif-empty p{font-size:13.5px}.notif-foot{background:var(--surface-2);width:100%;color:var(--navy);border:none;padding:12px;font-size:13.5px;font-weight:600;transition:background .12s}.notif-foot:hover{background:var(--navy-50)}.kpi-strip{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:20px;display:grid}.tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:20px;display:flex}.tab{color:var(--text-soft);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:11px 18px;font-size:14px;font-weight:600;transition:all .14s}.tab:hover{color:var(--navy);background:var(--surface-2)}.tab.active{background:var(--navy);color:#fff;border-bottom-color:#0000;box-shadow:0 2px 8px #1b4d7a40}.tab.active:hover{color:#fff;background:var(--navy-600)}.seg{grid-template-columns:1fr 1fr;gap:8px;display:grid}.seg-btn{border:2px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-soft);justify-content:center;align-items:center;gap:8px;padding:11px;font-weight:600;transition:all .14s;display:flex}.seg-btn.active-in{border-color:var(--green);background:var(--green-bg);color:var(--green)}.seg-btn.active-out{border-color:var(--red);background:var(--red-100);color:var(--red)}.bar-row{margin-bottom:14px}.bar-head{color:var(--text);justify-content:space-between;margin-bottom:6px;font-size:13.5px;font-weight:600;display:flex}.bar-track{background:var(--gray-bg);border-radius:100px;height:8px;overflow:hidden}.bar-fill{background:linear-gradient(90deg, var(--navy), var(--red));border-radius:100px;height:100%}.pl-card{max-width:720px}.pl-head{border-bottom:1px solid var(--border);padding:22px 24px}.pl-head h3{font-size:17px}.pl-section{border-bottom:1px solid var(--border);padding:16px 24px}.pl-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:10px;font-size:12px;font-weight:700}.pl-line{color:var(--text-soft);justify-content:space-between;padding:7px 0;font-size:14px;display:flex}.pl-line.muted{color:var(--text-muted);font-style:italic}.pl-line.total{border-top:1px solid var(--border);color:var(--navy-900);margin-top:6px;padding-top:12px;font-size:15px;font-weight:700}.pl-net{border-radius:var(--radius);background:var(--navy);color:#fff;justify-content:space-between;align-items:center;margin:18px 24px;padding:16px 20px;font-size:18px;font-weight:800;display:flex}.pl-net.loss{background:var(--red)}@media (width<=920px){.kpi-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=560px){.kpi-strip{grid-template-columns:1fr}}.overdue-bar{border-radius:var(--radius);background:linear-gradient(100deg, var(--red), var(--red-700));color:#fff;align-items:center;gap:14px;margin-bottom:22px;padding:14px 18px;animation:.25s slideDown;display:flex;box-shadow:0 8px 22px #a4283a47}.ob-icon{background:#ffffff2e;border-radius:10px;flex-shrink:0;place-items:center;width:40px;height:40px;display:grid}.ob-text{flex-direction:column;flex:1;min-width:0;line-height:1.35;display:flex}.ob-text strong{color:#fff;font-size:15px}.ob-text span{color:#ffffffd9;white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.ob-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.ob-close{color:#ffffffe6;background:0 0;border:none;border-radius:8px;place-items:center;width:34px;height:34px;transition:background .14s;display:grid}.ob-close:hover{background:#ffffff2e}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}}.alert-banner{border-radius:var(--radius);background:var(--red-100);color:var(--red-700);border:1px solid #a4283a40;align-items:center;gap:12px;margin-bottom:18px;padding:14px 18px;font-size:14px;display:flex}.alert-banner svg{color:var(--red);flex-shrink:0}.info-cell{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);align-items:center;gap:11px;padding:12px 14px;display:flex}.info-cell svg{color:var(--navy);flex-shrink:0}.info-cell span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:11.5px;font-weight:600;display:block}.info-cell strong{color:var(--text);font-size:14px;font-weight:600;display:block}.page-head{align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.page-head .titles h2{font-size:22px}.page-head .titles p{color:var(--text-soft);margin-top:4px;font-size:14px}.stat-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:22px;display:grid}@media (width<=920px){.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=560px){.stat-grid{grid-template-columns:1fr}}.stat{padding:18px 20px}.stat .stat-top{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.stat .stat-label{color:var(--text-soft);font-size:13px;font-weight:600}.stat .stat-ico{border-radius:10px;place-items:center;width:38px;height:38px;display:grid}.stat .stat-value{color:var(--navy-900);letter-spacing:-.02em;overflow-wrap:anywhere;font-size:clamp(20px,2.2vw,26px);font-weight:800;line-height:1.15}.stat .stat-sub{color:var(--text-muted);margin-top:3px;font-size:12.5px}.ico-navy{background:var(--navy-50);color:var(--navy)}.ico-red{background:var(--red-100);color:var(--red)}.ico-green{background:var(--green-bg);color:var(--green)}.ico-amber{background:var(--amber-bg);color:var(--amber)}.grid-2{grid-template-columns:1.5fr 1fr;gap:16px;display:grid}.section-title{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.section-title h3{font-size:15.5px}.toolbar{align-items:center;gap:10px;margin-bottom:18px;display:flex}.search-box{flex:1;max-width:360px;position:relative}.search-box svg{color:var(--text-muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-box input{padding-left:36px}.customer-picker{position:relative}.customer-picker-trigger{text-align:left;cursor:pointer;background:var(--surface);justify-content:space-between;align-items:center;gap:10px;width:100%;display:flex}.customer-picker-trigger span{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.customer-picker-trigger svg.flip{flex-shrink:0;transform:rotate(180deg)}.customer-picker-panel{z-index:40;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:8px;animation:.16s pop;position:absolute;top:calc(100% + 6px);left:0;right:0}.customer-picker-search{max-width:none;margin-bottom:6px}.customer-picker-list{max-height:240px;margin:0;padding:0;list-style:none;overflow-y:auto}.customer-picker-option{border-radius:var(--radius-sm);text-align:left;cursor:pointer;width:100%;color:var(--text-soft);background:0 0;border:none;align-items:center;gap:10px;padding:9px 10px;transition:background .12s;display:flex}.customer-picker-option:hover,.customer-picker-option.active{background:var(--navy-50);color:var(--navy)}.customer-picker-option strong{color:var(--text);font-size:13.5px;font-weight:600;display:block}.customer-picker-option span{color:var(--text-muted);margin-top:1px;font-size:12px;display:block}.customer-picker-option svg{color:var(--navy);flex-shrink:0;margin-left:auto}.customer-picker-empty{color:var(--text-muted);text-align:center;padding:12px 10px;font-size:13px}.table .status-cell{vertical-align:middle;min-width:120px;position:relative}.status-picker.open{z-index:50}.status-picker{display:inline-block;position:relative}.status-picker-trigger{cursor:pointer;border:none;transition:opacity .12s,transform .12s}.status-picker-trigger:hover{opacity:.92}.status-picker-trigger svg{opacity:.75;margin-left:2px}.status-picker-trigger svg.flip{transform:rotate(180deg)}.status-picker-menu{z-index:40;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:168px;box-shadow:var(--shadow-lg);padding:6px;animation:.14s pop;position:absolute;top:calc(100% + 6px);left:0}.status-picker-item{border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:none;width:100%;padding:6px 8px;display:flex}.status-picker-item:hover,.status-picker-item.active{background:var(--navy-50)}.customer-details-readonly{display:contents}.customer-details-readonly>.field:first-child{border-top:1px solid var(--border);grid-column:1/-1;margin-top:4px;padding-top:14px}.customer-details-readonly p{color:var(--text);margin:0;font-size:14px;line-height:1.45}.q-number{color:var(--navy);font-weight:700}.cust-cell strong{color:var(--text);display:block}.cust-cell span{color:var(--text-muted);font-size:12.5px}.actions-cell{justify-content:flex-end;gap:6px;display:flex}.icon-btn{border:1px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--text-soft);border-radius:8px;place-items:center;transition:all .14s;display:grid}.icon-btn:hover{border-color:var(--navy);color:var(--navy);background:var(--navy-50)}.icon-btn.danger:hover{border-color:var(--red);color:var(--red);background:var(--red-100)}.editor-head{align-items:center;gap:14px;margin-bottom:20px;display:flex}.editor-head .q-title{color:var(--navy-900);font-size:22px;font-weight:800}.editor-grid{grid-template-columns:1fr 300px;align-items:start;gap:18px;display:grid}@media (width<=1080px){.editor-grid{grid-template-columns:1fr}}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-grid .full{grid-column:1/-1}.lines-table{border-collapse:collapse;width:100%}.lines-table th{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);text-align:left;border-bottom:2px solid var(--border);padding:10px 8px;font-size:11px;font-weight:700}.lines-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:6px}.lines-table .num-col{width:70px}.lines-table .price-col{width:110px}.lines-table .tax-col{width:90px}.lines-table .total-col{text-align:right;width:120px}.lines-table .drag-col{width:30px;color:var(--text-muted);text-align:center;font-weight:700}.lines-table .del-col{width:38px}.line-input{background:0 0;border:1px solid #0000;border-radius:6px;width:100%;padding:7px 8px;transition:all .12s}.line-input:hover{background:var(--surface-2)}.line-input:focus{background:var(--surface);border-color:var(--navy-600);outline:none;box-shadow:0 0 0 3px #2261991a}.line-product{font-weight:600}.line-total{text-align:right;color:var(--navy-900);font-variant-numeric:tabular-nums;padding:9px 8px;font-weight:700}.add-line-row td{border-bottom:none;padding:12px 6px}.totals-row{color:var(--text-soft);justify-content:space-between;padding:9px 0;font-size:14px;display:flex}.totals-row.grand{border-top:2px solid var(--border);color:var(--navy-900);margin-top:6px;padding-top:14px;font-size:18px;font-weight:800}.totals-row.due{color:var(--red);font-weight:700}.totals-row .val{font-variant-numeric:tabular-nums;color:var(--text);font-weight:700}.side-card-pad{padding:18px}.side-card-pad h4{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:14px;font-size:13px}.pay-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;font-size:13.5px;display:flex}.pay-item:last-child{border-bottom:none}.pay-item .pay-amt{color:var(--green);font-weight:700}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;padding:max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));background:#102a4073;justify-content:center;align-items:center;animation:.15s fade;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-lg);margin:auto;animation:.18s pop;overflow:hidden}.modal--tall{flex-direction:column;max-height:min(92vh,880px);display:flex}.modal--tall .modal-body{-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow-y:auto}.modal-head{flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 20px 8px;display:flex}.modal-head h3{font-size:18px}.modal-sub{color:var(--text-soft);margin-top:4px;font-size:13.5px;line-height:1.4}.modal-body{padding:12px 20px 16px}.modal--tall .modal-body{padding:12px 20px}.modal-footer{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;padding:12px 20px 18px}.modal-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.modal-actions .btn{min-width:108px}.modal-form-scroll{flex-direction:column;gap:14px;display:flex}.pay-choice{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px;display:grid}.pay-opt{border:2px solid var(--border-strong);border-radius:var(--radius);text-align:left;background:var(--surface);padding:16px;transition:all .14s}.pay-opt:hover{border-color:var(--navy-600)}.pay-opt.selected{border-color:var(--navy);background:var(--navy-50)}.pay-opt .po-title{color:var(--navy-900);align-items:center;gap:8px;margin-bottom:4px;font-weight:700;display:flex}.pay-opt .po-desc{color:var(--text-soft);font-size:12.5px}.summary-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:16px;padding:14px 16px}.summary-box .sb-row{color:var(--text-soft);justify-content:space-between;padding:4px 0;font-size:13.5px;display:flex}.summary-box .sb-row.total{color:var(--navy-900);border-top:1px dashed var(--border-strong);margin-top:6px;padding-top:8px;font-weight:700}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px)scale(.98)}}.dot{border-radius:50%;width:8px;height:8px;margin-right:7px;display:inline-block}.dot-high{background:var(--red)}.dot-medium{background:var(--amber)}.dot-low{background:var(--green)}.task-check{border:2px solid var(--border-strong);background:var(--surface);color:#0000;border-radius:6px;flex-shrink:0;place-items:center;width:20px;height:20px;display:grid}.task-check.done{background:var(--green);border-color:var(--green);color:#fff}.task-title.done{color:var(--text-muted);text-decoration:line-through}@media (width<=920px){.grid-2{grid-template-columns:1fr}}@media (width<=1024px){.content{padding:22px}}@media (width<=860px){.sidebar{z-index:90;width:280px;max-width:84vw;height:100vh;box-shadow:var(--shadow-lg);transition:transform .26s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar.open .sidebar-close{display:grid}.sidebar.open .sidebar-logo{padding-right:56px}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:85;background:#102a4073;animation:.2s fade;display:block;position:fixed;inset:0}.hamburger{display:grid}.topbar{padding:0 16px}.topbar h1{font-size:17px}.topbar-status{display:none}}@media (width<=720px){.content{padding:16px}.form-grid{grid-template-columns:1fr}.page-head{flex-wrap:wrap}.page-head .titles h2{font-size:20px}.card{overflow-x:auto}.table{min-width:560px}.lines-table{min-width:640px}.toolbar{flex-wrap:wrap}.search-box{flex:100%;max-width:100%}.tabs{flex-wrap:nowrap;overflow-x:auto}.tab{white-space:nowrap}.modal-body{padding:12px 16px 14px}.modal-footer{padding:12px 16px 16px}.modal-actions{flex-direction:column-reverse;align-items:stretch}.modal-actions .btn{justify-content:center;width:100%;min-width:0}.pay-choice{grid-template-columns:1fr}}@media (width<=480px){.content{padding:13px}.page-head .btn{width:100%}.notif-panel{width:auto;position:fixed;top:70px;left:12px;right:12px}}.role-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.role-card{flex-direction:column;display:flex}.role-card-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.role-modules{flex-wrap:wrap;gap:6px;margin-top:auto;display:flex}.perm-chip{color:var(--navy-900,#15324f);background:var(--navy-100,#e7f0f7);border-radius:999px;align-items:center;gap:5px;padding:4px 9px;font-size:12px;font-weight:600;display:inline-flex}.perm-chip svg{color:var(--navy,#1b4d7a)}.perm-chip-count{color:var(--green,#1f9d63);background:#fff;border-radius:999px;padding:1px 6px;font-size:10.5px;font-weight:700}.perm-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.perm-checkbox{cursor:pointer;align-items:center;gap:8px;font-size:13px;display:inline-flex}.perm-checkbox input[type=checkbox]{cursor:pointer;width:17px;height:17px;accent-color:var(--navy,#1b4d7a);flex-shrink:0}.perm-all{color:var(--navy,#1b4d7a);font-size:12.5px;font-weight:600}.modal-error{color:var(--red);margin:0 0 10px;font-size:13px;font-weight:600;line-height:1.35}.role-modal-matrix{max-height:none}.modal--tall .role-modal-matrix{-webkit-overflow-scrolling:touch;max-height:min(42vh,360px);overflow:auto}.perm-matrix-wrap{border:1px solid var(--border,#e4e9f0);background:#fff;border-radius:12px;overflow-x:auto}.perm-matrix{border-collapse:collapse;width:100%;font-size:13px}.perm-matrix thead th{background:var(--neutral-50,#f8fafc);color:var(--text-muted,#6b7a8c);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--border,#e4e9f0);padding:12px 10px;font-size:11px;font-weight:700}.perm-matrix-mod{text-align:left;min-width:160px;padding-left:14px!important}.perm-matrix-col{text-align:center;width:88px}.perm-matrix-th{cursor:pointer;flex-direction:column;align-items:center;gap:6px;font-weight:700;display:inline-flex}.perm-matrix-th input{margin:0}.perm-matrix tbody tr{border-bottom:1px solid var(--border,#eef2f7)}.perm-matrix tbody tr:last-child{border-bottom:none}.perm-matrix tbody td{vertical-align:middle;padding:11px 10px}.perm-matrix-row-label{letter-spacing:.04em;text-transform:uppercase;color:var(--navy-900,#15324f);cursor:pointer;align-items:center;gap:8px;font-size:12.5px;font-weight:700;display:inline-flex}.perm-matrix-row-label input{flex-shrink:0}.perm-matrix-row-label svg{color:var(--navy,#1b4d7a);opacity:.85}.perm-matrix-cell{text-align:center}.perm-matrix-cell input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--navy,#1b4d7a)}
