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

:root {
  --link: #2563eb;
  --link-hover: #1d4ed8;
  --compact-space: 42px;
  --bg: #f7f8fb;
  --card: #ffffff;
  --muted: #6b7280;
  --text: #0f172a;
  --primary: #4f46e5;
  --primary-2: #06b6d4;
  --border: rgba(15,23,42,.08);
  --shadow: 0 18px 32px rgba(15,23,42,.08);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
}

a { color: inherit; text-decoration: none; }

.container {
  width: min(1120px, 92%);
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0;
  backdrop-filter: blur(12px);
  background: rgba(247,248,251,.9);
  border-bottom: 1px solid var(--border);
  z-index: 10;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 0;
}

.logo {
  font-weight: 700;
  letter-spacing: .5px;
  font-size: 20px;
}

.logo span { color: var(--primary-2); }

.nav {
  display: flex;
  gap: 22px;
  align-items: center;
}

.nav a {
  font-size: 14px;
  color: var(--muted);
}

.nav a.active,
.nav a:hover { color: var(--text); }

.nav a.ghost {
  padding: 6px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #ffffff;
}

.menu-btn {
  display: none;
  background: #ffffff;
  border: 1px solid var(--border);
  color: var(--text);
  padding: 6px 10px;
  border-radius: 8px;
}

.hero {
  padding: 80px 0 60px;
  background: radial-gradient(circle at top, rgba(79,70,229,.12), transparent 55%);
}

.hero.small { padding: 60px 0; }

.hero-inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 40px;
  align-items: center;
}

.eyebrow {
  color: var(--primary-2);
  font-weight: 600;
  margin-bottom: 12px;
}

.hero h1 { font-size: clamp(28px, 4vw, 48px); line-height: 1.1; }

.sub { margin-top: 14px; color: var(--muted); }

.cta-group { display: flex; gap: 12px; margin: 24px 0; flex-wrap: wrap; }

.btn {
  padding: 10px 20px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #ffffff;
  color: #111827;
  cursor: pointer;
  font-weight: 600;
  transition: all .2s ease;
}

.btn.primary {
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  border: none;
  color: #ffffff;
}

.btn.secondary {
  background: #f1f5f9;
  color: #1f2937;
  border: 1px solid rgba(15,23,42,.12);
}

.btn.ghost { background: #f1f5f9; color: #1f2937; }

.btn.danger {
  background: #ef4444;
  border: 1px solid #ef4444;
  color: #ffffff;
}

.btn.loading,
.btn[disabled] {
  opacity: .65;
  cursor: not-allowed;
  pointer-events: none;
}

.btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-soft);
}

.btn:active {
  transform: translateY(0);
  box-shadow: none;
}

.hero-badges { display: flex; gap: 12px; color: var(--muted); font-size: 13px; }

.hero-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 22px;
  box-shadow: var(--shadow);
}

.card-title { font-weight: 600; margin-bottom: 16px; }

.stats { display: flex; justify-content: space-between; margin-bottom: 18px; }

.stats h3 { font-size: 22px; }

.mini-chart { display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px; margin: 10px 0; }

.mini-chart span {
  display: block;
  height: 38px;
  background: linear-gradient(180deg, var(--primary), transparent);
  border-radius: 6px;
}

.section { padding: var(--compact-space) 0; }
.section.muted { background: #f1f5f9; }
.section-sub { color: var(--muted); margin-top: -12px; margin-bottom: 24px; }
.cta-section { background: #eef2ff; }

.section h2 { font-size: 28px; margin-bottom: 24px; }

.grid-4 { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.grid-2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; }

.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px;
}

.card h3 { margin-bottom: 10px; font-weight: 600; line-height:1.2; }

.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 20px; }
.step { background: var(--card); border-radius: 16px; padding: 18px; border: 1px solid var(--border); }
.step span { display: inline-flex; width: 32px; height: 32px; border-radius: 50%; background: var(--primary); align-items: center; justify-content: center; font-weight: 700; }

.table-wrap { overflow-x: auto; }

.table-wrap table { width: 100%; border-collapse: collapse; min-width: 560px; }

th, td { padding: 12px 10px; text-align: left; border-bottom: 1px solid var(--border); font-size: 14px; }

.status { padding: 3px 10px; border-radius: 10px; font-size: 11px; }
.tag { display: inline-flex; align-items: center; padding: 2px 8px; border-radius: 10px; font-size: 11px; }
.status.ok { background: rgba(34,197,94,.2); color: #34d399; }
.status.warn { background: rgba(251,191,36,.2); color: #fbbf24; }
.status.err { background: rgba(239,68,68,.2); color: #f87171; }

.tabs { background: var(--card); padding: 20px; border-radius: 16px; border: 1px solid var(--border); }
.tab-buttons { display: flex; gap: 8px; margin-bottom: 14px; }
.tab-buttons button {
  background: transparent; border: 1px solid var(--border); color: var(--muted); padding: 6px 12px; border-radius: 10px; cursor: pointer;
}
.tab-buttons button.active { color: var(--text); background: #eef2ff; border-color: rgba(79,70,229,.2); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }
pre { white-space: pre-wrap; font-size: 13px; color: #334155; background:#f8fafc; border:1px solid var(--border); padding:12px; border-radius:12px; }

.stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.trend.up { color: #34d399; }
.trend.down { color: #f87171; }

.pricing { position: relative; }
.pricing .price { font-size: 28px; margin: 10px 0; }
.pricing .price span { font-size: 14px; color: var(--muted); }
.pricing ul { list-style: none; color: var(--muted); display: grid; gap: 4px; margin: 12px 0 20px; }
.pricing.highlight { border: 1px solid var(--primary); box-shadow: 0 20px 40px rgba(99,102,241,.2); }
.badge { position: absolute; top: 16px; right: 16px; background: var(--primary); padding: 3px 10px; border-radius: 10px; font-size: 11px; }

.section-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }

.pill { padding: 3px 10px; background: rgba(255,255,255,.06); border-radius: 10px; font-size: 11px; }

.chart { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; align-items: end; height: 160px; margin-top: 10px; }
.chart span { background: linear-gradient(180deg, var(--primary), transparent); border-radius: 8px 8px 0 0; }

.chat-log { display: grid; gap: 12px; }
.chat-row { display: grid; gap: 4px; padding: 12px; background: #f1f5f9; border-radius: 12px; border: 1px solid var(--border); }
.chat-row .tag { background: #eef2ff; color: var(--text); width: fit-content; }

.auth { min-height: 100vh; display: grid; place-items: center; background: #f1f5f9; }
.auth-card { width: min(420px, 92%); background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 32px; box-shadow: var(--shadow); }
.auth-links { display: flex; justify-content: space-between; font-size: 11px; margin-top: 10px; color: var(--muted); }

.footer { padding: 32px 0; border-top: 1px solid var(--border); }
.footer-inner { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.footer-links { display: flex; gap: 14px; color: var(--muted); }
.muted { color: var(--muted); }

.form { display: grid; gap: 8px; }
input, textarea {
  background: #ffffff;
  border: 1px solid var(--border);
  padding: 10px 12px;
  border-radius: 10px;
  color: var(--text);
}

.accordion-item { border: 1px solid var(--border); border-radius: 12px; margin-bottom: 10px; overflow: hidden; }
.accordion-header {
  width: 100%; text-align: left; background: transparent; color: var(--text); border: none; padding: 12px 14px; cursor: pointer; font-weight: 600;
}
.accordion-body { padding: 0 14px 14px; color: var(--muted); display: none; }
.accordion-item.active .accordion-body { display: block; }

.cta-bar { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 20px; align-items: center; }

.budget { margin-top: 10px; }
.budget-bar { height: 10px; background: #e2e8f0; border-radius: 10px; overflow: hidden; }
.budget-bar span { display: block; height: 100%; background: linear-gradient(135deg, var(--primary), var(--primary-2)); }
.budget-meta { display: flex; justify-content: space-between; font-size: 11px; color: var(--muted); margin-top: 8px; }

.docs-layout { display: grid; grid-template-columns: 220px 1fr; gap: 20px; }
.docs-nav { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 16px; display: grid; gap: 8px; align-content: start; }
.docs-nav h4 { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; margin-top: 10px; }
.docs-nav a { padding: 8px 10px; border-radius: 10px; color: var(--muted); font-size: 13px; }
.docs-nav a.active, .docs-nav a:hover { background: #eef2ff; color: var(--text); }
.docs-content h2 { margin-bottom: 10px; }
.info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin: 16px 0; }
.info-grid div { background: #f1f5f9; border: 1px solid var(--border); border-radius: 12px; padding: 12px; }
.info-grid span { font-size: 11px; color: var(--muted); }
.info-grid strong { display: block; margin-top: 6px; font-size: 14px; color: var(--text); }

.layout { display: grid; grid-template-columns: 240px 1fr; gap: 24px; }
.sidebar { position: sticky; top: 96px; align-self: start; background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 16px; display: grid; gap: 8px; }
.sidebar h4 { font-size: 13px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 4px; }
.sidebar a { padding: 8px 10px; border-radius: 10px; color: var(--muted); font-size: 13px; }
.sidebar a.active, .sidebar a:hover { background: #eef2ff; color: var(--text); }
.breadcrumb { font-size: 11px; color: var(--muted); margin-bottom: 6px; }
.page-title { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 16px; }
.page-title h1 { font-size: 28px; }
.panel { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 20px; box-shadow: var(--shadow-soft); }


@media (max-width: 900px) {
  .docs-layout, .layout { grid-template-columns: 1fr; }
  .sidebar { position: static; }
}

@media (max-width: 860px) {
  .nav { display: none; }
  .menu-btn { display: inline-flex; }
  .nav.open { display: flex; flex-direction: column; gap: 12px; background: var(--card); position: absolute; right: 4%; top: 70px; padding: 12px; border-radius: 12px; }
}

.mobile-nav {
  display: none;
}

@media (max-width: 768px) {
  .header-inner { padding: 14px 0; }
  .hero { padding: 60px 0 40px; }
  .hero.small { padding: 40px 0; }
  .hero-inner { gap: 24px; }
  .cta-group { flex-direction: column; align-items: stretch; }
  .hero-badges { flex-wrap: wrap; }
  .grid-4, .grid-3, .grid-2, .stats-row { grid-template-columns: 1fr; }
  .section { padding: 40px 0; }
  .table-wrap table { min-width: 520px; }
  .footer-inner { align-items: flex-start; }
  .mobile-nav { display: grid; grid-template-columns: repeat(5, 1fr); gap: 4px; position: fixed; bottom: 12px; left: 50%; transform: translateX(-50%); background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 10px 12px; box-shadow: var(--shadow); z-index: 50; width: min(520px, 92%); }
  .mobile-nav a { text-align: center; font-size: 11px; color: var(--muted); }
  body { padding-bottom: 80px; }
}

.status-list { list-style: none; display: grid; gap: 8px; }
.status-list li { display: flex; justify-content: space-between; }
.list { margin-top: 10px; display: grid; gap: 4px; color: var(--muted); font-size: 13px; }
.score { margin-top: 8px; font-weight: 600; line-height:1.2; }
.chat-log { display: grid; gap: 12px; }
.chat-row { display: grid; gap: 4px; padding: 12px; background: #f1f5f9; border-radius: 12px; border: 1px solid var(--border); }
.chat-row .tag { background: #eef2ff; color: var(--text); width: fit-content; }


/* Visual polish: PC + Mobile */
:root {
  --link: #2563eb;
  --link-hover: #1d4ed8;
  --compact-space: 42px;
  --shadow-soft: 0 10px 24px rgba(15,23,42,.08);
  --shadow-hover: 0 18px 36px rgba(15,23,42,.12);
}

.card, .hero-card, .tabs { transition: transform .2s ease, box-shadow .2s ease; }
.card:hover, .hero-card:hover, .tabs:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.btn {
  transition: all .2s ease;
}

.btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-soft);
}

.nav a.active {
  font-weight: 600;
  position: relative;
}

.nav a.active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  border-radius: 10px;
}

.table-wrap table tr:hover {
  background: #f1f5f9;
}

input:focus, textarea:focus {
  outline: none;
  border-color: rgba(79,70,229,.4);
  box-shadow: 0 0 0 4px rgba(79,70,229,.12);
}

@media (max-width: 768px) {
  .btn { padding: 12px 18px; border-radius: 14px; }
  .card { padding: 18px; }
  .hero h1 { font-size: 28px; }
}


.filter-bar { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 12px; }
.filter-bar input, .filter-bar select { min-width: 140px; }

.table-actions { display:flex; justify-content: space-between; align-items:center; gap:12px; margin-bottom: 12px; flex-wrap: wrap; }
.filter-bar input, .filter-bar select { background:#fff; border:1px solid var(--border); padding:8px 10px; border-radius:10px; font-size:12px; }

.sticky-actions { position: sticky; top: 88px; background: var(--bg); padding: 8px 0; z-index: 5; }
.section-divider { margin: 24px 0; border-top: 1px dashed var(--border); }

.helper-note { background: #f1f5f9; border:1px dashed var(--border); padding: 12px; border-radius: 12px; color: var(--muted); font-size: 11px; }

label { margin-bottom: 4px; }

.chat-fab{position:fixed;right:22px;bottom:22px;width:62px;height:62px;animation:chatPulse 2s ease-in-out infinite;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 24px rgba(79,70,229,.35);z-index:999;cursor:pointer;font-size:22px;}
.chat-fab:hover{animation:chatBounce .25s ease-out forwards; box-shadow:0 18px 36px rgba(79,70,229,.55);}
.chat-panel{position:fixed;right:22px;bottom:96px;width:360px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 40px rgba(15,23,42,.2);overflow:hidden;display:none;z-index:999;}
.chat-panel.active{display:block;}
.chat-header{padding:12px 14px;border-bottom:1px solid var(--border);font-weight:600;}
.chat-body{padding:12px;max-height:360px;overflow:auto;background:#f8fafc;}
.chat-bubble{padding:10px 12px;border-radius:10px;margin-bottom:8px;font-size:14px;}
.chat-bubble.user{background:#e0e7ff;margin-left:40px;}
.chat-bubble.agent{background:#fff;border:1px solid var(--border);}
.chat-input{display:flex;gap:6px;padding:10px;border-top:1px solid var(--border);background:#fff;}
.chat-input input{flex:1;border:1px solid var(--border);border-radius:10px;padding:8px 10px;font-size:14px;}

.chat-marquee{padding:6px 10px;font-size:12px;color:#4f46e5;background:#eef2ff;border-bottom:1px solid var(--border);text-align:center;animation:blink 2s infinite;}
@keyframes blink{0%{opacity:1;}50%{opacity:.5;}100%{opacity:1;}}

.chat-tip{position:absolute;right:78px;bottom:12px;background:#111827;color:#fff;padding:6px 10px;border-radius:8px;font-size:16px;white-space:nowrap;opacity:0;transform:translateY(4px);transition:.2s;pointer-events:none;}
.chat-fab{position:fixed;right:22px;bottom:22px;width:62px;height:62px;animation:chatPulse 2s ease-in-out infinite;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 24px rgba(79,70,229,.35);z-index:999;cursor:pointer;font-size:22px;}
.chat-fab:hover{animation:chatBounce .25s ease-out forwards; box-shadow:0 18px 36px rgba(79,70,229,.55);}
.chat-fab:hover .chat-tip{opacity:1;transform:translateY(0);}
.chat-fab:hover{animation:chatBounce .25s ease-out forwards; box-shadow:0 18px 36px rgba(79,70,229,.55);}

.chat-fab{transition:transform .2s ease, box-shadow .2s ease; transform-origin:center;}

@keyframes chatBounce{0%{transform:translateY(0) scale(1);}50%{transform:translateY(-8px) scale(1.18);}100%{transform:translateY(-6px) scale(1.15);}}

@keyframes chatPulse{0%{transform:scale(1);box-shadow:0 12px 24px rgba(79,70,229,.35);}50%{transform:scale(1.04);box-shadow:0 16px 28px rgba(79,70,229,.45);}100%{transform:scale(1);box-shadow:0 12px 24px rgba(79,70,229,.35);}}

.chat-fab:hover + .chat-panel{display:block;}

.chat-panel:hover{display:block;}

.grid-6{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:1024px){.grid-6{grid-template-columns:repeat(3,1fr);}}
@media(max-width:768px){.grid-6{grid-template-columns:repeat(2,1fr);}}
.link{color:var(--link);font-weight:600;text-decoration:none;}

.model-filter{margin-bottom:16px;}
.model-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
@media(max-width:900px){.model-grid{grid-template-columns:1fr;}}
.model-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow-soft);display:grid;gap:10px;}
.model-head{display:flex;justify-content:space-between;align-items:center;}
.model-tags{display:flex;gap:6px;flex-wrap:wrap;}
.model-tags span{background:#f8fafc;border:1px solid var(--border);padding:4px 8px;border-radius:999px;font-size:12px;color:var(--muted);}
.model-meta{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:16px;}

.metric-grid .card{padding:18px;border-radius:16px;}
.metric-grid .card p{font-size:12px;color:var(--muted);margin-bottom:6px;}
.metric-grid .card h3{font-size:22px;line-height:1.1;}
.metric-grid .card .muted{font-size:12px;}

.module-grid .entry-card{display:flex;flex-direction:column;gap:6px;transition:transform .2s ease, box-shadow .2s ease;}
.module-grid .entry-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);}
.module-grid .entry-card h3{font-size:18px;}
.module-grid .entry-card p{font-size:12px;}

.metric-tick{animation:metricPop .35s ease;}
@keyframes metricPop{0%{transform:translateY(4px);opacity:.6;}100%{transform:translateY(0);opacity:1;}}

.sidebar-block{margin-top:16px;padding:12px;border:1px dashed var(--border);border-radius:12px;background:#f8fafc;}
.sidebar-block label{font-size:12px;color:var(--muted);display:block;margin-bottom:6px;}
.sidebar-block select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:#fff;font-size:12px;}


@media(max-width:900px){
.stat-item{padding:8px 0;border:none;background:transparent;}

.stat-small h3{font-size:16px;}
.stat-small p{font-size:11px;color:var(--muted);}

.stat-main{display:flex;flex-direction:column;gap:6px;}
.stat-main h3{font-size:26px;}
.stat-main p{font-size:12px;color:var(--muted);}
.stat-sub{margin-top:6px;align-self:flex-end;text-align:right;}
.stat-sub h3{font-size:16px;}
.stat-sub p{font-size:11px;color:var(--muted);}


.stat-today{margin-left:auto;text-align:right;}
.stat-today h3{font-size:16px;}


.stat-today{display:flex;align-items:baseline;justify-content:flex-end;gap:6px;}
.stat-today p{order:0;margin-right:12px;}
.stat-today h3{order:1;font-size:16px;}

.stat-row-inline{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;}
.stat-left h3{font-size:24px;margin-left:8px;}
.stat-right{text-align:right;}
.stat-right h3{font-size:16px;}







/* force stats cards */

/* unified stats cards */
.stat-card{background:var(--card);padding:18px;border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow-soft);}
.stat-card p{color:var(--muted);font-size:12px;}
.stat-card h3{font-size:22px;}

@media (max-width: 768px){
  }


.stat-card{background:var(--card);padding:18px;border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow-soft);}

.stats-hero{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.stat-card{background:var(--card);padding:12px;border-radius:14px;border:1px solid var(--border);box-shadow:var(--shadow-soft);}
.stat-card p{color:var(--muted);font-size:12px;}
.stat-card h3{font-size:20px;}


/* subtle-tech-console */
body[data-requires-auth=true] .card,
body[data-requires-auth=true] .panel,
body[data-requires-auth=true] .table-wrap,
body[data-requires-auth=true] .sidebar{
  border-color: rgba(99,102,241,.18);
  box-shadow: 0 6px 16px rgba(30,41,59,.08);
}
body[data-requires-auth=true] .pill{
  background: rgba(99,102,241,.12);
  color: #4338ca;
}
body[data-requires-auth=true] .section-header h2{
  position: relative;
}
body[data-requires-auth=true] .section-header h2::after{
  content: ;
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 36px;
  height: 3px;
  background: linear-gradient(90deg, #6366f1, #38bdf8);
  border-radius: 10px;
}
body[data-requires-auth=true] .btn.primary{
  box-shadow: 0 8px 18px rgba(99,102,241,.22);
}
body[data-requires-auth=true] .sidebar a.active{
  background: rgba(99,102,241,.08);
  border: 1px solid rgba(99,102,241,.18);
}
/* end-subtle-tech-console */

/* ux-enhancements */
.btn.is-loading{
  opacity:.8;
  cursor:wait;
  pointer-events:none;
}
.btn.is-loading::after{
  content:' ···';
}
.table-wrap table tbody tr:hover{
  background: rgba(99,102,241,.06);
}
.empty-state{
  padding: 22px;
  text-align:center;
  color: var(--muted);
  border:1px dashed rgba(99,102,241,.18);
  border-radius:12px;
  margin:12px 0;
}
.sidebar a.active{
  font-weight:700;
}
.nav a{
  transition: color .2s ease, opacity .2s ease;
}
.back-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:16px;
  color: var(--muted);
}
.back-link:hover{
  color: var(--text);
}
.input.error, .input.error:focus, textarea.error{
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,.12);
}
.form-error{
  color:#ef4444;
  font-size:12px;
  margin-top:6px;
}
.toast{
  position:fixed;
  right:24px;
  bottom:24px;
  background: #111827;
  color:#fff;
  padding:12px 16px;
  border-radius:12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  z-index:9999;
  font-size:16px;
}
/* end-ux-enhancements */



/* chat-hide */
.chat-fab,.chat-panel{display:none !important;}
/* end-chat-hide */

/* header-click-fix */
.site-header{position:relative;z-index:99999;}
.site-header .nav a,.site-header .menu-btn{position:relative;z-index:100000;pointer-events:auto;}
body *{pointer-events:auto;}
/* end-header-click-fix */







/* header-hitbox */
.site-header, .site-header *{pointer-events:auto !important;}
.nav{position:relative;z-index:100000;}
/* end-header-hitbox */

/* medium-animations */
:root{
  --anim-fast: .18s;
  --anim-mid: .28s;
  --anim-slow: .5s;
}

.btn, .card, .panel, .table-wrap, .nav a{
  transition: transform var(--anim-mid) ease, box-shadow var(--anim-mid) ease, color var(--anim-fast) ease, background var(--anim-fast) ease, border-color var(--anim-fast) ease;
}
.btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(15,23,42,.12);
}
.card:hover, .panel:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 36px rgba(15,23,42,.14);
}

.fade-in{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity var(--anim-slow) ease, transform var(--anim-slow) ease;
}
.fade-in.is-visible{
  opacity: 1;
  transform: translateY(0);
}

.nav a:hover{
  transform: translateY(-1px);
}

.table-wrap table tbody tr{
  transition: background var(--anim-fast) ease;
}

.hero-badges span, .pill{
  transition: transform var(--anim-fast) ease;
}
.hero-badges span:hover, .pill:hover{
  transform: translateY(-2px);
}
/* end-medium-animations */

/* mobile-update */
@media (max-width: 768px) {
  .header-inner{flex-wrap:wrap;gap:6px;}
  .logo{font-size:18px;}
  .nav.open{position:fixed;top:64px;right:8px;left:8px;z-index:9999;}
  .nav.open a{padding:10px 12px;border-radius:10px;}
  .cta-group .btn, .form .btn, .auth .btn{width:100%;}
  .panel, .card{border-radius:14px;}
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .table-wrap table{min-width:560px;}
  .layout{grid-template-columns:1fr;}
  .sidebar{position:static;}
  .hero-inner{grid-template-columns:1fr;}
  .hero-card{order:2;}
  .hero-text{order:1;}
  .section{padding:32px 0;}
}
/* end-mobile-update */

/* mobile-admin-update */
@media (max-width: 900px){
  .layout{grid-template-columns:1fr;}
  .sidebar{position:static;width:100%;}
}
@media (max-width: 768px){
  .sidebar a{padding:10px 12px;font-size:16px;}
  .panel{padding:16px;}
  .table-wrap{overflow-x:auto;}
  .table-wrap table{min-width:720px;}
}
/* end-mobile-admin-update */


.recharge-split .form { display: grid; gap: 8px; }
.recharge-split .form button { width: fit-content; }
@media (max-width: 768px) {
  .recharge-split { grid-template-columns: 1fr; }
  .recharge-split .form button { width: 100%; }
}

.cta-group.compact{gap:6px;}



.stat-row-inline .btn{white-space:nowrap;}

.balance-inline .link{font-size:12px;color:var(--link);font-weight:600;}
.balance-inline .link:hover{color:var(--link-hover);}

.sidebar-links{display:none;gap:6px;flex-direction:column;}
.sidebar-links.open{display:grid;}
.sidebar-links a{padding:8px 10px;border-radius:10px;color:var(--muted);font-size:16px;}
.sidebar-links a.active,.sidebar-links a:hover{background:#eef2ff;color:var(--text);}



.sidebar h4{display:flex;align-items:center;justify-content:space-between;}
.sidebar h4 .tri{font-size:12px;color:var(--muted);}

button[data-pending]{border:1px dashed rgba(15,23,42,.18);background:#f9fafb;color:#64748b;}
button[data-pending]:hover{background:#eef2ff;color:#4f46e5;}

.table-wrap table tr:nth-child(even){background:#fafafa;}

.balance-meta{font-size:12px;color:#94a3b8;margin-top:6px;}

.metric-updated{font-size:12px;color:#94a3b8;margin-top:6px;}

.meta-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.meta-item span{color:#64748b;font-size:12px;}
.meta-item strong{font-size:14px;}

.table-amount{text-align:right;}
.table-status{text-align:center;}

.tag-group{display:flex;gap:8px;align-items:center;}
.tag-group .tag{cursor:pointer;}

.faq-item{margin-bottom:10px;}
.faq-item p{color:#64748b;font-size:13px;margin-top:4px;}

.empty-actions{margin-top:12px;display:flex;gap:8px;justify-content:center;}

.status.info{background:#e0f2fe;color:#0369a1;}
.status.warn{background:#fef3c7;color:#92400e;}
.status.error{background:#fee2e2;color:#991b1b;}

.pagination{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;}

.btn.secondary:hover{background:#eef2ff;}

.btn.ghost:hover{background:#e0e7ff;}

.batch-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f8fafc;border:1px dashed rgba(15,23,42,.12);border-radius:10px;margin-bottom:12px;font-size:12px;color:#64748b;}

.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 37%,#f1f5f9 63%);background-size:400% 100%;animation:skeleton 1.4s ease infinite;border-radius:8px;}
@keyframes skeleton{0%{background-position:100% 0}100%{background-position:-100% 0}}





body.has-sidebar .container.layout{padding-left:72px;transition:padding .2s}
body.sidebar-open .container.layout{padding-left:260px}
.sidebar{position:fixed;left:0;top:64px;height:calc(100vh - 64px);width:64px;background:rgba(18,20,28,0.98);backdrop-filter:blur(8px);transition:width .2s;z-index:1100;overflow:auto;padding:16px}
.sidebar.open{width:260px}


/* sidebar-fullheight */
.sidebar{position:fixed;left:0;top:64px;height:calc(100vh - 64px);overflow:auto}
.container.layout{padding-left:260px}


/* panel-layout-sidebar */
.panel-layout .sidebar{position:fixed;left:0;top:64px;height:calc(100vh - 64px);width:240px;overflow:auto;background:rgba(18,20,28,0.98);border-right:1px solid rgba(255,255,255,0.06);padding:16px}
.panel-layout .container.layout{padding-left:240px}
.panel-layout .sidebar h4{margin-top:16px}
.panel-layout .sidebar a{display:block;padding:8px 10px;border-radius:8px}
.panel-layout .sidebar a:hover{background:rgba(255,255,255,0.04)}


.sidebar-group{padding-bottom:8px;margin-bottom:8px;border-bottom:1px solid rgba(15,23,42,0.06)}
.sidebar-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}


/* override: new sidebar style */
.panel-layout .sidebar,
.sidebar.open{
  background:#f7f8fb !important;
  backdrop-filter:none !important;
  border-right:none !important;
  box-shadow:none !important;
  color:#0f172a !important;
}
.panel-layout .sidebar a,
.panel-layout .sidebar h4{
  color:#0f172a !important;
}
.panel-layout .sidebar h4{font-size:13px;text-align:center}
.panel-layout .sidebar a{display:block;padding:8px 10px;border-radius:8px;text-align:center}
.panel-layout .sidebar a:hover{background:rgba(15,23,42,0.06)}
.panel-layout .sidebar .sidebar-logo{font-weight:700;font-size:18px;margin:10px 0 2px;text-align:center}
.panel-layout .sidebar .sidebar-tag{font-size:12px;color:rgba(15,23,42,0.6);margin-bottom:12px;text-align:center}
.panel-layout .sidebar .group-divider{height:1px;margin:8px 0;background:rgba(15,23,42,0.08)}
