/* ============================================================
   NUSAKIYE — Founder Portal (admin) styles
   ============================================================ */
.fp { min-height: 100vh; display: grid; grid-template-columns: 256px 1fr; background: var(--cream); }

/* sidebar */
.fp-side { background: var(--crimson-deep); color: #fff; padding: 26px 20px; display: flex; flex-direction: column; position: sticky; top: 0; height: 100vh; }
.fp-side .brand { display: flex; align-items: center; gap: 11px; padding-bottom: 22px; margin-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,.12); }
.fp-side .brand .nm { font-family: var(--serif); font-weight: 700; letter-spacing: .14em; font-size: 16px; }
.fp-side .brand .sub { font-size: 9px; letter-spacing: .2em; color: var(--gold-light); font-weight: 700; }
.fp-nav { display: flex; flex-direction: column; gap: 4px; }
.fp-nav button { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-radius: 10px; border: none; background: none; color: rgba(255,255,255,.7); font-size: 14.5px; font-weight: 600; text-align: left; cursor: pointer; transition: all .15s; width: 100%; }
.fp-nav button:hover { background: rgba(255,255,255,.07); color: #fff; }
.fp-nav button.on { background: var(--crimson); color: #fff; }
.fp-nav button.on svg { color: var(--gold-light); }
.fp-side .foot { margin-top: auto; font-size: 12px; color: rgba(255,255,255,.4); }
.fp-side .foot a { color: var(--gold-light); }

/* main */
.fp-main { padding: 34px 40px 60px; min-width: 0; }
.fp-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 28px; flex-wrap: wrap; }
.fp-head h1 { font-size: 32px; }
.fp-head p { color: var(--ink-soft); font-size: 14.5px; margin-top: 4px; }

/* stat cards */
.stat-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; margin-bottom: 28px; }
.stat { background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); padding: 22px; box-shadow: var(--sh-sm); }
.stat .ic { width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center; color: var(--crimson); background: var(--cream); border: 1px solid var(--gold-soft); margin-bottom: 14px; }
.stat .v { font-family: var(--serif); font-size: 32px; font-weight: 800; color: var(--ink); line-height: 1; }
.stat .l { font-size: 13px; color: var(--ink-soft); margin-top: 6px; }

/* card / table */
.fp-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-sm); overflow: hidden; margin-bottom: 22px; }
.fp-card-hd { padding: 20px 24px; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.fp-card-hd h3 { font-family: var(--sans); font-size: 16px; font-weight: 700; }
.fp-card-hd p { font-size: 13px; color: var(--ink-soft); margin-top: 2px; }
.fp-card-bd { padding: 24px; }

/* param editor */
.param-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; }
.param { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 16px 18px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--cream); transition: border-color .15s; }
.param:focus-within { border-color: var(--gold); background: #fff; }
.param .nm { font-weight: 700; font-size: 14px; }
.param .un { font-size: 12px; color: var(--ink-soft); margin-top: 2px; }
.param-input { display: flex; align-items: center; gap: 6px; }
.param-input .pre { font-weight: 700; color: var(--ink-soft); }
.param input { width: 110px; padding: 10px 12px; border: 1.5px solid var(--line-strong); border-radius: 8px; font-size: 15px; font-weight: 700; text-align: right; font-variant-numeric: tabular-nums; font-family: var(--sans); }
.param input:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(201,162,75,.16); }

.save-bar { position: sticky; bottom: 0; display: flex; align-items: center; justify-content: space-between; gap: 16px; background: #fff; border: 1px solid var(--gold-soft); border-radius: var(--r-md); padding: 14px 20px; box-shadow: var(--sh-md); margin-top: 8px; }
.save-bar.saved { border-color: #a9d2bb; background: var(--green-soft); }

/* table */
table.bk { width: 100%; border-collapse: collapse; font-size: 13.5px; }
table.bk th { text-align: left; font-size: 11.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); padding: 12px 16px; border-bottom: 1.5px solid var(--line); white-space: nowrap; }
table.bk td { padding: 14px 16px; border-bottom: 1px solid var(--line); vertical-align: middle; }
table.bk tr:last-child td { border-bottom: none; }
table.bk tr:hover td { background: var(--cream); }
.bk-ref { font-weight: 700; font-family: var(--serif); color: var(--crimson); }
.bk-route { max-width: 240px; }
.bk-amt { font-weight: 700; font-variant-numeric: tabular-nums; }

.status-sel { padding: 6px 10px; border-radius: 99px; font-size: 12px; font-weight: 700; border: 1.5px solid; cursor: pointer; background: #fff; }
.st-Baru { color: #8a5a1a; border-color: #e8c98f; background: #fcf3e8; }
.st-Dihubungi { color: #2563a8; border-color: #b6d2ee; background: #eef5fc; }
.st-Deposit { color: #8a6a1a; border-color: var(--gold); background: #fdf6e3; }
.st-Confirmed { color: #2c5e43; border-color: #a9d2bb; background: var(--green-soft); }

.filters { display: flex; gap: 8px; flex-wrap: wrap; }
.filters button { padding: 7px 14px; border-radius: 99px; border: 1.5px solid var(--line-strong); background: #fff; font-size: 13px; font-weight: 600; color: var(--ink-soft); cursor: pointer; transition: all .15s; }
.filters button.on { border-color: var(--crimson); background: var(--crimson); color: #fff; }

.empty-state { text-align: center; padding: 50px 20px; color: var(--ink-soft); }

/* city manager */
.city-row { display: grid; grid-template-columns: 1.4fr 1fr 90px 40px; gap: 12px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--line); }
.city-row input { padding: 9px 12px; border: 1.5px solid var(--line-strong); border-radius: 8px; font-size: 14px; font-family: var(--sans); width: 100%; }
.far-toggle { display: inline-flex; border: 1.5px solid var(--line-strong); border-radius: 99px; overflow: hidden; }
.far-toggle button { border: none; background: #fff; padding: 7px 10px; font-size: 11.5px; font-weight: 700; color: var(--ink-soft); }
.far-toggle button.on { background: var(--crimson); color: #fff; }

/* login */
.fp-login { min-height: 100vh; display: grid; place-items: center; background: radial-gradient(120% 120% at 50% 0%, #7A1E2B, var(--crimson-dark) 55%, var(--crimson-deep)); padding: 20px; }
.fp-login-card { background: #fff; border-radius: var(--r-xl); padding: 44px; max-width: 400px; width: 100%; box-shadow: var(--sh-lg); text-align: center; }

@media (max-width: 900px) {
  .fp { grid-template-columns: 1fr; }
  .fp-side { position: static; height: auto; flex-direction: row; align-items: center; gap: 16px; padding: 14px 18px; flex-wrap: wrap; }
  .fp-side .brand { border: none; padding: 0; margin: 0; }
  .fp-nav { flex-direction: row; flex-wrap: wrap; }
  .fp-side .foot { display: none; }
  .fp-main { padding: 24px 20px 60px; }
  .stat-grid { grid-template-columns: 1fr 1fr; }
  .param-grid { grid-template-columns: 1fr; }
  .fp-table-wrap { overflow-x: auto; }
}
