:root {
  --navy: #0f1729;
  --app-topbar-height: 76px;
  --abk-sticky-head-height: 88px;
  --navy-soft: #1a2744;
  --navy-mid: #243656;
  --gold: #c9a962;
  --gold-light: #e8d5a3;
  --gold-dark: #a8863a;
  --cream: #faf8f5;
  --cream-dark: #f3efe8;
  --blue: #243656;
  --blue-dark: #0f1729;
  --text: #1c2434;
  --muted: #64748b;
  --line: #e8e4dc;
  --line-soft: #f0ece4;
  --bg: #f5f2ec;
  --card: #fff;
  --accent-red: #c62828;
  --xp-yes: #2e7d32;
  --shadow-sm: 0 2px 8px rgba(15, 23, 41, 0.06);
  --shadow-md: 0 8px 32px rgba(15, 23, 41, 0.08);
  --shadow-lg: 0 20px 60px rgba(15, 23, 41, 0.12);
  --radius: 12px;
  --radius-lg: 16px;
  --font-display: Georgia, "Times New Roman", serif;
  --font-body: "Segoe UI", Tahoma, system-ui, sans-serif;
}

* { box-sizing: border-box; }

input[type="text"],
input[type="search"],
input[type="tel"],
input[type="email"],
input:not([type]),
textarea {
  text-transform: uppercase;
}
input[type="url"],
input[type="password"],
input[type="file"],
input[type="hidden"],
input[type="radio"],
input[type="checkbox"],
input[type="button"],
input[type="submit"],
input[type="reset"],
input[data-no-upper],
textarea[data-no-upper],
.auth-form input,
.abk-portal-login-form input,
input[autocomplete="username"],
input[autocomplete="current-password"],
input[autocomplete="new-password"],
input[name="username"],
input[name="password"],
input[name="password_confirm"],
[data-no-upper] input,
[data-no-upper] textarea {
  text-transform: none;
  letter-spacing: normal;
}

body {
  margin: 0;
  font-family: var(--font-body);
  background:
    radial-gradient(ellipse 120% 80% at 100% 0%, rgba(201, 169, 98, 0.08), transparent 50%),
    radial-gradient(ellipse 80% 60% at 0% 100%, rgba(15, 23, 41, 0.04), transparent 45%),
    var(--bg);
  color: var(--text);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 1100;
  display: flex;
  justify-content: center;
  padding: 0;
  background:
    radial-gradient(ellipse 90% 140% at 0% 0%, rgba(201, 169, 98, 0.14), transparent 55%),
    linear-gradient(135deg, #0a1020 0%, var(--navy) 38%, var(--navy-soft) 100%);
  color: #fff;
  border-bottom: 1px solid rgba(201, 169, 98, 0.32);
  box-shadow:
    0 10px 32px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
.topbar::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--gold-dark) 20%, var(--gold-light) 50%, var(--gold-dark) 80%, transparent 100%);
  pointer-events: none;
}
.topbar-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px 18px;
  width: 100%;
  max-width: min(100%, 1600px);
  padding: 12px 22px;
  overflow: visible;
}

.app-sticky-chrome {
  position: sticky;
  top: 0;
  z-index: 1100;
}

.app-back-bar {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.22);
  background: linear-gradient(180deg, rgba(250, 248, 245, 0.98) 0%, #fff 100%);
  box-shadow: 0 4px 14px rgba(15, 23, 41, 0.06);
}

.app-back-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 40px;
  padding: 8px 14px;
  border: 1px solid rgba(15, 23, 41, 0.12);
  border-radius: 10px;
  background: #fff;
  color: var(--navy, #0f172a);
  font: inherit;
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
}

.app-back-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(201, 169, 98, 0.55);
  background: rgba(250, 248, 245, 0.95);
}

.app-back-btn-topbar {
  flex: 0 0 auto;
  min-height: 38px;
  padding: 6px 12px;
}

.app-back-btn-topbar .app-back-label {
  display: none;
}

.app-back-btn-bar {
  width: 100%;
  max-width: 220px;
  justify-content: flex-start;
}

.app-back-btn-inline {
  border: none;
  background: transparent;
  min-height: auto;
  padding: 8px 0;
  font-weight: 600;
}

.app-back-icon {
  font-size: 1.05rem;
  line-height: 1;
}

.page-with-back-bar {
  padding-top: clamp(10px, 1.2vw, 18px);
}

@media (min-width: 900px) {
  .app-back-btn-topbar .app-back-label {
    display: inline;
  }

  .app-back-bar {
    display: none;
  }
}

@media (max-width: 768px) {
  .app-back-btn-topbar {
    min-height: 44px;
    min-width: 44px;
    padding: 10px 12px;
  }

  .app-back-btn-bar {
    max-width: none;
    min-height: 44px;
  }
}
.topbar-quicknav-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  min-width: 0;
  padding: 0 8px;
  overflow: visible;
}
.topbar-quicknav-wrap .abk-dash-quicknav-topbar {
  border-right: none;
  padding-right: 0;
  margin-right: 0;
}
.topbar-brand-block {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 0 1 auto;
  min-width: 0;
}
.topbar-left { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; }
.topbar-right a { color: #cbd5e1; transition: color 0.2s; }
.topbar-right a:hover { color: var(--gold-light); }

.brand-lux strong {
  display: block;
  font-size: 1.12rem;
  font-family: var(--font-display);
  letter-spacing: 0.05em;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}
.brand-lux span {
  display: block;
  margin-top: 2px;
  color: var(--gold-light);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.92;
}

.topbar-cycle {
  display: inline-flex;
  gap: 4px;
  padding: 3px;
  border-radius: 11px;
  background: rgba(0, 0, 0, 0.22);
  border: 1px solid rgba(201, 169, 98, 0.22);
  box-shadow: inset 0 2px 6px rgba(0, 0, 0, 0.28);
}
.topbar-cycle-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-width: 34px;
  padding: 6px 9px;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.05) 42%, rgba(0, 0, 0, 0.18) 100%);
  color: #f8fafc;
  font-size: 0.72rem;
  font-weight: 700;
  text-decoration: none;
  line-height: 1;
  cursor: pointer;
  box-shadow:
    0 4px 10px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  transition: transform 0.16s, box-shadow 0.16s, border-color 0.16s, background 0.16s;
}
.topbar-cycle-btn:hover:not(.is-disabled) {
  transform: translateY(-1px);
  border-color: rgba(201, 169, 98, 0.55);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.22) 0%, rgba(255, 255, 255, 0.08) 45%, rgba(0, 0, 0, 0.12) 100%);
  box-shadow:
    0 6px 14px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
  color: var(--gold-light);
  text-decoration: none;
}
.topbar-cycle-btn.is-disabled {
  opacity: 0.32;
  cursor: not-allowed;
  box-shadow: none;
}
.topbar-cycle-text {
  font-size: 0.64rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.topnav {
  display: flex;
  flex: 1 1 auto;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 0;
}
.topnav-lux { gap: 8px; }

.topnav-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 15px;
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.13) 0%, rgba(255, 255, 255, 0.04) 40%, rgba(0, 0, 0, 0.22) 100%);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.84rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  box-shadow:
    0 5px 14px rgba(0, 0, 0, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    inset 0 -2px 0 rgba(0, 0, 0, 0.22);
  transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s, color 0.18s, background 0.18s;
}
.topnav-pill:hover {
  transform: translateY(-2px);
  border-color: rgba(232, 213, 163, 0.55);
  color: #fff;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0.07) 42%, rgba(0, 0, 0, 0.15) 100%);
  box-shadow:
    0 8px 20px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
  text-decoration: none;
}
.topnav-pill.is-active {
  border-color: rgba(255, 255, 255, 0.45);
  color: var(--navy);
  background: linear-gradient(180deg, #f5e6bc 0%, var(--gold-light) 18%, var(--gold) 55%, var(--gold-dark) 100%);
  box-shadow:
    0 6px 18px rgba(168, 134, 58, 0.45),
    inset 0 2px 0 rgba(255, 255, 255, 0.55),
    inset 0 -3px 0 rgba(120, 90, 30, 0.35);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.35);
}
.topnav-pill.is-active:hover {
  color: var(--navy);
  transform: translateY(-1px);
}

.topnav a {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  font-size: 0.88rem;
  padding: 6px 8px;
  border-radius: 6px;
  transition: color 0.2s, background 0.2s;
}
.topnav a:hover { color: var(--gold-light); background: rgba(255, 255, 255, 0.06); text-decoration: none; }

.nav-dropdown { position: relative; }
.nav-dropdown-btn {
  color: #e2e8f0;
  font-size: 0.88rem;
  cursor: default;
  padding: 6px 4px;
}
.nav-dropdown-lux .nav-dropdown-btn {
  cursor: pointer;
  user-select: none;
}
.nav-dropdown-lux:hover .nav-dropdown-menu,
.nav-dropdown-lux:focus-within .nav-dropdown-menu {
  display: block;
}
.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 200px;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  padding: 6px 0;
  z-index: 50;
}
.nav-dropdown-menu-lux {
  padding: 8px;
  border-radius: 12px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background: linear-gradient(180deg, #fff 0%, var(--cream) 100%);
  box-shadow:
    0 16px 40px rgba(15, 23, 41, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}
.nav-dropdown-link {
  display: block;
  padding: 10px 14px;
  border-radius: 8px;
  color: var(--navy) !important;
  font-weight: 600;
  font-size: 0.86rem;
  text-decoration: none;
  transition: background 0.15s, transform 0.15s;
}
.nav-dropdown-link:hover {
  background: rgba(201, 169, 98, 0.14);
  text-decoration: none;
  transform: translateX(2px);
}
.nav-dropdown-link.is-active {
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.22), rgba(201, 169, 98, 0.08));
  color: var(--gold-dark) !important;
}
.nav-dropdown-menu a {
  display: block;
  padding: 10px 14px;
  color: #1e293b !important;
}
.nav-dropdown-menu a:hover { background: #f1f5f9; text-decoration: none; }

.topbar-right-lux {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  margin-left: auto;
  padding: 6px 10px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 2px 6px rgba(0, 0, 0, 0.2);
}
.topbar-user {
  font-size: 0.82rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.88);
  white-space: nowrap;
}
.topbar-logout {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 8px;
  border: 1px solid rgba(201, 169, 98, 0.35);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.1) 0%, rgba(0, 0, 0, 0.15) 100%);
  color: var(--gold-light) !important;
  font-size: 0.78rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
  transition: background 0.15s, border-color 0.15s, transform 0.15s;
}
.topbar-logout:hover {
  border-color: var(--gold);
  background: rgba(201, 169, 98, 0.18);
  transform: translateY(-1px);
  text-decoration: none;
}

.brand strong { display: block; font-size: 1.05rem; font-family: var(--font-display); letter-spacing: 0.04em; }
.brand span { color: rgba(201, 169, 98, 0.85); font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase; }

.page { max-width: min(100%, 1600px); margin: 0 auto; padding: 28px 20px 40px; width: 100%; }
.page-with-sticky-topbar { padding-top: 22px; }
.page-auth {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px 20px 48px;
  background:
    radial-gradient(ellipse 80% 60% at 15% 10%, rgba(201, 169, 98, 0.22), transparent 55%),
    radial-gradient(ellipse 70% 50% at 90% 85%, rgba(201, 169, 98, 0.12), transparent 50%),
    linear-gradient(145deg, #0a1020 0%, var(--navy) 42%, #121f38 100%);
}
.page-auth .footer {
  color: rgba(232, 213, 163, 0.55);
  padding-bottom: 28px;
}

.auth-scene {
  position: relative;
  width: min(440px, 100%);
  z-index: 1;
}
.auth-orb {
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(60px);
  opacity: 0.45;
  z-index: 0;
}
.auth-orb-a {
  width: 320px;
  height: 320px;
  top: 8%;
  left: -80px;
  background: rgba(201, 169, 98, 0.35);
}
.auth-orb-b {
  width: 280px;
  height: 280px;
  bottom: 10%;
  right: -60px;
  background: rgba(26, 39, 68, 0.8);
  border: 1px solid rgba(201, 169, 98, 0.15);
}

.auth-card {
  background: var(--card);
  padding: 28px;
  border-radius: 12px;
  width: min(400px, 100%);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.1);
}
.auth-card-lux {
  position: relative;
  width: 100%;
  padding: 0;
  overflow: hidden;
  border-radius: 20px;
  border: 1px solid rgba(201, 169, 98, 0.38);
  background: linear-gradient(165deg, #fff 0%, #fffdf9 38%, var(--cream) 100%);
  box-shadow:
    0 28px 70px rgba(0, 0, 0, 0.45),
    0 8px 24px rgba(15, 23, 41, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.95);
}
.auth-card-lux::before {
  content: "";
  display: block;
  height: 4px;
  background: linear-gradient(90deg, var(--gold-dark), var(--gold-light), var(--gold), var(--gold-light), var(--gold-dark));
}
.auth-card-shine {
  position: absolute;
  top: 0;
  right: 0;
  width: 55%;
  height: 140px;
  background: radial-gradient(ellipse at 100% 0%, rgba(255, 255, 255, 0.65), transparent 68%);
  pointer-events: none;
}
.auth-card-head {
  padding: 28px 32px 8px;
  text-align: center;
}
.auth-logo-mark {
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: linear-gradient(145deg, var(--navy-soft) 0%, var(--navy) 100%);
  border: 1px solid rgba(201, 169, 98, 0.45);
  box-shadow:
    0 10px 24px rgba(15, 23, 41, 0.35),
    inset 0 2px 0 rgba(255, 255, 255, 0.12),
    inset 0 -3px 0 rgba(0, 0, 0, 0.25);
}
.auth-logo-mark span {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--gold-light);
  text-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
}
.auth-eyebrow {
  margin: 0 0 8px;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-dark);
}
.auth-card-lux h1 {
  margin: 0 0 6px;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 4vw, 1.85rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--navy);
  line-height: 1.15;
}
.auth-tagline {
  margin: 0;
  font-size: 0.88rem;
  color: var(--muted);
  letter-spacing: 0.03em;
}
.auth-alert {
  margin: 16px 28px 0;
}
.auth-form input {
  text-transform: none;
  letter-spacing: normal;
}

.auth-form {
  padding: 20px 28px 28px;
}
.form-stack-lux .auth-field {
  display: grid;
  gap: 7px;
  margin-bottom: 16px;
}
.auth-field-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold-dark);
}
.form-stack-lux input {
  padding: 13px 15px;
  border: 1px solid rgba(201, 169, 98, 0.35);
  border-radius: 11px;
  background: linear-gradient(180deg, #fff 0%, #faf8f5 100%);
  font-size: 0.95rem;
  color: var(--navy);
  box-shadow:
    inset 0 2px 5px rgba(15, 23, 41, 0.06),
    0 1px 0 rgba(255, 255, 255, 0.9);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.form-stack-lux input::placeholder {
  color: #94a3b8;
  text-transform: none;
  letter-spacing: normal;
  font-weight: 400;
}
.form-stack-lux input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow:
    inset 0 2px 5px rgba(15, 23, 41, 0.05),
    0 0 0 3px rgba(201, 169, 98, 0.22);
}
.btn-auth-submit {
  margin-top: 6px;
  padding: 14px 20px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(255, 255, 255, 0.25) !important;
  background: linear-gradient(180deg, #f5e6bc 0%, var(--gold-light) 15%, var(--gold) 55%, var(--gold-dark) 100%) !important;
  color: var(--navy) !important;
  font-size: 0.92rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase;
  box-shadow:
    0 8px 22px rgba(168, 134, 58, 0.45),
    inset 0 2px 0 rgba(255, 255, 255, 0.55),
    inset 0 -3px 0 rgba(120, 90, 30, 0.3) !important;
  transition: transform 0.18s, box-shadow 0.18s !important;
}
.btn-auth-submit:hover {
  transform: translateY(-2px) !important;
  box-shadow:
    0 12px 28px rgba(168, 134, 58, 0.52),
    inset 0 2px 0 rgba(255, 255, 255, 0.6),
    inset 0 -3px 0 rgba(120, 90, 30, 0.35) !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
  color: var(--navy) !important;
}
.auth-footnote {
  margin: 0;
  padding: 0 28px 22px;
  text-align: center;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  color: var(--muted);
  opacity: 0.85;
}

.auth-card h1 { margin: 0 0 6px; font-size: 1.3rem; }
.footer { text-align: center; color: var(--muted); padding: 20px; font-size: 0.8rem; }

.panel {
  background: var(--card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  border: 1px solid var(--line-soft);
}

.panel-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: space-between;
  align-items: flex-start;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
}
.panel-toolbar h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.35rem;
  color: var(--navy);
  letter-spacing: 0.02em;
}
.muted { color: var(--muted); margin: 4px 0 0; }

.toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.search-form { display: flex; gap: 6px; }
.search-form input {
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  min-width: 220px;
  background: var(--cream);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.search-form input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.15);
  background: #fff;
}
.search-form button, .btn-add {
  padding: 8px 14px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font: inherit;
}
.search-form button { background: linear-gradient(135deg, var(--navy-soft), var(--navy)); color: #fff; border: 1px solid rgba(201, 169, 98, 0.25); }

.abk-index-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 18px 14px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #fff 0%, var(--cream) 100%);
}
.abk-index-filters-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(118px, 148px));
  gap: 10px 12px;
  flex: 0 1 auto;
  min-width: 0;
  justify-content: start;
  align-items: end;
}
.abk-filter-search {
  max-width: 168px;
}
.abk-filter-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.abk-filter-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}
.abk-index-filters input,
.abk-index-filters select {
  width: 100%;
  padding: 9px 11px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font: inherit;
  font-size: 0.82rem;
  color: var(--text);
}
.abk-index-filters input:focus,
.abk-index-filters select:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.15);
}
.abk-index-filters-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.btn-filter-apply,
.btn-filter-reset {
  padding: 9px 14px;
  border-radius: 10px;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
}
.btn-filter-apply {
  border: 1px solid rgba(201, 169, 98, 0.25);
  background: linear-gradient(135deg, var(--navy-soft), var(--navy));
  color: #fff;
}
.btn-filter-reset {
  border: 1px solid var(--line);
  background: #fff;
  color: var(--navy);
}
.btn-filter-reset:hover {
  background: var(--cream);
}

.btn-add {
  display: inline-flex;
  align-items: center;
  padding: 9px 16px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--gold-dark), var(--gold));
  color: var(--navy);
  text-decoration: none;
  font: inherit;
  font-weight: 600;
  border: none;
  box-shadow: var(--shadow-sm);
  transition: transform 0.15s, box-shadow 0.15s;
}
.btn-add:hover {
  background: linear-gradient(135deg, var(--gold), var(--gold-light));
  color: var(--navy);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.btn-reset { color: var(--blue); align-self: center; font-size: 0.85rem; }

.table-scroll { overflow-x: auto; max-width: 100%; }
.panel-table-fit .table-scroll { overflow-x: hidden; }

/* Isi sel tabel dari atas — konsisten di seluruh aplikasi */
table th,
table td {
  vertical-align: top;
}
.abk-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}
.abk-table-compact {
  min-width: 0;
}
.abk-table-compact thead th {
  padding: 8px 5px;
  font-size: 0.62rem;
  letter-spacing: 0.04em;
  word-break: break-word;
  hyphens: auto;
}
.abk-table-compact tbody td {
  padding: 8px 5px;
  font-size: 0.76rem;
  overflow: hidden;
  word-wrap: break-word;
}
.abk-table-compact .col-no { width: 3%; }
.abk-table-compact .col-daftar-foto { width: 7%; min-width: 0; }
.abk-table-compact .col-nama { width: 18%; min-width: 0; }
.abk-table-compact .col-status { width: 8%; min-width: 0; }
.abk-table-compact .col-marketing { width: 9%; min-width: 0; }
.abk-table-compact .col-xp { width: 8%; min-width: 0; }
.abk-table-compact .col-kapal { width: 14%; min-width: 0; }
.abk-table-compact .col-jabatan {
  width: 8%;
  min-width: 0;
  font-size: 0.68rem;
  line-height: 1.2;
  word-break: break-word;
}
.abk-table-compact .col-skill { width: 11%; min-width: 0; }
.abk-table-compact .col-aksi { width: 6%; min-width: 0; }
.abk-table-compact .abk-photo {
  width: 36px;
  height: 36px;
}
.abk-table-compact .cell-daftar-foto { gap: 3px; }
.abk-table-compact .cell-daftar-foto .cell-uniq-id { font-size: 0.52rem; }
.abk-table-compact .cell-daftar-foto .cell-daftar { font-size: 0.62rem; }
.abk-table-compact .cell-nama-main {
  font-size: 0.78rem;
  margin-bottom: 2px;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.abk-table-compact .cell-nama-nik {
  font-size: 0.62rem;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.abk-table-compact .cell-meta { display: none; }
.abk-table-compact .crew-status-badge {
  font-size: 0.52rem;
  padding: 0.12rem 0.28rem;
  letter-spacing: 0.02em;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}
.abk-table-compact .cell-marketing .mkt-name {
  font-size: 0.68rem;
  line-height: 1.25;
  word-break: break-word;
}
.abk-table-compact .xp-tipe-badge {
  font-size: 0.52rem;
  padding: 2px 5px;
}
.abk-table-compact .cell-xp-tipe { gap: 2px; }
.abk-table-compact .cell-kapal-item .kapal-name {
  font-size: 0.68rem;
  line-height: 1.25;
  word-break: break-word;
}
.abk-table-compact .cell-kapal-item div:not(.kapal-name) { display: none; }
.abk-table-compact .cell-kapal-more {
  font-size: 0.58rem;
  color: var(--muted);
  margin-top: 2px;
}
.abk-table-compact .cell-kapal-list { gap: 4px; }
.abk-table-compact .cell-kapal-item + .cell-kapal-item {
  padding-top: 0;
  border-top: 0;
  display: none;
}
.abk-table-compact .skill-chip {
  display: inline-block;
  padding: 1px 4px;
  margin: 1px;
  border-radius: 999px;
  font-size: 0.52rem;
  font-weight: 700;
  background: var(--cream-dark);
  color: var(--navy);
  line-height: 1.2;
}
.abk-table-compact .cell-skill-list {
  display: flex;
  flex-wrap: wrap;
  gap: 1px;
  max-height: 2.6em;
  overflow: hidden;
}
.abk-table-compact .btn-edit {
  padding: 4px 7px;
  font-size: 0.62rem;
}
.abk-table thead th {
  background: linear-gradient(180deg, var(--navy-soft) 0%, var(--navy) 100%);
  color: #fff;
  font-weight: 600;
  text-align: center;
  padding: 14px 12px;
  border: none;
  border-bottom: 2px solid var(--gold);
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.abk-table tbody td {
  border: 1px solid var(--line-soft);
  padding: 12px 14px;
  vertical-align: top;
  background: #fff;
}
.abk-table tbody tr:hover td { background: var(--cream); }
.abk-table .center { text-align: center; }
.abk-table .empty { text-align: center; color: var(--muted); padding: 32px; }

.col-no { width: 3%; }
.col-daftar-foto { width: 7%; min-width: 0; }
.cell-daftar-foto {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 4px 0;
}
.cell-daftar-foto .cell-uniq-id {
  margin-top: 0;
  font-size: 0.6rem;
  text-align: center;
  max-width: none;
}
.cell-daftar-foto .cell-daftar {
  font-size: 0.72rem;
  line-height: 1.2;
}
.col-nama { width: 18%; min-width: 0; text-align: left !important; }
.cell-daftar {
  display: inline-block;
  font-variant-numeric: tabular-nums;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--navy);
  letter-spacing: 0.02em;
}
.no-urut {
  display: inline-block;
  font-weight: 700;
  color: var(--gold-dark);
  min-width: 1.5em;
}
.cell-uniq-id {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 0;
  margin-top: 5px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: var(--navy);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
  white-space: nowrap;
  word-break: normal;
}
.cell-uniq-id-base {
  flex: 0 0 auto;
}
.cell-uniq-id-seq {
  flex: 0 0 auto;
  min-width: 0.75em;
  font-weight: 800;
  color: var(--gold-dark);
  text-align: left;
}
.uniq-id-field {
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--gold-dark) !important;
  background: linear-gradient(135deg, #fffdf7, var(--cream)) !important;
}
.col-marketing { width: 9%; min-width: 0; }
.col-xp { width: 8%; min-width: 0; }
.col-kapal { width: 14%; min-width: 0; }
.col-jabatan { width: 8%; min-width: 0; }
.col-skill { width: 11%; min-width: 0; text-align: left !important; }
.col-aksi { width: 6%; min-width: 0; }
.col-status { width: 8%; min-width: 0; }

.btn-edit {
  display: inline-block;
  padding: 6px 14px;
  background: linear-gradient(135deg, var(--navy-soft), var(--navy));
  color: #fff;
  border-radius: 8px;
  text-decoration: none;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  border: 1px solid rgba(201, 169, 98, 0.3);
  transition: transform 0.15s, box-shadow 0.15s;
}
.btn-edit:hover {
  background: linear-gradient(135deg, var(--navy-mid), var(--navy-soft));
  color: #fff;
  box-shadow: 0 4px 12px rgba(15, 23, 41, 0.2);
  transform: translateY(-1px);
}
.row-click { cursor: pointer; }
.row-click:hover td { background: var(--cream) !important; }

.abk-photo-link {
  display: inline-flex;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(201, 169, 98, 0.45);
  box-shadow: var(--shadow-sm);
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
.abk-photo-link:hover {
  transform: scale(1.05);
  border-color: var(--gold);
  box-shadow: var(--shadow-md);
}
.abk-photo {
  display: block;
  width: 52px;
  height: 52px;
  object-fit: contain;
  object-position: center center;
  background: var(--cream);
}
.abk-photo-empty {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cream-dark), var(--line-soft));
  border: 1px dashed rgba(201, 169, 98, 0.35);
  font-size: 1.35rem;
  opacity: 0.65;
}

.photo-field { margin-bottom: 20px; }
.reg-section-data {
  padding-bottom: 16px;
}
.reg-data-subsection {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}
.reg-data-subsection:first-of-type {
  margin-top: 14px;
}
.reg-data-subtitle {
  margin: 0 0 12px;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1rem, 1.1vw, 1.12rem);
  font-weight: 700;
  color: var(--ink, #0f172a);
  letter-spacing: 0.01em;
}
.abk-questionnaire-wrap {
  margin-top: 20px;
}
.abk-questionnaire-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  margin-bottom: 10px;
}
.abk-questionnaire-head .reg-data-subtitle {
  margin: 0;
  flex: 1 1 auto;
}
.btn-questionnaire-toggle.is-open {
  border-color: rgba(201, 169, 98, 0.55);
  background: rgba(201, 169, 98, 0.12);
}
.abk-questionnaire-badge {
  font-size: 0.72rem;
  font-weight: 800;
  padding: 4px 10px;
  border-radius: 999px;
  letter-spacing: 0.02em;
}
.abk-questionnaire-badge.is-complete {
  background: rgba(16, 185, 129, 0.14);
  color: #047857;
  border: 1px solid rgba(16, 185, 129, 0.35);
}
.abk-questionnaire-badge.is-pending {
  background: rgba(245, 158, 11, 0.12);
  color: #b45309;
  border: 1px solid rgba(245, 158, 11, 0.35);
}
.abk-questionnaire-panel {
  padding: 14px 16px 12px;
  border-radius: 12px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background: linear-gradient(165deg, rgba(255, 252, 245, 0.98), rgba(248, 250, 252, 0.92));
}
.abk-questionnaire-hint {
  margin: 0 0 12px;
}
.abk-questionnaire-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.abk-questionnaire-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px 14px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
}
.abk-questionnaire-item.is-answered {
  border-color: rgba(16, 185, 129, 0.28);
}
.abk-questionnaire-no {
  font-weight: 800;
  color: var(--gold-dark, #9a7b3c);
  min-width: 1.4em;
}
.abk-questionnaire-text {
  margin: 0 0 10px;
  font-weight: 600;
  color: var(--ink, #0f172a);
  line-height: 1.4;
}
.abk-questionnaire-choices {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.btn-questionnaire-choice {
  min-width: 72px;
  padding: 8px 16px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.18);
  background: #fff;
  font: inherit;
  font-size: 0.84rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.btn-questionnaire-choice:hover:not(:disabled) {
  border-color: rgba(201, 169, 98, 0.55);
}
.btn-questionnaire-choice.is-active {
  border-color: var(--gold, #c9a962);
  background: linear-gradient(165deg, rgba(201, 169, 98, 0.35), rgba(201, 169, 98, 0.12));
  color: var(--navy, #0f172a);
  box-shadow: 0 0 0 1px rgba(201, 169, 98, 0.25);
}
.btn-questionnaire-choice:disabled {
  opacity: 0.65;
  cursor: default;
}
.abk-db-card-questionnaire .abk-db-questionnaire-dl {
  margin: 0 0 12px;
}
.abk-db-questionnaire-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 16px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}
.abk-db-questionnaire-row:last-child {
  border-bottom: none;
}
.abk-db-questionnaire-row dt {
  margin: 0;
  font-size: 0.84rem;
  color: #475569;
}
.abk-db-questionnaire-row dd {
  margin: 0;
  text-align: right;
}
.reg-data-layout {
  display: grid;
  grid-template-columns: minmax(200px, 220px) minmax(0, 1fr);
  gap: 14px 18px;
  align-items: start;
  padding-top: 4px;
}
.photo-field-compact {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}
.photo-field-compact .photo-upload-card {
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 10px 8px;
  text-align: center;
}
.photo-field-compact .photo-preview-wrap {
  width: 88px;
  height: 88px;
  border-width: 2px;
}
.photo-field-compact .photo-placeholder-icon {
  font-size: 1.5rem;
}
.photo-upload-btn-compact {
  width: 100%;
  padding: 7px 6px !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.02em;
  text-align: center;
  justify-content: center;
}
.photo-field-compact .photo-file-name {
  margin-top: 0;
  font-size: 0.62rem;
  line-height: 1.2;
  max-width: 100%;
}
.reg-grid-compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 12px;
  padding-top: 0;
}
.reg-grid-compact label {
  gap: 4px;
  font-size: 0.68rem;
  letter-spacing: 0.05em;
  min-width: 0;
}
.reg-grid-compact label.span-2 {
  grid-column: span 2;
}
.reg-grid-compact label.full {
  grid-column: 1 / -1;
}
.reg-grid-compact input,
.reg-grid-compact select,
.reg-grid-compact textarea {
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 0.86rem;
  background: #fff;
}
.reg-grid-compact select {
  padding-right: 30px;
  background-position: right 10px center;
}
.reg-grid-compact textarea {
  min-height: 64px;
  resize: vertical;
}
.reg-grid-compact .date-field .date-input {
  padding-right: 36px;
}
.reg-grid-compact .date-toggle {
  width: 30px;
  font-size: 0.88rem;
}
.hint-compact {
  font-size: 0.62rem !important;
  line-height: 1.3 !important;
  margin-top: 2px !important;
  text-transform: none;
  letter-spacing: 0;
  color: var(--muted);
  opacity: 0.9;
}
.reg-section-data .uniq-id-field {
  padding: 8px 10px;
  font-size: 0.82rem;
}
.nik-warn-slot { min-height: 0; }
.nik-warn {
  margin: 4px 0 0;
  padding: 7px 10px;
  border-radius: 8px;
  font-size: 0.72rem;
  line-height: 1.35;
  text-transform: none;
  letter-spacing: 0;
}
.nik-warn--danger {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}
.nik-warn--warn {
  background: #fffbeb;
  border: 1px solid #fcd34d;
  color: #92400e;
}
.nik-input-error {
  border-color: #ef4444 !important;
  background: #fef2f2 !important;
}
.nik-input-warn {
  border-color: #f59e0b !important;
  background: #fffdf5 !important;
}
.photo-upload-card {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: center;
  padding: 20px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, #fff 0%, var(--cream) 100%);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}
.photo-preview-wrap {
  flex-shrink: 0;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid rgba(201, 169, 98, 0.5);
  box-shadow: var(--shadow-md);
  background: var(--cream-dark);
  display: grid;
  place-items: center;
}
.photo-preview-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  display: block;
  background: var(--cream-dark);
}
.photo-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 100%;
  height: 100%;
  color: var(--muted);
  text-align: center;
  padding: 8px;
}
.photo-placeholder-icon { font-size: 2rem; opacity: 0.5; }
.photo-placeholder-text { font-size: 0.68rem; letter-spacing: 0.04em; text-transform: uppercase; }
.photo-upload-meta { flex: 1; min-width: 200px; }
.photo-upload-title {
  margin: 0 0 4px;
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--navy);
  font-weight: 700;
}
.photo-upload-hint { margin: 0 0 12px; text-transform: none; }
.photo-upload-btn { cursor: pointer; margin: 0; }
.photo-file-name {
  display: block;
  margin-top: 8px;
  font-size: 0.78rem;
  color: var(--gold-dark);
  word-break: break-all;
}

.cell-nama-main {
  font-weight: 700;
  font-size: 0.95rem;
  margin-bottom: 6px;
  letter-spacing: 0.02em;
}
.cell-meta {
  color: #374151;
  font-size: 0.78rem;
  line-height: 1.45;
  margin-top: 2px;
}
.cell-meta .ico { opacity: 0.75; margin-right: 2px; }

.cell-marketing { font-weight: 600; font-size: 0.85rem; }
.cell-marketing .mkt-name { font-weight: 700; }
.cell-marketing .placement-pending { font-size: 0.78rem; margin-top: 4px; }
.cell-marketing .agency-tag {
  color: var(--blue-dark);
  font-size: 0.78rem;
  margin-top: 4px;
  font-weight: 600;
}
.cell-marketing .grade-tag {
  font-size: 0.72rem;
  color: var(--muted);
  margin-top: 4px;
  font-weight: 500;
}
.cell-nama-main a { color: inherit; text-decoration: none; }
.cell-nama-main a:hover { color: var(--blue); text-decoration: underline; }

.xp-yes {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #e8f5e9;
  color: var(--xp-yes);
  font-size: 1.1rem;
  font-weight: 700;
}
.xp-no { color: #9ca3af; font-size: 1.2rem; }
.cell-xp-tipe {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.xp-tipe-badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.2;
  white-space: nowrap;
  background: linear-gradient(135deg, var(--navy-soft), var(--navy));
  color: var(--gold-light);
  border: 1px solid rgba(201, 169, 98, 0.25);
}

.cell-kapal .kapal-name { font-weight: 700; margin-bottom: 2px; }
.cell-kapal div { font-size: 0.82rem; line-height: 1.4; }
.cell-kapal-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cell-kapal-item + .cell-kapal-item {
  padding-top: 10px;
  border-top: 1px dashed rgba(201, 169, 98, 0.35);
}
.cell-kapal-item .kapal-name { font-weight: 700; margin-bottom: 2px; }
.cell-kapal-item div { font-size: 0.82rem; line-height: 1.4; }

.auth-card {
  background: var(--card);
  padding: 28px;
  border-radius: 12px;
  width: min(400px, 100%);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.1);
}
.auth-card h1 { margin: 0 0 6px; font-size: 1.3rem; }
.form-stack label { display: grid; gap: 6px; margin-bottom: 12px; }
.form-stack input {
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
}
.btn-primary {
  width: 100%;
  padding: 12px 20px;
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 100%);
  color: #fff;
  border: 1px solid rgba(201, 169, 98, 0.35);
  border-radius: 10px;
  font: inherit;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: transform 0.15s, box-shadow 0.2s, border-color 0.2s;
}
.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
  border-color: var(--gold);
}
.alert.err {
  background: linear-gradient(135deg, #fef2f2, #fff5f5);
  color: #991b1b;
  padding: 14px 16px;
  border-radius: var(--radius);
  margin-bottom: 12px;
  font-size: 0.88rem;
  border: 1px solid #fecaca;
  border-left: 4px solid #dc2626;
}

@media (max-width: 768px) {
  .topbar-inner {
    padding: 10px 12px;
    gap: 10px;
  }
  .topbar-brand-block {
    flex: 1 1 100%;
    justify-content: space-between;
  }
  .topbar-cycle-text {
    display: none;
  }
  .topnav-lux {
    flex: 1 1 100%;
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .topnav-pill {
    flex: 0 0 auto;
    padding: 8px 12px;
    font-size: 0.78rem;
  }
  .topbar-right-lux {
    flex: 1 1 100%;
    justify-content: space-between;
    margin-left: 0;
  }
  .panel-toolbar { flex-direction: column; }
  .abk-index-filters-grid {
    grid-template-columns: 1fr;
  }
  .abk-index-filters-actions {
    width: 100%;
  }
  .btn-filter-apply,
  .btn-filter-reset {
    flex: 1;
  }
  .search-form input { min-width: 160px; }
  .reg-grid { grid-template-columns: 1fr; }
  .reg-grid-compact { grid-template-columns: 1fr; }
  .reg-grid-compact label.span-2 { grid-column: auto; }
  .reg-data-layout { grid-template-columns: 1fr; }
  .photo-field-compact .photo-upload-card {
    flex-direction: row;
    text-align: left;
    padding: 12px;
  }
  .photo-upload-btn-compact { width: auto; }
  .doc-row { grid-template-columns: 1fr; gap: 6px; }
  .doc-row-fields { grid-template-columns: 1fr; }
  .doc-pelaut-grid { grid-template-columns: 1fr; }
  .doc-pelaut-meta { grid-template-columns: 1fr; }
  .form-head { padding: 20px 20px 18px; }
  .reg-form-lux { padding: 20px; }
  .form-panel-lux .reg-form-lux { padding-right: 20px; padding-bottom: 88px; }
  .form-action-dock {
    bottom: 12px;
    right: 10px;
    left: auto;
    flex-direction: column;
    flex-wrap: nowrap;
    width: min(168px, calc(100vw - 20px));
    max-width: calc(100vw - 20px);
    gap: 0;
    padding: 0;
  }
  .form-panel-lux .reg-form-lux { padding-right: 20px; padding-bottom: 120px; }
  .form-dock-nav-block {
    padding: 10px 10px 8px;
  }
  .form-dock-nav-title {
    min-height: 0;
    font-size: 0.76rem;
  }
  .form-dock-nav-actions {
    grid-template-columns: 1fr 1fr;
    gap: 6px;
  }
  .btn-dock-nav {
    padding: 9px 8px;
    font-size: 0.64rem;
  }
  .btn-dock-nav-text {
    display: none;
  }
  .btn-dock-nav-icon {
    font-size: 1.15rem;
  }
  .form-action-dock > .btn-primary,
  .form-action-dock > .btn-ghost,
  .form-action-dock > .btn-dock-deactivate,
  .form-action-dock > .btn-dock-print,
  .form-action-dock > .btn-dock-reactivate {
    margin: 4px 8px 0;
  }
  .form-action-dock > .btn-ghost.btn-dock-cancel {
    margin-bottom: 8px;
  }
  .form-action-dock .btn-primary,
  .form-action-dock .btn-ghost,
  .form-dock-deactivate {
    flex: 0 0 auto;
    width: auto;
    min-width: 72px;
  }
.form-panel-lux > .alert.ok,
.form-panel-lux > .alert.err { margin-left: 20px; margin-right: 20px; }
.form-panel-lux-flash {
  margin: 16px 24px 0;
  max-width: none;
}
}

/* Registration form — luxury */
.form-panel {
  background: var(--card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 0;
  border: 1px solid var(--line-soft);
  overflow: hidden;
}
.form-panel-lux {
  background: linear-gradient(180deg, #fff 0%, var(--cream) 100%);
}
.form-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 0;
  padding: 28px 32px 24px;
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-soft) 100%);
  color: #fff;
  border-bottom: 3px solid var(--gold);
}
.form-head-text { flex: 1; min-width: 200px; }
.form-eyebrow {
  margin: 0 0 6px;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold-light);
  font-weight: 500;
}
.form-head h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.15;
}
.form-subtitle {
  margin: 8px 0 0;
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.72);
  max-width: 520px;
}
.link-back {
  color: var(--gold-light);
  font-size: 0.88rem;
  text-decoration: none;
  padding: 8px 14px;
  border: 1px solid rgba(201, 169, 98, 0.4);
  border-radius: 999px;
  transition: background 0.2s, color 0.2s;
  white-space: nowrap;
}
.link-back:hover {
  background: rgba(201, 169, 98, 0.15);
  color: #fff;
}

.reg-form-lux {
  padding: 28px 32px 32px;
}
.form-panel-lux .reg-form-lux {
  padding-right: 172px;
}
.form-action-spacer {
  height: 16px;
}
.form-action-dock {
  position: fixed;
  right: 14px;
  top: auto;
  bottom: 72px;
  transform: none;
  z-index: 900;
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 158px;
  padding: 0;
  border-radius: 12px;
  background: linear-gradient(165deg, #fff 0%, var(--cream) 100%);
  border: 1px solid rgba(201, 169, 98, 0.32);
  box-shadow:
    0 8px 28px rgba(15, 23, 41, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(8px);
  opacity: 0.96;
  transition: opacity 0.2s, box-shadow 0.2s;
  overflow: hidden;
}
.form-action-dock::before {
  content: "";
  display: block;
  height: 3px;
  background: linear-gradient(90deg, var(--gold-dark), var(--gold-light), var(--gold-dark));
}
.form-action-dock:hover {
  opacity: 1;
  box-shadow:
    0 12px 32px rgba(15, 23, 41, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}
.form-dock-nav-block {
  display: grid;
  gap: 8px;
  padding: 12px 12px 10px;
  background:
    radial-gradient(ellipse 120% 80% at 100% 0%, rgba(201, 169, 98, 0.12), transparent 55%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(250, 248, 245, 0.75) 100%);
  border-bottom: 1px solid rgba(201, 169, 98, 0.16);
}
.form-dock-nav-eyebrow {
  margin: 0;
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold-dark);
  text-align: center;
}
.form-dock-nav-progress {
  height: 4px;
  border-radius: 999px;
  background: rgba(15, 23, 41, 0.08);
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(15, 23, 41, 0.06);
}
.form-dock-nav-progress-fill {
  display: block;
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--gold-dark), var(--gold-light), var(--gold));
  transition: width 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 8px rgba(201, 169, 98, 0.45);
}
.form-dock-nav-step {
  margin: 0;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  color: var(--navy);
}
.form-dock-nav-title {
  margin: 0;
  min-height: 2.4em;
  font-family: var(--font-display);
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.25;
  text-align: center;
  color: var(--navy-soft);
  letter-spacing: 0.02em;
}
.form-dock-nav-actions {
  display: grid;
  gap: 5px;
}
.form-dock-divider {
  height: 1px;
  margin: 0 10px;
  background: linear-gradient(90deg, transparent, rgba(201, 169, 98, 0.35), transparent);
}
.btn-dock-nav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 100%;
  padding: 8px 10px;
  border-radius: 9px;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.15;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, box-shadow 0.18s, transform 0.18s, color 0.18s;
}
.btn-dock-nav-icon {
  font-size: 1rem;
  line-height: 1;
  font-weight: 700;
  opacity: 0.85;
}
.btn-dock-nav-back {
  border: 1px solid rgba(201, 169, 98, 0.42);
  background: rgba(255, 255, 255, 0.82);
  color: var(--navy);
  box-shadow: var(--shadow-sm);
}
.btn-dock-nav-back:hover:not(:disabled) {
  border-color: var(--gold);
  background: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(15, 23, 41, 0.08);
}
.btn-dock-nav-next {
  border: 1px solid rgba(15, 23, 41, 0.15);
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 100%);
  color: #fff;
  box-shadow: 0 4px 14px rgba(15, 23, 41, 0.22);
}
.btn-dock-nav-next:hover:not(:disabled) {
  border-color: var(--gold-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(15, 23, 41, 0.28);
}
.btn-dock-nav:disabled {
  opacity: 0.34;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.form-action-dock > .btn-primary,
.form-action-dock > .btn-ghost,
.form-action-dock > .btn-dock-deactivate,
.form-action-dock > .btn-dock-print,
.form-action-dock > .btn-dock-reactivate {
  margin: 0 10px;
}
.form-action-dock > .btn-dock-save {
  margin: 8px 10px 0;
}
.form-action-dock > .btn-dock-print,
.form-action-dock > .btn-dock-deactivate,
.form-action-dock > .btn-dock-reactivate,
.form-action-dock > .btn-dock-cancel {
  margin-top: 0;
}
.form-action-dock > .btn-ghost.btn-dock-cancel {
  margin-bottom: 10px;
}
.form-action-dock .btn-primary,
.form-action-dock .btn-ghost,
.form-action-dock .btn-dock-deactivate,
.form-action-dock .btn-dock-print {
  width: 100%;
  margin: 0;
  text-align: center;
  justify-content: center;
  box-sizing: border-box;
}
.btn-dock-print {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
  font: inherit;
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1.15;
  text-align: center;
  white-space: normal;
  text-decoration: none;
  transition: background 0.15s;
}
.btn-dock-print:hover {
  background: #dbeafe;
  transform: none;
  box-shadow: none;
}
.btn-dock-save {
  padding: 7px 8px !important;
  min-width: 0 !important;
  font-size: 0.72rem !important;
  line-height: 1.2;
  white-space: nowrap;
  border-radius: 8px;
}
.form-dock-deactivate {
  margin: 0;
  width: 100%;
}
.btn-dock-deactivate {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #991b1b;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  transition: background 0.15s;
}
.btn-dock-deactivate:hover {
  background: #fee2e2;
  transform: none;
  box-shadow: none;
}
.btn-dock-reactivate,
.btn-reregister {
  border: 1px solid #86efac;
  background: #ecfdf5;
  color: #166534;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
}
.btn-dock-reactivate {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 6px 8px;
  border-radius: 8px;
  font: inherit;
  font-size: 0.68rem;
  line-height: 1.2;
}
.btn-reregister {
  display: inline-flex;
  align-items: center;
  margin-left: 0.35rem;
  padding: 0.35rem 0.55rem;
  border-radius: 8px;
  font-size: 0.72rem;
}
.btn-dock-reactivate:hover,
.btn-reregister:hover {
  background: #dcfce7;
}
.reregister-modal .reregister-card { max-width: 520px; }
.reregister-intro {
  margin: 0 0 0.85rem;
  font-size: 0.86rem;
  color: var(--muted);
  line-height: 1.45;
}
.reregister-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 0.75rem;
  font-size: 0.82rem;
  font-weight: 600;
}
.reregister-field select,
.reregister-field textarea {
  font-weight: 500;
}
.col-aksi-inactive {
  white-space: nowrap;
}
.btn-dock-cancel {
  padding: 6px 8px !important;
  font-size: 0.68rem !important;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
}

.reg-section {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0 24px 24px;
  margin-bottom: 20px;
  background: #fff;
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.2s, border-color 0.2s;
  scroll-margin-top: 88px;
}
.reg-section.reg-section-active {
  border-color: rgba(201, 169, 98, 0.55);
  box-shadow:
    0 0 0 1px rgba(201, 169, 98, 0.18),
    inset 4px 0 0 var(--gold),
    var(--shadow-md);
}
.reg-section:hover {
  box-shadow: var(--shadow-md);
}
.reg-section legend {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.15rem;
  padding: 0 12px;
  color: var(--navy);
  letter-spacing: 0.03em;
  margin-left: -4px;
  margin-bottom: 8px;
}
.reg-section legend::after {
  content: "";
  display: block;
  width: 40px;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), transparent);
  margin-top: 4px;
}
.reg-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 20px;
  padding-top: 8px;
}
.reg-grid label {
  display: grid;
  gap: 7px;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}
.reg-grid label.full { grid-column: 1 / -1; }
.reg-grid input,
.reg-grid select,
.reg-grid textarea {
  padding: 11px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font: inherit;
  font-size: 0.95rem;
  text-transform: uppercase;
  background: var(--cream);
  color: var(--text);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
.reg-grid input:focus,
.reg-grid select:focus,
.reg-grid textarea:focus {
  outline: none;
  border-color: var(--gold);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.18);
}
.reg-grid select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23a8863a' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}
.reg-grid input.date-input {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.date-field {
  position: relative;
  display: flex;
  align-items: stretch;
}
.date-field .date-input {
  flex: 1;
  padding-right: 42px;
}
.date-toggle {
  position: absolute;
  right: 4px;
  top: 4px;
  bottom: 4px;
  width: 36px;
  border: none;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--cream-dark), var(--line-soft));
  color: var(--gold-dark);
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  z-index: 2;
  transition: background 0.2s;
}
.date-toggle:hover { background: var(--gold-light); color: var(--navy); }

.flatpickr-calendar {
  z-index: 100500;
  font-family: var(--font-body);
  font-size: 13px;
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--line);
}
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
  background: var(--navy);
  border-color: var(--navy);
}
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover {
  background: var(--gold-dark);
  border-color: var(--gold-dark);
}

.reg-grid input[readonly] {
  background: var(--line-soft);
  color: var(--muted);
  cursor: default;
}

.kota-field input[type="search"],
.kota-field input[type="text"] {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font: inherit;
}
.kota-combobox { position: relative; }
.kota-dropdown {
  position: absolute;
  z-index: 40;
  left: 0;
  right: 0;
  top: calc(100% + 4px);
  max-height: 220px;
  overflow: auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}
.kota-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border: none;
  background: #fff;
  cursor: pointer;
  font: inherit;
}
.kota-item:hover { background: #f1f5f9; }
.kota-item-manual {
  font-weight: 600;
  background: #eff6ff;
  border-bottom: 1px solid var(--line);
}
.kota-item.is-active {
  background: rgba(201, 169, 98, 0.22);
  box-shadow: inset 3px 0 0 var(--gold-dark);
}
.kota-dropdown-portal {
  z-index: 10150;
  max-height: min(280px, 42vh);
}
.tipe-kapal-input {
  cursor: pointer;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23a8863a' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px !important;
}
#xpModal .kota-combobox {
  overflow: visible;
}

.flatpickr-calendar.open {
  z-index: 100500 !important;
}

.hint { color: var(--muted); font-size: 0.78rem; line-height: 1.45; text-transform: none; letter-spacing: 0; font-weight: 400; }
.block-hint {
  padding: 14px 16px;
  background: var(--cream);
  border-radius: var(--radius);
  border-left: 3px solid var(--gold);
}

.xp-mode {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.radio-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: 1px solid var(--line);
  border-radius: 999px;
  cursor: pointer;
  background: var(--cream);
  font-size: 0.88rem;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.radio-pill:has(input:checked) {
  border-color: var(--gold);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.15);
}
.xp-summary { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 8px; }
.xp-chip {
  background: linear-gradient(135deg, var(--navy-soft), var(--navy));
  color: var(--gold-light);
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 0.8rem;
  border: 1px solid rgba(201, 169, 98, 0.25);
}

.btn-secondary, .btn-ghost {
  padding: 11px 18px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #fff;
  cursor: pointer;
  font: inherit;
  font-weight: 500;
  text-decoration: none;
  color: var(--navy);
  display: inline-flex;
  align-items: center;
  transition: border-color 0.2s, background 0.2s, transform 0.15s;
}
.btn-secondary:hover, .btn-ghost:hover {
  border-color: var(--gold);
  background: var(--cream);
  transform: translateY(-1px);
}
.form-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px solid var(--line-soft);
  margin-top: 8px;
}
.form-actions .btn-primary {
  width: auto;
  padding: 13px 28px;
  min-width: 180px;
}
.form-actions .btn-ghost {
  padding: 13px 22px;
}

.doc-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}

/* Dokumen & Pelaut — luxury cards */
.doc-section-lux {
  background: linear-gradient(180deg, #fff 0%, #fffdf9 100%);
  border-color: rgba(201, 169, 98, 0.22);
}
.doc-pelaut-intro {
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
}
.doc-pelaut-intro .doc-hint-lux {
  margin: 0;
}
.doc-rule-banner {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0;
  padding: 12px 16px;
  border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.12) 0%, rgba(201, 169, 98, 0.08) 100%);
  border: 1px solid rgba(201, 169, 98, 0.35);
  color: #92400e;
  font-size: 0.84rem;
  line-height: 1.45;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}
.doc-rule-banner-icon {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(201, 169, 98, 0.4);
  font-size: 0.9rem;
}
.doc-pelaut-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 16px;
  margin-bottom: 18px;
}
.doc-pelaut-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--doc-border, rgba(201, 169, 98, 0.28));
  background: linear-gradient(165deg, #fff 0%, var(--cream) 100%);
  box-shadow: var(--shadow-sm);
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}
.doc-pelaut-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--doc-bar, linear-gradient(90deg, var(--gold-dark), var(--gold-light), var(--gold-dark)));
}
.doc-pelaut-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: var(--doc-border-hover, rgba(201, 169, 98, 0.5));
}
.doc-pelaut-card-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 14px 12px;
  background: var(--doc-banner-bg, linear-gradient(135deg, var(--cream) 0%, #fff 100%));
  border-bottom: 1px solid var(--doc-banner-line, var(--line-soft));
}
.doc-pelaut-title-wrap {
  flex: 1;
  min-width: 0;
}
.doc-pelaut-icon-wrap {
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  border-radius: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--doc-icon-bg, linear-gradient(135deg, var(--navy-soft), var(--navy)));
  box-shadow: 0 4px 14px rgba(15, 23, 41, 0.18);
}
.doc-pelaut-icon {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  color: var(--gold-light);
}
.doc-pelaut-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--doc-title-color, var(--navy));
  letter-spacing: 0.02em;
  line-height: 1.15;
  overflow-wrap: anywhere;
}
.doc-pelaut-desc {
  margin: 3px 0 0;
  font-size: 0.68rem;
  color: var(--muted);
  line-height: 1.35;
  text-transform: none;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}
.doc-pelaut-fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  padding: 12px 14px 8px;
}
.doc-field {
  display: grid;
  gap: 5px;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
  min-width: 0;
}
.doc-field input,
.doc-field .date-field-sm input {
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font: inherit;
  font-size: 0.84rem;
  width: 100%;
  min-width: 0;
  background: #fff;
  color: var(--text);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
.doc-field .date-field-sm {
  width: 100%;
  min-width: 0;
}
.doc-field .date-field-sm input {
  width: 100%;
}
.doc-field input:focus,
.doc-field .date-field-sm input:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.15);
  background: #fff;
}
.doc-field input[readonly] {
  background: var(--cream-dark);
  color: var(--muted);
}
.doc-pelaut-actions {
  padding: 0 14px 12px;
  margin-top: auto;
}
.doc-pelaut-card .doc-upload-compact {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  padding: 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px dashed rgba(201, 169, 98, 0.35);
  min-width: 0;
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
}
.doc-upload-compact.doc-drop-active,
.doc-card-lux.doc-drop-active {
  border-color: var(--gold);
  background: rgba(201, 169, 98, 0.14);
  box-shadow: 0 0 0 2px rgba(201, 169, 98, 0.28);
}
.doc-drop-hint {
  display: block;
  font-size: 0.65rem;
  color: var(--muted);
  line-height: 1.3;
  text-align: center;
}
.doc-pelaut-card .doc-upload-compact.doc-drop-active .doc-drop-hint {
  color: var(--gold-dark);
  font-weight: 600;
}
.doc-pelaut-card .doc-save-status {
  text-align: left;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.doc-pelaut-card .doc-save-status.saved {
  display: block;
  color: #059669;
}
.doc-pelaut-card .doc-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: flex-start;
  width: 100%;
}
.doc-inline-file-info {
  margin-top: 2px;
  min-width: 0;
}
.doc-inline-file-empty {
  display: block;
  font-size: 0.68rem;
  color: var(--muted);
}
.doc-inline-file-link {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--navy-mid);
  text-decoration: underline;
  text-underline-offset: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.doc-inline-file-link:hover {
  color: var(--gold-dark);
}
.doc-pelaut-card .doc-btn {
  height: 30px;
  min-width: 0;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 0.68rem;
  flex: 0 1 auto;
}
.doc-pelaut-card .doc-btn-del {
  width: 30px;
  padding: 0;
  flex: 0 0 30px;
}
.doc-pelaut-card .doc-row-warn {
  margin: 0 10px 10px;
}
.doc-pelaut-card .doc-expiry-alert {
  border-radius: 10px;
  font-size: 0.72rem;
}
.doc-pelaut-card.doc-expiry-alert-active {
  border-color: rgba(245, 158, 11, 0.45);
  box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.12), var(--shadow-sm);
}
.doc-pelaut-card.doc-expiry-alert-active.doc-expiry-alert-active--danger {
  border-color: rgba(239, 68, 68, 0.45);
  box-shadow: 0 0 0 1px rgba(239, 68, 68, 0.1), var(--shadow-sm);
}
.doc-pelaut-card.doc-expiry-alert-active .date-input {
  border-color: #f59e0b;
  background: #fffdf5;
}
.doc-pelaut-card.doc-expiry-alert-active.doc-expiry-alert-active--danger .date-input {
  border-color: #ef4444;
  background: #fef2f2;
}
.doc-pelaut-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 100%);
  border: 1px solid rgba(201, 169, 98, 0.25);
  box-shadow: var(--shadow-md);
}
.doc-pelaut-meta-field {
  display: grid;
  gap: 6px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.72);
}
.doc-pelaut-meta-field input,
.doc-pelaut-meta-field select {
  padding: 11px 14px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  border-radius: 10px;
  font: inherit;
  font-size: 0.92rem;
  background: rgba(255, 255, 255, 0.96);
  color: var(--navy);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.doc-pelaut-meta-field input:focus,
.doc-pelaut-meta-field select:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.2);
}
.doc-pelaut-meta-field input[readonly] {
  background: rgba(250, 248, 245, 0.92);
  color: var(--muted);
}
.doc-tone-paspor {
  --doc-bar: linear-gradient(90deg, #1e3a8a, #3b82f6, #1e3a8a);
  --doc-banner-bg: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
  --doc-banner-line: rgba(59, 130, 246, 0.18);
  --doc-border: rgba(59, 130, 246, 0.22);
  --doc-border-hover: rgba(37, 99, 235, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #1d4ed8, #3b82f6);
  --doc-title-color: #1e3a8a;
}
.doc-tone-buku_pelaut {
  --doc-bar: linear-gradient(90deg, #0f1729, #334155, #0f1729);
  --doc-banner-bg: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
  --doc-banner-line: rgba(51, 65, 85, 0.16);
  --doc-border: rgba(51, 65, 85, 0.2);
  --doc-border-hover: rgba(15, 23, 41, 0.38);
  --doc-icon-bg: linear-gradient(135deg, #0f1729, #334155);
  --doc-title-color: #0f1729;
}
.doc-tone-bst {
  --doc-bar: linear-gradient(90deg, #115e59, #14b8a6, #115e59);
  --doc-banner-bg: linear-gradient(135deg, #f0fdfa 0%, #ccfbf1 100%);
  --doc-banner-line: rgba(20, 184, 166, 0.18);
  --doc-border: rgba(20, 184, 166, 0.22);
  --doc-border-hover: rgba(13, 148, 136, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #0f766e, #14b8a6);
  --doc-title-color: #115e59;
}
.doc-pelaut-card.doc-tone-sertifikat_kompetensi {
  --doc-bar: linear-gradient(90deg, #14532d, #22c55e, #14532d);
  --doc-banner-bg: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
  --doc-banner-line: rgba(34, 197, 94, 0.2);
  --doc-border: rgba(22, 163, 74, 0.22);
  --doc-border-hover: rgba(21, 128, 61, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #15803d, #22c55e);
  --doc-title-color: #14532d;
}
.doc-pelaut-note {
  margin: 0 16px 10px;
  font-size: 0.78rem;
  line-height: 1.4;
}
.doc-pelaut-card.doc-tone-ijin_orang_tua {
  --doc-bar: linear-gradient(90deg, #7c2d12, #ea580c, #7c2d12);
  --doc-banner-bg: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
  --doc-banner-line: rgba(234, 88, 12, 0.2);
  --doc-border: rgba(194, 65, 12, 0.22);
  --doc-border-hover: rgba(154, 52, 18, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #c2410c, #ea580c);
  --doc-title-color: #7c2d12;
}

/* Dokumen & Pelaut — compact table (legacy / SKCK) */
.doc-section { padding-bottom: 8px; }
.doc-hint {
  margin: 0 0 10px;
  font-size: 0.78rem;
  color: var(--muted);
}

.doc-table {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 16px;
  box-shadow: var(--shadow-sm);
}
.doc-row {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 12px;
  align-items: center;
  padding: 12px 16px;
  background: #fff;
  border-bottom: 1px solid var(--line-soft);
}
.doc-row:last-child { border-bottom: none; }
.doc-row:nth-child(even) { background: var(--cream); }
.doc-row-name {
  font-weight: 700;
  font-size: 0.78rem;
  color: var(--navy);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.doc-row-fields {
  display: grid;
  grid-template-columns: 1fr 1fr minmax(168px, auto);
  gap: 8px;
  align-items: end;
}
.doc-row-warn {
  grid-column: 1 / -1;
  margin-top: -2px;
}
.doc-hint-rule {
  margin: -6px 0 12px;
  padding: 8px 12px;
  border-radius: 8px;
  background: #fffbeb;
  border: 1px solid rgba(201, 169, 98, 0.35);
  color: #92400e;
  font-size: 0.82rem;
}
.doc-expiry-alert {
  margin: 0;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 0.78rem;
  line-height: 1.4;
  display: flex;
  align-items: flex-start;
  gap: 6px;
}
.doc-expiry-alert--warn {
  background: #fffbeb;
  border: 1px solid #fcd34d;
  color: #92400e;
}
.doc-expiry-alert--danger {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}
.doc-expiry-icon {
  flex: 0 0 auto;
  font-weight: 700;
}
.doc-row.doc-expiry-alert-active .date-input {
  border-color: #f59e0b;
  background: #fffdf5;
}
.doc-row.doc-expiry-alert-active.doc-expiry-alert-active--danger .date-input {
  border-color: #ef4444;
  background: #fef2f2;
}
.doc-mini {
  display: grid;
  gap: 3px;
  font-size: 0.76rem;
  color: var(--muted);
}
.doc-mini input,
.doc-mini .date-field-sm input {
  padding: 6px 8px;
  font-size: 0.84rem;
}
.date-field-sm .date-toggle {
  width: 28px;
  font-size: 0.85rem;
}
.doc-meta-grid {
  margin-top: 4px;
}
.doc-upload-compact {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 5px;
  min-width: 0;
}
.doc-save-status {
  font-size: 0.68rem;
  color: var(--muted);
  text-align: right;
  line-height: 1.2;
  min-height: 0.85rem;
}
.doc-save-status.saved {
  color: #059669;
  font-weight: 600;
}
.doc-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  justify-content: flex-end;
  align-items: center;
}
.doc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 30px;
  min-width: 30px;
  padding: 0 10px;
  border-radius: 8px;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--navy);
  white-space: nowrap;
  font-family: inherit;
  transition: transform 0.12s, box-shadow 0.12s;
}
.doc-btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.doc-upload-label { cursor: pointer; margin: 0; }
.doc-btn-add {
  border-color: rgba(201, 169, 98, 0.5);
  background: var(--cream);
  color: var(--gold-dark);
}
.doc-btn-add:hover { background: var(--gold-light); }
.doc-btn-new {
  border-color: #e8d5a3;
  background: #fffdf7;
  color: var(--gold-dark);
}
.doc-btn-new:hover { background: var(--gold-light); }
.doc-btn-view {
  border-color: var(--line);
  background: var(--cream);
  color: var(--navy);
}
.doc-btn-view:hover:not(:disabled) { background: #fff; border-color: var(--gold); }
.doc-btn-del {
  width: 28px;
  padding: 0;
  border-color: #fecaca;
  background: #fef2f2;
  color: #dc2626;
  font-size: 1.05rem;
}
.doc-btn-del:hover:not(:disabled) { background: #fee2e2; }
.doc-btn:disabled,
.doc-btn[hidden] { display: none; }
.doc-card-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 4px;
}

.doc-float-viewer {
  position: fixed;
  top: 12px;
  right: 12px;
  left: auto;
  bottom: auto;
  width: min(580px, calc(100vw - 24px));
  height: calc(100vh - 24px);
  min-width: 300px;
  min-height: 280px;
  max-width: calc(100vw - 12px);
  max-height: calc(100vh - 12px);
  z-index: 10050;
  display: flex;
  flex-direction: column;
  background: #1e293b;
  border-radius: 10px;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.45);
  border: 1px solid #334155;
  overflow: hidden;
  touch-action: none;
}
.doc-float-viewer.is-dragging,
.doc-float-viewer.is-resizing {
  box-shadow: 0 16px 48px rgba(15, 23, 42, 0.55);
  opacity: 0.98;
}
.doc-float-viewer[hidden] { display: none; }
.doc-float-head {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  background: #0f172a;
  color: #e2e8f0;
  font-size: 0.82rem;
  cursor: grab;
  user-select: none;
}
.doc-float-head:active {
  cursor: grabbing;
}
.doc-float-drag-hint {
  flex-shrink: 0;
  font-size: 1rem;
  line-height: 1;
  color: #94a3b8;
  letter-spacing: -0.08em;
}
.doc-float-head strong {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.doc-float-close {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border: 1px solid #475569;
  border-radius: 6px;
  background: #334155;
  color: #f8fafc;
  font-size: 1.2rem;
  line-height: 1;
  cursor: pointer;
  padding: 0;
}
.doc-float-close:hover { background: #475569; }
.doc-float-frame {
  flex: 1;
  width: 100%;
  min-height: 0;
  border: 0;
  background: #64748b;
}
.doc-float-resize-s {
  position: absolute;
  left: 0;
  right: 22px;
  bottom: 0;
  height: 14px;
  cursor: ns-resize;
  z-index: 4;
  background: linear-gradient(180deg, transparent 0%, rgba(201, 169, 98, 0.22) 100%);
}
.doc-float-resize-s:hover {
  background: linear-gradient(180deg, transparent 0%, rgba(201, 169, 98, 0.42) 100%);
}
.doc-float-resize-se {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 22px;
  height: 22px;
  cursor: nwse-resize;
  z-index: 5;
  border-bottom-right-radius: 10px;
  background:
    linear-gradient(135deg, transparent 42%, rgba(201, 169, 98, 0.55) 42%, rgba(201, 169, 98, 0.75) 100%);
}
.doc-float-resize-se:hover {
  background:
    linear-gradient(135deg, transparent 38%, rgba(201, 169, 98, 0.7) 38%, rgba(232, 213, 163, 0.9) 100%);
}

.doc-grid-wide {
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 18px;
  margin-top: 18px;
}

.reg-section-doc-lux .doc-hint-lux {
  margin: 0 0 18px;
  padding: 12px 16px;
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.1), rgba(15, 23, 41, 0.03));
  border-left: 3px solid var(--gold);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-size: 0.8rem;
  line-height: 1.45;
}
.doc-table-lux {
  border: 1px solid rgba(201, 169, 98, 0.25);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  background: #fff;
}
.doc-table-lux .doc-row {
  padding: 16px 18px;
  background: linear-gradient(135deg, #fff 0%, var(--cream) 100%);
}
.doc-table-lux .doc-row-name {
  font-family: var(--font-display);
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  color: var(--navy);
}

.doc-card-lux {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
  box-sizing: border-box;
  padding: 0;
  border: 1px solid var(--doc-border, rgba(201, 169, 98, 0.28));
  border-radius: var(--radius-lg);
  background: linear-gradient(165deg, #fff 0%, var(--cream) 100%);
  box-shadow: var(--shadow-sm);
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}
.doc-card-lux::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--doc-bar, linear-gradient(90deg, var(--gold-dark), var(--gold-light), var(--gold-dark)));
  opacity: 1;
}
.doc-card-lux:hover {
  transform: translateY(-4px);
  border-color: var(--doc-border-hover, rgba(201, 169, 98, 0.55));
  box-shadow: var(--shadow-md);
}
.doc-card-lux.doc-card-has-file:hover {
  transform: translateY(-4px);
}
.doc-card-lux.doc-card-has-file {
  border-color: var(--doc-border-hover, rgba(201, 169, 98, 0.45));
}
.doc-card-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--doc-banner-bg, linear-gradient(135deg, var(--cream) 0%, #fff 100%));
  border-bottom: 1px solid var(--doc-banner-line, var(--line-soft));
}
.doc-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 16px 0;
}
.doc-card-icon {
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  background: var(--doc-icon-bg, linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 100%));
  color: var(--doc-icon-color, var(--gold-light));
  font-size: 1.05rem;
  box-shadow: var(--doc-icon-shadow, inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 4px 10px rgba(15, 23, 41, 0.12));
}
.doc-card-title {
  display: block;
  flex: 1;
  min-width: 0;
  font-family: var(--font-body);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.025em;
  text-transform: uppercase;
  color: var(--doc-title-color, var(--navy));
  line-height: 1.25;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.doc-tone-skck {
  --doc-bar: linear-gradient(90deg, #7f1d1d, #ef4444, #7f1d1d);
  --doc-banner-bg: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
  --doc-banner-line: rgba(239, 68, 68, 0.2);
  --doc-border: rgba(220, 38, 38, 0.22);
  --doc-border-hover: rgba(185, 28, 28, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #b91c1c, #ef4444);
  --doc-title-color: #7f1d1d;
}
.doc-card-dates {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 0 16px 10px;
}
.doc-card-date {
  display: grid;
  gap: 4px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}
.doc-card-date .date-input {
  padding: 6px 8px;
  font-size: 0.82rem;
  font-weight: 500;
  text-transform: none;
  letter-spacing: normal;
}
.doc-card-date .date-field-sm {
  width: 100%;
}
.doc-card-date .date-field-sm .date-toggle {
  width: 28px;
  font-size: 0.85rem;
}
.doc-tone-ktp {
  --doc-bar: linear-gradient(90deg, #312e81, #6366f1, #312e81);
  --doc-banner-bg: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 100%);
  --doc-banner-line: rgba(99, 102, 241, 0.2);
  --doc-border: rgba(99, 102, 241, 0.22);
  --doc-border-hover: rgba(79, 70, 229, 0.45);
  --doc-icon-bg: linear-gradient(135deg, #4338ca, #6366f1);
  --doc-title-color: #1e1b4b;
}
.doc-tone-kk {
  --doc-bar: linear-gradient(90deg, #9a3412, #f97316, #9a3412);
  --doc-banner-bg: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
  --doc-banner-line: rgba(249, 115, 22, 0.2);
  --doc-border: rgba(234, 88, 12, 0.22);
  --doc-border-hover: rgba(234, 88, 12, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #c2410c, #ea580c);
  --doc-title-color: #7c2d12;
}
.doc-tone-akte {
  --doc-bar: linear-gradient(90deg, #581c87, #a855f7, #581c87);
  --doc-banner-bg: linear-gradient(135deg, #faf5ff 0%, #f3e8ff 100%);
  --doc-banner-line: rgba(168, 85, 247, 0.2);
  --doc-border: rgba(147, 51, 234, 0.22);
  --doc-border-hover: rgba(126, 34, 206, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #7e22ce, #9333ea);
  --doc-title-color: #581c87;
}
.doc-tone-ijazah {
  --doc-bar: linear-gradient(90deg, #065f46, #10b981, #065f46);
  --doc-banner-bg: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
  --doc-banner-line: rgba(16, 185, 129, 0.2);
  --doc-border: rgba(5, 150, 105, 0.22);
  --doc-border-hover: rgba(5, 150, 105, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #047857, #059669);
  --doc-title-color: #064e3b;
}
.doc-tone-buku_tabungan_1 {
  --doc-bar: linear-gradient(90deg, #92400e, #d97706, #92400e);
  --doc-banner-bg: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);
  --doc-banner-line: rgba(217, 119, 6, 0.22);
  --doc-border: rgba(180, 83, 9, 0.22);
  --doc-border-hover: rgba(180, 83, 9, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #b45309, #d97706);
  --doc-title-color: #78350f;
}
.doc-tone-buku_tabungan_2 {
  --doc-bar: linear-gradient(90deg, #a16207, #eab308, #a16207);
  --doc-banner-bg: linear-gradient(135deg, #fefce8 0%, #fef9c3 100%);
  --doc-banner-line: rgba(234, 179, 8, 0.22);
  --doc-border: rgba(161, 98, 7, 0.22);
  --doc-border-hover: rgba(161, 98, 7, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #ca8a04, #eab308);
  --doc-title-color: #713f12;
}
.doc-tone-medical_checkup {
  --doc-bar: linear-gradient(90deg, #0e7490, #06b6d4, #0e7490);
  --doc-banner-bg: linear-gradient(135deg, #ecfeff 0%, #cffafe 100%);
  --doc-banner-line: rgba(6, 182, 212, 0.2);
  --doc-border: rgba(8, 145, 178, 0.22);
  --doc-border-hover: rgba(8, 145, 178, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #0891b2, #06b6d4);
  --doc-title-color: #164e63;
}
.doc-tone-surat_ijin_keluarga {
  --doc-bar: linear-gradient(90deg, #9d174d, #ec4899, #9d174d);
  --doc-banner-bg: linear-gradient(135deg, #fdf2f8 0%, #fce7f3 100%);
  --doc-banner-line: rgba(236, 72, 153, 0.2);
  --doc-border: rgba(219, 39, 119, 0.22);
  --doc-border-hover: rgba(190, 24, 93, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #be185d, #db2777);
  --doc-title-color: #831843;
}
.doc-tone-buku_nikah {
  --doc-bar: linear-gradient(90deg, #831843, #f472b6, #831843);
  --doc-banner-bg: linear-gradient(135deg, #fff1f2 0%, #ffe4e6 100%);
  --doc-banner-line: rgba(244, 114, 182, 0.22);
  --doc-border: rgba(225, 29, 72, 0.22);
  --doc-border-hover: rgba(190, 18, 60, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #be123c, #e11d48);
  --doc-title-color: #881337;
}
.doc-tone-hasil_interview {
  --doc-bar: linear-gradient(90deg, #1e3a8a, #3b82f6, #1e3a8a);
  --doc-banner-bg: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
  --doc-banner-line: rgba(59, 130, 246, 0.2);
  --doc-border: rgba(37, 99, 235, 0.22);
  --doc-border-hover: rgba(29, 78, 216, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #1d4ed8, #2563eb);
  --doc-title-color: #1e3a8a;
}
.doc-tone-sertifikat_kompetensi {
  --doc-bar: linear-gradient(90deg, #14532d, #22c55e, #14532d);
  --doc-banner-bg: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
  --doc-banner-line: rgba(34, 197, 94, 0.2);
  --doc-border: rgba(22, 163, 74, 0.22);
  --doc-border-hover: rgba(21, 128, 61, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #15803d, #16a34a);
  --doc-title-color: #14532d;
}
.doc-tone-pkl {
  --doc-bar: linear-gradient(90deg, #0c4a6e, #0ea5e9, #0c4a6e);
  --doc-banner-bg: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
  --doc-banner-line: rgba(14, 165, 233, 0.2);
  --doc-border: rgba(2, 132, 199, 0.22);
  --doc-border-hover: rgba(3, 105, 161, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #0369a1, #0284c7);
  --doc-title-color: #0c4a6e;
}
.doc-tone-pembiayaan_pinjaman {
  --doc-bar: linear-gradient(90deg, #78350f, var(--gold), #78350f);
  --doc-banner-bg: linear-gradient(135deg, #fffdf7 0%, var(--gold-light) 100%);
  --doc-banner-line: rgba(201, 169, 98, 0.35);
  --doc-border: rgba(168, 134, 58, 0.28);
  --doc-border-hover: rgba(168, 134, 58, 0.5);
  --doc-icon-bg: linear-gradient(135deg, var(--gold-dark), var(--gold));
  --doc-icon-color: var(--navy);
  --doc-title-color: #422006;
}
.doc-tone-skema_pengembalian_pinjaman {
  --doc-bar: linear-gradient(90deg, #4c1d95, #8b5cf6, #4c1d95);
  --doc-banner-bg: linear-gradient(135deg, #f5f3ff 0%, #ede9fe 100%);
  --doc-banner-line: rgba(139, 92, 246, 0.2);
  --doc-border: rgba(109, 40, 217, 0.22);
  --doc-border-hover: rgba(91, 33, 182, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #6d28d9, #7c3aed);
  --doc-title-color: #4c1d95;
}
.doc-tone-dokumen_lainnya {
  --doc-bar: linear-gradient(90deg, #334155, #94a3b8, #334155);
  --doc-banner-bg: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
  --doc-banner-line: rgba(100, 116, 139, 0.2);
  --doc-border: rgba(71, 85, 105, 0.22);
  --doc-border-hover: rgba(51, 65, 85, 0.42);
  --doc-icon-bg: linear-gradient(135deg, #475569, #64748b);
  --doc-title-color: #1e293b;
}
.doc-card-status {
  display: inline-block;
  margin-top: 5px;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--muted);
  background: rgba(15, 23, 41, 0.05);
}
.doc-card-status.is-uploaded {
  color: #065f46;
  background: rgba(5, 150, 105, 0.1);
}
.doc-card-del {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border: 1px solid rgba(220, 38, 38, 0.25);
  border-radius: 50%;
  background: #fff5f5;
  color: #dc2626;
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  transition: background 0.15s, transform 0.15s;
}
.doc-card-del:hover:not(:disabled) {
  background: #fee2e2;
  transform: scale(1.05);
}
.doc-card-body {
  padding: 0 16px 12px;
  min-height: 1.4em;
  font-size: 0.72rem;
  line-height: 1.4;
}
.doc-card-empty {
  color: var(--muted);
  font-style: italic;
}
.doc-card-link {
  color: var(--doc-title-color, var(--gold-dark));
  font-weight: 600;
  text-decoration: none;
  word-break: break-all;
  cursor: pointer;
}
.doc-card-link:hover {
  color: var(--navy);
  text-decoration: underline;
}
.doc-card-view-hint {
  display: block;
  margin-top: 4px;
  font-size: 0.62rem;
  color: var(--muted);
  font-style: italic;
}
.doc-card-foot {
  margin-top: auto;
  padding: 12px 16px 16px;
  border-top: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.72);
  display: grid;
  gap: 8px;
}
.doc-card-foot-multi .doc-card-toolbar {
  width: 100%;
  justify-content: flex-start;
}
.doc-card-foot-multi .doc-card-hapus {
  width: auto;
  min-width: 72px;
  padding: 0 12px;
  height: 30px;
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.72rem;
}
.doc-card-drop-hint {
  font-size: 0.65rem;
  color: var(--muted);
  line-height: 1.35;
}
.doc-card-lux.doc-drop-active {
  outline: 2px dashed rgba(201, 169, 98, 0.55);
  outline-offset: 2px;
}
.doc-card-hapus {
  width: 100%;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid rgba(220, 38, 38, 0.28);
  background: #fff5f5;
  color: #b91c1c;
  font: inherit;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, opacity 0.15s;
}
.doc-card-hapus:hover:not(:disabled) {
  background: #fee2e2;
  border-color: #fca5a5;
}
.doc-card-hapus:disabled {
  opacity: 0.38;
  cursor: not-allowed;
}
.doc-card-upload {
  display: grid;
  gap: 6px;
  min-width: 0;
  cursor: pointer;
  margin: 0;
}
.doc-card-upload-btn {
  display: block;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.35);
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 100%);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #fff;
  line-height: 1.2;
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
.doc-card-upload:hover .doc-card-upload-btn {
  border-color: var(--gold);
  box-shadow: 0 6px 16px rgba(15, 23, 41, 0.18);
  transform: translateY(-1px);
}
.doc-card-upload-name {
  display: block;
  font-size: 0.66rem;
  color: var(--muted);
  line-height: 1.3;
  text-align: center;
  word-break: break-all;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}
.doc-card-upload-name.has-file {
  color: var(--gold-dark);
  font-weight: 600;
  font-style: normal;
}
.doc-card input[type="file"].doc-card-file {
  display: none;
}

/* Legacy doc-card fallback */
.doc-card:not(.doc-card-lux) {
  border: 1px dashed rgba(201, 169, 98, 0.45);
  border-radius: var(--radius);
  padding: 14px;
  display: grid;
  gap: 8px;
  font-size: 0.85rem;
  background: var(--cream);
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
  min-width: 0;
  overflow: hidden;
  box-sizing: border-box;
}
.doc-card:not(.doc-card-lux):hover {
  border-color: var(--gold);
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.doc-card:not(.doc-card-lux) strong {
  display: block;
  font-size: 0.72rem;
  line-height: 1.35;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--navy);
  word-break: break-word;
  overflow-wrap: anywhere;
  hyphens: auto;
}
.doc-card .doc-file-info {
  font-size: 0.72rem;
  line-height: 1.35;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.doc-card .doc-file-info a {
  color: var(--navy);
  font-weight: 600;
}
.doc-card:not(.doc-card-lux) .doc-card-upload {
  display: grid;
  gap: 5px;
  min-width: 0;
  cursor: pointer;
  margin: 0;
}
.doc-card:not(.doc-card-lux) .doc-card-upload-btn {
  display: block;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  padding: 8px 8px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--navy);
  line-height: 1.2;
}
.doc-card:not(.doc-card-lux) .doc-card-upload:hover .doc-card-upload-btn {
  border-color: var(--gold);
  background: var(--cream);
}
.doc-card:not(.doc-card-lux) .doc-card-upload-name {
  display: block;
  font-size: 0.66rem;
  color: var(--muted);
  line-height: 1.3;
  word-break: break-all;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}
.doc-card:not(.doc-card-lux) .doc-card-upload-name.has-file {
  color: var(--gold-dark);
  font-weight: 600;
}
.doc-card:not(.doc-card-lux) input[type="file"].doc-card-file {
  display: none;
}

.alert.ok {
  background: linear-gradient(135deg, #ecfdf5, #f0fdf4);
  color: #065f46;
  padding: 14px 16px;
  border-radius: var(--radius);
  margin: 0 32px 0;
  border: 1px solid #a7f3d0;
  border-left: 4px solid #059669;
}
.form-panel-lux > .alert.ok,
.form-panel-lux > .alert.err {
  margin: 16px 32px 0;
}

/* Modal pengalaman */
.modal { position: fixed; inset: 0; z-index: 10100; display: grid; place-items: center; padding: 16px; }
.modal[hidden] { display: none; }
.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 41, 0.55);
  backdrop-filter: blur(4px);
  z-index: 0;
}
.modal-card {
  position: relative;
  z-index: 1;
  background: #fff;
  width: min(920px, 96vw);
  max-height: 90vh;
  overflow: auto;
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--line);
}
.modal-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line-soft);
}
.modal-head h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.35rem;
  color: var(--navy);
}
.modal-hint { margin: 0 0 14px; padding: 0 4px; }
.modal-close {
  border: 1px solid var(--line);
  background: var(--cream);
  font-size: 1.25rem;
  cursor: pointer;
  line-height: 1;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  color: var(--navy);
  transition: background 0.2s, border-color 0.2s;
}
.modal-close:hover { background: var(--gold-light); border-color: var(--gold); }
.xp-item {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  margin-bottom: 14px;
  background: var(--cream);
}
.xp-item-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}
.btn-del-xp {
  border: none;
  background: #fee2e2;
  color: #991b1b;
  padding: 4px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 0.8rem;
}
.keahlian-box > span { display: block; margin-bottom: 8px; font-size: 0.85rem; font-weight: 600; }
.keahlian-group { margin-bottom: 10px; }
.keahlian-group-title {
  display: block;
  margin-bottom: 6px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.keahlian-chks { display: flex; flex-wrap: wrap; gap: 8px 14px; }
.keahlian-chks .chk { font-size: 0.85rem; display: inline-flex; gap: 4px; align-items: center; }
.keahlian-tambahan { margin-top: 10px; }
.keahlian-tambahan input { width: 100%; }
.xp-summary .xp-warn { color: #b45309; font-size: 0.9rem; }
.modal-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 8px; }

.nik-dup-modal { z-index: 100200; }
.nik-dup-card {
  width: min(440px, 94vw);
  text-align: center;
  border-color: rgba(239, 68, 68, 0.35);
  box-shadow: 0 20px 60px rgba(127, 29, 29, 0.18);
}
.nik-dup-card .modal-head {
  justify-content: center;
  position: relative;
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}
.nik-dup-card .modal-head h2 {
  color: #991b1b;
  font-size: 1.15rem;
}
.nik-dup-card .modal-close {
  position: absolute;
  right: 0;
  top: 0;
}
.nik-dup-icon {
  width: 52px;
  height: 52px;
  margin: 8px auto 12px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: #b45309;
  background: #fffbeb;
  border: 2px solid #fcd34d;
}
.nik-dup-message {
  margin: 0 0 8px;
  font-size: 0.92rem;
  line-height: 1.45;
  color: #991b1b;
  text-transform: none;
  letter-spacing: 0;
}
.nik-dup-detail {
  margin: 0 0 16px;
  font-size: 0.82rem;
  color: var(--navy);
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
}
.nik-dup-card .modal-actions {
  justify-content: center;
}

/* Masterdata */
.master-panel .panel-toolbar { align-items: center; }
.master-nav-links { display: flex; flex-wrap: wrap; gap: 6px; }

.doc-dash-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #fffdf8 0%, #fff 100%);
}
.doc-dash-stat {
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid var(--line-soft);
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.doc-dash-stat-num {
  display: block;
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.1;
}
.doc-dash-stat-label {
  display: block;
  margin-top: 4px;
  font-size: 0.78rem;
  color: var(--muted);
}
.doc-dash-stat--danger .doc-dash-stat-num { color: #b91c1c; }
.doc-dash-stat--warn .doc-dash-stat-num { color: #b45309; }
.doc-dash-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
}
.doc-dash-filter {
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--navy);
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
}
.doc-dash-filter:hover {
  border-color: var(--gold);
  color: var(--gold-dark);
  text-decoration: none;
}
.doc-dash-filter.is-active {
  background: linear-gradient(135deg, var(--navy-soft), var(--navy));
  border-color: rgba(201, 169, 98, 0.35);
  color: var(--gold-light);
}
.doc-dash-table .col-uniq { width: 118px; min-width: 118px; }
.doc-dash-table .col-doc-type { width: 10%; }
.doc-dash-table .col-doc-no { width: 12%; }
.doc-dash-table .col-doc-exp { width: 10%; }
.doc-dash-table .col-doc-status { width: 10%; }
.doc-dash-type {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--navy);
}
.doc-exp-cell {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--navy);
}
.doc-dash-badge {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  white-space: nowrap;
}
.doc-dash-badge--warn {
  background: #fffbeb;
  border: 1px solid #fcd34d;
  color: #92400e;
}
.doc-dash-badge--danger {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}
@media (min-width: 1100px) {
  .doc-pelaut-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .doc-pelaut-fields {
    grid-template-columns: 1fr 1fr;
    gap: 10px 8px;
  }
}
@media (max-width: 900px) {
  .reg-grid-compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .reg-grid-compact label.span-2 { grid-column: span 2; }
  .reg-grid-compact label.full { grid-column: 1 / -1; }
  .doc-dash-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 768px) {
  .reg-grid-compact { grid-template-columns: 1fr; }
  .reg-grid-compact label.span-2 { grid-column: auto; }
}
@media (max-width: 560px) {
  .doc-dash-stats { grid-template-columns: 1fr; }
}
.master-tab {
  padding: 6px 12px;
  border-radius: 999px;
  background: #f1f5f9;
  color: var(--text);
  text-decoration: none;
  font-size: 0.85rem;
}
.master-tab.active { background: var(--blue); color: #fff; }
.master-form-wrap {
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  background: #fafbfc;
}
.master-form-wrap h2 { margin: 0 0 12px; font-size: 1rem; }
.master-form { max-width: 900px; }
.master-search-wrap {
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  background: #fafbfc;
}
.master-search-form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px 16px;
  margin: 0;
  width: 100%;
}
.master-search-total {
  margin-left: auto;
  flex: 0 0 auto;
  align-self: flex-end;
  min-width: 88px;
  padding: 6px 14px 8px;
  text-align: center;
  border: 1px solid var(--line-soft);
  border-radius: 10px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.master-search-total-num {
  display: block;
  font-family: var(--font-display);
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.1;
}
.master-search-total-label {
  display: block;
  margin-top: 2px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}
.master-search-label {
  flex: 1 1 280px;
  margin: 0;
  display: grid;
  gap: 7px;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}
.master-search-input-field {
  display: block;
  width: 100%;
  box-sizing: border-box;
  padding: 11px 40px 11px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font: inherit;
  font-size: 0.95rem;
  text-transform: uppercase;
  background:
    var(--cream)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a8863a' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E")
    no-repeat right 14px center;
  color: var(--text);
  transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s;
  min-height: 44px;
  -webkit-appearance: none;
  appearance: none;
}
.master-search-input-field::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
}
.master-search-input-field::placeholder {
  color: #94a3b8;
  text-transform: none;
  letter-spacing: normal;
  font-size: 0.9rem;
}
.master-search-input-field:focus {
  outline: none;
  border-color: var(--gold);
  background-color: #fff;
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.18);
}
.master-search-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.master-search-btn {
  min-height: 44px;
  padding: 11px 20px;
}
.master-search-meta {
  flex: 1 1 100%;
  margin: 0;
  font-size: 0.82rem;
}
@media (max-width: 720px) {
  .master-search-total {
    margin-left: 0;
    width: 100%;
  }
}
.master-table-wrap {
  padding: 0 18px 18px;
}
.master-table .row-inactive { opacity: 0.55; }
.inline-del { display: inline; }
.btn-del {
  padding: 5px 10px;
  border: none;
  border-radius: 6px;
  background: #fee2e2;
  color: #991b1b;
  cursor: pointer;
  font-size: 0.82rem;
}

.withdrawal-banner {
  margin: 0 24px 16px;
  border: 1px solid #fecaca;
  border-left: 4px solid #dc2626;
  background: #fff7f7;
  color: #7f1d1d;
}
.withdrawal-banner strong {
  display: block;
  margin-bottom: 6px;
  font-size: 0.95rem;
}
.withdrawal-banner p {
  margin: 0 0 6px;
  font-size: 0.84rem;
  line-height: 1.45;
}
.withdrawal-meta {
  font-weight: 700;
  color: #991b1b;
}
.withdrawal-detail {
  padding: 8px 10px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #fecaca;
}
.withdrawal-note {
  font-size: 0.78rem;
  color: #b91c1c;
}

.withdraw-modal .withdraw-card {
  max-width: 520px;
}
.withdraw-intro {
  margin: 0 0 14px;
  font-size: 0.86rem;
  color: var(--muted);
  line-height: 1.45;
}
.withdraw-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}
.withdraw-field select,
.withdraw-field textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font: inherit;
  background: #fff;
}
.withdraw-field textarea {
  resize: vertical;
  min-height: 96px;
}
.btn-withdraw-submit {
  background: linear-gradient(135deg, #991b1b, #dc2626) !important;
  border-color: #fecaca !important;
}

.abk-inactive-filters-grid {
  grid-template-columns: minmax(180px, 1.4fr) minmax(200px, 1fr);
}
.inactive-count {
  padding: 0 18px 10px;
  margin: 0;
}
.inactive-table .row-inactive {
  background: #fffafa;
}
.inactive-name-block {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.inactive-name-block strong {
  font-size: 0.88rem;
}
.inactive-nik {
  font-size: 0.72rem;
  color: var(--muted);
}
.withdrawal-reason-badge {
  display: inline-block;
  padding: 4px 8px;
  border-radius: 999px;
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.3;
}
.col-withdraw-detail {
  max-width: 280px;
  font-size: 0.78rem;
  line-height: 1.35;
  word-break: break-word;
}
.col-withdraw-reason {
  min-width: 160px;
}
.col-withdraw-by {
  min-width: 90px;
  font-size: 0.78rem;
}

/* —— Alur Status ABK —— */
.crew-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.22rem 0.55rem;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  border: 1px solid transparent;
  white-space: nowrap;
}
.crew-status-badge.tone-slate { background: #e2e8f0; color: #334155; border-color: #cbd5e1; }
.crew-status-badge.tone-amber { background: #fef3c7; color: #92400e; border-color: #fde68a; }
.crew-status-badge.tone-sky { background: #e0f2fe; color: #075985; border-color: #bae6fd; }
.crew-status-badge.tone-green { background: #dcfce7; color: #166534; border-color: #bbf7d0; }
.crew-status-badge.tone-lime { background: #ecfccb; color: #3f6212; border-color: #d9f99d; }
.crew-status-badge.tone-teal { background: #ccfbf1; color: #115e59; border-color: #99f6e4; }
.crew-status-badge.tone-indigo { background: #e0e7ff; color: #3730a3; border-color: #c7d2fe; }
.crew-status-badge.tone-violet { background: #ede9fe; color: #5b21b6; border-color: #ddd6fe; }
.crew-status-badge.tone-navy { background: #dbeafe; color: #1e3a8a; border-color: #bfdbfe; }
.crew-status-badge.tone-orange { background: #ffedd5; color: #9a3412; border-color: #fed7aa; }
.crew-status-badge.tone-red { background: #fee2e2; color: #991b1b; border-color: #fecaca; }

.col-status { width: 8%; min-width: 0; }

@media (max-width: 900px) {
  .panel-table-fit .table-scroll { overflow-x: auto; }
  .abk-table-compact { min-width: 720px; }
}

.crew-status-panel {
  margin: 0 0 1.25rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #fff 0%, #faf8f5 100%);
  box-shadow: var(--shadow-sm);
}
.crew-status-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
}
.crew-status-current {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin: 0.35rem 0;
}
.crew-status-pct-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  padding: 6px 12px;
  border-radius: 12px;
  border: 2px solid transparent;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
  line-height: 1.1;
  text-align: center;
}
.crew-status-pct-value {
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.crew-status-pct-sub {
  margin-top: 2px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.92;
}
.crew-status-pct-badge.tone-low {
  background: linear-gradient(135deg, #ef4444, #dc2626);
  border-color: #fecaca;
  color: #fff;
  box-shadow: 0 4px 16px rgba(220, 38, 38, 0.35);
}
.crew-status-pct-badge.tone-mid {
  background: linear-gradient(135deg, #f59e0b, #ea580c);
  border-color: #fed7aa;
  color: #fff;
  box-shadow: 0 4px 16px rgba(234, 88, 12, 0.35);
}
.crew-status-pct-badge.tone-high {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  border-color: #bfdbfe;
  color: #fff;
  box-shadow: 0 4px 16px rgba(37, 99, 235, 0.35);
}
.crew-status-pct-badge.tone-full {
  background: linear-gradient(135deg, #16a34a, #15803d);
  border-color: #bbf7d0;
  color: #fff;
  box-shadow: 0 4px 16px rgba(22, 163, 74, 0.35);
}
.crew-status-hint { margin: 0.25rem 0 0; font-size: 0.82rem; }
.crew-status-meta { display: flex; flex-direction: column; gap: 0.2rem; font-size: 0.78rem; color: var(--muted); text-align: right; }
.crew-status-progress { display: flex; align-items: center; gap: 0.65rem; margin-bottom: 0.75rem; }
.crew-status-progress-track { flex: 1; height: 8px; border-radius: 999px; background: #e8e4dc; overflow: hidden; }
.crew-status-progress-fill { height: 100%; background: linear-gradient(90deg, #c9a962, #2e7d32); border-radius: inherit; }
.crew-status-progress-label { font-size: 0.75rem; color: var(--muted); white-space: nowrap; }
.crew-status-doc-block { margin-bottom: 0.85rem; }
.crew-status-doc-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  gap: 6px 10px;
  margin: 0 0 10px;
  padding: 0;
  list-style: none;
}
.crew-status-doc-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border-radius: 8px;
  font-size: 0.78rem;
  border: 1px solid var(--line-soft);
  background: #fff;
}
.crew-status-doc-item.is-done {
  border-color: rgba(46, 125, 50, 0.25);
  background: rgba(220, 252, 231, 0.45);
}
.crew-status-doc-item.is-missing {
  border-color: rgba(198, 40, 40, 0.18);
  background: rgba(254, 242, 242, 0.55);
}
.crew-status-doc-icon {
  flex: 0 0 auto;
  width: 16px;
  text-align: center;
  font-weight: 700;
  font-size: 0.82rem;
}
.crew-status-doc-item.is-done .crew-status-doc-icon { color: #166534; }
.crew-status-doc-item.is-missing .crew-status-doc-icon { color: #b45309; }
.crew-status-doc-link {
  color: inherit;
  text-decoration: none;
  font-weight: 600;
  line-height: 1.25;
}
.crew-status-doc-link:hover {
  color: var(--navy);
  text-decoration: underline;
}
.crew-status-doc-summary {
  display: grid;
  gap: 4px;
  font-size: 0.78rem;
  line-height: 1.4;
}
.crew-status-doc-done { margin: 0; color: #166534; }
.crew-status-doc-missing { margin: 0; color: #b45309; }
.crew-status-doc-summary strong { font-weight: 700; }
.crew-status-catatan { margin: 0 0 0.75rem; font-size: 0.82rem; }
.crew-status-form { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.crew-status-form.crew-status-form-nav {
  grid-template-columns: 1fr;
}
.crew-status-form.crew-status-form-nav label.full {
  grid-column: 1 / -1;
}
.crew-status-form.crew-status-form-nav .crew-status-actions {
  grid-column: 1 / -1;
  order: 2;
  margin-bottom: 4px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: stretch;
}
.crew-status-form-nav .crew-status-btn-prev,
.crew-status-form-nav .crew-status-btn-next {
  width: auto !important;
  min-width: 118px;
  max-width: min(100%, 200px);
  flex: 1 1 140px;
  padding: 10px 12px !important;
  border-radius: 12px !important;
  font: inherit;
  cursor: pointer;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  line-height: 1.25;
  text-align: center;
  white-space: normal;
  box-shadow: var(--shadow-sm);
  transition: transform 0.15s, box-shadow 0.2s, border-color 0.2s;
}
.crew-status-btn-line {
  display: block;
  width: 100%;
}
.crew-status-btn-line-main {
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.crew-status-btn-line-target {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  opacity: 0.95;
}
.crew-status-form-nav .crew-status-btn-prev {
  border: 1px solid rgba(100, 116, 139, 0.35) !important;
  background: #f8fafc !important;
  color: var(--navy) !important;
}
.crew-status-form-nav .crew-status-btn-prev:hover {
  border-color: rgba(100, 116, 139, 0.55) !important;
  background: #f1f5f9 !important;
}
.crew-status-form-nav .crew-status-btn-next {
  border: 1px solid rgba(201, 169, 98, 0.45) !important;
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 100%) !important;
  color: #fff !important;
}
.crew-status-form-nav .crew-status-btn-next:hover {
  transform: translateY(-1px);
  border-color: var(--gold) !important;
  box-shadow: var(--shadow-md);
}
.crew-status-form.crew-status-form-nav .crew-status-force {
  order: 1;
}
.crew-status-form.crew-status-form-nav .crew-status-catatan-field {
  order: 3;
}
.crew-status-form.crew-status-form-nav .crew-status-catatan-error {
  order: 4;
}
.crew-status-form.crew-status-form-nav .crew-status-form-hint,
.crew-status-form.crew-status-form-nav .crew-status-syarat-hint {
  order: 5;
}
.crew-status-form.crew-status-form-nav {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.crew-status-form-current {
  margin: 0 0 12px;
  font-size: 0.88rem;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.crew-status-form label { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.78rem; font-weight: 600; }
.crew-status-form select,
.crew-status-form textarea { font-size: 0.85rem; }
.crew-status-form textarea { grid-column: 1 / -1; min-height: 64px; resize: vertical; }
.crew-status-force { grid-column: 1 / -1; flex-direction: row !important; align-items: center; gap: 0.45rem !important; font-weight: 500 !important; }
.crew-status-actions { grid-column: 1 / -1; display: flex; gap: 0.5rem; flex-wrap: wrap; }

/* —— Alur Status ABK — tampilan luxe —— */
.crew-status-panel-lux {
  position: relative;
  margin: 0 0 1.5rem;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(201, 169, 98, 0.22);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #fff 0%, var(--cream) 100%);
  box-shadow: var(--shadow-lg), 0 0 0 1px rgba(255, 255, 255, 0.65) inset;
}
.crew-status-panel-lux::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold-dark), var(--gold-light), var(--gold-dark), transparent);
  z-index: 1;
}
.crew-status-banner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 16px;
  padding: 22px 26px 20px;
  background:
    radial-gradient(ellipse 80% 120% at 100% 0%, rgba(201, 169, 98, 0.12), transparent 55%),
    linear-gradient(135deg, var(--navy) 0%, var(--navy-soft) 72%, #1a2744 100%);
  border-bottom: 2px solid var(--gold);
  color: #fff;
}
.crew-status-eyebrow {
  margin: 0 0 8px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-light);
}
.crew-status-panel-lux .crew-status-current {
  gap: 12px;
  margin: 0 0 8px;
}
.crew-status-panel-lux .crew-status-badge {
  padding: 0.35rem 0.85rem;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
}
.crew-status-panel-lux .crew-status-hint {
  margin: 0;
  font-size: 0.84rem;
  color: rgba(255, 255, 255, 0.78);
  max-width: 560px;
  line-height: 1.45;
}
.crew-status-hint-note {
  margin-top: 6px !important;
  font-size: 0.78rem !important;
  color: rgba(232, 213, 163, 0.9) !important;
}
.crew-status-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}
.crew-status-meta-chip {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  padding: 8px 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(201, 169, 98, 0.28);
  font-size: 0.78rem;
  font-weight: 600;
  color: #fff;
  backdrop-filter: blur(4px);
}
.crew-status-meta-label {
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold-light);
}
.crew-status-panel-lux .crew-status-pct-badge {
  min-width: 78px;
  padding: 8px 14px;
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.22);
}
.crew-status-panel-lux .crew-status-pct-value {
  font-size: 1.45rem;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
}
.crew-status-panel-lux .crew-status-pct-badge.tone-high {
  background: linear-gradient(135deg, #1d4ed8 0%, #2563eb 45%, #c9a962 140%);
  border-color: rgba(232, 213, 163, 0.55);
}
.crew-status-body {
  padding: 20px 26px 4px;
}
.crew-status-panel-lux .crew-status-doc-block {
  margin: 0;
  padding: 18px 20px;
  border-radius: 14px;
  border: 1px solid rgba(201, 169, 98, 0.18);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(250, 248, 245, 0.9) 100%);
  box-shadow: var(--shadow-sm);
}
.crew-status-doc-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.crew-status-doc-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--navy);
}
.crew-status-panel-lux .crew-status-progress-label {
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--navy);
  background: rgba(201, 169, 98, 0.15);
  border: 1px solid rgba(201, 169, 98, 0.28);
}
.crew-status-panel-lux .crew-status-progress {
  gap: 12px;
  margin-bottom: 14px;
}
.crew-status-panel-lux .crew-status-progress-track {
  height: 12px;
  background: rgba(15, 23, 41, 0.08);
  border: 1px solid rgba(201, 169, 98, 0.15);
  box-shadow: inset 0 1px 3px rgba(15, 23, 41, 0.06);
}
.crew-status-panel-lux .crew-status-progress-fill {
  background: linear-gradient(90deg, var(--gold-dark), var(--gold), #16a34a);
  box-shadow: 0 0 12px rgba(201, 169, 98, 0.35);
}
.crew-status-progress-pct {
  min-width: 42px;
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--gold-dark);
  font-variant-numeric: tabular-nums;
}
.crew-status-panel-lux .crew-status-doc-list {
  grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}
.crew-status-panel-lux .crew-status-doc-item {
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 0.76rem;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.crew-status-panel-lux .crew-status-doc-item:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.crew-status-panel-lux .crew-status-doc-item.is-done {
  border-color: rgba(22, 101, 52, 0.28);
  background: linear-gradient(180deg, #f0fdf4, #dcfce7);
}
.crew-status-panel-lux .crew-status-doc-item.is-missing {
  border-color: rgba(220, 38, 38, 0.22);
  background: linear-gradient(180deg, #fff7ed, #ffedd5);
}
.crew-status-panel-lux .crew-status-doc-item.is-missing .crew-status-doc-link {
  color: #9a3412;
}
.crew-status-panel-lux .crew-status-doc-summary {
  padding-top: 12px;
  border-top: 1px dashed rgba(201, 169, 98, 0.35);
  gap: 6px;
}
.crew-status-panel-lux .crew-status-doc-done,
.crew-status-panel-lux .crew-status-doc-missing {
  padding: 8px 12px;
  border-radius: 10px;
  font-size: 0.76rem;
}
.crew-status-panel-lux .crew-status-doc-done {
  background: rgba(220, 252, 231, 0.55);
  border: 1px solid rgba(22, 101, 52, 0.15);
}
.crew-status-panel-lux .crew-status-doc-missing {
  background: rgba(255, 237, 213, 0.55);
  border: 1px solid rgba(234, 88, 12, 0.18);
}
.crew-status-panel-lux .crew-status-catatan {
  margin: 0;
  padding: 12px 26px;
  font-size: 0.82rem;
  background: rgba(201, 169, 98, 0.08);
  border-top: 1px solid rgba(201, 169, 98, 0.15);
  border-bottom: 1px solid rgba(201, 169, 98, 0.15);
}
.crew-status-form-section {
  padding: 20px 26px 24px;
  background: linear-gradient(180deg, #fff, rgba(250, 248, 245, 0.6));
}
.crew-status-form-eyebrow {
  margin: 0 0 14px;
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: 0.02em;
}
.crew-status-form-lux label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--gold-dark);
}
.crew-status-form-lux select,
.crew-status-form-lux textarea {
  padding: 11px 14px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 41, 0.1);
  background: #fff;
  box-shadow: inset 0 1px 3px rgba(15, 23, 41, 0.04);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.crew-status-form-lux select:focus,
.crew-status-form-lux textarea:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.14);
}
.crew-status-form-lux .crew-status-actions {
  gap: 10px;
  padding-top: 4px;
}
.crew-status-btn-next {
  padding: 11px 18px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(201, 169, 98, 0.45) !important;
  background: #fff !important;
  font-weight: 600 !important;
  box-shadow: var(--shadow-sm);
}
.crew-status-btn-next:hover {
  border-color: var(--gold) !important;
  color: var(--gold-dark) !important;
}
.crew-status-btn-save {
  padding: 11px 22px !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, var(--navy-soft), var(--navy)) !important;
  border: 1px solid rgba(201, 169, 98, 0.3) !important;
  font-weight: 700 !important;
  letter-spacing: 0.03em;
  box-shadow: 0 4px 14px rgba(15, 23, 41, 0.2);
}
.crew-status-btn-save:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(15, 23, 41, 0.25);
}
.crew-status-btn-prev {
  padding: 11px 18px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(100, 116, 139, 0.35) !important;
  background: #f8fafc !important;
  color: var(--navy) !important;
  font-weight: 600 !important;
}
.crew-status-btn-prev:hover {
  border-color: rgba(100, 116, 139, 0.55) !important;
  background: #f1f5f9 !important;
}
.crew-status-form-hint {
  grid-column: 1 / -1;
  margin: 0;
}
.crew-status-syarat-hint {
  grid-column: 1 / -1;
  margin: 0;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(132, 204, 22, 0.1);
  border: 1px solid rgba(132, 204, 22, 0.28);
  color: #3f6212;
  line-height: 1.45;
}
.crew-status-catatan-field.is-error textarea,
.crew-status-catatan-syarat.is-error textarea {
  border-color: #dc2626 !important;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12) !important;
}
.crew-status-catatan-syarat textarea {
  border-color: rgba(132, 204, 22, 0.45);
  background: rgba(247, 254, 231, 0.5);
}
.crew-status-catatan-error {
  grid-column: 1 / -1;
  margin: 0;
  padding: 10px 12px;
  border-radius: 10px;
  background: #fef2f2;
  border: 1px solid rgba(220, 38, 38, 0.25);
  color: #b91c1c;
  font-size: 0.84rem;
  line-height: 1.4;
}
.crew-status-history {
  padding: 14px 22px 18px;
  border-top: 1px solid rgba(201, 169, 98, 0.12);
  background: rgba(250, 248, 245, 0.5);
}
.crew-status-history-list {
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.crew-status-history-item {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
}
.crew-status-history-move {
  display: block;
  font-weight: 600;
  font-size: 0.84rem;
  color: var(--navy);
}
.crew-status-history-meta {
  display: block;
  font-size: 0.74rem;
  color: var(--muted);
  margin-top: 2px;
}
.crew-status-history-catatan {
  margin: 6px 0 0;
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--ink);
}

@media (max-width: 760px) {
  .crew-status-banner {
    padding: 18px 16px 16px;
  }
  .crew-status-body,
  .crew-status-form-section {
    padding-left: 16px;
    padding-right: 16px;
  }
  .crew-status-meta {
    align-items: flex-start;
    width: 100%;
  }
  .crew-status-meta-chip {
    align-items: flex-start;
  }
}

.status-board-panel .status-board-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0.85rem;
  margin-top: 1rem;
}
.status-board-card {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.95rem 1rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: #fff;
  text-decoration: none;
  color: inherit;
  box-shadow: var(--shadow-sm);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.status-board-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.status-board-card-order { font-size: 0.72rem; font-weight: 700; color: var(--muted); }
.status-board-card-label { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: var(--navy); }
.status-board-card-count { font-size: 1.35rem; font-weight: 800; color: var(--navy-soft); }
.status-board-card-hint { font-size: 0.72rem; color: var(--muted); line-height: 1.35; }
.status-board-card.tone-slate { border-left: 4px solid #64748b; }
.status-board-card.tone-amber { border-left: 4px solid #d97706; }
.status-board-card.tone-sky { border-left: 4px solid #0284c7; }
.status-board-card.tone-green { border-left: 4px solid #16a34a; }
.status-board-card.tone-lime { border-left: 4px solid #65a30d; }
.status-board-card.tone-teal { border-left: 4px solid #0d9488; }
.status-board-card.tone-indigo { border-left: 4px solid #4f46e5; }
.status-board-card.tone-violet { border-left: 4px solid #7c3aed; }
.status-board-card.tone-navy { border-left: 4px solid #1e3a8a; }
.status-board-card.tone-orange { border-left: 4px solid #ea580c; }
.status-board-card.tone-red { border-left: 4px solid #dc2626; }
.status-board-search { display: flex; gap: 0.65rem; align-items: end; margin-top: 0.75rem; }
.status-board-archive { margin-top: 1.5rem; }
.status-board-archive h2 { margin: 0 0 0.65rem; font-family: var(--font-display); color: var(--navy); }
.status-board-archive-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 0.75rem; }

/* —— Dashboard Status ABK (index) —— */
.abk-status-dashboard {
  padding: 14px 16px 12px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.2);
  background:
    radial-gradient(ellipse 80% 100% at 100% 0%, rgba(201, 169, 98, 0.14), transparent 52%),
    radial-gradient(ellipse 60% 80% at 0% 100%, rgba(15, 23, 41, 0.05), transparent 50%),
    linear-gradient(180deg, #f7f3eb 0%, #fff 42%, #faf8f5 100%);
  position: relative;
  overflow: visible;
}
.abk-status-dashboard::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--gold-dark) 12%, var(--gold-light) 50%, var(--gold-dark) 88%, transparent 100%);
  pointer-events: none;
}
.abk-status-dashboard::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(201, 169, 98, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201, 169, 98, 0.03) 1px, transparent 1px);
  background-size: 18px 18px;
  pointer-events: none;
  opacity: 0.45;
}
.abk-status-dashboard-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 6px 12px;
  margin-bottom: 10px;
  position: relative;
  z-index: 1;
}
.abk-status-dashboard-eyebrow {
  display: block;
  font-size: 0.56rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold-dark);
}
.abk-status-dashboard-title {
  margin: 2px 0 0;
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--navy);
  line-height: 1.1;
}
.abk-status-dashboard-sub {
  margin: 0;
  font-size: 0.68rem;
  color: var(--muted);
  letter-spacing: 0.04em;
}
.abk-status-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 7px;
  position: relative;
  z-index: 1;
}
.abk-status-dash-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  min-height: 78px;
  min-width: 0;
  padding: 9px 9px 7px;
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.32);
  background:
    radial-gradient(ellipse 120% 80% at 50% 0%, rgba(255, 255, 255, 0.95), transparent 70%),
    linear-gradient(168deg, #fffefb 0%, #f9f5ed 48%, #f3ece0 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 0 0 1px rgba(255, 255, 255, 0.5) inset,
    0 4px 14px rgba(15, 23, 41, 0.08),
    0 1px 3px rgba(201, 169, 98, 0.12);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition:
    transform 0.2s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.2s ease,
    border-color 0.2s ease;
}
.abk-status-dash-card-frame {
  position: absolute;
  inset: 3px;
  border-radius: 7px;
  border: 1px solid rgba(201, 169, 98, 0.14);
  pointer-events: none;
  transition: border-color 0.2s ease;
}
.abk-status-dash-card-gem {
  position: absolute;
  top: 0;
  right: 0;
  width: 18px;
  height: 18px;
  background: linear-gradient(135deg, rgba(232, 213, 163, 0.55) 0%, rgba(201, 169, 98, 0.15) 100%);
  clip-path: polygon(100% 0, 0 0, 100% 100%);
  pointer-events: none;
  opacity: 0.85;
}
.abk-status-dash-card-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(108deg, transparent 42%, rgba(255, 255, 255, 0.65) 50%, transparent 58%);
  transform: translateX(-130%);
  transition: transform 0.5s ease;
  pointer-events: none;
}
.abk-status-dash-card-top {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 4px;
}
.abk-status-dash-card:hover {
  transform: translateY(-2px) scale(1.02);
  border-color: rgba(201, 169, 98, 0.55);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.98) inset,
    0 0 0 1px rgba(201, 169, 98, 0.2),
    0 8px 22px rgba(15, 23, 41, 0.12),
    0 0 16px rgba(201, 169, 98, 0.15);
}
.abk-status-dash-card:hover .abk-status-dash-card-frame {
  border-color: rgba(201, 169, 98, 0.28);
}
.abk-status-dash-card:hover .abk-status-dash-card-shine {
  transform: translateX(130%);
}
.abk-status-dash-card.is-active {
  border-color: var(--gold);
  background:
    radial-gradient(ellipse 100% 90% at 50% 0%, rgba(201, 169, 98, 0.22), transparent 62%),
    linear-gradient(168deg, #121a2e 0%, var(--navy) 45%, #1a2744 100%);
  box-shadow:
    0 0 0 1px rgba(232, 213, 163, 0.35),
    0 0 20px rgba(201, 169, 98, 0.2),
    0 8px 24px rgba(15, 23, 41, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}
.abk-status-dash-card.is-active .abk-status-dash-card-frame {
  border-color: rgba(232, 213, 163, 0.22);
}
.abk-status-dash-card.is-active .abk-status-dash-card-gem {
  background: linear-gradient(135deg, rgba(232, 213, 163, 0.75) 0%, rgba(201, 169, 98, 0.35) 100%);
}
.abk-status-dash-card.is-active .abk-status-dash-card-label {
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}
.abk-status-dash-card.is-active .abk-status-dash-card-unit {
  color: rgba(232, 213, 163, 0.75);
}
.abk-status-dash-card.is-active .abk-status-dash-card-count {
  background: linear-gradient(135deg, #fff8e7 0%, var(--gold-light) 35%, var(--gold) 70%, var(--gold-dark) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.35));
}
.abk-status-dash-card.is-active .abk-status-dash-card-order {
  background: rgba(201, 169, 98, 0.18);
  border-color: rgba(232, 213, 163, 0.4);
  color: var(--gold-light);
}
.abk-status-dash-card-order {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  font-size: 0.52rem;
  font-weight: 800;
  letter-spacing: 0;
  color: var(--gold-dark);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.9) 0%, rgba(243, 236, 224, 0.95) 100%);
  border: 1px solid rgba(201, 169, 98, 0.35);
  box-shadow: 0 1px 2px rgba(15, 23, 41, 0.06);
}
.abk-status-dash-card-order-all {
  font-size: 0.58rem;
  font-weight: 700;
}
.abk-status-dash-card-label {
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.28;
  color: var(--navy);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  max-width: 100%;
  min-height: 2.05em;
  margin-bottom: 5px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  text-shadow: 0 0.5px 0 rgba(255, 255, 255, 0.9);
}
.abk-status-dash-card-foot {
  display: flex;
  align-items: baseline;
  gap: 3px;
  margin-top: auto;
  padding-top: 1px;
  border-top: 1px solid rgba(201, 169, 98, 0.16);
}
.abk-status-dash-card.is-active .abk-status-dash-card-foot {
  border-top-color: rgba(232, 213, 163, 0.2);
}
.abk-status-dash-card-count {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--navy);
}
.abk-status-dash-card-unit {
  font-size: 0.48rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-dark);
  opacity: 0.85;
}
.abk-status-dash-card.is-total {
  background:
    radial-gradient(ellipse 100% 80% at 0% 0%, rgba(201, 169, 98, 0.2), transparent 58%),
    linear-gradient(168deg, #fffefb 0%, #f6f0e4 100%);
}
.abk-status-dash-card.is-total.is-active {
  background:
    radial-gradient(ellipse 100% 90% at 0% 0%, rgba(201, 169, 98, 0.28), transparent 55%),
    linear-gradient(168deg, #121a2e 0%, var(--navy) 100%);
}
.abk-status-dash-card.tone-slate::before,
.abk-status-dash-card.tone-amber::before,
.abk-status-dash-card.tone-sky::before,
.abk-status-dash-card.tone-green::before,
.abk-status-dash-card.tone-lime::before,
.abk-status-dash-card.tone-teal::before,
.abk-status-dash-card.tone-indigo::before,
.abk-status-dash-card.tone-violet::before,
.abk-status-dash-card.tone-navy::before,
.abk-status-dash-card.tone-gold::before {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  top: 0;
  height: 2px;
  border-radius: 0 0 3px 3px;
  pointer-events: none;
}
.abk-status-dash-card.tone-slate::before { background: linear-gradient(90deg, #64748b, #94a3b8); }
.abk-status-dash-card.tone-amber::before { background: linear-gradient(90deg, #b45309, #f59e0b); }
.abk-status-dash-card.tone-sky::before { background: linear-gradient(90deg, #0369a1, #38bdf8); }
.abk-status-dash-card.tone-green::before { background: linear-gradient(90deg, #15803d, #4ade80); }
.abk-status-dash-card.tone-lime::before { background: linear-gradient(90deg, #4d7c0f, #a3e635); }
.abk-status-dash-card.tone-teal::before { background: linear-gradient(90deg, #0f766e, #2dd4bf); }
.abk-status-dash-card.tone-indigo::before { background: linear-gradient(90deg, #4338ca, #818cf8); }
.abk-status-dash-card.tone-violet::before { background: linear-gradient(90deg, #6d28d9, #a78bfa); }
.abk-status-dash-card.tone-navy::before { background: linear-gradient(90deg, #1e3a8a, #60a5fa); }
.abk-status-dash-card.tone-gold::before { background: linear-gradient(90deg, var(--gold-dark), var(--gold-light)); }
.abk-status-dash-card.is-active::before {
  background: linear-gradient(90deg, transparent, var(--gold-light), transparent) !important;
  opacity: 0.9;
}

.abk-status-dashboard-archive {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px dashed rgba(201, 169, 98, 0.35);
  position: relative;
  z-index: 1;
}
.abk-status-dashboard-compact .abk-status-dashboard-cards-row {
  display: flex;
  align-items: stretch;
  gap: 0;
  position: relative;
  z-index: 4;
  overflow: visible;
}
.abk-status-dashboard-compact .abk-status-dashboard-cards {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 7px;
  position: relative;
  z-index: 1;
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  padding-bottom: 2px;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact {
  flex: 1 1 0;
  min-width: 76px;
  max-width: none;
  min-height: 68px;
  padding: 8px 8px 6px;
  border-radius: 9px;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact .abk-status-dash-card-top {
  margin-bottom: 3px;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact .abk-status-dash-card-order {
  width: 16px;
  height: 16px;
  font-size: 0.52rem;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact .abk-status-dash-card-order-all {
  font-size: 0.54rem;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact .abk-status-dash-card-label {
  font-size: 0.62rem;
  line-height: 1.2;
  min-height: auto;
  margin-bottom: 3px;
  letter-spacing: 0.03em;
  -webkit-line-clamp: 2;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact .abk-status-dash-card-foot {
  margin-top: auto;
  padding-top: 3px;
  gap: 3px;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact .abk-status-dash-card-count {
  font-size: 0.98rem;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact .abk-status-dash-card-unit {
  font-size: 0.5rem;
  letter-spacing: 0.08em;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact .abk-status-dash-card-gem {
  width: 14px;
  height: 14px;
}
.abk-status-dashboard-compact .abk-status-dash-card.is-compact:hover {
  transform: translateY(-2px) scale(1.015);
}
.abk-status-dashboard-compact .abk-status-dash-card-archive {
  min-height: 68px;
  max-width: none;
  flex: 1 1 0;
  min-width: 68px;
  border-style: dashed;
  border-color: rgba(201, 169, 98, 0.28);
  background:
    radial-gradient(ellipse 120% 80% at 50% 0%, rgba(255, 255, 255, 0.88), transparent 70%),
    linear-gradient(168deg, #faf8f4 0%, #f3eee4 100%);
}
.abk-status-dash-divider {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  min-width: 16px;
  margin: 0 1px;
  position: relative;
  align-self: stretch;
}
.abk-status-dash-divider::before {
  content: "";
  position: absolute;
  top: 10%;
  bottom: 10%;
  left: 50%;
  transform: translateX(-50%);
  border-left: 1px dashed rgba(201, 169, 98, 0.42);
}
.abk-status-dash-divider span {
  position: relative;
  z-index: 1;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 0.46rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  background: linear-gradient(180deg, #f7f3eb 0%, #fff 50%, #faf8f5 100%);
  padding: 4px 0;
  line-height: 1;
}

/* —— Quick nav icons (topbar — gaya Android) —— */
.abk-dash-quicknav {
  display: inline-flex;
  flex-direction: row;
  align-items: flex-end;
  gap: 2px;
  flex: 0 0 auto;
}
.abk-dash-quicknav-topbar {
  gap: 6px;
  position: relative;
  z-index: 200;
  overflow: visible;
}
.abk-dash-quicknav-topbar .abk-quicknav-item,
.abk-dash-quicknav-topbar .abk-quicknav-item-btn,
.abk-dash-quicknav-topbar .abk-quicknav-dropdown {
  min-width: 64px;
  max-width: 88px;
  gap: 4px;
}
.abk-dash-quicknav-topbar .abk-quicknav-icon-box {
  width: 52px;
  height: 48px;
  border-radius: 13px;
}
.abk-dash-quicknav-topbar .abk-quicknav-glyph {
  font-size: 1.75rem;
}
.abk-dash-quicknav-topbar .abk-quicknav-label {
  font-size: 0.64rem;
}
.abk-quicknav-item {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 3px;
  min-width: 54px;
  max-width: 76px;
  padding: 0 3px 1px;
  text-decoration: none;
  color: inherit;
  flex-shrink: 0;
  transition: opacity 0.15s ease;
}
.abk-quicknav-item:hover,
.abk-quicknav-item:focus-visible {
  text-decoration: none;
  opacity: 0.95;
}
.abk-quicknav-item-btn {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 3px;
  min-width: 54px;
  max-width: 76px;
  padding: 0 3px 1px;
  margin: 0;
  background: none;
  border: none;
  cursor: pointer;
  font: inherit;
  color: inherit;
  flex-shrink: 0;
}
.abk-quicknav-icon-box {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 36px;
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  transition: background 0.15s, border-color 0.15s, transform 0.12s, box-shadow 0.15s;
}
.abk-quicknav-glyph {
  font-size: 1.3rem;
  line-height: 1;
}
.abk-quicknav-label {
  display: block;
  width: 100%;
  font-size: 0.56rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1.15;
  text-align: center;
  color: rgba(255, 255, 255, 0.62);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.abk-quicknav-item-topbar:hover .abk-quicknav-icon-box,
.abk-quicknav-item-topbar:focus-visible .abk-quicknav-icon-box,
.abk-quicknav-item-btn-topbar:hover .abk-quicknav-icon-box,
.abk-quicknav-item-btn-topbar:focus-visible .abk-quicknav-icon-box {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(201, 169, 98, 0.45);
  transform: translateY(-1px);
}
.abk-quicknav-item-topbar:hover .abk-quicknav-label,
.abk-quicknav-item-topbar:focus-visible .abk-quicknav-label,
.abk-quicknav-item-btn-topbar:hover .abk-quicknav-label,
.abk-quicknav-item-btn-topbar:focus-visible .abk-quicknav-label {
  color: rgba(255, 255, 255, 0.92);
}
.abk-quicknav-item-topbar.is-active .abk-quicknav-icon-box,
.abk-quicknav-item-btn-topbar.is-active .abk-quicknav-icon-box,
.abk-quicknav-dropdown-topbar.is-active .abk-quicknav-icon-box {
  border-color: var(--gold);
  background: linear-gradient(168deg, rgba(201, 169, 98, 0.38), rgba(201, 169, 98, 0.12));
  box-shadow: 0 0 0 1px rgba(232, 213, 163, 0.22);
}
.abk-quicknav-item-topbar.is-active .abk-quicknav-label,
.abk-quicknav-item-btn-topbar.is-active .abk-quicknav-label,
.abk-quicknav-dropdown-topbar.is-active .abk-quicknav-label {
  color: var(--gold-light);
  font-weight: 800;
}
.abk-quicknav-dropdown {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
}
.abk-quicknav-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 168px;
  padding: 6px;
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background: linear-gradient(180deg, #fff 0%, var(--cream, #f7f3eb) 100%);
  box-shadow: 0 12px 28px rgba(15, 23, 41, 0.18);
  z-index: 130;
}
.abk-quicknav-dropdown:hover .abk-quicknav-menu,
.abk-quicknav-dropdown:focus-within .abk-quicknav-menu {
  display: block;
}
.abk-quicknav-menu-link {
  display: block;
  padding: 8px 10px;
  border-radius: 7px;
  color: var(--navy) !important;
  font-size: 0.78rem;
  font-weight: 600;
  text-decoration: none;
}
.abk-quicknav-menu-link:hover {
  background: rgba(201, 169, 98, 0.14);
  text-decoration: none;
}
.abk-quicknav-menu-link.is-active {
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.22), rgba(201, 169, 98, 0.08));
  color: var(--gold-dark) !important;
}
.topbar-right-lux {
  overflow: visible;
}
.topbar {
  overflow: visible;
}
.brand-lux-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
  min-width: 0;
  transition: opacity 0.15s;
}
.brand-lux-link:hover {
  text-decoration: none;
  opacity: 0.92;
}
.brand-lux-link:hover strong {
  color: var(--gold-light);
}
.brand-lux-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.brand-lux-text > span {
  display: block;
}
.topbar-logo,
.auth-logo-img,
.app-logo {
  object-fit: contain;
  border-radius: 50%;
  background: #fff;
}
.topbar-logo {
  width: 44px;
  height: 44px;
  padding: 2px;
  flex-shrink: 0;
  box-shadow:
    0 4px 12px rgba(0, 0, 0, 0.28),
    0 0 0 1px rgba(201, 169, 98, 0.35);
}
.auth-logo-img {
  width: 88px;
  height: 88px;
  margin: 0 auto 16px;
  display: block;
  padding: 4px;
  box-shadow:
    0 12px 28px rgba(15, 23, 41, 0.18),
    0 0 0 1px rgba(201, 169, 98, 0.28);
}
.app-logo-fallback {
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--navy-soft) 0%, var(--navy) 100%);
  color: var(--gold-light);
  font-weight: 700;
  letter-spacing: 0.08em;
}

.abk-status-dashboard-archive-title {
  margin: 0 0 8px;
  font-size: 0.56rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}
.abk-status-dashboard-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}
.abk-status-dash-card-archive {
  min-height: 72px;
  border-style: dashed;
  border-color: rgba(201, 169, 98, 0.28);
  background:
    radial-gradient(ellipse 120% 80% at 50% 0%, rgba(255, 255, 255, 0.88), transparent 70%),
    linear-gradient(168deg, #faf8f4 0%, #f3eee4 100%);
}
.abk-status-dash-card-order-archive {
  font-size: 0.58rem;
  letter-spacing: 0.08em;
  opacity: 0.75;
}

@media (max-width: 1280px) {
  .abk-status-dashboard-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  .abk-status-dashboard-compact .abk-status-dash-card.is-compact {
    min-width: 64px;
  }
}
@media (max-width: 720px) {
  .abk-status-dashboard {
    padding: 12px 12px 10px;
  }
  .abk-status-dashboard-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 6px;
  }
  .abk-status-dash-card {
    min-height: 74px;
    padding: 8px 7px 6px;
  }
  .abk-status-dash-card-label {
    font-size: 0.72rem;
    min-height: 1.95em;
  }
  .abk-status-dash-card-count {
    font-size: 0.95rem;
  }
  .abk-status-dashboard-archive-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 480px) {
  .abk-status-dashboard-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* —— Database ABK — tampilan luxe —— */
.page-abk-index {
  animation: abkIndexFade 0.45s ease-out;
}
@keyframes abkIndexFade {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.panel-abk-lux {
  position: relative;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(201, 169, 98, 0.22);
  box-shadow:
    var(--shadow-lg),
    0 0 0 1px rgba(255, 255, 255, 0.6) inset,
    0 1px 0 rgba(201, 169, 98, 0.15);
  background: linear-gradient(180deg, #fff 0%, #fdfbf7 100%);
}
.panel-abk-lux::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--gold-dark) 18%, var(--gold-light) 50%, var(--gold-dark) 82%, transparent 100%);
  z-index: 1;
}

.abk-index-filters-lux {
  flex: 0 0 auto;
  padding: 12px 18px 14px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.12);
  background:
    linear-gradient(180deg, rgba(250, 248, 245, 0.95) 0%, #fff 100%);
  overflow-x: auto;
}
.abk-index-filters-lux .abk-index-filters-grid {
  display: grid;
  grid-template-columns:
    72px
    minmax(128px, 168px)
    minmax(92px, 118px)
    minmax(92px, 118px)
    minmax(92px, 118px)
    max-content;
  align-items: end;
  gap: 8px 10px;
  width: max-content;
  min-width: 100%;
}
.abk-index-filters-lux .abk-index-filters-grid-onboard {
  grid-template-columns:
    72px
    minmax(120px, 160px)
    minmax(96px, 128px)
    minmax(96px, 128px)
    minmax(88px, 110px)
    max-content;
}
.abk-index-filters-lux .abk-index-filters-actions {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  white-space: nowrap;
  padding-bottom: 1px;
  margin-left: auto;
}
.abk-index-filters-lux .btn-add-lux {
  padding: 9px 12px;
  font-size: 0.76rem;
  white-space: nowrap;
}

.panel-toolbar-lux {
  padding: 26px 30px 22px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.18);
  background:
    radial-gradient(ellipse 70% 120% at 100% 0%, rgba(201, 169, 98, 0.1), transparent 55%),
    linear-gradient(135deg, #fff 0%, var(--cream) 62%, rgba(250, 248, 245, 0.9) 100%);
  align-items: center;
}
.panel-eyebrow {
  margin: 0 0 6px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-dark);
}
.panel-toolbar-lux h1 {
  margin: 0;
  font-size: clamp(1.65rem, 2.4vw, 2.15rem);
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.1;
  color: var(--navy);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.8);
}
.panel-stat-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 10px !important;
}
.panel-stat-count {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--navy);
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(201, 169, 98, 0.35);
  box-shadow: var(--shadow-sm);
}

.toolbar-actions-lux {
  gap: 10px;
}
.btn-add-lux {
  padding: 11px 20px;
  border-radius: 10px;
  letter-spacing: 0.04em;
  box-shadow:
    0 4px 14px rgba(168, 134, 58, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);
}
.btn-add-lux:hover {
  box-shadow:
    0 8px 22px rgba(168, 134, 58, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.45);
}
.btn-ghost-lux {
  padding: 11px 18px;
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.45);
  background: rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(4px);
  font-weight: 600;
  letter-spacing: 0.02em;
  box-shadow: var(--shadow-sm);
}
.btn-ghost-lux:hover {
  background: #fff;
  border-color: var(--gold);
  color: var(--gold-dark);
}

.abk-filter-stat {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 72px;
}
.abk-filter-stat-value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  box-sizing: border-box;
  padding: 0 12px;
  border-radius: 10px;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--navy);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(201, 169, 98, 0.35);
  box-shadow: var(--shadow-sm);
  white-space: nowrap;
}
.abk-index-filters-lux .abk-filter-field {
  min-width: 0;
  gap: 5px;
}
.abk-filter-usia-range .abk-filter-usia-range-inputs {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
}
.abk-filter-usia-range .abk-filter-usia-range-inputs select {
  flex: 1 1 0;
  min-width: 0;
  max-width: 88px;
}
.abk-filter-usia-range-sep {
  font-size: 0.82rem;
  color: rgba(15, 23, 42, 0.45);
  flex-shrink: 0;
}
.abk-filter-usia-range-unit {
  font-size: 0.72rem;
  font-weight: 700;
  flex-shrink: 0;
}
.abk-index-filters-lux .abk-filter-search {
  min-width: 0;
}
.abk-index-filters-lux .abk-filter-label {
  font-size: 0.64rem;
  letter-spacing: 0.11em;
  color: var(--gold-dark);
}
.abk-index-filters-lux input,
.abk-index-filters-lux select {
  padding: 9px 11px;
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.22);
  background: linear-gradient(180deg, #fff 0%, #faf8f5 100%);
  font-size: 0.8rem;
  box-shadow:
    inset 0 1px 2px rgba(15, 23, 41, 0.04),
    0 1px 0 rgba(255, 255, 255, 0.8);
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
}

.btn-filter-apply-lux {
  padding: 9px 16px;
  font-size: 0.78rem;
  border-radius: 10px;
  letter-spacing: 0.04em;
  box-shadow: 0 4px 14px rgba(15, 23, 41, 0.18);
}
.abk-index-filters-lux input:focus,
.abk-index-filters-lux select:focus {
  border-color: var(--gold);
  box-shadow:
    0 0 0 3px rgba(201, 169, 98, 0.14),
    inset 0 1px 2px rgba(15, 23, 41, 0.04);
  transform: translateY(-1px);
}
.btn-filter-apply-lux:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(15, 23, 41, 0.22);
}


.table-scroll-lux {
  flex: 1 1 auto;
  padding: 12px 14px 18px;
  overflow-x: auto;
  max-width: 100%;
  background:
    radial-gradient(ellipse 100% 80% at 50% 100%, rgba(201, 169, 98, 0.05), transparent 60%),
    linear-gradient(180deg, #fff 0%, var(--cream-dark) 100%);
}
.panel-abk-lux.panel-table-fit .table-scroll-lux {
  overflow-x: auto;
}

.abk-table-lux {
  border-radius: 14px;
  border: 1px solid rgba(201, 169, 98, 0.15);
  box-shadow: var(--shadow-md);
}
.abk-table-lux thead th {
  padding: 12px 10px;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  font-weight: 700;
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  background: linear-gradient(180deg, var(--navy-mid) 0%, var(--navy) 55%, #0a1020 100%);
  border-bottom: 2px solid var(--gold);
}
.abk-table-lux thead th:first-child { border-radius: 14px 0 0 0; }
.abk-table-lux thead th:last-child { border-radius: 0 14px 0 0; }
.abk-table-lux tbody td {
  padding: 13px 10px;
  font-size: 0.8rem;
  border-color: rgba(232, 228, 220, 0.75);
  transition: background 0.22s ease, box-shadow 0.22s ease;
}
.abk-table-lux tbody tr:nth-child(even) td {
  background: rgba(250, 248, 245, 0.72);
}
.abk-table-lux tbody tr:hover td {
  background: linear-gradient(90deg, rgba(201, 169, 98, 0.1) 0%, rgba(255, 255, 255, 0.95) 38%) !important;
}
.abk-table-lux .row-click:hover td:first-child {
  box-shadow: inset 3px 0 0 var(--gold);
}
.abk-table-lux .no-urut {
  font-size: 0.88rem;
  color: var(--gold-dark);
}
.abk-table-lux .abk-photo-link {
  border: 2px solid rgba(201, 169, 98, 0.55);
  box-shadow: 0 2px 10px rgba(15, 23, 41, 0.12);
}
.abk-table-lux .abk-photo,
.abk-table-lux .abk-photo-empty {
  width: 44px;
  height: 44px;
}
.abk-table-lux .cell-daftar {
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--navy-mid);
}
.abk-table-lux .cell-uniq-id {
  font-size: 0.58rem;
  color: var(--muted);
}
.abk-table-lux .cell-nama-main {
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.3;
  color: var(--navy);
}
.abk-table-lux .cell-nama-nik {
  font-size: 0.68rem;
  margin-top: 2px;
}
.abk-table-lux .crew-status-badge {
  font-size: 0.58rem;
  padding: 0.2rem 0.45rem;
  box-shadow: 0 1px 3px rgba(15, 23, 41, 0.06);
}
.abk-table-lux .cell-marketing .mkt-name {
  font-size: 0.74rem;
  color: var(--navy-mid);
}
.abk-table-lux .xp-tipe-badge {
  font-size: 0.58rem;
  padding: 3px 8px;
  box-shadow: 0 2px 6px rgba(15, 23, 41, 0.15);
}
.abk-table-lux .cell-kapal-item .kapal-name {
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--navy);
}
.abk-table-lux .cell-kapal-more {
  font-size: 0.62rem;
  color: var(--gold-dark);
  font-weight: 600;
}
.abk-table-lux .skill-chip {
  padding: 3px 8px;
  font-size: 0.58rem;
  border: 1px solid rgba(201, 169, 98, 0.22);
  background: linear-gradient(180deg, #fff, var(--cream));
  box-shadow: 0 1px 2px rgba(15, 23, 41, 0.05);
}
.abk-table-lux .btn-edit {
  padding: 6px 12px;
  font-size: 0.68rem;
  border-radius: 999px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.abk-table-lux .empty {
  padding: 48px 24px;
  font-size: 0.92rem;
  font-style: italic;
  background: linear-gradient(180deg, #fff, var(--cream));
}

.page-abk-index .form-panel-lux-flash {
  margin-bottom: 16px;
  border-radius: 12px;
}

.abk-index-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px 16px;
  margin: 0;
  padding: 14px 16px 18px;
  border-top: 1px solid rgba(201, 169, 98, 0.18);
  background: linear-gradient(180deg, rgba(250, 248, 245, 0.92) 0%, #fff 100%);
}

.abk-index-pagination-info {
  margin: 0;
  font-size: 0.84rem;
  color: var(--muted, #64748b);
  line-height: 1.45;
}

.abk-index-pagination-info strong {
  color: var(--navy, #0f172a);
  font-weight: 700;
}

.abk-index-pagination-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.btn-index-page {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 18px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 41, 0.14);
  background: #fff;
  color: var(--navy, #0f172a);
  font: inherit;
  font-size: 0.84rem;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
}

.btn-index-page:hover {
  transform: translateY(-1px);
  border-color: rgba(201, 169, 98, 0.55);
  background: rgba(250, 248, 245, 0.95);
}

.btn-index-page-next {
  background: linear-gradient(180deg, var(--navy-soft, #1e293b) 0%, var(--navy, #0f172a) 100%);
  border-color: var(--navy, #0f172a);
  color: #fff;
}

.btn-index-page-next:hover {
  background: linear-gradient(180deg, #334155 0%, #1e293b 100%);
  color: #fff;
}

.btn-index-page.is-disabled {
  opacity: 0.42;
  pointer-events: none;
  cursor: default;
}

.abk-filter-stat-note {
  display: block;
  margin-top: 4px;
  font-size: 0.72rem;
}

@media (max-width: 768px) {
  .abk-index-pagination {
    flex-direction: column;
    align-items: stretch;
    padding: 12px 12px 16px;
  }

  .abk-index-pagination-actions {
    flex-direction: column;
  }

  .page-abk-index .btn-index-page {
    width: 100%;
    min-height: 44px;
  }
}

@media (max-width: 1200px) {
  .abk-index-filters-lux .abk-index-filters-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .abk-index-filters-lux .abk-filter-stat,
  .abk-index-filters-lux .abk-filter-search {
    grid-column: span 1;
  }
  .abk-index-filters-lux .abk-index-filters-actions {
    grid-column: 1 / -1;
    flex-wrap: wrap;
  }
}

@media (max-width: 900px) {
  .abk-index-filters-lux {
    padding: 14px 16px 16px;
  }
  .abk-index-filters-lux .abk-index-filters-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }
  .abk-index-filters-lux .abk-filter-stat {
    grid-column: 1 / -1;
  }
  .abk-index-filters-lux .abk-filter-field,
  .abk-index-filters-lux .abk-filter-search {
    min-width: 0;
  }
  .abk-index-filters-lux .abk-index-filters-actions {
    grid-column: 1 / -1;
  }
  .table-scroll-lux {
    padding: 6px 8px 12px;
  }
}

@media (max-width: 760px) {
  .crew-status-form { grid-template-columns: 1fr; }
  .crew-status-meta { text-align: left; }
}

.topbar-role-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  margin-left: 8px;
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--gold-dark);
  background: rgba(201, 169, 98, 0.14);
  border: 1px solid rgba(201, 169, 98, 0.35);
  border-radius: 999px;
}
.topnav-pill-admin.is-active {
  background: linear-gradient(180deg, #2a3f6b, var(--navy));
  color: #fff;
}
.users-role-legend {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
  margin: 0 0 18px;
}
.users-perm-fieldset {
  grid-column: 1 / -1;
  margin: 8px 0 0;
  padding: 16px 18px 18px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  border-radius: 14px;
  background: linear-gradient(180deg, #fff, rgba(250, 248, 245, 0.85));
}
.users-perm-fieldset legend {
  padding: 0 8px;
  font-weight: 600;
  color: var(--navy);
}
.users-perm-intro {
  margin: 0 0 14px;
}
.users-preset-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.users-preset-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.users-preset-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.btn-ghost-sm {
  padding: 5px 10px;
  font-size: 0.72rem;
}
.users-perm-all {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(201, 169, 98, 0.12);
  border: 1px solid rgba(201, 169, 98, 0.28);
}
.users-perm-groups {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
}
.users-perm-group-title {
  margin: 0 0 8px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--navy-mid);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.users-perm-checklist {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.users-perm-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: #fff;
  cursor: pointer;
}
.users-perm-item:hover {
  border-color: rgba(201, 169, 98, 0.45);
}
.users-perm-item input {
  margin-top: 3px;
  flex-shrink: 0;
}
.users-perm-item-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.users-perm-item-text strong {
  font-size: 0.82rem;
  color: var(--navy);
}
.users-perm-item-text small {
  font-size: 0.72rem;
  color: var(--muted);
  line-height: 1.35;
}
.users-perm-summary {
  font-size: 0.78rem;
  color: var(--navy-mid);
  max-width: 280px;
}
.users-role-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 12px;
  background: linear-gradient(180deg, #fff, var(--cream));
  border: 1px solid rgba(201, 169, 98, 0.22);
  font-size: 0.78rem;
}
.users-role-card strong {
  color: var(--navy);
  font-size: 0.82rem;
}
.users-role-card span {
  color: var(--muted);
  line-height: 1.45;
}
.users-form .users-active-check {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 28px;
}
.users-self-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 2px 7px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--navy);
  background: rgba(201, 169, 98, 0.2);
  border-radius: 999px;
}
.form-readonly-banner {
  margin-bottom: 14px;
}
.alert.warn {
  background: #fff8e8;
  border: 1px solid rgba(201, 169, 98, 0.45);
  color: #6b5416;
}
.reg-form-readonly input:not([readonly]),
.reg-form-readonly select,
.reg-form-readonly textarea,
.reg-form-readonly button:not(.btn-dock-cancel) {
  pointer-events: none;
}
.reg-form-readonly .doc-upload-card label,
.reg-form-readonly .photo-upload-btn,
.reg-form-readonly .doc-del-btn,
.reg-form-readonly .btn-secondary[id^="btn"],
.reg-section-doc-readonly .doc-upload-card label,
.reg-section-doc-readonly .photo-upload-btn,
.reg-section-doc-readonly .doc-del-btn {
  display: none !important;
}
.reg-form-readonly input,
.reg-form-readonly select,
.reg-form-readonly textarea {
  opacity: 0.88;
  background: #f7f6f3;
}

.interview-field-block {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 10px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 41, 0.1);
  background: rgba(255, 255, 255, 0.72);
}
.interview-under-photo {
  width: 100%;
  box-sizing: border-box;
}
.interview-field-label {
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--navy-mid);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.interview-hasil-select {
  width: 100%;
  max-width: none;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font: inherit;
  font-size: 0.82rem;
  background: #fff;
}
.interview-under-photo .interview-reject-field textarea {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font: inherit;
  font-size: 0.78rem;
  text-transform: none;
  resize: vertical;
  min-height: 72px;
  box-sizing: border-box;
}
.interview-under-photo .interview-upload-field input[type="file"] {
  width: 100%;
  font-size: 0.68rem;
}
.interview-panel {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.interview-upload-field,
.interview-reject-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--navy);
}
.interview-upload-field input[type="file"] {
  font-size: 0.8rem;
  font-weight: 400;
}
.interview-doc-link {
  margin: 0;
  font-size: 0.8rem;
}
.interview-doc-link a {
  color: var(--navy-mid);
  font-weight: 600;
}
.interview-hint {
  margin: 0;
}

.crew-status-force.is-error {
  color: #991b1b;
  padding: 6px 8px;
  border-radius: 8px;
  background: #fee2e2;
  border: 1px solid #fecaca;
}
.crew-status-force.is-error input {
  outline: 2px solid #dc2626;
}

.crew-interview-modal .crew-interview-card {
  max-width: 520px;
  width: 100%;
}
.crew-interview-intro {
  margin: 0 0 14px;
}
.crew-interview-promote-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.interview-panel[hidden],
.crew-interview-empty[hidden] {
  display: none !important;
}
.crew-interview-modal-lux .modal-backdrop {
  backdrop-filter: blur(6px);
}
.crew-interview-modal-lux .crew-interview-card {
  width: min(560px, calc(100vw - 24px));
  max-width: none;
  max-height: min(92vh, 720px);
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(201, 169, 98, 0.22);
  box-shadow: 0 22px 56px rgba(15, 23, 42, 0.18);
}
.crew-interview-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 20px 22px 18px;
  background: linear-gradient(135deg, #f8fafc 0%, #fff 52%, #faf8f5 100%);
  border-bottom: 1px solid rgba(201, 169, 98, 0.16);
  flex-shrink: 0;
}
.crew-interview-hero-main {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  min-width: 0;
}
.crew-interview-hero-icon {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: linear-gradient(145deg, rgba(201, 169, 98, 0.18), #fff);
  border: 1px solid rgba(201, 169, 98, 0.28);
  font-size: 1.35rem;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
}
.crew-interview-hero-text {
  min-width: 0;
}
.crew-interview-eyebrow {
  margin: 0 0 4px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold-dark, #9a7b2f);
}
.crew-interview-hero h2 {
  margin: 0 0 6px;
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 2vw, 1.35rem);
  line-height: 1.25;
  color: var(--navy);
  word-break: break-word;
}
.crew-interview-intro {
  margin: 0;
  font-size: 0.84rem;
  line-height: 1.55;
  color: var(--muted, #64748b);
}
.crew-interview-intro strong {
  color: var(--navy, #0f172a);
}
.crew-interview-close {
  flex: 0 0 auto;
}
.crew-interview-promote-form {
  gap: 0;
  padding: 0;
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.crew-interview-promote-form > .crew-interview-section,
.crew-interview-promote-form > .crew-interview-form-error {
  flex-shrink: 0;
  padding-left: 22px;
  padding-right: 22px;
}
.crew-interview-promote-form > .crew-interview-section {
  padding-top: 18px;
}
.crew-interview-section {
  margin-bottom: 14px;
}
.crew-interview-section-label {
  margin: 0 0 8px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--navy-mid, #334155);
}
.crew-interview-section-label .req,
.crew-interview-field .req {
  color: #b45309;
}
.crew-interview-choice {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.crew-interview-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 46px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1.5px solid rgba(15, 23, 42, 0.1);
  background: #fff;
  color: var(--navy, #0f172a);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}
.crew-interview-pill:hover {
  border-color: rgba(201, 169, 98, 0.45);
  transform: translateY(-1px);
}
.crew-interview-pill.is-active {
  border-color: rgba(22, 163, 74, 0.45);
  background: linear-gradient(180deg, rgba(220, 252, 231, 0.85), #fff);
  box-shadow: 0 4px 14px rgba(22, 163, 74, 0.12);
}
.crew-interview-pill-reject.is-active {
  border-color: rgba(220, 38, 38, 0.35);
  background: linear-gradient(180deg, rgba(254, 226, 226, 0.85), #fff);
  box-shadow: 0 4px 14px rgba(220, 38, 38, 0.1);
}
.crew-interview-pill-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  font-size: 0.72rem;
}
.crew-interview-pill.is-active .crew-interview-pill-icon {
  background: rgba(22, 163, 74, 0.16);
  color: #166534;
}
.crew-interview-pill-reject.is-active .crew-interview-pill-icon {
  background: rgba(220, 38, 38, 0.12);
  color: #991b1b;
}
.crew-interview-select-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}
.crew-interview-body {
  flex: 1 1 auto;
  min-height: 120px;
  max-height: none;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 0 22px 8px;
}
.crew-interview-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 22px 16px;
  border-radius: 12px;
  border: 1px dashed rgba(15, 23, 42, 0.12);
  background: rgba(248, 250, 252, 0.85);
  text-align: center;
}
.crew-interview-empty-icon {
  font-size: 1.4rem;
  opacity: 0.75;
}
.crew-interview-empty p {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.5;
  color: var(--muted, #64748b);
}
.crew-interview-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.92);
}
.crew-interview-panel-accept {
  border-color: rgba(22, 163, 74, 0.16);
  background: linear-gradient(180deg, rgba(240, 253, 244, 0.65), #fff);
}
.crew-interview-panel-reject {
  border-color: rgba(220, 38, 38, 0.14);
  background: linear-gradient(180deg, rgba(254, 242, 242, 0.65), #fff);
}
.crew-interview-panel-head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}
.crew-interview-panel-head p {
  margin: 0;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--muted, #64748b);
}
.crew-interview-panel-badge {
  display: inline-block;
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border: 1px solid transparent;
}
.crew-interview-panel-badge.tone-green {
  background: #dcfce7;
  color: #166534;
  border-color: #bbf7d0;
}
.crew-interview-panel-badge.tone-red {
  background: #fee2e2;
  color: #991b1b;
  border-color: #fecaca;
}
.crew-interview-upload-box {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 16px 14px;
  border-radius: 12px;
  border: 1.5px dashed rgba(201, 169, 98, 0.42);
  background: rgba(255, 255, 255, 0.9);
  text-align: center;
  cursor: pointer;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}
.crew-interview-upload-box:hover,
.crew-interview-upload-box.is-selected {
  border-color: rgba(201, 169, 98, 0.75);
  background: rgba(201, 169, 98, 0.06);
  box-shadow: 0 4px 14px rgba(201, 169, 98, 0.1);
}
.crew-interview-upload-icon {
  font-size: 1.5rem;
}
.crew-interview-upload-copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 0.78rem;
  color: var(--muted, #64748b);
}
.crew-interview-upload-copy strong {
  font-size: 0.82rem;
  color: var(--navy, #0f172a);
}
.crew-interview-upload-name {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--gold-dark, #9a7b2f);
  word-break: break-all;
}
.crew-interview-file-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}
.crew-interview-field {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--navy, #0f172a);
}
.crew-interview-field textarea,
.crew-interview-catatan-field textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 10px;
  font: inherit;
  font-size: 0.84rem;
  line-height: 1.45;
  min-height: 88px;
  resize: vertical;
  box-sizing: border-box;
  text-transform: none;
  background: #fff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.crew-interview-field textarea:focus,
.crew-interview-catatan-field textarea:focus {
  outline: none;
  border-color: rgba(201, 169, 98, 0.65);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.14);
}
.crew-interview-doc-hint {
  margin: 0;
}
.crew-interview-catatan-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 600;
}
.crew-interview-form-error {
  margin: 14px 0 0;
  padding: 10px 12px;
  border-radius: 10px;
  background: #fee2e2;
  color: #991b1b;
  font-size: 0.78rem;
  line-height: 1.45;
  border: 1px solid #fecaca;
}
.crew-interview-form-error[hidden] {
  display: none !important;
}
.crew-interview-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 0;
  padding: 14px 22px 18px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  flex-shrink: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), #fff 24%);
  box-shadow: 0 -8px 20px rgba(15, 23, 42, 0.06);
  position: relative;
  z-index: 2;
}
.crew-interview-actions-hint {
  margin: 0;
  font-size: 0.72rem;
  color: var(--muted, #64748b);
  text-align: center;
  line-height: 1.4;
}
.crew-interview-actions-hint[hidden] {
  display: none !important;
}
.crew-interview-actions-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  align-items: center;
}
.crew-interview-form-error {
  padding-left: 22px;
  padding-right: 22px;
}
.crew-interview-btn-cancel {
  min-width: 96px;
}
.crew-interview-btn-submit {
  min-width: 0;
  flex: 1 1 200px;
  max-width: none;
  min-height: 44px;
  padding: 12px 18px;
  font-size: 0.88rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--navy-soft, #1e293b), var(--navy, #0f172a));
  border: none;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.18);
}
.crew-interview-btn-submit:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}
@media (max-width: 520px) {
  .crew-interview-actions-row {
    flex-direction: column-reverse;
    align-items: stretch;
  }
  .crew-interview-btn-cancel,
  .crew-interview-btn-submit {
    width: 100%;
    max-width: none;
    flex: 1 1 auto;
  }
}
.crew-interview-btn-submit:hover {
  background: linear-gradient(135deg, #334155, #1e293b);
}
.crew-interview-btn-submit.is-reject {
  background: linear-gradient(135deg, #b91c1c, #991b1b);
  box-shadow: 0 4px 14px rgba(185, 28, 28, 0.2);
}
.crew-interview-btn-submit.is-reject:hover {
  background: linear-gradient(135deg, #991b1b, #7f1d1d);
}

/* Database ABK index & Crewlist penempatan — tabel responsif penuh layar */
main.page:has(.page-abk-index),
main.page:has(.page-abk-penempatan) {
  max-width: 100%;
  width: 100%;
  padding-left: clamp(10px, 1.5vw, 22px);
  padding-right: clamp(10px, 1.5vw, 22px);
  padding-top: clamp(12px, 1.2vw, 22px);
}

.page-abk-index,
.page-abk-penempatan {
  width: 100%;
  max-width: 100%;
}

.page-abk-index .panel-abk-lux,
.page-abk-penempatan .panel-abk-lux {
  width: 100%;
  max-width: 100%;
}

.page-abk-index .table-scroll-fluid,
.page-abk-penempatan .table-scroll-fluid {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: clamp(10px, 1.1vw, 16px) clamp(8px, 1vw, 14px) clamp(14px, 1.2vw, 18px);
}

.page-abk-index .abk-table-fluid,
.page-abk-penempatan .abk-table-fluid {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}

.page-abk-index .abk-table-fluid thead th,
.page-abk-penempatan .abk-table-fluid thead th {
  padding: clamp(10px, 0.9vw, 14px) clamp(7px, 0.75vw, 12px);
  font-size: clamp(0.75rem, 0.32vw + 0.64rem, 0.95rem);
  letter-spacing: 0.06em;
  line-height: 1.35;
  word-break: break-word;
  hyphens: auto;
}

.page-abk-index .abk-table-fluid tbody td,
.page-abk-penempatan .abk-table-fluid tbody td {
  padding: clamp(10px, 0.9vw, 14px) clamp(7px, 0.75vw, 12px);
  font-size: clamp(0.84rem, 0.38vw + 0.7rem, 1.02rem);
  line-height: 1.45;
  overflow: visible;
  word-wrap: break-word;
  word-break: break-word;
}

.page-abk-index .abk-table-fluid .col-no,
.page-abk-penempatan .abk-table-fluid .col-no { width: 4%; }
.page-abk-index .abk-table-fluid .col-daftar-foto { width: 8%; }
.page-abk-index .abk-table-fluid .col-usia { width: 5%; min-width: 52px; }
.page-abk-index .abk-table-fluid .col-nama,
.page-abk-penempatan .abk-table-fluid .col-nama { width: 17%; }
.page-abk-index .abk-table-fluid .col-status,
.page-abk-penempatan .abk-table-fluid .col-status { width: 9%; }
.page-abk-index .abk-table-fluid .col-marketing,
.page-abk-penempatan .abk-table-fluid .col-marketing { width: 10%; }
.page-abk-index .abk-table-fluid .col-xp { width: 8%; }
.page-abk-index .abk-table-fluid .col-kapal,
.page-abk-penempatan .abk-table-fluid .col-kapal { width: 14%; }
.page-abk-index .abk-table-fluid .col-jabatan { width: 9%; }
.page-abk-index .abk-table-fluid .col-skill { width: 12%; }
.page-abk-index .abk-table-fluid .col-aksi,
.page-abk-penempatan .abk-table-fluid .col-aksi { width: 7%; }
.page-abk-index .abk-table-fluid .col-stage-focus { width: 11%; min-width: 96px; }
.page-abk-index .abk-table-fluid .col-aksi-list { width: 10%; min-width: 118px; }

.abk-list-aksi-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
  min-width: 0;
}

.btn-list-aksi {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid rgba(15, 23, 41, 0.14);
  background: #fff;
  color: var(--navy, #0f172a);
  font: inherit;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-decoration: none;
  text-transform: uppercase;
  line-height: 1.2;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
}

.btn-list-aksi:hover {
  transform: translateY(-1px);
  border-color: rgba(201, 169, 98, 0.55);
}

.btn-list-aksi-primary {
  background: linear-gradient(180deg, var(--navy-soft, #1e293b) 0%, var(--navy, #0f172a) 100%);
  border-color: var(--navy, #0f172a);
  color: #fff;
}

.btn-list-aksi-primary:hover {
  background: linear-gradient(180deg, #334155 0%, #1e293b 100%);
  color: #fff;
}

.btn-list-aksi-accent {
  background: rgba(201, 169, 98, 0.14);
  border-color: rgba(201, 169, 98, 0.45);
  color: #7c5a12;
}

.btn-list-aksi-secondary {
  background: rgba(248, 250, 252, 0.95);
}

.btn-list-aksi-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--muted, #64748b);
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
}

.btn-list-aksi-ghost:hover {
  background: rgba(15, 23, 41, 0.04);
  border-color: transparent;
  color: var(--navy, #0f172a);
}

.abk-list-focus-cell {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  min-width: 0;
}

.abk-list-focus-cell .crew-status-pct-badge {
  transform: scale(0.92);
  transform-origin: top left;
}

.abk-list-focus-note {
  margin: 0;
  font-size: 0.68rem;
  line-height: 1.35;
  color: var(--muted, #64748b);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}

.abk-list-focus-muted {
  font-size: 0.72rem;
  color: var(--muted, #64748b);
}

.abk-list-focus-badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
}

.abk-list-focus-badge.tone-green {
  background: #dcfce7;
  color: #166534;
  border-color: #bbf7d0;
}

.abk-list-focus-badge.tone-red {
  background: #fee2e2;
  color: #991b1b;
  border-color: #fecaca;
}

.abk-list-focus-batch {
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--navy, #0f172a);
  text-decoration: none;
}

.abk-list-focus-batch:hover {
  color: var(--gold-dark, #9a7b2f);
  text-decoration: underline;
}

.abk-list-focus-sep {
  opacity: 0.55;
}

.page-abk-penempatan .abk-table-fluid .col-uniq { width: 8%; }
.page-abk-penempatan .abk-table-fluid .col-nama { width: 15%; }
.page-abk-penempatan .abk-table-fluid .col-status { width: 8%; }
.page-abk-penempatan .abk-table-fluid .col-marketing { width: 9%; }
.page-abk-penempatan .abk-table-fluid .col-agency { width: 14%; }
.page-abk-penempatan .abk-table-fluid .col-kapal { width: 15%; }
.page-abk-penempatan .abk-table-fluid .col-aksi { width: 7%; }

.page-abk-index .abk-table-fluid .abk-photo,
.page-abk-penempatan .abk-table-fluid .abk-photo,
.page-abk-index .abk-table-fluid .abk-photo-empty,
.page-abk-penempatan .abk-table-fluid .abk-photo-empty {
  width: clamp(42px, 3.8vw, 58px);
  height: clamp(42px, 3.8vw, 58px);
}

.page-abk-index .abk-table-fluid .cell-daftar-foto {
  gap: clamp(3px, 0.4vw, 6px);
}

.page-abk-index .abk-table-fluid .cell-daftar {
  font-size: clamp(0.74rem, 0.28vw + 0.64rem, 0.9rem);
}

.page-abk-index .abk-table-fluid .cell-uniq-id,
.page-abk-penempatan .abk-table-fluid .cell-uniq-id {
  font-size: clamp(0.66rem, 0.22vw + 0.56rem, 0.8rem);
}

.page-abk-index .abk-table-fluid .cell-nama-main,
.page-abk-penempatan .abk-table-fluid .cell-nama-main {
  font-size: clamp(0.9rem, 0.45vw + 0.76rem, 1.1rem);
  font-weight: 600;
  line-height: 1.35;
  display: block;
  overflow: visible;
  -webkit-line-clamp: unset;
  margin-bottom: 3px;
}

.page-abk-index .abk-table-fluid .cell-usia-val {
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--navy, #0f172a);
  white-space: nowrap;
}
.page-abk-index .abk-table-fluid .cell-nama-nik {
  font-size: clamp(0.74rem, 0.28vw + 0.64rem, 0.9rem);
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
}

.page-abk-index .abk-table-fluid .cell-meta {
  display: block;
  font-size: clamp(0.7rem, 0.24vw + 0.6rem, 0.84rem);
  margin-top: 2px;
}

.page-abk-index .abk-table-fluid .crew-status-badge,
.page-abk-penempatan .abk-table-fluid .crew-status-badge {
  font-size: clamp(0.66rem, 0.26vw + 0.56rem, 0.82rem);
  padding: 0.22em 0.48em;
  max-width: 100%;
  white-space: normal;
  line-height: 1.3;
}

.page-abk-index .abk-table-fluid .cell-marketing .mkt-name,
.page-abk-penempatan .abk-table-fluid .cell-marketing .mkt-name {
  font-size: clamp(0.8rem, 0.32vw + 0.68rem, 0.96rem);
  line-height: 1.35;
}

.page-abk-index .abk-table-fluid .xp-tipe-badge {
  font-size: clamp(0.66rem, 0.26vw + 0.56rem, 0.82rem);
  padding: 3px 8px;
}

.page-abk-index .abk-table-fluid .cell-kapal-item .kapal-name {
  font-size: clamp(0.8rem, 0.32vw + 0.68rem, 0.96rem);
  line-height: 1.35;
}

.page-abk-index .abk-table-fluid .cell-kapal-item div:not(.kapal-name) {
  display: block;
  font-size: clamp(0.68rem, 0.22vw + 0.58rem, 0.8rem);
  color: var(--muted);
  margin-top: 1px;
}

.page-abk-index .abk-table-fluid .cell-kapal-item + .cell-kapal-item {
  display: block;
  padding-top: 4px;
  margin-top: 4px;
  border-top: 1px solid var(--line-soft);
}

.page-abk-index .abk-table-fluid .cell-kapal-more {
  font-size: clamp(0.68rem, 0.22vw + 0.58rem, 0.82rem);
}

.page-abk-index .abk-table-fluid .skill-chip {
  font-size: clamp(0.66rem, 0.24vw + 0.56rem, 0.8rem);
  padding: 0.22em 0.5em;
}

.page-abk-index .abk-table-fluid .btn-edit,
.page-abk-penempatan .abk-table-fluid .btn-edit {
  font-size: clamp(0.74rem, 0.28vw + 0.64rem, 0.9rem);
  padding: clamp(6px, 0.55vw, 9px) clamp(10px, 0.85vw, 14px);
}

.page-abk-index .abk-table-fluid .no-urut,
.page-abk-penempatan .abk-table-fluid .no-urut {
  font-size: clamp(0.88rem, 0.38vw + 0.74rem, 1.05rem);
}

.page-abk-index .abk-table-fluid .empty,
.page-abk-penempatan .abk-table-fluid .empty {
  font-size: clamp(0.88rem, 0.35vw + 0.72rem, 1rem);
}

@media (max-width: 900px) and (min-width: 769px) {
  .page-abk-index .abk-table-fluid,
  .page-abk-penempatan .abk-table-fluid {
    min-width: 720px;
  }
}

/* Daftar ABK — kartu per baris di HP (scoped: tidak mengubah desktop/tablet) */
@media (max-width: 768px) {
  .page-abk-index .table-scroll-fluid {
    overflow-x: visible;
    padding: 8px 10px 16px;
  }

  .page-abk-index .abk-table-fluid {
    display: block;
    width: 100%;
    min-width: 0;
    table-layout: auto;
    border: none;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
  }

  /* Lepas lebar kolom persen desktop — penyebab sel ~10% layar & teks vertikal */
  .page-abk-index .abk-table-fluid th[class*="col-"],
  .page-abk-index .abk-table-fluid td[class*="col-"] {
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  .page-abk-index .abk-table-fluid thead {
    display: none;
  }

  .page-abk-index .abk-table-fluid tbody {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .page-abk-index .abk-table-fluid tbody tr {
    display: block;
    width: 100%;
    background: #fff;
    border: 1px solid rgba(201, 169, 98, 0.24);
    border-radius: 14px;
    box-shadow: 0 4px 18px rgba(15, 23, 41, 0.08);
    overflow: hidden;
  }

  .page-abk-index .abk-table-fluid tbody tr:nth-child(even) td {
    background: transparent;
  }

  .page-abk-index .abk-table-fluid tbody tr:hover td {
    background: transparent !important;
  }

  .page-abk-index .abk-table-fluid tbody td {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 5px;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    padding: 10px 14px;
    border-bottom: 1px solid rgba(232, 228, 220, 0.65);
    font-size: 0.9rem;
    line-height: 1.45;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
    text-align: left !important;
  }

  .page-abk-index .abk-table-fluid tbody td::before {
    content: attr(data-label);
    display: block;
    font-size: 0.66rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--muted, #64748b);
    line-height: 1.35;
  }

  .page-abk-index .abk-table-fluid tbody td > * {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  .page-abk-index .abk-table-fluid tbody td.col-no {
    display: none;
  }

  .page-abk-index .abk-table-fluid tbody td.col-daftar-foto {
    gap: 10px;
    padding: 14px 14px 10px;
    background: linear-gradient(180deg, rgba(250, 248, 245, 0.95) 0%, #fff 100%);
    border-bottom: 1px solid rgba(201, 169, 98, 0.18);
  }

  .page-abk-index .abk-table-fluid tbody td.col-daftar-foto::before {
    display: none;
  }

  .page-abk-index .abk-table-fluid .cell-daftar-foto {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    grid-template-rows: auto auto;
    column-gap: 12px;
    row-gap: 4px;
    align-items: center;
    width: 100%;
  }

  .page-abk-index .abk-table-fluid .cell-daftar-foto .abk-photo-link,
  .page-abk-index .abk-table-fluid .cell-daftar-foto > .abk-photo-empty {
    grid-row: 1 / -1;
  }

  .page-abk-index .abk-table-fluid .cell-daftar-foto .abk-photo,
  .page-abk-index .abk-table-fluid .cell-daftar-foto .abk-photo-empty {
    width: 52px;
    height: 52px;
    flex-shrink: 0;
  }

  .page-abk-index .abk-table-fluid .cell-daftar-foto .cell-daftar {
    font-size: 0.82rem;
  }

  .page-abk-index .abk-table-fluid .cell-daftar-foto .cell-uniq-id {
    font-size: 0.72rem;
    margin-top: 2px;
    word-break: break-all;
  }

  .page-abk-index .abk-table-fluid tbody td.col-nama {
    padding-top: 0;
    border-bottom: 1px solid rgba(201, 169, 98, 0.14);
  }

  .page-abk-index .abk-table-fluid tbody td.col-nama::before {
    display: none;
  }

  .page-abk-index .abk-table-fluid tbody td.col-nama .cell-nama-main {
    font-size: 1.05rem;
    line-height: 1.35;
    letter-spacing: 0.01em;
    word-break: normal;
  }

  .page-abk-index .abk-table-fluid tbody td.col-nama .cell-nama-nik {
    font-size: 0.78rem;
    margin-top: 4px;
    word-break: break-all;
  }

  .page-abk-index .abk-table-fluid tbody td.col-status .crew-status-badge {
    font-size: 0.72rem;
    padding: 0.28rem 0.55rem;
    white-space: nowrap;
    align-self: flex-start;
  }

  .page-abk-index .abk-table-fluid tbody td.col-marketing .mkt-name,
  .page-abk-index .abk-table-fluid tbody td.col-kapal .kapal-name,
  .page-abk-index .abk-table-fluid tbody td.col-kapal .cell-kapal-item .kapal-name {
    font-size: 0.92rem;
    line-height: 1.4;
    word-break: normal;
  }

  .page-abk-index .abk-table-fluid tbody td.col-aksi-list {
    padding: 12px 14px 14px;
    background: rgba(250, 248, 245, 0.85);
    border-bottom: none;
  }

  .page-abk-index .abk-table-fluid tbody td.col-aksi-list::before {
    margin-bottom: 6px;
  }

  .page-abk-index .abk-table-fluid tbody td.empty {
    padding: 24px 16px;
    text-align: center;
    border-bottom: none;
  }

  .page-abk-index .abk-table-fluid tbody td.empty::before {
    display: none;
  }

  .page-abk-index .abk-list-aksi-group {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
    width: 100%;
  }

  .page-abk-index .btn-list-aksi {
    flex: 1 1 calc(50% - 4px);
    min-height: 44px;
    padding: 10px 12px;
    font-size: 0.74rem;
    width: auto;
  }

  .page-abk-index .btn-list-aksi-primary {
    flex: 1 1 100%;
  }

  .page-abk-index .abk-index-filters-lux .abk-index-filters-grid {
    grid-template-columns: 1fr;
  }

  .page-abk-index .abk-index-filters-lux .abk-index-filters-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .page-abk-index .abk-index-filters-lux .abk-index-filters-actions .btn-add-lux,
  .page-abk-index .abk-index-filters-lux .abk-index-filters-actions .btn-filter-apply-lux {
    width: 100%;
    justify-content: center;
    min-height: 44px;
  }
}

/* Form ABK (edit / tambah) — responsif penuh layar */
main.page:has(.page-abk-form) {
  max-width: 100%;
  width: 100%;
  padding-left: clamp(10px, 1.5vw, 22px);
  padding-right: clamp(10px, 1.5vw, 22px);
  padding-top: clamp(12px, 1.2vw, 22px);
}

.page-abk-form {
  width: 100%;
  max-width: 100%;
}

.page-abk-form .form-head {
  padding: clamp(20px, 2vw, 32px) clamp(18px, 2.2vw, 36px) clamp(18px, 1.8vw, 26px);
}

.page-abk-form .form-head h1 {
  font-size: clamp(1.65rem, 1.2vw + 1.4rem, 2.25rem);
}

.page-abk-form .form-subtitle,
.page-abk-form .link-back {
  font-size: clamp(0.84rem, 0.35vw + 0.72rem, 1rem);
}

.page-abk-form .reg-form-lux {
  padding: clamp(18px, 1.8vw, 32px);
  padding-right: clamp(18px, 1.8vw, 32px);
  font-size: clamp(0.9rem, 0.35vw + 0.78rem, 1.05rem);
}

.page-abk-form .reg-section {
  padding: 0 clamp(16px, 1.6vw, 28px) clamp(18px, 1.6vw, 28px);
  margin-bottom: clamp(16px, 1.4vw, 24px);
}

.page-abk-form .reg-section legend {
  font-size: clamp(1.05rem, 0.55vw + 0.92rem, 1.35rem);
}

.page-abk-form .reg-data-layout {
  grid-template-columns: minmax(220px, clamp(220px, 16vw, 300px)) minmax(0, 1fr);
  gap: clamp(14px, 1.4vw, 24px) clamp(16px, 1.6vw, 28px);
}

.page-abk-form .photo-field-compact .photo-preview-wrap {
  width: clamp(88px, 7vw, 120px);
  height: clamp(88px, 7vw, 120px);
}

.page-abk-form .photo-upload-btn-compact {
  font-size: clamp(0.72rem, 0.28vw + 0.62rem, 0.88rem) !important;
  padding: clamp(8px, 0.6vw, 10px) clamp(8px, 0.8vw, 12px) !important;
}

.page-abk-form .reg-grid-compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(10px, 1vw, 16px) clamp(12px, 1.2vw, 20px);
}

.page-abk-form .reg-grid-compact label {
  font-size: clamp(0.74rem, 0.28vw + 0.64rem, 0.92rem);
  gap: clamp(4px, 0.4vw, 7px);
}

.page-abk-form .reg-grid-compact input,
.page-abk-form .reg-grid-compact select,
.page-abk-form .reg-grid-compact textarea {
  padding: clamp(9px, 0.7vw, 12px) clamp(10px, 0.85vw, 14px);
  font-size: clamp(0.88rem, 0.35vw + 0.76rem, 1.05rem);
  border-radius: clamp(8px, 0.6vw, 10px);
}

.page-abk-form .reg-grid-compact textarea {
  min-height: clamp(64px, 5vw, 88px);
}

.page-abk-form .hint-compact {
  font-size: clamp(0.68rem, 0.22vw + 0.58rem, 0.82rem) !important;
}

.page-abk-form .reg-grid label {
  font-size: clamp(0.78rem, 0.28vw + 0.66rem, 0.92rem);
}

.page-abk-form .reg-grid input,
.page-abk-form .reg-grid select,
.page-abk-form .reg-grid textarea {
  padding: clamp(10px, 0.75vw, 13px) clamp(12px, 0.9vw, 16px);
  font-size: clamp(0.92rem, 0.38vw + 0.8rem, 1.08rem);
}

.page-abk-form .hint {
  font-size: clamp(0.78rem, 0.28vw + 0.66rem, 0.92rem);
}

.page-abk-form .doc-pelaut-title {
  font-size: clamp(0.95rem, 0.4vw + 0.82rem, 1.12rem);
}

.page-abk-form .doc-pelaut-desc,
.page-abk-form .doc-field {
  font-size: clamp(0.72rem, 0.24vw + 0.62rem, 0.86rem);
}

.page-abk-form .doc-pelaut-meta-field {
  font-size: clamp(0.76rem, 0.26vw + 0.66rem, 0.9rem);
}

.page-abk-form .doc-pelaut-meta-field input,
.page-abk-form .doc-pelaut-meta-field select {
  font-size: clamp(0.88rem, 0.32vw + 0.76rem, 1rem);
}

.page-abk-form .crew-status-panel-lux .crew-status-hint {
  font-size: clamp(0.82rem, 0.3vw + 0.72rem, 0.96rem);
}

.page-abk-form .crew-status-panel-lux .crew-status-badge {
  font-size: clamp(0.68rem, 0.24vw + 0.58rem, 0.82rem);
}

.page-abk-form .form-action-dock {
  width: clamp(158px, 11vw, 188px);
  bottom: clamp(56px, 5vw, 72px);
  right: clamp(10px, 1.2vw, 18px);
}

.page-abk-form .form-action-dock .btn-primary,
.page-abk-form .form-action-dock .btn-ghost,
.page-abk-form .form-action-dock .btn-dock-deactivate,
.page-abk-form .form-action-dock .btn-dock-print,
.page-abk-form .form-action-dock .btn-dock-reactivate {
  font-size: clamp(0.72rem, 0.28vw + 0.62rem, 0.88rem);
  padding: clamp(8px, 0.65vw, 11px) clamp(10px, 0.85vw, 14px);
}

.page-abk-form .form-dock-nav-eyebrow {
  font-size: clamp(0.62rem, 0.2vw + 0.54rem, 0.74rem);
}

.page-abk-form .form-dock-nav-step {
  font-size: clamp(0.68rem, 0.22vw + 0.58rem, 0.8rem);
}

.page-abk-form .form-dock-nav-title {
  font-size: clamp(0.82rem, 0.32vw + 0.7rem, 0.98rem);
}

.page-abk-form .btn-dock-nav {
  font-size: clamp(0.68rem, 0.24vw + 0.58rem, 0.82rem);
  padding: clamp(8px, 0.65vw, 10px) clamp(9px, 0.75vw, 12px);
}

@media (min-width: 1400px) {
  .page-abk-form .reg-grid-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .page-abk-form .reg-grid-compact label.full {
    grid-column: 1 / -1;
  }
}

@media (max-width: 768px) {
  .page-abk-form .reg-form-lux {
    padding-bottom: clamp(100px, 18vw, 140px);
  }
}

/* Dock aksi form — mode ikon + tooltip hover */
.form-action-dock-icons {
  width: auto;
  min-width: 0;
  padding: 8px 8px 10px;
  gap: 8px;
  align-items: stretch;
  overflow: visible;
}

.form-action-dock-icons > .btn-dock-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  min-width: 46px;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 11px;
  text-decoration: none;
  flex: 0 0 auto;
}

.form-action-dock-icons .dock-icon {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  pointer-events: none;
}

.form-action-dock-icons .btn-dock-icon[data-dock-tip]::after {
  content: attr(data-dock-tip);
  position: absolute;
  right: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%) translateX(6px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  white-space: nowrap;
  max-width: min(240px, 50vw);
  padding: 8px 12px;
  border-radius: 9px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.3;
  text-transform: none;
  color: #fff;
  background: linear-gradient(135deg, var(--navy-soft) 0%, var(--navy) 100%);
  border: 1px solid rgba(201, 169, 98, 0.4);
  box-shadow: 0 8px 24px rgba(15, 23, 41, 0.22);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s;
  z-index: 960;
}

.form-action-dock-icons .btn-dock-icon[data-dock-tip]::before {
  content: "";
  position: absolute;
  right: calc(100% + 2px);
  top: 50%;
  transform: translateY(-50%);
  border: 7px solid transparent;
  border-left-color: var(--navy);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.18s ease, visibility 0.18s;
  z-index: 960;
}

.form-action-dock-icons .btn-dock-icon:hover::after,
.form-action-dock-icons .btn-dock-icon:focus-visible::after {
  opacity: 1;
  visibility: visible;
  transform: translateY(-50%) translateX(0);
}

.form-action-dock-icons .btn-dock-icon:hover::before,
.form-action-dock-icons .btn-dock-icon:focus-visible::before {
  opacity: 1;
  visibility: visible;
}

.page-abk-form .form-action-dock-icons {
  width: auto;
  right: clamp(10px, 1.2vw, 18px);
}

.page-abk-form .form-action-dock-icons > .btn-dock-icon {
  width: clamp(44px, 3.5vw, 50px);
  height: clamp(44px, 3.5vw, 50px);
  min-width: clamp(44px, 3.5vw, 50px);
}

@media (max-width: 768px) {
  .form-action-dock-icons .btn-dock-icon[data-dock-tip]::after {
    right: auto;
    left: 50%;
    top: auto;
    bottom: calc(100% + 10px);
    transform: translateX(-50%) translateY(4px);
    white-space: normal;
    text-align: center;
  }

  .form-action-dock-icons .btn-dock-icon[data-dock-tip]::before {
    right: auto;
    left: 50%;
    top: auto;
    bottom: calc(100% + 0px);
    transform: translateX(-50%);
    border: 7px solid transparent;
    border-top-color: var(--navy);
    border-left-color: transparent;
  }

  .form-action-dock-icons .btn-dock-icon:hover::after,
  .form-action-dock-icons .btn-dock-icon:focus-visible::after {
    transform: translateX(-50%) translateY(0);
  }
}

/* Crewlist / Penempatan */
.page-abk-penempatan {
  animation: abkIndexFade 0.45s ease-out;
}

.panel-penempatan .penempatan-panel-head {
  padding: clamp(14px, 1.4vw, 22px) clamp(14px, 1.6vw, 24px) clamp(10px, 1vw, 16px);
  border-bottom: 1px solid rgba(201, 169, 98, 0.12);
  background: linear-gradient(180deg, rgba(250, 248, 245, 0.95) 0%, #fff 100%);
}

.panel-penempatan .panel-toolbar {
  padding: 0 0 clamp(12px, 1vw, 16px);
  border-bottom: none;
  background: transparent;
  align-items: center;
}

.panel-penempatan .panel-toolbar h1 {
  font-size: clamp(1.25rem, 0.8vw + 1.05rem, 1.65rem);
}

.panel-penempatan .panel-toolbar .muted {
  font-size: clamp(0.82rem, 0.3vw + 0.72rem, 0.95rem);
}

.panel-penempatan .alert {
  margin-bottom: 12px;
}

.penempatan-status-chips {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(6px, 0.6vw, 8px);
  margin: 0 0 clamp(10px, 1vw, 14px);
}
.penempatan-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: #fff;
  color: var(--ink, #0f172a);
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
  transition: border-color 0.15s, background 0.15s;
}
.penempatan-chip:hover {
  border-color: rgba(15, 23, 42, 0.22);
  background: #f8fafc;
}
.penempatan-chip.is-active {
  border-color: var(--gold, #b8860b);
  background: rgba(184, 134, 11, 0.08);
}
.penempatan-chip-count {
  display: inline-flex;
  min-width: 1.4em;
  justify-content: center;
  padding: 1px 6px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.06);
  font-size: 0.78rem;
}
.penempatan-filters {
  margin-bottom: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  gap: 8px 10px;
}

.penempatan-filters .abk-filter-search {
  flex: 1 1 min(100%, 280px);
  min-width: 0;
}

.page-abk-penempatan .table-scroll-fluid {
  max-width: 100%;
  box-sizing: border-box;
}

.page-abk-penempatan .penempatan-table {
  max-width: 100%;
}
.page-penempatan-edit .form-head-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}
.page-penempatan-edit .btn-ghost-sm {
  font-size: 0.82rem;
  padding: 6px 10px;
}
.reg-section-penempatan {
  margin-top: 12px;
}
.penempatan-form-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  margin: 8px 0 24px;
}
.form-action-dock-icons .btn-dock-penempatan {
  color: #0f766e;
  border-color: rgba(15, 118, 110, 0.25);
  background: rgba(15, 118, 110, 0.06);
}
.form-action-dock-icons .btn-dock-penempatan:hover {
  background: rgba(15, 118, 110, 0.12);
}

.penempatan-toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  flex: 0 0 auto;
}

.penempatan-toolbar-actions .btn-penempatan-add {
  width: auto;
  flex: 0 0 auto;
  padding: 9px 16px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border-radius: 999px;
  white-space: nowrap;
  gap: 5px;
  line-height: 1.2;
  box-shadow:
    0 3px 10px rgba(168, 134, 58, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);
}

.penempatan-toolbar-actions .btn-penempatan-add:hover {
  transform: translateY(-1px);
  box-shadow:
    0 6px 16px rgba(168, 134, 58, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.penempatan-toolbar-actions .btn-penempatan-add .btn-plus {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.15em;
  height: 1.15em;
  border-radius: 50%;
  background: rgba(15, 23, 42, 0.12);
  font-size: 0.95em;
  font-weight: 800;
  line-height: 1;
}

.penempatan-toolbar-actions .btn-ghost {
  padding: 8px 14px;
  font-size: 0.82rem;
  border-radius: 999px;
  white-space: nowrap;
}

.penempatan-crewlist-history {
  padding: clamp(14px, 1.4vw, 22px) clamp(14px, 1.6vw, 24px) clamp(8px, 1vw, 14px);
}

.penempatan-crewlist-archive {
  padding: clamp(8px, 1vw, 14px) clamp(14px, 1.6vw, 24px) clamp(14px, 1.4vw, 22px);
  border-top: 1px solid rgba(15, 23, 41, 0.06);
  background: linear-gradient(180deg, rgba(224, 242, 254, 0.22) 0%, transparent 120px);
}

.penempatan-crewlist-archive[hidden] {
  display: none !important;
}

.btn-penempatan-history-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-color: rgba(14, 165, 233, 0.35);
  color: #0369a1;
}

.btn-penempatan-history-toggle:hover {
  background: rgba(224, 242, 254, 0.55);
  border-color: rgba(14, 165, 233, 0.5);
}

.btn-penempatan-history-toggle.is-open {
  background: rgba(224, 242, 254, 0.65);
  border-color: rgba(14, 165, 233, 0.55);
  color: #0c4a6e;
}

.penempatan-history-toggle-count {
  font-size: 0.88em;
  opacity: 0.85;
}

.penempatan-crewlist-archive-empty {
  margin: 0 0 4px;
  padding: 14px 16px;
  border-radius: 10px;
  border: 1px dashed rgba(14, 165, 233, 0.35);
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted, #64748b);
  font-size: 0.92rem;
}

.penempatan-crewlist-archive-table tbody tr {
  background: rgba(255, 255, 255, 0.55);
}

.penempatan-crewlist-archive-table tbody tr:hover {
  background: rgba(224, 242, 254, 0.35);
}

.page-abk-penempatan .penempatan-crewlist-archive-table .col-signon,
.page-abk-penempatan .penempatan-crewlist-archive-table .col-terbang,
.page-abk-penempatan .penempatan-crewlist-archive-table .col-selesai {
  width: 9%;
  white-space: nowrap;
}

.page-abk-penempatan .penempatan-crewlist-archive-table .col-aksi-crewlist {
  width: 14%;
  min-width: 140px;
}

.penempatan-ready-section {
  padding: 0 clamp(14px, 1.6vw, 24px) clamp(14px, 1.4vw, 22px);
}

.penempatan-section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 10px 16px;
  margin-bottom: 12px;
}

.penempatan-section-head h2,
.penempatan-ready-head h2 {
  margin: 0 0 4px;
  font-size: clamp(1rem, 0.4vw + 0.92rem, 1.2rem);
  color: var(--ink, #0f172a);
}

.penempatan-section-head .muted,
.penempatan-ready-head .muted {
  margin: 0;
  font-size: 0.84rem;
}

.penempatan-section-count {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.08);
  color: #0f766e;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
}

.penempatan-section-divider {
  height: 1px;
  margin: 0 clamp(14px, 1.6vw, 24px);
  background: linear-gradient(90deg, transparent, rgba(201, 169, 98, 0.35), transparent);
}

.penempatan-ready-head {
  margin: clamp(10px, 1vw, 16px) 0 12px;
}

.page-abk-penempatan .penempatan-crewlist-table .col-ref { width: 10%; }
.page-abk-penempatan .penempatan-crewlist-table .col-date { width: 11%; }
.page-abk-penempatan .penempatan-crewlist-table .col-count { width: 6%; }
.page-abk-penempatan .penempatan-crewlist-table .col-by { width: 12%; }
.page-abk-penempatan .penempatan-crewlist-table .col-aksi-crewlist { width: 22%; min-width: 220px; }

.btn-aksi-excel:hover {
  background: rgba(22, 163, 74, 0.08);
}

.btn-aksi-fly {
  background: linear-gradient(135deg, #0ea5e9 0%, #0369a1 100%);
  color: #fff;
  border-color: rgba(14, 165, 233, 0.45);
  gap: 4px;
}

.btn-aksi-fly:hover:not(:disabled):not(.is-disabled) {
  background: linear-gradient(135deg, #38bdf8 0%, #0284c7 100%);
  box-shadow: 0 4px 12px rgba(3, 105, 161, 0.25);
}

.btn-aksi-fly:disabled,
.btn-aksi-fly.is-disabled {
  opacity: 0.45;
  cursor: not-allowed;
  filter: grayscale(0.35);
}

.btn-terbangkan-submit.is-loading {
  opacity: 0.75;
  pointer-events: none;
}

.crewlist-flown-badge {
  display: inline-block;
  margin-left: 0.35rem;
  padding: 0.12rem 0.45rem;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #0c4a6e;
  background: #e0f2fe;
  border: 1px solid #bae6fd;
  vertical-align: middle;
}

.btn-aksi-fly-icon {
  font-size: 0.85rem;
  line-height: 1;
}

.crewlist-terbangkan-modal { z-index: 100180; }
.crewlist-terbangkan-card {
  width: min(680px, calc(100vw - 24px));
  max-height: min(90vh, 880px);
  overflow: auto;
}
.crewlist-terbangkan-ref {
  margin: 4px 0 0;
  font-size: 0.82rem;
  color: var(--muted);
  letter-spacing: 0.04em;
}
.crewlist-terbangkan-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 12px;
  margin-bottom: 12px;
}
.crewlist-terbangkan-fields label.full {
  grid-column: 1 / -1;
}
.crewlist-terbangkan-fields input:not(.date-input),
.crewlist-terbangkan-fields select,
.crewlist-terbangkan-fields textarea {
  width: 100%;
  margin-top: 4px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid rgba(201, 169, 98, 0.35);
}
.crewlist-terbangkan-estimasi {
  display: block;
  margin-top: 4px;
  font-weight: 700;
  color: var(--navy);
}
.crewlist-terbangkan-warn {
  border: 1px solid rgba(245, 158, 11, 0.35);
  border-radius: 10px;
  padding: 10px 12px;
  background: rgba(255, 251, 235, 0.85);
  margin-bottom: 10px;
}
.crewlist-terbangkan-warn-title {
  margin: 0 0 6px;
  font-weight: 700;
  color: #92400e;
  font-size: 0.84rem;
}
.crewlist-terbangkan-member-list {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 220px;
  overflow: auto;
}
.crewlist-terbangkan-member-list li {
  border-radius: 8px;
  padding: 8px 10px;
  border: 1px solid rgba(201, 169, 98, 0.25);
  background: #fff;
}
.crewlist-terbangkan-member-list li.tone-warn {
  border-color: rgba(245, 158, 11, 0.35);
  background: #fffbeb;
}
.crewlist-terbangkan-member-list li.tone-ok {
  border-color: rgba(22, 163, 74, 0.25);
  background: #f0fdf4;
}
.crewlist-terbangkan-member-list li.is-skipped {
  opacity: 0.65;
}
.crewlist-terbangkan-member-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}
.crewlist-terbangkan-doc-badge {
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(15, 23, 41, 0.08);
}
.crewlist-terbangkan-member-meta {
  font-size: 0.72rem;
  color: var(--muted);
}
.crewlist-terbangkan-missing {
  margin: 4px 0 0;
  font-size: 0.72rem;
  color: #b45309;
}
.crewlist-terbangkan-missing.is-ok {
  color: #166534;
}
.crewlist-terbangkan-incomplete-note {
  margin: 8px 0 0;
  font-size: 0.74rem;
  font-weight: 600;
  color: #92400e;
}
.crewlist-terbangkan-confirm {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-top: 10px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--navy);
}
.crewlist-terbangkan-error {
  margin-bottom: 8px;
  padding: 8px 10px;
  border-radius: 8px;
  background: #fee2e2;
  color: #991b1b;
  font-size: 0.78rem;
}
.btn-terbangkan-submit {
  background: linear-gradient(135deg, #0ea5e9 0%, #0369a1 100%);
}

.btn-aksi-delete {
  background: #fff;
  color: #b91c1c;
  border-color: rgba(185, 28, 28, 0.28);
  cursor: pointer;
  font: inherit;
}

.btn-aksi-delete:hover {
  background: rgba(254, 226, 226, 0.85);
}

.crewlist-delete-modal .crewlist-delete-card {
  max-width: 520px;
}

.crewlist-delete-modal textarea {
  width: 100%;
  min-height: 96px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font: inherit;
  resize: vertical;
}

.crewlist-delete-modal .btn-crewlist-delete-submit {
  width: auto;
  background: linear-gradient(135deg, #991b1b, #b91c1c);
  border-color: rgba(185, 28, 28, 0.45);
}

.crewlist-delete-modal .btn-crewlist-delete-submit:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.penempatan-aksi-group {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  justify-content: center;
  align-items: center;
}

.btn-aksi {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-decoration: none;
  border: 1px solid transparent;
  white-space: nowrap;
  transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
}

.btn-aksi:hover {
  transform: translateY(-1px);
}

.btn-aksi-view {
  background: linear-gradient(135deg, var(--navy-soft), var(--navy));
  color: #fff;
  border-color: rgba(201, 169, 98, 0.28);
}

.btn-aksi-edit {
  background: #fff;
  color: #92400e;
  border-color: rgba(146, 64, 14, 0.25);
}

.btn-aksi-edit:hover {
  background: rgba(251, 191, 36, 0.12);
}

.btn-aksi-print {
  background: #fff;
  color: #0f766e;
  border-color: rgba(15, 118, 110, 0.25);
}

.btn-aksi-print:hover {
  background: rgba(15, 118, 110, 0.08);
}

.btn-aksi-excel {
  background: rgba(22, 101, 52, 0.08);
  color: #166534;
  border-color: rgba(22, 101, 52, 0.22);
}

.btn-aksi-excel:hover {
  background: rgba(22, 101, 52, 0.14);
}

.page-penempatan-crewlist-edit .penempatan-release-catatan {
  padding: 0 clamp(14px, 1.6vw, 24px) 12px;
}

.page-penempatan-crewlist-edit .penempatan-release-catatan textarea {
  width: 100%;
  min-height: 84px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font: inherit;
  resize: vertical;
}

.page-penempatan-crewlist-edit .penempatan-release-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px 14px;
  padding: 0 clamp(14px, 1.6vw, 24px) 12px;
}

.page-penempatan-crewlist-edit .btn-penempatan-release {
  width: auto;
  flex: 0 0 auto;
  padding: 9px 16px;
  font-size: 0.82rem;
  border-radius: 999px;
}

.page-penempatan-crewlist-edit .btn-penempatan-release:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.page-penempatan-crewlist-edit .penempatan-crewlist-empty {
  padding: 24px clamp(14px, 1.6vw, 24px) 32px;
  text-align: center;
}

.page-penempatan-crewlist-edit .col-check {
  width: 34px;
}

.page-penempatan-crewlist-edit .penempatan-crewlist-edit-section {
  padding: clamp(12px, 1.2vw, 18px) clamp(14px, 1.6vw, 24px);
}

.page-penempatan-crewlist-edit .penempatan-crewlist-empty-inline {
  padding: 0 clamp(14px, 1.6vw, 24px) 12px;
}

.page-penempatan-crewlist-edit .penempatan-add-pick-head {
  padding: 0 0 12px;
}

.page-penempatan-crewlist-edit .penempatan-add-hint {
  padding: 0 clamp(14px, 1.6vw, 24px);
}

.page-penempatan-crewlist-edit .penempatan-crewlist-add-actions {
  padding: 8px clamp(14px, 1.6vw, 24px) clamp(16px, 1.4vw, 22px);
}

.page-penempatan-crewlist-edit .btn-crewlist-release {
  font-size: 0.82rem;
  padding: 8px 14px;
  border-radius: 999px;
}

.page-penempatan-crewlist-edit .btn-penempatan-add-submit {
  width: auto;
  padding: 9px 18px;
  font-size: 0.84rem;
  border-radius: 999px;
}

.page-penempatan-crewlist-edit .col-pre-doc {
  width: 108px;
  min-width: 108px;
}
.btn-pre-doc-open {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.45);
  background: linear-gradient(180deg, #fffefb 0%, #f7f2e8 100%);
  color: var(--navy);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}
.btn-pre-doc-open:hover {
  border-color: var(--gold);
  box-shadow: 0 4px 12px rgba(15, 23, 41, 0.08);
  transform: translateY(-1px);
}
.btn-pre-doc-label {
  text-transform: uppercase;
}
.pre-doc-progress {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 999px;
  background: #eef2f7;
  color: #475569;
}
.pre-doc-progress.tone-partial {
  background: #fef3c7;
  color: #92400e;
}
.pre-doc-progress.tone-full {
  background: #dcfce7;
  color: #166534;
}
.pre-doc-exp-warn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  font-size: 0.62rem;
  font-weight: 800;
  line-height: 1;
}
.pre-doc-exp-warn.tone-warn {
  background: #fef3c7;
  color: #b45309;
}
.pre-doc-exp-warn.tone-danger {
  background: #fee2e2;
  color: #b91c1c;
}

.pre-berangkat-modal { z-index: 100150; }
.pre-berangkat-card {
  width: min(720px, calc(100vw - 24px));
  max-height: min(88vh, 920px);
  overflow: auto;
}
.pre-berangkat-sub {
  margin: 4px 0 0;
  font-size: 0.82rem;
  color: var(--muted);
  letter-spacing: 0.04em;
}
.pre-berangkat-hint {
  margin-top: 0;
}
.pre-berangkat-progress-line {
  margin: 0 0 10px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--navy);
}
.pre-berangkat-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: min(52vh, 520px);
  overflow: auto;
  padding-right: 4px;
}
.pre-berangkat-row {
  border: 1px solid rgba(201, 169, 98, 0.28);
  border-radius: 10px;
  padding: 10px 12px;
  background: #fffefb;
}
.pre-berangkat-row.is-uploaded {
  border-color: rgba(22, 101, 52, 0.25);
  background: linear-gradient(180deg, #f8fff9 0%, #fffefb 100%);
}
.pre-berangkat-row-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}
.pre-berangkat-row-label {
  font-size: 0.82rem;
  color: var(--navy);
  letter-spacing: 0.03em;
}
.pre-berangkat-row-status {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--muted);
}
.pre-berangkat-row.is-uploaded .pre-berangkat-row-status {
  color: #166534;
}
.pre-berangkat-expiry {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 8px;
  font-size: 0.74rem;
}
.pre-berangkat-expiry input {
  max-width: 160px;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid rgba(201, 169, 98, 0.35);
}
.pre-berangkat-expiry-warn {
  margin: 0 0 6px;
  font-size: 0.72rem;
  font-weight: 600;
}
.pre-berangkat-expiry-warn.tone-warn { color: #b45309; }
.pre-berangkat-expiry-warn.tone-danger { color: #b91c1c; }
.pre-berangkat-row-file {
  margin-bottom: 8px;
  font-size: 0.76rem;
}
.pre-berangkat-view {
  color: var(--navy);
  font-weight: 600;
  text-decoration: underline;
}
.pre-berangkat-row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.btn-pre-doc-upload {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  font-size: 0.74rem;
  padding: 6px 12px;
}
.pre-berangkat-error {
  margin-top: 8px;
  padding: 8px 10px;
  border-radius: 8px;
  background: #fee2e2;
  color: #991b1b;
  font-size: 0.78rem;
}
.pre-berangkat-loading {
  padding: 12px 0;
}

.penempatan-crewlist-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding: 4px clamp(14px, 1.6vw, 24px) 14px;
}

.penempatan-crewlist-quick-actions .btn-crewlist-action-add {
  width: auto;
  flex: 0 0 auto;
  padding: 9px 16px;
  font-size: 0.82rem;
  border-radius: 999px;
  white-space: nowrap;
}

.penempatan-crewlist-quick-actions .btn-crewlist-action-release {
  padding: 9px 16px;
  font-size: 0.82rem;
  border-radius: 999px;
  white-space: nowrap;
  color: #b45309;
  border-color: rgba(180, 83, 9, 0.35);
  background: rgba(255, 251, 235, 0.9);
}

.penempatan-crewlist-quick-actions .btn-crewlist-action-release:hover:not(:disabled) {
  background: rgba(254, 243, 199, 0.95);
  border-color: rgba(180, 83, 9, 0.5);
}

.penempatan-crewlist-quick-hint {
  margin: 0;
  padding: 0 clamp(14px, 1.6vw, 24px) 14px;
  font-size: 0.82rem;
  color: var(--muted, #64748b);
}

.penempatan-crewlist-quick-hint.is-ready {
  color: #166534;
  font-weight: 600;
}

.penempatan-crewlist-quick-hint.is-warn {
  color: #b45309;
  font-weight: 600;
}

.penempatan-crewlist-quick-hint.is-muted {
  color: #94a3b8;
}

.penempatan-crewlist-quick-actions .btn-crewlist-action-add.is-action-ready,
.penempatan-crewlist-quick-actions .btn-crewlist-action-release.is-action-ready {
  box-shadow: 0 0 0 2px rgba(184, 134, 11, 0.35);
}

body.crewlist-catatan-modal-open {
  overflow: hidden;
}
.crewlist-catatan-modal .crewlist-catatan-card {
  max-width: 520px;
}

.crewlist-catatan-modal textarea {
  width: 100%;
  min-height: 96px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font: inherit;
  resize: vertical;
}

.crewlist-catatan-modal .btn-crewlist-release-submit {
  color: #b45309;
  border-color: rgba(180, 83, 9, 0.35);
  background: rgba(255, 251, 235, 0.95);
}

.crewlist-catatan-modal .btn-crewlist-release-submit:hover:not(:disabled) {
  background: rgba(254, 243, 199, 0.95);
  border-color: rgba(180, 83, 9, 0.5);
}

.crewlist-catatan-modal .btn-add {
  width: auto;
}

.crewlist-catatan-modal #crewlistCatatanConfirm:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.penempatan-crewlist-edit-section.is-crewlist-goto-flash {
  animation: crewlistSectionFlash 1.1s ease-out;
}

@keyframes crewlistSectionFlash {
  0% { box-shadow: inset 0 0 0 0 rgba(184, 134, 11, 0); }
  25% { box-shadow: inset 0 0 0 2px rgba(184, 134, 11, 0.45); }
  100% { box-shadow: inset 0 0 0 0 rgba(184, 134, 11, 0); }
}

.page-abk-penempatan .cell-ref-code {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 6px;
  background: rgba(15, 23, 42, 0.06);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.penempatan-batch-count {
  display: inline-flex;
  min-width: 1.8em;
  justify-content: center;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(184, 134, 11, 0.12);
  color: #92650a;
  font-weight: 700;
  font-size: 0.82rem;
}

.page-penempatan-crewlist-detail .penempatan-crewlist-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px 14px;
  margin-top: 14px;
}

.page-penempatan-crewlist-detail .penempatan-meta-card {
  padding: 12px 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 10px;
  background: #fff;
}

.page-penempatan-crewlist-detail .penempatan-meta-label {
  display: block;
  margin-bottom: 4px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.page-penempatan-crewlist-detail .penempatan-meta-card strong {
  font-size: 0.95rem;
  color: var(--ink, #0f172a);
}

.page-penempatan-crewlist-detail .penempatan-crewlist-catatan {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 10px;
  background: rgba(250, 248, 245, 0.9);
  border: 1px solid rgba(201, 169, 98, 0.18);
}

.page-penempatan-crewlist-detail .penempatan-crewlist-catatan p {
  margin: 6px 0 0;
  font-size: 0.88rem;
  line-height: 1.5;
  white-space: pre-wrap;
}

.page-penempatan-tambah .panel-penempatan-tambah {
  padding-bottom: 0;
  overflow: visible;
}

.page-penempatan-tambah .penempatan-tambah-head {
  padding-bottom: 18px;
}

.penempatan-tambah-lead {
  max-width: 52rem;
  line-height: 1.55;
}

.penempatan-tambah-steps {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  margin-top: 14px;
  padding: 10px 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(201, 169, 98, 0.2);
}

.penempatan-tambah-step {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--muted, #64748b);
}

.penempatan-tambah-step.is-active {
  color: var(--navy, #0f172a);
}

.penempatan-tambah-step-no {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  background: rgba(15, 23, 42, 0.06);
  color: var(--muted, #64748b);
}

.penempatan-tambah-step.is-active .penempatan-tambah-step-no {
  background: linear-gradient(135deg, var(--gold, #b8860b), #d4a853);
  color: #fff;
  box-shadow: 0 2px 8px rgba(184, 134, 11, 0.28);
}

.penempatan-tambah-step-div {
  width: 28px;
  height: 1px;
  background: rgba(15, 23, 42, 0.12);
  flex-shrink: 0;
}

.penempatan-tambah-form {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0 clamp(14px, 1.6vw, 24px) 24px;
}

.penempatan-tambah-card {
  margin: 18px 0 0;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 16px;
  padding: 0 20px 20px;
  background: linear-gradient(180deg, #fff 0%, rgba(250, 248, 245, 0.55) 100%);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}

.penempatan-tambah-card legend {
  font-size: 1.05rem;
  padding: 0 10px;
}

.penempatan-tambah-section-desc {
  margin: 0 0 16px;
  padding-top: 4px;
  font-size: 0.88rem;
  color: var(--muted, #64748b);
  line-height: 1.5;
}

.penempatan-tambah-grid {
  gap: 14px 18px;
}

.page-penempatan-tambah .penempatan-master-hint {
  display: none;
}

.page-penempatan-tambah .penempatan-master-row .btn-master-add {
  white-space: nowrap;
  font-size: 0.78rem;
  padding: 8px 12px;
  border-radius: 10px;
}

.page-penempatan-tambah .master-search-input,
.page-penempatan-tambah .kapal-search-input {
  border-radius: 10px;
  padding: 10px 36px 10px 12px;
  font-size: 0.88rem;
  background-color: #fff;
  border-color: rgba(15, 23, 42, 0.12);
}

.page-penempatan-tambah .master-search-status,
.page-penempatan-tambah .kapal-search-status {
  margin-top: 4px;
  font-size: 0.72rem;
  padding: 4px 8px;
}

.penempatan-tambah-target-hint,
.penempatan-tambah-gaji-hint {
  margin: 12px 0 0;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(248, 250, 252, 0.9);
  border: 1px dashed rgba(15, 23, 42, 0.1);
}

.penempatan-tambah-target {
  margin: 0;
}

.penempatan-tambah-pick {
  margin: 0;
}

.penempatan-tambah-toolbar {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.penempatan-tambah-toolbar-main {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  align-items: flex-end;
}

.penempatan-tambah-search-field {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 240px;
  min-width: 200px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  background: var(--cream, #faf8f5);
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.penempatan-tambah-search-field:focus-within {
  border-color: var(--gold, #b8860b);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.16);
}

.penempatan-tambah-search-icon {
  font-size: 0.9rem;
  opacity: 0.55;
  flex-shrink: 0;
}

.penempatan-tambah-search-field input {
  flex: 1 1 auto;
  min-width: 0;
  border: none;
  background: transparent;
  padding: 10px 0;
  font-size: 0.88rem;
  text-transform: none;
  outline: none;
}

.penempatan-tambah-pick-head {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  align-items: flex-end;
  margin-bottom: 12px;
}

.penempatan-tambah-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  align-items: flex-end;
  flex: 1 1 360px;
}

.penempatan-tambah-toolbar-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  padding-top: 4px;
  border-top: 1px solid rgba(15, 23, 42, 0.06);
}

.penempatan-filter-field {
  flex: 1 1 130px;
  min-width: 120px;
}

.penempatan-filter-field select {
  width: 100%;
  font-size: 0.82rem;
  padding: 9px 10px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 10px;
  background: #fff;
}

.penempatan-filter-reset {
  flex: 0 0 auto;
  align-self: flex-end;
  margin-bottom: 1px;
}

.penempatan-pick-visible {
  font-size: 0.76rem;
  color: var(--muted);
  font-weight: 600;
  margin-left: auto;
  white-space: nowrap;
}

.penempatan-tambah-search {
  flex: 1 1 220px;
  min-width: 180px;
}

.penempatan-pick-all {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  white-space: nowrap;
  padding: 6px 10px;
  border-radius: 8px;
  background: rgba(248, 250, 252, 0.9);
}

.penempatan-pick-count {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--navy, #0f172a);
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(184, 134, 11, 0.12);
  border: 1px solid rgba(184, 134, 11, 0.25);
}

.penempatan-tambah-table-wrap {
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.penempatan-tambah-footer {
  position: sticky;
  bottom: 0;
  z-index: 30;
  margin: 20px -24px -24px;
  padding: 0 clamp(14px, 1.6vw, 24px) 16px;
  background: linear-gradient(180deg, rgba(248, 246, 240, 0) 0%, rgba(248, 246, 240, 0.92) 24%, rgba(248, 246, 240, 0.98) 100%);
  backdrop-filter: blur(6px);
}

.penempatan-tambah-footer-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px 16px;
  padding: 14px 18px;
  border-radius: 14px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 4px 20px rgba(15, 23, 42, 0.08);
}

.penempatan-tambah-footer-note {
  margin: 0;
  font-size: 0.82rem;
  color: var(--muted, #64748b);
  max-width: 28rem;
  line-height: 1.45;
}

.penempatan-tambah-catatan textarea {
  min-height: 88px;
  resize: vertical;
  border-radius: 10px;
  font-size: 0.88rem;
  line-height: 1.5;
}

.penempatan-tambah-actions {
  padding-top: 0;
  margin: 0;
  flex-shrink: 0;
}

.penempatan-tambah-actions .btn-primary {
  min-width: 200px;
  padding: 11px 20px;
  font-size: 0.9rem;
}

/* Tabel pilih ABK — kolom proporsional, checkbox sempit */
.page-penempatan-tambah .penempatan-pick-table {
  table-layout: fixed;
  width: 100%;
}

.page-penempatan-tambah .penempatan-pick-table col.pick-col-check { width: 34px; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-no { width: 44px; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-uniq { width: 9%; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-nama { width: 18%; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-status { width: 9%; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-marketing { width: 8%; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-xp { width: 8%; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-jabatan { width: 9%; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-skill { width: 10%; }
.page-penempatan-tambah .penempatan-pick-table col.pick-col-gaji { width: 18%; min-width: 190px; }

.page-penempatan-tambah .penempatan-pick-table thead th,
.page-penempatan-tambah .penempatan-pick-table tbody td {
  padding: 10px 8px;
}

.page-penempatan-tambah .penempatan-pick-table thead th {
  font-size: 0.72rem;
  letter-spacing: 0.05em;
  white-space: nowrap;
  word-break: normal;
  hyphens: none;
  background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
  color: #f8fafc;
  border-bottom: 2px solid rgba(201, 169, 98, 0.35);
  padding: 11px 8px;
}

.page-penempatan-tambah .penempatan-pick-table tbody td {
  font-size: 0.84rem;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
}

.page-penempatan-tambah .penempatan-pick-table .col-check {
  width: 34px;
  min-width: 34px;
  max-width: 34px;
  padding: 8px 2px;
}

.page-penempatan-tambah .penempatan-pick-table .pick-check-cell {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.page-penempatan-tambah .penempatan-pick-table .col-no {
  width: 44px;
  min-width: 44px;
  text-align: center;
}

.page-penempatan-tambah .penempatan-pick-table .col-uniq {
  width: 9%;
}

.page-penempatan-tambah .penempatan-pick-table .col-nama {
  width: 22%;
  white-space: normal;
  word-break: break-word;
}

.page-penempatan-tambah .penempatan-pick-table .col-status {
  width: 10%;
  text-align: center;
}

.page-penempatan-tambah .penempatan-pick-table .col-marketing {
  width: 9%;
  white-space: nowrap;
}

.page-penempatan-tambah .penempatan-pick-table .col-xp {
  width: 9%;
  text-align: center;
}

.page-penempatan-tambah .penempatan-pick-table .col-jabatan {
  width: 10%;
  white-space: nowrap;
}

.page-penempatan-tambah .penempatan-pick-table .col-skill {
  width: 10%;
  text-align: left;
  white-space: normal;
  word-break: break-word;
}

.page-penempatan-tambah .penempatan-pick-table .col-gaji,
.page-penempatan-tambah .penempatan-pick-table .pick-gaji-cell {
  width: 16%;
  min-width: 168px;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
}

.page-penempatan-tambah .penempatan-pick-table tbody tr.is-picked td {
  background: rgba(184, 134, 11, 0.07);
  box-shadow: inset 3px 0 0 var(--gold, #b8860b);
}

.page-penempatan-tambah .penempatan-pick-table tbody tr.is-picked td.col-check {
  box-shadow: inset 3px 0 0 var(--gold, #b8860b);
}

.pick-gaji-fields {
  display: grid;
  gap: 7px;
  min-width: 170px;
  padding: 2px 0;
}

.pick-gaji-tipe,
.pick-gaji-currency,
.pick-gaji-nominal {
  width: 100%;
  font-size: 0.78rem;
  padding: 7px 9px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 8px;
  background: #fff;
  text-transform: none;
}

.pick-gaji-fields select:disabled,
.pick-gaji-fields input:disabled {
  background: #f8fafc;
  color: var(--muted);
  cursor: not-allowed;
}

.pick-gaji-fields select.is-invalid,
.pick-gaji-fields input.is-invalid {
  border-color: #dc2626;
  background: #fff7f7;
}

.pick-gaji-nominal-row {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 6px;
}

.crewlist-gaji-cell {
  display: grid;
  gap: 2px;
  line-height: 1.25;
}

.crewlist-gaji-amount {
  font-weight: 700;
  color: var(--ink, #0f172a);
}

.crewlist-gaji-tipe {
  font-size: 0.72rem;
  color: var(--muted);
}

.page-penempatan-tambah .penempatan-pick-table .col-marketing,
.page-penempatan-tambah .penempatan-pick-table .col-jabatan {
  white-space: nowrap;
}

.page-penempatan-tambah .penempatan-pick-table .cell-xp-tipe {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  justify-content: center;
}

.page-penempatan-tambah .penempatan-pick-table .xp-tipe-badge {
  font-size: 0.62rem;
  padding: 2px 5px;
  border-radius: 4px;
  background: #e0f2fe;
  color: #075985;
  font-weight: 700;
  white-space: nowrap;
}

.page-penempatan-tambah .penempatan-pick-table .cell-skill-list {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
}

.page-penempatan-tambah .penempatan-pick-table .skill-chip {
  font-size: 0.62rem;
  padding: 2px 5px;
  border-radius: 4px;
  background: #f3f4f6;
  color: #374151;
  font-weight: 600;
  white-space: nowrap;
}

.page-penempatan-tambah .penempatan-pick-table .cell-nama-main {
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.3;
}

.page-penempatan-tambah .penempatan-pick-table .cell-uniq-id {
  font-size: 0.72rem;
}

.page-penempatan-tambah .penempatan-pick-table .crew-status-badge {
  font-size: 0.62rem;
  padding: 3px 7px;
  white-space: nowrap;
}

.page-penempatan-tambah .penempatan-pick-table input[type="checkbox"].penempatan-pick-cb {
  width: 15px;
  height: 15px;
  min-width: 15px;
  min-height: 15px;
  margin: 0;
  cursor: pointer;
  flex-shrink: 0;
}

.page-penempatan-tambah .table-scroll-fluid {
  border-radius: 14px;
  border: none;
  background: transparent;
}

.page-penempatan-tambah .penempatan-pick-table tbody tr:hover {
  background: rgba(201, 169, 98, 0.05);
}

.page-penempatan-tambah .penempatan-pick-table tbody tr.is-picked:hover td {
  background: rgba(184, 134, 11, 0.09);
}

@media (max-width: 900px) {
  .penempatan-tambah-toolbar-main {
    flex-direction: column;
    align-items: stretch;
  }

  .penempatan-tambah-filters {
    flex: 1 1 auto;
  }

  .penempatan-tambah-footer-inner {
    flex-direction: column;
    align-items: stretch;
  }

  .penempatan-tambah-actions {
    width: 100%;
  }

  .penempatan-tambah-actions .btn-primary,
  .penempatan-tambah-actions .btn-ghost {
    flex: 1 1 auto;
    text-align: center;
  }

  .page-penempatan-tambah .reg-grid {
    grid-template-columns: 1fr;
  }
}

.penempatan-tambah-catatan textarea {
  min-height: 88px;
  resize: vertical;
}

.penempatan-form-error {
  margin: 0;
  padding: 10px 12px;
  border-radius: 8px;
  background: #fee2e2;
  color: #991b1b;
  font-size: 0.82rem;
  border: 1px solid #fecaca;
}

.penempatan-form-error[hidden] {
  display: none;
}

.penempatan-tambah-actions {
  padding-top: 4px;
}

.penempatan-master-row {
  display: flex;
  gap: 8px;
  align-items: stretch;
}

.penempatan-master-row .penempatan-master-combobox {
  flex: 1 1 auto;
  min-width: 0;
}

.penempatan-kapal-row {
  display: flex;
  gap: 8px;
  align-items: stretch;
}

.penempatan-kapal-row .kapal-combobox {
  flex: 1 1 auto;
  min-width: 0;
}

.master-search-input,
.kapal-search-input {
  width: 100%;
  box-sizing: border-box;
  cursor: text;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23a8863a' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px !important;
  font-size: 0.85rem;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.master-search-status,
.kapal-search-status {
  margin-top: 6px;
  font-size: 0.76rem;
  font-weight: 600;
  line-height: 1.4;
  padding: 6px 8px;
  border-radius: 6px;
}

.master-search-status[hidden],
.kapal-search-status[hidden] {
  display: none;
}

.master-search-status.is-found,
.kapal-search-status.is-found {
  color: #166534;
  background: #dcfce7;
  border: 1px solid #bbf7d0;
}

.master-search-status.is-hint,
.kapal-search-status.is-hint {
  color: #92400e;
  background: #fef3c7;
  border: 1px solid #fde68a;
}

.master-search-status.is-missing,
.kapal-search-status.is-missing {
  color: #991b1b;
  background: #fee2e2;
  border: 1px solid #fecaca;
}

.btn-master-add,
.btn-kapal-master-add {
  flex: 0 0 auto;
  white-space: nowrap;
  font-size: 0.78rem;
  padding: 8px 12px;
}

.penempatan-master-hint,
.penempatan-kapal-hint {
  margin-top: 4px;
}

.master-agency-card,
.master-kapal-card {
  max-width: 480px;
  width: 100%;
}

.master-agency-quick-form,
.master-kapal-quick-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.master-agency-quick-form label,
.master-kapal-quick-form label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: 0.78rem;
  font-weight: 600;
}

.master-agency-quick-form input,
.master-agency-quick-form select,
.master-kapal-quick-form input,
.master-kapal-quick-form select {
  font-size: 0.85rem;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.master-agency-quick-error,
.master-kapal-quick-error {
  margin: 0;
  padding: 8px 10px;
  border-radius: 8px;
  background: #fee2e2;
  color: #991b1b;
  font-size: 0.78rem;
  border: 1px solid #fecaca;
}

.master-agency-quick-error[hidden],
.master-kapal-quick-error[hidden] {
  display: none;
}

.btn-kapal-master-add {
  flex: 0 0 auto;
  white-space: nowrap;
  font-size: 0.78rem;
  padding: 8px 12px;
}

.penempatan-kapal-hint {
  margin-top: 4px;
}

.master-kapal-card {
  max-width: 480px;
  width: 100%;
}

.master-kapal-quick-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.master-kapal-quick-form label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: 0.78rem;
  font-weight: 600;
}

.master-kapal-quick-form input,
.master-kapal-quick-form select {
  font-size: 0.85rem;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.master-kapal-quick-error {
  margin: 0;
  padding: 8px 10px;
  border-radius: 8px;
  background: #fee2e2;
  color: #991b1b;
  font-size: 0.78rem;
  border: 1px solid #fecaca;
}

.master-kapal-quick-error[hidden] {
  display: none;
}

/* ——— Riwayat ABK (activity log) ——— */
.page-abk-form .form-head-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

.page-abk-form .btn-abk-riwayat-link {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.08);
}

.page-abk-form .btn-abk-riwayat-link:hover {
  background: rgba(255, 255, 255, 0.16);
  border-color: var(--gold-light);
}

.page-abk-riwayat .panel-crew-activity {
  padding-bottom: 24px;
}

.crew-activity-head {
  padding: clamp(18px, 2vw, 28px);
  border-bottom: 1px solid var(--line);
}

.crew-activity-sub {
  margin: 8px 0 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.crew-activity-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 20px;
  padding: 12px clamp(18px, 2vw, 28px);
  border-bottom: 1px solid var(--line);
  background: rgba(248, 250, 252, 0.85);
}

.crew-activity-stat strong {
  color: var(--navy);
}

.crew-activity-empty {
  padding: 32px clamp(18px, 2vw, 28px);
}

.crew-activity-preview {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px dashed var(--line);
}

.crew-activity-preview-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.crew-activity-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
}

.crew-activity-timeline-full {
  padding: 20px clamp(18px, 2vw, 28px) 8px;
  position: relative;
}

.crew-activity-timeline-full::before {
  content: "";
  position: absolute;
  left: calc(clamp(18px, 2vw, 28px) + 11px);
  top: 24px;
  bottom: 16px;
  width: 2px;
  background: linear-gradient(180deg, rgba(184, 134, 11, 0.45), rgba(148, 163, 184, 0.25));
}

.crew-activity-timeline-compact {
  display: grid;
  gap: 10px;
}

.crew-activity-item {
  position: relative;
  padding: 0 0 16px 28px;
}

.crew-activity-timeline-full .crew-activity-item::before {
  content: "";
  position: absolute;
  left: -21px;
  top: 6px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--gold);
  box-shadow: 0 0 0 2px rgba(184, 134, 11, 0.15);
}

.crew-activity-item-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.crew-activity-item-title {
  font-size: 0.88rem;
  color: var(--ink);
}

.crew-activity-item-time {
  margin-left: auto;
  font-size: 0.74rem;
  color: var(--muted);
  white-space: nowrap;
}

.crew-activity-item-summary {
  margin: 6px 0 0;
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--navy);
}

.crew-activity-item-detail {
  margin: 6px 0 0;
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--ink);
}

.crew-activity-item-by {
  margin: 4px 0 0;
  font-size: 0.74rem;
  color: var(--muted);
}

.crew-activity-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.crew-activity-badge.tone-gold { background: rgba(184, 134, 11, 0.14); color: #92650a; }
.crew-activity-badge.tone-blue { background: rgba(184, 134, 11, 0.14); color: #1d4ed8; }
.crew-activity-badge.tone-slate { background: rgba(100, 116, 139, 0.12); color: #475569; }
.crew-activity-badge.tone-teal { background: rgba(13, 148, 136, 0.12); color: #0f766e; }
.crew-activity-badge.tone-purple { background: rgba(124, 58, 237, 0.12); color: #6d28d9; }
.crew-activity-badge.tone-indigo { background: rgba(79, 70, 229, 0.12); color: #4338ca; }
.crew-activity-badge.tone-cyan { background: rgba(8, 145, 178, 0.12); color: #0e7490; }
.crew-activity-badge.tone-green { background: rgba(22, 163, 74, 0.12); color: #15803d; }
.crew-activity-badge.tone-amber { background: rgba(217, 119, 6, 0.12); color: #b45309; }
.crew-activity-badge.tone-red { background: rgba(220, 38, 38, 0.12); color: #b91c1c; }

.crew-activity-item.is-compact {
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.85);
}

.crew-activity-item.is-compact::before {
  display: none;
}

.crew-status-penempatan-hint,
.crew-status-auto-ready-hint {
  margin: 0 0 10px;
  padding: 8px 12px;
  border-radius: 10px;
  font-size: 0.82rem;
  line-height: 1.45;
}

.crew-status-penempatan-hint {
  background: rgba(14, 116, 144, 0.08);
  border: 1px solid rgba(14, 116, 144, 0.2);
  color: #0e7490;
}

.crew-status-auto-ready-hint {
  background: rgba(22, 163, 74, 0.08);
  border: 1px solid rgba(22, 163, 74, 0.2);
  color: #15803d;
}

/* —— ABK Onboard table & actions —— */
.page-abk-index .abk-table-onboard .col-no,
.page-abk-index .abk-table-onboard .col-uniq,
.page-abk-index .abk-table-onboard .col-signon,
.page-abk-index .abk-table-onboard .col-rencana,
.page-abk-index .abk-table-onboard .col-aksi-onboard {
  text-align: center;
}

.page-abk-index .abk-table-onboard .onboard-cell-id,
.page-abk-index .abk-table-onboard .onboard-date-val {
  display: inline-block;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.3;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.page-abk-index .abk-table-onboard .col-nama-onboard .cell-nama-main {
  font-size: 0.88rem;
  line-height: 1.35;
}

.page-abk-index .abk-table-onboard .col-agency-onboard {
  font-size: 0.78rem;
  line-height: 1.4;
  max-width: 200px;
  word-break: break-word;
}

.page-abk-index .abk-table-onboard .col-kapal-onboard {
  font-size: 0.84rem;
  font-weight: 600;
  white-space: nowrap;
}

.page-abk-index .abk-table-onboard .col-signon,
.page-abk-index .abk-table-onboard .col-rencana {
  width: 9%;
  white-space: nowrap;
}

.page-abk-index .abk-table-onboard .col-aksi-onboard {
  width: auto;
  min-width: 0;
  max-width: none;
  padding-left: 8px;
  padding-right: 8px;
}

.onboard-aksi-group {
  display: inline-flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 5px;
  min-width: 0;
  max-width: 220px;
}

.btn-onboard-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 41, 0.12);
  background: #fff;
  color: var(--navy, #0f172a);
  font: inherit;
  text-decoration: none;
  cursor: pointer;
  line-height: 1;
  flex-shrink: 0;
  transition: background 0.15s, border-color 0.15s, transform 0.12s;
}

.onboard-icon-glyph {
  font-size: 1rem;
  line-height: 1;
}

.btn-onboard-icon:hover,
.btn-onboard-icon:focus-visible {
  transform: translateY(-1px);
  background: rgba(15, 23, 41, 0.04);
  border-color: rgba(15, 23, 41, 0.22);
}

.btn-onboard-icon::after {
  content: attr(data-tip);
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  padding: 5px 9px;
  border-radius: 8px;
  background: rgba(15, 23, 42, 0.94);
  color: #fff;
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 1.25;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s, transform 0.15s, visibility 0.15s;
  z-index: 30;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.18);
}

.btn-onboard-icon::before {
  content: "";
  position: absolute;
  bottom: calc(100% + 2px);
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: rgba(15, 23, 42, 0.94);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.15s, visibility 0.15s;
  pointer-events: none;
  z-index: 30;
}

.btn-onboard-icon:hover::after,
.btn-onboard-icon:focus-visible::after,
.btn-onboard-icon:hover::before,
.btn-onboard-icon:focus-visible::before {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.btn-onboard-icon.btn-onboard-doc { border-color: rgba(14, 165, 233, 0.35); background: rgba(224, 242, 254, 0.5); }
.btn-onboard-icon.btn-onboard-monitor { border-color: rgba(99, 102, 241, 0.35); background: rgba(238, 242, 255, 0.65); }
.btn-onboard-icon.btn-onboard-sign { border-color: rgba(245, 158, 11, 0.4); background: rgba(255, 251, 235, 0.7); }
.btn-onboard-icon.btn-onboard-kapal { border-color: rgba(13, 148, 136, 0.35); background: rgba(240, 253, 250, 0.65); }
.btn-onboard-icon.btn-onboard-pulang { border-color: rgba(225, 29, 72, 0.35); background: rgba(255, 241, 242, 0.85); }
.btn-onboard-icon.btn-onboard-edit { border-color: rgba(15, 23, 41, 0.15); background: rgba(248, 250, 252, 0.9); }

.onboard-pulang-hint {
  margin-bottom: 0.65rem;
}

/* —— Modal Pulang (compact, no scroll) —— */
.onboard-modal-pulang-wrap .onboard-modal-pulang {
  overflow: hidden;
}
.onboard-modal-pulang-wrap .modal-backdrop {
  backdrop-filter: blur(6px);
}
.onboard-modal-pulang {
  width: min(640px, calc(100vw - 20px));
  max-height: min(92vh, 680px);
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(225, 29, 72, 0.12);
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.16);
}
.onboard-pulang-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 18px 12px;
  flex-shrink: 0;
  background: linear-gradient(135deg, #fff1f2 0%, #fff 55%, #f8fafc 100%);
  border-bottom: 1px solid rgba(225, 29, 72, 0.08);
}
.onboard-pulang-hero-main {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  min-width: 0;
  flex: 1;
}
.onboard-pulang-hero-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  border-radius: 12px;
  background: linear-gradient(145deg, #ffe4e6, #fff);
  border: 1px solid rgba(225, 29, 72, 0.15);
}
.onboard-pulang-hero-text {
  min-width: 0;
  flex: 1;
}
.onboard-pulang-hero-text h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.15rem;
  line-height: 1.2;
  color: var(--navy, #0f172a);
}
.onboard-pulang-sub {
  margin: 3px 0 0;
  font-size: 0.78rem;
  font-weight: 600;
  color: #64748b;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.onboard-pulang-lead {
  margin: 5px 0 0;
  font-size: 0.72rem;
  line-height: 1.35;
  color: #64748b;
}
.onboard-pulang-close {
  flex-shrink: 0;
}
.onboard-pulang-form {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
.onboard-pulang-form-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 12px 18px 8px;
}
.onboard-pulang-form-foot {
  flex-shrink: 0;
  padding: 10px 18px 14px;
  background: #fff;
  border-top: 1px solid rgba(15, 23, 41, 0.08);
  box-shadow: 0 -4px 16px rgba(15, 23, 42, 0.04);
}
.onboard-pulang-badge {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 999px;
  background: rgba(225, 29, 72, 0.1);
  color: #be123c;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
.onboard-pulang-penempatan {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr) minmax(0, 0.85fr);
  gap: 6px;
  margin-bottom: 10px;
}
.onboard-pulang-chip {
  padding: 7px 10px;
  border-radius: 10px;
  background: #f8fafc;
  border: 1px solid rgba(15, 23, 41, 0.07);
  min-width: 0;
}
.onboard-pulang-chip dt {
  margin: 0 0 2px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #94a3b8;
}
.onboard-pulang-chip dd {
  margin: 0;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--navy, #0f172a);
}
.onboard-pulang-chip-agency dd {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.72rem;
  font-weight: 600;
}
.onboard-pulang-chip.is-date dd {
  font-variant-numeric: tabular-nums;
  color: #b45309;
}
.onboard-pulang-grid {
  gap: 8px 12px;
  margin-bottom: 0;
}
.onboard-field-label {
  display: block;
  margin-bottom: 4px;
  font-size: 0.72rem;
  font-weight: 700;
  color: #334155;
}
.onboard-field-label em {
  font-style: normal;
  color: #e11d48;
}
.onboard-field-label .hint-compact {
  font-weight: 500;
  color: #94a3b8;
}
.onboard-pulang-form .onboard-select,
.onboard-pulang-form .onboard-textarea,
.onboard-pulang-form .onboard-date-field .date-input {
  border: 1px solid rgba(15, 23, 41, 0.12);
  border-radius: 8px;
  background: #fff;
  font-size: 0.84rem;
}
.onboard-pulang-form .onboard-select:focus,
.onboard-pulang-form .onboard-textarea:focus,
.onboard-pulang-form .onboard-date-field .date-input:focus {
  border-color: rgba(225, 29, 72, 0.4);
  box-shadow: 0 0 0 2px rgba(225, 29, 72, 0.1);
  outline: none;
}
.onboard-pulang-form .onboard-textarea {
  min-height: 52px;
  max-height: 72px;
  resize: vertical;
  padding: 8px 10px;
  line-height: 1.4;
}
.onboard-pulang-form[data-no-upper] textarea,
.onboard-pulang-form[data-no-upper] input[type="text"] {
  text-transform: none;
}
.onboard-pulang-upload-wrap {
  margin-top: 0;
}
.onboard-pulang-upload-box {
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 10px;
  border: 1.5px dashed rgba(225, 29, 72, 0.25);
  background: #fffafa;
  cursor: pointer;
  min-height: 44px;
}
.onboard-pulang-upload-box:hover,
.onboard-pulang-upload-box.is-selected {
  border-color: rgba(225, 29, 72, 0.45);
  background: #fff5f5;
}
.onboard-pulang-upload-icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: rgba(255, 228, 230, 0.85);
  font-size: 0.95rem;
}
.onboard-pulang-upload-copy {
  flex-shrink: 0;
}
.onboard-pulang-upload-copy strong {
  font-size: 0.78rem;
  color: #475569;
  font-weight: 600;
}
.onboard-pulang-upload-name {
  flex: 1;
  min-width: 0;
  font-size: 0.72rem;
  font-weight: 600;
  color: #be123c;
  text-align: right;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.onboard-pulang-file-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
}
.onboard-pulang-blacklist-wrap {
  margin-top: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: #f8fafc;
}
.onboard-pulang-blacklist-wrap.is-kabur-highlight {
  border-color: rgba(225, 29, 72, 0.22);
  background: rgba(255, 241, 242, 0.5);
}
.onboard-pulang-blacklist-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  margin: 0;
}
.onboard-pulang-blacklist-label input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  accent-color: #be123c;
}
.onboard-pulang-blacklist-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
  font-size: 0.78rem;
  line-height: 1.35;
  color: #334155;
}
.onboard-pulang-blacklist-text strong {
  font-size: 0.8rem;
  color: #0f172a;
}
.onboard-pulang-blacklist-text span {
  font-size: 0.72rem;
  color: #64748b;
}
.onboard-pulang-form-foot .onboard-form-error {
  margin: 0 0 8px;
  padding: 6px 10px;
  font-size: 0.78rem;
}
.onboard-pulang-actions {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.btn-onboard-pulang-submit {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 148px;
  justify-content: center;
  padding: 10px 16px;
  font-size: 0.88rem;
  background: linear-gradient(135deg, #be123c, #e11d48);
  border-color: #be123c;
  box-shadow: 0 4px 14px rgba(225, 29, 72, 0.22);
}
.btn-onboard-pulang-submit:hover:not(:disabled) {
  background: linear-gradient(135deg, #9f1239, #be123c);
}
.btn-onboard-pulang-submit:disabled {
  opacity: 0.65;
  cursor: wait;
}
.btn-pulang-icon {
  display: inline-flex;
  width: 18px;
  height: 18px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  font-size: 0.68rem;
}
.onboard-pulang-kabur-notice {
  margin: 0 0 8px;
  padding: 7px 10px;
  border-radius: 8px;
  background: rgba(254, 243, 199, 0.65);
  border: 1px solid rgba(245, 158, 11, 0.3);
  font-size: 0.74rem;
  line-height: 1.4;
  color: #78350f;
}
.onboard-pulang-kabur-notice strong {
  color: #92400e;
}
@media (max-width: 640px) {
  .onboard-pulang-penempatan {
    grid-template-columns: 1fr 1fr;
  }
  .onboard-pulang-chip-agency {
    grid-column: 1 / -1;
  }
  .onboard-pulang-hero { padding: 12px 14px 10px; }
  .onboard-pulang-form-body { padding: 10px 14px 6px; }
  .onboard-pulang-form-foot { padding: 8px 14px 12px; }
  .onboard-pulang-grid { grid-template-columns: 1fr; }
}

/* —— ABK Pulang: aksi daftar ulang —— */
.page-abk-index .col-aksi-pulang {
  min-width: 120px;
  white-space: nowrap;
}
.btn-onboard-icon.btn-pulang-daftar {
  border-color: rgba(13, 148, 136, 0.4);
  background: rgba(240, 253, 250, 0.85);
}
.btn-onboard-icon.btn-pulang-profil {
  border-color: rgba(14, 165, 233, 0.35);
  background: rgba(224, 242, 254, 0.5);
}
.btn-onboard-icon.btn-pulang-edit {
  border-color: rgba(15, 23, 41, 0.15);
  background: rgba(248, 250, 252, 0.9);
}
.pulang-aksi-group {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex-wrap: nowrap;
}

/* —— Modal Daftar Ulang (Pulang → Terdaftar) —— */
.pulang-rejoin-wrap .onboard-modal-pulang-rejoin {
  overflow: hidden;
}
.pulang-rejoin-wrap .modal-backdrop {
  backdrop-filter: blur(6px);
}
.onboard-modal-pulang-rejoin {
  width: min(640px, calc(100vw - 20px));
  max-height: min(92vh, 680px);
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(13, 148, 136, 0.14);
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.16);
}
.pulang-rejoin-hero {
  background: linear-gradient(135deg, #f0fdfa 0%, #fff 55%, #f8fafc 100%);
  border-bottom-color: rgba(13, 148, 136, 0.1);
}
.pulang-rejoin-hero-icon {
  background: linear-gradient(145deg, #ccfbf1, #fff);
  border-color: rgba(13, 148, 136, 0.18);
}
.pulang-rejoin-badge {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 999px;
  background: rgba(13, 148, 136, 0.12);
  color: #0f766e;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
.pulang-rejoin-upload-box.is-selected .onboard-pulang-upload-name {
  color: #0f766e;
}
.btn-pulang-rejoin-submit {
  background: linear-gradient(135deg, #0f766e, #14b8a6);
  border: none;
  box-shadow: 0 4px 14px rgba(13, 148, 136, 0.22);
}
.btn-pulang-rejoin-submit:hover:not(:disabled) {
  background: linear-gradient(135deg, #115e59, #0f766e);
}
.btn-pulang-rejoin-submit:disabled {
  opacity: 0.65;
  cursor: wait;
}
.abk-table tbody tr.onboard-row-leaving {
  opacity: 0;
  transform: translateX(12px);
  transition: opacity 0.26s ease, transform 0.26s ease;
}
.onboard-pulang-flash.is-fading {
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.crew-kabur-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: rgba(254, 243, 199, 0.9);
  border: 1px solid rgba(245, 158, 11, 0.45);
  color: #92400e;
}
.crew-kabur-warning-banner {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: linear-gradient(90deg, rgba(254, 243, 199, 0.75), rgba(255, 251, 235, 0.5));
  border: 1px solid rgba(245, 158, 11, 0.35);
}
.crew-kabur-warning-icon {
  font-size: 1.2rem;
  line-height: 1;
}
.crew-kabur-warning-text strong {
  display: block;
  font-size: 0.84rem;
  color: #92400e;
  margin-bottom: 4px;
}
.crew-kabur-warning-text p {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.45;
  color: #78350f;
}

.cell-status-stack {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  line-height: 1.15;
  min-width: 0;
}
.crew-ex-abp-note {
  display: block;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #64748b;
  line-height: 1.2;
  white-space: nowrap;
}
.crew-ex-abp-note-inline {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.66rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: rgba(241, 245, 249, 0.95);
  border: 1px solid rgba(100, 116, 139, 0.22);
  color: #475569;
}
.crew-ex-abp-info-banner {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: linear-gradient(90deg, rgba(240, 253, 250, 0.85), rgba(248, 250, 252, 0.65));
  border: 1px solid rgba(13, 148, 136, 0.2);
}
.crew-ex-abp-info-icon {
  font-size: 1.15rem;
  line-height: 1;
}
.crew-ex-abp-info-text strong {
  display: block;
  font-size: 0.84rem;
  color: #0f766e;
  margin-bottom: 4px;
}
.crew-ex-abp-info-text p {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.45;
  color: #334155;
}

.btn-onboard-aksi {
  display: block;
  width: 100%;
  padding: 5px 8px;
  border-radius: 8px;
  border: 1px solid rgba(15, 23, 41, 0.12);
  background: #fff;
  color: var(--navy, #0f172a);
  font-size: 0.72rem;
  font-weight: 600;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  line-height: 1.35;
  white-space: normal;
}
.btn-onboard-aksi:hover {
  background: rgba(15, 23, 41, 0.04);
  border-color: rgba(15, 23, 41, 0.2);
}
.btn-onboard-doc { border-color: rgba(14, 165, 233, 0.35); color: #0369a1; }
.btn-onboard-monitor { border-color: rgba(99, 102, 241, 0.35); color: #4338ca; }
.btn-onboard-sign { border-color: rgba(245, 158, 11, 0.4); color: #b45309; }
.btn-onboard-kapal { border-color: rgba(13, 148, 136, 0.35); color: #0f766e; }
.btn-onboard-edit { border-color: rgba(15, 23, 41, 0.15); text-align: center; }
.btn-onboard-mini-doc {
  font-size: 0.72rem;
  padding: 4px 8px;
}
.onboard-modal { z-index: 100160; }
.onboard-modal-card {
  width: min(720px, calc(100vw - 24px));
  max-height: min(92vh, 900px);
  overflow: auto;
}
.onboard-modal-card-sm { width: min(520px, calc(100vw - 24px)); }
.onboard-modal-sub {
  margin: 4px 0 0;
  font-size: 0.88rem;
  color: var(--muted, #64748b);
}
.onboard-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 12px;
  margin-bottom: 12px;
}
.onboard-form-grid label.full { grid-column: 1 / -1; }
.onboard-form-grid input,
.onboard-form-grid select,
.onboard-form-grid textarea {
  width: 100%;
  margin-top: 4px;
}
.onboard-form-error {
  margin: 0 0 10px;
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(220, 38, 38, 0.08);
  border: 1px solid rgba(220, 38, 38, 0.25);
  color: #b91c1c;
  font-size: 0.85rem;
}
.onboard-monitor-list {
  max-height: 280px;
  overflow: auto;
  margin-bottom: 14px;
  padding: 2px 4px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.6);
}
.onboard-monitor-timeline {
  list-style: none;
  margin: 0;
  padding: 8px;
}
.onboard-monitor-item {
  padding: 10px 10px 10px 12px;
  border-left: 3px solid rgba(99, 102, 241, 0.45);
  margin-bottom: 8px;
  background: rgba(248, 250, 252, 0.9);
  border-radius: 0 8px 8px 0;
}
.onboard-monitor-item-head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 6px;
  margin-bottom: 4px;
}
.onboard-monitor-cat {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #4338ca;
}
.onboard-monitor-summary {
  margin: 0;
  font-size: 0.86rem;
  font-weight: 600;
}
.onboard-monitor-detail {
  margin: 4px 0 0;
  font-size: 0.82rem;
  color: var(--muted, #64748b);
}
.onboard-monitor-meta {
  margin: 6px 0 0;
  font-size: 0.72rem;
}
.onboard-bukti-field input[type="file"] {
  margin-top: 6px;
  font-size: 0.82rem;
}
.onboard-monitor-bukti {
  margin: 8px 0 0;
}
.btn-onboard-bukti {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 8px;
  border: 1px solid rgba(14, 165, 233, 0.35);
  background: rgba(224, 242, 254, 0.55);
  color: #0369a1;
  font-size: 0.78rem;
  font-weight: 600;
  text-decoration: none;
}
.btn-onboard-bukti:hover {
  background: rgba(224, 242, 254, 0.95);
  border-color: rgba(14, 165, 233, 0.55);
}
.onboard-monitor-form {
  border-top: 1px dashed rgba(15, 23, 41, 0.12);
  padding-top: 12px;
}
.onboard-sign-meta {
  margin: 0 0 10px;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--navy, #0f172a);
}
@media (max-width: 900px) {
  .onboard-form-grid { grid-template-columns: 1fr; }
  .page-abk-index .abk-table-onboard .col-aksi-onboard { min-width: 160px; }
}

/* Database ABK — profil lengkap per ABK */
.page-abk-database {
  animation: abkIndexFade 0.4s ease-out;
}

.page-abk-database .abk-db-panel {
  padding: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
  border: none;
}

.abk-db-hero {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px 24px;
  padding: clamp(20px, 2vw, 28px) clamp(18px, 2vw, 28px);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(250, 248, 245, 0.95) 55%, rgba(255, 251, 240, 0.9) 100%);
  border-bottom: 1px solid rgba(201, 169, 98, 0.2);
  border-radius: var(--radius, 16px) var(--radius, 16px) 0 0;
}

.abk-db-hero-left {
  display: flex;
  flex-wrap: wrap;
  gap: 18px 22px;
  align-items: flex-start;
  flex: 1 1 320px;
  min-width: 0;
}

.abk-db-photo,
.abk-db-photo-placeholder {
  width: clamp(96px, 10vw, 128px);
  height: clamp(96px, 10vw, 128px);
  border-radius: 18px;
  object-fit: cover;
  border: 3px solid rgba(255, 255, 255, 0.95);
  background: #fff;
  box-shadow:
    0 0 0 2px rgba(184, 134, 11, 0.35),
    0 8px 24px rgba(15, 23, 42, 0.12);
}

.abk-db-photo-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.6rem;
}

.abk-db-hero-main h1 {
  margin: 4px 0 10px;
  font-size: clamp(1.35rem, 1vw + 1.1rem, 1.85rem);
  letter-spacing: 0.02em;
  color: var(--navy, #0f172a);
}

.abk-db-hero-meta {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.abk-db-hero-id {
  font-size: 0.82rem;
  padding: 4px 10px;
  border-radius: 8px;
  background: rgba(15, 23, 42, 0.06);
}

.abk-db-tag-muted {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(100, 116, 139, 0.12);
  color: #64748b;
}

.abk-db-stats {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  padding: 0 clamp(18px, 2vw, 28px) 18px;
  background: linear-gradient(180deg, rgba(250, 248, 245, 0.95) 0%, rgba(248, 246, 240, 0.85) 100%);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
}

.abk-db-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
  min-width: 0;
}

.abk-db-stat-label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.abk-db-stat-value-row {
  display: flex;
  align-items: baseline;
  gap: 4px;
}

.abk-db-stat-value-row strong {
  font-size: 1.35rem;
  line-height: 1;
  color: var(--navy, #0f172a);
}

.abk-db-stat-suffix {
  font-size: 0.72rem;
  color: #94a3b8;
  font-weight: 600;
}

.abk-db-stat-bar {
  height: 4px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.08);
  overflow: hidden;
  margin-top: 2px;
}

.abk-db-stat-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--gold, #b8860b), #d4a853);
}

.abk-db-stat-teal .abk-db-stat-bar span {
  background: linear-gradient(90deg, #0d9488, #14b8a6);
}

.abk-db-hero-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
  flex-shrink: 0;
}

.abk-db-nav {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  padding: 12px clamp(18px, 2vw, 28px);
  position: sticky;
  top: var(--topbar-height, 64px);
  z-index: 25;
  background: rgba(248, 246, 240, 0.97);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  overflow-x: auto;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
}

.abk-db-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 14px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 600;
  text-decoration: none;
  color: var(--navy, #0f172a);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 23, 42, 0.1);
  transition: background 0.15s, border-color 0.15s, box-shadow 0.15s, transform 0.15s;
  white-space: nowrap;
  flex-shrink: 0;
}

.abk-db-nav-link:hover {
  background: rgba(184, 134, 11, 0.1);
  border-color: rgba(184, 134, 11, 0.35);
}

.abk-db-nav-link.is-active {
  background: linear-gradient(135deg, var(--navy, #0f172a), #1e293b);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.2);
}

.abk-db-nav-icon {
  font-size: 0.95rem;
  line-height: 1;
}

.abk-db-content {
  padding: 20px clamp(18px, 2vw, 28px) 40px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  background: rgba(248, 246, 240, 0.5);
}

.abk-db-section {
  scroll-margin-top: calc(var(--topbar-height, 64px) + 80px);
  margin: 0;
  padding: 0;
  border: none;
}

.abk-db-section-panel {
  background: #fff;
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.04);
  overflow: hidden;
}

.abk-db-section-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 20px 22px 16px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
  background: linear-gradient(180deg, rgba(250, 248, 245, 0.6) 0%, #fff 100%);
}

.abk-db-section-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  font-size: 1.25rem;
  background: rgba(184, 134, 11, 0.12);
  border: 1px solid rgba(184, 134, 11, 0.22);
  flex-shrink: 0;
}

.abk-db-section-eyebrow {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gold, #b8860b);
  margin-bottom: 4px;
}

.abk-db-section-head h2 {
  margin: 0 0 4px;
  font-size: clamp(1.05rem, 0.5vw + 0.95rem, 1.25rem);
  color: var(--navy, #0f172a);
}

.abk-db-section-desc {
  margin: 0;
  font-size: 0.86rem;
  color: #64748b;
  line-height: 1.5;
}

.abk-db-section-body {
  padding: 20px 22px 22px;
}

.abk-db-biodata-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-items: stretch;
}

.abk-db-card {
  padding: 16px 18px;
  border-radius: 14px;
  background: rgba(248, 250, 252, 0.65);
  border: 1px solid rgba(15, 23, 42, 0.07);
  height: 100%;
  display: flex;
  flex-direction: column;
}

.abk-db-card-biodata {
  background: #fff;
}

.abk-db-card-highlight {
  background: linear-gradient(135deg, rgba(255, 251, 235, 0.9) 0%, #fff 100%);
  border-color: rgba(201, 169, 98, 0.25);
  margin-bottom: 18px;
}

.abk-db-card-title,
.abk-db-card h3 {
  margin: 0 0 12px;
  padding-bottom: 8px;
  font-size: 0.88rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--navy, #0f172a);
  border-bottom: 2px solid rgba(184, 134, 11, 0.25);
}

.abk-db-card-inline {
  margin-bottom: 16px;
}

.abk-db-dl {
  margin: 0;
  flex: 1 1 auto;
}

.abk-db-dl-row {
  display: grid;
  grid-template-columns: minmax(100px, 36%) 1fr;
  gap: 6px 14px;
  padding: 9px 0;
  border-bottom: 1px solid rgba(15, 23, 42, 0.05);
}

.abk-db-dl-row:last-child {
  border-bottom: none;
}

.abk-db-dl-row dt {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 700;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.4;
}

.abk-db-dl-row dd {
  margin: 0;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--navy, #0f172a);
  word-break: break-word;
  line-height: 1.45;
}

.abk-db-dl-inline {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 0 16px;
}

.abk-db-penempatan-aktif {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0;
}

.abk-db-penempatan-field {
  display: grid;
  grid-template-columns: minmax(88px, 120px) minmax(0, 1fr);
  gap: 8px 16px;
  align-items: start;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.abk-db-penempatan-field dt {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  line-height: 1.4;
  padding-top: 2px;
}

.abk-db-penempatan-field dd {
  margin: 0;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--navy, #0f172a);
  line-height: 1.45;
  word-break: normal;
  overflow-wrap: anywhere;
}

.abk-db-penempatan-agency dd {
  font-size: 0.92rem;
  letter-spacing: 0.01em;
}

.abk-db-penempatan-dates {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 720px) {
  .abk-db-penempatan-dates {
    grid-template-columns: 1fr;
  }
}

.abk-db-card-doc-identity {
  grid-column: 1 / -1;
}

.abk-db-doc-id-wrap {
  overflow-x: auto;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
}

.abk-db-doc-id-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
}

.abk-db-doc-id-table thead th {
  padding: 10px 14px;
  text-align: left;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
  background: rgba(248, 250, 252, 0.95);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.abk-db-doc-id-table tbody th[scope="row"] {
  padding: 11px 14px;
  text-align: left;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--navy, #0f172a);
  background: rgba(248, 250, 252, 0.5);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
  white-space: nowrap;
  width: 1%;
}

.abk-db-doc-id-table tbody td {
  padding: 11px 14px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
  font-weight: 600;
  color: var(--navy, #0f172a);
  word-break: normal;
}

.abk-db-doc-id-table tbody tr:last-child th,
.abk-db-doc-id-table tbody tr:last-child td {
  border-bottom: none;
}

.abk-db-doc-id-table tbody tr:hover td,
.abk-db-doc-id-table tbody tr:hover th[scope="row"] {
  background: rgba(201, 169, 98, 0.05);
}

.abk-db-doc-summary {
  margin-bottom: 14px;
}

.abk-db-doc-summary-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  color: #0f766e;
  background: rgba(13, 148, 136, 0.1);
  border: 1px solid rgba(13, 148, 136, 0.2);
}

.abk-db-doc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}

.abk-db-doc-card {
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: box-shadow 0.15s, border-color 0.15s;
}

.abk-db-doc-card:hover {
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
}

.abk-db-doc-card.is-uploaded {
  border-color: rgba(22, 163, 74, 0.28);
  background: linear-gradient(180deg, rgba(240, 253, 244, 0.85) 0%, #fff 100%);
}

.abk-db-doc-card.is-empty {
  opacity: 0.78;
  background: rgba(248, 250, 252, 0.8);
}

.abk-db-doc-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 2px;
}

.abk-db-doc-card-head strong {
  font-size: 0.82rem;
  line-height: 1.3;
}

.abk-db-doc-meta {
  margin: 0 0 8px;
  font-size: 0.78rem;
  color: #64748b;
}

.abk-db-doc-card .btn-ghost-sm {
  margin-top: auto;
  align-self: flex-start;
}

.abk-db-subhead {
  margin: 4px 0 12px;
}

.abk-db-subhead-title {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
}

.abk-db-table-wrap {
  overflow-x: auto;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.abk-db-table-wrap-lux {
  margin-bottom: 16px;
}

.abk-db-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.86rem;
}

.abk-db-table-lux thead th {
  background: linear-gradient(180deg, #0f172a 0%, #1e293b 100%);
  color: #f8fafc;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  border-bottom: 2px solid rgba(201, 169, 98, 0.35);
}

.abk-db-table th,
.abk-db-table td {
  padding: 11px 14px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
  text-align: left;
}

.abk-db-table th {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  background: rgba(248, 250, 252, 0.95);
  font-weight: 700;
}

.abk-db-table tbody tr:hover td {
  background: rgba(201, 169, 98, 0.04);
}

.abk-db-xp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}

.abk-db-xp-card {
  padding: 16px 18px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(180deg, #fff 0%, rgba(248, 250, 252, 0.7) 100%);
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.04);
}

.abk-db-xp-card-top {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
}

.abk-db-xp-no {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--gold, #b8860b);
  background: rgba(184, 134, 11, 0.12);
  border: 1px solid rgba(184, 134, 11, 0.25);
  flex-shrink: 0;
}

.abk-db-xp-kapal {
  font-size: 1rem;
  font-weight: 800;
  color: var(--navy, #0f172a);
  line-height: 1.3;
  word-break: break-word;
}

.abk-db-xp-dl {
  margin: 0;
  display: grid;
  gap: 0;
}

.abk-db-xp-row {
  display: grid;
  grid-template-columns: minmax(90px, 38%) 1fr;
  gap: 8px 12px;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(15, 23, 42, 0.06);
}

.abk-db-xp-row:last-child {
  border-bottom: none;
}

.abk-db-xp-row dt {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
}

.abk-db-xp-row dd {
  margin: 0;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--navy, #0f172a);
  word-break: break-word;
}

.abk-db-xp-row-dates dd {
  font-variant-numeric: tabular-nums;
}

.abk-db-monitoring-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.abk-db-monitoring-item {
  padding: 16px 18px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
  border-left: 4px solid #0e7490;
}

.abk-db-monitoring-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
  font-size: 0.78rem;
}

.abk-db-monitoring-cat {
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #0e7490;
}

.abk-db-monitoring-item strong {
  display: block;
  font-size: 0.92rem;
  color: var(--navy, #0f172a);
  margin-bottom: 4px;
}

.abk-db-monitoring-detail {
  margin: 8px 0 0;
  font-size: 0.86rem;
  line-height: 1.55;
  color: #334155;
}

.abk-db-monitoring-by {
  margin: 8px 0 0;
  font-size: 0.76rem;
}

.abk-db-status-log {
  margin-top: 4px;
}

.abk-db-timeline-wrap {
  padding: 4px 0 8px 4px;
}

.abk-db-timeline {
  margin: 0;
}

.abk-db-crewlist-riwayat-card {
  margin-bottom: 20px;
}

.abk-db-crewlist-riwayat-list {
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.abk-db-crewlist-riwayat-item {
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(248, 250, 252, 0.85);
}

.abk-db-crewlist-riwayat-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px 12px;
}

.abk-db-crewlist-riwayat-meta {
  margin: 6px 0 0;
  font-size: 0.82rem;
}

.abk-db-crewlist-riwayat-alasan {
  margin: 8px 0 0;
  font-size: 0.86rem;
  line-height: 1.45;
  color: #334155;
}

.abk-db-crewlist-riwayat-alasan-label {
  font-weight: 600;
  color: #b45309;
}

.abk-db-crewlist-history-table .col-crewlist-alasan {
  max-width: 280px;
  font-size: 0.82rem;
  line-height: 1.4;
}

.abk-db-subhead-hint {
  margin: 4px 0 0;
  font-size: 0.82rem;
}

.abk-db-empty {
  padding: 28px 20px;
  text-align: center;
  border-radius: 12px;
  background: rgba(248, 250, 252, 0.9);
  border: 1px dashed rgba(15, 23, 42, 0.12);
}

.abk-db-empty p {
  margin: 0;
  font-size: 0.88rem;
  color: #64748b;
}

.abk-db-empty-xp {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.abk-db-empty-icon {
  font-size: 2rem;
  opacity: 0.5;
}

.page-abk-database .alert {
  margin: 12px clamp(18px, 2vw, 28px) 0;
}

@media (max-width: 1100px) {
  .abk-db-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .abk-db-hero {
    flex-direction: column;
  }

  .abk-db-hero-actions {
    flex-direction: row;
    flex-wrap: wrap;
    width: 100%;
  }

  .abk-db-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .abk-db-biodata-grid {
    grid-template-columns: 1fr;
  }

  .abk-db-dl-row,
  .abk-db-xp-row {
    grid-template-columns: 1fr;
    gap: 2px;
  }

  .abk-db-section-head {
    flex-direction: column;
    gap: 10px;
  }
}

@media (max-width: 520px) {
  .abk-db-stats {
    grid-template-columns: 1fr;
  }

  .abk-db-nav-label {
    font-size: 0.76rem;
  }
}

/* Custom Report Crew — luxury layout */
.page-custom-report {
  padding: 0 clamp(12px, 2vw, 20px) 28px;
}

.page-custom-report .panel-custom-report {
  overflow: hidden;
}

.page-custom-report .custom-report-toolbar {
  align-items: center;
}

.page-custom-report .custom-report-head {
  flex: 1;
  min-width: 0;
}

.page-custom-report .custom-report-lead {
  margin: 10px 0 0;
  max-width: 560px;
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.55;
}

.page-custom-report .custom-report-alert {
  margin: 0 clamp(20px, 2.5vw, 32px) 0;
}

.custom-report-form {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.custom-report-section-eyebrow {
  margin: 0 0 4px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold-dark);
}

.custom-report-section-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: 0.02em;
}

.custom-report-section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px 20px;
  margin-bottom: 16px;
}

.custom-report-filters-lux {
  margin: 0;
  padding: 22px clamp(20px, 2.5vw, 32px) 24px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.14);
  background:
    radial-gradient(ellipse 80% 120% at 100% 0%, rgba(201, 169, 98, 0.08), transparent 55%),
    linear-gradient(180deg, rgba(250, 248, 245, 0.98) 0%, #fff 100%);
}

.custom-report-filters {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px 16px;
  padding: 18px 20px;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(201, 169, 98, 0.2);
  box-shadow:
    var(--shadow-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.custom-report-filter {
  display: flex;
  flex-direction: column;
  gap: 7px;
  min-width: 0;
}

.custom-report-filter-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold-dark);
}

.custom-report-filter select,
.custom-report-filter input[type="text"] {
  width: 100%;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  border-radius: 10px;
  background: #fff;
  font: inherit;
  color: var(--navy);
  box-shadow: inset 0 1px 2px rgba(15, 23, 41, 0.04);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.custom-report-filter select:focus,
.custom-report-filter input[type="text"]:focus {
  outline: none;
  border-color: rgba(201, 169, 98, 0.65);
  box-shadow:
    0 0 0 3px rgba(201, 169, 98, 0.16),
    inset 0 1px 2px rgba(15, 23, 41, 0.04);
}

.custom-report-filter-search {
  grid-column: span 2;
}

.custom-report-crew-combobox {
  width: 100%;
}

.custom-report-crew-combobox input[type="text"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a8863a' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 38px !important;
}

.custom-report-crew-dropdown {
  border-color: rgba(201, 169, 98, 0.35);
  border-radius: 10px;
  box-shadow: var(--shadow-md);
}

.custom-report-crew-dropdown .custom-report-crew-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  white-space: normal;
}

.custom-report-crew-item-name {
  font-weight: 600;
  color: var(--navy);
}

.custom-report-crew-item-meta {
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 400;
}

.custom-report-search-empty {
  padding: 12px 14px;
  font-size: 0.82rem;
  color: var(--muted);
}

.custom-report-search-status {
  display: block;
  min-height: 1.1em;
  margin-top: 5px;
  font-size: 0.72rem;
  color: var(--muted);
}

.custom-report-filter-check {
  grid-column: 1 / -1;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  margin-top: 2px;
}

.custom-report-check-pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 0.82rem;
  color: var(--navy);
  background: rgba(201, 169, 98, 0.08);
  border: 1px solid rgba(201, 169, 98, 0.22);
}

.custom-report-reset-btn {
  border-color: rgba(201, 169, 98, 0.35) !important;
  color: var(--gold-dark) !important;
}

.custom-report-columns-lux {
  padding: 22px clamp(20px, 2.5vw, 32px) 0;
}

.custom-report-section-head-columns {
  margin-bottom: 14px;
}

.custom-report-field-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px 10px;
}

.custom-report-selected-count {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--navy);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(201, 169, 98, 0.35);
  box-shadow: var(--shadow-sm);
}

.custom-report-groups {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.custom-report-group {
  margin: 0;
  padding: 0;
  border: 1px solid rgba(201, 169, 98, 0.18);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(250, 248, 245, 0.92) 100%);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.custom-report-group-title {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 14px 18px;
  margin: 0;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--navy);
  border-bottom: 1px solid rgba(201, 169, 98, 0.14);
  background:
    linear-gradient(90deg, rgba(201, 169, 98, 0.1) 0%, rgba(255, 255, 255, 0.4) 28%, transparent 100%);
}

.custom-report-group-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  font-size: 1rem;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(201, 169, 98, 0.25);
  box-shadow: var(--shadow-sm);
  flex-shrink: 0;
}

.custom-report-group-name {
  flex: 1;
  min-width: 0;
  font-family: var(--font-display);
  letter-spacing: 0.02em;
}

.custom-report-group-toggle {
  border: 1px solid rgba(201, 169, 98, 0.35);
  background: rgba(255, 255, 255, 0.85);
  color: var(--gold-dark);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
  flex-shrink: 0;
}

.custom-report-group-toggle:hover {
  background: rgba(201, 169, 98, 0.12);
  border-color: rgba(201, 169, 98, 0.55);
  color: var(--navy);
}

.custom-report-check-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 10px;
  padding: 16px 18px 18px;
}

.custom-report-check {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.16);
  background: rgba(255, 255, 255, 0.75);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s, transform 0.15s;
}

.custom-report-check:hover {
  border-color: rgba(201, 169, 98, 0.38);
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.custom-report-check.is-checked {
  border-color: rgba(201, 169, 98, 0.55);
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.12) 0%, rgba(255, 255, 255, 0.95) 100%);
  box-shadow:
    inset 3px 0 0 var(--gold-dark),
    var(--shadow-sm);
}

.custom-report-check input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}

.custom-report-check-box {
  width: 18px;
  height: 18px;
  border-radius: 5px;
  border: 1.5px solid rgba(201, 169, 98, 0.45);
  background: #fff;
  flex-shrink: 0;
  position: relative;
  transition: background 0.2s, border-color 0.2s;
}

.custom-report-check.is-checked .custom-report-check-box {
  background: linear-gradient(135deg, var(--gold-dark) 0%, var(--gold) 100%);
  border-color: var(--gold-dark);
}

.custom-report-check.is-checked .custom-report-check-box::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 2px;
  width: 5px;
  height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.custom-report-check-label {
  font-size: 0.8rem;
  line-height: 1.35;
  color: var(--navy);
  font-weight: 500;
}

.custom-report-actions-lux {
  position: sticky;
  bottom: 0;
  z-index: 20;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px 20px;
  margin-top: 20px;
  padding: 16px clamp(20px, 2.5vw, 32px) 22px;
  border-top: 1px solid rgba(201, 169, 98, 0.2);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82) 0%, rgba(250, 248, 245, 0.98) 100%);
  backdrop-filter: blur(8px);
  box-shadow: 0 -8px 24px rgba(15, 23, 41, 0.06);
}

.custom-report-actions-note {
  margin: 0;
  font-size: 0.78rem;
  color: var(--muted);
}

.custom-report-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.custom-report-actions .btn-primary {
  min-width: 180px;
  padding: 11px 20px;
  font-weight: 700;
  letter-spacing: 0.03em;
  box-shadow:
    0 4px 14px rgba(168, 134, 58, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.custom-report-result {
  margin: 8px clamp(20px, 2.5vw, 32px) 28px;
  padding: 20px 20px 22px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(201, 169, 98, 0.2);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(250, 248, 245, 0.95) 100%);
  box-shadow: var(--shadow-md);
}

.custom-report-result-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 10px 16px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.14);
}

.custom-report-result-head h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.15rem;
  color: var(--navy);
}

.custom-report-result-stat {
  margin: 0;
  font-size: 0.84rem;
  color: var(--muted);
}

.custom-report-result-stat strong {
  color: var(--navy);
  font-size: 1rem;
}

.custom-report-scroll {
  max-height: min(68vh, 680px);
  border-radius: 10px;
  border: 1px solid rgba(201, 169, 98, 0.16);
}

.custom-report-table {
  margin: 0;
}

.custom-report-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: linear-gradient(180deg, var(--navy) 0%, var(--navy-soft) 100%);
  color: #fff;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-color: rgba(201, 169, 98, 0.25);
}

.custom-report-table tbody tr:nth-child(even) {
  background: rgba(250, 248, 245, 0.65);
}

.custom-report-table tbody tr:hover {
  background: rgba(201, 169, 98, 0.08);
}

.custom-report-table th,
.custom-report-table td {
  white-space: nowrap;
  font-size: 0.8rem;
}

@media (max-width: 1100px) {
  .custom-report-filters {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .custom-report-filter-search {
    grid-column: span 2;
  }
}

@media (max-width: 720px) {
  .page-custom-report .custom-report-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .custom-report-filters {
    grid-template-columns: 1fr;
    padding: 14px;
  }

  .custom-report-filter-search {
    grid-column: auto;
  }

  .custom-report-section-head,
  .custom-report-section-head-columns {
    flex-direction: column;
    align-items: stretch;
  }

  .custom-report-field-toolbar {
    justify-content: flex-start;
  }

  .custom-report-check-grid {
    grid-template-columns: 1fr;
  }

  .custom-report-actions-lux {
    flex-direction: column;
    align-items: stretch;
  }

  .custom-report-actions {
    justify-content: stretch;
  }

  .custom-report-actions .btn-primary,
  .custom-report-actions .btn-ghost {
    flex: 1 1 100%;
  }
}

/* Pengumuman ABK */
.page-announcements {
  max-width: 980px;
  margin: 0 auto;
}
.panel-announcements .ann-flash {
  margin: 18px 28px 0;
}
.ann-upload-block,
.ann-list-block {
  padding: 24px 28px;
  border-top: 1px solid rgba(201, 169, 98, 0.16);
}
.ann-upload-block-prominent {
  background:
    radial-gradient(ellipse 80% 120% at 100% 0%, rgba(201, 169, 98, 0.12), transparent 55%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(250, 248, 245, 0.92) 100%);
}
.ann-upload-head {
  margin-bottom: 14px;
}
.ann-upload-hint {
  margin: 6px 0 0;
  font-size: 0.88rem;
}
.ann-upload-form-card {
  padding: 18px;
  border: 1px solid rgba(201, 169, 98, 0.35);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: var(--shadow-sm);
}
.ann-upload-action {
  display: flex;
  align-items: end;
}
.ann-flash-inline {
  margin: 0;
}
.ann-upload-block-readonly {
  padding-top: 18px;
  padding-bottom: 18px;
}
.ann-upload-block-briefing {
  background:
    radial-gradient(ellipse 80% 120% at 0% 0%, rgba(26, 54, 93, 0.08), transparent 55%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 250, 252, 0.92) 100%);
}
.ann-upload-btn-briefing {
  background: linear-gradient(135deg, #1a365d 0%, #2c5282 100%);
  border-color: #1a365d;
}
.ann-list-block-briefing {
  border-bottom: none;
}
.ann-section-title {
  margin: 0 0 16px;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: 0.02em;
}
.ann-upload-form {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 14px;
  align-items: end;
}
.ann-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ann-field-label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold-dark);
}
.ann-field-hint {
  font-size: 0.78rem;
  color: var(--muted, #64748b);
}
.ann-upload-form input[type="text"],
.ann-upload-form input[type="url"],
.ann-upload-form input[type="file"] {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid rgba(201, 169, 98, 0.35);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.85);
  font: inherit;
}
.ann-upload-form input[type="url"],
.ann-input-url {
  text-transform: none;
  letter-spacing: 0;
}
.ann-upload-btn {
  white-space: nowrap;
  align-self: end;
}
.ann-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ann-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border-radius: 12px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(250, 248, 245, 0.92) 100%);
  box-shadow: var(--shadow-sm);
}
.ann-item.is-inactive {
  opacity: 0.72;
  background: rgba(245, 245, 245, 0.85);
}
.ann-item-title {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--navy);
}
.ann-item-meta {
  margin: 0;
  font-size: 0.82rem;
  color: var(--muted);
}
.ann-item-dot {
  margin: 0 4px;
}
.ann-item-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.ann-inline-form {
  display: inline;
  margin: 0;
}
.ann-badge {
  font-size: 0.72rem;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(120, 120, 120, 0.12);
  color: #666;
}
.ann-badge-active {
  background: rgba(34, 139, 34, 0.12);
  color: #1f6b1f;
  font-weight: 600;
}
.ann-btn-danger {
  color: #b42318;
  border-color: rgba(180, 35, 24, 0.35);
}
.ann-empty {
  padding: 28px 18px;
  text-align: center;
  color: var(--muted);
  border: 1px dashed rgba(201, 169, 98, 0.35);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.5);
}
@media (max-width: 860px) {
  .ann-upload-form {
    grid-template-columns: 1fr;
  }
  .ann-upload-btn {
    width: 100%;
  }
  .ann-item {
    flex-direction: column;
    align-items: stretch;
  }
  .ann-item-actions {
    justify-content: flex-start;
  }
}

/* —— Modul keuangan —— */
.finance-panel .finance-dash-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px;
  margin: 18px 0;
}
.finance-dash-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 14px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.98), rgba(247, 243, 235, 0.92));
  text-decoration: none;
  color: inherit;
  transition: transform 0.12s, box-shadow 0.15s;
}
.finance-dash-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(15, 23, 41, 0.1);
  text-decoration: none;
}
.finance-dash-icon { font-size: 1.6rem; }
.finance-dash-value { font-size: 1.05rem; color: var(--navy, #0f1729); }
.finance-quick-actions { display: flex; flex-wrap: wrap; gap: 10px; margin: 12px 0 20px; }
.finance-section-title { margin: 24px 0 12px; font-size: 1rem; color: var(--navy, #0f1729); }
.finance-form { margin: 20px 0; padding: 18px; border-radius: 12px; border: 1px solid rgba(201, 169, 98, 0.22); background: rgba(255, 255, 255, 0.6); }
.finance-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px 16px;
  margin-bottom: 14px;
}
.finance-form-grid .finance-span-2 { grid-column: 1 / -1; }
.finance-summary-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin: 16px 0 20px;
}
.finance-summary-card {
  padding: 14px 16px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.finance-summary-card-accent { border-color: rgba(201, 169, 98, 0.45); }
.finance-summary-card-gold {
  border-color: var(--gold, #c9a962);
  background: linear-gradient(165deg, rgba(201, 169, 98, 0.12), #fff);
}
.finance-amt-in { color: #166534; font-weight: 700; }
.finance-amt-out { color: #b45309; font-weight: 700; }
.finance-search { display: flex; gap: 10px; margin-bottom: 16px; flex-wrap: wrap; }
.finance-search input { flex: 1; min-width: 200px; }
.finance-alloc-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.finance-alloc-sum { font-size: 0.9rem; }
.finance-diff-ok { color: #166534; }
.finance-diff-bad { color: #b91c1c; }
.finance-alloc-table input[type="text"],
.finance-alloc-table select { width: 100%; min-width: 0; }
.finance-inline-delete { display: inline; margin-left: 8px; }
.btn-link-danger {
  background: none;
  border: none;
  color: #b91c1c;
  cursor: pointer;
  text-decoration: underline;
  font: inherit;
  padding: 0;
}
.btn-sm { font-size: 0.82rem; padding: 4px 10px; }
.finance-close-form { border-color: rgba(201, 169, 98, 0.4); }

.finance-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(15, 23, 41, 0.08);
}
.finance-subnav-link {
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 0.88rem;
  text-decoration: none;
  color: var(--navy, #0f1729);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 23, 41, 0.1);
  transition: background 0.12s, border-color 0.12s;
}
.finance-subnav-link:hover {
  border-color: rgba(201, 169, 98, 0.45);
  text-decoration: none;
}
.finance-subnav-active {
  background: linear-gradient(165deg, rgba(201, 169, 98, 0.22), rgba(255, 255, 255, 0.95));
  border-color: var(--gold, #c9a962);
  font-weight: 600;
}
.finance-balance-banner {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 20px;
  padding: 16px 20px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(15, 23, 41, 0.04), rgba(201, 169, 98, 0.12));
  border: 1px solid rgba(201, 169, 98, 0.28);
}
.finance-balance-banner strong {
  font-size: 1.35rem;
  color: var(--navy, #0f1729);
}
.finance-form-title {
  margin: 0 0 14px;
  font-size: 1rem;
  color: var(--navy, #0f1729);
}
.finance-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}
.finance-proof-upload {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px dashed rgba(201, 169, 98, 0.45);
  background: rgba(255, 255, 255, 0.7);
}
.finance-proof-upload-label { font-weight: 600; font-size: 0.9rem; }
.finance-proof-current { font-size: 0.85rem; color: var(--muted, #64748b); }
.finance-proof-current a { font-weight: 600; }
.finance-req { color: #b91c1c; font-style: normal; }
.finance-proof-link {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 0.82rem;
  font-weight: 600;
  background: rgba(22, 101, 52, 0.1);
  color: #166534;
  text-decoration: none;
}
.finance-proof-link:hover { background: rgba(22, 101, 52, 0.18); text-decoration: none; }
.finance-proof-missing { color: #94a3b8; font-size: 0.85rem; }
.finance-proof-viewonly { margin: 12px 0 18px; font-size: 0.9rem; }
.finance-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 0.78rem;
  font-weight: 600;
}
.finance-badge-in { background: rgba(22, 101, 52, 0.12); color: #166534; }
.finance-badge-out { background: rgba(180, 83, 9, 0.12); color: #b45309; }
.finance-td-desc { max-width: 220px; word-break: break-word; }
.finance-table-wrap { margin-bottom: 24px; }
.finance-data-table th:last-child,
.finance-data-table td:last-child { white-space: nowrap; }

/* —— Keuangan: halaman kas (mewah & rapi) —— */
.page-finance-cash {
  padding-bottom: 28px;
}
.finance-cash-abk-panel {
  margin: 4px 0 0;
  padding: 16px 18px;
  border-radius: 14px;
  border: 1px dashed rgba(201, 169, 98, 0.55);
  background: rgba(201, 169, 98, 0.06);
}
.finance-cash-abk-panel-head {
  margin-bottom: 0;
}
.finance-cash-abk-toggle {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.92rem;
  cursor: pointer;
  line-height: 1.45;
}
.finance-cash-abk-toggle input {
  margin-top: 3px;
  flex-shrink: 0;
}
.finance-cash-abk-hint {
  margin: 8px 0 0 26px;
}
.finance-cash-abk-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(15, 23, 41, 0.08);
}
.finance-field-abk-pick .finance-cash-crew-combobox {
  position: relative;
}
.finance-cash-crew-selected {
  margin: 8px 0 0;
  font-size: 0.9rem;
}
.finance-cash-crew-clear {
  margin-left: 8px;
  padding: 0;
  border: 0;
  background: none;
  color: var(--accent, #b8860b);
  font-size: 0.85rem;
  cursor: pointer;
  text-decoration: underline;
}
.finance-cash-collective-toggle {
  margin: 12px 0 0;
  padding-top: 12px;
  border-top: 1px dashed rgba(15, 23, 41, 0.12);
}
.finance-cash-collective-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 18px;
  margin-top: 10px;
}
.finance-cash-collective-list-wrap {
  grid-column: 1 / -1;
}
.finance-cash-collective-list {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.finance-cash-collective-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px 6px 12px;
  border-radius: 999px;
  background: linear-gradient(165deg, rgba(201, 169, 98, 0.2), #fff);
  border: 1px solid rgba(201, 169, 98, 0.45);
  font-size: 0.82rem;
}
.finance-cash-collective-remove {
  width: 22px;
  height: 22px;
  border: 0;
  border-radius: 50%;
  background: rgba(15, 23, 41, 0.08);
  color: #334155;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
}
.finance-cash-collective-remove:hover {
  background: rgba(180, 83, 9, 0.2);
  color: #b45309;
}
.finance-cash-collective-split {
  grid-column: 1 / -1;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(15, 23, 41, 0.04);
  border: 1px solid rgba(201, 169, 98, 0.3);
  font-size: 0.88rem;
}
.finance-cash-collective-split strong {
  color: var(--navy, #0f1729);
}
.finance-crew-add-label {
  margin-left: auto;
  font-size: 0.72rem;
  font-weight: 800;
  color: #166534;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.finance-tx-abk-collective {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
  background: rgba(201, 169, 98, 0.25);
  border: 1px solid rgba(201, 169, 98, 0.4);
}
@media (max-width: 720px) {
  .finance-cash-collective-block {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 720px) {
  .finance-cash-abk-fields {
    grid-template-columns: 1fr;
  }
}
.finance-page-lead {
  max-width: 42rem;
  margin-top: 4px;
}
.finance-page-alert {
  margin: 0 0 16px;
}
.finance-balance-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px 24px;
  margin: 0 0 24px;
  padding: 22px 26px;
  border-radius: 16px;
  border: 1px solid rgba(201, 169, 98, 0.38);
  background:
    linear-gradient(135deg, rgba(15, 23, 41, 0.03) 0%, rgba(201, 169, 98, 0.14) 48%, rgba(255, 255, 255, 0.92) 100%);
  box-shadow: 0 12px 32px rgba(15, 23, 41, 0.06);
}
.finance-balance-hero-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted, #64748b);
}
.finance-balance-hero-hint {
  display: block;
  margin-top: 4px;
  font-size: 0.82rem;
  color: var(--muted, #64748b);
}
.finance-balance-hero-value {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  color: var(--navy, #0f1729);
  letter-spacing: -0.02em;
}
.finance-form-card {
  margin: 0 0 28px;
  padding: 0;
  border-radius: 16px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background: linear-gradient(180deg, #fff 0%, #faf8f4 100%);
  box-shadow: 0 8px 28px rgba(15, 23, 41, 0.05);
  overflow: hidden;
}
.finance-form-card-head {
  padding: 20px 24px 12px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.15);
  background: linear-gradient(180deg, rgba(201, 169, 98, 0.08), transparent);
}
.finance-form-sub {
  margin: 6px 0 0;
  font-size: 0.85rem;
  color: var(--muted, #64748b);
}
.finance-form-grid-lux {
  padding: 20px 24px 8px;
  gap: 16px 20px;
}
.finance-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0;
}
.finance-field-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--navy, #0f1729);
}
.finance-field input[type="text"],
.finance-field input[type="date"],
.finance-field select,
.finance-select {
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 41, 0.12);
  background: #fff;
  font-size: 0.92rem;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.finance-field input:focus,
.finance-field select:focus {
  outline: none;
  border-color: rgba(201, 169, 98, 0.65);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.18);
}
.finance-amount-wrap {
  display: flex;
  align-items: stretch;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 41, 0.12);
  background: #fff;
  overflow: hidden;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.finance-amount-wrap:focus-within {
  border-color: rgba(201, 169, 98, 0.65);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.18);
}
.finance-amount-prefix {
  display: flex;
  align-items: center;
  padding: 0 12px;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
  background: linear-gradient(180deg, rgba(201, 169, 98, 0.12), rgba(201, 169, 98, 0.04));
  border-right: 1px solid rgba(15, 23, 41, 0.08);
}
.finance-amount-wrap .finance-idr-input {
  flex: 1;
  border: none;
  border-radius: 0;
  box-shadow: none;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.finance-amount-wrap .finance-idr-input:focus {
  box-shadow: none;
}
.finance-field-hint,
.finance-form-footnote {
  font-size: 0.8rem;
  color: var(--muted, #64748b);
  line-height: 1.45;
}
.finance-form-footnote {
  margin: 0 24px;
  padding-bottom: 4px;
}
.finance-form-card .finance-form-actions {
  padding: 12px 24px 22px;
  margin: 0;
  border-top: 1px solid rgba(15, 23, 41, 0.06);
  background: rgba(250, 248, 245, 0.6);
}
.finance-btn-submit {
  min-width: 180px;
  padding: 11px 22px;
}
.finance-proof-dropzone {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 20px 16px;
  border-radius: 12px;
  border: 1px dashed rgba(201, 169, 98, 0.5);
  background: rgba(255, 255, 255, 0.85);
  text-align: center;
  transition: border-color 0.15s, background 0.15s;
}
.finance-proof-dropzone:hover,
.finance-proof-dropzone.has-file {
  border-color: var(--gold, #c9a962);
  background: rgba(201, 169, 98, 0.06);
}
.finance-proof-file-input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}
.finance-proof-dropzone-icon {
  font-size: 1.4rem;
  line-height: 1;
}
.finance-proof-dropzone-main {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--navy, #0f1729);
}
.finance-proof-filename {
  font-size: 0.8rem;
  color: var(--muted, #64748b);
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.finance-proof-current {
  margin: 0 0 8px;
  font-size: 0.85rem;
}
.finance-history-block {
  margin-top: 8px;
}
.finance-tx-history {
  margin-top: 32px;
  padding: 0;
  border-radius: 18px;
  border: 1px solid rgba(201, 169, 98, 0.32);
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.98) 0%, rgba(250, 248, 244, 0.96) 55%, rgba(248, 250, 252, 0.94) 100%);
  box-shadow:
    0 16px 40px rgba(15, 23, 41, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
  overflow: hidden;
}
.finance-tx-history-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px 24px;
  padding: 22px 26px 18px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.22);
  background:
    linear-gradient(135deg, rgba(15, 23, 41, 0.04) 0%, rgba(201, 169, 98, 0.14) 42%, rgba(255, 255, 255, 0.5) 100%);
}
.finance-tx-history-title {
  margin: 0;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1.15rem, 1.4vw, 1.35rem);
  font-weight: 700;
  color: var(--navy, #0f1729);
  letter-spacing: 0.01em;
}
.finance-tx-history-lead {
  margin: 6px 0 0;
  font-size: 0.86rem;
  max-width: 36rem;
}
.finance-tx-history-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  justify-content: flex-end;
}
.finance-tx-stat {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  color: #475569;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 23, 41, 0.08);
  box-shadow: 0 2px 8px rgba(15, 23, 41, 0.04);
}
.finance-tx-stat strong {
  font-weight: 800;
  color: var(--navy, #0f1729);
}
.finance-tx-stat-in {
  color: #166534;
  border-color: rgba(22, 101, 52, 0.22);
  background: linear-gradient(165deg, rgba(220, 252, 231, 0.65), rgba(255, 255, 255, 0.9));
}
.finance-tx-stat-out {
  color: #b45309;
  border-color: rgba(180, 83, 9, 0.22);
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.55), rgba(255, 255, 255, 0.9));
}
.finance-tx-history-empty {
  padding: 48px 28px 52px;
  text-align: center;
}
.finance-tx-history-empty-icon {
  display: block;
  font-size: 2.2rem;
  margin-bottom: 12px;
  opacity: 0.45;
}
.finance-tx-history-empty p {
  margin: 0 0 6px;
  font-size: 0.95rem;
  color: var(--navy, #0f1729);
}
.finance-tx-history-shell {
  padding: 4px 12px 16px;
}
.finance-tx-table-wrap {
  margin: 0;
  border: none;
  border-radius: 12px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.finance-tx-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.88rem;
}
.finance-tx-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 14px 16px;
  background: linear-gradient(180deg, #1a2744 0%, #0f1729 100%);
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border: none;
  white-space: nowrap;
}
.finance-tx-table thead th:first-child {
  border-radius: 10px 0 0 0;
}
.finance-tx-table thead th:last-child {
  border-radius: 0 10px 0 0;
}
.finance-tx-table tbody tr.finance-tx-row {
  transition: background 0.15s ease, box-shadow 0.15s ease;
}
.finance-tx-table tbody tr.finance-tx-row:nth-child(even) {
  background: rgba(248, 250, 252, 0.65);
}
.finance-tx-table tbody tr.finance-tx-row:hover {
  background: rgba(201, 169, 98, 0.1);
  box-shadow: inset 3px 0 0 var(--gold, #c9a962);
}
.finance-tx-table tbody td {
  padding: 14px 16px;
  vertical-align: middle;
  border-bottom: 1px solid rgba(15, 23, 41, 0.06);
  color: #334155;
}
.finance-tx-table tbody tr:last-child td {
  border-bottom: none;
}
.finance-tx-date time {
  font-weight: 600;
  color: var(--navy, #0f1729);
  white-space: nowrap;
}
.finance-tx-dir {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px 5px 10px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
}
.finance-tx-dir-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.15em;
  height: 1.15em;
  border-radius: 50%;
  font-size: 0.7rem;
  line-height: 1;
}
.finance-tx-dir-in {
  color: #166534;
  background: linear-gradient(165deg, rgba(220, 252, 231, 0.95), rgba(187, 247, 208, 0.5));
  border: 1px solid rgba(22, 101, 52, 0.25);
}
.finance-tx-dir-in .finance-tx-dir-icon {
  background: rgba(22, 101, 52, 0.12);
}
.finance-tx-dir-out {
  color: #b45309;
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.95), rgba(253, 230, 138, 0.35));
  border: 1px solid rgba(180, 83, 9, 0.28);
}
.finance-tx-dir-out .finance-tx-dir-icon {
  background: rgba(180, 83, 9, 0.12);
}
.finance-tx-cat {
  font-weight: 600;
  color: #475569;
}
.finance-tx-amt .finance-tx-amt-value {
  display: inline-block;
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  font-variant-numeric: tabular-nums;
}
.finance-tx-desc {
  max-width: 280px;
  line-height: 1.45;
  color: #64748b;
}
.finance-tx-abk-link {
  font-weight: 700;
  color: var(--navy, #0f1729);
  text-decoration: none;
  border-bottom: 1px solid rgba(201, 169, 98, 0.45);
}
.finance-tx-abk-link:hover {
  color: var(--gold-dark, #9a7b3c);
}
.finance-proof-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  text-decoration: none;
  color: #166534;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.95), rgba(220, 252, 231, 0.7));
  border: 1px solid rgba(22, 101, 52, 0.28);
  box-shadow: 0 2px 8px rgba(22, 101, 52, 0.08);
  transition: transform 0.12s, box-shadow 0.15s, border-color 0.15s;
}
.finance-proof-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(22, 101, 52, 0.45);
  box-shadow: 0 4px 12px rgba(22, 101, 52, 0.14);
}
.finance-proof-btn-icon {
  font-size: 0.85rem;
  line-height: 1;
}
.finance-proof-missing {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.76rem;
  color: #94a3b8;
}
.finance-proof-missing-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #cbd5e1;
}
.finance-table-lux {
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(15, 23, 41, 0.04);
}
.finance-table-lux .finance-data-table thead th {
  background: linear-gradient(180deg, #f8f6f1, #f3f0ea);
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.page-finance-cash .finance-tx-history .finance-tx-table-wrap {
  border: 1px solid rgba(15, 23, 41, 0.06);
  border-radius: 12px;
  background: #fff;
}
@media (max-width: 900px) {
  .finance-tx-history-head {
    flex-direction: column;
    align-items: flex-start;
  }
  .finance-tx-history-stats {
    justify-content: flex-start;
  }
}
@media (max-width: 768px) {
  .finance-tx-table thead {
    display: none;
  }
  .finance-tx-table tbody tr.finance-tx-row {
    display: block;
    margin: 12px 8px;
    padding: 4px 0;
    border-radius: 12px;
    border: 1px solid rgba(15, 23, 41, 0.08);
    background: #fff !important;
    box-shadow: 0 4px 14px rgba(15, 23, 41, 0.05);
  }
  .finance-tx-table tbody tr.finance-tx-row:hover {
    box-shadow: 0 6px 18px rgba(15, 23, 41, 0.08);
  }
  .finance-tx-table tbody td {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 14px;
    border-bottom: 1px solid rgba(15, 23, 41, 0.05);
    text-align: right;
  }
  .finance-tx-table tbody td::before {
    content: attr(data-label);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
    text-align: left;
    flex-shrink: 0;
  }
  .finance-tx-table tbody td.finance-th-amt {
    text-align: right;
  }
  .finance-tx-desc {
    max-width: none;
  }
}
.finance-th-amt {
  text-align: right;
  white-space: nowrap;
}
.finance-empty-row {
  text-align: center;
  padding: 24px !important;
}
.finance-panel-cash .finance-subnav {
  margin-bottom: 22px;
}
@media (max-width: 640px) {
  .finance-balance-hero {
    flex-direction: column;
    align-items: flex-start;
  }
  .finance-form-grid-lux {
    grid-template-columns: 1fr;
  }
}

/* —— Keuangan: semua halaman (shared) —— */
.page-finance {
  padding-bottom: 28px;
}
.finance-page-head-split {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
}
.finance-head-cta {
  flex-shrink: 0;
}
.finance-search-lux {
  margin: 0 0 22px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(201, 169, 98, 0.22);
  background: linear-gradient(180deg, #fff, #faf8f4);
  box-shadow: 0 4px 16px rgba(15, 23, 41, 0.04);
}
.finance-search-lux-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.finance-search-lux-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
}
.finance-search-lux-actions .btn-primary,
.finance-search-lux-actions .btn-ghost,
.finance-search-lux-btn {
  width: auto;
  flex: 0 0 auto;
  min-width: 96px;
}
.finance-search-lux-field {
  flex: 1;
  min-width: 200px;
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 41, 0.1);
  background: #fff;
}
.finance-search-lux-field-combobox {
  align-items: stretch;
  padding-right: 0;
}
.finance-search-lux-field-combobox .finance-crew-search-combobox {
  flex: 1;
  min-width: 0;
}
.finance-search-lux-field-combobox .finance-crew-search-combobox input {
  width: 100%;
  border: none;
  background: transparent;
  padding: 10px 0;
  font-size: 0.92rem;
  min-width: 0;
}
.finance-search-lux-field-combobox .finance-crew-search-combobox input:focus {
  outline: none;
  box-shadow: none;
}
.finance-crew-search-dropdown {
  border-radius: 12px;
  border-color: rgba(201, 169, 98, 0.35);
  box-shadow: 0 12px 32px rgba(15, 23, 41, 0.12);
}
.finance-crew-search-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 10px 14px;
}
.finance-crew-search-item-name {
  font-weight: 600;
  color: var(--navy, #0f1729);
}
.finance-crew-search-item-meta {
  font-size: 0.78rem;
  color: var(--muted, #64748b);
}
.finance-crew-search-empty {
  padding: 12px 14px;
  font-size: 0.85rem;
  color: var(--muted, #64748b);
}
.finance-search-crew-autocomplete .finance-crew-search-hint {
  flex: 1 1 100%;
  width: 100%;
  margin: 4px 0 0;
  font-size: 0.8rem;
}
.finance-search-crew-autocomplete .finance-search-lux-inner {
  align-items: center;
}
.finance-search-lux-field:focus-within {
  border-color: rgba(201, 169, 98, 0.55);
  box-shadow: 0 0 0 3px rgba(201, 169, 98, 0.15);
}
.finance-search-lux-icon {
  color: var(--muted, #64748b);
  font-size: 1.1rem;
}
.finance-search-lux-field input {
  flex: 1;
  border: none;
  background: transparent;
  padding: 10px 0;
  font-size: 0.92rem;
  min-width: 0;
}
.finance-search-lux-field input:focus {
  outline: none;
  box-shadow: none;
}
.finance-search-lux-btn {
  padding: 10px 22px;
}
.finance-dash-grid-lux {
  gap: 16px;
  margin: 8px 0 22px;
}
.finance-dash-card-lux {
  padding: 20px 22px;
  border-radius: 16px;
  box-shadow: 0 10px 28px rgba(15, 23, 41, 0.06);
}
.finance-dash-card-lux:hover {
  box-shadow: 0 14px 36px rgba(15, 23, 41, 0.1);
}
.finance-dash-card-label {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--navy, #0f1729);
}
.finance-dash-hint {
  font-size: 0.82rem;
  color: var(--muted, #64748b);
}
.finance-quick-actions-lux {
  margin: 0 0 24px;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(201, 169, 98, 0.06);
  border: 1px solid rgba(201, 169, 98, 0.18);
}
.finance-summary-cards-lux {
  gap: 14px;
  margin: 0 0 22px;
}
.finance-summary-cards-lux .finance-summary-card {
  padding: 16px 18px;
  border-radius: 14px;
  box-shadow: 0 4px 14px rgba(15, 23, 41, 0.04);
}
.finance-summary-cards-lux .finance-summary-card strong {
  font-size: 1.05rem;
}
.finance-td-abk strong {
  display: block;
  color: var(--navy, #0f1729);
}
.finance-abk-uniq {
  display: block;
  font-size: 0.8rem;
  color: var(--muted, #64748b);
  margin-top: 2px;
}
.finance-rate-mini {
  display: block;
  font-size: 0.75rem;
  color: var(--muted, #64748b);
  margin-top: 2px;
}
.finance-badge-pending {
  background: rgba(100, 116, 139, 0.12);
  color: #475569;
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 0.78rem;
  font-weight: 600;
}
.finance-btn-detail {
  white-space: nowrap;
}
.finance-empty-row {
  text-align: center;
  padding: 32px 16px !important;
  vertical-align: middle;
}
.finance-empty-title {
  margin: 0 0 6px;
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.finance-empty-inline {
  margin: 0 0 16px;
}
.finance-td-actions {
  white-space: nowrap;
}
.finance-amount-wrap-rate .finance-rate-idr {
  flex: 1;
  border: none;
  border-radius: 0;
  padding: 10px 12px;
  font-weight: 600;
}
.finance-amount-suffix {
  display: flex;
  align-items: center;
  padding: 0 12px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--muted, #64748b);
  background: rgba(15, 23, 41, 0.04);
  border-left: 1px solid rgba(15, 23, 41, 0.08);
}
.finance-usd-preview-wrap {
  padding: 14px 16px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.1), rgba(255, 255, 255, 0.9));
  border: 1px solid rgba(201, 169, 98, 0.25);
}
.finance-usd-preview-value {
  display: block;
  margin-top: 6px;
  font-size: 1.25rem;
  color: var(--navy, #0f1729);
}
.finance-textarea {
  min-height: 72px;
  resize: vertical;
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(15, 23, 41, 0.12);
}
.finance-subnav-lux {
  padding-bottom: 16px;
  margin-bottom: 20px;
}
.finance-subnav-with-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 14px 20px;
  border-bottom: 1px solid rgba(15, 23, 41, 0.08);
}
.finance-subnav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.finance-subnav-cash-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  border-radius: 14px;
  text-decoration: none;
  color: #fff;
  background: linear-gradient(135deg, #0f1729 0%, #1e293b 55%, #334155 100%);
  border: 1px solid rgba(201, 169, 98, 0.55);
  box-shadow: 0 8px 24px rgba(15, 23, 41, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  margin-left: auto;
}
.finance-subnav-cash-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(15, 23, 41, 0.28), 0 0 0 1px rgba(201, 169, 98, 0.45);
  text-decoration: none;
  color: #fff;
}
.finance-subnav-cash-cta.is-current {
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.95) 0%, #c9a962 45%, #b8923f 100%);
  color: #0f1729;
  border-color: rgba(15, 23, 41, 0.15);
}
.finance-subnav-cash-cta.is-current:hover {
  color: #0f1729;
}
.finance-subnav-cash-icon {
  font-size: 1.35rem;
  line-height: 1;
}
.finance-subnav-cash-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
  line-height: 1.2;
}
.finance-subnav-cash-text strong {
  font-size: 0.92rem;
  letter-spacing: 0.02em;
}
.finance-subnav-cash-text small {
  font-size: 0.68rem;
  opacity: 0.85;
  font-weight: 500;
}
.finance-cash-hub-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px 24px;
  margin: 0 0 22px;
  padding: 18px 22px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(15, 23, 41, 0.92) 0%, rgba(30, 41, 59, 0.88) 100%);
  border: 1px solid rgba(201, 169, 98, 0.4);
  box-shadow: 0 10px 32px rgba(15, 23, 41, 0.15);
  color: #f8fafc;
}
.finance-cash-hub-eyebrow {
  display: block;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(201, 169, 98, 0.95);
  margin-bottom: 6px;
}
.finance-cash-hub-title {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.5;
  max-width: 52rem;
  color: rgba(248, 250, 252, 0.92);
}
.finance-cash-hub-balance {
  margin: 8px 0 0;
  font-size: 0.82rem;
}
.finance-cash-hub-balance strong {
  color: #fde68a;
}
.finance-cash-hub-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.finance-cash-hub-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  border-radius: 14px;
  text-decoration: none;
  background: linear-gradient(165deg, #fde68a 0%, #c9a962 50%, #b8923f 100%);
  color: #0f1729;
  font-weight: 700;
  box-shadow: 0 6px 20px rgba(201, 169, 98, 0.35);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.finance-cash-hub-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(201, 169, 98, 0.45);
  text-decoration: none;
  color: #0f1729;
}
.finance-cash-hub-cta-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: rgba(15, 23, 41, 0.12);
  font-size: 1.1rem;
  font-weight: 700;
}
.finance-cash-hub-cta span small,
.finance-cash-hub-cta-inline span small {
  display: block;
  font-size: 0.68rem;
  font-weight: 600;
  opacity: 0.75;
}
.finance-cash-hub-cta-inline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  border-radius: 14px;
  text-decoration: none;
  background: linear-gradient(165deg, #0f1729, #1e293b);
  color: #fff;
  border: 1px solid rgba(201, 169, 98, 0.45);
}
.finance-cash-hub-cta-inline:hover {
  color: #fff;
  text-decoration: none;
}
.finance-cash-hub-secondary {
  padding: 10px 16px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  color: rgba(248, 250, 252, 0.9);
  border: 1px solid rgba(255, 255, 255, 0.25);
  text-decoration: none;
}
.finance-cash-hub-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
  text-decoration: none;
  color: #fff;
}
.finance-cash-hub-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: linear-gradient(165deg, rgba(201, 169, 98, 0.35), rgba(201, 169, 98, 0.15));
  border: 1px solid rgba(201, 169, 98, 0.45);
  color: var(--navy, #0f1729);
}
.finance-dash-grid-featured {
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .finance-dash-grid-featured {
    grid-template-columns: 1.2fr 1fr 1fr;
  }
  .finance-dash-card-primary {
    grid-row: span 1;
  }
}
.finance-dash-card-primary {
  border-color: rgba(201, 169, 98, 0.55);
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.45) 0%, rgba(255, 255, 255, 0.98) 55%);
  box-shadow: 0 8px 28px rgba(201, 169, 98, 0.18);
}
.finance-dash-card-cta {
  margin-top: 8px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
  opacity: 0.75;
}
.finance-dash-card-primary:hover .finance-dash-card-cta {
  opacity: 1;
}
.finance-quick-actions-minimal {
  justify-content: flex-start;
}
.page-finance-cash .finance-panel-cash,
.page-finance-loans,
.page-finance-dash,
.page-finance-transfers,
.page-finance-loan-detail,
.page-finance-transfer-form {
  min-height: 200px;
}

/* Transfer agency — form mewah */
.page-finance-transfer-form .finance-transfer-form-stack {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-top: 8px;
}
.page-finance-transfer-form .finance-form-grid-transfer {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.page-finance-transfer-form .finance-field-amount,
.page-finance-transfer-form .finance-field-proof,
.page-finance-transfer-form .finance-span-2 {
  grid-column: 1 / -1;
}
.page-finance-transfer-form .finance-field-amount .finance-amount-wrap {
  max-width: 100%;
}
.page-finance-transfer-form .finance-field-amount .finance-idr-input,
.page-finance-transfer-form .finance-field-amount .finance-usd-input {
  min-width: 8ch;
}
.finance-transfer-idr-preview-wrap {
  padding: 14px 16px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(15, 23, 41, 0.04), rgba(255, 255, 255, 0.95));
  border: 1px solid rgba(15, 23, 41, 0.1);
}
.finance-transfer-idr-preview {
  display: block;
  margin-top: 6px;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.finance-field-usd .finance-amount-prefix {
  background: linear-gradient(180deg, rgba(15, 23, 41, 0.08), rgba(15, 23, 41, 0.02));
}
.page-finance-transfer-form .finance-alloc-card {
  margin-bottom: 0;
}
.page-finance-transfer-form .finance-alloc-toolbar-lux {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px 20px;
  padding: 16px 24px 12px;
  border-bottom: 1px solid rgba(15, 23, 41, 0.06);
}
.page-finance-transfer-form .finance-alloc-sum-box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  padding: 10px 16px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.12), rgba(255, 255, 255, 0.95));
  border: 1px solid rgba(201, 169, 98, 0.28);
  font-size: 0.88rem;
  color: var(--navy, #0f1729);
}
.page-finance-transfer-form .finance-alloc-sum-box strong {
  font-weight: 700;
}
.page-finance-transfer-form .finance-alloc-sum-sep {
  color: var(--muted, #64748b);
}
.page-finance-transfer-form .finance-alloc-wrap {
  margin: 0 24px 20px;
}
.page-finance-transfer-form .finance-amount-wrap-inline {
  min-width: 140px;
}
.page-finance-transfer-form .finance-td-amt-input {
  min-width: 160px;
}
.page-finance-transfer-form .finance-form-actions-sticky {
  margin-top: 4px;
}
@media (min-width: 900px) {
  .page-finance-transfer-form .finance-form-grid-transfer {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .page-finance-transfer-form .finance-field-amount,
  .page-finance-transfer-form .finance-field-proof {
    grid-column: 1 / -1;
  }
}
@media (max-width: 640px) {
  .page-finance-transfer-form .finance-form-grid-transfer {
    grid-template-columns: 1fr;
  }
  .page-finance-transfer-form .finance-alloc-wrap {
    margin-left: 16px;
    margin-right: 16px;
  }
}

/* Pinjaman ABK — daftar & detail (mewah) */
.page-finance-loans {
  padding-bottom: 32px;
}
.page-finance-loans .finance-search-lux {
  margin-bottom: 22px;
  padding: 16px 20px;
  border-radius: 16px;
  border: 1px solid rgba(201, 169, 98, 0.28);
  background: linear-gradient(165deg, #fff 0%, #faf8f4 100%);
  box-shadow: 0 8px 24px rgba(15, 23, 41, 0.05);
}
.page-finance-loans .finance-loans-lux {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.page-finance-loans .finance-loans-stats-lux {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 0;
}
.page-finance-loans .finance-loans-stat-card {
  position: relative;
  padding: 18px 18px 16px 52px;
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: linear-gradient(165deg, #fff 0%, #f8f6f1 100%);
  box-shadow: 0 8px 22px rgba(15, 23, 41, 0.05);
  transition: transform 0.15s, box-shadow 0.15s;
}
.page-finance-loans .finance-loans-stat-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(15, 23, 41, 0.08);
}
.page-finance-loans .finance-loans-stat-card-accent {
  border-color: rgba(201, 169, 98, 0.42);
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.18) 0%, #fff 55%);
}
.page-finance-loans .finance-loans-stat-card-meta {
  background: linear-gradient(165deg, rgba(15, 23, 41, 0.03) 0%, #fff 100%);
}
.page-finance-loans .finance-loans-stat-icon {
  position: absolute;
  left: 16px;
  top: 18px;
  font-size: 1.15rem;
  line-height: 1;
  opacity: 0.75;
}
.page-finance-loans .finance-loans-stat-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted, #64748b);
  margin-bottom: 8px;
}
.page-finance-loans .finance-loans-stat-value {
  display: block;
  font-size: clamp(0.95rem, 1.2vw, 1.12rem);
  font-weight: 800;
  color: var(--navy, #0f1729);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.page-finance-loans .finance-loans-stat-in {
  color: #166534;
}
.page-finance-loans .finance-loans-stat-clear {
  color: #166534;
}
.page-finance-loans .finance-loans-list {
  border-radius: 18px;
  border: 1px solid rgba(201, 169, 98, 0.32);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.98), rgba(250, 248, 244, 0.96));
  box-shadow: 0 16px 40px rgba(15, 23, 41, 0.07);
  overflow: hidden;
}
.page-finance-loans .finance-loans-list-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px 20px;
  padding: 20px 24px 16px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.2);
  background: linear-gradient(135deg, rgba(15, 23, 41, 0.04), rgba(201, 169, 98, 0.12));
}
.page-finance-loans .finance-loans-list-title {
  margin: 0;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1.05rem, 1.3vw, 1.22rem);
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.page-finance-loans .finance-loans-list-lead {
  margin: 6px 0 0;
  font-size: 0.84rem;
  max-width: 32rem;
}
.page-finance-loans .finance-loans-list-count {
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(15, 23, 41, 0.08);
}
.page-finance-loans .finance-loans-empty {
  padding: 48px 28px 52px;
  text-align: center;
}
.page-finance-loans .finance-loans-empty-icon {
  display: block;
  font-size: 2.2rem;
  margin-bottom: 12px;
  opacity: 0.45;
}
.page-finance-loans .finance-loans-table-shell {
  padding: 10px 14px 18px;
  margin: 0;
}
.page-finance-loans .finance-loans-table-wrap {
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 41, 0.07);
  background: #fff;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}
.page-finance-loans .finance-loans-table {
  width: 100%;
  min-width: 880px;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.875rem;
  table-layout: fixed;
}
.page-finance-loans .finance-loans-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 13px 12px;
  background: linear-gradient(180deg, #1a2744 0%, #0f1729 100%);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  border: none;
  white-space: nowrap;
  vertical-align: middle;
}
.page-finance-loans .finance-loans-th-label {
  display: inline-block;
}
.page-finance-loans .finance-loans-th-sr {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.page-finance-loans .finance-loans-col-abk {
  width: 26%;
  text-align: left;
  padding-left: 16px;
}
.page-finance-loans .finance-loans-col-status {
  width: 14%;
  text-align: center;
}
.page-finance-loans .finance-loans-col-amt {
  width: 12%;
  text-align: right;
  padding-right: 14px;
}
.page-finance-loans .finance-loans-col-usd {
  width: 14%;
}
.page-finance-loans .finance-loans-col-action {
  width: 8%;
  text-align: center;
  padding-right: 12px;
}
.page-finance-loans .finance-loans-table thead th:first-child {
  border-radius: 12px 0 0 0;
}
.page-finance-loans .finance-loans-table thead th:last-child {
  border-radius: 0 12px 0 0;
}
.page-finance-loans .finance-loans-table tbody td {
  padding: 13px 12px;
  vertical-align: middle;
  border-bottom: 1px solid rgba(15, 23, 41, 0.06);
  color: #334155;
  line-height: 1.35;
}
.page-finance-loans .finance-loans-table tbody tr:last-child td {
  border-bottom: none;
}
.page-finance-loans .finance-loans-table tbody tr.finance-loans-row {
  transition: background 0.15s ease, box-shadow 0.15s ease;
}
.page-finance-loans .finance-loans-table tbody tr.finance-loans-row:nth-child(even) {
  background: rgba(248, 250, 252, 0.75);
}
.page-finance-loans .finance-loans-table tbody tr.finance-loans-row:hover {
  background: rgba(201, 169, 98, 0.12);
  box-shadow: inset 3px 0 0 var(--gold, #c9a962);
}
.page-finance-loans .finance-loans-table tbody tr.finance-loans-row-closed {
  opacity: 0.92;
}
.page-finance-loans .finance-loans-table tbody tr.finance-loans-row-closed:hover {
  opacity: 1;
}
.page-finance-loans .finance-loans-td-abk {
  padding-left: 14px;
  text-align: left;
}
.page-finance-loans .finance-loans-td-status {
  text-align: center;
}
.page-finance-loans .finance-loans-td-amt {
  text-align: right;
  padding-right: 14px;
  font-variant-numeric: tabular-nums;
}
.page-finance-loans .finance-loans-td-action {
  text-align: center;
  padding-right: 10px;
}
.page-finance-loans .finance-loans-abk-cell {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.page-finance-loans .finance-loans-abk-avatar {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--navy, #0f1729);
  background: linear-gradient(145deg, rgba(201, 169, 98, 0.35), rgba(255, 255, 255, 0.95));
  border: 1px solid rgba(201, 169, 98, 0.45);
  box-shadow: 0 2px 8px rgba(15, 23, 41, 0.06);
}
.page-finance-loans .finance-loans-abk-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.page-finance-loans .finance-loans-abk-name {
  font-size: 0.9rem;
  font-weight: 800;
  color: var(--navy, #0f1729);
  letter-spacing: 0.01em;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.page-finance-loans .finance-abk-uniq {
  font-size: 0.72rem;
  font-weight: 600;
  color: #64748b;
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}
.page-finance-loans .finance-loans-status-wrap {
  display: inline-flex;
  justify-content: center;
  max-width: 100%;
}
.page-finance-loans .finance-loans-table .crew-status-badge {
  font-size: 0.66rem;
  padding: 4px 10px;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.page-finance-loans .finance-loans-amt {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  max-width: 100%;
  padding: 6px 10px;
  border-radius: 10px;
  font-size: 0.84rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.page-finance-loans .finance-loans-amt-expense {
  color: #334155;
  background: rgba(15, 23, 41, 0.04);
  border: 1px solid rgba(15, 23, 41, 0.06);
}
.page-finance-loans .finance-loans-amt-repay {
  color: #166534;
  background: linear-gradient(165deg, rgba(220, 252, 231, 0.7), rgba(255, 255, 255, 0.9));
  border: 1px solid rgba(22, 101, 52, 0.15);
}
.page-finance-loans .finance-loans-amt-balance {
  font-size: 0.88rem;
  font-weight: 800;
}
.page-finance-loans .finance-loans-amt-balance.is-due {
  color: #b45309;
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.75), rgba(255, 255, 255, 0.95));
  border: 1px solid rgba(180, 83, 9, 0.22);
}
.page-finance-loans .finance-loans-amt-balance.is-clear {
  color: #166534;
  background: rgba(220, 252, 231, 0.35);
  border: 1px solid rgba(22, 101, 52, 0.12);
}
.page-finance-loans .finance-loans-amt-balance.is-over {
  color: #1d4ed8;
  background: rgba(219, 234, 254, 0.45);
  border: 1px solid rgba(29, 78, 216, 0.15);
}
.page-finance-loans .finance-loans-due-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.25);
  flex-shrink: 0;
}
.page-finance-loans .finance-loans-td-usd {
  text-align: right;
}
.page-finance-loans .finance-loans-usd-closed {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  padding: 6px 10px;
  border-radius: 10px;
  background: linear-gradient(165deg, rgba(15, 23, 41, 0.05), rgba(255, 255, 255, 0.95));
  border: 1px solid rgba(15, 23, 41, 0.08);
}
.page-finance-loans .finance-loans-usd-value {
  font-size: 0.86rem;
  font-weight: 800;
  color: var(--navy, #0f1729);
  font-variant-numeric: tabular-nums;
}
.page-finance-loans .finance-loans-usd-rate {
  font-size: 0.68rem;
  font-weight: 600;
  color: #64748b;
  letter-spacing: 0.02em;
}
.page-finance-loans .finance-loans-pending-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #64748b;
  background: rgba(148, 163, 184, 0.12);
  border: 1px dashed rgba(100, 116, 139, 0.35);
}
.page-finance-loans .finance-loans-detail-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-width: 84px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 700;
  text-decoration: none;
  color: var(--navy, #0f1729);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.98), rgba(201, 169, 98, 0.28));
  border: 1px solid rgba(201, 169, 98, 0.5);
  box-shadow: 0 2px 10px rgba(15, 23, 41, 0.07);
  transition: transform 0.12s, box-shadow 0.15s, background 0.15s;
}
.page-finance-loans .finance-loans-detail-btn-arrow {
  font-size: 0.9rem;
  line-height: 1;
  opacity: 0.7;
  transition: transform 0.15s;
}
.page-finance-loans .finance-loans-detail-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 5px 16px rgba(201, 169, 98, 0.3);
  color: var(--navy, #0f1729);
}
.page-finance-loans .finance-loans-detail-btn:hover .finance-loans-detail-btn-arrow {
  transform: translateX(2px);
  opacity: 1;
}
.finance-loans-view-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 18px;
}
.finance-loans-view-tab {
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
  text-decoration: none;
  color: var(--navy, #0f1729);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(15, 23, 41, 0.1);
}
.finance-loans-view-tab.is-active {
  background: linear-gradient(165deg, rgba(201, 169, 98, 0.35), #fff);
  border-color: rgba(201, 169, 98, 0.55);
  box-shadow: 0 2px 10px rgba(201, 169, 98, 0.2);
}
.finance-loans-abk-cards {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0;
}
/* Jangan pakai .finance-loans-abk-cards di <tbody> — merusak alignment kolom tabel */
.finance-loans-abk-table-lux tbody.finance-loans-abk-cards {
  display: table-row-group;
}
.finance-loans-abk-table-wrap {
  border: 1px solid rgba(15, 23, 41, 0.08);
  border-radius: 14px;
  overflow-x: auto;
  background: #fff;
  box-shadow: 0 4px 20px rgba(15, 23, 41, 0.05);
  -webkit-overflow-scrolling: touch;
}
.finance-loans-abk-table-lux {
  width: 100%;
  min-width: 820px;
  border-collapse: collapse;
  border-spacing: 0;
  table-layout: fixed;
}
.finance-loans-abk-table-lux thead,
.finance-loans-abk-table-lux tbody,
.finance-loans-abk-table-lux tfoot {
  display: table-header-group;
}
.finance-loans-abk-table-lux tbody {
  display: table-row-group;
}
.finance-loans-abk-table-lux tfoot {
  display: table-footer-group;
}
.finance-loans-abk-table-lux tr {
  display: table-row;
}
.finance-loans-abk-table-lux th,
.finance-loans-abk-table-lux td {
  display: table-cell;
}
.finance-loan-col-num { width: 4%; }
.finance-loan-col-name { width: 28%; }
.finance-loan-col-dob { width: 11%; }
.finance-loan-col-paspor { width: 12%; }
.finance-loan-col-tipe { width: 14%; }
.finance-loan-col-debt { width: 17%; }
.finance-loan-col-toggle { width: 4%; }
.finance-loans-abk-table-lux thead th,
.finance-loans-abk-table-lux .finance-loan-td {
  padding: 11px 12px;
  box-sizing: border-box;
}
.finance-loans-abk-table-lux thead th {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: left;
  vertical-align: middle;
  color: rgba(248, 250, 252, 0.85);
  background: linear-gradient(180deg, rgba(15, 23, 41, 0.92), rgba(30, 41, 59, 0.88));
  border-bottom: 1px solid rgba(201, 169, 98, 0.25);
}
.finance-loans-abk-table-lux thead th:first-child,
.finance-loan-summary-row .finance-loan-td:first-child,
.finance-loans-abk-table-foot-row td:first-child {
  padding-left: 16px;
}
.finance-loans-abk-table-lux thead th:last-child,
.finance-loan-summary-row .finance-loan-td:last-child,
.finance-loans-abk-table-foot-row td:last-child {
  padding-right: 16px;
}
.finance-loan-th-num {
  text-align: center;
}
.finance-loan-th-debt {
  text-align: right;
  color: rgba(253, 230, 138, 0.95);
}
.finance-loan-th-toggle {
  text-align: center;
  padding-left: 0;
  padding-right: 0;
}
.finance-loan-summary-row {
  cursor: pointer;
  background: #fff;
  transition: background 0.12s ease;
}
.finance-loan-summary-row:nth-child(4n+1) {
  background: rgba(248, 250, 252, 0.65);
}
.finance-loan-summary-row:hover {
  background: rgba(254, 243, 199, 0.18);
}
.finance-loan-summary-row.is-open {
  background: rgba(248, 250, 252, 0.95);
  box-shadow: inset 0 3px 0 rgba(201, 169, 98, 0.55);
}
.finance-loan-summary-row.finance-loan-abk-card-due {
  box-shadow: inset 3px 0 0 rgba(201, 169, 98, 0.75);
}
.finance-loan-td {
  vertical-align: middle;
  border-bottom: 1px solid rgba(15, 23, 41, 0.06);
  font-size: 0.78rem;
  color: #475569;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.finance-loan-td-num {
  text-align: center;
  font-size: 0.72rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: #94a3b8;
}
.finance-loan-td-name {
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.finance-loan-td-mono {
  font-family: ui-monospace, "Cascadia Code", "Consolas", monospace;
  font-size: 0.72rem;
  letter-spacing: 0.02em;
}
.finance-loan-td-debt {
  text-align: right;
  font-size: 0.84rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--navy, #0f1729);
}
.finance-loan-td-debt.is-due {
  color: #b45309;
}
.finance-loan-td-chevron {
  text-align: center;
  padding-left: 0;
}
.finance-loan-detail-row .finance-loan-detail-cell {
  padding: 0 16px 16px;
  border-bottom: 1px solid rgba(15, 23, 41, 0.08);
  background: rgba(248, 250, 252, 0.55);
}
.finance-loan-detail-row[hidden] {
  display: none;
}
.finance-loans-abk-table-lux tfoot td {
  padding: 12px;
  border-top: 2px solid rgba(201, 169, 98, 0.45);
  background: linear-gradient(180deg, rgba(254, 243, 199, 0.35), rgba(255, 255, 255, 0.95));
}
.finance-loans-abk-table-foot-row td:first-child {
  padding-left: 16px;
}
.finance-loan-foot-label {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--navy, #0f1729);
}
.finance-loan-foot-label em {
  font-style: normal;
  font-weight: 600;
  font-size: 0.72rem;
  letter-spacing: 0;
  text-transform: none;
  color: #64748b;
  margin-left: 8px;
}
.finance-loan-foot-debt {
  text-align: right;
  font-size: 0.95rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #b45309;
}
.finance-loan-row-chevron {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-right: 2px solid #94a3b8;
  border-bottom: 2px solid #94a3b8;
  transform: rotate(-45deg);
  transition: transform 0.15s ease;
}
.finance-loan-summary-row.is-open .finance-loan-row-chevron {
  transform: rotate(45deg);
}
.finance-loans-abk-cards-lux {
  gap: 0;
  padding: 0;
}
.finance-loan-abk-card-lux .finance-loan-card-meta-grid {
  padding: 14px 0 12px;
}
.finance-loan-card-meta-value.is-due {
  color: #b45309;
  font-weight: 800;
}
.finance-loan-th-toggle .visually-hidden,
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.finance-loans-total-debt-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--navy, #0f1729);
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.65), rgba(255, 255, 255, 0.95));
  border: 1px solid rgba(201, 169, 98, 0.45);
  box-shadow: 0 4px 14px rgba(201, 169, 98, 0.15);
}
.finance-loans-total-debt-pill strong {
  font-size: 0.92rem;
  font-weight: 800;
  color: #b45309;
  font-variant-numeric: tabular-nums;
}
.finance-loan-card-meta-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px 12px;
  padding: 14px 0 12px;
  border-top: none;
}
.finance-loan-card-meta-item {
  min-width: 0;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(15, 23, 41, 0.03);
  border: 1px solid rgba(15, 23, 41, 0.05);
}
.finance-loan-card-meta-label {
  display: block;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #64748b;
  margin-bottom: 4px;
}
.finance-loan-card-meta-value {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--navy, #0f1729);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.finance-loan-abk-crewlist-link {
  color: var(--navy, #0f1729);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.finance-loan-abk-card-lux .finance-loan-abk-body {
  padding: 0 16px 16px;
  border-top: 1px solid rgba(15, 23, 41, 0.06);
  background: rgba(248, 250, 252, 0.55);
}
.finance-loan-abk-card-lux .finance-loan-abk-body-meta {
  padding: 0 0 10px;
  font-size: 0.78rem;
  border-bottom: 1px solid rgba(15, 23, 41, 0.06);
  margin-bottom: 4px;
}
.finance-loan-abk-card-lux .finance-loan-abk-body-head {
  padding: 12px 0 8px;
}
.finance-loan-abk-card-lux .finance-loan-abk-history-slot {
  padding: 0 0 4px;
}
@media (max-width: 720px) {
  .finance-subnav-cash-cta {
    width: 100%;
    margin-left: 0;
    justify-content: center;
  }
  .finance-loans-abk-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .finance-loans-abk-table-lux {
    min-width: 760px;
  }
  .finance-loan-card-meta-grid {
    grid-template-columns: 1fr 1fr;
  }
}
.finance-loan-abk-card {
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: #fff;
  box-shadow: 0 4px 16px rgba(15, 23, 41, 0.05);
  overflow: hidden;
}
.finance-loan-abk-card-due {
  border-color: rgba(201, 169, 98, 0.45);
  box-shadow: 0 6px 20px rgba(201, 169, 98, 0.12);
}
.finance-loan-abk-card-compact .finance-loan-abk-summary-compact {
  display: block;
  padding: 10px 14px 10px 12px;
}
.finance-loan-abk-summary-grid,
.finance-loan-abk-list-head {
  display: grid;
  grid-template-columns: minmax(120px, 1.35fr) minmax(72px, 0.75fr) minmax(88px, 0.85fr) minmax(72px, 0.7fr) minmax(120px, 1.25fr) minmax(72px, 0.75fr) minmax(96px, 0.95fr);
  gap: 8px 12px;
  align-items: center;
  width: 100%;
}
.finance-loan-abk-list-head {
  padding: 8px 14px 6px 12px;
  margin-bottom: 2px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #64748b;
  border-bottom: 1px solid rgba(15, 23, 41, 0.08);
}
.finance-loan-abk-col {
  min-width: 0;
  font-size: 0.8rem;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
}
.finance-loan-abk-col-name {
  font-size: 0.84rem;
}
.finance-loan-abk-col-debt {
  text-align: right;
  font-weight: 700;
  white-space: nowrap;
}
.finance-loan-abk-col-debt .finance-loan-abk-summary-debt {
  font-size: 0.84rem;
}
.finance-loan-abk-crewlist-link {
  color: var(--navy, #0f1729);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.finance-loan-abk-summary-compact::after {
  content: '';
  position: absolute;
  right: 14px;
  top: 50%;
  width: 8px;
  height: 8px;
  margin-top: -6px;
  border-right: 2px solid #64748b;
  border-bottom: 2px solid #64748b;
  transform: rotate(-45deg);
  transition: transform 0.15s ease;
}
.finance-loan-abk-card-compact .finance-loan-abk-summary-compact {
  position: relative;
  padding-right: 28px;
}
.finance-loan-abk-card-compact[open] .finance-loan-abk-summary-compact::after {
  transform: rotate(45deg);
  margin-top: -2px;
}
.finance-loan-abk-summary-name {
  font-weight: 700;
  font-size: 0.86rem;
  color: var(--navy, #0f1729);
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.finance-loan-abk-summary-debt {
  font-weight: 700;
}
.finance-loan-abk-body-meta {
  font-size: 0.78rem;
  padding: 12px 16px 0;
  line-height: 1.5;
}
.finance-loans-closed-badge-inline {
  color: #5b21b6;
  font-weight: 600;
}
.finance-loan-abk-history-slot {
  padding: 0 16px 4px;
}
.finance-loan-history-loading {
  margin: 8px 0 12px;
  font-size: 0.82rem;
}
.finance-loan-abk-card-compact .finance-loan-abk-body-head {
  padding: 10px 16px 8px;
}
.finance-loan-abk-card-compact .finance-loan-abk-body {
  padding: 0 0 12px;
}
.finance-loan-abk-summary {
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  gap: 8px 14px;
  align-items: center;
  padding: 14px 18px;
  cursor: pointer;
  list-style: none;
  background: linear-gradient(135deg, rgba(248, 250, 252, 0.9), rgba(255, 255, 255, 0.98));
}
.finance-loan-abk-summary::-webkit-details-marker {
  display: none;
}
.finance-loan-abk-card-due .finance-loan-abk-summary {
  background: linear-gradient(135deg, rgba(254, 243, 199, 0.35), rgba(255, 255, 255, 0.98));
}
.finance-loan-abk-summary-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.finance-loan-abk-summary-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}
.finance-loan-abk-balance-pill {
  font-size: 0.88rem;
  white-space: nowrap;
}
.finance-loan-abk-summary-amts {
  grid-column: 2 / -1;
  font-size: 0.78rem;
}
.finance-loan-abk-summary-actions {
  grid-column: 3;
  grid-row: 1 / span 2;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
}
.finance-loans-detail-btn-inline,
.finance-print-btn-inline {
  min-width: auto;
  padding: 5px 12px;
  font-size: 0.72rem;
  white-space: nowrap;
}
.finance-loans-focus-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 0 0 14px;
  padding: 12px 16px;
  border-radius: 12px;
  border: 1px solid rgba(201, 169, 98, 0.4);
  background: linear-gradient(135deg, rgba(254, 243, 199, 0.45), rgba(255, 255, 255, 0.95));
}
.finance-loans-focus-banner p {
  margin: 0;
  font-size: 0.88rem;
}
.finance-loans-focus-clear {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--navy, #0f1729);
  text-decoration: underline;
}
.finance-loan-abk-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.finance-loan-abk-body {
  padding: 0 16px 16px;
  border-top: 1px solid rgba(15, 23, 41, 0.06);
}
.finance-loan-abk-body-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 0 10px;
}
.finance-loan-abk-history-title {
  margin: 0;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.finance-loans-closed-badge {
  color: #5b21b6;
  background: rgba(237, 233, 254, 0.8);
  border-color: rgba(91, 33, 182, 0.25);
}
.finance-loan-history-compact {
  overflow-x: auto;
}
.finance-loan-history-mini {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8rem;
}
.finance-loan-history-mini thead th {
  padding: 8px 10px;
  text-align: left;
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #64748b;
  background: rgba(15, 23, 41, 0.04);
  border-bottom: 1px solid rgba(15, 23, 41, 0.08);
}
.finance-loan-history-mini tbody td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(15, 23, 41, 0.05);
  vertical-align: top;
}
.finance-loan-history-mini tbody tr:last-child td {
  border-bottom: none;
}
.finance-loan-history-mini .num {
  text-align: right;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.finance-loan-history-mini-amt.is-plus {
  color: #b45309;
  font-weight: 700;
}
.finance-loan-history-mini-amt.is-minus {
  color: #166534;
  font-weight: 700;
}
.finance-loan-history-mini-amt.is-close {
  color: #5b21b6;
  font-weight: 700;
}
.finance-loan-history-mini-type {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
}
.finance-loan-history-more {
  margin: 8px 0 0;
  font-size: 0.78rem;
}
.finance-loan-history-foot {
  margin: 12px 0 0;
}
.finance-loans-detail-btn-sm {
  min-width: auto;
  padding: 6px 14px;
  font-size: 0.74rem;
}
@media (max-width: 960px) {
  .finance-loan-abk-list-head {
    display: none;
  }
  .finance-loan-abk-summary-grid {
    grid-template-columns: 1fr 1fr;
    gap: 6px 10px;
  }
  .finance-loan-abk-col-name {
    grid-column: 1 / -1;
  }
  .finance-loan-abk-col-debt {
    grid-column: 1 / -1;
    text-align: left;
  }
  .finance-loan-abk-col:not(.finance-loan-abk-col-name):not(.finance-loan-abk-col-debt)::before {
    content: attr(data-label) ': ';
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #64748b;
  }
}
@media (max-width: 720px) {
  .finance-loan-abk-summary {
    grid-template-columns: auto 1fr;
  }
  .finance-loan-abk-summary-meta {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
  .finance-loan-abk-summary-amts {
    grid-column: 1 / -1;
  }
  .finance-loan-abk-summary-actions {
    grid-column: 1 / -1;
    grid-row: auto;
    flex-direction: row;
    justify-content: flex-start;
  }
}
.finance-amt-cell {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.finance-usd-closed {
  display: block;
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.finance-rate-mini {
  display: block;
  font-size: 0.72rem;
  color: #64748b;
  margin-top: 2px;
}
@media (max-width: 1100px) {
  .page-finance-loans .finance-loans-stats-lux {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .page-finance-loans .finance-loans-table {
    min-width: 760px;
    table-layout: auto;
  }
}
@media (max-width: 768px) {
  .page-finance-loans .finance-loans-stats-lux {
    grid-template-columns: 1fr;
  }
  .page-finance-loans .finance-loans-table {
    min-width: 0;
  }
  .page-finance-loans .finance-loans-table thead {
    display: none;
  }
  .page-finance-loans .finance-loans-table tbody tr.finance-loans-row {
    display: block;
    margin: 12px 10px;
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 41, 0.08);
    background: #fff !important;
    box-shadow: 0 6px 18px rgba(15, 23, 41, 0.06);
    overflow: hidden;
  }
  .page-finance-loans .finance-loans-table tbody tr.finance-loans-row-due {
    border-color: rgba(201, 169, 98, 0.45);
    box-shadow: 0 6px 20px rgba(201, 169, 98, 0.15);
  }
  .page-finance-loans .finance-loans-table tbody td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    padding: 11px 16px;
    text-align: right;
    border-bottom: 1px solid rgba(15, 23, 41, 0.05);
  }
  .page-finance-loans .finance-loans-table tbody td::before {
    content: attr(data-label);
    flex: 0 0 auto;
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
    text-align: left;
  }
  .page-finance-loans .finance-loans-td-abk {
    display: block;
    padding: 14px 16px 10px;
    border-bottom: 1px solid rgba(201, 169, 98, 0.2);
    background: linear-gradient(135deg, rgba(201, 169, 98, 0.1), rgba(255, 255, 255, 0.5));
  }
  .page-finance-loans .finance-loans-td-abk::before {
    display: none;
  }
  .page-finance-loans .finance-loans-abk-cell {
    width: 100%;
  }
  .page-finance-loans .finance-loans-abk-name {
    white-space: normal;
  }
  .page-finance-loans .finance-loans-td-status {
    justify-content: space-between;
  }
  .page-finance-loans .finance-loans-status-wrap {
    margin-left: auto;
  }
  .page-finance-loans .finance-loans-td-amt .finance-loans-amt {
    margin-left: auto;
  }
  .page-finance-loans .finance-loans-td-action {
    justify-content: center;
    padding: 14px 16px 16px;
    border-bottom: none;
  }
  .page-finance-loans .finance-loans-td-action::before {
    display: none;
  }
  .page-finance-loans .finance-loans-detail-btn {
    width: 100%;
    max-width: 220px;
  }
}
/* Detail pinjaman ABK — riwayat transaksi (read-only) */
.page-finance-loan-detail {
  padding-bottom: 32px;
}
.page-finance-loan-detail .finance-loan-detail-back {
  display: inline-block;
  margin-bottom: 14px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--muted, #64748b);
  text-decoration: none;
  letter-spacing: 0.02em;
}
.page-finance-loan-detail .finance-loan-detail-back:hover {
  color: var(--navy, #0f1729);
}
.page-finance-loan-detail .finance-loan-detail-hero {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
.page-finance-loan-detail .finance-loan-detail-avatar {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--navy, #0f1729);
  background: linear-gradient(145deg, rgba(201, 169, 98, 0.4), rgba(255, 255, 255, 0.95));
  border: 1px solid rgba(201, 169, 98, 0.5);
  box-shadow: 0 4px 14px rgba(15, 23, 41, 0.08);
}
.page-finance-loan-detail .finance-loan-detail-summary-lux {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin: 0 0 22px;
}
.page-finance-loan-detail .finance-loan-detail-stat {
  padding: 16px 18px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: linear-gradient(165deg, #fff, #f8f6f1);
  box-shadow: 0 6px 18px rgba(15, 23, 41, 0.05);
}
.page-finance-loan-detail .finance-loan-detail-stat-accent {
  border-color: rgba(201, 169, 98, 0.4);
  background: linear-gradient(135deg, rgba(201, 169, 98, 0.16), #fff 60%);
}
.page-finance-loan-detail .finance-loan-detail-stat-gold {
  border-color: rgba(201, 169, 98, 0.45);
}
.page-finance-loan-detail .finance-loan-detail-stat-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted, #64748b);
  margin-bottom: 6px;
}
.page-finance-loan-detail .finance-loan-detail-stat strong {
  font-size: 1rem;
  font-weight: 800;
  color: var(--navy, #0f1729);
  font-variant-numeric: tabular-nums;
}
.page-finance-loan-detail .finance-loan-detail-stat-in {
  color: #166534;
}
.page-finance-loan-detail .finance-loan-detail-stat-clear {
  color: #166534;
}
.page-finance-loan-detail .finance-abk-tx-history {
  border-radius: 18px;
  border: 1px solid rgba(201, 169, 98, 0.32);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.98), rgba(250, 248, 244, 0.96));
  box-shadow: 0 16px 40px rgba(15, 23, 41, 0.07);
  overflow: hidden;
}
.page-finance-loan-detail .finance-abk-tx-history-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px 20px;
  padding: 20px 24px 16px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.2);
  background: linear-gradient(135deg, rgba(15, 23, 41, 0.04), rgba(201, 169, 98, 0.12));
}
.page-finance-loan-detail .finance-abk-tx-history-title {
  margin: 0;
  font-family: var(--font-serif, Georgia, serif);
  font-size: clamp(1.05rem, 1.3vw, 1.2rem);
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.page-finance-loan-detail .finance-abk-tx-history-lead {
  margin: 6px 0 0;
  font-size: 0.84rem;
  max-width: 36rem;
}
.page-finance-loan-detail .finance-abk-tx-history-count {
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 23, 41, 0.08);
}
.page-finance-loan-detail .finance-abk-tx-history-empty {
  padding: 48px 28px 52px;
  text-align: center;
}
.page-finance-loan-detail .finance-abk-tx-history-empty-icon {
  display: block;
  font-size: 2rem;
  margin-bottom: 10px;
  opacity: 0.45;
}
.page-finance-loan-detail .finance-abk-tx-table-shell {
  padding: 10px 14px 18px;
}
.page-finance-loan-detail .finance-abk-tx-table-wrap {
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 41, 0.07);
  background: #fff;
  overflow: auto;
}
.page-finance-loan-detail .finance-abk-tx-table {
  width: 100%;
  min-width: 820px;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.875rem;
  table-layout: fixed;
}
.page-finance-loan-detail .finance-abk-tx-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 13px 12px;
  background: linear-gradient(180deg, #1a2744 0%, #0f1729 100%);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  border: none;
}
.page-finance-loan-detail .finance-abk-tx-col-date { width: 11%; text-align: left; padding-left: 14px; }
.page-finance-loan-detail .finance-abk-tx-col-type { width: 11%; text-align: center; }
.page-finance-loan-detail .finance-abk-tx-col-detail { width: 22%; text-align: left; }
.page-finance-loan-detail .finance-abk-tx-col-effect { width: 11%; text-align: center; }
.page-finance-loan-detail .finance-abk-tx-col-amt { width: 14%; text-align: right; padding-right: 14px; }
.page-finance-loan-detail .finance-abk-tx-col-desc { width: 20%; text-align: left; }
.page-finance-loan-detail .finance-abk-tx-col-ref { width: 11%; text-align: center; }
.page-finance-loan-detail .finance-abk-tx-table thead th:first-child { border-radius: 12px 0 0 0; }
.page-finance-loan-detail .finance-abk-tx-table thead th:last-child { border-radius: 0 12px 0 0; }
.page-finance-loan-detail .finance-abk-tx-table tbody td {
  padding: 12px;
  vertical-align: middle;
  border-bottom: 1px solid rgba(15, 23, 41, 0.06);
  color: #334155;
  line-height: 1.35;
}
.page-finance-loan-detail .finance-abk-tx-table tbody tr:last-child td { border-bottom: none; }
.page-finance-loan-detail .finance-abk-tx-row:nth-child(even) { background: rgba(248, 250, 252, 0.75); }
.page-finance-loan-detail .finance-abk-tx-row:hover {
  background: rgba(201, 169, 98, 0.1);
  box-shadow: inset 3px 0 0 var(--gold, #c9a962);
}
.page-finance-loan-detail .finance-abk-tx-td-date time {
  font-weight: 700;
  color: var(--navy, #0f1729);
  white-space: nowrap;
}
.page-finance-loan-detail .finance-abk-tx-type {
  display: inline-flex;
  padding: 5px 11px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  white-space: nowrap;
}
.page-finance-loan-detail .finance-abk-tx-type-expense {
  color: #334155;
  background: rgba(15, 23, 41, 0.06);
  border: 1px solid rgba(15, 23, 41, 0.1);
}
.page-finance-loan-detail .finance-abk-tx-type-repayment {
  color: #166534;
  background: rgba(220, 252, 231, 0.65);
  border: 1px solid rgba(22, 101, 52, 0.18);
}
.page-finance-loan-detail .finance-abk-tx-type-close {
  color: #5b21b6;
  background: rgba(237, 233, 254, 0.8);
  border: 1px solid rgba(91, 33, 182, 0.2);
}
.page-finance-loan-detail .finance-abk-tx-effect {
  display: inline-flex;
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 0.72rem;
  font-weight: 700;
}
.page-finance-loan-detail .finance-abk-tx-effect-plus {
  color: #b45309;
  background: rgba(254, 243, 199, 0.6);
}
.page-finance-loan-detail .finance-abk-tx-effect-minus {
  color: #166534;
  background: rgba(220, 252, 231, 0.5);
}
.page-finance-loan-detail .finance-abk-tx-effect-close {
  color: #5b21b6;
  background: rgba(237, 233, 254, 0.55);
}
.page-finance-loan-detail .finance-abk-tx-td-amt {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.page-finance-loan-detail .finance-abk-tx-amt {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  padding: 6px 10px;
  border-radius: 10px;
  font-weight: 800;
  font-size: 0.84rem;
}
.page-finance-loan-detail .finance-abk-tx-amt-expense {
  background: rgba(15, 23, 41, 0.04);
  border: 1px solid rgba(15, 23, 41, 0.08);
}
.page-finance-loan-detail .finance-abk-tx-amt-repayment {
  color: #166534;
  background: linear-gradient(165deg, rgba(220, 252, 231, 0.75), #fff);
  border: 1px solid rgba(22, 101, 52, 0.15);
}
.page-finance-loan-detail .finance-abk-tx-amt-close {
  color: var(--navy, #0f1729);
  background: linear-gradient(165deg, rgba(201, 169, 98, 0.2), #fff);
  border: 1px solid rgba(201, 169, 98, 0.35);
}
.page-finance-loan-detail .finance-abk-tx-amt-sub {
  font-size: 0.72rem;
  font-weight: 600;
  color: #64748b;
}
.page-finance-loan-detail .finance-abk-tx-td-desc {
  word-break: break-word;
  font-size: 0.84rem;
}
.page-finance-loan-detail .finance-abk-tx-ref-link {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
  text-decoration: none;
  padding: 5px 12px;
  border-radius: 999px;
  border: 1px solid rgba(201, 169, 98, 0.45);
  background: rgba(201, 169, 98, 0.12);
}
.page-finance-loan-detail .finance-abk-tx-ref-link:hover {
  background: rgba(201, 169, 98, 0.28);
}
.finance-print-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  white-space: nowrap;
  text-decoration: none;
  border: 1px solid rgba(201, 169, 98, 0.45);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.98), rgba(201, 169, 98, 0.15));
  color: var(--navy, #0f1729);
  box-shadow: 0 2px 8px rgba(15, 23, 41, 0.06);
}
.finance-print-btn:hover {
  box-shadow: 0 4px 14px rgba(201, 169, 98, 0.22);
  color: var(--navy, #0f1729);
}
.finance-print-btn-icon {
  font-size: 0.95rem;
  line-height: 1;
}
.finance-history-print-row,
.finance-tx-history-head,
.finance-loans-list-head,
.finance-abk-tx-history-head {
  flex-wrap: wrap;
}
.finance-tx-history-head .finance-print-btn,
.finance-loans-list-head .finance-print-btn,
.finance-abk-tx-history-head .finance-print-btn,
.finance-history-block > .finance-section-title + .finance-print-btn,
.page-finance-transfers .finance-history-block-head .finance-print-btn,
.page-finance-dash .finance-history-block-head .finance-print-btn {
  flex-shrink: 0;
}
.page-finance-transfers .finance-history-block-head,
.page-finance-dash .finance-history-block-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px 16px;
  margin-bottom: 14px;
}
.page-finance-transfer-form .finance-page-head {
  flex-wrap: wrap;
}
.page-finance-transfer-form .finance-head-print {
  margin-left: auto;
  align-self: flex-start;
}
.finance-cash-agency-panel {
  margin-top: 4px;
}
.finance-cash-agency-card {
  border: 1px solid rgba(201, 169, 98, 0.35);
  border-radius: 14px;
  padding: 4px 16px 16px;
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.2), rgba(255, 255, 255, 0.98));
}
.finance-alloc-card-inner {
  margin-top: 16px;
  padding-top: 8px;
  border-top: 1px dashed rgba(15, 23, 41, 0.1);
}
.finance-readonly-dl {
  margin: 0;
  padding: 0 16px 16px;
}
.finance-readonly-dl-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px 20px;
}
.finance-readonly-dl div {
  margin: 0;
}
.finance-readonly-dl dt {
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #64748b;
  margin-bottom: 4px;
}
.finance-readonly-dl dd {
  margin: 0;
  font-size: 0.92rem;
  color: var(--navy, #0f1729);
}
.finance-readonly-span-2 {
  grid-column: 1 / -1;
}
.finance-readonly-back {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 16px 0 0;
}
.finance-transfer-readonly {
  padding: 0 4px 8px;
}
@media (max-width: 768px) {
  .page-finance-loan-detail .finance-abk-tx-table {
    min-width: 0;
  }
  .page-finance-loan-detail .finance-abk-tx-table thead {
    display: none;
  }
  .page-finance-loan-detail .finance-abk-tx-row {
    display: block;
    margin: 12px 10px;
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 41, 0.08);
    background: #fff !important;
    box-shadow: 0 6px 18px rgba(15, 23, 41, 0.06);
  }
  .page-finance-loan-detail .finance-abk-tx-table tbody td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    text-align: right;
    border-bottom: 1px solid rgba(15, 23, 41, 0.05);
  }
  .page-finance-loan-detail .finance-abk-tx-table tbody td::before {
    content: attr(data-label);
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #94a3b8;
    text-align: left;
  }
  .page-finance-loan-detail .finance-abk-tx-td-type,
  .page-finance-loan-detail .finance-abk-tx-td-amt {
    justify-content: space-between;
  }
}
@media (max-width: 640px) {
  .finance-search-lux-inner {
    flex-direction: column;
    align-items: stretch;
  }
  .finance-search-lux-field {
    min-width: 0;
  }
  .finance-search-lux-actions {
    width: 100%;
    justify-content: stretch;
  }
  .finance-search-lux-actions .btn-primary,
  .finance-search-lux-actions .btn-ghost {
    flex: 1 1 auto;
  }
}

/* —— Transaksi Kas: mode aplikasi keuangan premium —— */
.page-finance-cash-lux {
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.5) 0%, transparent 120px);
}
.page-finance-cash-lux .panel-toolbar-lux {
  display: none;
}
.finance-cash-page-hero {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px 28px;
  margin: 0 0 8px;
  padding: 4px 4px 20px;
  border-bottom: 1px solid rgba(201, 169, 98, 0.2);
}
.finance-cash-page-title {
  margin: 0;
  font-size: clamp(1.45rem, 3vw, 1.85rem);
  letter-spacing: -0.02em;
  color: var(--navy, #0f1729);
}
.finance-cash-page-lead {
  margin: 10px 0 0;
  max-width: 36rem;
  font-size: 0.9rem;
  line-height: 1.55;
  color: #64748b;
}
.finance-cash-page-hero-emblem {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 88px;
  padding: 16px 20px;
  border-radius: 16px;
  background: linear-gradient(145deg, rgba(15, 23, 41, 0.94), rgba(30, 41, 59, 0.88));
  border: 1px solid rgba(201, 169, 98, 0.45);
  box-shadow: 0 12px 32px rgba(15, 23, 41, 0.18);
  color: #f8fafc;
}
.finance-cash-page-emblem-icon {
  font-size: 1.75rem;
  line-height: 1;
}
.finance-cash-page-emblem-label {
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(201, 169, 98, 0.95);
}
.finance-cash-kpi-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 24px;
}
.finance-cash-kpi {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: #fff;
  box-shadow: 0 6px 22px rgba(15, 23, 41, 0.05);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.finance-cash-kpi:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(15, 23, 41, 0.08);
}
.finance-cash-kpi-balance {
  border-color: rgba(201, 169, 98, 0.45);
  background: linear-gradient(135deg, rgba(254, 243, 199, 0.35) 0%, #fff 55%);
}
.finance-cash-kpi-in {
  border-color: rgba(22, 101, 52, 0.2);
}
.finance-cash-kpi-out {
  border-color: rgba(180, 83, 9, 0.2);
}
.finance-cash-kpi-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  font-size: 1.1rem;
  font-weight: 800;
  background: rgba(15, 23, 41, 0.06);
  color: var(--navy, #0f1729);
}
.finance-cash-kpi-in .finance-cash-kpi-icon {
  background: rgba(22, 101, 52, 0.12);
  color: #166534;
}
.finance-cash-kpi-out .finance-cash-kpi-icon {
  background: rgba(180, 83, 9, 0.12);
  color: #b45309;
}
.finance-cash-kpi-balance .finance-cash-kpi-icon {
  background: rgba(201, 169, 98, 0.25);
  color: #92400e;
}
.finance-cash-kpi-label {
  display: block;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #64748b;
}
.finance-cash-kpi-value {
  display: block;
  margin-top: 4px;
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  font-weight: 800;
  color: var(--navy, #0f1729);
  letter-spacing: -0.02em;
}
.finance-cash-kpi-in .finance-cash-kpi-value {
  color: #166534;
}
.finance-cash-kpi-out .finance-cash-kpi-value {
  color: #b45309;
}
.finance-cash-kpi-hint {
  display: block;
  margin-top: 4px;
  font-size: 0.74rem;
  color: #94a3b8;
}
.finance-cash-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(240px, 0.85fr);
  gap: 20px 24px;
  margin-bottom: 28px;
  align-items: start;
}
.finance-cash-form-lux {
  border-radius: 18px;
  border: 1px solid rgba(201, 169, 98, 0.35);
  background: linear-gradient(180deg, #fff 0%, #faf8f4 100%);
  box-shadow: 0 12px 40px rgba(15, 23, 41, 0.07);
  overflow: hidden;
}
.finance-cash-form-lux-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 20px 24px 16px;
  background: linear-gradient(135deg, rgba(15, 23, 41, 0.92) 0%, rgba(30, 41, 59, 0.88) 100%);
  border-bottom: 1px solid rgba(201, 169, 98, 0.35);
  color: #f8fafc;
}
.finance-cash-form-lux-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
}
.finance-cash-form-lux-sub {
  margin: 6px 0 0;
  font-size: 0.82rem;
  opacity: 0.85;
}
.finance-cash-form-step {
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: rgba(201, 169, 98, 0.2);
  border: 1px solid rgba(201, 169, 98, 0.45);
  color: #fde68a;
}
.finance-cash-form-lux-body {
  padding: 22px 24px 24px;
}
.finance-cash-dir-block {
  margin-bottom: 20px;
}
.finance-cash-dir-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 8px;
}
.finance-cash-dir-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 2px solid rgba(15, 23, 41, 0.1);
  background: #fff;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
  cursor: pointer;
  transition: all 0.15s ease;
}
.finance-cash-dir-btn:hover {
  border-color: rgba(201, 169, 98, 0.45);
}
.finance-cash-dir-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 800;
}
.finance-cash-dir-in.is-active {
  border-color: rgba(22, 101, 52, 0.55);
  background: linear-gradient(165deg, rgba(220, 252, 231, 0.9), #fff);
  color: #166534;
}
.finance-cash-dir-in.is-active .finance-cash-dir-icon {
  background: rgba(22, 101, 52, 0.15);
}
.finance-cash-dir-out.is-active {
  border-color: rgba(180, 83, 9, 0.55);
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.5), #fff);
  color: #b45309;
}
.finance-cash-dir-out.is-active .finance-cash-dir-icon {
  background: rgba(180, 83, 9, 0.12);
}
.finance-cash-dir-select {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}
.finance-cash-form-grid {
  padding: 0;
}
.finance-cash-form-mode-in .finance-cash-amt-field .finance-amount-wrap {
  border-color: rgba(22, 101, 52, 0.35);
}
.finance-cash-form-mode-out .finance-cash-amt-field .finance-amount-wrap {
  border-color: rgba(180, 83, 9, 0.35);
}
.finance-cash-form-note {
  margin: 16px 0 0;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(15, 23, 41, 0.03);
  border: 1px dashed rgba(15, 23, 41, 0.1);
  font-size: 0.82rem;
}
.finance-cash-form-actions {
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid rgba(201, 169, 98, 0.2);
}
.finance-cash-submit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 16px 24px;
  border: 0;
  border-radius: 14px;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: #0f1729;
  cursor: pointer;
  background: linear-gradient(165deg, #fde68a 0%, #c9a962 45%, #b8923f 100%);
  box-shadow: 0 8px 24px rgba(201, 169, 98, 0.4);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.finance-cash-submit-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(201, 169, 98, 0.5);
}
.finance-cash-submit-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: rgba(15, 23, 41, 0.12);
  font-size: 0.9rem;
}
.finance-cash-aside {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.finance-cash-aside-card {
  padding: 18px 20px;
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: linear-gradient(180deg, #fff, #f8fafc);
  box-shadow: 0 4px 18px rgba(15, 23, 41, 0.04);
}
.finance-cash-aside-card-accent {
  border-color: rgba(201, 169, 98, 0.4);
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.35), #fff);
}
.finance-cash-aside-title {
  margin: 0 0 10px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--navy, #0f1729);
}
.finance-cash-aside-list {
  margin: 0;
  padding: 0 0 0 18px;
  font-size: 0.84rem;
  line-height: 1.55;
  color: #475569;
}
.finance-cash-aside-text {
  margin: 0;
  font-size: 0.84rem;
  line-height: 1.55;
  color: #475569;
}
.finance-cash-aside-link {
  display: inline-block;
  margin-top: 12px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.finance-cash-aside-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}
.finance-cash-aside-links a {
  font-size: 0.82rem;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(15, 23, 41, 0.06);
  text-decoration: none;
  color: var(--navy, #0f1729);
}
.finance-cash-ledger {
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: #fff;
  box-shadow: 0 8px 32px rgba(15, 23, 41, 0.06);
  padding: 20px 22px 24px;
}
.finance-cash-ledger-eyebrow {
  display: block;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(201, 169, 98, 0.95);
  margin-bottom: 4px;
}
.finance-cash-ledger-head {
  padding-bottom: 16px;
  margin-bottom: 4px;
  border-bottom: 1px solid rgba(15, 23, 41, 0.08);
}
.finance-cash-table-wrap {
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 41, 0.06);
  overflow: hidden;
}
.page-finance-cash-lux .finance-cash-ledger-table thead th {
  background: linear-gradient(180deg, rgba(15, 23, 41, 0.06), rgba(15, 23, 41, 0.02));
  font-size: 0.68rem;
  letter-spacing: 0.08em;
}
.finance-cash-cat-pill {
  display: inline-block;
  max-width: 100%;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 600;
  background: rgba(15, 23, 41, 0.05);
  border: 1px solid rgba(15, 23, 41, 0.08);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.page-finance-cash-lux .finance-cash-agency-card {
  border-radius: 14px;
  border-color: rgba(22, 101, 52, 0.25);
  background: linear-gradient(165deg, rgba(220, 252, 231, 0.25), #fff);
}

/* —— Transaksi Kas v2: polish premium —— */
.page-finance-cash-lux .finance-cash-kpi {
  position: relative;
  overflow: hidden;
  padding: 20px 22px;
}
.page-finance-cash-lux .finance-cash-kpi::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, rgba(201, 169, 98, 0.15), rgba(201, 169, 98, 0.85), rgba(201, 169, 98, 0.15));
}
.page-finance-cash-lux .finance-cash-kpi-balance::before {
  background: linear-gradient(90deg, rgba(201, 169, 98, 0.3), #c9a962, rgba(201, 169, 98, 0.3));
}
.page-finance-cash-lux .finance-cash-kpi-in::before {
  background: linear-gradient(90deg, rgba(22, 101, 52, 0.2), #166534, rgba(22, 101, 52, 0.2));
}
.page-finance-cash-lux .finance-cash-kpi-out::before {
  background: linear-gradient(90deg, rgba(180, 83, 9, 0.2), #b45309, rgba(180, 83, 9, 0.2));
}
.page-finance-cash-lux .finance-cash-kpi-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  font-size: 1.15rem;
}
.page-finance-cash-lux .finance-cash-form-lux {
  border-radius: 20px;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.8) inset,
    0 20px 50px rgba(15, 23, 41, 0.09);
}
.page-finance-cash-lux .finance-cash-form-lux-head {
  padding: 22px 28px 18px;
}
.page-finance-cash-lux .finance-cash-form-lux-body {
  padding: 24px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.page-finance-cash-lux .finance-cash-dir-block {
  margin-bottom: 0;
}
.page-finance-cash-lux .finance-cash-dir-toggle {
  gap: 6px;
  margin-top: 10px;
  padding: 5px;
  border-radius: 16px;
  background: rgba(15, 23, 41, 0.05);
  border: 1px solid rgba(15, 23, 41, 0.06);
}
.page-finance-cash-lux .finance-cash-dir-btn {
  flex-direction: row;
  justify-content: flex-start;
  gap: 12px;
  padding: 14px 18px;
  border: none;
  border-radius: 12px;
  background: transparent;
  box-shadow: none;
  text-align: left;
}
.page-finance-cash-lux .finance-cash-dir-btn:hover {
  background: rgba(255, 255, 255, 0.55);
}
.page-finance-cash-lux .finance-cash-dir-in.is-active,
.page-finance-cash-lux .finance-cash-dir-out.is-active {
  background: #fff;
  box-shadow: 0 4px 16px rgba(15, 23, 41, 0.1);
}
.page-finance-cash-lux .finance-cash-dir-in.is-active {
  color: #166534;
}
.page-finance-cash-lux .finance-cash-dir-out.is-active {
  color: #b45309;
}
.page-finance-cash-lux .finance-cash-dir-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  font-size: 1.05rem;
  flex-shrink: 0;
}
.page-finance-cash-lux .finance-cash-dir-in.is-active .finance-cash-dir-icon {
  background: rgba(22, 101, 52, 0.14);
  color: #166534;
}
.page-finance-cash-lux .finance-cash-dir-out.is-active .finance-cash-dir-icon {
  background: rgba(180, 83, 9, 0.12);
  color: #b45309;
}
.page-finance-cash-lux .finance-cash-dir-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.25;
}
.page-finance-cash-lux .finance-cash-dir-text strong {
  font-size: 0.95rem;
  font-weight: 800;
}
.page-finance-cash-lux .finance-cash-dir-text small {
  font-size: 0.72rem;
  font-weight: 500;
  opacity: 0.72;
}
.page-finance-cash-lux .finance-cash-form-section {
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 41, 0.07);
  background: #fff;
  box-shadow: 0 2px 12px rgba(15, 23, 41, 0.04);
  overflow: hidden;
}
.page-finance-cash-lux .finance-cash-form-section-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(15, 23, 41, 0.06);
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.95), rgba(255, 255, 255, 0.6));
}
.page-finance-cash-lux .finance-cash-form-section-num {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: #92400e;
  background: linear-gradient(145deg, rgba(254, 243, 199, 0.9), rgba(201, 169, 98, 0.35));
  border: 1px solid rgba(201, 169, 98, 0.45);
}
.page-finance-cash-lux .finance-cash-form-section-title {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--navy, #0f1729);
  letter-spacing: -0.01em;
}
.page-finance-cash-lux .finance-cash-form-section-sub {
  margin: 4px 0 0;
  font-size: 0.78rem;
  color: #94a3b8;
  line-height: 1.4;
}
.page-finance-cash-lux .finance-cash-form-section .finance-form-grid-lux {
  padding: 18px 20px 20px;
  gap: 18px 20px;
}
.page-finance-cash-lux .finance-cash-form-section-proof .finance-field-proof {
  padding: 0 20px 20px;
  margin: 0;
}
.page-finance-cash-lux .finance-field-label {
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: #64748b;
}
.page-finance-cash-lux .finance-field input[type="text"],
.page-finance-cash-lux .finance-field input[type="date"],
.page-finance-cash-lux .finance-field select,
.page-finance-cash-lux .finance-select {
  padding: 12px 14px;
  border-radius: 12px;
  border-color: rgba(15, 23, 41, 0.1);
  background: #fafbfc;
  font-size: 0.94rem;
}
.page-finance-cash-lux .finance-field input:focus,
.page-finance-cash-lux .finance-field select:focus {
  background: #fff;
  border-color: rgba(201, 169, 98, 0.55);
  box-shadow: 0 0 0 4px rgba(201, 169, 98, 0.12);
}
.page-finance-cash-lux .finance-cash-amt-field .finance-amount-wrap {
  border-radius: 14px;
  border-width: 2px;
  background: linear-gradient(180deg, #fff, #faf8f4);
}
.page-finance-cash-lux .finance-cash-amt-field .finance-amount-prefix {
  padding: 0 16px;
  font-size: 0.95rem;
  min-width: 52px;
  justify-content: center;
}
.page-finance-cash-lux .finance-cash-amt-field .finance-idr-input {
  padding: 16px 18px;
  font-size: clamp(1.15rem, 2.5vw, 1.45rem);
  font-weight: 700;
  letter-spacing: 0.03em;
}
.page-finance-cash-lux .finance-cash-abk-panel-lux {
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  border-radius: 0;
}
.page-finance-cash-lux .finance-cash-abk-panel-head {
  padding: 0 0 4px;
}
.page-finance-cash-lux .finance-cash-abk-toggle-lux {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 41, 0.08);
  background: linear-gradient(180deg, #fafbfc, #fff);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.page-finance-cash-lux .finance-cash-abk-toggle-lux:hover {
  border-color: rgba(201, 169, 98, 0.4);
}
.page-finance-cash-lux .finance-cash-abk-toggle-lux:has(input:checked) {
  border-color: rgba(201, 169, 98, 0.55);
  background: linear-gradient(165deg, rgba(254, 243, 199, 0.35), #fff);
  box-shadow: 0 4px 14px rgba(201, 169, 98, 0.15);
}
.page-finance-cash-lux .finance-cash-abk-toggle-lux input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
}
.page-finance-cash-lux .finance-cash-abk-toggle-box {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  margin-top: 1px;
  border-radius: 7px;
  border: 2px solid rgba(15, 23, 41, 0.18);
  background: #fff;
  transition: all 0.15s ease;
  position: relative;
}
.page-finance-cash-lux .finance-cash-abk-toggle-lux input:checked + .finance-cash-abk-toggle-box {
  border-color: #b8923f;
  background: linear-gradient(145deg, #fde68a, #c9a962);
}
.page-finance-cash-lux .finance-cash-abk-toggle-lux input:checked + .finance-cash-abk-toggle-box::after {
  content: "✓";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 900;
  color: #0f1729;
}
.page-finance-cash-lux .finance-cash-abk-toggle-text {
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--navy, #0f1729);
}
.page-finance-cash-lux .finance-cash-abk-toggle-text em {
  font-style: normal;
  color: #64748b;
  font-weight: 500;
}
.page-finance-cash-lux .finance-cash-collective-toggle {
  margin: 10px 0 0;
  padding-top: 0;
  border-top: none;
}
.page-finance-cash-lux .finance-cash-abk-fields {
  margin-top: 12px;
  padding-top: 16px;
  border-top: 1px solid rgba(15, 23, 41, 0.06);
  gap: 16px 18px;
}
.page-finance-cash-lux .finance-cash-form-grid-ext {
  padding-top: 14px;
}
.page-finance-cash-lux .finance-proof-dropzone {
  padding: 28px 20px;
  border-radius: 14px;
  border: 1px solid rgba(201, 169, 98, 0.35);
  border-style: solid;
  background: linear-gradient(180deg, rgba(254, 252, 248, 0.95), #fff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}
.page-finance-cash-lux .finance-proof-dropzone:hover,
.page-finance-cash-lux .finance-proof-dropzone.has-file {
  border-color: rgba(201, 169, 98, 0.65);
  background: linear-gradient(180deg, rgba(254, 243, 199, 0.2), #fff);
  box-shadow: 0 6px 20px rgba(201, 169, 98, 0.12);
}
.page-finance-cash-lux .finance-proof-dropzone-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  font-size: 1.35rem;
  background: rgba(201, 169, 98, 0.15);
  border: 1px solid rgba(201, 169, 98, 0.3);
}
.page-finance-cash-lux .finance-proof-dropzone-main {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--navy, #0f1729);
}
.page-finance-cash-lux .finance-proof-filename {
  font-size: 0.78rem;
  color: #94a3b8;
}
.page-finance-cash-lux .finance-field-hint {
  font-size: 0.74rem;
  margin-top: 6px;
}
.page-finance-cash-lux .finance-cash-form-note {
  margin: 0;
  padding: 12px 16px;
  border-radius: 12px;
  border: none;
  background: rgba(15, 23, 41, 0.04);
  font-size: 0.78rem;
  color: #64748b;
}
.page-finance-cash-lux .finance-cash-form-actions {
  margin-top: 4px;
  padding-top: 0;
  border-top: none;
}
.page-finance-cash-lux .finance-cash-submit-btn {
  padding: 18px 28px;
  border-radius: 16px;
  font-size: 1.02rem;
  letter-spacing: 0.03em;
}
.page-finance-cash-lux .finance-cash-submit-icon {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: rgba(15, 23, 41, 0.15);
}
.page-finance-cash-lux .finance-cash-aside-card {
  border-radius: 18px;
  padding: 20px 22px;
}
.page-finance-cash-lux .finance-cash-agency-panel .finance-form-card {
  margin: 0;
  border-radius: 14px;
  box-shadow: none;
}
.page-finance-cash-lux .finance-cash-form-section-abk:has(#financeCashAbkPanel[hidden]):has(#financeCashAgencyPanel[hidden]) {
  display: none;
}
.page-finance-cash-lux .finance-cash-form-section-proof[hidden] {
  display: none;
}
@media (max-width: 960px) {
  .finance-cash-kpi-strip {
    grid-template-columns: 1fr;
  }
  .finance-cash-workspace {
    grid-template-columns: 1fr;
  }
  .finance-cash-aside {
    order: -1;
  }
}
@media (max-width: 640px) {
  .finance-cash-page-hero-emblem {
    display: none;
  }
  .finance-cash-form-lux-body {
    padding: 18px 16px 20px;
  }
  .page-finance-cash-lux .finance-cash-form-lux-body {
    padding: 18px 16px 22px;
    gap: 18px;
  }
  .page-finance-cash-lux .finance-cash-form-section .finance-form-grid-lux,
  .page-finance-cash-lux .finance-cash-form-section-proof .finance-field-proof {
    padding-left: 16px;
    padding-right: 16px;
  }
  .page-finance-cash-lux .finance-cash-dir-btn {
    flex-direction: column;
    align-items: flex-start;
    padding: 12px 14px;
  }
  .page-finance-cash-lux .finance-cash-dir-text small {
    display: none;
  }
  .finance-cash-ledger {
    padding: 16px 14px 18px;
  }
}
