/* ============================================================
   Insentif Teknisi — Solusi Fiber  ·  Premium UI
   Font: Plus Jakarta Sans (self-hosted)
   ============================================================ */
@font-face{font-family:'Plus Jakarta Sans';font-weight:400;font-display:swap;src:url('/static/fonts/pjs-400.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:500;font-display:swap;src:url('/static/fonts/pjs-500.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:600;font-display:swap;src:url('/static/fonts/pjs-600.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:700;font-display:swap;src:url('/static/fonts/pjs-700.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:800;font-display:swap;src:url('/static/fonts/pjs-800.woff2') format('woff2')}

:root{
  --navy:#0E1B33; --navy-2:#16294a; --ink:#15233d; --muted:#68758d; --muted-2:#9aa6ba;
  --azure:#1B9DE3; --azure-deep:#0c6fb2; --azure-soft:#e9f5fd;
  --paper:#f3f6fb; --card:#ffffff; --line:#e7ecf4; --line-2:#eef2f8;
  --good:#10996a; --good-soft:#e7f6ee; --amber:#b87708; --amber-soft:#fdf2dd;
  --rose:#d6453a; --rose-soft:#fde9e7; --slate:#64748b;
  --font:'Plus Jakarta Sans',-apple-system,'Segoe UI',Roboto,system-ui,sans-serif;
  --r:16px; --r-sm:11px; --r-pill:999px; --side-w:236px;
  --sh:0 1px 2px rgba(14,27,51,.04),0 12px 34px rgba(14,27,51,.05);
  --sh-lg:0 20px 55px rgba(10,23,46,.30);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font);font-size:14.5px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--azure-deep);text-decoration:none}
h1,h2,h3{margin:0 0 .5rem;letter-spacing:-.02em;font-weight:700}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
.muted{color:var(--muted)} .small{font-size:.8rem} .center{text-align:center} .right{text-align:right}
::selection{background:var(--azure);color:#fff}

/* ---------- shell ---------- */
.app{display:flex;min-height:100vh}
.scrim{display:none;position:fixed;inset:0;background:rgba(10,23,46,.55);z-index:40;backdrop-filter:blur(2px)}
.sidebar{width:var(--side-w);flex-shrink:0;z-index:50;background:linear-gradient(176deg,var(--navy),#0a1526);
  color:#c4d2e6;padding:1.2rem .8rem;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden auto;scrollbar-width:none;-ms-overflow-style:none}
.sidebar::-webkit-scrollbar{width:0;height:0;display:none}
.brand{font-weight:800;letter-spacing:-.025em;font-size:1.34rem;color:#fff;padding:0 .5rem;position:relative}
.brand span{color:var(--azure)}
.brand::after{content:"";display:block;height:2px;width:42px;margin:.7rem .5rem 0;border-radius:2px;background:linear-gradient(90deg,var(--azure),transparent)}
.brand small{display:block;font-weight:500;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:#6f86a6;margin-top:.55rem}
.sidebar nav{margin-top:1.05rem;display:flex;flex-direction:column;gap:1px}
.sidebar nav a{display:flex;align-items:center;gap:.7rem;padding:.52rem .65rem;white-space:nowrap;border-radius:10px;color:#bccbe0;font-size:.9rem;font-weight:500;position:relative;transition:.15s}
.sidebar nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.sidebar nav a.active{background:rgba(27,157,227,.14);color:#fff}
.sidebar nav a.active::before{content:"";position:absolute;left:-.5rem;top:14%;bottom:14%;width:3px;border-radius:3px;background:var(--azure)}
.nav-sep{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:#5f7596;margin:.85rem .65rem .3rem;font-weight:600}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:30;background:rgba(243,246,251,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);padding:1.15rem 2rem .95rem;display:flex;align-items:flex-start;gap:.85rem}
.topbar .tb-main{flex:1;min-width:0}
.topbar .eye{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--azure-deep);font-weight:700}
.topbar h1{font-weight:800;font-size:1.55rem;letter-spacing:-.035em;margin:.15rem 0 0;color:var(--navy);line-height:1.1}
.topbar .thr{height:2px;width:48px;margin-top:.55rem;border-radius:2px;background:linear-gradient(90deg,var(--azure),transparent)}
.hamburger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:11px;background:#fff;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:4px;flex-shrink:0}
.hamburger span{display:block;width:18px;height:2px;background:var(--navy);border-radius:2px}
.userbox{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.who{text-align:right;line-height:1.2}
.who b{font-weight:600;font-size:.84rem}
.who em{display:block;color:var(--muted);font-style:normal;font-size:.7rem;text-transform:capitalize}
.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-weight:700;color:#04263e;
  background:linear-gradient(150deg,#5fc6f5,var(--azure));font-size:.85rem}
.content{padding:1.7rem 2rem 3rem;max-width:1100px;width:100%}

/* ---------- cards & grid ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:1.4rem;margin-bottom:1.4rem}
.card h3,.card h2{font-weight:700;font-size:1.1rem;letter-spacing:-.02em;color:var(--navy);margin-bottom:.9rem}
.card .sub{color:var(--muted);font-size:.82rem;margin:-.65rem 0 1.1rem}
.grid{display:grid;gap:1.4rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.cols{display:grid;grid-template-columns:1.3fr 1fr;gap:1.4rem}

/* ---------- statement (dashboard hero) ---------- */
.statement{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);
  display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden;margin-bottom:1.4rem}
.fig{padding:1.3rem 1.4rem;border-left:1px solid var(--line-2)}
.fig:first-child{border-left:none}
.fig .l{font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:600}
.fig .v{font-size:1.85rem;font-weight:800;letter-spacing:-.03em;margin-top:.3rem;color:var(--navy)}
.fig .v.rp{font-size:1.4rem}
.fig .d{font-size:.74rem;color:var(--muted-2);margin-top:.1rem}
.fig a.d{color:var(--azure-deep);font-weight:600}

/* legacy .stat support */
.stat{display:flex;flex-direction:column;gap:.25rem}
.stat-label{color:var(--muted);font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.stat-num{font-size:1.7rem;font-weight:800;letter-spacing:-.03em}
.stat-link{font-size:.8rem;font-weight:600;color:var(--azure-deep)}

/* ---------- pipeline / stepper ---------- */
.pipe{display:flex;align-items:flex-start;margin-top:.4rem}
.pstep{flex:1;text-align:center;position:relative;padding:0 .2rem}
.pstep .node{width:42px;height:42px;border-radius:50%;margin:0 auto;display:grid;place-items:center;background:#fff;
  border:2px solid var(--line);color:var(--muted-2);font-weight:700;position:relative;z-index:2;font-size:.95rem}
.pstep.done .node{background:var(--azure);border-color:var(--azure);color:#fff;box-shadow:0 6px 16px rgba(27,157,227,.35)}
.pstep.now .node{border-color:var(--azure);color:var(--azure-deep);box-shadow:0 0 0 4px var(--azure-soft)}
.pstep .bar{position:absolute;top:21px;left:-50%;width:100%;height:2px;background:var(--line);z-index:1}
.pstep.done .bar,.pstep.now .bar{background:var(--azure)}
.pstep:first-child .bar{display:none}
.pstep .nm{font-size:.78rem;font-weight:600;margin-top:.55rem;color:var(--ink)}
.pstep .ct{font-size:.72rem;color:var(--muted)}
.pstep.now .nm{color:var(--azure-deep)}

/* ---------- status list ---------- */
.slist{display:flex;flex-direction:column;gap:.85rem}
.srow{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:center}
.srow .nm{font-size:.86rem;color:var(--ink);font-weight:500}
.srow .ct{font-weight:700;color:var(--navy);font-size:.9rem}
.srow .track{grid-column:1/3;height:6px;border-radius:6px;background:var(--line-2);overflow:hidden}
.srow .track i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--azure),var(--azure-deep))}

/* ---------- chart ---------- */
.chart{width:100%;height:175px;display:block}

/* ---------- estimate ---------- */
.estimate{border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden}
.estimate .er{display:flex;justify-content:space-between;gap:1rem;padding:.7rem 1rem;border-bottom:1px solid var(--line-2);font-size:.88rem}
.estimate .er .basis{color:var(--muted);font-size:.76rem;display:block;font-weight:400}
.estimate .er b{font-weight:700;color:var(--navy);white-space:nowrap}
.estimate .tot{background:var(--navy);color:#fff;padding:.85rem 1rem;display:flex;justify-content:space-between;align-items:center}
.estimate .tot .v{font-weight:800;font-size:1.2rem;letter-spacing:-.02em}

/* ---------- forms ---------- */
label{display:block;font-size:.76rem;color:var(--muted);margin:.8rem 0 .3rem;font-weight:600;letter-spacing:.01em}
input,select,textarea{width:100%;padding:.7rem .8rem;border:1px solid var(--line);border-radius:11px;font:inherit;font-size:.92rem;background:#fff;color:var(--ink);min-height:46px;transition:border-color .15s,box-shadow .15s}
textarea{min-height:auto}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 3px var(--azure-soft)}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2368758d' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2rem}
fieldset{border:1px solid var(--line);border-radius:12px;padding:.4rem 1rem 1rem;margin:0 0 1rem}
legend{font-size:.7rem;font-weight:700;padding:0 .45rem;color:var(--azure-deep);text-transform:uppercase;letter-spacing:.06em}
.row-inline{display:flex;gap:.6rem;margin-bottom:.5rem}
.inline{display:inline-flex;align-items:center;gap:.35rem;width:auto;margin:0}
.inline input{width:auto;min-height:auto}
.edit-form{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;margin-top:.55rem;padding:.6rem;background:var(--paper);border-radius:11px}
.edit-form input,.edit-form select{width:auto;min-height:40px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.7rem 1.1rem;min-height:46px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:11px;cursor:pointer;font:inherit;font-weight:600;font-size:.9rem;line-height:1;transition:transform .08s,background .15s;text-align:center}
.btn:hover{background:var(--paper)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(150deg,var(--azure),var(--azure-deep));border-color:transparent;color:#fff;box-shadow:0 8px 20px rgba(27,157,227,.26)}
.btn-primary:hover{filter:brightness(1.05)}
.btn-danger{background:var(--rose);border-color:transparent;color:#fff}
.btn-ghost{background:transparent;border-color:transparent;color:var(--azure-deep)}
.btn-sm{padding:.42rem .7rem;min-height:38px;font-size:.82rem}
.btn-block{width:100%;margin-top:1rem}
.btn-row{display:flex;gap:.55rem;flex-wrap:wrap;margin-top:.6rem}
details summary{list-style:none;display:inline-block;cursor:pointer}
details summary::-webkit-details-marker{display:none}

/* ---------- tables (ledger) ---------- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:.66rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:0 .55rem .7rem;border-bottom:1px solid var(--line)}
.table td{padding:.85rem .55rem;border-bottom:1px solid var(--line-2);font-size:.9rem}
.table tbody tr:last-child td{border-bottom:none}
.table tbody tr{transition:background .12s}
.table tbody tr:hover{background:var(--paper)}
.table tfoot th{font-size:.92rem;text-transform:none;border-top:2px solid var(--line);border-bottom:none;color:var(--navy);padding-top:.8rem}
.kv{width:100%;border-collapse:collapse}
.kv th{text-align:left;color:var(--muted);font-weight:500;width:44%;padding:.42rem 0;vertical-align:top;font-size:.85rem}
.kv td{padding:.42rem 0;font-weight:520;font-size:.9rem}
.list{margin:.3rem 0;padding-left:1.1rem}.list li{margin:.15rem 0}

/* ---------- toolbar / chips ---------- */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.1rem;flex-wrap:wrap}
.filters,.chips{display:flex;gap:.4rem;flex-wrap:wrap}
.chip{padding:.4rem .8rem;min-height:36px;display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-pill);font-size:.8rem;font-weight:600;color:var(--ink);background:#fff;cursor:pointer}
.chip:hover{border-color:var(--azure)}
.chip.active{background:linear-gradient(150deg,var(--azure),var(--azure-deep));border-color:transparent;color:#fff}
.tag{display:inline-block;background:var(--azure-soft);color:var(--azure-deep);padding:.15rem .55rem;border-radius:8px;font-size:.78rem;font-weight:600;margin:0 .25rem .25rem 0}
.crumb{font-size:.8rem;color:var(--muted)} .crumb a{color:var(--muted)}

/* ---------- badges (premium pill) ---------- */
.job-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:600;padding:.24rem .6rem;border-radius:var(--r-pill);border:1px solid transparent;white-space:nowrap}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.badge-gray,.badge-slate{color:var(--muted);background:#eef1f6;border-color:#e1e7f0}
.badge-blue,.badge-teal{color:var(--azure-deep);background:var(--azure-soft);border-color:#cfeafb}
.badge-amber{color:var(--amber);background:var(--amber-soft);border-color:#f4e2bd}
.badge-red{color:var(--rose);background:var(--rose-soft);border-color:#f6cfca}
.badge-green{color:var(--good);background:var(--good-soft);border-color:#c7ead6}

/* ---------- alerts ---------- */
.alert{padding:.8rem 1rem;border-radius:12px;margin-bottom:1.1rem;font-size:.88rem;font-weight:500}
.alert-error{background:var(--rose-soft);color:#a52c1a;border:1px solid #f4ccc4}
.alert-ok{background:var(--good-soft);color:#0c7340;border:1px solid #bce6cd}

/* ---------- photos ---------- */
.thumbs{display:flex;flex-wrap:wrap;gap:.65rem}
.thumbs a{position:relative;display:block;width:124px;border-radius:12px;overflow:hidden;box-shadow:var(--sh)}
.thumbs img{width:124px;height:94px;object-fit:cover;display:block}
.thumbs span{position:absolute;bottom:5px;left:5px;background:rgba(10,23,46,.74);color:#fff;font-size:.62rem;font-weight:600;padding:2px 6px;border-radius:6px;text-transform:capitalize}

/* ---------- login ---------- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1.2rem;
  background:radial-gradient(1200px 600px at 70% -10%,#15538f 0%,transparent 60%),linear-gradient(160deg,var(--navy),#0a1729)}
.login-card{background:var(--card);border-radius:22px;padding:2.2rem 1.9rem;width:100%;max-width:374px;box-shadow:var(--sh-lg)}
.login-card .brand{font-size:1.6rem;color:var(--navy);margin-bottom:1.5rem;text-align:center}
.login-card .brand::after{margin-left:auto;margin-right:auto}
.login-card .brand small{color:var(--muted)}

/* ---------- responsive ---------- */
@media(max-width:960px){
  :root{--side-w:268px}
  .hamburger{display:inline-flex}
  .sidebar{position:fixed;top:0;left:0;height:100vh;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--sh-lg)}
  body.nav-open .sidebar{transform:translateX(0)}
  body.nav-open .scrim{display:block}
  .grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}
  .cols{grid-template-columns:1fr}
  .topbar,.content{padding-left:1.1rem;padding-right:1.1rem}
}
@media(max-width:680px){
  body{font-size:14px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .statement{grid-template-columns:1fr 1fr}
  .fig{border-top:1px solid var(--line-2)} .fig:nth-child(-n+2){border-top:none} .fig:nth-child(odd){border-left:none}
  .who{display:none}
  .topbar h1{font-size:1.35rem}
  .pipe{flex-direction:column;gap:.15rem;align-items:stretch}
  .pstep{display:flex;align-items:center;gap:.9rem;text-align:left;padding:.3rem 0}
  .pstep .node{margin:0} .pstep .bar{display:none}
  /* tabel -> kartu */
  .table thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
  .table,.table tbody{display:block;width:100%}
  .table tr{display:block;border:1px solid var(--line);border-radius:12px;background:var(--card);padding:.35rem .85rem;margin-bottom:.7rem;box-shadow:var(--sh)}
  .table tbody tr:hover{background:var(--card)}
  .table td{display:flex;justify-content:space-between;align-items:center;gap:1rem;border:none;border-bottom:1px solid var(--line-2);padding:.55rem 0;text-align:right}
  .table tr td:last-child{border-bottom:none}
  .table td::before{content:attr(data-label);font-weight:600;color:var(--muted);text-align:left;font-size:.76rem;flex-shrink:0}
  .table td:empty{display:none}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}
