:root{
  --navy:#06142f;
  --navy-2:#09275f;
  --blue:#1667e8;
  --cyan:#04b8df;
  --teal:#12b8a6;
  --gold:#f8b51c;
  --orange:#f97316;
  --green:#22c55e;
  --purple:#7c3aed;
  --red:#ef4444;
  --ink:#102039;
  --muted:#64748b;
  --soft:#f4f8ff;
  --line:#dbe7f3;
  --card:#ffffff;
  --glass:rgba(255,255,255,.88);
  --shadow-sm:0 8px 24px rgba(15,23,42,.06);
  --shadow:0 18px 48px rgba(15,23,42,.10);
  --shadow-lg:0 28px 70px rgba(15,23,42,.16);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;color:var(--ink);background:radial-gradient(circle at 15% 5%,rgba(14,165,233,.18),transparent 26%),radial-gradient(circle at 88% 9%,rgba(20,184,166,.16),transparent 24%),linear-gradient(180deg,#f7fbff 0%,#eef6ff 100%);line-height:1.45}
a{color:inherit}img{max-width:100%}
.layout{display:flex;min-height:100vh}.main{margin-left:292px;width:calc(100% - 292px);min-height:100vh;padding:26px}.sidebar{position:fixed;inset:0 auto 0 0;width:292px;height:100vh;z-index:60;overflow:auto;color:#fff;padding:22px 18px;background:radial-gradient(circle at 20% 2%,rgba(248,181,28,.24),transparent 24%),linear-gradient(180deg,#071326 0%,#09245a 52%,#073b5f 100%);box-shadow:18px 0 44px rgba(2,6,23,.22);border-right:1px solid rgba(255,255,255,.11)}.sidebar::-webkit-scrollbar{width:7px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:99px}
.brand{display:flex;align-items:center;gap:12px;padding:14px;border-radius:22px;background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px 0 rgba(255,255,255,.16);margin-bottom:16px}.brand-logo{width:64px;height:64px;object-fit:contain;background:#fff;border-radius:18px;padding:7px;box-shadow:0 14px 28px rgba(0,0,0,.22);flex:0 0 auto}.brand-logo-text{display:grid;place-items:center;color:#075985;font-weight:950}.brand-text{min-width:0}.brand-text span{display:block;font-size:20px;font-weight:950;line-height:1;letter-spacing:.2px;color:#facc15}.brand-text b{display:block;margin-top:3px;font-size:13px;letter-spacing:.42em}.brand-text small{display:block;margin-top:6px;color:#c7e7ff;font-size:11px;font-weight:700;line-height:1.35}.sidebar-route{display:flex;gap:12px;align-items:center;margin:12px 0 18px;padding:14px;border-radius:20px;background:linear-gradient(135deg,rgba(14,165,233,.22),rgba(6,182,212,.10));border:1px solid rgba(125,211,252,.18)}.sidebar-route span{font-size:26px}.sidebar-route b{display:block}.sidebar-route small{color:#cbd5e1;font-size:12px}.nav{padding-bottom:22px}.nav a{position:relative;display:flex;align-items:center;gap:10px;text-decoration:none;color:#e6f4ff;font-size:14px;font-weight:850;letter-spacing:.01em;padding:12px 13px;border-radius:16px;margin:6px 0;border:1px solid transparent;transition:.18s ease}.nav a:before{content:'◆';font-size:8px;display:grid;place-items:center;width:22px;height:22px;border-radius:8px;background:rgba(37,99,235,.35);color:#facc15;flex:0 0 auto}.nav a:hover,.nav a.active{background:linear-gradient(135deg,#1d4ed8,#06b6d4);border-color:rgba(255,255,255,.18);box-shadow:0 14px 28px rgba(6,182,212,.22);transform:translateX(2px)}.nav .badge{margin-left:auto}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;min-height:22px;padding:4px 8px;border-radius:999px;background:#e2e8f0;color:#334155;font-weight:950;font-size:11px}.badge.red{background:#fee2e2;color:#991b1b}.badge.green{background:#dcfce7;color:#166534}.badge.blue{background:#dbeafe;color:#1d4ed8}.badge.gold,.badge.orange{background:#ffedd5;color:#9a3412}
.topbar{position:sticky;top:14px;z-index:45;display:grid;grid-template-columns:auto minmax(230px,1fr) auto;gap:14px;align-items:center;margin-bottom:22px;background:rgba(255,255,255,.78);backdrop-filter:blur(18px);border:1px solid rgba(219,231,243,.82);border-radius:26px;padding:16px 18px;box-shadow:var(--shadow-sm)}.top-icon{position:relative;width:46px;height:46px;border-radius:16px;border:1px solid var(--line);background:#fff;display:inline-grid;place-items:center;text-decoration:none;color:var(--ink);font-weight:950;box-shadow:0 7px 20px rgba(15,23,42,.05);cursor:pointer}.top-icon em{position:absolute;right:-5px;top:-6px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--red);color:#fff;font-size:11px;font-style:normal;display:grid;place-items:center}.top-search{min-height:46px;display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:0 12px}.top-search input{border:0!important;box-shadow:none!important;background:transparent!important;padding:9px 0!important}.top-search kbd{background:#f8fafc;border:1px solid #e2e8f0;border-bottom-width:2px;border-radius:8px;padding:4px 7px;font-size:11px;color:#64748b}.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.user-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 13px;border-radius:17px;background:#fff;border:1px solid var(--line);font-size:13px;font-weight:900}.user-pill:before{content:'👤';font-size:18px}.user-pill strong{display:block;line-height:1.05}.user-pill small{display:block;color:var(--muted);font-size:11px;font-weight:800}
.card{background:var(--glass);border:1px solid rgba(219,231,243,.9);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;margin-bottom:20px}.card h1,.card h2,.card h3{letter-spacing:-.35px}.card h3{margin-top:0}.muted,.mini{color:var(--muted)}.mini{font-size:12px}.alert{padding:14px 16px;margin-bottom:16px;border-radius:16px;background:#dcfce7;color:#166534;border:1px solid #bbf7d0;font-weight:800}.alert.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}.grid,.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(310px,.65fr);gap:18px}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:15px}.quick-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.report-title{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.dashboard-hero{position:relative;overflow:hidden;color:#fff;border:0!important;background:linear-gradient(135deg,#07153a 0%,#124bb7 52%,#03aee0 100%)!important;min-height:250px}.dashboard-hero:before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 82% 20%,rgba(255,255,255,.26),transparent 16%),radial-gradient(circle at 35% 92%,rgba(20,184,166,.25),transparent 22%)}.dashboard-hero:after{content:'SURABAYA · KUPANG';position:absolute;right:-32px;bottom:18px;color:rgba(255,255,255,.08);font-size:56px;font-weight:1000;letter-spacing:.08em}.hero-content{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:28px;align-items:center}.hero-kicker{color:#facc15;text-transform:uppercase;letter-spacing:.08em;font-weight:950;font-size:12px}.hero-title{font-size:42px;line-height:1;margin:10px 0 8px;color:#fff}.hero-title span{display:block;color:#22d3ee}.hero-sub{color:#dbeafe;font-size:16px}.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.hero-badges span{padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.18);font-weight:850;font-size:13px}.hero-visual{min-height:178px;border-radius:26px;background:linear-gradient(135deg,rgba(255,255,255,.17),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.2);display:grid;place-items:center}.truck-art{font-size:78px;filter:drop-shadow(0 18px 28px rgba(0,0,0,.28))}.route-line{height:3px;width:82%;background:repeating-linear-gradient(90deg,#fff 0 10px,transparent 10px 18px);opacity:.75}.stat{position:relative;overflow:hidden;min-height:134px;background:linear-gradient(135deg,#fff 0%,#f8fbff 100%)}.stat:before{content:'';display:block;width:50px;height:50px;border-radius:18px;margin-bottom:12px;background:linear-gradient(135deg,var(--blue),var(--cyan));box-shadow:0 14px 28px rgba(37,99,235,.22)}.stat:nth-child(2):before{background:linear-gradient(135deg,var(--cyan),var(--teal))}.stat:nth-child(3):before{background:linear-gradient(135deg,var(--orange),var(--gold))}.stat:nth-child(4):before{background:linear-gradient(135deg,var(--green),#86efac)}.stat:nth-child(5):before{background:linear-gradient(135deg,var(--purple),#a78bfa)}.stat:after{content:'';position:absolute;right:-36px;top:-36px;width:116px;height:116px;border-radius:999px;background:linear-gradient(135deg,rgba(14,165,233,.12),rgba(248,181,28,.15))}.stat h3,.stat b{font-size:11px;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);margin:0}.stat p,.stat strong{display:block;margin:10px 0 0;font-size:26px;font-weight:1000;color:#07153a;letter-spacing:-.7px}.stat span{display:block;color:var(--muted);font-size:13px;margin-top:5px}.quick-link{display:flex;align-items:center;gap:10px;text-decoration:none;background:linear-gradient(135deg,#fff,#f8fbff);border:1px solid var(--line);border-radius:18px;padding:14px;font-weight:950;color:#0a1f4b;box-shadow:var(--shadow-sm);transition:.18s}.quick-link:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.quick-link i{font-style:normal;display:grid;place-items:center;width:38px;height:38px;border-radius:14px;background:#dbeafe;color:#1d4ed8}.quick-link:nth-child(2) i{background:#ffedd5;color:#ea580c}.quick-link:nth-child(3) i{background:#dcfce7;color:#16a34a}.quick-link:nth-child(4) i{background:#ede9fe;color:#7c3aed}.activity-item{display:flex;gap:11px;padding:12px 0;border-bottom:1px solid #edf2f7}.activity-dot{width:34px;height:34px;border-radius:14px;display:grid;place-items:center;background:#dbeafe;color:#1d4ed8;flex:none}.activity-item p{margin:0;font-weight:850}.activity-item small{color:#64748b}.chart-fake{height:250px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fff,#f8fbff);padding:14px}.chart-fake svg{width:100%;height:100%}
.btn{border:0;border-radius:14px;min-height:40px;padding:10px 14px;text-decoration:none;color:#fff;background:linear-gradient(135deg,#1d4ed8,#06b6d4);font-weight:950;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:7px;box-shadow:0 12px 24px rgba(37,99,235,.18);transition:.18s}.btn:hover{transform:translateY(-1px);filter:brightness(.99)}.btn.gray{background:linear-gradient(135deg,#475569,#334155)}.btn.green{background:linear-gradient(135deg,#16a34a,#14b8a6)}.btn.red{background:linear-gradient(135deg,#dc2626,#ef4444)}.btn.orange{background:linear-gradient(135deg,#f97316,#f59e0b);color:#172554}.btn.yellow,.btn.gold{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#0f172a}.table-wrap{width:100%;overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff}.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff}.table th,.table td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.table th{position:sticky;top:0;z-index:1;background:linear-gradient(180deg,#f8fbff,#eef6ff);font-size:12px;text-transform:uppercase;color:#475569;letter-spacing:.05em}.table tr:hover td{background:#fbfdff}.table tr:last-child td{border-bottom:0}.table .btn{min-height:34px;padding:8px 10px;font-size:12px}
label{display:block;margin-bottom:6px;color:#25364a;font-size:13px;font-weight:900}input,select,textarea{width:100%;padding:12px 13px;border:1px solid #d7e4f0;border-radius:14px;background:rgba(255,255,255,.94);font:inherit;color:var(--ink);outline:none;transition:.16s}input:focus,select:focus,textarea:focus{border-color:#38bdf8;box-shadow:0 0 0 4px rgba(14,165,233,.14)}input[type=file]{padding:10px;background:#fff}.scanner{border:1px solid rgba(37,99,235,.24);border-radius:20px;min-height:260px;padding:12px;background:radial-gradient(circle at center,rgba(6,182,212,.08),transparent 45%),linear-gradient(135deg,#f8fbff,#fff);box-shadow:inset 0 0 0 1px rgba(255,255,255,.7),0 20px 40px rgba(37,99,235,.10)}.scanner video,#reader video{width:100%!important;border-radius:18px}.scanner-tools{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.scanner-notice{display:grid;grid-template-columns:auto 1fr;gap:10px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;padding:13px;border-radius:16px;margin-top:12px}.scanner-status-ok{background:#dcfce7!important;color:#166534!important;border-color:#bbf7d0!important}.scanner-status-warn{background:#fff7ed!important;color:#9a3412!important;border-color:#fed7aa!important}.photo-grid,.photo-preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.photo-grid img,.photo-preview-grid img{width:100%;height:120px;object-fit:cover;border-radius:16px;border:1px solid var(--line)}.photo-preview-grid img{height:90px}.map-box{background:#f8fafc;border:1px dashed #38bdf8;border-radius:16px;padding:12px}.live-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#16a34a;box-shadow:0 0 0 6px rgba(22,163,74,.15);margin-right:8px}.danger-soft{background:#fff7ed;border-left:5px solid #f59e0b}
/* Unified public/auth pages */
.login-page,.auth-page{min-height:100vh;display:grid;place-items:center;padding:22px;background:radial-gradient(circle at 18% 8%,rgba(248,181,28,.24),transparent 22%),radial-gradient(circle at 78% 16%,rgba(6,182,212,.23),transparent 24%),linear-gradient(135deg,#050b22 0%,#0b2c6f 52%,#06a3d7 100%)}.login-shell,.auth-shell{width:min(1040px,100%);display:grid;grid-template-columns:1.08fr 440px;gap:22px;align-items:stretch}.auth-shell.register{grid-template-columns:1fr;max-width:900px}.login-visual,.auth-visual{display:flex;flex-direction:column;justify-content:space-between;min-height:560px;border-radius:34px;padding:36px;background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.2);box-shadow:0 28px 72px rgba(2,6,23,.29);color:#fff;position:relative;overflow:hidden}.login-visual:after,.auth-visual:after{content:'🚚';position:absolute;right:30px;bottom:38px;font-size:150px;opacity:.16;filter:drop-shadow(0 10px 18px rgba(0,0,0,.3))}.login-visual h1,.auth-visual h1{font-size:50px;line-height:1;margin:0;letter-spacing:-1px}.login-visual h1 span,.auth-visual h1 span{display:block;color:#22d3ee}.login-visual p,.auth-visual p{color:#dbeafe;font-size:17px;max-width:470px}.login-metrics,.auth-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;position:relative;z-index:1}.login-metrics div,.auth-metrics div{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:15px}.login-metrics b,.auth-metrics b{display:block;font-size:22px;color:#facc15}.login-metrics small,.auth-metrics small{display:block;color:#e0f2fe}.login-card,.auth-card{margin:0;align-self:center;border-radius:32px;padding:32px;background:rgba(255,255,255,.95);box-shadow:0 28px 72px rgba(2,6,23,.22)}.auth-card-wide{max-width:900px;width:100%;margin:auto}.login-logo,.auth-logo{width:96px;height:96px;object-fit:contain;border-radius:24px;background:#fff;padding:8px;box-shadow:0 12px 30px rgba(15,23,42,.16);margin-bottom:12px}.login-title,.auth-title{text-align:center;margin-bottom:18px}.login-title h2,.auth-title h2{margin:4px 0 0;font-size:28px}.login-title h3,.auth-title h3{margin:0;color:#082f49}.login-title p,.auth-title p{color:var(--muted);margin:11px auto 0;max-width:540px}.secure-note{text-align:center;background:#f8fbff;border:1px solid var(--line);border-radius:16px;padding:10px;color:var(--muted);font-size:12px}.auth-links{text-align:center;margin-top:16px;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.auth-links a{color:#0b5f8a;font-weight:850}.public-form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.public-form-grid .full{grid-column:1/-1}.public-form-grid .two{grid-column:span 2}.public-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:4px}.mobile-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:1000;border:0;background:linear-gradient(135deg,#07153a,#06b6d4);color:#fff;border-radius:15px;padding:11px 15px;font-weight:950;box-shadow:0 12px 28px rgba(15,23,42,.22)}.mobile-overlay{display:none}
.kop-print{display:flex;align-items:center;gap:14px;border-bottom:3px double #111;padding-bottom:10px;margin-bottom:14px;text-align:left}.kop-print img{max-width:82px;max-height:82px;object-fit:contain}.kop-print h1,.kop-print h2,.kop-print h3{margin:0}.kop-print p{margin:2px 0;color:#334155}.paper-wrap{position:relative;background:#fff}.watermark{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;opacity:.09;font-size:70px;font-weight:1000;transform:rotate(-22deg);color:#111;z-index:0}.paper-content{position:relative;z-index:1}
@media(max-width:1180px){.hero-content{grid-template-columns:1fr}.hero-visual{display:none}.dashboard-grid{grid-template-columns:1fr}.topbar{grid-template-columns:auto 1fr}.topbar-actions{grid-column:1/-1;justify-content:flex-end}.login-shell,.auth-shell{grid-template-columns:1fr;width:min(520px,100%)}.login-visual,.auth-visual{display:none}.public-form-grid,.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.mobile-menu-btn{display:block}.layout{display:block}.sidebar{transform:translateX(-110%);transition:.22s ease;width:min(310px,86vw)}body.sidebar-open .sidebar{transform:translateX(0)}body.sidebar-open .mobile-overlay{display:block;position:fixed;inset:0;background:rgba(2,6,23,.48);z-index:55}.main{margin-left:0;width:100%;padding:72px 14px 18px}.topbar{position:relative;top:auto;grid-template-columns:auto 1fr;border-radius:22px}.top-search{grid-column:1/-1;order:3;width:100%}.topbar-actions{justify-content:flex-start}.dashboard-hero{min-height:auto}.hero-title{font-size:32px}.hero-badges span{font-size:12px}.grid,.grid-4{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))!important}.card{padding:17px}.photo-grid,.photo-preview-grid{grid-template-columns:repeat(2,1fr)}.auth-card,.login-card{border-radius:26px;padding:24px}}
@media(max-width:560px){body{background:#f4f8ff}.login-page,.auth-page{padding:12px;align-items:start}.login-shell,.auth-shell{width:100%;display:block}.login-card,.auth-card{width:100%;padding:20px;border-radius:24px}.login-title h2,.auth-title h2{font-size:22px}.public-form-grid,.form-grid,.grid,.grid-4{grid-template-columns:1fr}.public-form-grid .two{grid-column:1}.quick-actions{grid-template-columns:1fr!important}.hero-title{font-size:27px}.dashboard-hero:after{font-size:30px}.topbar{padding:12px}.user-pill{max-width:100%;font-size:12px}.topbar-actions .btn.gray{display:none}.photo-grid,.photo-preview-grid{grid-template-columns:1fr}.table th,.table td{padding:11px 12px;white-space:nowrap}.card{border-radius:20px}.stat p,.stat strong{font-size:23px}}
@media print{body{background:#fff}.sidebar,.topbar,.mobile-menu-btn,.mobile-overlay,.no-print{display:none!important}.main{margin:0!important;width:100%!important;padding:0!important}.card{box-shadow:none;border:0}.table th,.table td{font-size:11px;padding:7px}.btn{display:none!important}.watermark{display:grid!important}}

/* =========================================================
   FINAL MOBILE LOGIN RESPONSIVE - DUA PUTRY EXPRESS
   Fokus: presisi di HP, jarak kiri/kanan/atas/bawah rapi,
   logo lebih jelas, font kontras dengan background.
   ========================================================= */
.login-page,
.auth-page{
  min-height:100vh;
  min-height:100svh;
  min-height:100dvh;
  overflow-x:hidden;
  padding:max(16px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));
  background:
    radial-gradient(circle at 18% 6%,rgba(255,201,64,.28),transparent 24%),
    radial-gradient(circle at 88% 18%,rgba(34,211,238,.28),transparent 25%),
    linear-gradient(155deg,#061331 0%,#0b347a 54%,#08acd2 100%);
  background-attachment:fixed;
}
.login-shell,
.auth-shell{
  width:min(1040px,100%);
}
.login-card,
.auth-card{
  border:1px solid rgba(255,255,255,.56);
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(244,250,255,.94));
  box-shadow:0 26px 70px rgba(2,12,36,.30);
}
.login-logo,
.auth-logo{
  width:92px;
  height:92px;
  border-radius:24px;
  padding:7px;
  object-fit:contain;
  image-rendering:auto;
  filter:contrast(1.08) saturate(1.08);
  box-shadow:0 14px 34px rgba(6,20,47,.18);
}
.login-title h2,
.auth-title h2{
  color:#061331;
  font-weight:1000;
  letter-spacing:-.65px;
  line-height:1.08;
}
.login-title h3,
.auth-title h3{
  color:#073b5f;
  font-weight:950;
  letter-spacing:-.25px;
  line-height:1.18;
}
.login-title p,
.auth-title p{
  color:#526985;
  font-weight:650;
}
.login-card label,
.auth-card label{
  color:#061331;
  font-weight:950;
}
.login-card input,
.auth-card input,
.auth-card select,
.auth-card textarea{
  min-height:49px;
  background:#edf5ff;
  border-color:#cdddf1;
  color:#061331;
  font-weight:650;
}
.login-card input::placeholder,
.auth-card input::placeholder{
  color:#71849c;
  font-weight:600;
}
.login-card .btn.gold,
.auth-card .btn.gold,
.login-card button.btn.gold{
  min-height:48px;
  border-radius:15px;
  font-weight:1000;
  box-shadow:0 14px 28px rgba(245,158,11,.20);
}
.login-card .secure-note,
.auth-card .secure-note{
  border-color:#d4e3f4;
  background:rgba(248,251,255,.92);
  color:#53677f;
  line-height:1.45;
}
.login-card .auth-links,
.auth-card .auth-links{
  align-items:center;
}
.login-card .auth-links .btn,
.auth-card .auth-links .btn{
  color:#064d68;
  background:linear-gradient(135deg,#22c7e8,#0ea5d7);
  box-shadow:0 12px 24px rgba(14,165,215,.18);
}
.login-card .auth-links a:not(.btn),
.auth-card .auth-links a:not(.btn){
  color:#075985;
  text-decoration:underline;
  text-underline-offset:4px;
  font-weight:950;
}

@media(max-width:1180px){
  .login-page,
  .auth-page{
    place-items:center;
  }
  .login-shell,
  .auth-shell{
    width:min(520px,100%);
  }
}

@media(max-width:560px){
  body.login-page,
  body.auth-page{
    background:
      radial-gradient(circle at 18% 6%,rgba(255,201,64,.24),transparent 25%),
      radial-gradient(circle at 88% 18%,rgba(34,211,238,.26),transparent 25%),
      linear-gradient(155deg,#061331 0%,#0b347a 56%,#08acd2 100%) !important;
  }
  .login-page,
  .auth-page{
    place-items:center !important;
    align-items:center !important;
    padding:clamp(10px,3.2vw,16px) !important;
  }
  .login-shell,
  .auth-shell{
    width:100%;
    max-width:460px;
    margin:0 auto;
  }
  .login-card,
  .auth-card{
    width:100%;
    margin:0 auto;
    border-radius:22px;
    padding:clamp(18px,4.5vw,24px);
  }
  .login-logo,
  .auth-logo{
    width:84px;
    height:84px;
    border-radius:22px;
    margin-bottom:11px;
  }
  .login-title,
  .auth-title{
    margin-bottom:18px;
  }
  .login-title h2,
  .auth-title h2{
    font-size:clamp(21px,5.4vw,26px);
  }
  .login-title h3,
  .auth-title h3{
    font-size:clamp(16px,4.3vw,19px);
    margin-top:3px;
  }
  .login-title p,
  .auth-title p{
    font-size:clamp(13px,3.6vw,15px);
    margin-top:12px;
  }
  .login-card label,
  .auth-card label{
    font-size:13px;
    margin-bottom:8px;
  }
  .login-card input,
  .auth-card input,
  .auth-card select,
  .auth-card textarea{
    min-height:48px;
    border-radius:15px;
    padding:11px 13px;
    font-size:15px;
  }
  .login-card form br,
  .auth-card form br{
    display:none;
  }
  .login-card form label:not(:first-of-type),
  .auth-card form label:not(:first-of-type){
    margin-top:18px;
  }
  .login-card form .btn,
  .auth-card form .btn{
    margin-top:22px;
  }
  .login-card .secure-note,
  .auth-card .secure-note{
    margin-top:16px !important;
    padding:12px 11px;
    border-radius:16px;
    font-size:12px;
  }
  .login-card .auth-links,
  .auth-card .auth-links{
    margin-top:16px;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  .login-card .auth-links .btn,
  .auth-card .auth-links .btn,
  .login-card .auth-links a:not(.btn),
  .auth-card .auth-links a:not(.btn){
    min-height:44px;
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    border-radius:15px;
    font-size:clamp(13px,3.7vw,15px);
    line-height:1.2;
  }
}

@media(max-width:380px){
  .login-card,
  .auth-card{
    padding:16px;
    border-radius:20px;
  }
  .login-logo,
  .auth-logo{
    width:76px;
    height:76px;
  }
  .login-card .auth-links,
  .auth-card .auth-links{
    grid-template-columns:1fr;
  }
}

@media(max-height:700px) and (max-width:560px){
  .login-page,
  .auth-page{
    place-items:start center !important;
    align-items:start !important;
    padding-top:10px !important;
    padding-bottom:10px !important;
  }
  .login-logo,
  .auth-logo{
    width:74px;
    height:74px;
    margin-bottom:8px;
  }
  .login-title,
  .auth-title{
    margin-bottom:14px;
  }
  .login-title p,
  .auth-title p{
    margin-top:8px;
  }
  .login-card,
  .auth-card{
    padding:16px;
  }
  .login-card input,
  .auth-card input,
  .auth-card select,
  .auth-card textarea{
    min-height:46px;
  }
  .login-card form label:not(:first-of-type),
  .auth-card form label:not(:first-of-type){
    margin-top:14px;
  }
  .login-card form .btn,
  .auth-card form .btn{
    margin-top:18px;
  }
  .login-card .secure-note,
  .auth-card .secure-note{
    margin-top:12px !important;
  }
  .login-card .auth-links,
  .auth-card .auth-links{
    margin-top:12px;
  }
}

/* =========================================================
   SIDEBAR MENU TERSTRUKTUR FINAL - DUA PUTRY EXPRESS
   Menu dikelompokkan sesuai fungsi agar tidak berantakan.
   Aman: hanya CSS tampilan, logic akses menu tetap dari PHP.
   ========================================================= */
.nav.nav-structured{
  display:block;
  padding:4px 0 28px;
}
.nav.nav-structured .nav-group{
  margin:10px 0;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(255,255,255,.075),rgba(255,255,255,.025));
  overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.nav.nav-structured .nav-group[open]{
  background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(6,182,212,.055));
  border-color:rgba(125,211,252,.20);
}
.nav.nav-structured summary{
  list-style:none;
  cursor:pointer;
  user-select:none;
  min-height:48px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  color:#f8fbff;
  font-weight:1000;
  font-size:13px;
  letter-spacing:.02em;
  outline:none;
}
.nav.nav-structured summary::-webkit-details-marker{display:none}
.nav.nav-structured .nav-group-icon{
  width:30px;
  height:30px;
  flex:0 0 30px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:linear-gradient(135deg,rgba(37,99,235,.42),rgba(6,182,212,.25));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.nav.nav-structured .nav-group-title{
  flex:1;
  min-width:0;
  white-space:normal;
  line-height:1.2;
}
.nav.nav-structured .nav-arrow{
  width:24px;
  height:24px;
  flex:0 0 24px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#facc15;
  transition:transform .18s ease;
}
.nav.nav-structured .nav-group[open] .nav-arrow{
  transform:rotate(180deg);
}
.nav.nav-structured .nav-group-list{
  padding:0 8px 10px 8px;
}
.nav.nav-structured a.nav-link{
  margin:4px 0;
  padding:10px 10px;
  border-radius:14px;
  display:flex;
  align-items:center;
  gap:9px;
  color:#dcefff;
  font-size:13px;
  font-weight:850;
  line-height:1.25;
  background:transparent;
  border:1px solid transparent;
  text-decoration:none;
  transform:none;
  box-shadow:none;
}
.nav.nav-structured a.nav-link:before{display:none!important;content:none!important}
.nav.nav-structured .nav-dot{
  width:18px;
  height:18px;
  flex:0 0 18px;
  border-radius:8px;
  background:rgba(14,165,233,.18);
  border:1px solid rgba(125,211,252,.18);
  position:relative;
}
.nav.nav-structured .nav-dot:after{
  content:'';
  position:absolute;
  inset:6px;
  border-radius:99px;
  background:#facc15;
}
.nav.nav-structured .nav-label{
  flex:1;
  min-width:0;
  white-space:normal;
  overflow-wrap:anywhere;
}
.nav.nav-structured a.nav-link:hover,
.nav.nav-structured a.nav-link.active{
  background:linear-gradient(135deg,rgba(29,78,216,.96),rgba(6,182,212,.88));
  color:#fff;
  border-color:rgba(255,255,255,.20);
  box-shadow:0 10px 22px rgba(6,182,212,.18);
}
.nav.nav-structured a.nav-link.active .nav-dot{
  background:rgba(255,255,255,.24);
  border-color:rgba(255,255,255,.32);
}
.nav.nav-structured .badge{
  margin-left:auto;
  flex:0 0 auto;
  min-width:22px;
}
.nav.nav-structured .nav-logout{
  margin:14px 0 0;
  padding:12px 14px;
  border-radius:16px;
  background:linear-gradient(135deg,#ef4444,#f97316);
  color:#fff;
  border:1px solid rgba(255,255,255,.15);
  justify-content:center;
  font-weight:1000;
  box-shadow:0 14px 28px rgba(239,68,68,.16);
}
.nav.nav-structured .nav-logout:before{display:none!important;content:none!important}
.sidebar{
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.28) transparent;
}
.sidebar .brand{
  margin-bottom:12px;
}
.sidebar-route{
  margin-bottom:14px;
}

@media(max-width:900px){
  .sidebar{
    width:min(320px,88vw);
    padding:16px 14px;
  }
  .nav.nav-structured summary{
    min-height:46px;
    padding:10px 11px;
    font-size:12.8px;
  }
  .nav.nav-structured a.nav-link{
    font-size:12.8px;
    padding:10px;
  }
  .brand-logo{
    width:58px;
    height:58px;
  }
  .brand-text span{
    font-size:18px;
  }
  .brand-text b{
    letter-spacing:.35em;
  }
}

@media(max-width:420px){
  .sidebar{
    width:90vw;
  }
  .brand{
    padding:12px;
    border-radius:20px;
  }
  .sidebar-route{
    padding:12px;
    border-radius:18px;
  }
  .nav.nav-structured .nav-group{
    border-radius:16px;
    margin:8px 0;
  }
  .nav.nav-structured .nav-group-list{
    padding-left:7px;
    padding-right:7px;
  }
}

/* DASHBOARD LINK AKTIF - FINAL */
.dashboard-stat-links .stat-link,
a.card.stat.stat-link{
  display:block;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
  outline:none;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.dashboard-stat-links .stat-link:hover,
a.card.stat.stat-link:hover,
.dashboard-stat-links .stat-link:focus-visible,
a.card.stat.stat-link:focus-visible{
  transform:translateY(-3px);
  border-color:rgba(14,165,233,.45);
  box-shadow:0 20px 42px rgba(15,23,42,.16);
}
.stat-link em{
  position:relative;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:12px;
  padding:7px 10px;
  border-radius:999px;
  background:#e0f2fe;
  color:#075985;
  font-style:normal;
  font-size:12px;
  font-weight:950;
}
.stat-link em:after{content:'›';font-size:15px;line-height:1}
.activity-link{
  text-decoration:none;
  color:inherit;
  border-radius:14px;
  padding-left:8px;
  padding-right:8px;
  margin-left:-8px;
  margin-right:-8px;
  transition:background .18s ease, transform .18s ease;
}
.activity-link:hover,
.activity-link:focus-visible{
  background:#f1f7ff;
  transform:translateX(3px);
}
.quick-link:active,.stat-link:active,.activity-link:active{transform:scale(.99)}
@media(max-width:560px){
  .dashboard-stat-links .stat-link{min-height:126px}
  .stat-link em{width:100%;justify-content:center;margin-top:10px}
}


/* =========================================================
   FINAL POLISH: FOOTER + MODERN RESPONSIVE PRESISI
   Developer copyright: Atasoge Software 2026
   ========================================================= */
.main{
  display:flex;
  flex-direction:column;
}
.app-footer{
  margin-top:auto;
  padding:18px 20px;
  border:1px solid rgba(219,231,243,.92);
  border-radius:22px;
  background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(239,249,255,.86));
  box-shadow:0 16px 38px rgba(15,23,42,.07);
  color:#0f2747;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  font-size:13px;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.footer-brand b{
  padding:7px 11px;
  border-radius:999px;
  background:linear-gradient(135deg,#06142f,#0ea5e9);
  color:#fff;
  letter-spacing:.03em;
  box-shadow:0 10px 22px rgba(14,165,233,.16);
}
.footer-brand span{
  font-weight:950;
  color:#0b3b61;
}
.footer-note{
  color:#64748b;
  font-weight:750;
}
.card,
.topbar,
.app-footer{
  max-width:100%;
}
.table{
  min-width:780px;
}
.card > div[style*="overflow:auto"],
.table-wrap{
  -webkit-overflow-scrolling:touch;
}
.form-grid input,
.form-grid select,
.form-grid textarea,
.public-form-grid input,
.public-form-grid select,
.public-form-grid textarea{
  width:100%;
}
@media(max-width:900px){
  .app-footer{
    border-radius:18px;
    padding:15px;
    margin-top:18px;
  }
  .footer-note{
    width:100%;
  }
}
@media(max-width:560px){
  .main{
    padding-left:max(12px,env(safe-area-inset-left));
    padding-right:max(12px,env(safe-area-inset-right));
    padding-bottom:max(16px,env(safe-area-inset-bottom));
  }
  .app-footer{
    text-align:center;
    justify-content:center;
    font-size:12px;
    gap:10px;
  }
  .footer-brand{
    justify-content:center;
  }
  .footer-brand b,
  .footer-brand span,
  .footer-note{
    width:100%;
  }
  .topbar{
    gap:10px;
  }
  .card h1{font-size:24px;line-height:1.12}
  .card h2{font-size:21px;line-height:1.15}
  .card h3{font-size:18px;line-height:1.18}
  .btn{
    min-height:42px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
}
