/* =============================================================
   pid24h — Design System v2
   Product Keys, 24 hours a day.
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ---------- 1. Tokens ---------- */
:root {
  /* surface */
  --bg-0:#050810; --bg-1:#0a0f1c; --bg-2:#101728; --bg-3:#171f36; --bg-4:#1f2944;
  --border:#212a47; --border-2:#2e3a5e; --border-3:#3b4978;
  /* type */
  --text-1:#f1f4ff; --text-2:#c6cce0; --text-3:#9098b5; --text-4:#5d6589;
  /* signature: electric mint */
  --mint:#2dd4bf; --mint-2:#5eead4; --mint-3:#7ef7e5;
  --mint-bg:rgba(45,212,191,.12); --mint-bg-2:rgba(45,212,191,.22);
  --mint-glow:0 0 0 1px rgba(45,212,191,.4), 0 8px 32px rgba(45,212,191,.28);
  /* premium */
  --violet:#a78bfa; --violet-2:#c4b5fd; --violet-bg:rgba(167,139,250,.14);
  /* signal */
  --amber:#fbbf24; --amber-bg:rgba(251,191,36,.12);
  --rose:#ff5d6c; --rose-bg:rgba(255,93,108,.1);
  --green:#34d399; --green-bg:rgba(52,211,153,.1);
  --blue:#60a5fa; --blue-bg:rgba(96,165,250,.1);
  /* radius / shadow */
  --r-sm:8px; --r:12px; --r-md:16px; --r-lg:22px; --r-xl:28px;
  --shadow-1:0 1px 2px rgba(0,0,0,.4);
  --shadow-2:0 6px 24px rgba(0,0,0,.35), 0 1px 2px rgba(0,0,0,.2);
  --shadow-3:0 20px 60px rgba(0,0,0,.5), 0 4px 12px rgba(0,0,0,.3);
  --shadow-mint:0 8px 32px rgba(45,212,191,.22);
  /* font */
  --font-display:'Space Grotesk', system-ui, sans-serif;
  --font-body:'Inter', system-ui, sans-serif;
  --font-mono:'JetBrains Mono', ui-monospace, monospace;
  /* motion */
  --ease:cubic-bezier(.2,.8,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- 2. Reset ---------- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:var(--font-body);
  background:var(--bg-0); color:var(--text-1); line-height:1.55;
  min-height:100vh; -webkit-font-smoothing:antialiased;
  font-feature-settings:'ss01','cv11','tnum';
}
a { color:var(--mint-2); text-decoration:none; transition:color .2s var(--ease); }
a:hover { color:var(--mint-3); }
button { font-family:inherit; }
::selection { background:var(--mint); color:#001a14; }
::-webkit-scrollbar { width:8px; height:8px; }
::-webkit-scrollbar-track { background:var(--bg-0); }
::-webkit-scrollbar-thumb { background:var(--border-2); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--border-3); }

h1,h2,h3,h4 { font-family:var(--font-display); font-weight:700; letter-spacing:-.02em; line-height:1.15; }
.mono { font-family:var(--font-mono); font-variant-numeric:tabular-nums; }

/* ---------- 3. Backgrounds & ambient effects ---------- */
.bg-aurora {
  position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none;
  background:var(--bg-0);
}
.bg-aurora::before, .bg-aurora::after {
  content:''; position:absolute; border-radius:50%; filter:blur(120px); opacity:.4;
  will-change:transform;
}
.bg-aurora::before {
  width:680px; height:680px; left:-10%; top:-20%;
  background:radial-gradient(circle, var(--mint) 0%, transparent 70%);
  animation:auroraA 24s var(--ease) infinite alternate;
}
.bg-aurora::after {
  width:520px; height:520px; right:-8%; top:30%;
  background:radial-gradient(circle, var(--violet) 0%, transparent 70%);
  animation:auroraB 32s var(--ease) infinite alternate;
}
.bg-grid {
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%, #000 30%, transparent 80%);
  opacity:.35;
}
.bg-noise {
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.025;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
@keyframes auroraA { 0%{transform:translate(0,0) scale(1);} 100%{transform:translate(120px,80px) scale(1.15);} }
@keyframes auroraB { 0%{transform:translate(0,0) scale(1);} 100%{transform:translate(-100px,-60px) scale(1.2);} }

/* ---------- 4. Top navigation ---------- */
.topnav {
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:24px;
  padding:14px 32px;
  background:rgba(10,15,28,.72);
  backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  border-bottom:1px solid var(--border);
}
.topnav-brand {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-display); font-weight:700; font-size:18px;
  color:var(--text-1); white-space:nowrap;
}
.topnav-brand .brand-mark {
  width:34px; height:34px; border-radius:10px;
  background:linear-gradient(135deg, var(--mint) 0%, var(--mint-2) 50%, var(--violet) 130%);
  display:grid; place-items:center; color:#001a14;
  box-shadow:0 4px 16px rgba(45,212,191,.4), inset 0 1px 0 rgba(255,255,255,.3);
  position:relative; overflow:hidden;
}
.topnav-brand .brand-mark::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
  animation:shine 4s var(--ease) infinite;
}
.topnav-brand .brand-mark svg { width:18px; height:18px; position:relative; z-index:1; }
.topnav-brand .brand-name { letter-spacing:-.02em; }
.topnav-brand .brand-name .accent { color:var(--mint); }

.topnav-links { display:flex; gap:4px; align-items:center; flex:1; }
.topnav-link {
  position:relative;
  padding:8px 14px; border-radius:8px;
  font-size:14px; font-weight:500; color:var(--text-2);
  transition:all .2s var(--ease); white-space:nowrap;
}
.topnav-link:hover { color:var(--text-1); background:rgba(255,255,255,.04); }
.topnav-link.active { color:var(--text-1); background:var(--mint-bg); }
.topnav-link.active::after {
  content:''; position:absolute; left:14px; right:14px; bottom:-15px; height:2px;
  background:var(--mint); border-radius:2px;
  box-shadow:0 0 12px var(--mint);
}

.topnav-spacer { flex:1; }
.topnav-right { display:flex; align-items:center; gap:12px; }
.topnav-user-text { font-size:13px; color:var(--text-3); }
.topnav-user-text strong { color:var(--text-1); font-weight:600; }

.infinite-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 12px; border-radius:50px;
  background:linear-gradient(135deg, var(--mint-bg), var(--violet-bg));
  border:1px solid rgba(45,212,191,.3);
  color:var(--mint-2); font-size:12px; font-weight:600;
  position:relative; overflow:hidden;
}
.infinite-badge::before {
  content:''; position:absolute; inset:-1px;
  background:conic-gradient(from 0deg, transparent, var(--mint), transparent);
  animation:spin 3s linear infinite;
  opacity:.7;
}
.infinite-badge > * { position:relative; z-index:1; }
.infinite-badge::after {
  content:''; position:absolute; inset:1px; border-radius:50px; background:var(--bg-1); z-index:0;
}
@keyframes spin { to { transform:rotate(360deg); } }

.cmdk-trigger {
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 12px; border-radius:8px;
  background:var(--bg-2); border:1px solid var(--border);
  color:var(--text-3); font-size:13px; cursor:pointer;
  transition:all .2s var(--ease);
}
.cmdk-trigger:hover { border-color:var(--border-2); color:var(--text-1); }
.cmdk-trigger kbd {
  font-family:var(--font-mono); font-size:11px;
  padding:2px 6px; background:var(--bg-3); border:1px solid var(--border-2);
  border-radius:4px; color:var(--text-2);
}

/* ---------- 5. Layout ---------- */
.app { min-height:100vh; display:flex; flex-direction:column; }
.app-body { flex:1; }
.main-content { max-width:1320px; margin:0 auto; padding:36px 32px 80px; }
.section + .section { margin-top:48px; }

/* page header */
.page-header { margin-bottom:32px; display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.page-header-text h1, .page-header-text h2 { font-size:36px; font-weight:800; margin-bottom:8px; }
.page-header-text p { color:var(--text-3); font-size:15px; max-width:680px; }
.page-header-text .eyebrow {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:50px;
  background:var(--mint-bg); border:1px solid rgba(45,212,191,.2);
  color:var(--mint-2); font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.08em;
  margin-bottom:14px;
}
.page-header-actions { display:flex; gap:10px; }

/* breadcrumbs */
.breadcrumbs { display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-3); margin-bottom:16px; }
.breadcrumbs a { color:var(--text-3); }
.breadcrumbs a:hover { color:var(--mint-2); }
.breadcrumbs .sep { opacity:.5; }
.breadcrumbs .curr { color:var(--text-1); font-weight:500; }

/* ---------- 6. Cards ---------- */
.card {
  position:relative;
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:28px;
  transition:border-color .3s var(--ease), transform .3s var(--ease);
}
.card.card-pad-sm { padding:18px; }
.card.card-pad-lg { padding:36px; }
.card.card-glow { box-shadow:var(--shadow-mint); }
.card.card-spotlight {
  --x:50%; --y:50%;
  background:
    radial-gradient(420px circle at var(--x) var(--y), rgba(45,212,191,.08), transparent 60%),
    linear-gradient(180deg, var(--bg-2), var(--bg-1));
}
.card-header { display:flex; align-items:center; gap:14px; margin-bottom:20px; padding-bottom:18px; border-bottom:1px solid var(--border); }
.card-icon {
  width:44px; height:44px; border-radius:12px;
  background:linear-gradient(135deg, var(--mint), var(--mint-2));
  display:grid; place-items:center; color:#001a14;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3), 0 4px 14px rgba(45,212,191,.25);
}
.card-icon.violet { background:linear-gradient(135deg, var(--violet), var(--violet-2)); color:#0c0117; box-shadow:inset 0 1px 0 rgba(255,255,255,.3), 0 4px 14px rgba(167,139,250,.25); }
.card-icon.amber { background:linear-gradient(135deg, var(--amber), #fde68a); color:#3a2400; }
.card-icon.rose { background:linear-gradient(135deg, var(--rose), #fda4af); color:#3d0a13; }
.card-icon svg { width:20px; height:20px; }
.card-title { font-family:var(--font-display); font-size:18px; font-weight:700; color:var(--text-1); }
.card-subtitle { font-size:12px; color:var(--text-3); margin-top:2px; }

.card-grid { display:grid; gap:24px; grid-template-columns:repeat(12, minmax(0, 1fr)); }
.col-12 { grid-column:span 12; } .col-8 { grid-column:span 8; } .col-7 { grid-column:span 7; } .col-6 { grid-column:span 6; }
.col-5 { grid-column:span 5; } .col-4 { grid-column:span 4; } .col-3 { grid-column:span 3; }
@media(max-width:960px) { .col-8,.col-7,.col-6,.col-5,.col-4,.col-3 { grid-column:span 12; } }

/* ---------- 7. Stat boxes ---------- */
.stats { display:grid; grid-template-columns:repeat(auto-fit, minmax(180px, 1fr)); gap:14px; }
.stat {
  position:relative;
  padding:18px 20px; border-radius:var(--r);
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--border);
  transition:all .3s var(--ease);
  overflow:hidden;
}
.stat::before {
  content:''; position:absolute; left:0; right:0; top:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--mint), transparent);
  opacity:0; transition:opacity .3s var(--ease);
}
.stat:hover { border-color:var(--border-2); transform:translateY(-2px); }
.stat:hover::before { opacity:1; }
.stat-label { font-size:11px; font-weight:600; color:var(--text-3); text-transform:uppercase; letter-spacing:.08em; margin-bottom:10px; display:flex; align-items:center; gap:6px; }
.stat-label svg { width:12px; height:12px; }
.stat-value { font-family:var(--font-display); font-size:32px; font-weight:700; line-height:1; letter-spacing:-.02em; }
.stat-value.mono { font-family:var(--font-mono); font-size:24px; }
.stat-value.mint { color:var(--mint-2); }
.stat-value.violet { color:var(--violet-2); }
.stat-value.amber { color:var(--amber); }
.stat-value.rose { color:var(--rose); }
.stat-value.green { color:var(--green); }
.stat-value.blue { color:var(--blue); }
.stat-sub { font-size:12px; color:var(--text-3); margin-top:8px; display:flex; align-items:center; gap:6px; }
.stat-sub.up { color:var(--green); }
.stat-sub.down { color:var(--rose); }

/* ---------- 8. Forms ---------- */
.form-group { margin-bottom:18px; }
.form-label { display:flex; align-items:center; gap:6px; font-size:12px; font-weight:600; color:var(--text-2); text-transform:uppercase; letter-spacing:.06em; margin-bottom:8px; }
.form-label .req { color:var(--rose); }
.form-control {
  width:100%; padding:12px 16px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r); color:var(--text-1); font-size:14px; font-family:inherit;
  outline:none; transition:all .2s var(--ease);
}
.form-control:hover { border-color:var(--border-2); }
.form-control:focus { border-color:var(--mint); background:var(--bg-2); box-shadow:0 0 0 4px var(--mint-bg); }
.form-control::placeholder { color:var(--text-4); }
.form-control.mono { font-family:var(--font-mono); font-size:13px; }
textarea.form-control { resize:vertical; min-height:110px; line-height:1.5; }
select.form-control { appearance:none; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'><path d='M3 4.5L6 7.5L9 4.5' stroke='%23a4abc7' stroke-width='1.5' stroke-linecap='round'/></svg>"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-row-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
@media(max-width:640px) { .form-row, .form-row-3 { grid-template-columns:1fr; } }

.input-group { display:flex; }
.input-group .form-control { border-top-right-radius:0; border-bottom-right-radius:0; }
.input-suffix { display:flex; align-items:center; padding:0 14px; background:var(--bg-3); border:1px solid var(--border); border-left:none; border-top-right-radius:var(--r); border-bottom-right-radius:var(--r); color:var(--text-3); font-size:13px; white-space:nowrap; }

.checkbox-card {
  position:relative; padding:14px 16px;
  background:var(--bg-1); border:1px solid var(--border); border-radius:var(--r);
  cursor:pointer; transition:all .2s var(--ease);
  display:flex; gap:10px; align-items:flex-start;
}
.checkbox-card:hover { border-color:var(--border-2); }
.checkbox-card input { margin-top:2px; accent-color:var(--mint); width:16px; height:16px; cursor:pointer; }
.checkbox-card.checked { border-color:var(--mint); background:var(--mint-bg); }
.checkbox-card .title { font-size:14px; font-weight:600; }
.checkbox-card .desc { font-size:12px; color:var(--text-3); margin-top:2px; }

/* file drop */
.dropzone {
  border:2px dashed var(--border-2); border-radius:var(--r-md);
  padding:32px; text-align:center; transition:all .25s var(--ease);
  background:var(--bg-1);
}
.dropzone:hover, .dropzone.active { border-color:var(--mint); background:var(--mint-bg); }
.dropzone svg { width:32px; height:32px; color:var(--text-3); margin-bottom:8px; }

/* ---------- 9. Buttons ---------- */
.btn {
  position:relative; display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 20px; border:none; border-radius:var(--r);
  font-size:14px; font-weight:600; font-family:inherit;
  cursor:pointer; transition:all .2s var(--ease);
  text-decoration:none; white-space:nowrap; overflow:hidden;
  isolation:isolate;
}
.btn:disabled { opacity:.5; cursor:not-allowed; }
.btn svg { width:16px; height:16px; }

.btn-primary {
  background:linear-gradient(135deg, var(--mint), var(--mint-2));
  color:#001a14;
  box-shadow:0 4px 18px rgba(45,212,191,.3), inset 0 1px 0 rgba(255,255,255,.4);
}
.btn-primary::before {
  content:''; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.5) 50%, transparent 70%);
  transform:translateX(-100%); transition:transform .6s var(--ease);
}
.btn-primary:hover:not(:disabled) { transform:translateY(-2px); box-shadow:0 8px 28px rgba(45,212,191,.5), inset 0 1px 0 rgba(255,255,255,.4); }
.btn-primary:hover:not(:disabled)::before { transform:translateX(100%); }

.btn-secondary {
  background:var(--bg-2); color:var(--text-1); border:1px solid var(--border-2);
}
.btn-secondary:hover:not(:disabled) { background:var(--bg-3); border-color:var(--border-3); }

.btn-ghost {
  background:transparent; color:var(--text-2); border:1px solid var(--border);
}
.btn-ghost:hover:not(:disabled) { color:var(--text-1); border-color:var(--border-2); background:rgba(255,255,255,.03); }

.btn-violet {
  background:linear-gradient(135deg, var(--violet), var(--violet-2));
  color:#0c0117; box-shadow:0 4px 18px rgba(167,139,250,.3), inset 0 1px 0 rgba(255,255,255,.4);
}
.btn-violet:hover:not(:disabled) { transform:translateY(-2px); box-shadow:0 8px 28px rgba(167,139,250,.5); }

.btn-danger { background:var(--rose-bg); color:var(--rose); border:1px solid rgba(255,93,108,.25); }
.btn-danger:hover:not(:disabled) { background:rgba(255,93,108,.18); border-color:rgba(255,93,108,.4); }

.btn-success { background:var(--green-bg); color:var(--green); border:1px solid rgba(52,211,153,.25); }
.btn-warning { background:var(--amber-bg); color:var(--amber); border:1px solid rgba(251,191,36,.25); }

.btn-sm { padding:7px 14px; font-size:12px; }
.btn-sm svg { width:14px; height:14px; }
.btn-lg { padding:15px 28px; font-size:15px; }
.btn-xl { padding:18px 32px; font-size:16px; }
.btn-block { width:100%; }
.btn-icon { width:36px; height:36px; padding:0; }
.btn-icon.btn-sm { width:30px; height:30px; }

.btn-group { display:inline-flex; }
.btn-group .btn { border-radius:0; }
.btn-group .btn:first-child { border-radius:var(--r) 0 0 var(--r); }
.btn-group .btn:last-child { border-radius:0 var(--r) var(--r) 0; }
.btn-group .btn + .btn { margin-left:-1px; }

.spinner {
  width:16px; height:16px; border:2px solid rgba(255,255,255,.25); border-top-color:currentColor;
  border-radius:50%; animation:spin .7s linear infinite;
}

/* ---------- 10. Tables ---------- */
.table-wrap { border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; background:var(--bg-1); }
.table-wrap .table-toolbar {
  display:flex; align-items:center; justify-content:space-between; padding:14px 18px;
  background:var(--bg-2); border-bottom:1px solid var(--border); gap:12px;
}
.table-wrap .table-toolbar .search {
  flex:1; max-width:360px; position:relative;
}
.table-wrap .table-toolbar .search input {
  width:100%; padding:8px 14px 8px 36px; border-radius:8px;
  background:var(--bg-1); border:1px solid var(--border); color:var(--text-1); font-size:13px;
  outline:none;
}
.table-wrap .table-toolbar .search svg { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--text-3); width:14px; height:14px; }
table { width:100%; border-collapse:collapse; }
th { background:var(--bg-1); color:var(--text-3); font-weight:600; font-size:11px; text-transform:uppercase; letter-spacing:.06em; padding:12px 16px; text-align:left; border-bottom:1px solid var(--border); }
td { padding:14px 16px; border-bottom:1px solid rgba(33,42,71,.4); font-size:13px; color:var(--text-2); }
tr:last-child td { border-bottom:none; }
tr:hover td { background:rgba(45,212,191,.03); }

/* row card style (used in users list) */
.row-card {
  display:grid; align-items:center; gap:16px;
  padding:16px 18px; background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r); transition:all .2s var(--ease); margin-bottom:8px;
}
.row-card:hover { border-color:var(--border-2); transform:translateX(2px); }
.row-card.cols-6 { grid-template-columns:1.5fr 1.2fr 1fr .8fr 1fr auto; }
.row-card.cols-5 { grid-template-columns:2fr 1.2fr 1fr 1fr auto; }
.row-card .col-label { font-size:11px; font-weight:600; color:var(--text-3); text-transform:uppercase; letter-spacing:.05em; margin-bottom:4px; }
.row-card .col-value { font-size:13px; color:var(--text-1); font-weight:500; }
.row-card .user-name { font-weight:700; font-size:14px; color:var(--text-1); }
.row-card .user-handle { font-size:12px; color:var(--mint-2); margin-top:2px; }
@media(max-width:900px) { .row-card.cols-6, .row-card.cols-5 { grid-template-columns:1fr; } }

/* ---------- 11. Badges & Pills ---------- */
.badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:3px 10px; border-radius:50px; font-size:11px; font-weight:600;
  border:1px solid transparent;
}
.badge-success { background:var(--green-bg); color:var(--green); border-color:rgba(52,211,153,.18); }
.badge-danger { background:var(--rose-bg); color:var(--rose); border-color:rgba(255,93,108,.18); }
.badge-warning { background:var(--amber-bg); color:var(--amber); border-color:rgba(251,191,36,.18); }
.badge-info { background:var(--blue-bg); color:var(--blue); border-color:rgba(96,165,250,.18); }
.badge-mint { background:var(--mint-bg); color:var(--mint-2); border-color:rgba(45,212,191,.2); }
.badge-violet { background:var(--violet-bg); color:var(--violet-2); border-color:rgba(167,139,250,.2); }
.badge-neutral { background:var(--bg-3); color:var(--text-2); border-color:var(--border-2); }
.dot { width:6px; height:6px; border-radius:50%; background:currentColor; }
.dot.pulse { animation:pulseDot 1.6s var(--ease) infinite; }
@keyframes pulseDot { 0%,100% { box-shadow:0 0 0 0 currentColor; } 50% { box-shadow:0 0 0 5px transparent; } }

.code-tag {
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:6px;
  background:var(--bg-3); border:1px solid var(--border-2);
  font-family:var(--font-mono); font-size:12px; color:var(--mint-2);
  white-space:nowrap; flex-shrink:0;
}
.code-tag.amber { color:var(--amber); }
.code-tag.violet { color:var(--violet-2); }
.code-tag .method { color:var(--amber); font-weight:600; }

/* info-pill: label + value box used in headers */
.info-pill {
  padding:14px 18px; border-radius:var(--r); background:var(--bg-1); border:1px solid var(--border);
  min-width:0;
}
.info-pill .label { font-size:11px; font-weight:600; color:var(--text-3); text-transform:uppercase; letter-spacing:.06em; margin-bottom:6px; }
.info-pill .value { font-family:var(--font-display); font-weight:700; font-size:18px; color:var(--text-1); }
.info-pill .value.mono { font-family:var(--font-mono); font-size:14px; word-break:break-all; }
.info-pill .value.mint { color:var(--mint-2); }
.info-pill-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(180px,1fr)); gap:12px; }

/* ---------- 12. Alerts ---------- */
.alert {
  padding:14px 18px; border-radius:var(--r); font-size:13px;
  display:flex; align-items:flex-start; gap:12px;
  border:1px solid; margin-bottom:16px; line-height:1.5;
}
.alert svg { width:18px; height:18px; flex-shrink:0; margin-top:1px; }
.alert .alert-title { font-weight:600; margin-bottom:2px; }
.alert-info { background:var(--blue-bg); border-color:rgba(96,165,250,.2); color:var(--blue); }
.alert-success { background:var(--green-bg); border-color:rgba(52,211,153,.2); color:var(--green); }
.alert-danger { background:var(--rose-bg); border-color:rgba(255,93,108,.2); color:var(--rose); }
.alert-warning { background:var(--amber-bg); border-color:rgba(251,191,36,.2); color:var(--amber); }
.alert-mint { background:var(--mint-bg); border-color:rgba(45,212,191,.2); color:var(--mint-2); }

/* ---------- 13. Toast ---------- */
.toast-container { position:fixed; top:80px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:10px; pointer-events:none; }
.toast {
  pointer-events:auto;
  padding:14px 18px; border-radius:var(--r); font-size:13px; font-weight:500;
  display:flex; align-items:center; gap:10px;
  min-width:300px; max-width:420px;
  background:var(--bg-2); border:1px solid var(--border-2);
  box-shadow:var(--shadow-3); backdrop-filter:blur(20px);
  animation:toastIn .4s var(--ease-out);
}
.toast svg { width:18px; height:18px; flex-shrink:0; }
.toast-success { border-left:3px solid var(--green); color:var(--text-1); }
.toast-success svg { color:var(--green); }
.toast-error { border-left:3px solid var(--rose); color:var(--text-1); }
.toast-error svg { color:var(--rose); }
.toast-info { border-left:3px solid var(--blue); color:var(--text-1); }
.toast-info svg { color:var(--blue); }
@keyframes toastIn { from { opacity:0; transform:translateX(40px); } to { opacity:1; transform:translateX(0); } }

/* ---------- 14. Modal ---------- */
.modal-overlay {
  display:none; position:fixed; inset:0; z-index:10000;
  background:rgba(2,4,10,.7); backdrop-filter:blur(8px);
  align-items:center; justify-content:center; padding:20px;
}
.modal-overlay.show { display:flex; animation:fadeIn .2s var(--ease); }
.modal-box {
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--border-2); border-radius:var(--r-lg);
  padding:32px; max-width:480px; width:100%;
  box-shadow:var(--shadow-3);
  animation:modalIn .35s var(--ease-out);
}
.modal-box.lg { max-width:680px; }
.modal-box .modal-icon {
  width:48px; height:48px; border-radius:14px; margin-bottom:16px;
  background:var(--mint-bg); color:var(--mint-2);
  display:grid; place-items:center;
}
.modal-box .modal-icon.danger { background:var(--rose-bg); color:var(--rose); }
.modal-box h3 { font-size:22px; margin-bottom:8px; }
.modal-box p { color:var(--text-2); font-size:14px; margin-bottom:24px; }
.modal-actions { display:flex; gap:10px; justify-content:flex-end; }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes modalIn { from { opacity:0; transform:scale(.94) translateY(20px); } to { opacity:1; transform:scale(1) translateY(0); } }

/* ---------- 15. Command palette ---------- */
.cmdk { display:none; position:fixed; top:80px; left:50%; transform:translateX(-50%); width:min(620px, 92vw); z-index:10001; }
.cmdk.show { display:block; animation:cmdkIn .25s var(--ease-out); }
.cmdk-shell {
  background:rgba(16,23,40,.92); backdrop-filter:blur(28px) saturate(150%);
  border:1px solid var(--border-2); border-radius:var(--r-lg);
  box-shadow:var(--shadow-3);
  overflow:hidden;
}
.cmdk-input-wrap { display:flex; align-items:center; gap:12px; padding:18px 20px; border-bottom:1px solid var(--border); }
.cmdk-input-wrap svg { width:18px; height:18px; color:var(--text-3); }
.cmdk-input { flex:1; background:transparent; border:none; outline:none; color:var(--text-1); font-size:16px; font-family:inherit; }
.cmdk-input::placeholder { color:var(--text-4); }
.cmdk-list { max-height:380px; overflow-y:auto; padding:8px; }
.cmdk-group-title { padding:10px 12px 6px; font-size:11px; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.08em; }
.cmdk-item {
  display:flex; align-items:center; gap:12px;
  padding:10px 12px; border-radius:8px;
  font-size:14px; color:var(--text-2); cursor:pointer;
  transition:all .15s var(--ease);
}
.cmdk-item:hover, .cmdk-item.selected { background:var(--mint-bg); color:var(--text-1); }
.cmdk-item .icon { width:32px; height:32px; border-radius:8px; background:var(--bg-3); display:grid; place-items:center; color:var(--mint-2); flex-shrink:0; }
.cmdk-item .text { flex:1; }
.cmdk-item .subtitle { font-size:11px; color:var(--text-3); margin-top:2px; }
.cmdk-item kbd { font-family:var(--font-mono); font-size:11px; padding:2px 6px; background:var(--bg-3); border-radius:4px; color:var(--text-2); }
.cmdk-footer { padding:10px 16px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; font-size:11px; color:var(--text-3); }
.cmdk-footer .hints { display:flex; gap:14px; }
.cmdk-footer kbd { font-family:var(--font-mono); font-size:10px; padding:1px 5px; background:var(--bg-3); border-radius:3px; color:var(--text-2); margin-right:4px; }
@keyframes cmdkIn { from { opacity:0; transform:translate(-50%,-10px); } to { opacity:1; transform:translate(-50%,0); } }

/* ---------- 16. Tabs ---------- */
.tabs {
  display:inline-flex; gap:4px; padding:4px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r); margin-bottom:24px;
}
.tab-btn {
  position:relative; padding:8px 16px;
  background:transparent; border:none; border-radius:8px;
  color:var(--text-3); font-size:13px; font-weight:600; cursor:pointer;
  transition:all .2s var(--ease); font-family:inherit;
  display:inline-flex; align-items:center; gap:8px;
}
.tab-btn:hover { color:var(--text-1); }
.tab-btn.active { background:var(--mint); color:#001a14; box-shadow:0 2px 12px rgba(45,212,191,.35); }
.tab-btn .count { background:rgba(0,0,0,.15); padding:1px 6px; border-radius:50px; font-size:10px; }
.tab-pane { display:none; }
.tab-pane.active { display:block; animation:fadeUp .35s var(--ease-out); }
@keyframes fadeUp { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

/* ---------- 17. Credentials box ---------- */
.cred-box {
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:14px 16px; margin-bottom:10px;
  background:var(--bg-1); border:1px solid var(--border); border-radius:var(--r);
  transition:border-color .2s var(--ease);
}
.cred-box:hover { border-color:var(--border-2); }
.cred-box .cred-content { flex:1; min-width:0; }
.cred-label { font-size:10px; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.08em; margin-bottom:4px; }
.cred-value { font-family:var(--font-mono); font-size:14px; font-weight:500; color:var(--text-1); word-break:break-all; }
.cred-value.mint { color:var(--mint-2); }

.btn-copy {
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 12px; border-radius:8px;
  background:var(--mint-bg); border:1px solid rgba(45,212,191,.25); color:var(--mint-2);
  font-size:12px; font-weight:600; cursor:pointer; font-family:inherit;
  transition:all .2s var(--ease); white-space:nowrap;
}
.btn-copy:hover { background:var(--mint-bg-2); border-color:rgba(45,212,191,.4); }
.btn-copy.copied { background:var(--green-bg); border-color:rgba(52,211,153,.3); color:var(--green); }
.btn-copy svg { width:13px; height:13px; }

/* ---------- 18. Progress ---------- */
.progress-wrap { margin-bottom:16px; }
.progress-info { display:flex; justify-content:space-between; margin-bottom:8px; font-size:12px; }
.progress-info .label { color:var(--text-2); font-weight:500; }
.progress-info .value { color:var(--text-1); font-weight:600; }
.progress-bar { height:8px; background:var(--bg-1); border-radius:50px; overflow:hidden; position:relative; }
.progress-fill { height:100%; background:linear-gradient(90deg, var(--mint), var(--mint-2)); border-radius:50px; transition:width .8s var(--ease-out); position:relative; }
.progress-fill::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
  animation:shimmer 2s linear infinite;
}
.progress-fill.warn { background:linear-gradient(90deg, var(--amber), var(--rose)); }
.progress-fill.danger { background:linear-gradient(90deg, var(--rose), #f87171); }
@keyframes shimmer { from { transform:translateX(-100%); } to { transform:translateX(100%); } }
@keyframes shine { 0% { transform:translateX(-120%); } 60%,100% { transform:translateX(120%); } }

/* setup progress ring */
.setup-ring { display:flex; align-items:center; gap:14px; }
.setup-ring .ring { position:relative; width:48px; height:48px; }
.setup-ring .ring svg { transform:rotate(-90deg); }
.setup-ring .ring .pct { position:absolute; inset:0; display:grid; place-items:center; font-size:13px; font-weight:700; color:var(--mint-2); }

/* ---------- 19. Package / Pricing cards ---------- */
.packages-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:18px; }
.pkg-card {
  position:relative;
  padding:28px;
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--border); border-radius:var(--r-md);
  transition:all .3s var(--ease); overflow:hidden;
}
.pkg-card.featured { border-color:var(--mint); box-shadow:var(--shadow-mint); }
.pkg-card.featured::before {
  content:'Most popular'; position:absolute; top:14px; right:14px;
  padding:4px 10px; border-radius:50px;
  background:var(--mint); color:#001a14;
  font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
}
.pkg-card:hover { border-color:var(--border-3); transform:translateY(-4px); box-shadow:var(--shadow-2); }
.pkg-card .pkg-name { font-family:var(--font-display); font-size:20px; font-weight:700; margin-bottom:4px; }
.pkg-card .pkg-desc { font-size:13px; color:var(--text-3); margin-bottom:20px; min-height:36px; }
.pkg-card .pkg-price { display:flex; align-items:baseline; gap:6px; margin-bottom:6px; }
.pkg-card .pkg-price .num { font-family:var(--font-display); font-size:42px; font-weight:800; color:var(--mint-2); line-height:1; }
.pkg-card .pkg-price .unit { color:var(--text-3); font-size:14px; }
.pkg-card .pkg-credits { font-size:13px; color:var(--text-3); margin-bottom:20px; }
.pkg-card .pkg-credits b { color:var(--text-1); font-weight:600; }
.pkg-features { list-style:none; margin-bottom:24px; display:flex; flex-direction:column; gap:8px; }
.pkg-features li { font-size:13px; color:var(--text-2); display:flex; align-items:center; gap:10px; }
.pkg-features li svg { width:14px; height:14px; color:var(--mint); flex-shrink:0; }

/* pricing row (used in account page) */
.pricing-row {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:18px 20px; background:var(--bg-1); border:1px solid var(--border); border-radius:var(--r);
  margin-bottom:10px; transition:all .2s var(--ease);
}
.pricing-row:hover { border-color:var(--border-2); }
.pricing-row .pricing-info { flex:1; }
.pricing-row .pricing-title { font-weight:700; font-size:15px; margin-bottom:4px; display:flex; align-items:center; gap:8px; }
.pricing-row .pricing-desc { font-size:13px; color:var(--text-3); }
.pricing-row .pricing-meta { font-size:12px; color:var(--text-4); margin-top:4px; }
.pricing-row .pricing-cost {
  padding:8px 16px; border-radius:50px;
  background:var(--mint-bg); border:1px solid rgba(45,212,191,.2); color:var(--mint-2);
  font-weight:700; font-size:13px; white-space:nowrap;
}
.pricing-row .pricing-cost.zero { background:var(--bg-3); border-color:var(--border-2); color:var(--text-3); }

/* ---------- 20. Empty state ---------- */
.empty { text-align:center; padding:48px 24px; color:var(--text-3); }
.empty .empty-icon {
  width:64px; height:64px; margin:0 auto 16px; border-radius:50%;
  background:var(--bg-2); border:1px solid var(--border);
  display:grid; place-items:center; color:var(--text-3);
}
.empty h4 { font-family:var(--font-display); font-size:18px; color:var(--text-1); margin-bottom:6px; }
.empty p { font-size:14px; max-width:380px; margin:0 auto 18px; }

/* ---------- 21. Hero / Landing ---------- */
.hero {
  position:relative;
  padding:80px 32px;
  text-align:center; overflow:hidden;
}
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 16px; border-radius:50px;
  background:var(--mint-bg); border:1px solid rgba(45,212,191,.25);
  color:var(--mint-2); font-size:12px; font-weight:600;
  margin-bottom:24px;
  animation:fadeUp .6s var(--ease-out) both;
}
.hero-eyebrow .dot.pulse { color:var(--mint); }
.hero h1 {
  font-family:var(--font-display);
  font-size:clamp(40px, 6vw, 76px); font-weight:800;
  line-height:1.02; letter-spacing:-.035em;
  margin-bottom:20px;
  animation:fadeUp .7s var(--ease-out) .1s both;
}
.hero h1 .grad {
  background:linear-gradient(135deg, var(--mint) 0%, var(--mint-2) 40%, var(--violet) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
}
.hero p.lead {
  font-size:clamp(15px, 1.6vw, 19px); color:var(--text-2); line-height:1.55;
  max-width:640px; margin:0 auto 36px;
  animation:fadeUp .7s var(--ease-out) .2s both;
}
.hero-cta { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; animation:fadeUp .7s var(--ease-out) .3s both; }
.hero-trust {
  display:flex; gap:24px; justify-content:center; flex-wrap:wrap;
  margin-top:48px; padding-top:32px; border-top:1px solid var(--border);
  animation:fadeUp .7s var(--ease-out) .5s both;
}
.hero-trust .item { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--text-3); }
.hero-trust .item svg { width:14px; height:14px; color:var(--mint); }

/* live counter strip */
.live-strip {
  display:inline-flex; align-items:center; gap:12px;
  padding:10px 18px; border-radius:50px;
  background:rgba(45,212,191,.08); border:1px solid rgba(45,212,191,.18);
  font-size:13px; color:var(--text-2);
  margin-bottom:20px;
}
.live-strip .dot { color:var(--mint); width:8px; height:8px; }

/* feature grid (used in landing) */
.feature-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)); gap:18px; }
.feature {
  padding:24px; background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--border); border-radius:var(--r-md);
  transition:all .3s var(--ease);
}
.feature:hover { border-color:var(--mint); transform:translateY(-3px); box-shadow:var(--shadow-mint); }
.feature .feat-icon {
  width:42px; height:42px; border-radius:12px; margin-bottom:14px;
  background:linear-gradient(135deg, var(--mint-bg), var(--violet-bg));
  border:1px solid rgba(45,212,191,.2);
  display:grid; place-items:center; color:var(--mint-2);
}
.feature h4 { font-family:var(--font-display); font-size:17px; margin-bottom:6px; }
.feature p { font-size:13px; color:var(--text-3); line-height:1.55; }

/* ---------- 22. FAQ ---------- */
.faq { display:flex; flex-direction:column; gap:8px; }
.faq-item {
  border:1px solid var(--border); border-radius:var(--r);
  background:var(--bg-1); overflow:hidden;
  transition:border-color .2s var(--ease);
}
.faq-item.open { border-color:var(--mint); }
.faq-q {
  width:100%; padding:18px 20px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  background:none; border:none; cursor:pointer; text-align:left;
  font-family:var(--font-display); font-size:15px; font-weight:600; color:var(--text-1);
}
.faq-q .icon {
  width:24px; height:24px; border-radius:50%;
  background:var(--bg-3); display:grid; place-items:center; flex-shrink:0;
  transition:all .25s var(--ease);
}
.faq-item.open .faq-q .icon { background:var(--mint); color:#001a14; transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .35s var(--ease); }
.faq-item.open .faq-a { max-height:300px; }
.faq-a-inner { padding:0 20px 18px; color:var(--text-2); font-size:14px; line-height:1.6; }

/* testimonial */
.testimonial {
  padding:24px; border-radius:var(--r-md);
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--border);
}
.testimonial .stars { color:var(--amber); margin-bottom:12px; letter-spacing:2px; }
.testimonial blockquote { font-size:15px; color:var(--text-1); line-height:1.6; margin-bottom:16px; }
.testimonial .author { display:flex; align-items:center; gap:10px; }
.testimonial .avatar {
  width:36px; height:36px; border-radius:50%;
  background:linear-gradient(135deg, var(--mint), var(--violet));
  display:grid; place-items:center; color:#001a14; font-weight:700; font-size:13px;
}
.testimonial .name { font-weight:600; font-size:14px; }
.testimonial .role { font-size:12px; color:var(--text-3); }

/* trust strip */
.trust-strip {
  display:flex; flex-wrap:wrap; gap:20px;
  padding:20px 24px; border-radius:var(--r-md);
  background:var(--bg-1); border:1px solid var(--border);
}
.trust-item { display:flex; align-items:center; gap:10px; font-size:13px; color:var(--text-2); }
.trust-item svg { width:18px; height:18px; color:var(--mint); flex-shrink:0; }
.trust-item b { color:var(--text-1); font-weight:600; }

/* ---------- 23. Activity feed (live) ---------- */
.activity-feed { display:flex; flex-direction:column; gap:8px; max-height:420px; overflow-y:auto; }
.activity-item {
  display:flex; align-items:center; gap:12px;
  padding:12px 14px; border-radius:var(--r);
  background:var(--bg-1); border:1px solid var(--border);
  animation:slideDown .45s var(--ease-out);
}
.activity-item .av {
  width:32px; height:32px; border-radius:50%; flex-shrink:0;
  display:grid; place-items:center; font-size:11px; font-weight:700;
  background:var(--mint-bg); color:var(--mint-2);
}
.activity-item .info { flex:1; min-width:0; font-size:13px; }
.activity-item .info .name { font-weight:600; color:var(--text-1); }
.activity-item .info .action { color:var(--text-3); }
.activity-item .time { font-size:11px; color:var(--text-4); white-space:nowrap; }
@keyframes slideDown { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }

/* countdown */
.countdown {
  display:inline-flex; gap:8px;
}
.countdown .seg {
  min-width:60px; padding:12px 8px; border-radius:var(--r);
  background:var(--bg-2); border:1px solid var(--border); text-align:center;
}
.countdown .seg .n { font-family:var(--font-display); font-size:24px; font-weight:800; color:var(--mint-2); font-variant-numeric:tabular-nums; line-height:1; }
.countdown .seg .l { font-size:10px; color:var(--text-3); text-transform:uppercase; letter-spacing:.06em; margin-top:4px; }

/* sticky purchase bar */
.sticky-bar {
  position:fixed; bottom:20px; left:50%; transform:translateX(-50%);
  display:flex; align-items:center; gap:16px;
  padding:12px 16px 12px 20px; border-radius:50px;
  background:rgba(16,23,40,.92); backdrop-filter:blur(20px);
  border:1px solid var(--border-2); box-shadow:var(--shadow-3);
  z-index:60; animation:slideUp .5s var(--ease-out);
}
.sticky-bar .info { font-size:13px; color:var(--text-2); }
.sticky-bar .info b { color:var(--text-1); }
@keyframes slideUp { from { opacity:0; transform:translate(-50%, 20px); } to { opacity:1; transform:translate(-50%, 0); } }

/* ---------- 24. Toolkit chat-like UI ---------- */
.toolkit-shell { display:grid; grid-template-rows:auto 1fr auto; height:calc(100vh - 120px); min-height:520px; }
.toolkit-help { padding:16px 20px; background:var(--bg-1); border:1px solid var(--border); border-radius:var(--r); font-size:14px; color:var(--text-2); margin-bottom:16px; line-height:1.65; }
.toolkit-help code { background:var(--bg-3); border:1px solid var(--border-2); padding:1px 7px; border-radius:5px; font-family:var(--font-mono); font-size:12px; color:var(--amber); }
.toolkit-stream { flex:1; overflow-y:auto; padding:8px 4px; display:flex; flex-direction:column; gap:8px; }
.toolkit-result {
  display:grid; grid-template-columns:auto 1fr 1fr auto; gap:16px; align-items:center;
  padding:14px 18px; border-radius:var(--r); background:var(--bg-1); border:1px solid var(--border);
  transition:all .2s var(--ease);
}
.toolkit-result:hover { border-color:var(--border-2); }
.toolkit-result .meta { font-size:11px; }
.toolkit-result .meta .label { color:var(--text-3); text-transform:uppercase; letter-spacing:.06em; font-weight:600; }
.toolkit-result .meta .val { color:var(--text-1); font-family:var(--font-mono); font-size:12px; margin-top:2px; }
.toolkit-result .status .badge-mint { display:inline-block; margin-top:2px; }
.toolkit-input-bar {
  display:flex; align-items:center; gap:10px;
  padding:14px; background:var(--bg-1); border:1px solid var(--border-2); border-radius:50px;
  box-shadow:var(--shadow-2); position:relative;
}
.toolkit-input-bar.focus { border-color:var(--mint); box-shadow:0 0 0 4px var(--mint-bg); }
.toolkit-input-bar input {
  flex:1; padding:8px 12px; background:transparent; border:none; outline:none;
  color:var(--text-1); font-size:14px; font-family:inherit;
}
.toolkit-input-bar input::placeholder { color:var(--text-4); }
.toolkit-input-bar .attach-btn {
  width:38px; height:38px; border-radius:50%; background:var(--bg-3); border:1px solid var(--border-2);
  display:grid; place-items:center; color:var(--text-2); cursor:pointer; transition:all .2s var(--ease);
}
.toolkit-input-bar .attach-btn:hover { background:var(--mint-bg); color:var(--mint-2); }
.toolkit-input-bar .send-btn {
  width:38px; height:38px; border-radius:50%; border:none;
  background:linear-gradient(135deg, var(--mint), var(--mint-2)); color:#001a14;
  display:grid; place-items:center; cursor:pointer; transition:all .2s var(--ease);
}
.toolkit-input-bar .send-btn:hover { transform:scale(1.06); box-shadow:0 4px 16px rgba(45,212,191,.4); }
.toolkit-input-bar .toggle { font-size:11px; color:var(--text-3); padding-left:12px; border-left:1px solid var(--border); display:flex; flex-direction:column; align-items:center; }
.toolkit-input-bar .toggle b { color:var(--mint-2); font-size:11px; }

/* ---------- 25. Onboarding tour ---------- */
.tour-overlay {
  display:none; position:fixed; inset:0; z-index:9998;
  background:rgba(2,4,10,.78); backdrop-filter:blur(4px);
}
.tour-overlay.show { display:block; animation:fadeIn .25s var(--ease); }
.tour-card {
  position:fixed; max-width:340px; padding:20px;
  background:linear-gradient(180deg, var(--bg-2), var(--bg-1));
  border:1px solid var(--mint); border-radius:var(--r-md);
  box-shadow:0 0 0 4px rgba(45,212,191,.15), var(--shadow-3);
  z-index:9999;
}
.tour-card .tour-step { font-size:11px; color:var(--mint-2); font-weight:700; text-transform:uppercase; letter-spacing:.08em; margin-bottom:8px; }
.tour-card h4 { font-family:var(--font-display); font-size:17px; margin-bottom:6px; }
.tour-card p { font-size:13px; color:var(--text-2); margin-bottom:16px; line-height:1.5; }
.tour-card .tour-actions { display:flex; justify-content:space-between; align-items:center; }
.tour-progress { display:flex; gap:4px; }
.tour-progress .pip { width:18px; height:3px; border-radius:2px; background:var(--bg-3); }
.tour-progress .pip.done, .tour-progress .pip.current { background:var(--mint); }

/* ---------- 26. Skeleton ---------- */
.sk { background:linear-gradient(90deg, var(--bg-2), var(--bg-3), var(--bg-2)); background-size:200% 100%; animation:skLoad 1.4s linear infinite; border-radius:6px; height:14px; }
@keyframes skLoad { from { background-position:200% 0; } to { background-position:-200% 0; } }

/* ---------- 27. Animations base ---------- */
@keyframes fadeUp { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
@keyframes spin { to { transform:rotate(360deg); } }
.reveal { opacity:0; animation:fadeUp .7s var(--ease-out) forwards; }
.reveal.d1 { animation-delay:.08s; } .reveal.d2 { animation-delay:.16s; } .reveal.d3 { animation-delay:.24s; }
.reveal.d4 { animation-delay:.32s; } .reveal.d5 { animation-delay:.4s; }

/* count-up number */
.count-up { display:inline-block; font-variant-numeric:tabular-nums; }

/* ---------- 28. Footer ---------- */
.footer {
  margin-top:80px; padding:32px;
  border-top:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;
  font-size:13px; color:var(--text-3);
}
.footer .footer-meta { display:flex; gap:18px; flex-wrap:wrap; }
.footer .footer-meta b { color:var(--text-1); font-weight:600; }

/* ---------- 29. Endpoint card (API page) ---------- */
.endpoint-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:14px; }
.endpoint {
  padding:18px; background:var(--bg-1); border:1px solid var(--border); border-radius:var(--r);
  transition:all .25s var(--ease);
}
.endpoint:hover { border-color:var(--mint); transform:translateY(-2px); }
.endpoint .ep-route { display:flex; gap:8px; align-items:center; margin-bottom:10px; }
.endpoint .ep-method { padding:2px 8px; border-radius:4px; font-family:var(--font-mono); font-size:11px; font-weight:700; }
.endpoint .ep-method.get { background:var(--blue-bg); color:var(--blue); }
.endpoint .ep-method.post { background:var(--amber-bg); color:var(--amber); }
.endpoint .ep-path { font-family:var(--font-mono); font-size:12px; color:var(--text-1); }
.endpoint .ep-desc { font-size:12px; color:var(--text-3); line-height:1.55; margin-bottom:12px; }
.endpoint pre {
  background:var(--bg-0); border:1px solid var(--border); border-radius:8px;
  padding:10px 12px; font-family:var(--font-mono); font-size:11px;
  overflow-x:auto; color:var(--text-2);
  scrollbar-width:thin;
}

/* ---------- 30. Utilities ---------- */
.flex { display:flex; } .inline-flex { display:inline-flex; }
.flex-col { flex-direction:column; }
.flex-wrap { flex-wrap:wrap; }
.items-center { align-items:center; }
.items-start { align-items:flex-start; }
.items-end { align-items:flex-end; }
.justify-between { justify-content:space-between; }
.justify-end { justify-content:flex-end; }
.justify-center { justify-content:center; }
.flex-1 { flex:1; }
.gap-4 { gap:4px; } .gap-8 { gap:8px; } .gap-12 { gap:12px; } .gap-16 { gap:16px; } .gap-24 { gap:24px; }
.mb-4 { margin-bottom:4px; } .mb-8 { margin-bottom:8px; } .mb-12 { margin-bottom:12px; } .mb-16 { margin-bottom:16px; } .mb-24 { margin-bottom:24px; } .mb-32 { margin-bottom:32px; }
.mt-8 { margin-top:8px; } .mt-12 { margin-top:12px; } .mt-16 { margin-top:16px; } .mt-24 { margin-top:24px; } .mt-32 { margin-top:32px; }
.text-center { text-align:center; }
.text-right { text-align:right; }
.text-sm { font-size:13px; } .text-xs { font-size:12px; }
.text-mute { color:var(--text-3); }
.text-mute-2 { color:var(--text-2); }
.text-mint { color:var(--mint-2); }
.text-amber { color:var(--amber); }
.font-display { font-family:var(--font-display); }
.font-bold { font-weight:700; }
.font-semibold { font-weight:600; }
.w-full { width:100%; }
.hidden { display:none !important; }
.no-scroll { overflow:hidden; }
.rounded { border-radius:var(--r); }
.rounded-lg { border-radius:var(--r-md); }
.shadow-glow { box-shadow:var(--shadow-mint); }

/* ---------- 31. Responsive ---------- */
@media(max-width:880px) {
  .topnav { padding:10px 16px; gap:12px; }
  .topnav-links { display:none; }
  .main-content { padding:24px 16px 60px; }
  .page-header-text h1, .page-header-text h2 { font-size:26px; }
  .card { padding:20px; }
  .stat-value { font-size:24px; }
  .stats { grid-template-columns:1fr 1fr; }
  .hero { padding:48px 20px; }
}

/* ---------- 32. Print ---------- */
@media print {
  .bg-aurora, .bg-grid, .bg-noise, .topnav, .sticky-bar, .cmdk, .toast-container, .tour-overlay, .tour-card { display:none !important; }
  body { background:#fff; color:#000; }
  .card { border:1px solid #ddd; box-shadow:none; background:#fff; }
}

/* ============================================================
   33. Legacy compat layer — old class names → new design tokens
   Added during pid24h redesign so legacy .cshtml views render
   correctly until their inner markup is migrated.
============================================================ */
.container { width:100%; max-width:1280px; margin:0 auto; padding:0 32px; }
.content-section { padding:64px 0; }
.page-content { padding:24px 0 48px; }
.app-body { padding:24px 0 48px; }

.panel-card {
  background:linear-gradient(180deg, var(--bg-1) 0%, var(--bg-2) 100%);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:32px;
  position:relative;
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset;
}
.panel-card.mb-4 { margin-bottom:24px; }
.panel-card h1, .panel-card h2 { color:var(--text-1); letter-spacing:-.02em; }
.panel-card h1 { font-size:32px; margin:0 0 12px; }
.panel-card h2 { font-size:22px; margin:0 0 12px; }
.panel-subtitle { color:var(--text-2); font-size:15px; line-height:1.55; margin:0 0 12px; }
.muted-text { color:var(--text-3); font-size:14px; line-height:1.55; }
.hero-section { padding:48px 0; }
.hero-title { font-size:54px; letter-spacing:-.03em; margin:0 0 14px; color:var(--text-1); }
.hero-copy { font-size:16px; color:var(--text-2); max-width:640px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:20px; }

.stats-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:16px;
  margin-top:24px;
}
.metric-card {
  background:var(--bg-1);
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px 18px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.metric-label { font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--text-3); font-weight:600; }
.metric-value { font-size:18px; color:var(--text-1); font-weight:600; font-family:var(--font-display); word-break:break-word; }
.metric-value code { font-family:var(--font-mono); font-size:13px; color:var(--mint); background:var(--mint-bg); padding:2px 6px; border-radius:6px; }

.status-banner { display:flex; gap:12px; padding:14px 16px; border-radius:12px; border:1px solid; margin-bottom:14px; flex-direction:column; }
.status-banner h3 { margin:0 0 4px; font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:.08em; }
.status-banner p { margin:0; font-size:14px; color:var(--text-2); }
.status-banner-success, .status-banner-mint { background:var(--mint-bg); border-color:rgba(45,212,191,.25); }
.status-banner-success h3, .status-banner-mint h3 { color:var(--mint); }
.status-banner-warning, .status-banner-warn { background:var(--amber-bg); border-color:rgba(251,191,36,.25); }
.status-banner-warning h3, .status-banner-warn h3 { color:var(--amber); }
.status-banner-danger { background:var(--rose-bg); border-color:rgba(244,114,182,.25); }
.status-banner-danger h3 { color:var(--rose); }
.status-banner-info { background:var(--blue-bg); border-color:rgba(96,165,250,.25); }
.status-banner-info h3 { color:var(--blue); }
.status-banner-muted { background:var(--bg-3); border-color:var(--border); }

.workspace-grid, .api-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(360px, 1fr));
  gap:24px;
  margin-top:24px;
}
.workspace-form { display:flex; flex-direction:column; gap:14px; }
.stack-sm { display:flex; flex-direction:column; gap:10px; }

.mt-3 { margin-top:12px; }
.mt-4 { margin-top:16px; }
.mb-3 { margin-bottom:12px; }
.mb-4 { margin-bottom:16px; }
.w-100 { width:100%; }
.text-warning { color:var(--amber); }
.text-warning.small, .small { font-size:12px; }
.btn-outline-light {
  background:transparent;
  color:var(--text-1);
  border:1px solid var(--border-2);
  padding:10px 18px;
  border-radius:12px;
  font-weight:600;
  font-size:13px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  transition:all .15s var(--ease-out);
  text-decoration:none;
}
.btn-outline-light:hover { background:rgba(255,255,255,.05); border-color:var(--mint); color:var(--mint); }
.btn-lg { padding:14px 24px; font-size:15px; }

.home-landing-section { padding:48px 0; }
.home-landing-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
@media(max-width:880px){ .home-landing-grid { grid-template-columns:1fr; } }
.home-story-card { padding:32px; }
.home-landing-title { font-size:48px; letter-spacing:-.03em; margin:0 0 16px; }
.home-landing-copy { font-size:16px; color:var(--text-2); line-height:1.55; }
.home-service-list { display:flex; flex-direction:column; gap:16px; margin-top:24px; }
.home-service-item h2 { font-size:16px; margin:0 0 6px; color:var(--text-1); }
.home-service-item p { margin:0; font-size:13px; color:var(--text-3); }
.home-access-card { padding:32px; }
.home-access-copy { color:var(--text-2); font-size:14px; }
.home-access-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:16px; }
.home-auth-switcher { display:flex; gap:6px; padding:6px; background:var(--bg-2); border:1px solid var(--border); border-radius:14px; margin-bottom:16px; }
.home-auth-switch { flex:1; padding:10px 14px; border-radius:10px; background:transparent; color:var(--text-3); border:none; font-weight:600; font-size:13px; cursor:pointer; transition:all .15s var(--ease-out); }
.home-auth-switch.is-active { background:var(--bg-3); color:var(--text-1); box-shadow:0 0 0 1px var(--border-2); }
.home-auth-switch:hover { color:var(--text-1); }
.home-auth-panels { position:relative; }
.home-auth-panel { display:none; }
.home-auth-panel.is-active { display:block; }
.home-auth-form { display:flex; flex-direction:column; gap:14px; }
.forgot-password-panel { margin-top:16px; padding:14px; background:var(--mint-bg); border:1px solid rgba(45,212,191,.2); border-radius:12px; font-size:13px; color:var(--text-2); }
.forgot-password-link { color:var(--mint); font-weight:600; text-decoration:none; }
.forgot-password-link:hover { color:var(--mint-2); }
.badge-soft { display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:50px; background:var(--mint-bg); color:var(--mint); font-size:11px; font-weight:600; border:1px solid rgba(45,212,191,.25); }

.auth-wrapper { max-width:560px; margin:32px auto; padding:0 24px; }
.auth-card { padding:32px; }

.chat-screen { padding:24px 0; }
.chat-page { width:100%; margin:0; }
.toolkit-layout { display:grid; grid-template-columns:1fr 320px; gap:24px; }
@media(max-width:980px){ .toolkit-layout { grid-template-columns:1fr; } }
.toolkit-column { min-width:0; }
.chat-shell { padding:24px; min-height:560px; }
.chat-thread { display:flex; flex-direction:column; gap:14px; }
.chat-message { display:flex; gap:10px; }
.chat-message-assistant .chat-bubble { background:var(--bg-2); border:1px solid var(--border); padding:14px 16px; border-radius:14px; color:var(--text-1); }
.chat-message-user { justify-content:flex-end; }
.chat-message-user .chat-bubble { background:var(--mint-bg); border:1px solid rgba(45,212,191,.25); padding:14px 16px; border-radius:14px; color:var(--text-1); }

.telegram-verify-modal { position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; padding:24px; }
.telegram-verify-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.7); backdrop-filter:blur(8px); }
.telegram-verify-dialog { position:relative; z-index:1; }

/* =============================================================
   v4.7 — UX refresh
   Auth shell (Login / Register / Home logged-in)
   ============================================================= */
.auth-shell {
  display:grid;
  grid-template-columns: minmax(0, 420px) minmax(0, 360px);
  gap:32px;
  align-items:start;
  max-width:880px;
  margin:48px auto;
  padding:0 20px;
}
@media (max-width: 880px) {
  .auth-shell { grid-template-columns: 1fr; max-width:480px; }
}
.auth-card {
  background:var(--bg-1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:36px 32px;
  box-shadow:var(--shadow-2);
}
.auth-brand {
  display:inline-flex; align-items:center; gap:10px;
  text-decoration:none; color:var(--text-1);
  font-family:var(--font-display); font-weight:700; font-size:18px;
  margin-bottom:24px;
}
.auth-brand .brand-mark {
  width:34px; height:34px; border-radius:10px;
  background:linear-gradient(135deg,var(--mint),var(--mint-2));
  display:grid; place-items:center; color:#001a14;
}
.auth-brand .brand-mark svg { width:18px; height:18px; }
.auth-title {
  font-family:var(--font-display); font-weight:700;
  font-size:32px; letter-spacing:-.025em; line-height:1.1;
  margin:0 0 8px;
}
.auth-sub {
  color:var(--text-2); font-size:14.5px; line-height:1.55;
  margin:0 0 24px;
}
.auth-form .form-group { margin-bottom:14px; }
.auth-foot {
  display:flex; justify-content:space-between; gap:12px;
  margin-top:18px; padding-top:18px;
  border-top:1px solid var(--border);
  font-size:13px;
}
.auth-foot a { color:var(--text-2); text-decoration:none; }
.auth-foot a:hover { color:var(--mint-2); }
.auth-side {
  background:transparent;
  border:1px dashed var(--border-2);
  border-radius:var(--r-lg);
  padding:28px 24px;
}
.auth-side .eyebrow { margin-bottom:10px; }
.auth-side h2 {
  font-family:var(--font-display); font-weight:700;
  font-size:22px; margin:0 0 16px; letter-spacing:-.02em;
}
.auth-steps {
  list-style:none; margin:0 0 20px; padding:0;
  display:flex; flex-direction:column; gap:14px;
  counter-reset:auth-step;
}
.auth-steps li {
  position:relative; padding-left:36px;
  font-size:13.5px; color:var(--text-2); line-height:1.55;
}
.auth-steps li::before {
  counter-increment:auth-step; content:counter(auth-step);
  position:absolute; left:0; top:0;
  width:24px; height:24px; border-radius:50%;
  background:var(--mint-bg); color:var(--mint-2);
  display:grid; place-items:center;
  font-family:var(--font-display); font-weight:700; font-size:12px;
  border:1px solid rgba(45,212,191,.3);
}
.auth-steps li b { color:var(--text-1); font-weight:600; }
.auth-steps li a { color:var(--mint-2); word-break:break-all; }
.auth-side-lead { color:var(--text-2); font-size:14px; line-height:1.6; margin:0 0 16px; }
.auth-bullets {
  list-style:none; margin:20px 0 0; padding:16px 0 0;
  border-top:1px solid var(--border);
  display:flex; flex-direction:column; gap:8px;
  font-size:13px; color:var(--text-2);
}
.auth-bullets b { color:var(--mint-2); font-weight:700; font-family:var(--font-mono); }

/* Account hub */
.account-hero {
  display:grid;
  grid-template-columns: 1fr auto;
  gap:24px; align-items:end;
  padding:8px 0 28px;
  margin-bottom:28px;
  border-bottom:1px solid var(--border);
}
@media (max-width:720px) {
  .account-hero { grid-template-columns: 1fr; }
}
.account-name {
  font-family:var(--font-display); font-weight:700;
  font-size:40px; letter-spacing:-.03em; line-height:1.05;
  margin:10px 0 6px;
}
.account-meta { color:var(--text-3); font-size:13px; }
.account-balance {
  text-align:right;
  background:var(--bg-1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:18px 22px;
  min-width:220px;
}
.account-balance.is-empty { border-color:rgba(251,191,36,.35); background:linear-gradient(135deg,rgba(251,191,36,.05),var(--bg-1)); }
.account-balance.is-positive { border-color:rgba(45,212,191,.25); }
.account-balance.is-unlimited { border-color:rgba(167,139,250,.3); background:linear-gradient(135deg,rgba(167,139,250,.05),var(--bg-1)); }
.balance-amount {
  font-family:var(--font-display); font-weight:700;
  font-size:42px; letter-spacing:-.03em; line-height:1;
  color:var(--mint-2);
}
.account-balance.is-empty .balance-amount { color:var(--amber); }
.account-balance.is-unlimited .balance-amount { color:var(--violet-2); }
.balance-caption { color:var(--text-3); font-size:12px; margin-top:6px; }
.balance-actions { margin-top:14px; display:flex; gap:8px; justify-content:flex-end; }

.account-grid {
  display:grid; gap:18px;
  grid-template-columns: repeat(3, 1fr);
  margin-bottom:32px;
}
@media (max-width:1024px) {
  .account-grid { grid-template-columns: 1fr; }
}
.account-tile {
  background:var(--bg-1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:24px 22px;
  display:flex; flex-direction:column;
}
.tile-head { display:flex; align-items:flex-start; gap:14px; margin-bottom:18px; }
.tile-num {
  flex-shrink:0;
  width:32px; height:32px; border-radius:10px;
  background:var(--mint-bg); color:var(--mint-2);
  display:grid; place-items:center;
  font-family:var(--font-display); font-weight:700; font-size:15px;
  border:1px solid rgba(45,212,191,.3);
}
.tile-title {
  font-family:var(--font-display); font-weight:700;
  font-size:18px; letter-spacing:-.015em;
  margin:0 0 2px;
}
.tile-sub { color:var(--text-3); font-size:12.5px; margin:0; }
.tile-foot { color:var(--text-3); font-size:12px; margin:14px 0 0; }
.tile-foot a { color:var(--mint-2); text-decoration:none; }
.tile-empty { color:var(--text-2); font-size:14px; margin:0; }

.redeem-form { display:flex; flex-direction:column; gap:12px; }
.redeem-input {
  width:100%;
  padding:14px 16px;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--r);
  color:var(--text-1);
  font-size:14px;
  letter-spacing:.04em;
  font-variant-numeric:tabular-nums;
  text-transform:uppercase;
}
.redeem-input::placeholder { color:var(--text-4); letter-spacing:.04em; }
.redeem-input:focus { outline:none; border-color:var(--mint); box-shadow:0 0 0 3px rgba(45,212,191,.15); }

.tile-actions { display:flex; flex-direction:column; gap:8px; }
.tile-link {
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 14px; border-radius:var(--r);
  background:var(--bg-2); border:1px solid var(--border);
  text-decoration:none; color:var(--text-1);
  transition:border-color .2s var(--ease), background .2s var(--ease);
}
.tile-link:hover { border-color:var(--border-2); background:var(--bg-3); }
.tile-link-label { font-weight:500; font-size:14px; }
.tile-link-cost { color:var(--mint-2); font-size:12px; font-family:var(--font-mono); }

.tile-cta {
  display:flex; align-items:center; gap:14px;
  padding:14px 16px; border-radius:var(--r);
  background:var(--bg-2); border:1px solid var(--border);
  text-decoration:none; color:var(--text-1);
  margin-bottom:10px;
  transition:border-color .2s var(--ease);
}
.tile-cta:hover { border-color:var(--border-2); }
.tile-cta:last-child { margin-bottom:0; }
.tile-cta svg { width:20px; height:20px; flex-shrink:0; color:var(--text-2); }
.tile-cta strong { display:block; font-weight:600; font-size:14px; color:var(--text-1); }
.tile-cta small { display:block; font-size:11.5px; color:var(--text-3); margin-top:2px; }
.tile-cta-mint { border-color:rgba(45,212,191,.25); background:linear-gradient(135deg,rgba(45,212,191,.06),var(--bg-2)); }
.tile-cta-mint svg { color:var(--mint-2); }

/* Pricing strip */
.section-head {
  display:flex; justify-content:space-between; align-items:baseline;
  margin-bottom:16px; gap:12px;
}
.section-head h3 {
  font-family:var(--font-display); font-weight:700;
  font-size:18px; letter-spacing:-.015em; margin:0;
}
.section-head span { color:var(--text-3); font-size:12.5px; }
.account-pricing { margin-bottom:32px; }
.pricing-grid {
  display:grid; gap:10px;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}
.pricing-cell {
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r);
  padding:14px 16px;
}
.pricing-cell-name { font-size:12px; font-weight:600; color:var(--text-3); text-transform:uppercase; letter-spacing:.06em; margin-bottom:8px; }
.pricing-cell-amount { font-family:var(--font-display); font-size:24px; font-weight:700; color:var(--mint-2); letter-spacing:-.02em; }
.pricing-cell-amount small { font-size:11px; font-weight:500; color:var(--text-3); letter-spacing:.04em; margin-left:4px; text-transform:uppercase; }
.pricing-cell-unit { color:var(--text-3); font-size:11.5px; margin-top:4px; }

.account-history { margin-bottom:32px; }
.account-history-list { display:flex; flex-direction:column; gap:8px; }
.account-history-row {
  display:grid; grid-template-columns: minmax(150px, auto) 1fr minmax(120px, auto);
  gap:16px; align-items:center;
  padding:12px 16px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r);
}
@media (max-width:640px) {
  .account-history-row { grid-template-columns: 1fr; gap:6px; }
}
.account-history-meta { display:flex; flex-direction:column; gap:4px; }
.account-history-when { font-size:11.5px; color:var(--text-3); font-family:var(--font-mono); }
.account-history-desc { color:var(--text-1); font-size:13px; line-height:1.5; }
.account-history-cost { text-align:right; font-family:var(--font-mono); font-size:13px; color:var(--rose); }
.account-history-cost small { display:block; color:var(--text-3); font-size:11px; margin-top:2px; }

/* =============================================================
   v4.8.3 — Visual fixes
   ============================================================= */

/* Toolkit history sidebar (was completely unstyled) */
.toolkit-history-shell {
  padding:0;
  display:flex; flex-direction:column;
  min-height:560px; max-height:calc(100vh - 160px);
  overflow:hidden;
}
.toolkit-history-header {
  padding:18px 18px 14px;
  border-bottom:1px solid var(--border);
  display:flex; flex-direction:column; gap:10px;
}
.toolkit-history-header h2 {
  font-family:var(--font-display); font-weight:700;
  font-size:18px; letter-spacing:-.015em;
  margin:0; color:var(--text-1);
}
.toolkit-history-header .eyebrow {
  font-size:10px; color:var(--mint-2);
  letter-spacing:.1em; text-transform:uppercase;
  font-weight:700;
}
.toolkit-history-mobile-back {
  display:none; align-items:center; gap:6px;
  background:transparent; border:none; color:var(--text-2);
  font-size:13px; cursor:pointer; padding:0;
}
.toolkit-history-mobile-back-icon { font-size:16px; }
.toolkit-history-filters {
  display:flex; gap:4px; padding:4px;
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:10px;
  margin-top:4px;
}
.history-filter-button {
  flex:1; padding:6px 10px;
  background:transparent; border:none;
  border-radius:7px;
  color:var(--text-3); font-size:11.5px; font-weight:600;
  cursor:pointer;
  transition:color .15s var(--ease), background .15s var(--ease);
  text-transform:uppercase; letter-spacing:.04em;
}
.history-filter-button:hover { color:var(--text-1); }
.history-filter-button.is-active {
  background:var(--mint-bg); color:var(--mint-2);
}

.toolkit-history-list {
  flex:1; overflow-y:auto;
  padding:14px 14px 18px;
  display:flex; flex-direction:column; gap:10px;
}
.toolkit-history-list::-webkit-scrollbar { width:6px; }
.toolkit-history-list::-webkit-scrollbar-thumb { background:var(--border-2); border-radius:3px; }

.history-empty {
  text-align:center; padding:32px 16px;
  color:var(--text-3);
}
.history-empty h3 {
  font-family:var(--font-display); font-weight:700;
  font-size:15px; margin:0 0 8px; color:var(--text-2);
}
.history-empty p { font-size:12.5px; line-height:1.55; margin:0; }

.history-row {
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:10px;
  overflow:hidden;
}
.history-row[hidden] { display:none !important; }
.history-row-summary,
.history-row-summary-expandable {
  display:flex !important;
  flex-direction:column !important;
  gap:8px !important;
  width:100%; text-align:left;
  background:transparent; border:none; color:inherit;
  padding:12px 32px 12px 14px; cursor:pointer;
  font-family:inherit;
  position:relative;
  align-items:stretch !important;
}
.history-row-summary:hover { background:rgba(255,255,255,.03); }
.history-row-cell {
  display:flex !important; flex-direction:column !important; gap:3px;
  min-width:0;
  width:100%;
}
.history-row-label {
  display:block;
  font-size:9.5px; font-weight:700;
  color:var(--text-3); text-transform:uppercase;
  letter-spacing:.08em;
  margin:0; padding:0;
}
.history-row-value {
  display:block;
  color:var(--text-1); font-size:12.5px;
  line-height:1.5; word-break:break-all;
  margin:0; padding:0;
}
.history-row-mono { font-family:var(--font-mono); font-size:11.5px; }
.history-row-time { color:var(--text-2); font-family:var(--font-mono); font-size:11px; }
.history-row-key { color:var(--text-2); }
.history-row-code { color:var(--mint-2); font-weight:600; }
.history-row-code-tone-warn { color:var(--amber); }
.history-row-code-tone-error { color:var(--rose); }
.history-row-meta {
  display:inline-block; margin-top:4px;
  font-size:10px; color:var(--text-3);
  padding:1px 6px; background:var(--bg-3); border-radius:4px;
}
.history-row-toggle-indicator {
  position:absolute; right:10px; top:14px;
  width:14px; height:14px;
  background:transparent;
}
.history-row-toggle-indicator::after {
  content:'▸'; color:var(--text-3); font-size:11px;
  transition:transform .2s var(--ease);
  display:block;
}
.history-row-summary[aria-expanded="true"] .history-row-toggle-indicator::after {
  transform:rotate(90deg);
}

/* History pagination controls */
.history-pager {
  display:flex; align-items:center; justify-content:space-between;
  gap:6px; padding:10px 14px;
  border-top:1px solid var(--border);
  background:var(--bg-2);
  margin-top:auto;
  flex-shrink:0;
}
.history-pager-btn {
  display:inline-grid; place-items:center;
  width:28px; height:28px; border-radius:7px;
  background:var(--bg-3); border:1px solid var(--border);
  color:var(--text-2); cursor:pointer;
  font-size:14px;
  transition:background .15s var(--ease), color .15s var(--ease);
}
.history-pager-btn:hover:not(:disabled) { background:var(--bg-4); color:var(--text-1); }
.history-pager-btn:disabled { opacity:.35; cursor:not-allowed; }
.history-pager-info {
  font-size:11px; color:var(--text-3);
  font-family:var(--font-mono);
}
.history-pager-info b { color:var(--text-1); font-weight:600; }
.history-row-details {
  border-top:1px solid var(--border);
  padding:10px 12px;
  background:var(--bg-2);
  display:flex; flex-direction:column; gap:10px;
}
.history-detail-block {
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:8px; padding:8px 10px;
}
.history-detail-title {
  display:flex; align-items:center; gap:6px;
  margin-bottom:6px; font-size:11px; color:var(--text-3);
}
.history-detail-key { font-family:var(--font-mono); color:var(--text-1); font-weight:600; }
.history-detail-grid {
  display:grid; gap:4px;
  font-size:11px; color:var(--text-2);
  font-family:var(--font-mono); word-break:break-all;
}
.shadow-badge {
  font-size:9px; padding:1px 5px; border-radius:4px;
  background:var(--violet-bg); color:var(--violet-2);
  font-weight:700; letter-spacing:.04em;
}

/* Toolkit layout: widen sidebar slightly, keep main column comfortable */
.toolkit-layout { grid-template-columns: minmax(0, 1fr) 340px; }

/* Database log list (was completely unstyled) */
.database-log-list { display:flex; flex-direction:column; gap:8px; margin-top:16px; }
.database-log-row {
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:10px; overflow:hidden;
}
.database-log-summary {
  display:grid;
  grid-template-columns: minmax(140px, 0.9fr) minmax(180px, 1.2fr) minmax(160px, 1fr) minmax(180px, 1.6fr);
  gap:14px; padding:12px 14px;
  cursor:pointer; list-style:none;
  align-items:start;
}
.database-log-summary::-webkit-details-marker { display:none; }
.database-log-summary::marker { display:none; }
.database-log-row[open] .database-log-summary { background:var(--bg-2); border-bottom:1px solid var(--border); }
.database-log-summary > div { display:flex; flex-direction:column; gap:3px; min-width:0; }
.database-log-summary > div > span:nth-of-type(2) {
  color:var(--text-1); font-size:12.5px; line-height:1.45;
  word-break:break-all; font-family:var(--font-mono);
}
.database-log-summary > div > small {
  color:var(--text-3); font-size:11px;
}
.database-log-label {
  font-size:9.5px; font-weight:700;
  color:var(--text-3); text-transform:uppercase;
  letter-spacing:.08em;
}
.database-log-details {
  padding:14px;
  background:var(--bg-2);
  display:flex; flex-direction:column; gap:12px;
}
.database-detail-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:10px;
}
.database-detail-item {
  display:flex; flex-direction:column; gap:4px;
  padding:8px 10px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:8px;
  min-width:0;
}
.database-detail-wide { grid-column:1 / -1; }
.database-detail-item span:not(.database-log-label),
.database-mono {
  font-size:12px; color:var(--text-1);
  font-family:var(--font-mono); word-break:break-all;
}
.database-mono {
  display:block; padding:0;
}
.database-result-stack {
  display:flex; flex-direction:column; gap:8px;
  padding-top:8px; border-top:1px solid var(--border);
}
@media (max-width:780px) {
  .database-log-summary { grid-template-columns: 1fr; }
}

/* Role checkbox pill (Users admin pending verifications) */
.role-pill {
  display:flex; align-items:center; gap:8px;
  padding:8px 12px;
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:10px;
  font-size:12.5px; color:var(--text-1);
  cursor:pointer;
  transition:border-color .15s var(--ease), background .15s var(--ease);
}
.role-pill:hover { border-color:var(--border-2); }
.role-pill input[type="checkbox"] {
  appearance:none; -webkit-appearance:none;
  width:16px; height:16px;
  background:var(--bg-3); border:1.5px solid var(--border-2);
  border-radius:4px;
  cursor:pointer; flex-shrink:0;
  position:relative;
  transition:background .15s var(--ease), border-color .15s var(--ease);
}
.role-pill input[type="checkbox"]:checked {
  background:var(--mint); border-color:var(--mint);
}
.role-pill input[type="checkbox"]:checked::after {
  content:'✓'; position:absolute;
  inset:0; display:grid; place-items:center;
  color:#001a14; font-size:11px; font-weight:900;
}
.role-pill:has(input:checked) {
  background:var(--mint-bg); border-color:rgba(45,212,191,.35);
}
.role-pill small { color:var(--violet-2); font-size:11px; }

/* =============================================================
   Toolkit page — hero + channels + composer + how-it-works
   All composer + chat input elements were unstyled before.
   ============================================================= */

/* Hero banner above the chat shell */
.toolkit-hero {
  display:grid;
  grid-template-columns: 1fr auto;
  gap:24px; align-items:center;
  padding:22px 24px;
  margin:0 0 18px;
  background:linear-gradient(135deg, rgba(45,212,191,.08), rgba(167,139,250,.06));
  border:1px solid var(--border-2);
  border-radius:var(--r-lg);
}
.toolkit-hero h1 {
  font-family:var(--font-display); font-weight:700;
  font-size:28px; letter-spacing:-.025em; line-height:1.15;
  margin:8px 0 6px; color:var(--text-1);
}
.toolkit-hero p {
  color:var(--text-2); font-size:13.5px; line-height:1.55;
  margin:0; max-width:560px;
}
.toolkit-hero .eyebrow { margin:0; }
.toolkit-balance-pill {
  display:flex; flex-direction:column; align-items:flex-end;
  gap:6px; padding:14px 18px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r);
  min-width:180px;
}
.toolkit-balance-pill .balance-label {
  font-size:10px; font-weight:700; color:var(--text-3);
  text-transform:uppercase; letter-spacing:.08em;
}
.toolkit-balance-pill .balance-value {
  font-family:var(--font-display); font-weight:700;
  font-size:26px; color:var(--mint-2); letter-spacing:-.02em;
  line-height:1;
}
.toolkit-balance-pill .balance-value.is-unlimited { color:var(--violet-2); }
.toolkit-balance-pill .balance-value.is-empty { color:var(--amber); }
.toolkit-balance-pill a {
  font-size:11.5px; color:var(--mint-2); text-decoration:none;
  margin-top:4px; padding:4px 8px;
  background:var(--mint-bg); border-radius:6px;
}
.toolkit-balance-pill a:hover { background:var(--mint-bg-2); }
@media (max-width:780px) {
  .toolkit-hero { grid-template-columns: 1fr; }
  .toolkit-balance-pill { align-items:flex-start; }
}

/* Three channel cards (Web / API / Telegram) */
.toolkit-channels {
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
  margin:0 0 22px;
}
@media (max-width:880px) {
  .toolkit-channels { grid-template-columns: 1fr; }
}
.channel-card {
  position:relative;
  display:flex; flex-direction:column; gap:10px;
  padding:18px 20px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r-lg);
  transition:border-color .2s var(--ease), transform .2s var(--ease);
}
.channel-card:hover { border-color:var(--border-2); }
.channel-card.is-active {
  border-color:rgba(45,212,191,.4);
  background:linear-gradient(135deg, rgba(45,212,191,.05), var(--bg-1));
  box-shadow:0 0 0 1px rgba(45,212,191,.15);
}
.channel-card-head {
  display:flex; align-items:center; gap:12px;
}
.channel-card-icon {
  width:38px; height:38px; border-radius:10px;
  display:grid; place-items:center;
  background:var(--bg-3); color:var(--text-2);
  flex-shrink:0;
}
.channel-card-icon svg { width:18px; height:18px; }
.channel-card.is-active .channel-card-icon {
  background:linear-gradient(135deg, var(--mint), var(--mint-2));
  color:#001a14;
}
.channel-card.is-api .channel-card-icon { background:linear-gradient(135deg, var(--violet), var(--violet-2)); color:#0c0117; }
.channel-card.is-telegram .channel-card-icon { background:linear-gradient(135deg, #229ED9, #5ec4ed); color:#001a23; }
.channel-card h3 {
  font-family:var(--font-display); font-weight:700;
  font-size:15px; margin:0; letter-spacing:-.015em;
  color:var(--text-1);
}
.channel-card p {
  color:var(--text-2); font-size:12.5px; line-height:1.5;
  margin:0;
}
.channel-card-meta {
  display:flex; gap:10px; align-items:center;
  margin-top:auto; padding-top:8px;
  border-top:1px solid var(--border);
}
.channel-card-status {
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; font-weight:600; color:var(--mint-2);
  padding:3px 8px; background:var(--mint-bg);
  border-radius:6px;
}
.channel-card-link {
  font-size:12px; color:var(--text-2); text-decoration:none;
  margin-left:auto;
}
.channel-card-link:hover { color:var(--mint-2); }
.channel-card-link::after { content:' →'; }

/* Sample buttons (one-click try) */
.toolkit-samples {
  display:flex; gap:10px; flex-wrap:wrap;
  padding:14px 16px;
  background:var(--bg-1); border:1px dashed var(--border-2);
  border-radius:var(--r);
  margin:0 0 18px;
}
.toolkit-samples .samples-label {
  font-size:11px; font-weight:700; color:var(--text-3);
  text-transform:uppercase; letter-spacing:.08em;
  align-self:center; margin-right:6px;
}
.sample-btn {
  padding:6px 12px; border-radius:8px;
  background:var(--bg-2); border:1px solid var(--border);
  color:var(--text-1); font-size:12px; cursor:pointer;
  font-family:var(--font-mono);
  transition:border-color .15s var(--ease), background .15s var(--ease);
}
.sample-btn:hover { border-color:var(--mint); background:var(--mint-bg); color:var(--mint-2); }

/* Composer (input row) — was completely unstyled */
.cid-form.chat-form { margin-top:18px; padding-top:18px; border-top:1px solid var(--border); }
.attachment-input { display:none; }
.attachment-list {
  display:flex; gap:6px; flex-wrap:wrap;
  margin-bottom:8px; min-height:0;
}
.attachment-list:empty { margin-bottom:0; }
.attachment-pill {
  display:inline-flex; align-items:center; gap:4px;
  padding:4px 8px; background:var(--mint-bg);
  color:var(--mint-2); border:1px solid rgba(45,212,191,.25);
  border-radius:6px;
  font-size:11px; font-family:var(--font-mono);
}

.chat-composer {
  position:relative;
  display:grid;
  grid-template-columns: auto 1fr auto;
  gap:10px; align-items:end;
  padding:12px;
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:var(--r);
  transition:border-color .15s var(--ease);
}
.chat-composer:focus-within { border-color:var(--mint); box-shadow:0 0 0 3px rgba(45,212,191,.1); }
.chat-composer.is-dragover { border-color:var(--mint); background:var(--mint-bg); }

.composer-side-stack {
  display:flex; flex-direction:column; gap:6px;
  flex-shrink:0;
}
.composer-icon-button {
  display:inline-grid; place-items:center;
  width:36px; height:36px; border-radius:10px;
  background:var(--bg-3); border:1px solid var(--border);
  color:var(--text-2);
  font-size:18px; font-weight:600;
  cursor:pointer;
  transition:background .15s var(--ease), color .15s var(--ease), border-color .15s var(--ease);
  text-decoration:none;
}
.composer-icon-button:hover { background:var(--bg-4); color:var(--text-1); border-color:var(--border-2); }
.composer-icon-button.send-icon-button {
  background:linear-gradient(135deg, var(--mint), var(--mint-2));
  border-color:transparent; color:#001a14;
  box-shadow:0 4px 14px rgba(45,212,191,.25);
}
.composer-icon-button.send-icon-button:hover { transform:translateY(-1px); }
.send-arrow { font-size:18px; font-weight:900; }

.diagnostic-toggle-button {
  padding:6px 10px; border-radius:8px;
  background:var(--bg-3); border:1px solid var(--border);
  color:var(--text-3); font-size:10.5px; font-weight:700;
  text-transform:uppercase; letter-spacing:.06em;
  cursor:pointer;
  transition:all .15s var(--ease);
}
.diagnostic-toggle-button[aria-pressed="true"] {
  background:var(--amber-bg); color:var(--amber);
  border-color:rgba(251,191,36,.3);
}

.chat-textarea {
  resize:none; min-height:44px; max-height:200px;
  background:transparent; border:none; outline:none;
  color:var(--text-1); font-family:inherit; font-size:14px;
  line-height:1.55; padding:10px 4px;
  width:100%;
}
.chat-textarea::placeholder { color:var(--text-3); }

.composer-drop-hint {
  position:absolute; inset:0;
  display:none;
  flex-direction:column; align-items:center; justify-content:center;
  background:rgba(45,212,191,.08); backdrop-filter:blur(2px);
  border:2px dashed var(--mint);
  border-radius:var(--r);
  pointer-events:none; z-index:2;
}
.chat-composer.is-dragover .composer-drop-hint { display:flex; }
.composer-drop-title {
  font-family:var(--font-display); font-weight:700;
  font-size:16px; color:var(--mint-2); margin-bottom:4px;
}
.composer-drop-copy {
  font-size:12px; color:var(--text-2);
  max-width:300px; text-align:center;
}

/* Chat result blocks */
.key-result-block {
  display:flex; flex-direction:column; gap:6px;
  padding:12px 14px; margin-top:8px;
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:10px;
  font-size:13px;
}
.key-result-block > div { line-height:1.55; }
.key-result-block strong { color:var(--text-1); font-weight:600; margin-right:4px; }
.key-result-block.result-tone-success { border-color:rgba(52,211,153,.3); }
.chat-result-pair { display:flex; gap:8px; align-items:baseline; }
.chat-result-label { font-size:11px; color:var(--text-3); text-transform:uppercase; letter-spacing:.06em; min-width:90px; }
.chat-result-value { color:var(--text-1); font-size:13px; word-break:break-all; }
.chat-response-meta {
  font-size:11px; color:var(--text-3); margin-top:8px;
  padding-top:8px; border-top:1px solid var(--border);
}
.chat-user-text { font-family:var(--font-mono); font-size:13px; word-break:break-all; color:var(--text-1); }
.chat-attachment-list { display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.attachment-preview-card {
  position:relative;
  border-radius:10px;
  overflow:hidden;
  background:var(--bg-3);
  border:1px solid var(--border-2);
  width:160px; height:120px;
  box-shadow:0 4px 14px rgba(0,0,0,.35);
  transition:transform .2s var(--ease), border-color .2s var(--ease);
}
.attachment-preview-card:hover { transform:translateY(-2px); border-color:var(--mint); }
.attachment-preview-card-compact { width:56px; height:56px; }
.attachment-preview-image {
  display:block;
  width:100%; height:100%;
  object-fit:cover;
  background:var(--bg-2);
}
.attachment-preview-card::after {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.55));
  pointer-events:none;
}
.attachment-preview-card[title]::before {
  content:attr(title);
  position:absolute; bottom:6px; left:8px; right:8px;
  font-size:10.5px; color:#fff;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  z-index:1; font-family:var(--font-mono);
  text-shadow:0 1px 2px rgba(0,0,0,.6);
}
.attachment-preview-card-compact::after, .attachment-preview-card-compact::before { display:none; }

/* Loading: 3-dot bounce while waiting for OCR / CID response */
.chat-loading {
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 6px;
}
.chat-loading > span {
  width:8px; height:8px; border-radius:50%;
  background:var(--mint-2);
  animation:chat-dot 1.2s ease-in-out infinite;
}
.chat-loading > span:nth-child(2) { animation-delay:.2s; }
.chat-loading > span:nth-child(3) { animation-delay:.4s; }
@keyframes chat-dot {
  0%, 80%, 100% { opacity:.25; transform:scale(.7); }
  40% { opacity:1; transform:scale(1.1); }
}
.chat-loading-label {
  font-size:12.5px; color:var(--text-2);
  display:flex; align-items:center; gap:10px;
  padding-bottom:6px;
}
.chat-loading-label svg {
  width:14px; height:14px;
  animation:spin 1.2s linear infinite;
  color:var(--mint-2);
}
@keyframes spin { to { transform:rotate(360deg); } }

/* Slide-in animation for new chat messages */
.chat-message-enter { animation:chat-msg-in .3s var(--ease-out); }
@keyframes chat-msg-in {
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}

/* Success pulse when result comes back */
.chat-bubble-resolve { animation:chat-resolve .55s var(--ease-out); }
@keyframes chat-resolve {
  0%   { box-shadow:0 0 0 0 rgba(45,212,191,.5); }
  60%  { box-shadow:0 0 0 8px rgba(45,212,191,0); }
  100% { box-shadow:0 0 0 0 rgba(45,212,191,0); }
}

/* Composer disable feedback while submitting */
.chat-composer.is-submitting {
  border-color:var(--mint);
  box-shadow:0 0 0 3px rgba(45,212,191,.12);
}
.chat-composer.is-submitting .composer-icon-button.send-icon-button {
  animation:send-pulse 1s ease-in-out infinite;
}
@keyframes send-pulse {
  0%, 100% { transform:scale(1); box-shadow:0 4px 14px rgba(45,212,191,.25); }
  50%      { transform:scale(.92); box-shadow:0 4px 18px rgba(45,212,191,.55); }
}

/* Disabled send while no content */
.composer-icon-button.send-icon-button:disabled {
  opacity:.4; cursor:not-allowed;
  background:var(--bg-3); color:var(--text-3);
  box-shadow:none;
}

/* "Photos attached" user bubble — make caption pop */
.chat-message-user .chat-bubble {
  max-width:280px;
}
.chat-message-user .chat-user-text {
  font-size:11px; color:var(--mint-2);
  text-transform:uppercase; letter-spacing:.08em;
  font-weight:700;
  margin-bottom:6px;
}
/* CID success card with a prominent copy button */
.cid-result-card {
  display:flex; flex-direction:column;
  gap:10px;
  padding:16px 18px;
  border:1px solid rgba(45,212,191,.35);
  background:linear-gradient(135deg, rgba(45,212,191,.06), var(--bg-2));
}
.cid-result-meta {
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  font-size:12px; color:var(--text-2);
}
.cid-result-iid {
  font-size:12.5px; color:var(--text-2); line-height:1.5;
  padding-bottom:6px; border-bottom:1px dashed var(--border);
}
.cid-result-iid .mono { color:var(--text-1); }
.cid-result-output {
  display:grid; grid-template-columns: 1fr auto;
  gap:12px; align-items:center;
  padding:10px 12px;
  background:var(--bg-1); border:1px solid var(--border-2);
  border-radius:10px;
}
.cid-result-label {
  grid-column: 1 / -1;
  font-size:10.5px; font-weight:700;
  color:var(--mint-2); text-transform:uppercase;
  letter-spacing:.1em;
}
.cid-result-value {
  font-family:var(--font-mono); font-size:14px;
  color:var(--mint-2); font-weight:600;
  word-break:break-all; line-height:1.45;
  cursor:pointer;
  padding:4px 6px; border-radius:5px;
  transition:background .15s var(--ease);
}
.cid-result-value:hover { background:var(--mint-bg); }
/* The CID block already has a big Copy button next to it; suppress the inline ⧉/✓ pill that
   .copyable-value renders so the card stays readable. */
.cid-result-value::after { content:none !important; }
.cid-result-value.is-copied { background:var(--mint-bg-2); animation:copy-pop .55s var(--ease-out); }
.cid-copy-btn {
  white-space:nowrap;
  font-size:12.5px; padding:8px 14px;
  display:inline-flex; align-items:center; gap:6px;
}
.cid-copy-btn svg { width:14px; height:14px; }
.cid-copy-btn.is-copied {
  background:var(--green); color:#001a14;
  animation:copy-pop .55s var(--ease-out);
}
.cid-copy-btn.is-copied span::after { content:' ✓'; }
@media (max-width:600px) {
  .cid-result-output { grid-template-columns: 1fr; }
}

.copyable-value {
  cursor:pointer;
  text-decoration:underline; text-decoration-style:dotted; text-underline-offset:3px;
  padding:2px 6px; border-radius:5px;
  transition:background .15s var(--ease), color .15s var(--ease);
  position:relative;
}
.copyable-value:hover {
  color:var(--mint-3);
  background:var(--mint-bg);
}
.copyable-value::after {
  content:'⧉';
  font-size:.85em;
  margin-left:6px;
  opacity:.5;
  transition:opacity .15s var(--ease);
}
.copyable-value:hover::after { opacity:1; color:var(--mint-2); }
.copyable-value.is-copied {
  background:var(--mint);
  color:#001a14 !important;
  text-decoration:none;
  animation:copy-pop .55s var(--ease-out);
}
.copyable-value.is-copied::after { content:'✓ Copied'; opacity:1; color:#001a14; font-weight:700; margin-left:8px; font-size:.85em; }
@keyframes copy-pop {
  0%   { transform:scale(1); }
  40%  { transform:scale(1.05); box-shadow:0 0 0 6px rgba(45,212,191,.25); }
  100% { transform:scale(1); box-shadow:0 0 0 0 rgba(45,212,191,0); }
}
.duplicate-badge { font-size:10px; padding:1px 5px; border-radius:4px; background:var(--amber-bg); color:var(--amber); margin-left:6px; font-weight:700; }

/* How it works section */
.toolkit-how {
  margin-top:24px; padding:22px 24px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r-lg);
}
.toolkit-how h3 {
  font-family:var(--font-display); font-weight:700;
  font-size:16px; margin:0 0 16px; color:var(--text-1);
}
.toolkit-how-steps {
  display:grid; gap:14px;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  list-style:none; padding:0; margin:0;
  counter-reset:howstep;
}
.toolkit-how-steps li {
  position:relative; padding:14px 16px 14px 50px;
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:var(--r);
  font-size:13px; color:var(--text-2); line-height:1.55;
}
.toolkit-how-steps li::before {
  counter-increment:howstep; content:counter(howstep);
  position:absolute; left:14px; top:14px;
  width:24px; height:24px; border-radius:50%;
  background:var(--mint-bg); color:var(--mint-2);
  display:grid; place-items:center;
  font-family:var(--font-display); font-weight:700; font-size:12px;
  border:1px solid rgba(45,212,191,.3);
}
.toolkit-how-steps li b { color:var(--text-1); font-weight:600; display:block; margin-bottom:4px; }

/* Redeem codes admin page */
.redeem-admin-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
  gap:16px;
  align-items:end;
}
.redeem-quick-presets {
  display:flex; gap:8px; flex-wrap:wrap; align-items:center;
  margin-top:16px; padding-top:14px;
  border-top:1px solid var(--border);
}
.redeem-presets-label {
  font-size:11px; font-weight:700; color:var(--text-3);
  text-transform:uppercase; letter-spacing:.06em; margin-right:6px;
}
.redeem-filter-tabs {
  display:flex; gap:6px; padding:4px;
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:10px; margin-bottom:16px;
}
.redeem-filter-tab {
  flex:1; text-align:center; padding:8px 12px;
  border-radius:7px; text-decoration:none;
  color:var(--text-3); font-size:12.5px; font-weight:600;
  transition:color .15s var(--ease), background .15s var(--ease);
}
.redeem-filter-tab:hover { color:var(--text-1); }
.redeem-filter-tab.is-active { background:var(--mint-bg); color:var(--mint-2); }
.redeem-filter-tab span {
  display:inline-block; margin-left:6px;
  padding:1px 7px; border-radius:50px;
  background:var(--bg-3); color:var(--text-2);
  font-family:var(--font-mono); font-size:10.5px;
}
.redeem-filter-tab.is-active span { background:rgba(45,212,191,.2); color:var(--mint-2); }

.redeem-table-wrap { overflow-x:auto; }
.redeem-table { width:100%; border-collapse:collapse; font-size:13px; }
.redeem-table thead th {
  text-align:left; padding:10px 12px;
  background:var(--bg-2); color:var(--text-3);
  font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.06em;
  border-bottom:1px solid var(--border);
}
.redeem-table tbody td {
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  color:var(--text-1);
  vertical-align:middle;
}
.redeem-table tbody tr:hover { background:rgba(255,255,255,.02); }
.redeem-table tr.is-used td { opacity:.65; }
.redeem-table tr.is-used td strong { color:var(--text-3) !important; }
.redeem-code-cell {
  display:inline-block; padding:4px 8px;
  background:var(--bg-3); border:1px solid var(--border-2);
  border-radius:6px;
  font-family:var(--font-mono); font-size:11px;
  color:var(--mint-2); letter-spacing:.04em;
  max-width:240px; overflow:hidden; text-overflow:ellipsis;
  vertical-align:middle; margin-right:6px;
}
.redeem-table-meta { color:var(--text-2); font-size:12px; }
.redeem-table-meta small { color:var(--text-3); font-size:11px; display:block; }
.btn-copy {
  display:inline-grid; place-items:center;
  width:24px; height:24px; border-radius:5px;
  background:var(--bg-3); border:1px solid var(--border);
  color:var(--text-2); cursor:pointer;
  vertical-align:middle;
}
.btn-copy:hover { color:var(--mint-2); border-color:var(--border-2); }
.btn-copy svg { width:12px; height:12px; }

/* Dashboard role row (was collapsing to vertical letters) */
.role-row {
  display:grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  gap:10px; align-items:center;
  padding:10px 12px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:10px;
}
.role-row-name {
  color:var(--text-1); font-size:13px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.role-row-count {
  font-family:var(--font-mono); font-size:11px;
  color:var(--text-3); padding:2px 6px;
  background:var(--bg-3); border-radius:6px;
}

/* Hero polish */
.hero-clean { padding-top:48px; padding-bottom:32px; }
.hero-pricing {
  display:flex; gap:18px; flex-wrap:wrap; justify-content:center;
  margin-top:28px;
  padding:16px 22px;
  background:var(--bg-1); border:1px solid var(--border);
  border-radius:var(--r-lg);
  font-size:13px; color:var(--text-2);
  max-width:640px; margin-left:auto; margin-right:auto;
}
.hero-pricing b { color:var(--mint-2); font-family:var(--font-mono); font-weight:700; }

/* Nav divider */
.topnav-divider {
  display:inline-block;
  width:1px; height:18px;
  background:var(--border);
  margin:0 6px;
}
