: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)}.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{transition:background .12s}.table tbody tr:hover{background:var(--navy-50)}.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}.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}}.user-menu-divider{background:var(--border);height:1px;margin:6px 2px}.user-menu-item.signout strong{color:var(--red)}.signout-ic{background:var(--red-100);width:30px;height:30px;color:var(--red);border-radius:8px;flex-shrink:0;place-items:center;display:grid}.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:22px 22px 18px;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:18px 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:14px}.user-chip{border-radius:var(--radius-sm);align-items:center;gap:11px;padding:8px 10px;display:flex}.user-chip:hover{background:var(--surface-2)}.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}.user-chip strong{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;display:block;overflow:hidden}.user-chip span{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;display:block;overflow:hidden}.user-switch{position:relative}.user-switch .user-chip{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);width:100%;color:var(--text-soft)}.user-switch .user-chip:hover{border-color:var(--navy);background:var(--navy-50)}.user-switch .user-chip svg.flip{transform:rotate(180deg)}.user-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:50;max-height:320px;padding:8px;animation:.16s pop;position:absolute;bottom:calc(100% + 8px);left:0;right:0;overflow-y:auto}.user-menu-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:4px 8px 8px;font-size:11px;font-weight:700}.user-menu-item{border-radius:var(--radius-sm);width:100%;color:var(--text-soft);background:0 0;border:none;align-items:center;gap:10px;padding:8px;transition:background .12s;display:flex}.user-menu-item:hover{background:var(--surface-2)}.user-menu-item.active{background:var(--navy-50);color:var(--navy)}.user-menu-item strong{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;display:block;overflow:hidden}.user-menu-item span{color:var(--text-muted);font-size:12px;display:block}.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(auto-fit,minmax(200px,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)}.tab.active{color:var(--navy);border-bottom-color:var(--navy)}.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,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(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:22px;display:grid}.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}.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;background:#102a4073;place-items:center;padding:20px;animation:.15s fade;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-lg);animation:.18s pop;overflow:hidden}.modal-head{justify-content:space-between;align-items:flex-start;padding:22px 22px 6px;display:flex}.modal-head h3{font-size:18px}.modal-sub{color:var(--text-soft);margin-top:4px;font-size:13.5px}.modal-body{padding:16px 22px 24px}.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:14px 18px 20px}.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}.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)}
