:root{--blue:#183f91;--blue2:#2867d8;--dark:#10244d;--gold:#f5b21b;--bg:#f4f7fb;--card:#fff;--text:#172033;--muted:#6b7280;--line:#e8edf5}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}button,input,textarea,select{font:inherit}.hidden{display:none!important}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:22px;background:radial-gradient(circle at 90% 90%,#f4a51c 0,#f4a51c22 25%,transparent 45%),linear-gradient(135deg,#10244d,#235bc4)}.login-card{width:100%;max-width:480px;background:rgba(255,255,255,.92);backdrop-filter:blur(20px);border-radius:34px;padding:38px;box-shadow:0 28px 90px #0005}.mark{width:82px;height:82px;border-radius:24px;background:linear-gradient(145deg,var(--blue),#0d2d72);color:white;display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:900;margin:0 auto 20px}.login-card h1{text-align:center;margin:0;font-size:36px}.subtitle{text-align:center;color:var(--muted);font-weight:700;margin:6px 0 32px}.field{margin:14px 0}.field label{display:block;font-weight:800;margin-bottom:8px}.input{width:100%;border:1px solid var(--line);background:#fff;border-radius:18px;padding:15px 18px;outline:none;box-shadow:0 8px 20px #1d2b4f08}.input:focus{border-color:var(--blue);box-shadow:0 0 0 4px #2867d81c}.btn{border:0;border-radius:18px;padding:14px 18px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff}.btn-gold{background:var(--gold);color:#fff}.btn-danger{background:#dc2626;color:#fff}.btn-soft{background:#eef4ff;color:var(--blue)}.btn-block{width:100%}.link{border:0;background:transparent;color:var(--blue);font-weight:800;cursor:pointer}.app{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:linear-gradient(180deg,#10244d,#132b61);color:#fff;padding:22px;z-index:50}.brand{display:flex;gap:12px;align-items:center;margin-bottom:28px}.brand .brand-logo{width:52px;height:52px;border-radius:16px;background:#fff;color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:22px}.brand b{font-size:18px}.brand small{color:#b8c9ee}.nav button{width:100%;border:0;background:transparent;color:#fff;padding:13px 14px;border-radius:16px;text-align:left;font-weight:800;margin:4px 0}.nav button:hover,.nav button.active{background:#ffffff1f}.main{margin-left:280px;width:100%;padding:26px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px}.topbar h1{margin:0;font-size:30px}.topbar p{margin:4px 0 0;color:var(--muted);font-weight:600}.menu-btn{display:none}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.card{background:var(--card);border-radius:26px;padding:22px;box-shadow:0 14px 40px #1f2f5a12;border:1px solid #fff}.card small{color:var(--muted);font-weight:800}.card b{display:block;font-size:28px;margin-top:8px}.panel{background:#fff;border-radius:26px;box-shadow:0 14px 40px #1f2f5a12;overflow:hidden;margin-top:20px}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line)}.panel-head h2{margin:0}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;min-width:900px}th,td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}th{background:#f8fafc;color:#64748b;text-transform:uppercase;font-size:12px;letter-spacing:.05em}.badge{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:900}.Paid,.Approved,.Received{background:#dcfce7;color:#15803d}.Unpaid,.Pending,.Ordered{background:#fef3c7;color:#b45309}.Rejected,.Cancelled{background:#fee2e2;color:#b91c1c}.actions{display:flex;gap:6px;flex-wrap:wrap}.modal-backdrop{position:fixed;inset:0;background:#07132799;z-index:100;display:flex;align-items:center;justify-content:center;padding:18px}.modal{width:100%;max-width:920px;max-height:92vh;overflow:auto;background:#fff;border-radius:28px;box-shadow:0 24px 90px #0008}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:20px 22px;border-bottom:1px solid var(--line)}.modal-head h2{margin:0}.modal-body{padding:22px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.item-row{display:grid;grid-template-columns:1fr 100px 160px 44px;gap:8px;margin-bottom:8px}.toast{position:fixed;right:18px;bottom:18px;background:#10244d;color:white;padding:14px 18px;border-radius:18px;box-shadow:0 18px 50px #0005;z-index:200}.mobile-cards{display:none}@media(max-width:920px){.sidebar{transform:translateX(-110%);transition:.22s}.sidebar.show{transform:translateX(0)}.main{margin-left:0;padding:16px}.menu-btn{display:inline-flex}.grid{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.item-row{grid-template-columns:1fr}.topbar{align-items:flex-start}.desktop-table{display:none}.mobile-cards{display:grid;gap:12px;padding:14px}.mobile-card{background:white;border:1px solid var(--line);border-radius:20px;padding:14px}.mobile-card b{display:block;margin-bottom:6px}.mobile-card small{color:var(--muted)}}@media(max-width:560px){.grid{grid-template-columns:1fr}.login-card{padding:28px}.login-card h1{font-size:30px}.topbar{display:block}.topbar .btn{margin-top:12px;width:100%}.panel-head{display:block}.panel-head .btn{width:100%;margin-top:12px}.card b{font-size:24px}}
/* Premium quotation/editor update */
.field.full{grid-column:1/-1}.rt-toolbar{display:flex;gap:8px;flex-wrap:wrap;background:#f8fafc;border:1px solid #d6dde8;border-bottom:0;border-radius:14px 14px 0 0;padding:8px}.rt-toolbar button{border:0;background:white;border-radius:9px;padding:8px 10px;font-weight:800;box-shadow:0 2px 8px #1d2b4f10;cursor:pointer}.rich-editor{min-height:125px;background:white;border:1px solid #d6dde8;border-radius:0 0 14px 14px;padding:13px 14px;line-height:1.6;outline:none}.logo-preview{margin-top:10px;min-height:84px;border:1px dashed #cbd5e1;border-radius:16px;background:#f8fafc;display:flex;align-items:center;justify-content:center;overflow:hidden}.logo-preview img{max-height:78px;max-width:220px;object-fit:contain}.item-row.premium{grid-template-columns:190px 1fr 90px 100px 150px 46px}.modal{max-width:980px}.modal-body{max-height:78vh;overflow:auto}@media(max-width:900px){.item-row.premium{grid-template-columns:1fr}.modal{width:94vw}.modal-body{max-height:76vh}}
/* Gas cylinder control module */
.Filled,.Available,.ReturnFilled,.Fill{background:#dcfce7;color:#15803d}.Delivered,.Delivery{background:#dbeafe;color:#1d4ed8}.Empty,.ReturnEmpty{background:#fef3c7;color:#b45309}.Maintenance,.Adjustment{background:#ede9fe;color:#6d28d9}.Lost,.Retired,.Retire{background:#fee2e2;color:#b91c1c}.due-soon{font-weight:900;color:#b91c1c}.gas-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}@media(max-width:920px){.gas-summary{grid-template-columns:1fr 1fr}}@media(max-width:560px){.gas-summary{grid-template-columns:1fr}}

/* Perbaikan toolbar pencarian modul tabung gas */
.gas-toolbar{display:grid;grid-template-columns:1.2fr .8fr 1fr auto;gap:12px;align-items:end;padding:14px 18px;border-bottom:1px solid #e5e7eb;background:#f8fafc}
.gas-toolbar .field{margin:0}.gas-toolbar-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.gas-result-info{padding:10px 18px;color:#64748b;font-size:13px;border-bottom:1px solid #e5e7eb;background:#fff}
@media(max-width:920px){.gas-toolbar{grid-template-columns:1fr}.gas-toolbar-actions .btn{width:100%}}
