/* ═══════════════════════════════════════════════
   COMPONENTS — SANTET V3
   All reusable UI components
   Source: style.css (cleaned)
   ═══════════════════════════════════════════════ */

/* cards inside public grids */
.product-card, .shop-card { display:flex; flex-direction:column; }
.product-card .product-features, .shop-card .shop-features { margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:8px; }
.product-card .product-features li, .shop-card .shop-features li { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--tx2); }

/* ════════════════════════════════════════════════════════
   AUTH PAGES — contained card layout
════════════════════════════════════════════════════════ */
.auth-wrap {
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  background:
    radial-gradient(ellipse 70% 50% at 20% 60%, rgba(139,0,0,.12), transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 20%, rgba(80,0,0,.08), transparent 55%),
    var(--bg);
}
.auth-split {
  width:100%; max-width:920px;
  display:flex;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow: 0 0 0 1px var(--neon-border), 0 40px 80px rgba(0,0,0,.7), 0 8px 24px rgba(0,0,0,.5);
  animation:fade-up .5s cubic-bezier(.22,.68,0,1.2);
}
.auth-split__left::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--shadow-r),transparent);
  display:none;
}
.auth-split__left-inner { position:relative; z-index:1; text-align:center; max-width:280px; }
.auth-split__right {
  flex:1;
  display:flex; align-items:center; justify-content:center;
  padding:48px 40px;
  background:var(--card);
  border-left:1px solid rgba(255,255,255,.06);
  position:relative;
}
.auth-split__right::before {
  content:''; position:absolute; top:0; right:0; width:60%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);
}
.auth-brand-logo {
  width:72px; height:72px; border-radius:20px;
  background:linear-gradient(145deg,var(--border-r),rgba(139,0,0,.15));
  border:1px solid var(--border-r2);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 40px var(--shadow-r), 0 0 80px var(--neon-border), inset 0 1px 0 rgba(255,255,255,.12);
  position:relative; overflow:hidden; margin:0 auto 28px;
  transition:box-shadow .3s;
}
.auth-brand-logo::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%,var(--shadow-r),transparent 65%);
}
.auth-brand-logo svg { position:relative; z-index:1; filter:drop-shadow(0 0 10px var(--shadow-r)); }
.auth-brand-name {
  font-size:20px; font-weight:800; letter-spacing:3px;
  text-transform:uppercase; color:var(--tx);
  text-shadow:0 1px 0 var(--r1),0 2px 0 var(--r2),0 4px 16px var(--shadow-r);
  line-height:1.25; margin-bottom:14px;
}
.auth-brand-tagline { font-size:12px; color:rgba(241,241,245,.45); line-height:1.7; }
.auth-brand-dots { display:flex; justify-content:center; gap:6px; margin-top:32px; }
.auth-brand-dot { width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.12); }
.auth-brand-dot:nth-child(2) { background:var(--border-r); width:22px; border-radius:4px; }
.auth-brand-dot:nth-child(3) { background:rgba(255,255,255,.07); }

/* ── Auth form container ─────────────────────────────── */
.auth-card {
  width:100%; max-width:340px;
}
.auth-card--standalone {
  background:var(--surface);
  border:1px solid var(--border-r);
  border-radius:var(--radius);
  padding:36px 32px;
  box-shadow:var(--shadow-lg), var(--shadow-r);
  position:relative; overflow:hidden;
}
.auth-card--standalone::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--r1),var(--r3),var(--r1));
  animation:shimmer 3.5s linear infinite; background-size:200% auto;
  box-shadow:0 0 18px var(--shadow-r);
}
.auth-title { font-size:22px; font-weight:700; color:var(--tx); margin-bottom:3px; letter-spacing:-.3px; }
.auth-sub   { font-size:12px; color:var(--tx3); margin-bottom:24px; }
.auth-form  { display:flex; flex-direction:column; gap:16px; }
.login-btn--mt { margin-top:4px; }
.login-divider--mt { margin-top:20px; }
.pass-wrap { position:relative; }
.pass-wrap .shop-form-input { padding-right:44px; }
.pass-toggle { position:absolute; right:12px; top:50%; transform:translateY(-50%); background:none; border:none; cursor:pointer; color:var(--tx3); font-size:15px; line-height:1; transition:color .2s; }
.pass-toggle:hover { color:var(--tx); }
.pass-eye { position:absolute; right:12px; top:50%; transform:translateY(-50%); background:none; border:none; cursor:pointer; color:var(--tx3); font-size:15px; line-height:1; transition:color .2s; padding:4px 8px; border-radius:var(--radius-xs); }
.pass-eye:hover { color:var(--tx); background:rgba(255,255,255,.06); }
.pass-wrap .flex-input { padding-right:44px; }
.auth-home-row { text-align:center; margin:0 0 10px; font-size:12px; }
.auth-home-link { color:var(--tx3); text-decoration:none; }
.auth-home-link:hover { color:var(--tx); }
.forgot-desc { font-size:12px; color:var(--tx3); line-height:1.6; }

/* approved reset */
.approved-reset { background:rgba(87,242,135,.08); border:1px solid rgba(87,242,135,.3); border-radius:var(--radius-sm); padding:14px 16px; }
.approved-reset__header { display:flex; align-items:center; gap:8px; margin-bottom:10px; }
.approved-reset__title { font-size:13px; font-weight:600; color:var(--green); }
.approved-reset__body { font-size:12px; color:rgba(241,241,245,.6); margin:0 0 12px; }
.approved-reset__link { display:block; width:100%; padding:11px; background:rgba(87,242,135,.15); border:1px solid rgba(87,242,135,.35); border-radius:var(--radius-sm); color:var(--green); font-size:13px; font-weight:600; text-align:center; text-decoration:none; transition:background .2s; }
.approved-reset__link:hover { background:rgba(87,242,135,.25); }
.auth-brand-dots--spaced { margin-top:36px; }

/* ── Forgot password panel ───────────────────────────── */
.forgot-panel { overflow:hidden; max-height:0; transition:max-height .38s cubic-bezier(.22,.68,0,1.2), opacity .3s; opacity:0; }
.forgot-panel.open { max-height:240px; opacity:1; }
.forgot-panel-inner { border-top:1px solid var(--border); padding:16px 0 4px; display:flex; flex-direction:column; gap:10px; }
.forgot-link { background:none; border:none; color:var(--tx3); font-size:11px; cursor:pointer; font-family:inherit; padding:0; transition:color var(--transition); text-align:center; display:block; width:100%; }
.forgot-link:hover { color:var(--r4); }
.auth-footer-link { text-align:center; margin-top:18px; padding-top:14px; border-top:1px solid var(--border); font-size:11px; color:var(--tx3); }

/* ════════════════════════════════════════════════════════
   FIELDS / INPUTS
════════════════════════════════════════════════════════ */
.field { display:flex; flex-direction:column; gap:6px; }
.field label, .form-label {
  font-size:11px; font-weight:600; color:var(--tx3);
  text-transform:uppercase; letter-spacing:.8px;
}
.field input[type=text],
.field input[type=password],
.field input[type=number],
.field input[type=email],
.field textarea,
.field select,
input.flex-input,
textarea.flex-input,
select.flex-input,
.form-input {
  padding:10px 13px;
  background:var(--input);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--tx); font-size:13px; font-family:inherit;
  transition:border-color var(--transition), box-shadow var(--transition);
  outline:none;
  width:100%;
  box-sizing:border-box;
}
select.flex-input,
.field select {
  cursor:pointer;
  min-height:40px;
  appearance:none;
  -webkit-appearance:none;
  padding-right:38px;

  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239494b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  background-color:var(--input);
}
select.flex-input:focus,
.field select:focus {
  background-color:var(--surface);
}
textarea.flex-input,
.field textarea {
  resize:vertical;
  min-height:88px;
  line-height:1.45;
}
.field input:focus,
input.flex-input:focus,
textarea.flex-input:focus,
select.flex-input:focus,
.form-input:focus {
  border-color:var(--border-r2);
  box-shadow:0 0 0 3px var(--r-bg);
}
.field input::placeholder,
textarea.flex-input::placeholder { color:var(--tx3); }
.field-hint { font-size:11px; color:var(--tx3); }
.add-form { display:flex; gap:10px; flex-wrap:wrap; align-items:flex-end; }
.add-form .field { flex:1; min-width:120px; }
.inline-form { display:flex; gap:9px; flex-wrap:wrap; align-items:center; }
.inline-form .flex-input { flex:1; min-width:180px; }

/* ── Toggle ──────────────────────────────────────────── */
.toggle-label {
  display:flex; align-items:center; gap:9px; cursor:pointer;
  font-size:13px; color:var(--tx2); user-select:none;
}
.toggle-label input[type=checkbox] { display:none; }
.toggle-track {
  width:36px; height:20px; border-radius:10px;
  background:var(--surface); border:1px solid var(--border);
  position:relative; transition:all .25s; flex-shrink:0;
}
.toggle-thumb {
  position:absolute; top:3px; left:3px; width:12px; height:12px;
  border-radius:50%; background:var(--tx3); transition:all .25s;
}
.toggle-label input:checked ~ .toggle-track { background:var(--green); border-color:var(--green); box-shadow:0 0 8px rgba(34,197,94,.35); }
.toggle-label input:checked ~ .toggle-track .toggle-thumb { left:19px; background:#fff; }
.bs-check { display:flex; align-items:center; gap:8px; cursor:pointer; font-size:13px; color:var(--tx2); }
.bs-check input[type=checkbox] { accent-color:var(--green); }

/* ── Settings form ───────────────────────────────────── */
.settings-form { display:flex; flex-direction:column; gap:14px; }
.settings-form--narrow { max-width:480px; }
.field-inline-pair {
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:flex-end;
}
.field-inline-pair .field--grow {
  flex:1 1 220px;
  min-width:200px;
  max-width:100%;
}

/* Equal-width selects on admin account creation row */
.admin-account-grid {
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,168px) minmax(0,168px) auto;
  gap:10px;
  align-items:end;
  max-width:920px;
}
@media (max-width:720px) {
  .admin-account-grid {
    grid-template-columns:1fr 1fr;
    max-width:none;
  }
  .admin-account-grid__submit { grid-column:1/-1; justify-self:start; }
  .admin-account-grid__role,
  .admin-account-grid__parent { grid-column:span 1; min-width:0; }
}

/* Notification table action cluster */
.inline-0 { margin:0; }
.action-btn-row {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px;
}
.th-actions, .td-actions { white-space:nowrap; vertical-align:middle; }
.btn-ghost.btn-ghost--danger:hover,
.btn-ghost.btn-danger-ghost:hover { border-color:var(--border-r2); color:var(--r4); }
.form-actions-row {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px;
  margin-top:4px;
}
.form-actions-row--after {
  padding-top:14px;
  margin-top:10px;
  border-top:1px solid var(--border);
}
.inline-danger-form { margin:0; display:inline-block; }
.settings-form--bot { display:grid; grid-template-columns:1fr 1fr; gap:14px 20px; }
.settings-form--bot > .field--span-full,
.settings-form--bot > .btn-primary { grid-column:1/-1; }
@media (max-width:680px) { .settings-form--bot { grid-template-columns:1fr; } }
.settings-page { width:100%; max-width:1100px; }

/* ════════════════════════════════════════════════════════
   BUTTONS
════════════════════════════════════════════════════════ */
.btn-primary {
  padding:10px 22px;
  background:linear-gradient(135deg,var(--r2),var(--r1));
  color:var(--tx); border:none; border-radius:var(--radius-sm);
  font-size:13px; font-weight:600; font-family:inherit;
  cursor:pointer; white-space:nowrap;
  box-shadow:var(--shadow-r), inset 0 1px 0 rgba(255,255,255,.12);
  transition:all var(--transition);
  position:relative; overflow:hidden;
}
.btn-primary:hover {
  background:linear-gradient(135deg,var(--r3),var(--r2));
  box-shadow:var(--shadow-r2), inset 0 1px 0 rgba(255,255,255,.18);
  transform:translateY(-1px) scale(1.01);
}
.btn-primary:active { transform:translateY(0) scale(.99); }
.btn-primary--full,
.btn-block { width:100%; padding:11px; text-align:center; display:block; text-decoration:none; }

.btn-full {
  width:100%; padding:11px;
  background:linear-gradient(135deg,var(--r2),var(--r1));
  color:var(--tx); border:none; border-radius:var(--radius-sm);
  font-size:13px; font-weight:600; font-family:inherit;
  cursor:pointer; text-decoration:none; display:block; text-align:center;
  box-shadow:var(--shadow-r), inset 0 1px 0 rgba(255,255,255,.12);
  transition:all var(--transition);
}
.btn-full:hover {
  background:linear-gradient(135deg,var(--r3),var(--r2));

}
.btn-full:active { transform:translateY(0); }

.btn-ghost {
  padding:8px 14px;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  color:var(--tx2); border-radius:var(--radius-sm);
  font-size:12px; font-family:inherit; cursor:pointer;
  text-decoration:none; display:inline-block;
  transition:all var(--transition);
}
.btn-ghost:hover {
  border-color:var(--border2); color:var(--tx);
  background:rgba(255,255,255,.07); transform:translateY(-1px);
}
.btn-ghost.btn-danger-ghost:hover { border-color:var(--border-r2); color:var(--r4); background:var(--r-bg); }

.btn-danger {
  padding:8px 16px;
  background:var(--r-bg); color:var(--r4);
  border:1px solid var(--border-r); border-radius:var(--radius-sm);
  font-size:13px; font-weight:600; font-family:inherit; cursor:pointer;
  text-decoration:none; display:inline-block; transition:all var(--transition);
}
.btn-danger:hover { background:var(--r-bg); transform:translateY(-1px); }

.btn-primary.btn-sm,
.btn-ghost.btn-sm,
.btn-danger.btn-sm,
.btn-full.btn-sm { padding:6px 12px; font-size:12px; }
.btn-primary.btn-xs,
.btn-ghost.btn-xs,
.btn-danger.btn-xs,
.btn-full.btn-xs { padding:3px 9px; font-size:11px; }
.btn-icon-danger {
  width:28px; height:28px; background:transparent;
  border:1px solid transparent; color:var(--tx3);
  border-radius:var(--radius-xs); cursor:pointer; font-size:12px;
  display:inline-flex; align-items:center; justify-content:center;
  transition:all var(--transition);
}
.btn-icon-danger:hover { background:var(--r-bg); border-color:var(--border-r); color:var(--r4); transform:scale(1.1); }
.btn-copy {
  flex-shrink:0; padding:4px 10px; font-size:11px; font-weight:600;
  background:rgba(255,255,255,.06); border:1px solid var(--border);
  border-radius:var(--radius-xs); color:var(--tx2); cursor:pointer;
  transition:all var(--transition); font-family:inherit;
}
.btn-copy:hover { border-color:var(--border2); color:var(--tx); }

/* ════════════════════════════════════════════════════════
   TABLE
════════════════════════════════════════════════════════ */
.table-wrap,
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0 -2px;
  padding: 0 2px 2px;
  scrollbar-color:var(--shadow-r) transparent;
}
.table-wrap table,
.table-responsive table {
  min-width: 520px;
}
@media (min-width: 900px) {
  .table-wrap thead th,
  .table-responsive thead th {
    position: sticky;
    top: 0;
    z-index: 1;
    background: var(--card);
    box-shadow: 0 1px 0 var(--border2);
  }
}
table { width:100%; border-collapse:collapse; font-size:13px; }
thead tr { border-bottom:1px solid var(--border2); }
th { text-align:left; padding:10px 14px; color:var(--tx3); font-weight:600; font-size:10px; text-transform:uppercase; letter-spacing:.9px; white-space:nowrap; }
td { padding:11px 14px; border-bottom:1px solid var(--border); vertical-align:middle; transition:background .15s; }
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover td { background:rgba(255,255,255,.02); }
code { background:rgba(255,255,255,.06); border:1px solid var(--border); padding:2px 6px; border-radius:var(--radius-xs); font-size:12px; font-family:'Geist Mono','Consolas',monospace; color:var(--tx2); }
span.muted,
p.muted,
div.muted,
td.muted { color:var(--tx3); }
.mono-sm { font-family:'Geist Mono','Consolas',monospace; font-size:12px; }

/* ════════════════════════════════════════════════════════
   TAGS / BADGES
════════════════════════════════════════════════════════ */
.badge { background:rgba(255,255,255,.06); border:1px solid var(--border); color:var(--tx2); padding:2px 9px; border-radius:20px; font-size:11px; font-weight:500; }
.badge-blue { background:var(--blue-bg); border-color:rgba(59,130,246,.25); color:#60a5fa; }
.badge-red  { background:var(--r-bg); border-color:var(--border-r); color:var(--r4); }

.tag { padding:2px 9px; border-radius:20px; font-size:11px; font-weight:500; display:inline-flex; align-items:center; gap:4px; }
.tag-green  { background:var(--green-bg);  color:var(--green);  border:1px solid var(--green-border); }
.tag-gray   { background:rgba(255,255,255,.05); color:var(--tx3); border:1px solid var(--border); }
.tag-purple { background:var(--purple-bg); color:#c084fc;       border:1px solid rgba(168,85,247,.25); }
.tag-warn   { background:var(--orange-bg); color:var(--orange);  border:1px solid rgba(249,115,22,.25); }
.tag-red    { background:var(--r-bg);      color:var(--r4);      border:1px solid var(--border-r); }
.tag-blue-soft { background:var(--blue-bg); color:#60a5fa; border:1px solid rgba(59,130,246,.25); }
.expiry-tag { font-size:12px; color:var(--tx3); font-family:'Geist Mono',monospace; }
.stat-chip { display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:600; }
.stat-chip .a { color:var(--green); }
.stat-chip .e { color:var(--r4); }
.stat-chip .sep { color:var(--tx3); }

/* ════════════════════════════════════════════════════════
   ALERTS / TOAST
════════════════════════════════════════════════════════ */
.alert { padding:12px 15px; border-radius:var(--radius-sm); margin-bottom:16px; font-size:13px; }
.alert-ok    { background:var(--green-bg); border:1px solid var(--green-border); color:var(--green); }
.alert-error { background:var(--r-bg); border:1px solid var(--border-r); color:var(--r4); }

/* Toast */
.toast-root {
  position:fixed; top:16px; right:16px; z-index:9999;
  display:flex; flex-direction:column; gap:8px;
  pointer-events:none;
}
.toast {
  min-width:280px; max-width:380px;
  padding:12px 16px; border-radius:var(--radius-sm);
  background:var(--surface2); border:1px solid var(--border2);
  box-shadow:var(--shadow-lg);
  color:var(--tx); font-size:13px;
  display:flex; align-items:center; gap:10px;
  pointer-events:all;
  animation:toast-in .3s cubic-bezier(.22,.68,0,1.2);
}
.toast.toast-ok  { border-left:3px solid var(--green); }
.toast.toast-err { border-left:3px solid var(--r3); }
.toast.toast-out { animation:toast-out .25s ease forwards; }
.toast-icon { font-size:15px; flex-shrink:0; }

/* ════════════════════════════════════════════════════════
   PILL TABS
════════════════════════════════════════════════════════ */
.pill-tabs { display:flex; gap:6px; margin-bottom:16px; flex-wrap:wrap; }
.pill-tab {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 15px; border-radius:20px; font-size:12px; font-weight:500;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  color:var(--tx2); cursor:pointer; text-decoration:none;
  transition:all var(--transition);
}
.pill-tab:hover { background:rgba(255,255,255,.07); border-color:var(--border2); color:var(--tx); transform:translateY(-1px); }
.pill-tab.active {
  background:var(--r-bg); border-color:var(--border-r2);
  color:var(--tx); font-weight:600;
  box-shadow:var(--shadow-r);
}
.pill-tab-dot { width:7px; height:7px; border-radius:50%; background:var(--r2); flex-shrink:0; box-shadow:0 0 5px var(--r2); }
.pill-tab-dot.green { background:var(--green); box-shadow:0 0 5px var(--green); }
.pill-tab-emoji { font-size:13px; }

/* ── Admin tabs ──────────────────────────────────────── */
.admin-tabs { display:flex; gap:6px; margin-bottom:18px; flex-wrap:wrap; }
.admin-tab {
  display:inline-flex; align-items:center; gap:7px;
  padding:6px 15px; border-radius:20px; font-size:12px; font-weight:500;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  color:var(--tx2); text-decoration:none; transition:all var(--transition);
}
.admin-tab:hover { border-color:var(--border2); color:var(--tx); background:rgba(255,255,255,.07); transform:translateY(-1px); }
.admin-tab.active { background:var(--r-bg); border-color:var(--border-r2); color:var(--tx); font-weight:600; box-shadow:var(--shadow-r); }
.admin-tab__logo { display:inline-flex; flex-shrink:0; }

/* ════════════════════════════════════════════════════════

════════════════════════════════════════════════════════ */
.search-wrap { position:relative; margin-bottom:14px; }
.search-wrap input {
  width:100%; padding:9px 12px 9px 36px;
  background:var(--input); border:1px solid var(--border);
  border-radius:var(--radius-sm); color:var(--tx);
  font-size:13px; font-family:inherit; outline:none;
  transition:border-color var(--transition), box-shadow var(--transition);
}
.search-wrap input:focus { border-color:var(--border-r); box-shadow:0 0 0 3px var(--r-bg); }
.search-wrap input::placeholder { color:var(--tx3); }
.search-icon { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--tx3); font-size:13px; pointer-events:none; }

/* ════════════════════════════════════════════════════════
   UID LIST / USER LIST
════════════════════════════════════════════════════════ */
.user-list { display:flex; flex-direction:column; }
.user-list-row {
  display:flex; align-items:center; gap:12px;
  padding:10px 14px; border-bottom:1px solid var(--border);
  transition:all var(--transition);
}
.user-list-row:last-child { border-bottom:none; }
.user-list-row:hover { background:rgba(255,255,255,.025); }
.user-list-row--expired { opacity:.65; }
.ula { width:34px; height:34px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; color:var(--tx); }
.ula--a { background:linear-gradient(135deg,var(--r1),var(--r1)); }
.ula--b { background:linear-gradient(135deg,#1a5276,#2980b9); }
.ula--c { background:linear-gradient(135deg,#145a32,#27ae60); }
.ula--d { background:linear-gradient(135deg,#7d6608,#d4ac0d); }
.ula--e { background:linear-gradient(135deg,#4a235a,#8e44ad); }
.ula--f { background:linear-gradient(135deg,var(--r1),var(--r1)); }
.ula--g { background:linear-gradient(135deg,#0e6655,#1abc9c); }

.ula--h { background:linear-gradient(135deg,#784212,#d35400); }
.user-list-info { flex:1; min-width:0; }
.user-list-name { font-size:13px; font-weight:500; color:var(--tx); }
.user-list-sub  { font-size:11px; color:var(--tx2); margin-top:1px; }
.user-list-sub.user-list-sub--expired { color:var(--r4); }
.user-list-badge { min-width:24px; height:22px; padding:0 7px; background:rgba(255,255,255,.05); border:1px solid var(--border); border-radius:20px; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:600; color:var(--tx2); flex-shrink:0; }

/* UID status dot */
.uid-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; display:inline-block; margin-right:2px; }
.uid-dot--active  { background:var(--green); box-shadow:0 0 4px var(--green); }
.uid-dot--bs      { background:#14b8a6; box-shadow:0 0 4px rgba(20,184,166,.85); }
.uid-dot--expired { background:var(--r3); box-shadow:0 0 4px var(--r3); }
.uid-dot--unknown { background:var(--tx3); }

.form-inline { margin:0; display:inline; }

/* ════════════════════════════════════════════════════════
   ADMIN DROPDOWNS
════════════════════════════════════════════════════════ */
.device-reset-dropdown { position:relative; display:inline-flex; }
.device-reset-menu {
  display:none;
  position:absolute;
  right:0; top:calc(100% + 6px);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  min-width:190px;
  z-index:100;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.35);
}
.device-reset-item {
  width:100%; text-align:left;
  padding:10px 14px; background:none; border:none;
  color:var(--tx); font-size:12px; cursor:pointer;
  display:flex; align-items:center; gap:8px;
  font-family:inherit; transition:background .15s;
}
.device-reset-item:hover { background:rgba(255,255,255,.04); }
.device-reset-item + .device-reset-item { border-top:1px solid var(--border); }
.device-reset-item .chevron { font-size:9px; opacity:.6; margin-left:auto; }

/* Admin section card color variants (replaces inline bg/border colors) */
.card--orange { border-color:rgba(255,85,0,.35); background:rgba(255,85,0,.05); }
.card--green  { border-color:rgba(87,242,135,.35); background:rgba(87,242,135,.04); }
.card--orange .card-title { color:var(--r4); }
.card--orange .badge { background:rgba(255,85,0,.12); color:var(--r4); border-color:rgba(255,85,0,.3); }
.card--green  .card-title { color:var(--green); }
.card--green .badge { background:rgba(87,242,135,.12); color:var(--green); border-color:rgba(87,242,135,.3); }

/* Inline text sizes — replacements for style="font-size:…" */
.txt-xs { font-size:9px; }
.txt-sm { font-size:11px; }
.txt-body-sm { font-size:12px; font-weight:500; }

/* xs tag variant */
.tag--xs { font-size:9px; padding:1px 6px; }

/* ════════════════════════════════════════════════════════
   KEY ROW / API KEY DISPLAY
════════════════════════════════════════════════════════ */
.key-row { display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.key-row--sm { gap:7px; }
.key-display {
  flex:1; min-width:180px; padding:10px 13px;
  background:var(--input); border:1px solid var(--border);
  border-radius:var(--radius-sm); word-break:break-all;
  font-size:12px; color:var(--tx2); font-family:'Geist Mono','Consolas',monospace;
}
.key-mini { display:flex; align-items:center; gap:5px; }
.hint { font-size:12px; color:var(--tx3); margin-bottom:10px; }
.hint--sm { margin-top:4px; margin-bottom:0; }
.state-enabled  { color:var(--green); font-weight:600; }
.state-disabled { color:var(--r4);    font-weight:600; }
.link { color:var(--r3); text-decoration:none; transition:color var(--transition); }
.link:hover { color:var(--r4); }
.inline-link { color:var(--r3); text-decoration:none; font-weight:600; }
.inline-link:hover { color:var(--r4); }
.info-row { display:flex; align-items:center; gap:9px; margin-top:10px; font-size:12px; }
.info-label { color:var(--tx2); font-weight:500; }
.inline-code { background:rgba(255,255,255,.06); border:1px solid var(--border); padding:2px 7px; border-radius:var(--radius-xs); font-family:'Geist Mono',monospace; font-size:12px; color:var(--tx2); }

/* ════════════════════════════════════════════════════════
   MISC
═══════════════════════════════════════════════════════
.empty-state { text-align:center; padding:40px 20px; color:var(--tx3); }
.empty-icon  { font-size:28px; display:block; margin-bottom:12px; opacity:.15; }
.error-code {
  font-size:64px; font-weight:800; letter-spacing:-3px; line-height:1; margin:20px 0;
  background:linear-gradient(135deg,var(--r2),var(--r4));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 20px var(--shadow-r));
}
.error-msg { color:var(--tx3); margin-bottom:28px; font-size:13px; }

/* ════════════════════════════════════════════════════════
   ADMIN CONTROLS GRID
════════════════════════════════════════════════════════ */
.controls-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(255px,1fr)); gap:14px; }
.ctrl-card {
  background:
    linear-gradient(160deg, rgba(255,255,255,.02), rgba(255,255,255,.01)),
    var(--surface);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px 14px 12px;
  display:flex; flex-direction:column; gap:10px;
  box-shadow:0 0 0 1px rgba(255,255,255,.02), 0 10px 24px rgba(0,0,0,.28);
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.ctrl-card:hover {
  transform:translateY(-2px);
  border-color:var(--border2);
  box-shadow:0 0 0 1px rgba(255,255,255,.04), 0 18px 36px rgba(0,0,0,.38);
}
.ctrl-card-head { display:flex; align-items:center; gap:9px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.ctrl-card-name { font-size:13px; font-weight:600; color:var(--tx); flex:1; }

.ctrl-label { font-size:10px; font-weight:700; color:var(--tx3); text-transform:uppercase; letter-spacing:.8px; margin-bottom:5px; display:block; }
.ctrl-input {
  width:100%; padding:7px 10px;
  background:var(--input); border:1px solid var(--border);
  border-radius:var(--radius-xs); color:var(--tx); font-size:12px; font-family:inherit;
  outline:none; transition:border-color var(--transition);
}
.ctrl-input:focus { border-color:var(--border-r2); box-shadow:0 0 0 2px var(--r-bg); }
.ctrl-api-row { display:flex; align-items:center; justify-content:space-between; font-size:12px; color:var(--tx2); }
.ctrl-save {
  margin-top:2px; padding:7px 14px; font-size:11px; font-weight:600;
  background:linear-gradient(135deg, var(--r-bg), rgba(139,0,0,.14));

  color:var(--r4); cursor:pointer; font-family:inherit; transition:all var(--transition); width:100%;
}
.ctrl-save:hover { background:linear-gradient(135deg, var(--shadow-r), var(--r-bg)); transform:translateY(-1px); }

/* ── Limit shortcut pills ────────────────────────────── */
.ctrl-shortcuts {
  display:flex; flex-wrap:wrap; gap:4px;
}
.ctrl-shortcut {
  padding:3px 8px; font-size:10px; font-weight:600; font-family:inherit;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:20px; color:var(--tx3); cursor:pointer;
  transition:all var(--transition);
}
.ctrl-shortcut:hover {
  background:rgba(234,179,8,.14); border-color:rgba(234,179,8,.4);
  color:var(--yellow); transform:translateY(-1px);
}
.ctrl-shortcut--clear { color:var(--green); border-color:rgba(34,197,94,.25); background:var(--green-bg); }
.ctrl-shortcut--clear:hover { background:rgba(34,197,94,.2); border-color:var(--green); color:var(--green); }

/* Admin panel polish */
.admin-section-eyebrow {
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-bottom:10px;
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.85px;
  color:var(--tx3);
}
.admin-section-eyebrow::before {
  content:'';
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--r3);
  box-shadow:0 0 8px var(--shadow-r);
}
.admin-split {
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
}
@media (min-width:1200px) {
  .admin-split {
    grid-template-columns: 1fr 1fr;
  }
}

/* ════════════════════════════════════════════════════════
   SLIDEOVER (Add UID panel)
════════════════════════════════════════════════════════ */
/* Slideover */
.slideover {
  position:fixed; top:0; bottom:0; right:-100%;
  width:380px; max-width:100vw;
  background:var(--card);
  border-left:1px solid var(--border);
  z-index:500; padding:28px 24px;
  overflow-y:auto;
  transition:right var(--transition-slow);
  box-shadow:-8px 0 40px rgba(0,0,0,.4);
}
.slideover.open { right:0; }
.slideover-backdrop {
  display:none; position:fixed; inset:0; z-index:499;
  background:rgba(0,0,0,.6); backdrop-filter:blur(4px);
}
.slideover-backdrop.open { display:block; animation:fade-in .2s; }
.slideover-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.slideover-title { font-size:16px; font-weight:700; color:var(--tx); }
.slideover-close { width:30px; height:30px; background:none; border:1px solid var(--border); border-radius:var(--radius-xs); color:var(--tx3); cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; transition:all var(--transition); }
.slideover-close:hover { background:var(--surface); color:var(--tx); }

.reset-req-pending td { background:var(--r-bg2); }

/* ════════════════════════════════════════════════════════
   USER CARDS (admin_users)
════════════════════════════════════════════════════════ */
.admin-users-page { width:100%; }
.user-grid { display:flex; flex-direction:column; gap:14px; }
.user-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow);
  transition:box-shadow var(--transition), border-color var(--transition);
  position:relative;
  animation:fade-up .45s cubic-bezier(.22,.68,0,1.2) calc(var(--i,0)*50ms) backwards;
}
.user-card::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent); pointer-events:none; }
.user-card:hover { box-shadow:var(--shadow-lg); border-color:var(--border2); }
.user-card__head {
  display:flex; flex-wrap:wrap; align-items:center; gap:12px;
  padding:16px 18px; border-bottom:1px solid var(--border);
  background:rgba(0,0,0,.2);
}
.user-card__avatar { width:44px; height:44px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:15px; font-weight:700; color:var(--tx); }

.user-card__identity { flex:1; min-width:130px; }
.user-card__name { font-size:15px; font-weight:700; margin:0 0 2px; color:var(--tx); letter-spacing:-.2px; }
.user-card__id   { font-size:11px; color:var(--tx3); margin:0; }
.user-card__badges { display:flex; flex-wrap:wrap; align-items:center; gap:6px; }
.user-card__live { font-size:11px; font-weight:600; color:var(--green); display:inline-flex; align-items:center; gap:5px; }
.user-card__live-dot { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 5px var(--green); animation:pulse-dot 2s ease-in-out infinite; }
.user-card__actions { margin-left:auto; display:flex; flex-wrap:wrap; gap:6px; align-items:center; }
.user-card__form { display:inline; margin:0; }

.user-card__stats { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; padding:16px 18px; border-bottom:1px solid var(--border); background:rgba(0,0,0,.15); }
@media (max-width:600px) { .user-card__stats { grid-template-columns:repeat(3,1fr); } }
@media (max-width:400px) { .user-card__stats { grid-template-columns:repeat(2,1fr); } }
.user-stat {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:10px 8px; text-align:center;
  transition:all var(--transition);
}
.user-stat:hover { border-color:var(--border2); transform:translateY(-2px); box-shadow:var(--shadow); }
.user-stat__val { display:block; font-size:20px; font-weight:700; color:var(--tx); line-height:1.1; }
.user-stat__lbl { display:block; font-size:9px; font-weight:600; color:var(--tx2); text-transform:uppercase; letter-spacing:.6px; margin-top:4px; }

.user-card__dl { margin:0; padding:4px 18px 14px; }
.user-card__row { display:grid; grid-template-columns:minmax(130px,24%) 1fr; gap:6px 14px; padding:8px 0; border-bottom:1px solid var(--border); align-items:center; }
.user-card__row:last-of-type { border-bottom:none; }
.user-card__row--full { grid-column:1/-1; }
@media (max-width:560px) { .user-card__row { grid-template-columns:1fr; gap:3px; } }
.user-card__dl dt { font-size:10px; font-weight:700; color:var(--tx2); text-transform:uppercase; letter-spacing:.8px; margin:0; }
.user-card__dl dd { margin:0; font-size:13px; color:var(--tx); word-break:break-word; }
.user-card__code { display:inline-block; max-width:100%; padding:3px 8px; border-radius:var(--radius-sm); background:rgba(255,255,255,.06); border:1px solid var(--border); font-family:'Geist Mono',monospace; font-size:12px; color:#c0c0d8; }
.user-card__keybar { display:flex; align-items:center; gap:8px; min-width:0; padding:7px 10px; border-radius:var(--radius-sm); background:var(--input); border:1px solid var(--border); transition:all var(--transition); }
.user-card__keybar:hover { border-color:var(--border2); }
.user-card__code--masked { flex:1; min-width:0; display:block; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; border:none; background:transparent; padding:0; font-family:'Geist Mono',monospace; font-size:12px; color:var(--tx2); }
.user-card__keycell { margin:0; }
.user-card__empty { color:var(--tx3); font-size:12px; font-style:italic; }

.user-card__meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 3px;
  font-size: 11px;
  color: var(--tx3);
}
.user-card__meta-sep { color: var(--tx3); opacity: .7; }

.user-card__status-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  color: var(--tx3);
  white-space: nowrap;
}
.user-card__status-pill--active {
  background: var(--green-bg);
  border-color: var(--green-border);
  color: var(--green);
}
.user-card__status-pill--warn {
  background: var(--yellow-bg);
  border-color: rgba(234,179,8,.25);
  color: var(--orange);
}
.user-card__status-pill--muted {
  background: rgba(255,255,255,.04);
  border-color: var(--border);
  color: var(--tx3);
}
.user-card__status-pill--off {
  background: var(--r-bg);
  border-color: var(--border-r);
  color: var(--r4);
}
.user-card__status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 6px currentColor;
  flex-shrink: 0;
}

/* ════════════════════════════════════════════════════════
   PORTAL (public free portal)
════════════════════════════════════════════════════════ */
.portal-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; background:var(--bg); }
.portal-card {
  width:100%; max-width:420px;
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:40px 32px;
  box-shadow:var(--shadow-lg);
  position:relative; overflow:hidden;
  animation:fade-up .45s cubic-bezier(.22,.68,0,1.2);
}
.portal-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--r1),var(--r3),var(--r1)); animation:shimmer 4s linear infinite; background-size:200% auto; box-shadow:0 0 18px var(--shadow-r); }
.portal-title { font-size:22px; font-weight:700; text-align:center; margin-bottom:8px; }
.portal-sub { text-align:center; color:var(--tx3); font-size:13px; margin-bottom:22px; line-height:1.65; }
.portal-info { display:flex; gap:7px; justify-content:center; margin-bottom:22px; flex-wrap:wrap; }
.portal-field-lg.portal-field-lg input { font-size:15px; padding:12px 14px; }
.portal-submit-lg.portal-submit-lg { margin-top:10px; padding:13px; font-size:14px; }
.success-box { background:var(--green-bg); border:1px solid var(--green-border); border-radius:var(--radius-sm); padding:22px; text-align:center; color:var(--green); }
.success-icon { font-size:32px; display:block; margin-bottom:8px; }
.success-uid { font-family:'Geist Mono',monospace; font-size:18px; font-weight:700; margin:8px 0; color:var(--tx); }
.success-msg { font-size:12px; color:var(--tx3); margin-top:6px; }
.disabled-box { background:var(--r-bg); border:1px solid var(--border-r); border-radius:var(--radius-sm); padding:26px; text-align:center; color:var(--r4); }
.disabled-box p { color:var(--tx3); font-size:13px; margin-top:10px; }

/* ════════════════════════════════════════════════════════
   API DOCS
════════════════════════════════════════════════════════ */
.endpoint-card { border-left:3px solid var(--r3); border-radius:var(--radius); }
.endpoint-header { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:14px; }
.endpoint-path { font-size:13px; color:var(--tx); font-family:'Geist Mono',monospace; }
.endpoint-desc { font-size:12px; color:var(--tx3); margin-left:auto; }
.ep-section { margin-bottom:16px; }
.ep-section:last-child { margin-bottom:0; }
.ep-label { font-size:10px; font-weight:600; color:var(--tx2); text-transform:uppercase; letter-spacing:.7px; margin-bottom:6px; display:flex; align-items:center; gap:6px; }

.code-block { background:rgba(0,0,0,.5); border:1px solid var(--border); border-radius:var(--radius-sm); overflow:hidden; }
.code-bar { display:flex; align-items:center; justify-content:space-between; padding:7px 12px; background:rgba(255,255,255,.03); border-bottom:1px solid var(--border); font-size:11px; color:var(--tx3); }
.code-bar button { background:rgba(255,255,255,.06); border:1px solid var(--border); color:var(--tx2); padding:3px 9px; border-radius:var(--radius-xs); font-size:11px; cursor:pointer; transition:all var(--transition); font-family:inherit; }
.code-bar button:hover { border-color:var(--border-r); color:var(--r3); }
pre { padding:16px; margin:0; font-family:'Geist Mono','Consolas',monospace; font-size:12.5px; line-height:1.75; color:var(--tx); overflow-x:auto; white-space:pre; }
.code-comment { color:var(--tx3); }
.api-docs { display:flex; flex-direction:column; gap:7px; }
.api-row { display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.method { padding:2px 8px; border-radius:var(--radius-xs); font-size:11px; font-weight:700; letter-spacing:.3px; min-width:42px; text-align:center; font-family:'Geist Mono',monospace; }
.method.post { background:var(--yellow-bg); color:var(--yellow); border:1px solid rgba(234,179,8,.25); }
.method.get  { background:var(--green-bg); color:var(--green); border:1px solid var(--green-border); }
.api-desc { font-size:12px; color:var(--tx3); }
.tabs { display:flex; gap:4px; margin-bottom:6px; }
.tab { padding:4px 12px; border-radius:20px; background:rgba(255,255,255,.04); border:1px solid var(--border); color:var(--tx2); font-size:12px; cursor:pointer; transition:all var(--transition); font-family:inherit; }
.tab.active { background:var(--r-bg); border-color:var(--border-r); color:var(--r3); }
.tab-content.hidden { display:none; }
.lang-tabs { display:flex; border-bottom:1px solid var(--border); }
.lang-tab { padding:7px 14px; background:transparent; border:none; border-bottom:2px solid transparent; color:var(--tx2); font-size:12px; font-weight:500; cursor:pointer; transition:all var(--transition); margin-bottom:-1px; font-family:inherit; }
.lang-tab:hover { color:var(--tx); }
.lang-tab.active { color:var(--r3); border-bottom-color:var(--r2); }
.lang-content { margin-top:10px; }
.lang-content.hidden { display:none; }

/* ════════════════════════════════════════════════════════

════════════════════════════════════════════════════════ */
.settings-tabs { display:flex; gap:4px; border-bottom:1px solid var(--border); margin-bottom:22px; flex-wrap:wrap; }
.settings-tab { padding:9px 16px; background:none; border:none; border-bottom:2px solid transparent; color:var(--tx3); font-size:13px; font-weight:500; cursor:pointer; transition:all var(--transition); font-family:inherit; margin-bottom:-1px; }
.settings-tab:hover { color:var(--tx); }
.settings-tab.active { color:var(--r3); border-bottom-color:var(--r2); font-weight:600; }
.settings-panel { display:none; }
.settings-panel.active { display:block; animation:fade-up .3s cubic-bezier(.22,.68,0,1.2); }

/* ════════════════════════════════════════════════════════
   CUSTOM CONFIRM MODAL
════════════════════════════════════════════════════════ */
.sg-modal-wrap { display:none; position:fixed; inset:0; z-index:9999; align-items:center; justify-content:center; background:rgba(0,0,0,.75); backdrop-filter:blur(6px); }
.sg-modal-box { background:var(--surface2); border:1px solid var(--border-r); border-radius:var(--radius); padding:30px 28px 24px; max-width:340px; width:90%; box-shadow:var(--shadow-lg), var(--shadow-r); position:relative; animation:fade-up .25s cubic-bezier(.22,.68,0,1.2); }
.sg-modal-box::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; border-radius:var(--radius) var(--radius) 0 0; background:linear-gradient(90deg,var(--r1),var(--r3),var(--r1)); }

/* ════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════ */
 @media (max-width:1100px) {
   .stats-grid { grid-template-columns:repeat(2,1fr); }
 }
 @media (max-width: 768px) {
   :root { --sw: 0px; --sw-icon: 0px; }
   .sidebar { display:none; }
   .sidebar.sidebar.open { display:flex; width:var(--sw); animation:slide-in-left .3s cubic-bezier(.22,.68,0,1.2); }
   .sidebar.open .sidebar-logo-texts,
   .sidebar.open .nav-label,
   .sidebar.open .nav-section,
   .sidebar.open .sidebar-status-block,
   .sidebar.open .user-info,
   .sidebar.open .sc-brand { display:block; }
   .sidebar.open .nav-item { justify-content:flex-start; padding:7px 10px; }

   .sidebar.open .user-chip .logout-btn { display:inline-block; }
   .main-wrap { margin-left:0; padding:70px 16px 40px; }
   .topbar { display:flex; }
   .stats-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
   .page-title { font-size:18px; }
   .auth-split { max-width:420px; border-radius:var(--radius); }
   .auth-split__left { display:none; }
   .auth-split__right { min-height:auto; padding:40px 28px; }
 }
@media (max-width:520px) {
   .stats-grid { grid-template-columns:repeat(2,1fr); gap:8px; }
   .add-form { flex-direction:column; align-items:stretch; }
   .main-wrap { padding:65px 12px 36px; }
   .page-top { flex-direction:column; align-items:flex-start; }
   .slideover { width:100vw; }
 }

/* ════════════════════════════════════════════════════════
   LANDING + MAINTENANCE + SITE NOTICES
════════════════════════════════════════════════════════ */
.container { width:100%; max-width:1100px; margin:0 auto; padding:0 clamp(16px,4vw,32px); }
.section-header { text-align:center; margin:0 auto clamp(28px,4vw,36px); max-width:720px; }
.section-header .section-tag { display:inline-flex; align-items:center; gap:8px; padding:7px 16px; border-radius:100px; background:rgba(255,255,255,.04); border:1px solid var(--border); color:var(--tx2); font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; margin-bottom:14px; }
.section-header .section-title { font-size:clamp(24px,3.8vw,32px); font-weight:700; letter-spacing:-.02em; line-height:1.15; margin:0 0 12px; color:var(--tx); }
.section-header .section-desc { font-size:15px; color:var(--tx2); line-height:1.6; max-width:560px; margin:0 auto; }
.features-grid, .products-preview .products-grid, .shop-section .shop-grid { display:grid; gap:16px; }
.features-grid, .shop-section .shop-grid { grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }
.products-preview .products-grid { grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.shop-card, .product-card { display:flex; flex-direction:column; gap:14px; }
.shop-card .shop-features, .product-card .product-features { margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:8px; }
.shop-card .shop-features li, .product-card .product-features li { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--tx2); }
@media (max-width:720px){
  .features-grid,.products-preview .products-grid,.shop-section .shop-grid { grid-template-columns:1fr; }
}

/* ════════════════════════════════════════════════════════
   LANDING + MAINTENANCE + SITE NOTICES
════════════════════════════════════════════════════════ */
.landing-body {
  margin:0; min-height:100vh;
  background:
    radial-gradient(ellipse 800px 600px at 30% 20%, rgba(255,184,0,0.12), transparent 50%),
    radial-gradient(ellipse 700px 500px at 70% 30%, rgba(255,122,0,0.08), transparent 50%),
    radial-gradient(ellipse 600px 800px at 50% 70%, rgba(255,85,0,0.06), transparent 50%),
    radial-gradient(ellipse 500px 500px at 10% 70%, rgba(255,184,0,0.04), transparent 50%),
    radial-gradient(ellipse 500px 500px at 90% 80%, rgba(255,122,0,0.04), transparent 50%),
    var(--bg);
  color:var(--tx);
  font-family:var(--font-body);
}
.landing-header { display:flex; align-items:center; justify-content:space-between; padding:20px clamp(18px,4vw,32px); border-bottom:1px solid var(--border); max-width:1100px; margin:0 auto; width:100%; }

.landing-nav { display:flex; align-items:center; gap:14px; font-size:13px; }
.landing-nav a:not(.btn-primary) { color:var(--tx2); text-decoration:none; }
.landing-nav a:not(.btn-primary):hover { color:var(--tx); }
.landing-main {
  max-width:920px;
  margin:0 auto;
  padding:clamp(36px,6vw,64px) clamp(18px,4vw,32px) 72px;
  text-align:center;
}
.landing-hero { margin-bottom:clamp(36px,5vw,48px); }
.landing-headline {
  font-size:clamp(28px,4.2vw,40px); font-weight:700; line-height:1.12; margin:0 auto 16px;
  max-width:min(720px,100%);
  letter-spacing:-.02em;
}
.landing-sub { font-size:15px; color:var(--tx2); line-height:1.6; max-width:560px; margin:0 auto; }
.landing-stats {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin:32px auto 0;
  align-items:stretch;
  justify-content:center;
  align-content:center;
  width:100%;
  max-width:100%;
}
.landing-stat {
  box-sizing:border-box;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:6px;
  flex:0 1 168px;
  min-width:min(168px,100%);
  max-width:198px;
  padding:18px 20px;
  background:linear-gradient(165deg, rgba(255,255,255,.04), transparent 55%), var(--card);
  border:1px solid var(--border); border-radius:calc(var(--radius) + 2px);
  box-shadow:0 12px 32px rgba(0,0,0,.35);
}
.landing-stat--highlight { border-color:var(--border-r); box-shadow:0 14px 40px var(--r-bg), 0 12px 32px rgba(0,0,0,.35); }
.landing-stat__value-row {
  display:flex; align-items:baseline; justify-content:center; gap:2px;
  font-variant-numeric:tabular-nums;
  width:100%;
}
.landing-stat__value-row--plain .landing-stat__num { font-size:clamp(20px,3.8vw,26px); }
.landing-stat__num {
  font-size:clamp(24px,4.2vw,30px); font-weight:700; letter-spacing:-.03em;
  color:var(--tx); line-height:1;
}
.landing-stat__plus {
  font-size:clamp(15px,2.4vw,19px); font-weight:700; color:var(--r3);
  line-height:1; translate:0 -6px;
}
.landing-stat__label {
  font-size:11px; font-weight:500; letter-spacing:.06em; text-transform:lowercase;
  color:var(--tx2); line-height:1.35;
}
.landing-cta { display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; align-items:center; justify-content:center; }
.btn-buy-wa {
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 18px; border-radius:var(--radius-sm);
  font-weight:600; font-size:13px; text-decoration:none;
  border:1px solid #25d366; background:rgba(37,211,102,.12); color:#4ade80;
}
.btn-buy-wa:hover { background:rgba(37,211,102,.22); border-color:#4ade80; color:#86efac; }
.landing-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;
  margin:0 auto 36px;
  max-width:880px;
  text-align:left;
}
.landing-card {
  background:linear-gradient(160deg, rgba(255,255,255,.035), transparent 48%), var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 20px 18px;
  box-shadow:0 10px 36px rgba(0,0,0,.28);
}
.landing-card h2 { margin:0 0 8px; font-size:15px; color:var(--tx); }
.landing-card p { margin:0; font-size:13px; color:var(--tx3); line-height:1.5; }
.landing-note {
  font-size:12px; color:var(--tx3); line-height:1.58;
  padding:16px 18px; border-radius:var(--radius-sm);
  background:rgba(255,255,255,.03); border:1px solid var(--border);
  max-width:640px; margin:0 auto; text-align:left;
}
.landing-footer { text-align:center; padding:24px; font-size:11px; color:var(--tx3); border-top:1px solid var(--border); }

.maintenance-body {
  margin:0; min-height:100vh;
  background:
    radial-gradient(ellipse 900px 500px at 50% -8%, var(--neon-border), transparent 55%),
    radial-gradient(ellipse 560px 360px at 15% 70%, var(--r-bg2), transparent 50%),
    radial-gradient(ellipse 560px 360px at 85% 60%, var(--r-bg2), transparent 48%),
    var(--bg);
  color:var(--tx);
  font-family:'Geist','Inter',system-ui,sans-serif;
}
.maintenance-page {
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(20px,4vw,40px);
  animation:fade-in .5s ease both;
}
.maintenance-wrap { width:100%; max-width:460px; text-align:center; }
.maintenance-brand {
  margin:0 0 22px;
  font-size:13px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--r3);
}
.maintenance-card {
  position:relative;
  text-align:center;
  background:linear-gradient(175deg, rgba(255,255,255,.05), transparent 42%), var(--card);
  border:1px solid var(--border);
  border-radius:calc(var(--radius) + 4px);
  padding:clamp(32px,5vw,44px) clamp(26px,4vw,40px) 38px;
  box-shadow:
    var(--shadow-lg),
    0 0 0 1px var(--neon-border) inset;
  overflow:hidden;
  animation:fade-up .55s var(--transition-slow) both;
}
.maintenance-card__accent {
  position:absolute; inset:0 0 auto 0; height:3px;
  background:linear-gradient(90deg, var(--r1), var(--r3) 45%, var(--r3) 100%);
  opacity:.95;
}
.maintenance-icon { margin:8px auto 14px; color:var(--tx2); }
.maintenance-icon__svg { display:block; margin:0 auto; opacity:.95; filter:drop-shadow(0 4px 20px var(--shadow-r)); }
.maintenance-title { margin:0 0 12px; font-size:clamp(22px,3.8vw,26px); font-weight:700; letter-spacing:-.02em; }
.maintenance-lead { margin:0 0 20px; color:var(--tx2); font-size:14px; line-height:1.6; max-width:36ch; margin-inline:auto; }
.maintenance-msg {
  margin:0 0 22px;
  padding:14px 16px;
  border-radius:var(--radius-sm);
  background:rgba(0,0,0,.35);
  border:1px solid var(--border2);
  font-size:13px;
  color:var(--tx2);
  text-align:left;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.maintenance-msg__label {
  font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--r4); opacity:.9;
}
.maintenance-msg__text { color:var(--tx); font-weight:500; line-height:1.5; word-break:break-word; }
.maintenance-foot { font-size:12px; line-height:1.55; color:var(--tx3); margin:0 auto 24px; max-width:36ch; }
.maintenance-foot strong { color:var(--tx2); font-weight:600; }
.maintenance-btn.maintenance-btn { display:inline-flex; justify-content:center; min-width:180px; padding:11px 24px; }
.site-notice-stack { padding:10px 18px 0; max-width:1200px; margin:0 auto; }
.site-notice-stack--public { max-width:900px; margin-left:auto; margin-right:auto; padding-top:16px; }
.site-notice { display:flex; flex-wrap:wrap; gap:8px 14px; align-items:center; padding:10px 14px; border-radius:var(--radius-sm); margin-bottom:8px; font-size:13px; border:1px solid var(--border); }
.site-notice--info { background:rgba(87,142,255,.08); border-color:rgba(87,142,255,.25); }
.site-notice--warn { background:rgba(240,180,65,.1); border-color:rgba(240,180,65,.35); }
.site-notice__body { color:var(--tx2); font-weight:400; }

/* ════════════════════════════════════════════════════════
   PRICING / PLANS
════════════════════════════════════════════════════════ */
.page-actions--centered { justify-content:center; }
.section-header--pricing { text-align:center; margin:0 auto clamp(28px,4vw,36px); max-width:720px; display:flex; flex-direction:column; align-items:center; gap:14px; }
.section-header--pricing .section-tag { display:inline-flex; align-items:center; justify-content:center; padding:7px 16px; border-radius:100px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); color:var(--tx2); font-size:11px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; }
.section-header--pricing .section-title { width:100%; font-size:clamp(24px,3.8vw,32px); font-weight:700; letter-spacing:-.02em; line-height:1.15; margin:0 0 12px; color:var(--tx); }
.section-header--pricing .section-desc { width:100%; font-size:15px; color:var(--tx2); line-height:1.6; max-width:560px; margin:0 auto; }

.plan-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:start; max-width:1100px; margin:0 auto; }
@media (max-width:900px){ .plan-grid { grid-template-columns:1fr; max-width:420px; } }

.plan-card {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:28px 24px 24px;
  box-shadow:var(--shadow);
  position:relative; overflow:hidden;
  display:flex; flex-direction:column; gap:18px;
  transition:box-shadow var(--transition), border-color var(--transition), transform var(--transition);
}
.plan-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
  pointer-events:none;
}
.plan-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--r2),transparent);
  opacity:0; transition:opacity var(--transition);
}
.plan-card:hover { box-shadow:var(--shadow-lg); border-color:var(--border2); transform:translateY(-3px); }
.plan-card:hover::after { opacity:1; }

.plan-card--featured {
  border-color:var(--border-r);
  background:linear-gradient(160deg, var(--r-bg), var(--r-bg2)), var(--card);
  box-shadow:var(--shadow-r), var(--shadow);
}
.plan-card--featured::after { opacity:1; background:linear-gradient(90deg,transparent,var(--r3),transparent); }
.plan-badge {
  position:absolute; top:14px; right:14px;
  padding:4px 10px; border-radius:20px; font-size:10px; font-weight:700;
  background:var(--r-bg); color:var(--r4); border:1px solid var(--border-r);
  letter-spacing:.4px; text-transform:uppercase;
}
.plan-name { font-size:15px; font-weight:700; color:var(--tx); letter-spacing:-.2px; }
.plan-desc { font-size:12px; color:var(--tx3); line-height:1.6; }
.plan-price { display:flex; align-items:baseline; gap:6px; }
.plan-price__amount { font-size:38px; font-weight:800; color:var(--tx); letter-spacing:-1.5px; line-height:1; }
.plan-price__currency { font-size:15px; color:var(--tx3); font-weight:500; }
.plan-price__period { font-size:12px; color:var(--tx3); }
.plan-features { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; flex:1; }
.plan-features li { display:flex; align-items:flex-start; gap:9px; font-size:13px; color:var(--tx2); line-height:1.5; }
.plan-features li::before { content:'✓'; color:var(--green); font-weight:700; font-size:12px; margin-top:1px; flex-shrink:0; }
.plan-cta { width:100%; padding:11px; text-align:center; display:block; text-decoration:none; font-size:13px; font-weight:600; border-radius:var(--radius-sm); transition:all var(--transition); font-family:inherit; cursor:pointer; border:1px solid transparent; }
.plan-cta--primary {
  background:linear-gradient(135deg,var(--r2),var(--r1)); color:var(--tx);
  box-shadow:var(--shadow-r), inset 0 1px 0 rgba(255,255,255,.12);
}
.plan-cta--primary:hover { background:linear-gradient(135deg,var(--r3),var(--r2)); box-shadow:var(--shadow-r2), inset 0 1px 0 rgba(255,255,255,.18); transform:translateY(-1px); }
.plan-cta--ghost { background:rgba(255,255,255,.04); border-color:var(--border); color:var(--tx2); }
.plan-cta--ghost:hover { border-color:var(--border2); color:var(--tx); background:rgba(255,255,255,.07); transform:translateY(-1px); }

/* ════════════════════════════════════════════════════════
   PRICING PAGE COMPONENTS
════════════════════════════════════════════════════════ */
.pricing-page { min-height:100vh; display:flex; flex-direction:column; }

/* Header */
.pricing-header {
  position:sticky; top:0; z-index:200;
  background:rgba(6,6,8,.82);
  border-bottom:1px solid var(--border);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.pricing-header__inner {
  display:flex; align-items:center; justify-content:space-between;
  height:60px; gap:16px;
}
.pricing-logo {
  display:inline-flex; align-items:center; gap:10px;
  text-decoration:none; color:var(--tx);
  font-weight:700; font-size:14px; letter-spacing:-.2px;
}
.pricing-logo__mark {
  display:inline-flex; align-items:center; justify-content:center;
  width:30px; height:30px; border-radius:var(--radius-xs);
  background:linear-gradient(135deg,var(--r2),var(--r1));
  color:var(--tx); font-size:13px; box-shadow:var(--shadow-r);
  border:1px solid var(--border-r);
}
.pricing-logo__accent { color:var(--r4); }
.pricing-nav {
  display:flex; align-items:center; gap:14px;
}
.pricing-nav__link {
  font-size:13px; color:var(--tx2); text-decoration:none; font-weight:500;
  transition:color var(--transition);
}
.pricing-nav__link:hover { color:var(--tx); }
.pricing-nav__cta { text-decoration:none; }

/* Main */
.pricing-main { flex:1; padding:28px 0 56px; }

/* FAQ */
.pricing-faq { max-width:920px; margin:0 auto; }
.pricing-faq__title {
  text-align:center; font-size:18px; font-weight:700; color:var(--tx); margin:0 0 18px;
}
.faq-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
@media (max-width:900px){ .faq-grid { grid-template-columns:1fr; } }
.faq-item {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:16px;
  box-shadow:var(--shadow);
  transition:border-color var(--transition), box-shadow var(--transition);
}
.faq-item:hover { border-color:var(--border2); box-shadow:var(--shadow-lg); }
.faq-item__q { font-size:13px; font-weight:700; color:var(--tx); margin:0 0 6px; }
.faq-item__a { font-size:12px; color:var(--tx2); line-height:1.6; margin:0; }

/* Logo text */
.pricing-logo__text { font-weight:700; font-size:14px; letter-spacing:-.2px; color:var(--tx); }

/* Plan header wrapper */
.plan-header { margin-bottom:2px; }

/* Footer */
.pricing-footer {
  border-top:1px solid var(--border);
  background:rgba(6,6,8,.65);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding:18px 0;
}
.pricing-footer__inner {
  display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap;
}
.pricing-foot-brand {
  display:inline-flex; align-items:center; gap:10px;
  font-weight:700; font-size:14px; color:var(--tx); letter-spacing:-.2px;
}
.pricing-foot-brand .pricing-logo__mark { width:26px; height:26px; font-size:11px; }
.pricing-footer__copy { font-size:11px; color:var(--tx3); }
.pricing-foot-nav { display:flex; align-items:center; gap:14px; }

/* ════════════════════════════════════════════════════════
   UNIFIED DESIGN SYSTEM TOKENS
════════════════════════════════════════════════════════ */
.ds-flex { display:flex; }
.ds-inline-flex { display:inline-flex; }
.ds-grid { display:grid; }
.ds-gap-xs { gap:4px; }
.ds-gap-sm { gap:8px; }
.ds-gap-md { gap:16px; }
.ds-gap-lg { gap:24px; }
.ds-p-xs { padding:4px; }
.ds-p-sm { padding:8px; }
.ds-p-md { padding:16px; }
.ds-p-lg { padding:24px; }
.ds-mb-xs { margin-bottom:4px; }
.ds-mb-sm { margin-bottom:8px; }
.ds-mb-md { margin-bottom:16px; }
.ds-mb-lg { margin-bottom:24px; }
.ds-text-xs { font-size:11px; }
.ds-text-sm { font-size:12px; }
.ds-text-base { font-size:13px; }
.ds-text-lg { font-size:15px; }
.ds-text-xl { font-size:18px; }
.ds-font-medium { font-weight:500; }
.ds-font-semibold { font-weight:600; }
.ds-font-bold { font-weight:700; }
.ds-text-center { text-align:center; }
.ds-text-right { text-align:right; }
.ds-w-full { width:100%; }
.ds-max-w-container { max-width:1100px; margin:0 auto; }
.ds-truncate { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* Consistency helpers */
.ds-no-margin { margin:0; }

.ds-border-0 { border:0; }
.ds-bg-transparent { background:transparent; }
.ds-cursor-pointer { cursor:pointer; }
.ds-user-select-none { user-select:none; }
.ds-items-center { align-items:center; }
.ds-justify-center { justify-content:center; }
.ds-justify-between { justify-content:space-between; }
.ds-flex-col { flex-direction:column; }
.ds-flex-wrap { flex-wrap:wrap; }
.ds-mt-xs { margin-top:4px; }
.ds-mt-sm { margin-top:8px; }
.ds-mt-md { margin-top:12px; }
.ds-mt-lg { margin-top:16px; }
.ds-mt-xl { margin-top:20px; }
.ds-ml-xs { margin-left:4px; }
.ds-ml-sm { margin-left:8px; }
.ds-pt-md { padding-top:12px; }
.ds-block { display:block; }
.ds-none  { display:none; }
.ds-leading-normal { line-height:1.5; }

/* Color text utilities */
.txt-green { color:var(--green); }
.txt-r4    { color:var(--r4); }
.txt-yellow { color:var(--yellow); }
.txt-blue   { color:var(--blue); }
.txt-purple { color:var(--purple); }
.txt-red    { color:var(--red); }

/* Border utilities */
.border-top { border-top:1px solid var(--border); }
.border-subtle { border:1px solid rgba(255,255,255,.06); }
.border-dashed { border-style:dashed; }

/* Text utilities */
.text-capitalize { text-transform:capitalize; }
.ds-nowrap { white-space:nowrap; }
/* === Inline style replacements used across templates === */
.btn-auto { width: fit-content; }
.btn-ghost--danger,
.btn-danger-ghost { border-color: var(--border-r); color: var(--r4); }
.btn-ghost--danger:hover,
.btn-danger-ghost:hover { border-color: var(--border-r2); color: var(--r4); background: var(--r-bg); }
.accent-r2 { accent-color: var(--r2); }
.stat-card-value--green { color: var(--green); }
.stat-card-value--red   { color: var(--r3); }
.stat-card-value--yellow { color: var(--yellow); }
.stat-card-value--blue  { color: var(--blue); }
.u-hidden.u-hidden { display: none; }
.text-warn { color: var(--yellow); }
.form-actions-row--end { justify-content: flex-end; }
.portal-alert { border-color: rgba(240,180,65,.45); background: rgba(240,180,65,.06); }
.portal-section { margin-bottom: 14px; }
.portal-key-row { margin-bottom: 12px; }
.portal-table-card { overflow: hidden; }
.portal-card-head { margin-bottom: 10px; flex-wrap: wrap; gap: 8px; align-items: center; }
.portal-spacer { flex: 1; }
.portal-empty { padding: 30px 20px; }

/* User stat value color variants */
.user-stat__val.user-stat__val--green { color:var(--green); }
.user-stat__val.user-stat__val--red { color:var(--r3); }

/* User card footer / back link */
.user-card__footer { padding:8px 18px 12px; border-top:1px solid rgba(255,255,255,.05); }
.user-card__back-link { font-size:11px; color:var(--tx3); }

/* Portal-specific layout helpers */
.card--portal-alert { max-width:640px; margin-bottom:16px; border-color:rgba(240,180,65,.45); background:rgba(240,180,65,.06); }
.card--520        { max-width:520px; }
.toggle-label-title { font-size:13px; font-weight:500; color:var(--tx); }
.toggle-label-desc  { font-size:11px; color:var(--tx3); margin-top:1px; }
.key-row--mb12    { margin-bottom:12px; }
.key-display--plain { font-size:12px; }
.portal-actions-row { display:flex; gap:10px; flex-wrap:wrap; }
.portal-card-head  { margin-bottom:10px; flex-wrap:wrap; gap:8px; align-items:center; }
.portal-spacer    { flex:1; }
.portal-actions-end { display:flex; flex-wrap:wrap; gap:8px; justify-content:flex-end; }
.portal-text-warn { color:var(--yellow); }
.empty-state--tight { padding:30px 20px; }

/* Auth page helpers */
.flex-shrink-none { flex-shrink:0; }
.auth-icon-r3 { color:var(--r3); }
.auth-tips-box { margin-top:28px; padding:16px; background:rgba(0,0,0,.3); border:1px solid rgba(255,255,255,.06); border-radius:12px; }
.auth-tips-text { font-size:11px; color:rgba(241,241,245,.4); line-height:1.8; }
.auth-form-gap { display:flex; flex-direction:column; gap:16px; }
.auth-footer { text-align:center; margin-top:18px; padding-top:14px; border-top:1px solid rgba(255,255,255,.06); }
.auth-footer-link { font-size:12px; color:var(--tx3); text-decoration:none; transition:color .2s; }
.auth-footer-link:hover { color:var(--tx); }

.uid-list-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; flex-wrap:wrap; gap:8px; }
.uid-stat-bs { color:var(--green); font-weight:500; }
.add-uid-btn { margin-top:10px; }
.uid-pagination--bar { margin-top:12px; padding-top:14px; border-top:1px solid var(--border); display:flex; flex-wrap:wrap; gap:10px; align-items:center; justify-content:center; }
.card-footnote { font-size:11px; padding:10px 16px 0; line-height:1.5; border-top:1px solid var(--border); }


/* ── Role tag/badge colors ── */
.tag-gold   { background: rgba(255,184,0,.12); color: #ffb800; border: 1px solid rgba(255,184,0,.3); }
.badge-gold { background: rgba(255,184,0,.12); color: #ffb800; border: 1px solid rgba(255,184,0,.3); }
.badge-gray { background: rgba(255,255,255,.05); color: var(--tx3); border: 1px solid var(--border); }

/* ── Utility classes ──────────────────────────── */
.d-inline { display: inline; margin: 0; }
.text-green { color: var(--green); }
.fw-500 { font-weight: 500; }

/* ── Empty state centered ─────────────────────── */
.empty-state--centered {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 200px;
}
.empty-icon--lg {
  font-size: 32px;
  margin-bottom: 12px;
  color: var(--r3);
}
.empty-text {
  margin: 0;
  font-size: 14px;
  color: var(--tx3);
}

/* ── Pagination centered ──────────────────────── */
.uid-pagination--centered {
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: center;
}

/* ── Logo accent ──────────────────────────────── */
.logo-accent { color: var(--r3); }
