/* Admin desktop — SNC theme aligned to safencare.co.id (orange #F7951D, Inter) */
:root{
  --snc:#F7951D;        /* primary brand orange (matches public site) */
  --snc-dark:#d97a0a;   /* hover/pressed */
  --snc-soft:#fff4e5;   /* very soft orange — active menu, hover bg */
  --snc-soft-2:#fde2bf; /* soft orange accent border */
  --bg:#f3f4f5;         /* neutral gray page bg (SNC section bg) */
  --card:#ffffff;
  --border:#e5e7eb;
  --text:#1A1A1A;       /* primary text — SNC dark */
  --muted:#717171;      /* secondary text — SNC muted */
  --thead:#2b2b2b;      /* table header — dark neutral, pro admin feel */
  --btn:#F7951D;        /* primary CTA = SNC orange */
  --btn-dark:#d97a0a;
  --link:#c46a00;       /* darker orange, readable on white */
  --danger:#e14d4d;
  --ok:#27a46a;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:"Inter","Segoe UI",Roboto,-apple-system,BlinkMacSystemFont,Arial,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

/* Topbar */
.a-topbar{position:fixed;top:0;left:0;right:0;height:56px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;z-index:50}
.a-topbar .brand{display:flex;align-items:center;gap:10px;padding-left:4px;flex-shrink:0}
.a-topbar .brand img{height:36px;width:auto;max-width:240px;object-fit:contain;display:block}
.a-topbar .brand span{font-weight:700;color:var(--snc);font-size:18px;letter-spacing:.5px}
.a-topbar .title{color:var(--text);font-size:16px;margin-left:12px;flex:1}
.a-topbar .user{display:flex;align-items:center;gap:10px;cursor:pointer;position:relative}
.a-topbar .user .avatar{width:34px;height:34px;border-radius:50%;background:var(--snc);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}
.a-topbar .user .name{font-weight:600;text-transform:uppercase;font-size:13px}
.a-topbar .user-menu{position:absolute;top:44px;right:0;background:#fff;border:1px solid var(--border);border-radius:6px;min-width:220px;box-shadow:0 4px 16px rgba(0,0,0,.12);display:none;overflow:hidden}
.a-topbar .user-menu.open{display:block}
.a-topbar .user-menu-header{padding:14px 16px 12px;border-bottom:1px solid var(--border);text-align:right}
.a-topbar .user-menu-header .user-email{font-size:13px;color:var(--text);font-weight:500;margin-bottom:2px}
.a-topbar .user-menu-header .user-role{font-size:12px;color:#888}
.a-topbar .user-menu a{display:block;padding:10px 16px;color:var(--text);text-align:right;font-size:13px}
.a-topbar .user-menu a i{margin-right:6px;color:#999}
.a-topbar .user-menu a:hover{background:var(--snc-soft);color:var(--snc-dark);text-decoration:none}

/* Sidebar */
.a-sidebar{position:fixed;top:56px;left:0;bottom:0;width:200px;background:#fff;border-right:1px solid var(--border);overflow-y:auto;padding:10px 0}
.a-sidebar .item{display:flex;align-items:center;gap:10px;padding:11px 18px;color:#4b5563;cursor:pointer;position:relative}
.a-sidebar .item:hover{background:var(--snc-soft);color:var(--snc-dark);text-decoration:none}
.a-sidebar .item.active{background:var(--snc-soft);color:var(--snc-dark);font-weight:600;border-left:3px solid var(--snc);padding-left:15px}
.a-sidebar .item i{width:16px;text-align:center}
.a-sidebar .item .chev{margin-left:auto;font-size:10px;color:#bbb}
.a-sidebar .sub{display:none;padding-left:38px;background:#fafbfc}
.a-sidebar .sub.open{display:block}
.a-sidebar .sub a{display:block;padding:8px 10px;color:#4b5563;font-size:13px}
.a-sidebar .sub a:hover{color:var(--snc-dark);text-decoration:none}
.a-sidebar .sub a.active{color:var(--snc-dark);font-weight:600}

/* Main */
.a-main{margin-left:200px;padding-top:56px;min-height:100vh}
.a-page{padding:18px 22px}
/* List pages: scroll isi tabel saja, bukan seluruh page. Header table sticky.
   max-height = viewport minus topbar(56) + page padding + filter/pageinfo ~= 220px. */
.a-table-wrap{max-height:calc(100vh - 220px);overflow-y:auto}
.a-table thead th{position:sticky;top:0;z-index:2}

/* Action bar */
.a-actions{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.a-btn{background:var(--btn);color:#fff;padding:9px 16px;border:none;border-radius:4px;cursor:pointer;font-size:13px;display:inline-flex;align-items:center;gap:6px;text-decoration:none;font-weight:500}
.a-btn:hover{background:var(--btn-dark);text-decoration:none;color:#fff}
.a-btn-primary{background:var(--btn)}
.a-btn-primary:hover{background:var(--btn-dark)}
.a-btn-danger{background:var(--danger)}
.a-btn-danger:hover{background:#c23c3c}
.a-btn-ghost{background:#f0f4f6;color:#4b5563}
.a-btn-ghost:hover{background:#e3e9ec;color:#222}

/* Card */
.a-card{background:var(--card);border-radius:6px;padding:16px 18px;margin-bottom:16px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.a-card h3{margin:0 0 14px;font-size:15px;color:#4b5563;font-weight:600}

/* Filter bar */
.a-filters{background:#fff;padding:10px 14px;border-radius:6px;display:flex;gap:18px;align-items:center;margin-bottom:10px;flex-wrap:wrap;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.a-filters .fi{display:flex;align-items:center;gap:5px;font-size:13px;color:#6b7280}
.a-filters .fi strong{color:#374151}
.a-filters select,.a-filters input{border:1px solid var(--border);border-radius:3px;padding:3px 6px;font-size:13px;background:#fff}

/* Table */
.a-table-wrap{background:#fff;border-radius:6px;overflow:auto;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.a-pageinfo{padding:10px 16px;display:flex;align-items:center;gap:10px;color:#6b7280;font-size:13px}
.a-pageinfo .grow{flex:1}
.a-pageinfo .of{color:#8a98a5}
.a-pageinfo .sep{width:1px;height:14px;background:#e3e8ec;margin:0 4px}
.a-pageinfo .records{color:#6b7280}
.a-pageinfo .ppg{display:inline-flex;align-items:center;gap:4px;color:#6b7280;cursor:pointer;user-select:none;position:relative;padding:4px 6px;border-radius:4px}
.a-pageinfo .ppg:hover{background:#f3f4f6}
.a-pageinfo .ppg .fa-caret-down{font-size:11px;color:#888}
.a-pageinfo .ppg select{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;background:transparent;font:inherit}
.a-pageinfo .dl,.a-pageinfo .rf{color:#6b7280;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:4px}
.a-pageinfo .dl:hover,.a-pageinfo .rf:hover{color:var(--snc);text-decoration:none}
.a-pageinfo .rf i{font-size:12px}
/* Fixed-width: cegah kolom bergeser saat sort/filter/page change.
   Column widths ditentukan per template (<th style="width:XXX"> atau <th class="w-XX">).
   Tidak ada default width — browser bagi rata kolom yang tidak eksplisit. */
.a-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}
.a-table thead th{background:#2b2b2b;color:#fff;padding:12px 14px;text-align:center;font-weight:600;font-size:12px;letter-spacing:.3px;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.a-table thead th.act{width:80px}
/* Width helper classes — assign via <th class="w-xs|w-sm|w-md|w-lg|w-xl"> */
.a-table th.w-xs{width:60px}
.a-table th.w-sm{width:90px}
.a-table th.w-md{width:130px}
.a-table th.w-lg{width:180px}
.a-table th.w-xl{width:240px}
.a-table tbody td{padding:14px 14px;border-bottom:1px solid #f3f4f6;color:#4b5563;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;word-wrap:break-word}
.a-table tbody tr:hover{background:#fafbfc}
.a-table .num{color:var(--link);text-align:center}
.a-table .link{color:var(--link)}
.a-table .c{text-align:center}
.a-table .act{width:48px;text-align:center}
.a-table .act a{color:#9ca3af}
.a-table .act a:hover{color:var(--snc)}
.a-table .empty-big{padding:40px;text-align:center;color:#9ca3af}

/* Form */
.form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px 20px}
.form-grid .full{grid-column:1/-1}
.form-grid .field label{display:block;color:#6b7280;font-size:13px;margin-bottom:5px}
.form-grid .field .req{color:var(--danger)}
.form-grid .field input,.form-grid .field select,.form-grid .field textarea{
  width:100%;border:1px solid var(--border);border-radius:14px;padding:8px 12px;font-size:13px;background:#fff;outline:none
}
.form-grid .field textarea{border-radius:8px;min-height:70px;resize:vertical}
.form-grid .field input:focus,.form-grid .field select:focus,.form-grid .field textarea:focus{border-color:var(--snc)}
.form-grid .field .readonly{background:#f3f4f6;color:#6b7280}

/* Badge */
.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase}
.badge-yes{background:#dcfce7;color:#15803d}
.badge-no{background:#f3f4f6;color:#6b7280}
.badge-open{background:#fef3c7;color:#92400e}
.badge-paid{background:#dcfce7;color:#15803d}
.badge-review{background:#dbeafe;color:#1e40af}
.badge-run{background:#fef3c7;color:#92400e}
.badge-done{background:#dcfce7;color:#15803d}

/* Pagination */
.a-pag{display:inline-flex;align-items:center;gap:4px}
.a-pag a,.a-pag span{padding:3px 8px;color:#6b7280;font-size:13px;border-radius:3px}
.a-pag a:hover{background:var(--snc-soft);color:var(--snc-dark);text-decoration:none}
.a-pag input{width:40px;text-align:center;border:1px solid var(--border);border-radius:3px;padding:2px 4px}

/* Empty */
.a-empty{padding:40px;text-align:center;color:#9ca3af}

/* Login — wave oren SNC */
.a-login-body{margin:0;min-height:100vh;background:#fff;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.a-wave{position:absolute;left:0;width:100%;height:42vh;pointer-events:none;z-index:0}
.a-wave-top{top:0}
.a-wave-bot{bottom:0}
.a-login-card{position:relative;z-index:1;background:#fff;padding:40px 40px 30px;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.12);width:340px}
.a-brand{text-align:center;margin-bottom:28px}
.a-brand-img{height:60px;width:auto;max-width:100%;object-fit:contain;display:inline-block}
.a-back-link{position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;gap:4px;padding:6px 10px;background:#f3f4f6;border-radius:16px;color:#1A1A1A;font-size:13px;font-weight:600;text-decoration:none;z-index:2}
.a-back-link:hover{background:#F7951D;color:#fff;text-decoration:none}
.a-brand-logo{display:inline-block;font-size:48px;font-weight:900;color:#1a1a1a;letter-spacing:0;font-style:italic}
.a-login-card .err{background:#fee;color:#c23c3c;padding:10px;border-radius:6px;font-size:13px;margin-bottom:14px;text-align:center}

/* Underline float-label input */
.uf{position:relative;margin-bottom:22px}
.uf input{width:100%;border:none;border-bottom:1.5px solid #d1d5db;background:transparent;padding:22px 8px 8px;font-size:14px;outline:none;transition:border-color .15s,background .15s}
.uf input:focus,.uf input:not(:placeholder-shown){background:#fff7eb;border-bottom-color:var(--snc)}
.uf label{position:absolute;left:8px;top:16px;font-size:14px;color:#9ca3af;pointer-events:none;transition:all .15s}
.uf input:focus + label,.uf input:not(:placeholder-shown) + label{top:0;font-size:11px;color:var(--snc);font-weight:600}
.uf .eye{position:absolute;right:6px;top:18px;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px}
.uf .eye:hover{color:var(--snc)}

.btn-pill{display:block;width:100%;background:var(--snc);color:#fff;border:none;border-radius:40px;padding:14px;font-size:15px;font-weight:700;letter-spacing:1.5px;cursor:pointer;margin-top:8px;transition:background .15s;box-shadow:0 6px 14px rgba(247,149,29,.28)}
.btn-pill:hover{background:var(--snc-dark)}
.forgot{display:block;text-align:center;margin-top:16px;color:#6b7280;font-size:13px;text-decoration:underline}
.forgot:hover{color:var(--snc)}

/* Utility */
.text-muted{color:var(--muted)}
.text-right{text-align:right}
.mt-0{margin-top:0}.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mt-3{margin-top:18px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:6px}.mb-2{margin-bottom:12px}

/* ── Functional chip controls — pixel-match Kelava chip, but real inputs ── */
.chip-ctrl{position:relative;display:inline-flex;align-items:center;gap:4px;background:#f3f4f6;padding:6px 10px;border-radius:4px;color:#555;font-size:13px;line-height:1.4;cursor:pointer}
.chip-ctrl .lbl{color:#555}
.chip-ctrl .val{color:#333;font-weight:500}
/* Native input/select sits on top, invisible — chip is clickable area opening native picker */
.chip-ctrl > input,
.chip-ctrl > select{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;background:transparent;font:inherit;color:transparent;padding:0;margin:0;-webkit-appearance:none;appearance:none}
.chip-ctrl > input::-webkit-calendar-picker-indicator{opacity:0;position:absolute;inset:0;width:100%;height:100%;cursor:pointer}
.chip-ctrl .caret{color:#888;font-size:11px;margin-left:2px;pointer-events:none}
.chip-ctrl .x{color:#888;cursor:pointer;margin-left:4px;padding:0 2px;background:none;border:none;font-size:14px;line-height:1;position:relative;z-index:2}
.chip-ctrl .x:hover{color:#e53e3e}
.chip-ctrl:hover{background:#e9ebee}
.chip-ctrl:focus-within{outline:1px solid var(--snc);outline-offset:1px}
