/* =====================================================================
   RS SENJAKALA — Sistem Absensi
   Theme: "Senjakala / Golden Hour" — molten gold on warm twilight
   ===================================================================== */

:root{
  /* Metallic gold ramp (sampled from the Senjakala emblem) */
  --g1:#5A2A0A;  --g2:#9A5410;  --g3:#C77A1E;  --g4:#E8A830;  --g5:#F6D873;
  --gold:#E6A93C; --gold-2:#F2C868; --gold-deep:#B5781F;

  /* Twilight surfaces */
  --noir:#140D09;
  --noir-2:#1B120C;
  --panel-solid:#211710;
  --panel-2:#281C12;
  --line:rgba(231,176,96,.15);
  --line-strong:rgba(231,176,96,.34);

  /* Ink */
  --ivory:#F4EADB;
  --ivory-2:#CDB99E;
  --muted:#9C8A72;

  /* Signals */
  --jade:#8FB97A;
  --ember:#D9663B;

  /* Type */
  --f-display:'Fraunces','Georgia',serif;
  --f-body:'Manrope',system-ui,-apple-system,'Segoe UI',sans-serif;
  --f-mono:'IBM Plex Mono',ui-monospace,'SFMono-Regular',monospace;

  /* Foil gradient (reused) */
  --foil-edge:linear-gradient(135deg,var(--g2),var(--g4) 28%,var(--g5) 50%,var(--g3) 72%,var(--g1));
  --gold-text:linear-gradient(168deg,var(--g5) 4%,var(--g4) 34%,var(--g3) 70%,var(--g2));

  --radius:18px;
  --radius-sm:12px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-body);
  color:var(--ivory);
  background:var(--noir);
  color-scheme:dark;
  line-height:1.55;
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.hidden{display:none !important}

/* ---------------- Ambient twilight backdrop ---------------- */
.bg-sky{
  position:fixed; inset:0; z-index:-3;
  background:
    radial-gradient(120% 90% at 50% 118%, rgba(232,140,40,.34), transparent 55%),
    radial-gradient(90% 70% at 84% -10%, rgba(120,42,86,.30), transparent 60%),
    linear-gradient(176deg,#1a1020 0%,#1a1110 42%,#140d09 78%);
}
.bg-glow{
  position:fixed; left:50%; bottom:-34vh; z-index:-2;
  width:120vw; height:80vh; transform:translateX(-50%);
  background:radial-gradient(closest-side, rgba(246,176,72,.20), rgba(246,176,72,.05) 55%, transparent 72%);
  filter:blur(8px);
  animation:dusk 22s var(--ease) infinite alternate;
  pointer-events:none;
}
@keyframes dusk{
  from{opacity:.7; transform:translateX(-50%) translateY(10px) scale(1)}
  to  {opacity:1;  transform:translateX(-50%) translateY(-8px) scale(1.06)}
}
.bg-grain{
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------------- Shared type helpers ---------------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:.72rem; letter-spacing:.34em; text-transform:uppercase;
  color:var(--gold-2); display:flex; align-items:center; gap:.7em;
  margin-bottom:1rem;
}
.eyebrow-mark{width:26px; height:1px; background:linear-gradient(90deg,transparent,var(--gold))}
.gold-ink{
  background:var(--gold-text); -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ===================== TOP BAR ===================== */
.topbar{
  position:sticky; top:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; padding:.85rem clamp(1rem,4vw,2.6rem);
  background:linear-gradient(180deg, rgba(20,13,9,.82), rgba(20,13,9,.42) 70%, transparent);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex; align-items:center; gap:.8rem; cursor:pointer; user-select:none; border-radius:12px}
.brand:focus-visible{outline:2px solid var(--gold); outline-offset:4px}
.brand-logo{width:42px; height:42px; object-fit:contain; filter:drop-shadow(0 2px 8px rgba(230,140,40,.4))}
.brand-txt{display:flex; flex-direction:column; line-height:1.05}
.brand-name{font-family:var(--f-display); font-weight:700; font-size:1.16rem; letter-spacing:.02em;
  background:var(--gold-text); -webkit-background-clip:text; background-clip:text; color:transparent}
.brand-sub{font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--muted)}

.topnav{display:flex; align-items:center; gap:.5rem}
.week-chip{
  font-family:var(--f-mono); font-size:.68rem; letter-spacing:.06em;
  color:var(--ivory-2); padding:.4rem .75rem; border:1px solid var(--line);
  border-radius:999px; background:rgba(40,28,18,.5); white-space:nowrap;
}
.navbtn{
  font-family:var(--f-body); font-weight:600; font-size:.86rem; color:var(--ivory-2);
  background:transparent; border:1px solid transparent; border-radius:999px;
  padding:.5rem .95rem; cursor:pointer; display:inline-flex; align-items:center; gap:.4rem;
  transition:color .25s, background .25s, border-color .25s;
}
.navbtn:hover{color:var(--ivory); background:rgba(231,176,96,.08)}
.navbtn[aria-current="true"]{color:var(--noir); background:var(--gold); border-color:var(--gold)}
.navbtn svg{opacity:.85}

/* ===================== VIEWS ===================== */
.view{max-width:1180px; margin:0 auto; padding:clamp(1.2rem,4vw,2.6rem) clamp(1rem,4vw,2.6rem) 3rem}
.view.hidden{display:none}

/* ===================== HERO ===================== */
.hero{text-align:center; padding:clamp(1.2rem,5vw,2.8rem) 0 clamp(1.4rem,4vw,2.4rem)}
.hero .eyebrow{justify-content:center}
.hero-logo{width:clamp(74px,12vw,108px); height:auto; margin:0 auto 1rem; display:block; filter:drop-shadow(0 8px 26px rgba(230,140,40,.45))}
.hero-title{
  font-family:var(--f-display); font-weight:700; font-optical-sizing:auto;
  font-size:clamp(2.6rem,8vw,4.6rem); line-height:1; letter-spacing:-.01em;
  background:var(--gold-text); -webkit-background-clip:text; background-clip:text; color:transparent;
  display:inline-block;
}
.hero-tag{max-width:48ch; margin:1rem auto 0; color:var(--muted); font-size:1rem}
.hero-meta{display:flex; flex-wrap:wrap; gap:.55rem; justify-content:center; margin-top:1.4rem}
.hero-chip{
  font-family:var(--f-mono); font-size:.72rem; letter-spacing:.04em; color:var(--ivory-2);
  padding:.45rem .85rem; border:1px solid var(--line); border-radius:999px;
  background:linear-gradient(120deg, rgba(231,176,96,.09), rgba(231,176,96,.02));
}

/* ===================== FOIL CARD SYSTEM (signature) ===================== */
.card{position:relative; border-radius:var(--radius); padding:clamp(1.3rem,3vw,1.9rem)}
.foil{
  background:
    linear-gradient(180deg, rgba(40,28,18,.86), rgba(26,18,12,.92));
  border:1px solid transparent;
  background-clip:padding-box;
  box-shadow:
    0 24px 60px -28px rgba(0,0,0,.85),
    inset 0 1px 0 rgba(255,224,170,.08);
}
.foil::before{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:var(--foil-edge);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  opacity:.55; pointer-events:none;
}
.foil::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(120% 60% at 50% -10%, rgba(246,176,72,.10), transparent 60%);
}

.card-head{margin-bottom:1.2rem}
.card-head.row{display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; flex-wrap:wrap}
.card-title{font-family:var(--f-display); font-weight:600; font-size:1.32rem; letter-spacing:.01em; color:var(--ivory)}
.card-desc{font-size:.82rem; color:var(--muted); margin-top:.2rem}

/* ===================== STAGE / FORM ===================== */
.stage{display:grid; grid-template-columns:1.35fr .95fr; gap:clamp(1rem,2.5vw,1.6rem); align-items:start}

.field{margin-bottom:1.05rem; position:relative}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
.field label{display:block; font-size:.74rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--ivory-2); margin-bottom:.5rem}
.lbl-mut{color:var(--muted); font-weight:500; letter-spacing:.04em; text-transform:none}
.field-hint{font-size:.72rem; color:var(--muted); margin-top:.42rem}

.readonly-box{
  width:100%; min-height:46px; display:flex; align-items:center;
  font-family:var(--f-body); font-size:.95rem; color:var(--muted);
  background:rgba(20,13,9,.42); border:1px dashed var(--line); border-radius:var(--radius-sm); padding:.78rem .9rem;
}
.readonly-box.filled{color:var(--gold-2); font-weight:600; border-style:solid; border-color:var(--line-strong); background:rgba(231,176,96,.07)}

.shift-note{font-size:.8rem; color:var(--ivory-2); margin:.1rem 0 1.1rem; padding:.6rem .85rem; border-left:2px solid var(--gold-deep); background:rgba(231,176,96,.05); border-radius:0 8px 8px 0}
.shift-note b{color:var(--gold-2)}

input,select{
  width:100%; font-family:var(--f-body); font-size:.95rem; color:var(--ivory);
  background:rgba(20,13,9,.66); border:1px solid var(--line);
  border-radius:var(--radius-sm); padding:.78rem .9rem;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
input::placeholder{color:#7a6a57}
input:hover,select:hover{border-color:var(--line-strong)}
input:focus,select:focus{outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(230,169,60,.16); background:rgba(20,13,9,.85)}
input[type="time"],input[type="date"]{font-family:var(--f-mono); letter-spacing:.04em}

.select-wrap{position:relative}
.select-wrap select{appearance:none; -webkit-appearance:none; padding-right:2.4rem; cursor:pointer}
.select-wrap .chev{position:absolute; right:.85rem; top:50%; transform:translateY(-50%); width:18px; height:18px; color:var(--gold); pointer-events:none}
.select-wrap.sm select{padding:.6rem .8rem; padding-right:2.2rem; font-size:.86rem}
select optgroup{background:var(--panel-solid); color:var(--gold-2); font-style:normal; font-weight:700}
select option{background:var(--panel-solid); color:var(--ivory)}

/* Total preview */
.total-preview{
  display:flex; align-items:baseline; gap:.8rem; flex-wrap:wrap;
  margin:.4rem 0 1.3rem; padding:.95rem 1.1rem; border-radius:var(--radius-sm);
  background:linear-gradient(120deg, rgba(230,169,60,.12), rgba(230,169,60,.03));
  border:1px solid var(--line);
}
.tp-label{font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ivory-2)}
.tp-value{font-family:var(--f-mono); font-size:1.7rem; font-weight:600; letter-spacing:.02em;
  background:var(--gold-text); -webkit-background-clip:text; background-clip:text; color:transparent; margin-left:auto}
.tp-human{font-size:.82rem; color:var(--muted); width:100%}

/* Gold button */
.btn-gold{
  position:relative; width:auto; display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--f-body); font-weight:700; font-size:.96rem; letter-spacing:.02em;
  color:#3a1d05; cursor:pointer; border:none; border-radius:999px;
  padding:.85rem 1.6rem; width:100%;
  background:linear-gradient(135deg,var(--g3),var(--g4) 45%,var(--g5) 70%,var(--g4));
  box-shadow:0 12px 30px -12px rgba(230,140,40,.7), inset 0 1px 0 rgba(255,255,255,.45);
  transition:transform .18s var(--ease), box-shadow .25s, filter .2s;
  overflow:hidden;
}
.btn-gold::after{content:""; position:absolute; inset:0; background:linear-gradient(100deg,transparent 40%,rgba(255,255,255,.6) 50%,transparent 60%); transform:translateX(-120%); transition:transform .7s var(--ease)}
.btn-gold:hover{transform:translateY(-2px); box-shadow:0 18px 38px -12px rgba(230,140,40,.85)}
.btn-gold:hover::after{transform:translateX(120%)}
.btn-gold:active{transform:translateY(0)}
.btn-gold:focus-visible{outline:2px solid var(--gold-2); outline-offset:3px}
.btn-gold.sm{width:auto; padding:.62rem 1.1rem; font-size:.84rem}
.btn-gold.full{width:100%}

.btn-ghost{
  font-family:var(--f-body); font-weight:600; font-size:.85rem; color:var(--ivory-2);
  background:rgba(231,176,96,.05); border:1px solid var(--line-strong); border-radius:999px;
  padding:.6rem 1.1rem; cursor:pointer; transition:all .2s;
}
.btn-ghost:hover{color:var(--ivory); border-color:var(--gold); background:rgba(231,176,96,.12)}
.btn-ghost.danger:hover{color:#ffd9c9; border-color:var(--ember); background:rgba(217,102,59,.14)}

/* ===================== RECENT CARD ===================== */
.recent-stats{display:flex; gap:.6rem; margin-bottom:1.1rem}
.rs-item{flex:1; text-align:center; padding:.8rem .4rem; border-radius:var(--radius-sm); background:rgba(20,13,9,.5); border:1px solid var(--line)}
.rs-num{display:block; font-family:var(--f-display); font-weight:600; font-size:1.5rem; color:var(--gold-2); font-variant-numeric:tabular-nums}
.rs-lbl{font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted)}
.recent-list{list-style:none; display:flex; flex-direction:column; gap:.55rem; max-height:340px; overflow:auto}
.recent-item{display:flex; align-items:center; gap:.7rem; padding:.65rem .75rem; border-radius:10px; background:rgba(20,13,9,.4); border:1px solid var(--line)}
.ri-dot{width:8px; height:8px; border-radius:50%; background:var(--jade); flex-shrink:0; box-shadow:0 0 8px var(--jade)}
.ri-main{flex:1; min-width:0}
.ri-name{font-weight:600; font-size:.88rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.ri-meta{font-size:.7rem; color:var(--muted); font-family:var(--f-mono)}
.ri-dur{font-family:var(--f-mono); font-size:.84rem; color:var(--gold-2); font-weight:600}
.recent-empty{text-align:center; color:var(--muted); font-size:.85rem; padding:1.2rem 0}

/* ===================== PAGE FOOT ===================== */
.page-foot{display:flex; align-items:center; justify-content:center; gap:.6rem; flex-wrap:wrap;
  margin-top:2.6rem; padding-top:1.4rem; border-top:1px solid var(--line);
  font-size:.74rem; color:var(--muted); letter-spacing:.04em}
.page-foot .dot{color:var(--gold-deep)}

/* ===================== DASHBOARD ===================== */
.dash-head{display:flex; align-items:flex-end; justify-content:space-between; gap:1.2rem; flex-wrap:wrap; margin-bottom:1.6rem}
.dash-title{font-family:var(--f-display); font-weight:700; font-size:clamp(2rem,5vw,3rem); line-height:1; color:var(--ivory)}
.dash-period{font-family:var(--f-mono); font-size:.82rem; letter-spacing:.1em; color:var(--gold-2); margin-top:.5rem}
.dash-actions{display:flex; gap:.6rem; flex-wrap:wrap}

/* KPI */
.kpi-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:1.4rem}
.kpi{padding:1.3rem 1.3rem 1.2rem}
.kpi-label{font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ivory-2)}
.kpi-value{font-family:var(--f-display); font-weight:600; font-size:2.5rem; line-height:1.05; margin-top:.5rem; color:var(--ivory); font-variant-numeric:tabular-nums}
.kpi-value .unit{font-size:1rem; color:var(--gold-2); margin-left:.18rem; font-family:var(--f-mono); font-weight:500}
.kpi-foot{font-size:.74rem; color:var(--muted); margin-top:.35rem; display:flex; align-items:center; gap:.35rem}
.kpi-ic{width:34px; height:34px; border-radius:10px; display:grid; place-items:center; margin-bottom:.2rem;
  background:linear-gradient(135deg,rgba(230,169,60,.22),rgba(230,169,60,.06)); border:1px solid var(--line); color:var(--gold-2)}

/* Charts */
.chart-grid{display:grid; grid-template-columns:1.3fr 1fr; gap:1rem; margin-bottom:1.4rem}
.chart-card.wide{grid-column:1 / -1}
.chart-body{margin-top:.4rem}
.donut-body{display:flex; align-items:center; gap:1.4rem; flex-wrap:wrap; justify-content:center}

/* SVG bar chart */
.bars{display:flex; align-items:flex-end; gap:.5rem; height:200px; padding-top:.5rem}
.bar-col-wrap{flex:1; display:flex; flex-direction:column; align-items:center; gap:.5rem; height:100%; justify-content:flex-end}
.bar{width:100%; max-width:44px; border-radius:7px 7px 3px 3px;
  background:linear-gradient(180deg,var(--g5),var(--g4) 40%,var(--g3));
  box-shadow:0 -2px 14px -4px rgba(246,176,72,.5); position:relative; min-height:3px;
  transition:height .6s var(--ease); animation:grow .7s var(--ease) both}
@keyframes grow{from{transform:scaleY(0); transform-origin:bottom}}
.bar.empty{background:rgba(231,176,96,.1); box-shadow:none}
.bar-val{position:absolute; top:-1.35rem; left:50%; transform:translateX(-50%); font-family:var(--f-mono); font-size:.66rem; color:var(--gold-2); white-space:nowrap}
.bar-lbl{font-size:.68rem; color:var(--muted); letter-spacing:.05em}
.bar-col-wrap.today .bar-lbl{color:var(--gold-2); font-weight:700}

/* Donut */
.donut{flex-shrink:0}
.donut-center{font-family:var(--f-display)}
.legend{display:flex; flex-direction:column; gap:.6rem}
.legend-item{display:flex; align-items:center; gap:.6rem; font-size:.84rem}
.legend-dot{width:11px; height:11px; border-radius:3px; flex-shrink:0}
.legend-name{color:var(--ivory-2)}
.legend-val{margin-left:auto; font-family:var(--f-mono); color:var(--gold-2); font-weight:600; padding-left:1rem}

/* Ranking */
.rank-row{display:grid; grid-template-columns:1.6rem 1fr auto; align-items:center; gap:.8rem; padding:.5rem 0}
.rank-row + .rank-row{border-top:1px solid var(--line)}
.rank-no{font-family:var(--f-mono); font-size:.8rem; color:var(--gold-deep); text-align:center}
.rank-mid{min-width:0}
.rank-name{font-size:.88rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.rank-track{height:7px; border-radius:99px; background:rgba(231,176,96,.1); margin-top:.35rem; overflow:hidden}
.rank-fill{height:100%; border-radius:99px; background:linear-gradient(90deg,var(--g2),var(--g4),var(--g5)); animation:slide .7s var(--ease) both}
@keyframes slide{from{width:0 !important}}
.rank-val{font-family:var(--f-mono); font-size:.84rem; color:var(--gold-2); font-weight:600}
.rank-job{font-size:.68rem; color:var(--muted)}

/* ===================== LEDGER TABLES ===================== */
.ledger-tools{display:flex; gap:.5rem; flex-wrap:wrap}
.table-scroll{overflow-x:auto; margin:0 -.4rem}
.staff-scroll{max-height:360px; overflow-y:auto}
.ledger{width:100%; border-collapse:collapse; font-size:.86rem}
.ledger th{
  text-align:left; font-size:.66rem; letter-spacing:.13em; text-transform:uppercase;
  color:var(--muted); font-weight:700; padding:.7rem .7rem; border-bottom:1px solid var(--line-strong); white-space:nowrap}
.ledger th.num,.ledger td.num{text-align:right; font-variant-numeric:tabular-nums}
.ledger td{padding:.72rem .7rem; border-bottom:1px solid var(--line); vertical-align:middle}
.ledger tbody tr{transition:background .2s}
.ledger tbody tr.clickable{cursor:pointer}
.ledger tbody tr.clickable:hover{background:rgba(231,176,96,.06)}
.ledger.compact td,.ledger.compact th{padding:.55rem .6rem}
.td-name{font-weight:600; color:var(--ivory)}
.td-mono{font-family:var(--f-mono); color:var(--gold-2)}
.pill{display:inline-block; font-size:.66rem; letter-spacing:.06em; padding:.18rem .55rem; border-radius:99px; border:1px solid var(--line-strong); color:var(--ivory-2); white-space:nowrap}
.pill.medis{color:#cfe0c4; border-color:rgba(143,185,122,.4); background:rgba(143,185,122,.08)}
.pill.direksi{color:#f0d59a; border-color:rgba(231,176,96,.4); background:rgba(231,176,96,.08)}
.bar-col{width:22%}
.mini-track{height:7px; border-radius:99px; background:rgba(231,176,96,.1); overflow:hidden}
.mini-fill{height:100%; background:linear-gradient(90deg,var(--g3),var(--g5)); border-radius:99px}

.status-tag{display:inline-flex; align-items:center; gap:.4rem; font-size:.72rem; font-weight:600}
.status-tag::before{content:""; width:7px; height:7px; border-radius:50%}
.status-tag.aktif{color:var(--jade)} .status-tag.aktif::before{background:var(--jade); box-shadow:0 0 7px var(--jade)}
.status-tag.off{color:var(--muted)} .status-tag.off::before{background:var(--muted)}

.icon-btn{background:transparent; border:1px solid var(--line); color:var(--ivory-2); width:30px; height:30px; border-radius:8px; cursor:pointer; display:inline-grid; place-items:center; transition:all .18s}
.icon-btn:hover{border-color:var(--ember); color:#ffd9c9; background:rgba(217,102,59,.12)}
.icon-btn.edit:hover{border-color:var(--gold); color:var(--gold-2); background:rgba(231,176,96,.12)}
.row-tools{display:flex; gap:.35rem; justify-content:flex-end}

/* ===================== ARCHIVE RAIL ===================== */
.archive-count{font-family:var(--f-mono); font-size:.78rem; color:var(--gold-2); padding:.3rem .7rem; border:1px solid var(--line); border-radius:99px}
.archive-rail{display:flex; gap:.85rem; overflow-x:auto; padding:.4rem .2rem 1rem}
.coin{
  flex:0 0 auto; width:172px; text-align:left; cursor:pointer;
  padding:1rem 1.1rem; border-radius:14px; position:relative;
  background:linear-gradient(160deg,rgba(40,28,18,.9),rgba(26,18,12,.95));
  border:1px solid var(--line-strong); transition:transform .2s var(--ease), border-color .2s;
}
.coin:hover{transform:translateY(-3px); border-color:var(--gold)}
.coin-no{font-family:var(--f-mono); font-size:.64rem; letter-spacing:.1em; color:var(--gold-deep)}
.coin-range{font-family:var(--f-display); font-weight:600; font-size:1.02rem; margin:.25rem 0 .55rem; color:var(--ivory); line-height:1.15}
.coin-stat{display:flex; justify-content:space-between; font-size:.72rem; color:var(--muted)}
.coin-stat b{color:var(--gold-2); font-family:var(--f-mono); font-weight:600}
.coin.newest::after{content:"Terbaru"; position:absolute; top:.7rem; right:.7rem; font-size:.56rem; letter-spacing:.1em; text-transform:uppercase; color:var(--noir); background:var(--gold); padding:.1rem .4rem; border-radius:99px; font-weight:700}

/* ===================== ADMIN GRID ===================== */
.admin-grid{display:grid; grid-template-columns:1.25fr 1fr; gap:1rem; margin-top:1.4rem}
.staff-add{display:flex; gap:.5rem; margin-bottom:1rem; flex-wrap:wrap}
.staff-add input{flex:1; min-width:130px}
.staff-add .select-wrap{flex:1; min-width:130px}

.setting-block{padding:1rem 0; border-top:1px solid var(--line)}
.setting-block:first-of-type{border-top:none; padding-top:.3rem}
.setting-h{font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ivory-2); margin-bottom:.7rem; font-weight:700}
.setting-note{font-size:.76rem; color:var(--muted); margin-bottom:.7rem}
.pw-form{display:flex; gap:.5rem; flex-wrap:wrap}
.pw-form input{flex:1; min-width:120px}
.chip-btn{font-family:var(--f-body); font-weight:600; font-size:.78rem; color:var(--ivory-2);
  background:rgba(231,176,96,.06); border:1px solid var(--line-strong); border-radius:99px; padding:.5rem .9rem; cursor:pointer; transition:all .18s; white-space:nowrap}
.chip-btn:hover{color:var(--ivory); border-color:var(--gold); background:rgba(231,176,96,.13)}
.chip-btn.solid{background:var(--gold); color:#3a1d05; border-color:var(--gold)}
.chip-btn.solid:hover{filter:brightness(1.08)}
.file-btn{display:inline-block}
.dz-row{display:flex; gap:.6rem; flex-wrap:wrap}
.chip-btn.outline-danger{border-color:rgba(217,102,59,.45); color:#e9a283}
.chip-btn.outline-danger:hover{background:rgba(217,102,59,.16); border-color:var(--ember); color:#ffd9c9}
.danger-zone .setting-h{color:#e9a283}

/* ===================== ACCESS ROLE + LOGIN OPTIONS ===================== */
.btn-ghost.full{width:100%; display:flex; align-items:center; justify-content:center}
.login-or{display:flex; align-items:center; gap:.8rem; margin:1rem 0; color:var(--muted); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase}
.login-or span{flex:0 0 auto}
.login-or::before,.login-or::after{content:""; height:1px; flex:1; background:var(--line)}
.mode-badge{font-family:var(--f-mono); font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; padding:.38rem .7rem; border-radius:999px; border:1px solid var(--line-strong); color:var(--muted); align-self:center; white-space:nowrap}
.mode-badge.admin{color:var(--jade); border-color:rgba(143,185,122,.4); background:rgba(143,185,122,.08)}
#btnAdminLogin{align-items:center; gap:.4rem; display:inline-flex}

/* ===================== PAYROLL / PENGGAJIAN ===================== */
.payroll-total{font-family:var(--f-mono); font-weight:600; font-size:1.05rem; color:var(--gold-2); padding:.4rem .9rem; border:1px solid var(--line-strong); border-radius:999px; white-space:nowrap; background:rgba(231,176,96,.06)}
.ledger td.pay{color:var(--gold-2); font-weight:600}
.payroll-note{font-size:.76rem; color:var(--muted); margin-top:.85rem}
.ot-tag{font-size:.62rem; color:var(--jade); margin-left:.2rem}
.rate-grid{display:block; overflow-x:auto}
.rate-table{width:100%; border-collapse:collapse; font-size:.82rem; min-width:430px}
.rate-table thead th{text-align:right; font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:700; padding:.5rem .5rem; border-bottom:1px solid var(--line-strong)}
.rate-table thead th:first-child{text-align:left}
.rate-table td{padding:.34rem .5rem; border-bottom:1px solid var(--line); vertical-align:middle; text-align:right}
.rate-table td.rate-name{text-align:left; color:var(--ivory-2); white-space:nowrap}
.rate-div td{font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-2); padding:.9rem .5rem .35rem; border-bottom:1px solid var(--line); text-align:left}
.rp-in{display:inline-flex; align-items:center; gap:.3rem; justify-content:flex-end; color:var(--muted); font-size:.72rem; white-space:nowrap}
.rp-in input{width:90px; padding:.36rem .5rem; font-family:var(--f-mono); text-align:right}
.rp-in i{font-style:normal; font-size:.66rem}

/* ===================== MODALS ===================== */
.modal-overlay{position:fixed; inset:0; z-index:60; display:grid; place-items:center; padding:1.2rem;
  background:rgba(10,7,5,.74); backdrop-filter:blur(7px); animation:fade .3s ease}
@keyframes fade{from{opacity:0}}
.modal{position:relative; width:100%; border-radius:22px; padding:clamp(1.6rem,4vw,2.4rem); animation:pop .4s var(--ease)}
@keyframes pop{from{opacity:0; transform:translateY(16px) scale(.97)}}
.login-modal{max-width:430px; text-align:center}
.detail-modal{max-width:640px; max-height:86vh; display:flex; flex-direction:column; overflow:hidden}
.detail-modal > *{flex-shrink:0}
.detail-modal > .table-scroll{flex:1 1 auto; min-height:0; margin:0; overflow-y:auto}
.modal-x{position:absolute; top:1rem; right:1.1rem; background:transparent; border:none; color:var(--muted); font-size:1.6rem; line-height:1; cursor:pointer; transition:color .2s}
.modal-x:hover{color:var(--ivory)}
.lock-emblem{width:60px; height:60px; margin:0 auto 1.1rem; border-radius:16px; display:grid; place-items:center;
  background:linear-gradient(135deg,rgba(230,169,60,.2),rgba(230,169,60,.05)); border:1px solid var(--line-strong); color:var(--gold-2)}
.modal-title{font-family:var(--f-display); font-weight:700; font-size:1.7rem; color:var(--ivory)}
.modal-sub{color:var(--muted); font-size:.88rem; margin:.5rem auto 1.4rem; max-width:34ch}
.pw-input{position:relative; margin-bottom:.7rem}
.pw-input input{padding-right:3rem; text-align:center; letter-spacing:.12em; font-family:var(--f-mono)}
.pw-eye{position:absolute; right:.6rem; top:50%; transform:translateY(-50%); background:transparent; border:none; color:var(--muted); cursor:pointer; padding:.3rem; display:grid; place-items:center}
.pw-eye:hover{color:var(--gold-2)}
.login-error{color:#f0a487; font-size:.8rem; margin-bottom:.7rem; font-weight:600}
.login-foot{font-size:.74rem; color:var(--muted); margin-top:1.1rem}
.login-foot code{font-family:var(--f-mono); color:var(--gold-2); background:rgba(231,176,96,.1); padding:.1rem .4rem; border-radius:5px}

.detail-head{display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; margin-bottom:1.2rem; padding-right:2rem}
.detail-name{font-family:var(--f-display); font-weight:700; font-size:1.5rem; color:var(--ivory)}
.detail-sub{font-size:.8rem; color:var(--muted); margin-top:.2rem}
.detail-kpis{display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:1.2rem}
.detail-kpi{flex:1; min-width:90px; padding:.7rem .8rem; border-radius:10px; background:rgba(20,13,9,.5); border:1px solid var(--line); text-align:center}
.detail-kpi b{display:block; font-family:var(--f-display); font-size:1.3rem; color:var(--gold-2)}
.detail-kpi span{font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted)}

/* ===================== TOASTS ===================== */
.toasts{position:fixed; bottom:1.4rem; left:50%; transform:translateX(-50%); z-index:90; display:flex; flex-direction:column; gap:.6rem; align-items:center; pointer-events:none; width:max-content; max-width:92vw}
.toast{pointer-events:auto; display:flex; align-items:center; gap:.7rem; padding:.85rem 1.2rem; border-radius:14px;
  background:linear-gradient(180deg,rgba(40,28,18,.97),rgba(26,18,12,.98)); border:1px solid var(--line-strong);
  box-shadow:0 18px 40px -18px rgba(0,0,0,.9); font-size:.86rem; font-weight:600; color:var(--ivory);
  animation:toastIn .4s var(--ease); max-width:90vw}
@keyframes toastIn{from{opacity:0; transform:translateY(14px)}}
.toast.out{animation:toastOut .35s var(--ease) forwards}
@keyframes toastOut{to{opacity:0; transform:translateY(10px)}}
.toast-ic{width:22px; height:22px; border-radius:50%; display:grid; place-items:center; flex-shrink:0; font-size:.8rem}
.toast.ok .toast-ic{background:rgba(143,185,122,.2); color:var(--jade)}
.toast.err .toast-ic{background:rgba(217,102,59,.2); color:var(--ember)}
.toast.info .toast-ic{background:rgba(231,176,96,.2); color:var(--gold-2)}

/* ===================== RESPONSIVE ===================== */
@media (max-width:920px){
  .stage{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .chart-grid{grid-template-columns:1fr}
  .admin-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .brand-sub{display:none}
  .week-chip{display:none}
  .field-row{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .kpi-value{font-size:2rem}
  .hero-title{font-size:clamp(2.2rem,12vw,3.2rem)}
  .recent-stats{flex-wrap:wrap}
  .dash-actions{width:100%}
  .navbtn{padding:.5rem .7rem; font-size:.8rem}
}

/* ===================== A11Y ===================== */
:focus-visible{outline:2px solid var(--gold-2); outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important}
  .bg-glow{animation:none}
}
