/* =====================================================================
   COGS Workflow — app.css
   Desktop : sidebar + tabel.  Mobile (<992px) : tampilan mobile-app
   (top bar + bottom navigation + cards + FAB).
   ===================================================================== */

:root{
  --brand-900:#0f2747; --brand-800:#13386b; --brand-700:#18488a;
  --brand-600:#1f5aa8; --brand:#2563b8;     --brand-400:#5b8fd6;
  --accent:#f26a1b;     --accent-600:#d85a13;

  --ok:#16a34a;   --ok-bg:#dcfce7;
  --warn:#b45309;  --warn-bg:#fef3c7;
  --danger:#dc2626;--danger-bg:#fee2e2;
  --info:#1d4ed8;  --info-bg:#dbeafe;
  --muted:#64748b; --muted-bg:#e7ebf1;

  --bg:#eef2f7; --surface:#ffffff; --surface-2:#f8fafc;
  --ink:#0f172a; --ink-2:#475569; --ink-3:#94a3b8; --line:#e3e8ef;

  --radius:14px; --radius-lg:20px; --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06),0 1px 3px rgba(15,23,42,.04);
  --shadow:0 4px 16px rgba(15,23,42,.08);
  --shadow-lg:0 12px 32px rgba(15,23,42,.16);
  --sidebar-w:252px;
  --sat:env(safe-area-inset-top,0px);
  --sab:env(safe-area-inset-bottom,0px);

  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;
  font-size:15px;line-height:1.5;
}
a{color:var(--brand);text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em}
img{max-width:100%}

/* ---------------------------------------------------------------------
   SHELL & SIDEBAR (DESKTOP)
   --------------------------------------------------------------------- */
.app-shell{min-height:100vh}

.sidebar{
  position:fixed;inset:0 auto 0 0;width:var(--sidebar-w);
  background:linear-gradient(180deg,var(--brand-900),var(--brand-800));
  color:#cdd9ee;display:flex;flex-direction:column;z-index:40;
  padding:18px 14px;
}
.brand{display:flex;align-items:center;gap:12px;color:#fff;padding:6px 8px 18px}
.brand-mark{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-600));
  font-size:1.25rem;color:#fff;box-shadow:0 6px 14px rgba(242,106,27,.35);flex:none;
}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{font-size:1.05rem}
.brand-text small{color:#9fb4d6;font-size:.74rem}

.side-nav{display:flex;flex-direction:column;gap:4px;margin-top:6px;flex:1}
.side-link{
  display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;
  color:#bcccea;font-weight:500;transition:.15s;position:relative;
}
.side-link i{font-size:1.15rem;width:22px;text-align:center}
.side-link:hover{background:rgba(255,255,255,.07);color:#fff}
.side-link.active{background:rgba(255,255,255,.12);color:#fff}
.side-link.active::before{
  content:"";position:absolute;left:-14px;top:9px;bottom:9px;width:4px;
  border-radius:0 4px 4px 0;background:var(--accent);
}

.side-user{
  display:flex;align-items:center;gap:10px;padding:12px;border-radius:13px;
  background:rgba(255,255,255,.06);margin-top:8px;
}
.avatar{
  width:38px;height:38px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand-400),var(--brand-600));color:#fff;font-weight:700;
}
.avatar.sm{width:32px;height:32px;font-size:.85rem}
.su-meta{display:flex;flex-direction:column;line-height:1.2;min-width:0;flex:1}
.su-meta strong{color:#fff;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-meta small{color:#9fb4d6;font-size:.74rem}
.su-logout{color:#9fb4d6;font-size:1.15rem;padding:6px}
.su-logout:hover{color:#fff}

/* ---------------------------------------------------------------------
   MOBILE TOP BAR  (disembunyikan di desktop)
   --------------------------------------------------------------------- */
.mobile-topbar{display:none}

/* ---------------------------------------------------------------------
   KONTEN
   --------------------------------------------------------------------- */
.content{margin-left:var(--sidebar-w);min-height:100vh}
.content-head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 30px;border-bottom:1px solid var(--line);background:var(--surface);
  position:sticky;top:0;z-index:20;
}
.page-title{font-size:1.4rem}
.page-subtitle{margin:.25rem 0 0;color:var(--ink-2);font-size:.9rem}
.head-user{display:flex;align-items:center;gap:9px;color:var(--ink-2);font-size:.9rem;font-weight:500}
.content-body{padding:26px 30px;max-width:1180px}

.app-alert{border:0;border-radius:var(--radius);font-size:.92rem;box-shadow:var(--shadow-sm)}

/* ---------------------------------------------------------------------
   KOMPONEN UMUM
   --------------------------------------------------------------------- */
.card-x{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:20px;
}
.card-x + .card-x{margin-top:18px}

.section{margin-bottom:18px}
.section-title{
  display:flex;align-items:center;gap:9px;font-size:.95rem;font-weight:700;
  color:var(--ink);margin-bottom:14px;text-transform:uppercase;letter-spacing:.04em;
}
.section-title i{color:var(--brand);font-size:1.1rem}
.section-title .st-rule{flex:1;height:1px;background:var(--line)}

/* Badge status */
.badge-status{
  display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;
  font-size:.78rem;font-weight:600;line-height:1;white-space:nowrap;
}
.badge-status i{font-size:.9rem}
.st-ok{background:var(--ok-bg);color:var(--ok)}
.st-warn{background:var(--warn-bg);color:var(--warn)}
.st-danger{background:var(--danger-bg);color:var(--danger)}
.st-info{background:var(--info-bg);color:var(--info)}
.st-muted{background:var(--muted-bg);color:var(--muted)}

/* Key-value */
.kv{display:grid;grid-template-columns:190px 1fr;gap:10px 16px}
.kv dt{color:var(--ink-2);font-size:.88rem}
.kv dd{margin:0;font-weight:500;color:var(--ink)}

/* Buttons */
.btn-brand{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}
.btn-brand:hover{background:var(--brand-700);border-color:var(--brand-700);color:#fff}
.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
.btn-accent:hover{background:var(--accent-600);border-color:var(--accent-600);color:#fff}
.btn-soft{background:var(--surface-2);border:1px solid var(--line);color:var(--ink-2);font-weight:600}
.btn-soft:hover{background:#eef2f7;color:var(--ink)}
.btn .bi{vertical-align:-2px}

/* Tabel (desktop) */
.req-table{display:block}
.tbl{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.tbl th,.tbl td{padding:13px 16px;text-align:left;font-size:.9rem;vertical-align:middle}
.tbl thead th{background:var(--surface-2);color:var(--ink-2);font-weight:600;
  font-size:.76rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--line)}
.tbl tbody tr{border-top:1px solid var(--line)}
.tbl tbody tr:first-child{border-top:0}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl .code{font-weight:700;color:var(--brand-700);white-space:nowrap}
.tbl .t-tenant{font-weight:600}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}

/* Daftar kartu (mobile) — disembunyikan di desktop */
.req-cards{display:none}

/* Filter chips */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.chip{
  display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;
  background:var(--surface);border:1px solid var(--line);color:var(--ink-2);
  font-size:.85rem;font-weight:600;cursor:pointer;transition:.15s;
}
.chip:hover{border-color:var(--brand-400);color:var(--brand-700)}
.chip.active{background:var(--brand);border-color:var(--brand);color:#fff}
.chip .n{background:rgba(0,0,0,.08);border-radius:999px;padding:1px 7px;font-size:.72rem}
.chip.active .n{background:rgba(255,255,255,.25)}

/* Dashboard stat grid */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.stat-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 16px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;
}
.stat-card .sc-ico{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:1.2rem;margin-bottom:12px;
}
.sc-ico.b{background:var(--info-bg);color:var(--info)}
.sc-ico.w{background:var(--warn-bg);color:var(--warn)}
.sc-ico.g{background:var(--ok-bg);color:var(--ok)}
.sc-ico.r{background:var(--danger-bg);color:var(--danger)}
.stat-card .sc-num{font-size:1.9rem;font-weight:800;line-height:1;letter-spacing:-.02em}
.stat-card .sc-lbl{color:var(--ink-2);font-size:.85rem;margin-top:4px}

/* Call-to-action panel */
.cta{
  display:flex;align-items:center;gap:16px;background:linear-gradient(120deg,var(--brand-800),var(--brand-600));
  color:#fff;border-radius:var(--radius-lg);padding:20px 24px;box-shadow:var(--shadow);margin-bottom:22px;
}
.cta .cta-ico{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  background:rgba(255,255,255,.15);font-size:1.5rem;flex:none}
.cta-body{flex:1}
.cta-body h3{font-size:1.1rem}
.cta-body p{margin:.2rem 0 0;color:#d6e2f5;font-size:.9rem}

/* Empty state */
.empty{
  text-align:center;padding:48px 20px;color:var(--ink-2);
  background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius);
}
.empty i{font-size:2.6rem;color:var(--ink-3);display:block;margin-bottom:12px}
.empty h4{color:var(--ink);margin-bottom:6px}

/* Forms */
.form-label{font-weight:600;font-size:.86rem;color:var(--ink-2);margin-bottom:5px}
.form-control,.form-select{border-radius:var(--radius-sm);border-color:var(--line);font-size:.95rem;padding:.55rem .8rem}
.form-control:focus,.form-select:focus{border-color:var(--brand-400);box-shadow:0 0 0 3px rgba(37,99,184,.12)}
.req-mark{color:var(--danger)}
.help{font-size:.8rem;color:var(--ink-3);margin-top:4px}

/* Attachments */
.att-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.att{
  display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;background:var(--surface-2);
}
.att .thumb{height:104px;background:#dde4ee center/cover no-repeat;display:grid;place-items:center}
.att .thumb i{font-size:2.2rem;color:var(--brand)}
.att .meta{padding:8px 10px;font-size:.78rem}
.att .meta .fn{font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.att .meta .fs{color:var(--ink-3)}

/* File picker preview */
.file-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.file-pill{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:.82rem;color:var(--ink-2)}
.file-pill i{color:var(--brand)}

/* =====================================================================
   EDITOR ITEM BIAYA (COGS)
   ===================================================================== */
.items-editor{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.items-head,.item-row{
  display:grid;
  grid-template-columns:1.1fr 2.1fr .7fr .8fr 1.2fr 1.2fr 40px;
  gap:10px;align-items:center;
}
.items-head{background:var(--surface-2);padding:11px 14px;font-size:.74rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.03em;color:var(--ink-2);border-bottom:1px solid var(--line)}
.item-row{padding:11px 14px;border-bottom:1px solid var(--line)}
.item-row .ie-label{display:none}
.item-row .subtotal-cell{font-weight:700;text-align:right;font-variant-numeric:tabular-nums;color:var(--ink)}
.item-row .btn-del{border:0;background:var(--danger-bg);color:var(--danger);width:34px;height:34px;
  border-radius:9px;display:grid;place-items:center;cursor:pointer;font-size:1rem}
.item-row .btn-del:hover{background:#fbb;}
.items-foot{padding:14px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.btn-add-item{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);
  border:1px dashed var(--brand-400);color:var(--brand-700);font-weight:600;padding:9px 16px;
  border-radius:var(--radius-sm);cursor:pointer}
.btn-add-item:hover{background:#eaf1fb}

.totals{display:flex;flex-direction:column;gap:6px;min-width:240px}
.total-row{display:flex;justify-content:space-between;gap:24px;font-size:.92rem;color:var(--ink-2)}
.total-row.grand{font-size:1.25rem;font-weight:800;color:var(--ink);border-top:1px dashed var(--line);padding-top:8px}
.total-row.grand .val{color:var(--brand-700)}
.total-row .val{font-variant-numeric:tabular-nums;font-weight:700;color:var(--ink)}

/* =====================================================================
   SIGNATURE PAD
   ===================================================================== */
.sigpad-wrap{position:relative;border:2px dashed var(--line);border-radius:var(--radius);
  background:var(--surface);overflow:hidden}
.sigpad-wrap.has-ink{border-style:solid;border-color:var(--brand-400)}
canvas.sigpad{display:block;width:100%;height:200px;touch-action:none;cursor:crosshair}
.sig-hint{position:absolute;inset:0;display:grid;place-items:center;color:var(--ink-3);
  font-size:.9rem;pointer-events:none;text-align:center}
.sig-clear{position:absolute;top:8px;right:8px;background:var(--surface);border:1px solid var(--line);
  border-radius:8px;padding:6px 12px;font-size:.8rem;font-weight:600;color:var(--ink-2);cursor:pointer;z-index:2}
.sig-clear:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-bg)}
.sig-baseline{position:absolute;left:14px;right:14px;bottom:34px;border-bottom:1px solid var(--line);pointer-events:none}

/* Tampilan tanda tangan tersimpan */
.sig-show{display:inline-block;border:1px solid var(--line);border-radius:10px;background:#fff;padding:6px}
.sig-show img{height:90px;display:block}

/* Decision toggle */
.decision-toggle{display:flex;gap:10px;flex-wrap:wrap}
.dt-opt{flex:1;min-width:160px;border:2px solid var(--line);border-radius:var(--radius);padding:14px;
  cursor:pointer;display:flex;align-items:center;gap:12px;background:var(--surface);transition:.15s}
.dt-opt i{font-size:1.4rem}
.dt-opt input{display:none}
.dt-opt .dt-t{font-weight:700}
.dt-opt .dt-d{font-size:.8rem;color:var(--ink-3)}
.dt-opt.sel-approve.on{border-color:var(--ok);background:var(--ok-bg)}
.dt-opt.sel-approve i{color:var(--ok)}
.dt-opt.sel-reject.on{border-color:var(--danger);background:var(--danger-bg)}
.dt-opt.sel-reject i{color:var(--danger)}

/* Alert revisi */
.reject-note{background:var(--danger-bg);border:1px solid #fcaca6;border-radius:var(--radius);
  padding:14px 16px;color:#7f1d1d}
.reject-note .rn-h{font-weight:700;display:flex;align-items:center;gap:7px;margin-bottom:4px}

/* =====================================================================
   LOGIN
   ===================================================================== */
.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr;background:var(--bg)}
.login-hero{
  background:linear-gradient(150deg,var(--brand-900),var(--brand-700) 60%,var(--brand-600));
  color:#fff;padding:60px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;
}
.login-hero::after{content:"";position:absolute;right:-80px;bottom:-80px;width:320px;height:320px;
  border-radius:50%;background:radial-gradient(circle,rgba(242,106,27,.35),transparent 70%)}
.login-hero .lh-brand{display:flex;align-items:center;gap:14px;margin-bottom:30px}
.login-hero .lh-brand .brand-mark{width:50px;height:50px;font-size:1.5rem}
.login-hero h1{font-size:2rem;line-height:1.15;max-width:420px}
.login-hero p{color:#cdd9ee;max-width:420px;margin-top:14px}
.login-hero .lh-flow{display:flex;gap:10px;margin-top:34px;flex-wrap:wrap}
.lh-step{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);
  border-radius:999px;padding:8px 15px;font-size:.85rem;font-weight:600}
.lh-step i{color:var(--accent)}
.login-form-wrap{display:flex;align-items:center;justify-content:center;padding:40px}
.login-card{width:100%;max-width:380px}
.login-card h2{font-size:1.5rem;margin-bottom:6px}
.login-card .lc-sub{color:var(--ink-2);margin-bottom:26px;font-size:.92rem}
.demo-box{margin-top:22px;background:var(--surface-2);border:1px solid var(--line);
  border-radius:var(--radius);padding:14px 16px;font-size:.82rem;color:var(--ink-2)}
.demo-box code{color:var(--brand-700);font-weight:700}
.demo-box table{width:100%;border-collapse:collapse}
.demo-box td{padding:3px 0}

/* =====================================================================
   MOBILE  (<992px)  —  TAMPILAN MIRIP MOBILE APP
   ===================================================================== */
@media (max-width:991.98px){
  body{background:var(--bg)}
  .sidebar{display:none}
  .content{margin-left:0}
  .content-head{display:none}                 /* judul ditangani top bar */

  /* Top app bar */
  .mobile-topbar{
    display:flex;align-items:center;gap:6px;
    position:sticky;top:0;z-index:50;
    height:calc(54px + var(--sat));padding:var(--sat) 8px 0;
    background:linear-gradient(180deg,var(--brand-800),var(--brand-700));
    color:#fff;box-shadow:0 2px 10px rgba(15,39,71,.25);
  }
  .mtb-btn{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;
    color:#fff;font-size:1.3rem;flex:none}
  .mtb-btn:active{background:rgba(255,255,255,.12)}
  .mtb-logo{color:#fff;opacity:.95}
  .mtb-title{flex:1;text-align:center;font-weight:700;font-size:1.05rem;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

  .content-body{padding:16px 14px calc(86px + var(--sab));max-width:none}
  .app-alert{border-radius:var(--radius)}

  /* Kartu lebih membulat & “app” */
  .card-x{border-radius:18px;padding:16px}
  .stat-grid{grid-template-columns:1fr 1fr;gap:12px}
  .stat-card{padding:15px;border-radius:16px}
  .stat-card .sc-num{font-size:1.55rem}
  .stat-card .sc-ico{width:38px;height:38px;margin-bottom:9px}
  .cta{border-radius:18px;padding:16px 18px}
  .cta .cta-ico{width:46px;height:46px}

  /* Sembunyikan tabel, tampilkan kartu */
  .req-table{display:none}
  .req-cards{display:flex;flex-direction:column;gap:10px}
  .rc{
    display:flex;align-items:center;gap:12px;background:var(--surface);
    border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow-sm);
    transition:transform .08s;
  }
  .rc:active{transform:scale(.985)}
  .rc-main{flex:1;min-width:0}
  .rc-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}
  .rc-code{font-size:.74rem;font-weight:700;color:var(--brand-700)}
  .rc-tenant{font-weight:700;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .rc-sub{color:var(--ink-2);font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
  .rc-foot{display:flex;align-items:center;gap:10px;margin-top:7px}
  .rc-chev{color:var(--ink-3);font-size:1.3rem;flex:none}

  /* KV jadi satu kolom */
  .kv{grid-template-columns:1fr;gap:3px 0}
  .kv dt{font-size:.78rem;color:var(--ink-3);text-transform:uppercase;letter-spacing:.03em}
  .kv dd{margin-bottom:12px}
  .kv dd:last-child{margin-bottom:0}

  /* Tombol form full-width & tinggi sentuh nyaman */
  .form-actions .btn{width:100%}
  .btn{min-height:46px;border-radius:12px}
  .btn-sm{min-height:36px}
  .form-control,.form-select{font-size:16px;min-height:46px;border-radius:12px}
  textarea.form-control{min-height:auto}

  .chips{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    margin:0 -14px 14px;padding:0 14px 4px;scrollbar-width:none}
  .chips::-webkit-scrollbar{display:none}
  .chip{flex:none}

  /* Editor item biaya -> kartu bertumpuk */
  .items-editor{border:0;background:transparent;overflow:visible}
  .items-head{display:none}
  .item-row{
    display:block;background:var(--surface);border:1px solid var(--line);
    border-radius:16px;padding:14px;margin-bottom:12px;box-shadow:var(--shadow-sm);
  }
  .item-row .ie-cell{margin-bottom:10px}
  .item-row .ie-cell:last-child{margin-bottom:0}
  .item-row .ie-label{display:block;font-size:.74rem;font-weight:700;color:var(--ink-3);
    text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px}
  .item-row .ie-inline{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .item-row .subtotal-cell{text-align:left;font-size:1.05rem;color:var(--brand-700)}
  .item-row .del-cell{display:flex;justify-content:flex-end}
  .item-row .btn-del{width:auto;padding:0 14px;height:38px;gap:6px}
  .item-row .btn-del::after{content:"Hapus";font-size:.85rem;font-weight:600}
  .items-foot{flex-direction:column;align-items:stretch;padding:0}
  .btn-add-item{width:100%;justify-content:center;min-height:46px}
  .totals{min-width:0;background:var(--surface);border:1px solid var(--line);
    border-radius:16px;padding:14px;margin-top:12px}

  canvas.sigpad{height:180px}
  .decision-toggle{flex-direction:column}
  .att-grid{grid-template-columns:1fr 1fr}

  /* FAB */
  .fab{
    position:fixed;right:18px;bottom:calc(80px + var(--sab));z-index:55;
    width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
    background:linear-gradient(135deg,var(--accent),var(--accent-600));color:#fff;
    font-size:1.6rem;box-shadow:0 10px 22px rgba(242,106,27,.45);transition:transform .1s;
  }
  .fab:active{transform:scale(.92)}

  /* Bottom navigation */
  .bottom-nav{
    position:fixed;left:0;right:0;bottom:0;z-index:50;
    display:grid;grid-template-columns:repeat(var(--tabs,4),1fr);
    background:var(--surface);border-top:1px solid var(--line);
    box-shadow:0 -2px 14px rgba(15,23,42,.07);
    padding-bottom:var(--sab);
  }
  .bn-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
    padding:9px 0 8px;color:var(--ink-3);font-size:.68rem;font-weight:600;position:relative}
  .bn-link i{font-size:1.35rem}
  .bn-link.active{color:var(--accent)}
  .bn-link.active::before{content:"";position:absolute;top:0;width:34px;height:3px;
    border-radius:0 0 3px 3px;background:var(--accent)}

  /* Login responsif */
  .login-page{grid-template-columns:1fr}
  .login-hero{display:none}
  .login-form-wrap{padding:26px 18px;min-height:100vh}
}

/* FAB & bottom-nav tak tampil di desktop */
@media (min-width:992px){
  .fab,.bottom-nav,.mobile-topbar{display:none}
}

/* =====================================================================
   PRINT — lembar COGS bersih untuk dicetak / Save as PDF
   ===================================================================== */
@media print{
  .sidebar,.mobile-topbar,.bottom-nav,.fab,.content-head,.app-alert,.no-print{display:none !important}
  body{background:#fff;font-size:12px}
  .content{margin:0 !important}
  .content-body{padding:0 !important;max-width:none}
  .card-x{box-shadow:none;border:1px solid #ccc;border-radius:8px;page-break-inside:avoid}
  .print-only{display:block !important}
  a{color:#000;text-decoration:none}
  .tbl thead th{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}
.print-only{display:none}
