:root{--bg:#f4f7fb;--panel:#fff;--ink:#172033;--muted:#64748b;--blue:#2563eb;--blue2:#0ea5e9;--green:#16a34a;--red:#dc2626;--amber:#f59e0b;--line:#e2e8f0;--shadow:0 16px 45px rgba(15,23,42,.10);--side:#111827;--side2:#172554}
*{box-sizing:border-box}body{margin:0;background:linear-gradient(135deg,#f8fbff,#eef4ff);color:var(--ink);font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;font-size:14px}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;z-index:20;inset:0 auto 0 0;width:268px;background:linear-gradient(180deg,var(--side),var(--side2));color:#dbeafe;overflow:auto;padding:16px 14px;transition:.22s;width:268px}.brand-block{display:flex;gap:10px;align-items:center;padding:10px 8px 18px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:12px}.brand-icon{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,#60a5fa,#1d4ed8);font-weight:900;font-size:22px;color:#fff;box-shadow:0 12px 24px rgba(37,99,235,.35)}.brand-text b{display:block;font-size:17px;color:#fff}.brand-text small{display:block;color:#a8c7ff;margin-top:2px}.menu p{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#93a4c7;margin:18px 10px 7px}.menu a{position:relative;display:flex;align-items:center;gap:10px;color:#eef5ff;text-decoration:none;padding:10px 11px;border-radius:14px;margin:3px 0;transition:.15s}.menu a:hover,.menu a.active{background:rgba(255,255,255,.10);transform:translateX(2px)}.mi{width:25px;height:25px;display:grid;place-items:center;border-radius:9px;background:rgba(255,255,255,.11);font-size:14px;flex:none}.main-area{margin-left:268px;flex:1;min-width:0;transition:.22s}.topbar{height:74px;background:rgba(255,255,255,.82);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}.page-title h1{margin:0;font-size:22px;font-weight:800}.page-title small,.muted{color:var(--muted)}.icon-btn{width:42px;height:42px;border-radius:13px;border:1px solid var(--line);background:#fff;box-shadow:0 8px 20px rgba(15,23,42,.08);cursor:pointer;font-weight:800}.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.fy-switcher{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);padding:6px 8px;border-radius:14px}.fy-switcher label{font-weight:800;color:#334155}.fy-switcher select{border:0;margin:0;padding:5px;background:transparent}.user-chip{display:flex;align-items:center;gap:7px;background:#eff6ff;color:#1d4ed8;font-weight:700;border-radius:999px;padding:8px 12px}.content{padding:24px}.card{background:var(--panel);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:20px;margin-bottom:18px}.card h2{margin:0 0 16px;font-size:18px}.card-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.kpis{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:18px}.kpi{background:#fff;border:1px solid var(--line);border-radius:21px;padding:18px;box-shadow:var(--shadow);position:relative;overflow:hidden}.kpi:before{content:"";position:absolute;right:-18px;top:-18px;width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,rgba(37,99,235,.16),rgba(14,165,233,.04))}.kpi small{display:block;color:var(--muted);font-weight:700}.kpi b{display:block;font-size:24px;margin-top:7px}.quick-vouchers{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.voucher-tile{display:flex;align-items:center;gap:12px;text-decoration:none;background:linear-gradient(135deg,#fff,#f0f7ff);border:1px solid #dbeafe;color:#172033;border-radius:18px;padding:16px;box-shadow:0 10px 24px rgba(37,99,235,.09)}.voucher-tile strong{display:block}.voucher-tile span{width:38px;height:38px;display:grid;place-items:center;border-radius:14px;background:#2563eb;color:#fff;font-weight:900}.form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:13px}.form.two{grid-template-columns:repeat(2,minmax(0,1fr))}.form label{font-weight:750;color:#475569;font-size:12px}.span-2{grid-column:span 2}.span-4{grid-column:span 4}input,select,textarea{display:block;width:100%;border:1px solid var(--line);border-radius:12px;padding:10px 11px;background:#fff;margin-top:6px;color:var(--ink);outline:none}input:focus,select:focus,textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 4px rgba(59,130,246,.11)}textarea{min-height:72px;resize:vertical}.check-row{display:flex!important;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:9px 12px;margin-top:20px}.check-row input{width:auto;margin:0}.btn,.primary,.danger-soft,.icon-action{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;gap:7px;border-radius:12px;border:1px solid var(--line);padding:9px 13px;font-weight:800;cursor:pointer;background:#fff;color:var(--ink)}.primary{background:linear-gradient(135deg,#2563eb,#0ea5e9);border-color:#2563eb;color:#fff}.danger-soft{background:#fff1f2;color:#be123c;border-color:#fecdd3}.tiny{padding:7px 10px;font-size:12px}.large{padding:12px 20px}.actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.tablebox{overflow:auto;border:1px solid var(--line);border-radius:16px;background:#fff}.data-table{width:100%;border-collapse:separate;border-spacing:0;min-width:820px;background:#fff}.data-table th,.data-table td{border-bottom:1px solid var(--line);padding:10px 12px;text-align:left;white-space:nowrap}.data-table th{background:#f8fbff;font-size:12px;color:#475569;text-transform:capitalize;position:sticky;top:0}.data-table tr:hover td{background:#fbfdff}.action-col{width:105px}.row-actions{display:flex;gap:6px;align-items:center}.row-actions form{display:inline}.icon-action{width:34px;height:34px;padding:0;border-radius:11px}.icon-action.edit{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.icon-action.delete{background:#fff1f2;color:#be123c;border-color:#fecdd3}.empty{text-align:center;color:var(--muted);padding:20px!important}.ok{background:#ecfdf5;border:1px solid #a7f3d0;color:#047857;padding:12px 14px;border-radius:14px;margin-bottom:16px;font-weight:700}.text-danger,.err{background:#fff1f2;border:1px solid #fecdd3;color:#be123c;padding:10px;border-radius:12px}.report-head{display:grid;gap:4px;text-align:center;margin-bottom:15px}.report-head h2{margin:0;font-size:22px}.report-head .report-title{font-weight:900;font-size:18px}.report-actions{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.login{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,#bfdbfe,transparent 35%),radial-gradient(circle at bottom right,#e0f2fe,transparent 32%),var(--bg)}.loginbox{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:26px;padding:30px;width:min(430px,92vw)}.loginbox h1{margin-top:0}.combo{position:relative}.combo input{margin-top:0}.combo-list{display:none;position:absolute;z-index:50;inset:auto 0 auto 0;max-height:230px;overflow:auto;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:12px;margin-top:4px}.combo.open .combo-list{display:block}.combo-item{padding:8px 10px;cursor:pointer}.combo-item:hover{background:#eff6ff}.line-total{display:flex;justify-content:flex-end;font-weight:900;gap:18px;margin-top:10px}.balanced{color:#047857}.unbalanced{color:#be123c}.collapsed .sidebar{width:76px}.collapsed .brand-text,.collapsed .mt,.collapsed .menu p{display:none}.collapsed .main-area{margin-left:76px}.collapsed .menu a{justify-content:center}.collapsed .mi{margin:0}.collapsed .menu a:hover:after{content:attr(data-tip);position:absolute;left:62px;top:8px;background:#0f172a;color:#fff;padding:6px 9px;border-radius:9px;white-space:nowrap;z-index:99;box-shadow:var(--shadow)}
@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.quick-vouchers{grid-template-columns:repeat(2,1fr)}.grid,.grid.three{grid-template-columns:1fr}.form{grid-template-columns:repeat(2,1fr)}.span-4{grid-column:span 2}.sidebar{transform:translateX(-100%)}.main-area{margin-left:0}.sidebar-open .sidebar{transform:none}.collapsed .sidebar{width:268px}.collapsed .brand-text,.collapsed .mt,.collapsed .menu p{display:block}.collapsed .main-area{margin-left:0}}
@media(max-width:680px){.content{padding:14px}.topbar{height:auto;min-height:70px;padding:12px;align-items:flex-start}.top-actions{justify-content:flex-end}.kpis,.quick-vouchers,.form{grid-template-columns:1fr}.span-2,.span-4{grid-column:span 1}.page-title h1{font-size:18px}.user-chip{display:none}.card{padding:15px;border-radius:18px}}
@media print{.sidebar,.topbar,.report-actions,.card.filter-card{display:none!important}.main-area{margin:0}.content{padding:0}.card{box-shadow:none;border:0}.data-table th,.data-table td{font-size:11px;padding:5px 7px}}

/* === Patch: collapsible main-menu/sub-menu, dashboard overflow fix, high z-index combo === */
.menu{padding-bottom:28px}.menu-single{margin-bottom:10px}.menu-group{margin:8px 0}.menu-head{position:relative;display:flex;align-items:center;gap:10px;width:100%;border:0;background:transparent;color:#eef5ff;text-align:left;padding:10px 11px;border-radius:14px;cursor:pointer;font:inherit;font-weight:800;transition:.15s}.menu-head:hover,.menu-group.open>.menu-head{background:rgba(255,255,255,.10)}.menu-head .menu-caret{margin-left:auto;color:#a8c7ff;font-size:15px;transition:.18s}.menu-group.open>.menu-head .menu-caret{transform:rotate(180deg)}.menu-sub{display:none;margin:4px 0 10px 14px;padding-left:12px;border-left:1px dashed rgba(255,255,255,.18)}.menu-group.open>.menu-sub{display:block}.menu-sub a{padding:9px 10px;margin:3px 0}.menu-sub .mi{width:24px;height:24px;font-size:13px;background:rgba(255,255,255,.08)}.collapsed .menu-sub{display:none!important}.collapsed .menu-head{justify-content:center}.collapsed .menu-head .menu-caret{display:none}.collapsed .menu-head .mi{margin:0}.collapsed .menu-head:hover:after{content:attr(data-tip);position:absolute;left:62px;top:8px;background:#0f172a;color:#fff;padding:6px 9px;border-radius:9px;white-space:nowrap;z-index:999;box-shadow:var(--shadow)}
.grid>.card{min-width:0}.dashboard-grid{align-items:start}.summary-card{overflow:hidden}.summary-table-wrap{width:100%;overflow:hidden;border:1px solid var(--line);border-radius:15px;background:#fff}.summary-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.summary-table th,.summary-table td{border-bottom:1px solid var(--line);padding:10px 12px;text-align:left}.summary-table tr:last-child td{border-bottom:0}.summary-table th{background:#f8fbff;font-size:12px;color:#475569}.summary-table td:first-child{white-space:normal;word-break:break-word}.summary-table td:last-child,.summary-table th:last-child{text-align:right;width:190px;font-weight:800;white-space:nowrap}.fast-action-card{overflow:hidden}.dashboard-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-actions .voucher-tile{min-width:0;padding:14px}.dashboard-actions .voucher-tile div{min-width:0}.dashboard-actions .voucher-tile strong,.dashboard-actions .voucher-tile small{overflow:hidden;text-overflow:ellipsis}.kpi b{word-break:break-word}.voucher-line-box{overflow-x:auto;overflow-y:visible;padding-bottom:8px}.voucher-line-box .data-table{min-width:1120px}.voucher-line-box td{position:relative}.combo{position:relative;min-width:205px}.combo-list{display:none;position:absolute;z-index:50;inset:auto 0 auto 0;max-height:230px;overflow:auto;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:12px;margin-top:4px}.combo-list.floating-combo-list{position:fixed;display:none;z-index:2147483000;max-height:280px;margin-top:0}.combo-list.floating-combo-list.is-open{display:block}.combo-item{padding:9px 11px;cursor:pointer;white-space:normal;border-bottom:1px solid #f1f5f9}.combo-item:last-child{border-bottom:0}.combo-item:hover,.combo-item.active{background:#eff6ff}.combo-empty{padding:10px;color:var(--muted)}
@media(max-width:1100px){.collapsed .menu-sub{display:block!important}.collapsed .menu-head{justify-content:flex-start}.collapsed .menu-head .menu-caret{display:block}.dashboard-actions{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:680px){.summary-table td:last-child,.summary-table th:last-child{width:130px}.dashboard-actions{grid-template-columns:1fr}.menu-sub{margin-left:10px;padding-left:10px}}
