:root{
  --bg:#f1f5f9; --card:#fff; --ink:#0f172a; --muted:#64748b; --line:#e2e8f0;
  --brand:#1d4ed8; --brand2:#1e40af; --ok:#16a34a; --warn:#d97706; --bad:#dc2626;
  --chip:#eff6ff; --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',system-ui,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px}
header.app{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;padding:12px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;box-shadow:var(--shadow);position:sticky;top:0;z-index:50}
header.app .logo{font-weight:700;font-size:18px;letter-spacing:.3px;display:flex;align-items:center;gap:8px}
header.app .logo span{font-size:22px}
header.app .spacer{flex:1}
header.app .who{display:flex;align-items:center;gap:8px;font-size:13px}
header.app select{padding:6px 10px;border-radius:8px;border:none;font-size:13px}
nav.tabs{display:flex;gap:4px;padding:10px 16px 0;background:var(--bg);flex-wrap:wrap;position:sticky;top:56px;z-index:40}
nav.tabs button{border:1px solid var(--line);background:var(--card);color:var(--muted);padding:8px 14px;border-radius:10px 10px 0 0;cursor:pointer;font-size:13px;font-weight:600}
nav.tabs button.active{color:var(--brand);border-bottom-color:var(--card);background:var(--card)}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow);margin-bottom:16px}
.card h2{margin:0 0 4px;font-size:17px}
.card h3{margin:18px 0 8px;font-size:14px;color:var(--brand2);border-bottom:1px solid var(--line);padding-bottom:6px}
.sub{color:var(--muted);font-size:12.5px;margin:0 0 12px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
label.field{display:block;position:relative;font-size:12.5px;font-weight:600;color:#334155;line-height:1.35}
label.field>input,label.field>select,label.field>textarea{display:block;width:100%;box-sizing:border-box;margin-top:6px;padding:9px 10px;border:1px solid var(--line);border-radius:9px;font-size:13px;font-family:inherit;background:#fff}
label.field input:focus,label.field select:focus,label.field textarea:focus{outline:2px solid #bfdbfe;border-color:var(--brand)}
textarea{resize:vertical;min-height:64px}
.req:after{content:"*";color:var(--bad);position:absolute;top:0;right:3px;font-size:14px;font-weight:700}
.btn{background:var(--brand);color:#fff;border:none;padding:10px 16px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:600}
.btn:hover{background:var(--brand2)}
.btn.sec{background:#fff;color:var(--brand);border:1px solid var(--brand)}
.btn.ok{background:var(--ok)}.btn.bad{background:var(--bad)}.btn.warn{background:var(--warn)}
.btn.sm{padding:6px 10px;font-size:12px;border-radius:8px}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.toggle{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--chip);border-radius:10px;font-weight:600;cursor:pointer}
.toggle input{width:18px;height:18px}
.chip{display:inline-block;padding:3px 9px;border-radius:999px;font-size:11.5px;font-weight:700}
.chip.pending{background:#fef3c7;color:#92400e}.chip.approved{background:#dcfce7;color:#166534}
.chip.rejected{background:#fee2e2;color:#991b1b}.chip.done{background:#e0e7ff;color:#3730a3}
.chip.rescheduled{background:#fae8ff;color:#86198f}
.eng-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.eng-pill{display:flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:10px;padding:7px 11px;cursor:pointer;background:#fff;font-size:12.5px}
.eng-pill.sel{border-color:var(--brand);background:var(--chip)}
.eng-pill.busy{border-color:#cbd5e1;background:#f1f5f9;color:#94a3b8;cursor:not-allowed;opacity:.85}
.eng-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--ok)}
.eng-pill.busy .dot{background:#94a3b8}
.car-card{border:1px solid var(--line);border-radius:10px;padding:10px;cursor:pointer;background:#fff}
.car-card.sel{border-color:var(--brand);background:var(--chip)}
.car-card.busy{opacity:.6}
.visit-item{border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:10px}
.visit-item .head{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:center}
.visit-item .title{font-weight:700;font-size:15px}
.meta{color:var(--muted);font-size:12.5px;display:flex;gap:14px;flex-wrap:wrap;margin-top:5px}
.meta b{color:#334155}
.itin-row,.cost-row{display:grid;grid-template-columns:1.2fr 2fr 1.5fr auto;gap:8px;margin-bottom:6px}
.banner{padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:12px}
.banner.info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}
.banner.warn{background:#fffbeb;color:#92400e;border:1px solid #fde68a}
.banner.ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}
.kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.kpi .box{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid var(--line);border-radius:12px;padding:14px}
.kpi .box .n{font-size:26px;font-weight:800;color:var(--brand)}
.kpi .box .l{font-size:12px;color:var(--muted)}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal .dow{font-weight:700;text-align:center;font-size:11px;color:var(--muted);padding:4px}
.cal .day{min-height:78px;border:1px solid var(--line);border-radius:8px;padding:4px;background:#fff;font-size:11px}
.cal .day.off{background:#f8fafc;color:#cbd5e1}
.cal .day .num{font-weight:700;font-size:11px}
.cal .ev{background:var(--chip);border-left:3px solid var(--brand);border-radius:4px;padding:2px 4px;margin-top:3px;font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal .ev.approved{border-left-color:var(--ok);background:#f0fdf4}
.cal .ev.pending{border-left-color:var(--warn);background:#fffbeb}
.file-link{font-size:12px;color:var(--brand);text-decoration:none}
.file-link:hover{text-decoration:underline}
small.hint{color:var(--muted);font-weight:400;font-size:11px;display:inline}
.empty{text-align:center;color:var(--muted);padding:30px}
.divider{height:1px;background:var(--line);margin:14px 0}
table.simple{width:100%;border-collapse:collapse;font-size:12.5px}
table.simple th,table.simple td{text-align:left;padding:7px 8px;border-bottom:1px solid var(--line)}
table.simple th{color:var(--muted);font-weight:700}
.tag{font-size:11px;background:#f1f5f9;border-radius:6px;padding:2px 7px;color:#475569}
@media(max-width:640px){.itin-row,.cost-row{grid-template-columns:1fr}}
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:flex;align-items:flex-start;justify-content:center;z-index:200;padding:40px 16px;overflow:auto}
.modal-box{background:#fff;border-radius:14px;max-width:680px;width:100%;box-shadow:0 12px 45px rgba(0,0,0,.32);animation:pop .12s ease}
@keyframes pop{from{transform:translateY(-8px);opacity:.6}to{transform:none;opacity:1}}
.modal-head{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;border-radius:14px 14px 0 0}
.modal-head h3{margin:0;font-size:16px}
.modal-x{background:none;border:none;font-size:20px;cursor:pointer;color:#64748b;line-height:1}
.modal-body{padding:16px 18px}
.dl{display:grid;grid-template-columns:130px 1fr;gap:4px 10px;font-size:13px;margin:6px 0}
.dl .k{color:#64748b;font-weight:600}
.cal .ev{cursor:pointer}
.cal .ev:hover{filter:brightness(.94)}
.det-sec{margin-top:10px;border-top:1px solid var(--line);padding-top:8px}
.det-sec h4{margin:0 0 4px;font-size:12.5px;color:var(--brand2)}
.det-sec ol{margin:4px 0;padding-left:20px;font-size:12.5px}
table.recap{width:100%;border-collapse:collapse;font-size:12.5px;min-width:820px}
table.recap th{background:#1F3864;color:#fff;font-weight:700;padding:8px 10px;border:1px solid #15294d;text-align:center}
table.recap td{border:1px solid var(--line);padding:7px 10px;vertical-align:middle}
table.recap tr:nth-child(even) td{background:#f8fafc}
table.recap tr:hover td{background:#eff6ff}
table.recap .center{text-align:center}
.cal .ev.rescheduled{border-left-color:#a21caf;background:#fdf4ff}
.cal .ev.done{border-left-color:#64748b;background:#f1f5f9;color:#475569}
.kpi .box:hover{box-shadow:0 2px 8px rgba(29,78,216,.18);transform:translateY(-1px);transition:.12s}

/* ===================== APP SHELL (sidebar + login) ===================== */
body{margin:0;background:#eef2f7}
/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 55%,#3b82f6 100%);padding:20px}
.login-card{background:#fff;border-radius:18px;box-shadow:0 24px 60px rgba(0,0,0,.28);padding:34px 32px;width:100%;max-width:390px;text-align:center}
.login-brand img{height:64px;margin-bottom:6px}
.login-card h1{margin:6px 0 2px;font-size:22px;color:#0f172a}
.login-sub{color:#64748b;font-size:12.5px;margin:0 0 18px}
.login-card .field{text-align:left}
.login-card input{padding:11px 12px;font-size:14px}
.login-btn{width:100%;margin-top:18px;padding:12px;font-size:15px;border-radius:10px}
.login-foot{color:#94a3b8;font-size:11.5px;margin:16px 0 0}
#loginErr .banner{margin-bottom:12px}

/* APP LAYOUT */
#app{display:flex;min-height:100vh}
.sidebar{width:256px;background:linear-gradient(180deg,#eaf2fd 0%,#e2ecfb 100%);border-right:1px solid #cdddf4;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;flex-shrink:0}
.side-logo{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;border-bottom:1px solid #cdddf4}
.side-logo img{height:38px}
.side-logo-txt{display:flex;flex-direction:column;line-height:1.15}
.side-logo-txt b{font-size:14px;color:#0f172a}
.side-logo-txt span{font-size:10.5px;color:#94a3b8}
.side-nav{flex:1;overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:3px}
.side-nav button{display:flex;align-items:center;gap:11px;width:100%;border:none;background:none;color:#475569;
  padding:10px 12px;border-radius:9px;cursor:pointer;font-size:13.5px;font-weight:600;text-align:left;transition:.12s}
.side-nav button .ic{font-size:16px;width:20px;text-align:center}
.side-nav button:hover{background:rgba(37,99,235,.10);color:#1e3a8a}
.side-nav button.active{background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%);color:#fff;box-shadow:0 6px 16px rgba(30,58,138,.38)}
.side-user{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid #cdddf4;background:rgba(255,255,255,.55)}
.su-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.su-meta{display:flex;flex-direction:column;line-height:1.2;flex:1;min-width:0}
.su-meta b{font-size:13px;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-meta span{font-size:11px;color:#64748b}
.su-logout{border:1px solid #e2e8f0;background:#fff;color:#dc2626;width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:16px;flex-shrink:0}
.su-logout:hover{background:#fef2f2}
.main{flex:1;display:flex;flex-direction:column;min-width:0;max-width:none;width:100%;margin:0;padding:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 32px;background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:30}
.topbar h1{margin:0;font-size:18px;color:#0f172a}
.content{padding:24px 32px;max-width:none;width:100%}
@media(max-width:760px){.sidebar{width:64px}.side-logo-txt,.side-nav button span:not(.ic),.su-meta{display:none}.side-nav button{justify-content:center}.side-user{justify-content:center}}

/* ===== enriched topbar ===== */
.topbar{align-items:center}
.tb-left{display:flex;flex-direction:column;gap:1px}
.topbar h1{margin:0;font-size:21px;font-weight:800;line-height:1.15;color:#0f172a}
.tb-sub{font-size:12.5px;color:#64748b}
.tb-right{display:flex;align-items:center;gap:14px}
.tb-date{font-size:12px;color:#475569;background:#f1f5f9;padding:7px 12px;border-radius:8px;white-space:nowrap}
.tb-user{text-align:right;font-size:13px;white-space:nowrap}
.tb-user b{color:#0f172a;font-weight:700}
.tb-user span{color:#64748b}
@media(max-width:820px){.tb-sub,.tb-date{display:none}}
.grid-ident{align-items:start}
/* dev impersonation bar */
.devbar{background:#0f172a;color:#fff;padding:6px 12px;border-radius:8px;font-size:12px;display:flex;align-items:center;gap:10px}
.devbar button{background:#f59e0b;color:#0f172a;border:none;padding:5px 12px;border-radius:6px;font-weight:700;cursor:pointer;font-size:11px}
.devbar button:hover{background:#fbbf24}
/* password eye */
.pwd-field{position:relative}
.pwd-field>input{padding-right:40px}
.pwd-eye{position:absolute;right:8px;bottom:7px;background:none;border:none;cursor:pointer;font-size:17px;line-height:1;padding:4px}

/* ===== micro-interactions & feedback animations (lightweight, CSS-only) ===== */
.btn{transition:transform .08s ease, background .15s ease, box-shadow .15s ease}
.btn:active{transform:scale(.94)}
.side-nav button{transition:transform .08s ease, background .12s ease}
.side-nav button:active{transform:scale(.97)}
.kpi .box,.car-card,.eng-pill,.visit-item{transition:transform .1s ease, box-shadow .15s ease}
.eng-pill:active,.car-card:active{transform:scale(.96)}
#toasts{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{pointer-events:auto;min-width:170px;max-width:330px;padding:11px 14px;border-radius:11px;color:#fff;font-size:13px;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.18);display:flex;align-items:center;gap:9px;animation:toastIn .28s cubic-bezier(.2,.9,.3,1.3)}
.toast.out{animation:toastOut .22s ease forwards}
.toast.ok{background:linear-gradient(135deg,#16a34a,#22c55e)}
.toast.warn{background:linear-gradient(135deg,#d97706,#f59e0b)}
.toast.bad{background:linear-gradient(135deg,#dc2626,#ef4444)}
.toast.info{background:linear-gradient(135deg,#1e40af,#3b82f6)}
.toast .ic{font-size:16px;display:inline-block;animation:pop .45s ease}
@keyframes toastIn{from{opacity:0;transform:translateX(40px) scale(.9)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px) scale(.9)}}
@keyframes pop{0%{transform:scale(0)}60%{transform:scale(1.35)}100%{transform:scale(1)}}
@keyframes shakeX{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(3px)}}
.shake{animation:shakeX .4s ease}
.field.shake>input,.field.shake>select,.field.shake>textarea{border-color:#dc2626 !important;box-shadow:0 0 0 2px #fecaca}
.content>.card{animation:cardIn .24s ease}
@keyframes cardIn{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
.banner.ok{animation:popBanner .3s ease}
@keyframes popBanner{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}

/* wide modal + fit grid rows inside modal */
.modal-box.wide{max-width:920px}
.itin-row{gap:8px}
.itin-row > *{min-width:0}
.itin-row input,.itin-row select{min-width:0;width:100%;box-sizing:border-box}
.modal-body{overflow-x:hidden}
.modal-body .car-card{min-width:0}

.chip.cancelled{background:#e5e7eb;color:#374151}

/* notification bell */
.tb-bell{position:relative;background:#f1f5f9;border:1px solid var(--line);border-radius:10px;width:38px;height:38px;cursor:pointer;font-size:17px;line-height:1}
.tb-bell:hover{background:#e2e8f0}
.tb-bell-badge{position:absolute;top:-6px;right:-6px;background:#dc2626;color:#fff;font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}

option:disabled{color:#9ca3af}

/* clickable Rekapan Laporan KPI boxes */
.box.rkpi{cursor:pointer;transition:transform .1s ease, box-shadow .15s ease, border-color .15s ease}
.box.rkpi:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(29,78,216,.18);border-color:var(--brand)}
.box.rkpi.sel{border-color:var(--brand);box-shadow:0 0 0 2px rgba(29,78,216,.25);background:linear-gradient(135deg,#eff4ff,#f8fafc)}
.box.rkpi.sel .l{color:var(--brand);font-weight:600}

/* ============================================================
   MOBILE-FRIENDLY (≤760px). Desktop layout above is untouched.
   ============================================================ */
.tb-burger{display:none}
.nav-backdrop{display:none}

@media(max-width:760px){
  /* ---- App shell: off-canvas drawer instead of squished sidebar ---- */
  #app{display:block}
  .main{width:100%;min-width:0}

  .tb-burger{display:inline-flex;align-items:center;justify-content:center;
    width:42px;height:42px;flex:0 0 auto;border:1px solid #d7e3f6;background:#eef5ff;
    color:#1e3a8a;border-radius:11px;font-size:21px;line-height:1;cursor:pointer;padding:0}
  .tb-burger:active{transform:scale(.92)}

  .sidebar{position:fixed;top:0;left:0;height:100dvh;width:82vw;max-width:300px;
    transform:translateX(-100%);transition:transform .25s ease;z-index:1000}
  body.nav-open .sidebar{transform:none;box-shadow:14px 0 44px rgba(15,23,42,.4)}

  /* drawer shows full labels (override the 64px icon-only collapse) */
  .side-logo-txt,.su-meta{display:flex}
  .side-nav button span:not(.ic){display:inline}
  .side-nav button{justify-content:flex-start;padding:13px 14px;font-size:15px}
  .side-nav button .ic{font-size:18px}
  .side-user{justify-content:flex-start}

  .nav-backdrop{display:block;position:fixed;inset:0;background:rgba(15,23,42,.5);
    z-index:999;opacity:0;visibility:hidden;transition:opacity .25s ease}
  body.nav-open .nav-backdrop{opacity:1;visibility:visible}
  body.nav-open{overflow:hidden}

  /* ---- Topbar ---- */
  .topbar{padding:10px 13px;gap:10px}
  .tb-left{flex:1;min-width:0}
  .topbar h1{font-size:16.5px;line-height:1.2;white-space:normal}
  .tb-right{gap:8px;flex:0 0 auto}

  /* ---- Content & cards ---- */
  .content{padding:14px 13px}
  .card{padding:14px;border-radius:12px}
  .card h2{font-size:16px}
  .card h3{font-size:13.5px}

  /* ---- Forms: single column, comfortable tap targets ---- */
  .grid,.grid-ident{grid-template-columns:1fr}
  .kpi{grid-template-columns:1fr 1fr}
  .dl{grid-template-columns:1fr;gap:1px 0}
  .dl .k{margin-top:7px}
  label.field>input,label.field>select,label.field>textarea{padding:11px 11px;font-size:15px}
  .itin-row,.cost-row{grid-template-columns:1fr}

  /* toggle text wraps cleanly, checkbox stays put */
  .toggle{align-items:flex-start;line-height:1.45;padding:12px 13px}
  .toggle input{flex:0 0 auto;margin-top:2px;width:20px;height:20px}

  /* buttons easier to tap; full-width primary actions */
  .btn{padding:11px 16px}
  .row{gap:8px}

  /* ---- Tables (already wrapped in overflow-x:auto) ---- */
  table.simple{font-size:12px}

  /* ---- Calendar ---- */
  .cal{gap:3px}
  .cal .day{min-height:58px;padding:3px}
  .cal .ev{font-size:9.5px}

  /* ---- Modals near full-screen ---- */
  .modal-overlay{padding:12px 8px;align-items:flex-start}
  .modal-box,.modal-box.wide{max-width:100%}
  .dl{grid-template-columns:1fr}

  /* ---- Login ---- */
  .login-card{padding:26px 20px}
}

/* extra-small phones */
@media(max-width:430px){
  .topbar h1{font-size:15.5px}
  .tb-user{font-size:11.5px;max-width:96px;white-space:normal;line-height:1.2}
  .kpi{grid-template-columns:1fr}
}
