/* =====================================================================
   COOL BEANS RESTAURANT — Sistem Absensi
   Theme: "Creamery / Soft-serve" — dusty grape + strawberry-milk drips
   on warm vanilla cream. Cute, creamy, aesthetic. Signature = the drip.
   Master color knobs (live-customizable): --accent, --accent-rgb,
   --pink, --pink-rgb  +  background presets (--bg, --surface, …).
   ===================================================================== */

:root{
  /* ---- master knobs (the color customizer overrides these) ---- */
  --accent:#7A5DC7;        --accent-rgb:122,93,199;     /* soft grape  */
  --pink:#E89AAE;          --pink-rgb:232,154,174;      /* strawberry milk */
  --caramel:#DDA45E;                                    /* 3rd division */

  /* ---- background / surfaces (customizer can swap the bg preset) ---- */
  --bg:#FBF1E6;            --bg-2:#F3E3D2;              /* vanilla cream / latte */
  --surface:#FFFBF7;       --surface-2:#FBF3EA;        /* creamy white / warm inset */
  --inset:#F6EADB;

  /* ---- ink (warm plum) ---- */
  --ink:#43325E;
  --ink-2:#6E6079;
  --muted:#A294A8;

  /* ---- lines & signals ---- */
  --line:rgba(var(--accent-rgb),.2);
  --line-strong:rgba(var(--accent-rgb),.36);
  --success:#8FB46B;       /* matcha   */
  --danger:#E0746B;        /* strawberry red */

  /* ---- type ---- */
  --f-display:'Baloo 2','Fredoka',system-ui,sans-serif;
  --f-body:'Nunito',system-ui,-apple-system,'Segoe UI',sans-serif;
  --f-mono:'IBM Plex Mono',ui-monospace,'SFMono-Regular',monospace;

  /* ---- reusable gradients ---- */
  --grad:linear-gradient(135deg,var(--accent),var(--pink));
  --grad-soft:linear-gradient(135deg,rgba(var(--accent-rgb),.16),rgba(var(--pink-rgb),.16));

  --radius:22px;
  --radius-sm:14px;
  --shadow:0 22px 48px -28px rgba(var(--accent-rgb),.45), 0 6px 18px -12px rgba(var(--pink-rgb),.4);
  --shadow-sm:0 12px 26px -16px rgba(var(--accent-rgb),.36);
  --ease:cubic-bezier(.22,.61,.36,1);

  /* ---- soft snow/cream cap for card tops (white-on-transparent for masks) ---- */
  --cap:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='12' viewBox='0 0 40 12'%3E%3Cpath fill='%23fff' d='M0 12 H40 V5 C36 5 35 0 30 0 C25 0 24 5 20 5 C16 5 15 0 10 0 C5 0 4 5 0 5 Z'/%3E%3C/svg%3E");
}

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

/* ---------------- Ambient creamy backdrop ---------------- */
.bg-sky{
  position:fixed; inset:0; z-index:-3;
  background:
    radial-gradient(52% 42% at 88% 2%, rgba(var(--pink-rgb),.30), transparent 60%),
    radial-gradient(50% 42% at 6% 4%, rgba(var(--accent-rgb),.20), transparent 60%),
    radial-gradient(70% 55% at 50% 116%, rgba(var(--pink-rgb),.16), transparent 62%),
    linear-gradient(180deg,var(--bg),var(--bg-2));
}
.bg-glow{
  position:fixed; left:50%; top:-20vh; z-index:-2;
  width:80vw; height:56vh; transform:translateX(-50%);
  background:radial-gradient(closest-side, rgba(var(--pink-rgb),.22), rgba(var(--accent-rgb),.05) 56%, transparent 72%);
  filter:blur(12px);
  animation:floaty 20s var(--ease) infinite alternate;
  pointer-events:none;
}
@keyframes floaty{
  from{opacity:.7; transform:translateX(-50%) translateY(0) scale(1)}
  to  {opacity:1;  transform:translateX(-50%) translateY(20px) scale(1.06)}
}
/* sprinkles — hearts, sparkles, swirls & dots, echoing the shirt's patterned cream */
.bg-grain{
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.55;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='168' height='168' viewBox='0 0 168 168'%3E%3Cg fill='%23E89AAE' fill-opacity='0.14'%3E%3Cpath d='M30 46 C24 40 20 36 20 32 C20 29 22 27.5 24.5 27.5 C26.5 27.5 28 28.8 30 31 C32 28.8 33.5 27.5 35.5 27.5 C38 27.5 40 29 40 32 C40 36 36 40 30 46 Z'/%3E%3Cpath d='M128 26 C129 33 131 35 138 36 C131 37 129 39 128 46 C127 39 125 37 118 36 C125 35 127 33 128 26 Z'/%3E%3Cpath d='M104 132 C100 128 97 125 97 122 C97 120 98.5 119 100 119 C101.5 119 102.5 119.8 104 121.4 C105.5 119.8 106.5 119 108 119 C109.5 119 111 120 111 122 C111 125 108 128 104 132 Z'/%3E%3Cpath d='M152 96 C152.8 101 154 102.2 159 103 C154 103.8 152.8 105 152 110 C151.2 105 150 103.8 145 103 C150 102.2 151.2 101 152 96 Z'/%3E%3Ccircle cx='84' cy='80' r='2.3'/%3E%3Ccircle cx='150' cy='150' r='1.9'/%3E%3Ccircle cx='20' cy='110' r='1.9'/%3E%3Ccircle cx='70' cy='20' r='1.7'/%3E%3C/g%3E%3Cg fill='none' stroke='%23E89AAE' stroke-opacity='0.14' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M40 122 C40 116 53 116 53 123 C53 128 44 128 44 122.5'/%3E%3Cpath d='M120 70 C120 65 131 65 131 71 C131 75.5 123 75.5 123 71'/%3E%3C/g%3E%3C/svg%3E");
}

/* ---------------- Shared type helpers ---------------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:.72rem; letter-spacing:.26em; text-transform:uppercase;
  color:var(--accent); display:flex; align-items:center; gap:.7em;
  margin-bottom:1rem; font-weight:600;
}
.eyebrow-mark{width:24px; height:3px; border-radius:3px; background:var(--grad)}

/* ---------------- Cool Beans logo mark ---------------- */
.cb-logo .hat{fill:var(--accent)}
.cb-logo .band{fill:var(--pink)}
.cb-logo .stache,.cb-logo .eye{fill:var(--ink)}
.cb-logo .brow{fill:none; stroke:var(--ink); stroke-width:2.1; stroke-linecap:round}

/* Real Cool Beans logo (white line-art) on a soft grape→rose badge — like the shirt */
.logo-badge{display:inline-grid; place-items:center; border-radius:50%; background:var(--grad); flex-shrink:0;
  box-shadow:0 14px 28px -14px rgba(var(--accent-rgb),.55), inset 0 2px 6px rgba(255,255,255,.32)}
.logo-badge img{width:74%; height:74%; object-fit:contain; display:block}
.hero-badge{width:clamp(98px,15vw,134px); height:clamp(98px,15vw,134px); margin:0 auto .9rem}
.brand-badge{width:44px; height:44px}
.brand-badge img{width:78%; height:78%}

/* ===================== TOP BAR ===================== */
.topbar{
  position:sticky; top:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; padding:.7rem clamp(1rem,4vw,2.6rem);
  background:linear-gradient(180deg, rgba(255,251,247,.9), rgba(255,251,247,.62) 72%, rgba(255,251,247,.32));
  backdrop-filter:blur(14px);
}
.brand{display:flex; align-items:center; gap:.7rem; cursor:pointer; user-select:none; border-radius:16px}
.brand:focus-visible{outline:2px solid var(--accent); outline-offset:4px}
.brand-logo{width:44px; height:44px; object-fit:contain; filter:drop-shadow(0 5px 8px rgba(var(--accent-rgb),.3))}
.brand-txt{display:flex; flex-direction:column; line-height:1.06}
.brand-name{font-family:var(--f-display); font-weight:800; font-size:1.34rem; letter-spacing:.005em;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent}
.brand-sub{font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); font-weight:600; font-style:italic}

.topnav{display:flex; align-items:center; gap:.5rem}
.week-chip{
  font-family:var(--f-mono); font-size:.68rem; letter-spacing:.04em;
  color:var(--ink-2); padding:.4rem .75rem; border:1px solid var(--line);
  border-radius:999px; background:rgba(var(--accent-rgb),.05); white-space:nowrap;
}
.navbtn{
  font-family:var(--f-body); font-weight:700; font-size:.86rem; color:var(--ink-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(--accent); background:rgba(var(--accent-rgb),.09)}
.navbtn[aria-current="true"]{color:#fff; background:var(--grad); border-color:transparent; box-shadow:var(--shadow-sm)}
.navbtn svg{opacity:.9}

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

/* ===================== HERO ===================== */
.hero{text-align:center; padding:clamp(1rem,4vw,2.4rem) 0 clamp(1.2rem,3.4vw,2rem)}
.hero .eyebrow{justify-content:center}
.hero-logo{width:clamp(86px,13vw,122px); height:auto; margin:0 auto .8rem; display:block; filter:drop-shadow(0 12px 22px rgba(var(--accent-rgb),.28))}
.hero-title{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(2.8rem,8.4vw,4.8rem); line-height:1; letter-spacing:0;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
  display:inline-block;
}
.hero-tag{max-width:48ch; margin:.9rem auto 0; color:var(--ink-2); font-size:1rem}
.hero-meta{display:flex; flex-wrap:wrap; gap:.55rem; justify-content:center; margin-top:1.3rem}
.hero-chip{
  font-family:var(--f-mono); font-size:.72rem; letter-spacing:.04em; color:var(--ink-2);
  padding:.45rem .85rem; border:1px solid var(--line); border-radius:999px;
  background:var(--surface);
}

/* ===================== CARD SYSTEM ===================== */
.card{position:relative; border-radius:var(--radius); padding:clamp(1.3rem,3vw,1.9rem)}
/* Cards: soft creamy "snow cap" top + melting-ice-cream pool at the bottom
   + a faint shirt-motif texture (all behind text, so readability is safe) */
.foil{
  position:relative;
  background-color:var(--surface);
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='148' height='148' viewBox='0 0 148 148'%3E%3Cg fill='%23E89AAE' fill-opacity='0.055'%3E%3Cpath d='M110 44 C105 39 102 36 102 33 C102 30.8 103.5 29.5 105.5 29.5 C107 29.5 108.3 30.4 110 32.3 C111.7 30.4 113 29.5 114.5 29.5 C116.5 29.5 118 30.8 118 33 C118 36 115 39 110 44 Z'/%3E%3Cpath d='M30 28 C31 34 32.6 35.6 38 36.6 C32.6 37.6 31 39.2 30 44.6 C29 39.2 27.4 37.6 22 36.6 C27.4 35.6 29 34 30 28 Z'/%3E%3Ccircle cx='74' cy='80' r='2.2'/%3E%3Ccircle cx='122' cy='112' r='1.8'/%3E%3Ccircle cx='30' cy='106' r='1.7'/%3E%3C/g%3E%3Cg fill='none' stroke='%23E89AAE' stroke-opacity='0.06' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M58 116 C58 111 69 111 69 117 C69 121.5 61 121.5 61 117'/%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg, rgba(var(--accent-rgb),.2), rgba(var(--accent-rgb),0) 30px),
    radial-gradient(130% 88% at 50% 134%, rgba(var(--pink-rgb),.22), rgba(var(--pink-rgb),.06) 44%, transparent 70%);
  background-repeat:repeat, no-repeat, no-repeat;
  background-position:center top, center top, center bottom;
  background-size:148px 148px, 100% 100%, 100% 80%;
  border-radius:var(--radius);
  -webkit-mask-image:var(--cap), linear-gradient(#fff,#fff);
  -webkit-mask-repeat:repeat-x, no-repeat;
  -webkit-mask-position:top center, bottom center;
  -webkit-mask-size:40px 12px, 100% calc(100% - 11px);
  mask-image:var(--cap), linear-gradient(#fff,#fff);
  mask-repeat:repeat-x, no-repeat;
  mask-position:top center, bottom center;
  mask-size:40px 12px, 100% calc(100% - 11px);
  box-shadow:inset 0 0 0 1.6px rgba(var(--accent-rgb),.34), inset 0 2.5px 0 rgba(255,255,255,.6);
  filter:drop-shadow(0 16px 22px rgba(var(--accent-rgb),.2)) drop-shadow(0 5px 9px rgba(var(--pink-rgb),.16));
}
.foil::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.6), transparent 22%);
}

.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:700; font-size:1.46rem; letter-spacing:.005em; color:var(--accent); display:inline-flex; align-items:center}
.card-desc{font-size:.84rem; color:var(--muted); margin-top:.18rem}

/* ===================== 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:.07em; text-transform:uppercase; color:var(--ink-2); margin-bottom:.5rem}
.lbl-mut{color:var(--muted); font-weight:600; letter-spacing:.02em; 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); font-weight:600;
  background:var(--inset); border:1px dashed var(--line-strong); border-radius:var(--radius-sm); padding:.78rem .9rem;
}
.readonly-box.filled{color:var(--accent); font-weight:800; border-style:solid; border-color:var(--line-strong); background:rgba(var(--accent-rgb),.08)}

.shift-note{font-size:.8rem; color:var(--ink-2); margin:.1rem 0 1.1rem; padding:.6rem .85rem; border-left:3px solid var(--pink); background:rgba(var(--pink-rgb),.1); border-radius:0 12px 12px 0}
.shift-note b{color:var(--accent)}

input,select{
  width:100%; font-family:var(--f-body); font-size:.95rem; font-weight:600; color:var(--ink);
  background:var(--surface); border:1.5px solid var(--line-strong);
  border-radius:var(--radius-sm); padding:.78rem .9rem;
  transition:border-color .2s, box-shadow .2s, background .2s;
}
input::placeholder{color:#bdb0c4; font-weight:500}
input:hover,select:hover{border-color:var(--accent)}
input:focus,select:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(var(--accent-rgb),.18); background:var(--surface)}
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(--accent); pointer-events:none}
.select-wrap.sm select{padding:.6rem .8rem; padding-right:2.2rem; font-size:.86rem}
select optgroup{background:var(--surface); color:var(--accent); font-style:normal; font-weight:700}
select option{background:var(--surface); color:var(--ink)}

/* 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:var(--grad-soft);
  border:1px solid var(--line);
}
.tp-label{font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); font-weight:700}
.tp-value{font-family:var(--f-mono); font-size:1.7rem; font-weight:600; letter-spacing:.02em;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent; margin-left:auto}
.tp-human{font-size:.82rem; color:var(--muted); width:100%}

/* Primary (candy) button — class kept as .btn-gold for compatibility */
.btn-gold{
  position:relative; display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--f-display); font-weight:600; font-size:1rem; letter-spacing:.01em;
  color:#fff; cursor:pointer; border:none; border-radius:999px;
  padding:.82rem 1.6rem; width:100%;
  background:var(--grad);
  box-shadow:0 14px 28px -12px rgba(var(--accent-rgb),.65), 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,.5) 50%,transparent 60%); transform:translateX(-120%); transition:transform .7s var(--ease)}
.btn-gold:hover{transform:translateY(-2px); box-shadow:0 20px 38px -12px rgba(var(--accent-rgb),.78)}
.btn-gold:hover::after{transform:translateX(120%)}
.btn-gold:active{transform:translateY(0)}
.btn-gold:focus-visible{outline:2px solid var(--accent); outline-offset:3px}
.btn-gold.sm{width:auto; padding:.6rem 1.1rem; font-size:.88rem}
.btn-gold.full{width:100%}

.btn-ghost{
  font-family:var(--f-body); font-weight:700; font-size:.85rem; color:var(--ink-2);
  background:var(--surface); border:1.5px solid var(--line-strong); border-radius:999px;
  padding:.58rem 1.1rem; cursor:pointer; transition:all .2s;
}
.btn-ghost:hover{color:var(--accent); border-color:var(--accent); background:rgba(var(--accent-rgb),.07)}
.btn-ghost.danger:hover{color:var(--danger); border-color:var(--danger); background:rgba(224,116,107,.1)}

/* ===================== 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:var(--inset); border:1px solid var(--line)}
.rs-num{display:block; font-family:var(--f-display); font-weight:600; font-size:1.6rem; color:var(--accent); font-variant-numeric:tabular-nums}
.rs-lbl{font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:600}
.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:14px; background:var(--surface-2); border:1px solid var(--line)}
.ri-dot{width:9px; height:9px; border-radius:50%; background:var(--success); flex-shrink:0; box-shadow:0 0 8px rgba(143,180,107,.7)}
.ri-main{flex:1; min-width:0}
.ri-name{font-weight:700; 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(--accent); 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:.02em; font-weight:600}
.page-foot .dot{color:var(--pink)}

/* ===================== 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(--ink)}
.dash-period{font-family:var(--f-mono); font-size:.82rem; letter-spacing:.06em; color:var(--accent); 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:.1em; text-transform:uppercase; color:var(--ink-2); font-weight:700}
.kpi-value{font-family:var(--f-display); font-weight:600; font-size:2.5rem; line-height:1.05; margin-top:.5rem; color:var(--ink); font-variant-numeric:tabular-nums}
.kpi-value .unit{font-size:1rem; color:var(--accent); 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:36px; height:36px; border-radius:12px; display:grid; place-items:center; margin-bottom:.2rem;
  background:var(--grad-soft); border:1px solid var(--line); color:var(--accent)}

/* 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}

/* 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:11px 11px 5px 5px;
  background:linear-gradient(180deg,var(--pink),var(--accent));
  box-shadow:0 -2px 14px -4px rgba(var(--accent-rgb),.45); 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(var(--accent-rgb),.13); 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(--accent); white-space:nowrap; font-weight:600}
.bar-lbl{font-size:.68rem; color:var(--muted); letter-spacing:.04em; font-weight:600}
.bar-col-wrap.today .bar-lbl{color:var(--accent); font-weight:800}

/* 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:.86rem}
.legend-dot{width:12px; height:12px; border-radius:5px; flex-shrink:0}
.legend-name{color:var(--ink-2); font-weight:600}
.legend-val{margin-left:auto; font-family:var(--f-mono); color:var(--accent); 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(--pink); text-align:center; font-weight:600}
.rank-mid{min-width:0}
.rank-name{font-size:.88rem; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.rank-track{height:9px; border-radius:99px; background:rgba(var(--accent-rgb),.12); margin-top:.35rem; overflow:hidden}
.rank-fill{height:100%; border-radius:99px; background:var(--grad); animation:slide .7s var(--ease) both}
@keyframes slide{from{width:0 !important}}
.rank-val{font-family:var(--f-mono); font-size:.84rem; color:var(--accent); 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:.08em; text-transform:uppercase;
  color:var(--muted); font-weight:700; padding:.7rem .7rem; border-bottom:2px 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(var(--accent-rgb),.07)}
.ledger.compact td,.ledger.compact th{padding:.55rem .6rem}
.td-name{font-weight:700; color:var(--ink)}
.td-mono{font-family:var(--f-mono); color:var(--accent)}
.pill{display:inline-block; font-size:.66rem; font-weight:700; letter-spacing:.02em; padding:.18rem .55rem; border-radius:99px; border:1px solid var(--line-strong); color:var(--ink-2); white-space:nowrap}
.bar-col{width:22%}
.mini-track{height:9px; border-radius:99px; background:rgba(var(--accent-rgb),.12); overflow:hidden}
.mini-fill{height:100%; background:var(--grad); border-radius:99px}

.status-tag{display:inline-flex; align-items:center; gap:.4rem; font-size:.72rem; font-weight:700; background:none; border:none; cursor:pointer; font-family:var(--f-body)}
.status-tag::before{content:""; width:7px; height:7px; border-radius:50%}
.status-tag.aktif{color:var(--success)} .status-tag.aktif::before{background:var(--success); box-shadow:0 0 7px rgba(143,180,107,.8)}
.status-tag.off{color:var(--muted)} .status-tag.off::before{background:var(--muted)}

.icon-btn{background:var(--surface); border:1.5px solid var(--line-strong); color:var(--ink-2); width:30px; height:30px; border-radius:10px; cursor:pointer; display:inline-grid; place-items:center; transition:all .18s}
.icon-btn:hover{border-color:var(--danger); color:var(--danger); background:rgba(224,116,107,.1)}
.icon-btn.edit:hover{border-color:var(--accent); color:var(--accent); background:rgba(var(--accent-rgb),.08)}
.row-tools{display:flex; gap:.35rem; justify-content:flex-end}

/* ===================== ARCHIVE RAIL ===================== */
.archive-count{font-family:var(--f-mono); font-size:.78rem; color:var(--accent); padding:.3rem .7rem; border:1px solid var(--line-strong); border-radius:99px}
.archive-rail{display:flex; gap:.85rem; overflow-x:auto; padding:.4rem .2rem 1rem}
.coin{
  flex:0 0 auto; width:176px; text-align:left; cursor:pointer;
  padding:1rem 1.1rem; border-radius:18px; position:relative;
  background:var(--surface);
  border:1.5px solid var(--line-strong); box-shadow:var(--shadow-sm);
  transition:transform .2s var(--ease), border-color .2s, box-shadow .2s;
}
.coin:hover{transform:translateY(-3px); border-color:var(--accent); box-shadow:var(--shadow)}
.coin-no{font-family:var(--f-mono); font-size:.64rem; letter-spacing:.06em; color:var(--pink); font-weight:600}
.coin-range{font-family:var(--f-display); font-weight:600; font-size:1.05rem; margin:.25rem 0 .55rem; color:var(--ink); line-height:1.15}
.coin-stat{display:flex; justify-content:space-between; font-size:.72rem; color:var(--muted); font-weight:600}
.coin-stat b{color:var(--accent); font-family:var(--f-mono); font-weight:600}
.coin.newest::after{content:"Terbaru"; position:absolute; top:.7rem; right:.7rem; font-size:.56rem; letter-spacing:.06em; text-transform:uppercase; color:#fff; background:var(--grad); padding:.14rem .44rem; 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:.06em; text-transform:uppercase; color:var(--ink-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:700; font-size:.78rem; color:var(--ink-2);
  background:var(--surface); border:1.5px solid var(--line-strong); border-radius:99px; padding:.5rem .9rem; cursor:pointer; transition:all .18s; white-space:nowrap}
.chip-btn:hover{color:var(--accent); border-color:var(--accent); background:rgba(var(--accent-rgb),.07)}
.chip-btn.solid{background:var(--grad); color:#fff; border-color:transparent}
.chip-btn.solid:hover{filter:brightness(1.05); color:#fff}
.file-btn{display:inline-block}
.dz-row{display:flex; gap:.6rem; flex-wrap:wrap}
.chip-btn.outline-danger{border-color:rgba(224,116,107,.5); color:var(--danger)}
.chip-btn.outline-danger:hover{background:rgba(224,116,107,.12); border-color:var(--danger); color:var(--danger)}
.danger-zone .setting-h{color:var(--danger)}

/* ===================== 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:.12em; text-transform:uppercase; font-weight:700}
.login-or span{flex:0 0 auto}
.login-or::before,.login-or::after{content:""; height:1px; flex:1; background:var(--line-strong)}
.mode-badge{font-family:var(--f-mono); font-size:.64rem; letter-spacing:.08em; 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(--success); border-color:rgba(143,180,107,.45); background:rgba(143,180,107,.1)}
#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(--accent); padding:.4rem .9rem; border:1px solid var(--line-strong); border-radius:999px; white-space:nowrap; background:rgba(var(--accent-rgb),.06)}
.ledger td.pay{color:var(--accent); font-weight:700}
.payroll-note{font-size:.76rem; color:var(--muted); margin-top:.85rem}
.ot-tag{font-size:.62rem; color:var(--pink); margin-left:.2rem; font-weight:700}
.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:.06em; text-transform:uppercase; color:var(--muted); font-weight:700; padding:.5rem .5rem; border-bottom:2px 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(--ink-2); white-space:nowrap; font-weight:700}
.rate-div td{font-size:.64rem; letter-spacing:.08em; text-transform:uppercase; color:var(--pink); font-weight:700; 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}

/* ===================== SEGMENTED RANGE CONTROL ===================== */
.seg{display:inline-flex; gap:.25rem; padding:.25rem; border:1.5px solid var(--line-strong); border-radius:999px; background:var(--surface); flex-wrap:wrap}
.seg-btn{font-family:var(--f-body); font-weight:700; font-size:.74rem; letter-spacing:.01em; color:var(--ink-2);
  background:transparent; border:none; border-radius:999px; padding:.4rem .82rem; cursor:pointer; white-space:nowrap;
  transition:color .18s, background .18s, box-shadow .18s}
.seg-btn:hover{color:var(--accent); background:rgba(var(--accent-rgb),.09)}
.seg-btn.active{color:#fff; background:var(--grad); box-shadow:var(--shadow-sm)}
.seg-btn:focus-visible{outline:2px solid var(--accent); outline-offset:2px}
.period-bar{display:flex; align-items:center; gap:.85rem; flex-wrap:wrap; margin:-.2rem 0 1.4rem}
.period-bar-label{font-family:var(--f-mono); font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted)}

/* Archive coin — total gaji line */
.coin-stat.gaji{margin-top:.45rem; padding-top:.45rem; border-top:1px dashed var(--line-strong)}
.coin-stat.gaji b{color:var(--pink)}

/* Archive modal — sub-sections */
.arch-sub{display:flex; align-items:center; justify-content:space-between; gap:1rem; margin:1.4rem 0 .55rem; padding-top:1.1rem; border-top:1px solid var(--line)}
.arch-sub.first{margin-top:.1rem; padding-top:0; border-top:none}
.arch-sub-title{font-family:var(--f-display); font-weight:600; font-size:1.08rem; color:var(--accent)}
.payroll-total.sm{font-size:.86rem; padding:.32rem .7rem}

/* ===================== MODALS ===================== */
.modal-overlay{position:fixed; inset:0; z-index:60; display:grid; place-items:center; padding:1.2rem;
  background:rgba(67,50,94,.3); backdrop-filter:blur(7px); animation:fade .3s ease}
@keyframes fade{from{opacity:0}}
.modal{position:relative; width:100%; border-radius:26px; 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(--ink)}
.lock-emblem{width:62px; height:62px; margin:0 auto 1.1rem; border-radius:20px; display:grid; place-items:center;
  background:var(--grad-soft); border:1px solid var(--line-strong); color:var(--accent)}
.modal-title{font-family:var(--f-display); font-weight:700; font-size:1.8rem; color:var(--ink)}
.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(--accent)}
.login-error{color:var(--danger); font-size:.8rem; margin-bottom:.7rem; font-weight:700}
.login-foot{font-size:.74rem; color:var(--muted); margin-top:1.1rem}
.login-foot code{font-family:var(--f-mono); color:var(--accent); background:rgba(var(--accent-rgb),.1); padding:.1rem .4rem; border-radius:7px; font-weight:600}

.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.55rem; color:var(--ink)}
.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:14px; background:var(--inset); border:1px solid var(--line); text-align:center}
.detail-kpi b{display:block; font-family:var(--f-display); font-size:1.35rem; color:var(--accent)}
.detail-kpi span{font-size:.64rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); font-weight:600}

/* ===================== 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:18px;
  background:var(--surface); border:1.5px solid var(--line-strong);
  box-shadow:var(--shadow); font-size:.86rem; font-weight:700; color:var(--ink);
  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,180,107,.18); color:var(--success)}
.toast.err .toast-ic{background:rgba(224,116,107,.18); color:var(--danger)}
.toast.info .toast-ic{background:rgba(var(--accent-rgb),.14); color:var(--accent)}

/* ===================== COLOR CUSTOMIZER (dashboard · manajemen) ===================== */
.theme-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; align-items:start}
.theme-sec-label{font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:700; margin-bottom:.6rem}
.preset-grid{display:flex; gap:.6rem; flex-wrap:wrap}
.preset-chip{width:38px; height:38px; border-radius:50%; cursor:pointer; border:3px solid var(--surface);
  box-shadow:0 0 0 1px var(--line-strong); transition:transform .15s var(--ease); padding:0}
.preset-chip:hover{transform:scale(1.12)}
.preset-chip.active{box-shadow:0 0 0 2px var(--accent)}
.color-fields{display:flex; gap:.6rem; flex-wrap:wrap}
.color-field{flex:1; min-width:118px; display:flex; align-items:center; gap:.55rem; padding:.5rem .6rem; border:1.5px solid var(--line-strong); border-radius:14px; background:var(--surface-2)}
.color-field label{font-size:.8rem; color:var(--ink-2); font-weight:700}
.color-field input[type="color"]{width:32px; height:32px; padding:0; border:none; border-radius:9px; background:none; cursor:pointer; flex-shrink:0}
.color-field input[type="color"]::-webkit-color-swatch-wrapper{padding:0}
.color-field input[type="color"]::-webkit-color-swatch{border:1px solid var(--line-strong); border-radius:9px}
.bg-grid{display:flex; gap:.55rem; flex-wrap:wrap}
.bg-swatch{width:34px; height:34px; border-radius:11px; cursor:pointer; border:3px solid var(--surface); box-shadow:0 0 0 1px var(--line-strong); transition:transform .15s var(--ease); padding:0}
.bg-swatch:hover{transform:scale(1.1)}
.bg-swatch.active{box-shadow:0 0 0 2px var(--accent)}
.theme-reset{font-family:var(--f-body); font-weight:700; font-size:.78rem; color:var(--ink-2);
  background:var(--surface); border:1.5px solid var(--line-strong); border-radius:99px; padding:.5rem .9rem; cursor:pointer; transition:all .18s; display:inline-flex; align-items:center; gap:.4rem}
.theme-reset:hover{color:var(--accent); border-color:var(--accent); background:rgba(var(--accent-rgb),.07)}
@media (max-width:680px){ .theme-grid{grid-template-columns:1fr} }

/* ===================== DECOR: field icons + hero motifs ===================== */
.ro-wrap{position:relative}
.select-wrap.has-ic select{padding-left:2.6rem}
.readonly-box.has-ic{padding-left:2.55rem}
.field-ic{position:absolute; left:.92rem; top:50%; transform:translateY(-50%); width:18px; height:18px; color:var(--accent); pointer-events:none; opacity:.92}
.card-title .ct-ic{width:21px; height:21px; color:var(--accent); vertical-align:-3px; margin-right:.45rem}

.hero{position:relative; z-index:0}
.hero-deco{position:absolute; inset:-4% -1% 0; pointer-events:none; z-index:-1}
.hero-deco .m{position:absolute; color:var(--pink); opacity:.5; animation:bob 6s var(--ease) infinite alternate}
.hero-deco .m svg{display:block; width:100%; height:100%}
.hero-deco .m1{left:5%; top:24%; width:26px; height:26px; color:var(--accent); opacity:.4; animation-delay:.3s}
.hero-deco .m2{right:7%; top:12%; width:30px; height:30px; animation-delay:1.1s}
.hero-deco .m3{left:13%; bottom:10%; width:22px; height:22px; animation-delay:.7s}
.hero-deco .m4{right:11%; bottom:18%; width:27px; height:27px; color:var(--accent); opacity:.34; animation-delay:1.5s}
@keyframes bob{from{transform:translateY(0) rotate(-5deg)} to{transform:translateY(-12px) rotate(5deg)}}
@media (max-width:560px){ .hero-deco .m1,.hero-deco .m3{display:none} }

/* ===================== 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.4rem,12vw,3.2rem)}
  .recent-stats{flex-wrap:wrap}
  .dash-actions{width:100%}
  .navbtn{padding:.5rem .7rem; font-size:.8rem}
  .seg{width:100%}
  .seg-btn{flex:1 1 auto; text-align:center; padding:.45rem .5rem}
}

/* ===================== A11Y ===================== */
:focus-visible{outline:2px solid var(--accent); 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}
}
