:root{
  --doka-blue:#003b78;
  --doka-blue-2:#002b5c;
  --doka-yellow:#ffd900;
  --ink:#07142b;
  --muted:#6b7280;
  --line:#e8edf4;
  --bg:#f6f8fb;
  --card:#ffffff;
  --success:#16a34a;
  --warning:#f59e0b;
  --danger:#ef4444;
  --info:#0b63ce;
}
*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}a{color:var(--doka-blue);text-decoration:none}button,input,select,textarea{font:inherit}.app{display:grid;grid-template-columns:282px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,var(--doka-blue) 0%,var(--doka-blue-2) 100%);color:white;position:sticky;top:0;height:100vh;padding:0 20px 22px;display:flex;flex-direction:column;box-shadow:18px 0 45px rgba(0,43,92,.18)}.brand{height:150px;margin:0 -20px 20px;background:var(--doka-yellow);display:flex;align-items:center;justify-content:center;flex-direction:column;border-bottom-right-radius:34px}.brand img{width:145px;height:auto;object-fit:contain}.brand small{color:var(--doka-blue);font-weight:800;letter-spacing:.18em;margin-top:6px}.nav{display:grid;gap:8px}.nav a{color:#eaf2ff;padding:14px 16px;border-radius:15px;display:flex;gap:12px;align-items:center;font-weight:700}.nav a.active,.nav a:hover{background:rgba(255,217,0,.14);color:white;box-shadow:inset 4px 0 0 var(--doka-yellow)}.nav .count{margin-left:auto;background:var(--doka-yellow);color:var(--doka-blue);width:26px;height:26px;border-radius:999px;display:grid;place-items:center;font-size:12px}.sidebar-bottom{margin-top:auto}.help{border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:18px;background:rgba(255,255,255,.08);margin-bottom:14px}.logout{width:100%;border:1px solid rgba(255,255,255,.2);background:transparent;color:white;border-radius:14px;padding:13px 16px;display:block;text-align:center}.content{min-width:0}.topbar{height:76px;background:rgba(255,255,255,.86);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;padding:0 34px;position:sticky;top:0;z-index:10}.hamb{font-size:24px;color:var(--doka-blue)}.search{max-width:460px;margin-left:auto;position:relative}.search input{width:100%;border:1px solid var(--line);border-radius:16px;padding:13px 44px 13px 16px;background:#fff}.search span{position:absolute;right:16px;top:12px}.user{display:flex;align-items:center;gap:12px;font-weight:800}.avatar{width:42px;height:42px;border-radius:50%;background:var(--doka-blue);color:var(--doka-yellow);display:grid;place-items:center}.page{padding:32px 34px 42px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:26px}.page-head h1{font-size:32px;line-height:1.1;margin:0;color:var(--doka-blue-2)}.page-head p{margin:8px 0 0;color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;border-radius:14px;background:var(--doka-yellow);color:var(--doka-blue);font-weight:900;padding:13px 18px;box-shadow:0 12px 25px rgba(255,217,0,.28);cursor:pointer}.btn.secondary{background:var(--doka-blue);color:white;box-shadow:0 12px 25px rgba(0,59,120,.22)}.btn.ghost{background:#fff;border:1px solid var(--line);box-shadow:none}.btn.success{background:#dcfce7;color:#166534;box-shadow:none}.btn.danger{background:#fee2e2;color:#991b1b;box-shadow:none}.kpis{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:18px;margin-bottom:22px}.kpi,.card{background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:0 12px 34px rgba(0,43,92,.07)}.kpi{padding:22px;display:flex;gap:17px;align-items:center;position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;left:22px;right:22px;bottom:0;height:4px;background:var(--doka-blue);border-radius:999px}.kpi.yellow:after{background:var(--doka-yellow)}.ico{width:54px;height:54px;border-radius:18px;background:var(--doka-blue);color:var(--doka-yellow);display:grid;place-items:center;font-size:24px}.ico.yellow{background:var(--doka-yellow);color:var(--doka-blue)}.kpi small{display:block;color:var(--muted);font-weight:700}.kpi strong{font-size:25px}.grid{display:grid;grid-template-columns:1.1fr 1fr;gap:18px}.card{padding:0;overflow:hidden}.card-head{padding:20px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.card-head h2{font-size:18px;margin:0;color:var(--doka-blue-2)}table{width:100%;border-collapse:collapse}th,td{padding:17px 22px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}th{color:#56627a;font-size:12px;text-transform:uppercase;letter-spacing:.04em}tr:hover td{background:#fbfcff}.badge{display:inline-flex;align-items:center;padding:7px 10px;border-radius:10px;font-size:12px;font-weight:900;text-transform:capitalize}.badge.draft{background:#eef2ff;color:#3730a3}.badge.submitted{background:#fef3c7;color:#92400e}.badge.approved{background:#dcfce7;color:#166534}.badge.rejected{background:#fee2e2;color:#991b1b}.badge.paid{background:#dbeafe;color:#1d4ed8}.detail-body{display:grid;grid-template-columns:.8fr 1fr;gap:22px;padding:22px}.detail-list p{margin:0 0 18px}.detail-list b{display:block;color:#56627a;font-size:12px;text-transform:uppercase;margin-bottom:5px}.receipt-preview{background:linear-gradient(180deg,#fff,#f7f7f7);border:1px solid #e5e7eb;border-radius:18px;min-height:330px;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;box-shadow:inset 0 0 0 8px #fff}.receipt-paper{font-family:'Courier New',monospace;color:#111;background:white;padding:22px;border-radius:10px;box-shadow:0 14px 25px rgba(0,0,0,.13);width:270px}.receipt-actions{display:flex;gap:10px;margin-top:16px}.charts{margin-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:18px}.donut-wrap{display:flex;align-items:center;gap:28px;padding:26px}.donut{width:165px;height:165px;border-radius:50%;background:conic-gradient(var(--doka-blue) 0 54%,var(--doka-yellow) 54% 78%,#9ca3af 78% 100%);position:relative}.donut:after{content:"";position:absolute;inset:38px;background:white;border-radius:50%}.legend{display:grid;gap:14px;flex:1}.legend-row{display:flex;justify-content:space-between;gap:15px}.dot{width:11px;height:11px;border-radius:99px;background:var(--doka-blue);display:inline-block;margin-right:8px}.dot.y{background:var(--doka-yellow)}.dot.g{background:#9ca3af}.activity{padding:8px 22px 22px}.activity-item{display:flex;align-items:center;gap:14px;padding:17px 0;border-bottom:1px solid var(--line)}.activity-item:last-child{border-bottom:0}.activity-icon{width:34px;height:34px;border-radius:50%;background:var(--doka-yellow);color:var(--doka-blue);display:grid;place-items:center;font-weight:900}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;padding:24px}.form-grid label{font-weight:800;color:var(--doka-blue-2);display:grid;gap:8px}.form-grid input,.form-grid select,.form-grid textarea{border:1px solid var(--line);border-radius:14px;padding:13px 14px;background:#fff}.full{grid-column:1/-1}.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(120deg,var(--doka-blue) 0 45%,var(--doka-yellow) 45% 100%)}.login-card{width:min(430px,92vw);background:white;border-radius:28px;padding:34px;box-shadow:0 30px 70px rgba(0,43,92,.26);display:grid;gap:16px}.login-card .login-logo{width:140px;margin:auto}.login-card h1{text-align:center;margin:0;color:var(--doka-blue)}.login-card p{text-align:center;margin:0;color:var(--muted)}.login-card label{font-weight:800;color:var(--doka-blue-2);display:grid;gap:8px}.login-card input{border:1px solid var(--line);border-radius:14px;padding:14px}.login-card button{border:0;border-radius:14px;background:var(--doka-yellow);color:var(--doka-blue);font-weight:900;padding:14px}.alert{padding:12px 14px;border-radius:14px;background:#fee2e2;color:#991b1b}@media(max-width:1100px){.app{grid-template-columns:1fr}.sidebar{display:none}.kpis,.grid,.charts{grid-template-columns:1fr}.detail-body{grid-template-columns:1fr}}@media(max-width:760px){.topbar{padding:0 16px}.search{display:none}.page{padding:22px 16px}.page-head{flex-direction:column}.kpis{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}th:nth-child(2),td:nth-child(2),th:nth-child(3),td:nth-child(3){display:none}}
.approval-flow{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 22px}.flow-step{padding:10px 14px;border-radius:999px;background:#eef2f7;color:#001f4e;font-weight:800;border:1px solid #d9e2ef}.flow-step.done{background:#ffd600;color:#001f4e;border-color:#ffd600}.badge.manager_approved,.badge.finance_approved{background:#dbeafe;color:#001f4e}.badge.paid{background:#dcfce7;color:#166534}.badge.submitted{background:#fff7cc;color:#7a5b00}.badge.draft{background:#eef2f7;color:#334155}.badge.rejected{background:#fee2e2;color:#991b1b}code{background:#f1f5f9;padding:3px 6px;border-radius:7px;color:#001f4e}.btn.success{background:#16a34a;color:#fff}.btn.danger{background:#dc2626;color:#fff}.receipt-actions form{display:inline-flex;gap:8px;align-items:center;margin-right:8px}.receipt-actions input{padding:10px 12px;border:1px solid #d6deea;border-radius:10px}
