/* ── Reset & base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --green:   #16a34a;
  --green-d: #15803d;
  --green-l: #dcfce7;
  --green-xl:#f0fdf4;
  --gray-50: #f9fafb;
  --gray-100:#f3f4f6;
  --gray-200:#e5e7eb;
  --gray-300:#d1d5db;
  --gray-400:#9ca3af;
  --gray-500:#6b7280;
  --gray-600:#4b5563;
  --gray-700:#374151;
  --gray-800:#1f2937;
  --gray-900:#111827;
  --blue:    #2563eb;
  --radius:  8px;
  --shadow:  0 1px 3px rgba(0,0,0,.10), 0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);
}
html, body { overflow-x: hidden; max-width: 100vw; }
html { font-size: 15px; }
body {
  font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  color: var(--gray-800);
  background: var(--gray-50);
  line-height: 1.5;
}
a { color: var(--green); text-decoration: none; }
a:hover { text-decoration: underline; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }

/* ── Utility ── */
.section-inner { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* ── Buttons ── */
.btn-primary {
  display: inline-block;
  background: var(--green);
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  padding: 10px 22px;
  border-radius: var(--radius);
  border: none;
  cursor: pointer;
  transition: background .15s;
}
.btn-primary:hover { background: var(--green-d); text-decoration: none; color: #fff; }
.btn-ghost {
  display: inline-block;
  background: transparent;
  color: var(--green-l);
  font-weight: 600;
  font-size: 14px;
  padding: 10px 22px;
  border-radius: var(--radius);
  border: 2px solid rgba(255,255,255,.35);
  transition: border-color .15s, color .15s;
}
.btn-ghost:hover { border-color: #fff; color: #fff; text-decoration: none; }
.btn-nav {
  background: var(--green);
  color: #fff !important;
  padding: 8px 18px;
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 600;
  transition: background .15s;
}
.btn-nav:hover { background: var(--green-d); text-decoration: none; }
.btn-sm {
  display: inline-block;
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 600;
  border-radius: 6px;
  border: 1px solid var(--gray-300);
  color: var(--gray-700);
  background: #fff;
  cursor: pointer;
  transition: background .12s;
}
.btn-sm:hover { background: var(--gray-100); }
.btn-sm.active { background: var(--green); color: #fff; border-color: var(--green); }

/* ══════════════════════════════════════════
   PUBLIC PAGES (landing, pricing, auth)
══════════════════════════════════════════ */

/* ── Navbar ── */
.navbar {
  position: sticky;
  top: 0;
  z-index: 100;
  background: #fff;
  border-bottom: 1px solid var(--gray-200);
  box-shadow: var(--shadow);
}
.nav-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 24px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.logo {
  font-size: 20px;
  font-weight: 800;
  color: var(--green);
  letter-spacing: -.3px;
  text-decoration: none;
}
.logo span { color: var(--gray-700); }
.nav-links {
  display: flex;
  gap: 20px;
  align-items: center;
  font-size: 14px;
  font-weight: 500;
}
.nav-links a { color: var(--gray-700); transition: color .12s; }
.nav-links a:hover { color: var(--green); text-decoration: none; }
.lang-switch { display:flex; align-items:center; gap:4px; font-size:13px; font-weight:600; border:1px solid var(--gray-300); border-radius:6px; padding:2px 4px; }
.lang-switch a { color:var(--gray-500); padding:1px 5px; border-radius:4px; transition:background .12s,color .12s; }
.lang-switch a:hover { color:var(--green); text-decoration:none; }
.lang-switch a.lang-active { background:var(--green); color:#fff; }

/* ── Buttons extra ── */
.btn-lg { padding: 14px 28px; font-size: 15px; border-radius: 10px; }
.btn-outline-white {
  display: inline-block;
  background: rgba(255,255,255,.1);
  color: #fff;
  font-weight: 600;
  font-size: 15px;
  padding: 14px 28px;
  border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.35);
  transition: background .15s, border-color .15s;
}
.btn-outline-white:hover { background: rgba(255,255,255,.2); border-color: #fff; text-decoration: none; color: #fff; }
.btn-ghost-dark {
  display: inline-block;
  background: rgba(255,255,255,.12);
  color: #fff;
  font-weight: 600;
  font-size: 15px;
  padding: 14px 28px;
  border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.35);
  transition: background .15s, border-color .15s;
}
.btn-ghost-dark:hover { background: rgba(255,255,255,.22); border-color: #fff; text-decoration: none; color: #fff; }

/* ── Hero ── */
.hero {
  background: linear-gradient(145deg, #052e16 0%, #14532d 40%, #166534 70%, #15803d 100%);
  color: #fff;
  padding: 90px 24px 80px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.hero-glow {
  position: absolute;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(134,239,172,.12) 0%, transparent 70%);
  top: -100px; left: 50%; transform: translateX(-50%);
  pointer-events: none;
}
.hero-inner { max-width: 760px; margin: 0 auto; position: relative; z-index: 1; }
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  color: #bbf7d0;
  font-size: 12px;
  font-weight: 600;
  padding: 6px 16px;
  border-radius: 100px;
  margin-bottom: 28px;
  letter-spacing: .3px;
}
.badge-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #4ade80;
  box-shadow: 0 0 6px #4ade80;
  animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: .4; }
}
.hero h1 {
  font-size: clamp(36px, 5.5vw, 64px);
  font-weight: 900;
  line-height: 1.08;
  margin-bottom: 20px;
  letter-spacing: -1px;
}
.hero h1 span { color: #4ade80; }
.hero-sub {
  font-size: 17px;
  color: #a7f3d0;
  margin-bottom: 36px;
  line-height: 1.6;
}
.hero-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 52px; }
.hero-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  padding: 20px 32px;
  gap: 0;
}
.hstat { text-align: center; padding: 0 28px; }
.hstat strong { display: block; font-size: 28px; font-weight: 800; color: #fff; line-height: 1; }
.hstat span { font-size: 12px; color: #86efac; font-weight: 500; margin-top: 4px; display: block; }
.hstat-div { width: 1px; height: 36px; background: rgba(255,255,255,.15); }

/* ── Feature strip ── */
.feature-strip {
  background: #fff;
  border-bottom: 1px solid var(--gray-200);
  padding: 28px 24px;
}
.strip-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0;
}
.strip-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 24px;
  border-right: 1px solid var(--gray-200);
}
.strip-item:last-child { border-right: none; }
.strip-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.icon-green { background: #dcfce7; color: #16a34a; }
.icon-blue  { background: #dbeafe; color: #2563eb; }
.icon-purple{ background: #f3e8ff; color: #9333ea; }
.icon-orange{ background: #fef3c7; color: #d97706; }
.strip-item strong { display: block; font-size: 13px; font-weight: 700; color: var(--gray-900); margin-bottom: 2px; }
.strip-item p { font-size: 12px; color: var(--gray-500); line-height: 1.4; margin: 0; }

/* ── Features detail ── */
.features-detail { padding: 80px 24px; background: var(--gray-50); }
.fd-header { text-align: center; margin-bottom: 52px; }
.fd-header h2 { font-size: clamp(24px, 3vw, 36px); font-weight: 800; color: var(--gray-900); line-height: 1.2; margin-bottom: 12px; letter-spacing: -.3px; }
.fd-header p { font-size: 16px; color: var(--gray-500); }
.fd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
}
.fd-card {
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  padding: 28px;
  box-shadow: var(--shadow);
  transition: box-shadow .2s, transform .2s;
}
.fd-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.fd-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.fd-card h3 { font-size: 16px; font-weight: 700; color: var(--gray-900); margin-bottom: 8px; }
.fd-card p { font-size: 13px; color: var(--gray-500); line-height: 1.6; }

/* ── CTA section ── */
.cta-section { padding: 60px 24px; background: #fff; }
.cta-box {
  background: linear-gradient(135deg, #052e16 0%, #14532d 50%, #166534 100%);
  border-radius: 20px;
  padding: 48px 44px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;
}
.cta-text { flex: 1; min-width: 240px; }
.cta-text h2 { font-size: 26px; font-weight: 800; color: #fff; margin-bottom: 8px; line-height: 1.2; }
.cta-text p { font-size: 14px; color: #a7f3d0; }
.cta-actions { display: flex; gap: 12px; align-items: center; flex-shrink: 0; flex-wrap: wrap; }
@media (max-width: 640px) {
  .cta-box { padding: 32px 24px; flex-direction: column; align-items: stretch; text-align: center; }
  .cta-actions { justify-content: center; }
  .cta-actions a { flex: 1; text-align: center; }
}

/* ── CTA band (keep for pricing) ── */
.cta-band {
  background: linear-gradient(135deg, #14532d, #15803d);
  padding: 64px 24px;
  color: #fff;
}
.cta-band h2 { font-size: 28px; font-weight: 700; margin-bottom: 10px; }

/* ── Footer ── */
.footer {
  border-top: 1px solid var(--gray-200);
  padding: 24px;
  font-size: 13px;
  color: var(--gray-500);
  background: #fff;
}
.footer .section-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.footer-logo { font-size: 15px; font-weight: 800; color: var(--green); }
.footer-legal { color: var(--gray-400); font-size: 12px; }
.footer-links { display: flex; gap: 16px; }
.footer-links a { color: var(--gray-400); font-size: 12px; transition: color .12s; }
.footer-links a:hover { color: var(--gray-700); text-decoration: none; }

/* ── Pricing ── */
.pricing-hero {
  background: var(--green-xl);
  padding: 56px 24px 40px;
  text-align: center;
}
.pricing-hero h1 { font-size: 32px; font-weight: 800; color: var(--gray-900); margin-bottom: 8px; }
.pricing-hero p { color: var(--gray-500); font-size: 15px; }

.pricing-cards {
  display: flex;
  gap: 24px;
  justify-content: center;
  flex-wrap: wrap;
  padding: 48px 24px;
}
.plan-card {
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  padding: 32px;
  width: 320px;
  box-shadow: var(--shadow);
  position: relative;
}
.plan-card.plan-featured {
  border: 2px solid var(--green);
  box-shadow: 0 0 0 4px #dcfce7, var(--shadow-lg);
}
.plan-badge {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--green);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 14px;
  border-radius: 100px;
  white-space: nowrap;
  letter-spacing: .4px;
}
.plan-name { font-size: 14px; font-weight: 700; color: var(--gray-500); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 12px; }
.plan-price { font-size: 40px; font-weight: 800; color: var(--gray-900); margin-bottom: 4px; }
.plan-price span { font-size: 16px; font-weight: 500; color: var(--gray-500); }
.plan-saving {
  display: inline-block;
  background: #dcfce7;
  color: var(--green-d);
  font-size: 12px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 6px;
  margin-bottom: 20px;
}
.plan-features { margin: 20px 0 28px; display: flex; flex-direction: column; gap: 10px; }
.plan-features li { font-size: 13px; color: var(--gray-700); }

/* ── FAQ ── */
.faq { padding: 56px 24px 80px; }
.faq h2 { color: var(--gray-900); font-size: 24px; }
.faq-item {
  border-bottom: 1px solid var(--gray-200);
  padding: 18px 0;
}
.faq-item strong { display: block; color: var(--gray-800); margin-bottom: 6px; font-size: 14px; }
.faq-item p { font-size: 13px; color: var(--gray-500); }

/* ── Auth ── */
.auth-page { background: var(--gray-100); min-height: 100vh; display: flex; align-items: center; justify-content: center; }
.auth-wrap { width: 100%; max-width: 420px; padding: 24px; }
.auth-card {
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  padding: 36px 32px;
  box-shadow: var(--shadow-md);
}
.auth-card h2 { font-size: 22px; font-weight: 700; color: var(--gray-900); margin-bottom: 4px; }
.form-group { display: flex; flex-direction: column; gap: 5px; margin-bottom: 16px; }
.form-group label { font-size: 13px; font-weight: 600; color: var(--gray-700); }
.form-group input {
  padding: 10px 13px;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  font-size: 14px;
  color: var(--gray-800);
  transition: border-color .12s, box-shadow .12s;
  outline: none;
}
.form-group input:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(22,163,74,.12);
}
.auth-switch { text-align: center; font-size: 13px; color: var(--gray-500); margin-top: 20px; }
.alert-error {
  background: #fef2f2; border: 1px solid #fecaca; color: #dc2626;
  border-radius: var(--radius); padding: 10px 14px; font-size: 13px; margin-bottom: 16px;
}
.alert-success {
  background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534;
  border-radius: var(--radius); padding: 10px 14px; font-size: 13px; margin-bottom: 16px;
}

/* ══════════════════════════════════════════
   DASHBOARD
══════════════════════════════════════════ */
body.app-body {
  background: #f0f4f8;
  min-height: 100vh;
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
}

/* ── Topbar — dark green like the local version ── */
.topbar {
  background: linear-gradient(90deg, #14532d 0%, #166534 100%);
  position: sticky; top: 0; z-index: 200;
  display: flex; align-items: center; gap: 14px;
  padding: 0 24px; height: 56px;
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.topbar .logo { font-size: 18px; font-weight: 900; color: #fff; letter-spacing: -.3px; }
.topbar .logo span { color: #86efac; }
.topbar-snap {
  font-size: 12px; color: #bbf7d0;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  padding: 3px 14px; border-radius: 100px; white-space: nowrap;
}
.topbar-right { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.topbar-email { font-size: 12px; color: #a7f3d0; font-weight: 500; }
.btn-ghost-sm {
  font-size: 12px; color: #fff; font-weight: 600;
  border: 1px solid rgba(255,255,255,.35); border-radius: 6px;
  padding: 5px 14px; transition: background .12s; background: rgba(255,255,255,.1);
}
.btn-ghost-sm:hover { background: rgba(255,255,255,.2); text-decoration: none; color: #fff; }

/* ── KPI row ── */
.kpi-row {
  display: flex; gap: 12px; flex-wrap: wrap;
  padding: 16px 24px; max-width: 1600px; margin: 0 auto; width: 100%;
  box-sizing: border-box;
}
.kpi {
  background: #fff; border: 1px solid var(--gray-200); border-radius: 12px;
  padding: 16px 20px; flex: 1; min-width: 140px;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
  border-top: 3px solid var(--green);
}
.kpi.kpi-warn { border-top-color: #f59e0b; }
.kpi { position: relative; }
.kpi-filter-badge {
  position: absolute; top: 8px; right: 10px;
  font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px;
  background: #dbeafe; color: #1d4ed8; padding: 1px 6px; border-radius: 20px;
}
.kv { font-size: 26px; font-weight: 900; color: #1a7a4a; line-height: 1.1; }
.kpi.kpi-warn .kv { color: #b45309; }
.kl { font-size: 11px; color: var(--gray-400); font-weight: 700; text-transform: uppercase; letter-spacing: .5px; margin-top: 4px; }
.kl small { font-size: 10px; text-transform: none; letter-spacing: 0; display: block; color: var(--gray-400); }

/* ── Tabs ── */
.tabs-bar {
  display: flex; gap: 0; padding: 0 24px;
  border-bottom: 2px solid var(--gray-200);
  background: #fff; max-width: 1600px; margin: 0 auto; width: 100%;
  box-sizing: border-box; box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.tab {
  padding: 12px 22px; font-size: 14px; font-weight: 600;
  color: var(--gray-500); border: none; background: none; cursor: pointer;
  border-bottom: 3px solid transparent; margin-bottom: -2px;
  transition: color .12s, border-color .12s;
}
.tab:hover { color: var(--green); }
.tab.active { color: var(--green); border-bottom-color: var(--green); background: #f0fdf4; }
.tab-panel { display: none; max-width: 1600px; margin: 0 auto; padding: 16px 24px; width: 100%; box-sizing: border-box; }
.tab-panel.active { display: block; }

/* ── Warning banner ── */
.banner-warn {
  display: flex; align-items: center; gap: 8px;
  background: #fffbeb; border: 1px solid #fde68a; border-radius: 8px;
  padding: 10px 14px; font-size: 13px; color: #92400e; margin-bottom: 12px;
}

/* ── Spinner ── */
.spinner {
  width:36px;height:36px;border:3px solid var(--gray-200);
  border-top-color:var(--green);border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Favorites ── */
.th-fav,.td-fav { width:28px; text-align:center; padding:0 4px; }
.btn-fav-star {
  background:none;border:none;cursor:pointer;font-size:15px;
  color:var(--gray-400);padding:2px;line-height:1;transition:color .12s,transform .1s;
}
.btn-fav-star:hover { color:#f59e0b; transform:scale(1.2); }
.btn-fav-star.fav-on { color:#f59e0b; }
.btn-fav-filter {
  background:none;border:1px solid var(--gray-300);border-radius:6px;
  padding:6px 10px;font-size:15px;cursor:pointer;color:var(--gray-500);
  transition:background .12s,color .12s,border-color .12s;line-height:1;
}
.btn-fav-filter:hover { border-color:#f59e0b;color:#f59e0b; }
.btn-fav-filter.active { background:#fef3c7;border-color:#f59e0b;color:#f59e0b; }
.btn-export {
  padding:6px 11px;border:1px solid var(--gray-300);border-radius:6px;
  font-size:12px;font-weight:600;color:var(--gray-600);text-decoration:none;
  transition:background .12s,border-color .12s;white-space:nowrap;
}
.btn-export:hover { background:var(--gray-50);border-color:var(--green);color:var(--green); }

/* ── Filters ── */
.filters {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
  background: #fff; border: 1px solid var(--gray-200); border-radius: 12px;
  padding: 10px 14px; margin-bottom: 12px; box-shadow: var(--shadow);
}
.filters input[type="text"], .filters select {
  padding: 7px 10px; border: 1px solid var(--gray-300); border-radius: 6px;
  font-size: 13px; color: var(--gray-700); outline: none;
  transition: border-color .12s; background: #fff; font-family: inherit;
}
.filters input[type="text"] { min-width: 180px; max-width: 320px; flex: 1 1 180px; }
.filters select { min-width: 120px; max-width: 200px; flex: 1 1 120px; }
.filters input:focus, .filters select:focus {
  border-color: var(--green); box-shadow: 0 0 0 2px rgba(22,163,74,.1);
}
.btn-reset {
  padding: 7px 12px; font-size: 12px; font-weight: 600;
  border: 1px solid var(--gray-200); border-radius: 6px;
  color: var(--gray-500); background: #fff; cursor: pointer; transition: background .12s;
}
.btn-reset:hover { background: var(--gray-100); }
.res-count { font-size: 12px; color: var(--gray-400); margin-left: auto; white-space: nowrap; }

/* ── Table ── */
.tbl-wrap {
  background: #fff; border: 1px solid var(--gray-200);
  border-radius: 12px; box-shadow: var(--shadow); overflow: auto;
}
.tbl-wrap table { width: 100%; border-collapse: collapse; font-size: 13px; }
.tbl-wrap thead th {
  background: #1a7a4a; border-bottom: 2px solid #145c38;
  padding: 11px 12px; text-align: left;
  font-size: 11px; font-weight: 700; color: #fff;
  text-transform: uppercase; letter-spacing: .5px;
  white-space: nowrap; cursor: pointer; user-select: none;
}
.tbl-wrap thead th:hover { background: #166534; }
.sa { opacity: .6; margin-left: 2px; color: #86efac; }
.tbl-wrap tbody tr { border-bottom: 1px solid #f1f5f9; transition: background .08s; }
.tbl-wrap tbody tr:hover { background: #f0fdf4; cursor: pointer; }
.tbl-wrap tbody td { padding: 9px 12px; vertical-align: middle; }
.num { text-align: right; }
.td-name { font-weight: 600; color: var(--gray-900); max-width: 240px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.td-muted { color: var(--gray-500); font-size: 12px; }
.tbl-link { color: var(--gray-900); font-weight: 600; }
.tbl-link:hover { color: var(--green); text-decoration: underline; }

/* ── Badges ── */
.badge-cat {
  display: inline-block; padding: 2px 8px; border-radius: 100px;
  font-size: 11px; font-weight: 700; white-space: nowrap;
}
.badge-fmt {
  display: inline-block; padding: 2px 7px; border-radius: 5px;
  font-size: 11px; font-weight: 600; background: var(--gray-100); color: var(--gray-600);
}
.badge-thc {
  display: inline-block; padding: 2px 7px; border-radius: 5px;
  font-size: 11px; font-weight: 700; background: #dcfce7; color: #166534;
}
.badge-sales {
  display: inline-block; padding: 2px 7px; border-radius: 5px;
  font-size: 11px; font-weight: 700; background: #dbeafe; color: #1e40af;
}
.badge-web {
  display: inline-block; font-size: 11px; color: var(--gray-400);
}
.price-yes { font-weight: 700; color: var(--gray-800); }
.price-no  { font-size: 11px; color: var(--gray-300); font-style: italic; }
.price-up   { font-size: 11px; font-weight: 800; color: #dc2626; margin-left: 3px; cursor: help; }
.price-down { font-size: 11px; font-weight: 800; color: #16a34a; margin-left: 3px; cursor: help; }

/* ── Stock bar ── */
.sbar { display: inline-flex; align-items: center; gap: 6px; }
.sbar-fill { height: 6px; border-radius: 3px; background: var(--green); opacity: .7; }
.link-store {
  display: inline-block; font-size: 12px; font-weight: 700; color: var(--blue);
  cursor: pointer; border-bottom: 1px dashed var(--blue);
}
.link-store:hover { color: var(--green); border-color: var(--green); }

/* ── Pagination ── */
.pager { display: flex; gap: 4px; justify-content: center; padding: 14px 0 4px; flex-wrap: wrap; }
.pager button {
  min-width: 32px; height: 32px; padding: 0 8px;
  border: 1px solid var(--gray-200); border-radius: 6px;
  font-size: 13px; font-weight: 600; background: #fff; color: var(--gray-600);
  cursor: pointer; transition: background .1s;
}
.pager button:hover { background: var(--gray-100); }
.pager button.active { background: var(--green); color: #fff; border-color: var(--green); }
.pager-dots { display: inline-flex; align-items: center; padding: 0 4px; color: var(--gray-400); font-size: 13px; }
.pager-info { text-align: center; font-size: 12px; color: var(--gray-400); padding-bottom: 10px; }

/* ── Store grid ── */
.store-grid, #store-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 10px;
}
.store-card {
  background: #fff; border: 1px solid var(--gray-200); border-radius: 12px;
  padding: 14px; box-shadow: var(--shadow); transition: box-shadow .15s;
}
.store-card:hover { box-shadow: var(--shadow-md); }
.store-card-empty { opacity: .5; }
.store-prod-wrap { position: relative; flex: 1; min-width: 200px; max-width: 300px; }

/* ── Price range slider ── */
.price-range-wrap { display:flex; flex-direction:column; gap:5px; min-width:160px; padding:2px 0; }
.price-range-label { font-size:11px; font-weight:700; color:var(--green); text-align:center; white-space:nowrap; letter-spacing:.3px; }
.price-range-track { position:relative; height:22px; }
.price-range-base { position:absolute; width:100%; height:4px; background:var(--gray-200); top:50%; transform:translateY(-50%); border-radius:2px; }
.price-range-fill { position:absolute; height:4px; background:var(--green); top:50%; transform:translateY(-50%); border-radius:2px; pointer-events:none; }
.price-range-track input[type="range"] {
  position:absolute; width:100%; height:4px;
  background:transparent; appearance:none; -webkit-appearance:none; -moz-appearance:none;
  pointer-events:none; top:50%; transform:translateY(-50%); margin:0; outline:none;
}
.price-range-track input[type="range"]::-webkit-slider-runnable-track { background:transparent; height:4px; }
.price-range-track input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance:none; appearance:none;
  width:16px; height:16px; border-radius:50%;
  background:var(--green); cursor:pointer; pointer-events:all;
  border:2px solid #fff; box-shadow:0 1px 4px rgba(0,0,0,.25);
  transition:transform .1s; margin-top:-6px;
}
.price-range-track input[type="range"]::-webkit-slider-thumb:hover { transform:scale(1.2); }
.price-range-track input[type="range"]::-moz-range-track { background:transparent; height:4px; border:none; }
.price-range-track input[type="range"]::-moz-range-progress { background:transparent; }
.price-range-track input[type="range"]::-moz-range-thumb {
  width:16px; height:16px; border-radius:50%;
  background:var(--green); cursor:pointer; pointer-events:all;
  border:2px solid #fff; box-shadow:0 1px 4px rgba(0,0,0,.25);
  appearance:none; -moz-appearance:none;
}
.restock-legend {
  margin:8px 0 0; font-size:11px; color:var(--gray-500);
  display:flex; align-items:center; gap:6px;
}
.restock-dot {
  display:inline-block; width:10px; height:10px; border-radius:50%;
  background:#f97316; flex-shrink:0;
}
.store-card h4 {
  font-size: 12px; font-weight: 700; color: var(--gray-900);
  margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sc-city { font-size: 10px; color: var(--gray-400); margin-bottom: 8px; line-height: 1.4; }
.sc-stats { display: flex; gap: 12px; }
.sc-val { font-size: 17px; font-weight: 800; color: var(--gray-800); line-height: 1; }
.sc-lbl { font-size: 9px; color: var(--gray-400); font-weight: 600; text-transform: uppercase; margin-top: 2px; }

/* ── Charts grid ── */
.charts-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(380px, 1fr)); gap: 14px;
  overflow-x: hidden;
}
.chart-card {
  background: #fff; border: 1px solid var(--gray-200); border-radius: 12px;
  padding: 20px; box-shadow: var(--shadow); min-width: 0; overflow: hidden;
}
.chart-card h4 {
  font-size: 12px; font-weight: 700; color: var(--gray-500);
  text-transform: uppercase; letter-spacing: .4px; margin-bottom: 16px;
}
.chart-card canvas { max-height: 280px; }
.chart-card-wide { grid-column: 1 / -1; }

/* ── Ranked list rows (replace Chart.js bar charts) ── */
.ranked-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px;
  transition: background .1s;
}
.ranked-row:hover { background: var(--gray-50); }
.ranked-num {
  font-size: 11px; font-weight: 700; color: var(--gray-400);
  min-width: 26px; text-align: right;
}

/* ── Popup / overlay ── */
.overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(15,23,42,.5); z-index: 1000;
  align-items: flex-start; justify-content: center;
  padding: 40px 20px; overflow-y: auto;
}
.overlay.show { display: flex; }
.popup {
  background: #fff; border-radius: 16px; box-shadow: 0 20px 60px rgba(0,0,0,.2);
  width: 100%; max-width: 720px; position: relative;
  animation: pop-in .18s ease;
}
@keyframes pop-in {
  from { opacity:0; transform: translateY(-10px) scale(.97); }
  to   { opacity:1; transform: none; }
}
.popup-close {
  position: absolute; top: 14px; right: 16px;
  font-size: 20px; color: var(--gray-400); cursor: pointer;
  width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
  border-radius: 6px; transition: background .12s;
}
.popup-close:hover { background: var(--gray-100); color: var(--gray-700); }
.popup h3 {
  font-size: 16px; font-weight: 700; color: var(--gray-900);
  padding: 20px 48px 4px 20px; line-height: 1.3;
}
.popup-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
  padding: 0 20px 14px; border-bottom: 1px solid var(--gray-200);
  font-size: 12px; color: var(--gray-500);
}
.popup-tabs {
  display: flex; border-bottom: 1px solid var(--gray-200);
}
.ptab {
  flex: 1; padding: 11px; text-align: center;
  font-size: 13px; font-weight: 600; color: var(--gray-400);
  cursor: pointer; border-bottom: 2px solid transparent;
  margin-bottom: -1px; transition: color .12s;
}
.ptab:hover { color: var(--green); }
.ptab.active { color: var(--green); border-bottom-color: var(--green); }
#pop-stores, #pop-history { padding: 16px 20px; max-height: 55vh; overflow-y: auto; }

/* Store rows in popup */
.s-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0; border-bottom: 1px solid #f1f5f9;
}
.s-row:last-child { border-bottom: none; }
.s-name { font-size: 13px; font-weight: 600; color: var(--gray-800); }
.s-city { font-size: 11px; color: var(--gray-400); margin-top: 1px; }
.s-qty  { font-size: 13px; font-weight: 700; color: var(--green); white-space: nowrap; }
.s-zero { font-size: 12px; color: var(--gray-300); font-style: italic; }

/* History table in popup */
.hist-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.hist-table th {
  text-align: left; font-size: 11px; font-weight: 700;
  color: var(--gray-400); text-transform: uppercase; letter-spacing: .4px;
  padding: 6px 8px; border-bottom: 2px solid var(--gray-200);
}
.hist-table td { padding: 7px 8px; border-bottom: 1px solid #f1f5f9; color: var(--gray-700); }
.hist-table tr:last-child td { border-bottom: none; }
.d-up { color: var(--green); font-weight: 700; }
.d-dn { color: #dc2626; font-weight: 700; }
.d-eq { color: var(--gray-300); }
.empty-msg { text-align: center; color: var(--gray-400); font-size: 13px; padding: 24px 0; }

/* ── Scrape banner ── */
#scrape-banner {
  display: flex; align-items: center; gap: 10px;
  background: #fefce8; border-bottom: 1px solid #fde047;
  color: #854d0e; font-size: 13px; font-weight: 500;
  padding: 10px 24px;
}
.scrape-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: #f59e0b; flex-shrink: 0;
  animation: scrape-pulse 1.2s ease-in-out infinite;
}
@keyframes scrape-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .4; transform: scale(.75); }
}

/* ── Badges nouveau / retiré ── */
.badge-new {
  display: inline-block; font-size: 10px; font-weight: 700; letter-spacing: .4px;
  background: #dcfce7; color: #15803d; border: 1px solid #86efac;
  border-radius: 4px; padding: 1px 5px; margin-right: 5px;
  vertical-align: middle; white-space: nowrap;
}
.badge-retired {
  display: inline-block; font-size: 10px; font-weight: 700; letter-spacing: .4px;
  background: #f3f4f6; color: #6b7280; border: 1px solid #d1d5db;
  border-radius: 4px; padding: 1px 5px; margin-right: 5px;
  vertical-align: middle; white-space: nowrap; text-decoration: line-through;
}
.row-retired { opacity: .55; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--gray-100); }
::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--gray-400); }

/* ── Ventes tab ── */
.ventes-controls {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 12px 16px; background: #fff;
  border: 1px solid var(--gray-200); border-radius: 12px;
  box-shadow: var(--shadow); margin-bottom: 12px;
}
.ventes-search-wrap { position: relative; flex: 1; min-width: 220px; max-width: 480px; }
.ventes-search-wrap input {
  width: 100%; padding: 9px 14px; font-size: 14px;
  border: 1.5px solid var(--gray-200); border-radius: 8px;
  outline: none; font-family: inherit; box-sizing: border-box;
}
.ventes-search-wrap input:focus { border-color: var(--green); }
.ventes-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 200;
  background: #fff; border: 1px solid var(--gray-200); border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.10); max-height: 260px; overflow-y: auto;
  display: none;
}
.ventes-dropdown.open { display: block; }
.vdd-item {
  padding: 9px 14px; cursor: pointer; font-size: 13.5px;
  border-bottom: 1px solid var(--gray-100);
}
.vdd-item:last-child { border-bottom: none; }
.vdd-item:hover, .vdd-item.focused { background: #f0fdf4; }
.vdd-item strong { color: var(--green-dark); }
.vdd-item small { color: var(--gray-400); margin-left: 6px; }

.period-btns { display: flex; gap: 4px; flex-shrink: 0; }
.period-btn {
  padding: 7px 14px; font-size: 13px; font-weight: 600; cursor: pointer;
  border: 1.5px solid var(--gray-200); border-radius: 6px; background: #fff;
  color: var(--gray-500); transition: all .15s; font-family: inherit;
}
.period-btn:hover { border-color: var(--green); color: var(--green); }
.period-btn.active { background: var(--green); border-color: var(--green); color: #fff; }

.ventes-selected-label {
  font-size: 13px; color: var(--gray-400); flex-shrink: 0;
}
.ventes-selected-label strong { color: var(--gray-700); }

.ventes-body { padding: 24px; }
.ventes-empty-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  min-height: 300px; color: var(--gray-400); gap: 10px;
}
.ventes-empty-state .big-icon { font-size: 48px; }
.ventes-empty-state p { font-size: 15px; margin: 0; }
.ventes-empty-state small { font-size: 12px; color: var(--gray-300); }

.ventes-kpis { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 20px; }
.vkpi {
  background: #fff; border: 1px solid var(--gray-100); border-radius: 10px;
  padding: 14px 20px; flex: 1; min-width: 140px;
  border-top: 3px solid var(--green);
}
.vkpi .kv { font-size: 22px; font-weight: 900; color: #1a7a4a; }
.vkpi .kl { font-size: 11px; color: var(--gray-400); text-transform: uppercase; letter-spacing: .5px; margin-top: 3px; }

.ventes-chart-wrap {
  background: #fff; border: 1px solid var(--gray-200); border-radius: 12px;
  padding: 20px; margin-bottom: 16px; box-shadow: var(--shadow);
}
.ventes-chart-wrap h4 { font-size: 14px; font-weight: 600; color: var(--gray-600); margin: 0 0 16px; }

.ventes-tbl-wrap {
  background: #fff; border: 1px solid var(--gray-200); border-radius: 12px;
  overflow: hidden; box-shadow: var(--shadow);
}
.ventes-tbl-wrap table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.ventes-tbl-wrap thead th {
  background: #1a7a4a; color: #fff; padding: 10px 16px;
  text-align: left; font-size: 12px; font-weight: 600; letter-spacing: .4px;
}
.ventes-tbl-wrap thead th.num { text-align: right; }
.ventes-tbl-wrap tbody tr:nth-child(even) { background: #f8faf9; }
.ventes-tbl-wrap tbody td { padding: 9px 16px; color: var(--gray-700); }
.ventes-tbl-wrap tbody td.num { text-align: right; font-variant-numeric: tabular-nums; }
.ventes-tbl-wrap tbody tr:hover { background: #f0fdf4; }
.vt-zero { color: var(--gray-300) !important; }
.vt-peak { background: #f0fdf4 !important; font-weight: 700; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .charts-grid { grid-template-columns: 1fr; }
  .hstat { padding: 0 16px; }
}
@media (max-width: 768px) {
  .filters { flex-direction: column; align-items: stretch; }
  .filters input, .filters select { width: 100%; }
  .plan-card { width: 100%; max-width: 400px; }
  .pricing-cards { padding: 32px 16px; }
  .hero h1 { font-size: 28px; }
  .hero-stats { padding: 16px; gap: 0; }
  .hstat { padding: 8px 12px; }
  .hstat-div { display: none; }
  .ventes-controls { padding: 12px 16px; }
  .ventes-body { padding: 16px; }
  .vkpi { min-width: 120px; }
  .nav-inner { padding: 0 14px; }
  .nav-links { gap: 10px; font-size: 13px; }
  .btn-nav { padding: 6px 10px; font-size: 12px; }

  /* Dashboard layout */
  .dash-wrap { padding: 0 12px 24px; }

  /* Tabs bar: scroll horizontally, hide scrollbar */
  .tabs-bar { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap;
              padding: 0 12px; scrollbar-width: none; -ms-overflow-style: none; }
  .tabs-bar::-webkit-scrollbar { display: none; }
  .tab { white-space: nowrap; flex-shrink: 0; padding: 10px 14px; font-size: 13px; }

  /* Filters bar: stack price range + action buttons */
  .filters { gap: 8px; }
  .price-range-wrap { width: 100%; }
  .price-range-track { width: 100%; }

  /* Product table: horizontal scroll */
  .tbl-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .tbl-wrap table { min-width: 640px; }

  /* Ventes table */
  .ventes-tbl-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  /* Ventes controls: prevent overflow from min-width */
  .ventes-search-wrap { min-width: 0; width: 100%; }
  .ventes-controls { padding: 12px; }
  #tab-ventes { overflow-x: hidden; }

  /* KPI cards: 2 per row */
  .kpi-row { flex-wrap: wrap; gap: 8px; padding: 12px 12px; }
  .kpi { min-width: calc(50% - 4px); flex: 1 1 calc(50% - 4px); padding: 14px 16px; }
  .kv { font-size: 22px; }

  /* Topbar: hide email, compress, prevent overflow */
  .topbar-email { display: none; }
  .topbar-right { gap: 6px; min-width: 0; flex-shrink: 0; }
  .topbar { overflow: hidden; }
  .topbar .logo { flex-shrink: 1; min-width: 0; overflow: hidden;
                  text-overflow: ellipsis; white-space: nowrap; }
  .btn-ghost-sm { padding: 5px 10px; font-size: 11px; }
}
@media (max-width: 500px) {
  .topbar { padding: 0 12px; }
  .topbar-snap { display: none; }
  .popup { border-radius: 0; }
  .overlay { padding: 0; align-items: flex-end; }
  .period-btns { width: 100%; }
  .period-btn { flex: 1; padding: 7px 6px; font-size: 12px; }

  /* KPI cards: tighter on very small screens */
  .kpi { padding: 12px; }
  .kv { font-size: 20px; }
  .kl { font-size: 10px; }

  /* Compact tabs */
  .tab { padding: 9px 10px; font-size: 12px; }

  /* Table font */
  .tbl-wrap table { font-size: 12px; }
  .tbl-wrap th, .tbl-wrap td { padding: 7px 8px; }

  /* Topbar logo + button */
  .logo { font-size: 15px; }
  .btn-ghost-sm { padding: 4px 8px; font-size: 11px; }
  .lang-switch { margin-right: 4px !important; font-size: 12px; }

  /* Ventes KPIs: wrap */
  .vkpi-row { flex-wrap: wrap; gap: 8px; }
  .vkpi { min-width: calc(50% - 4px); flex: 1 1 calc(50% - 4px); }

  /* Dash section padding */
  .tab-panel { padding: 14px 0; }
}
