/* =============================================================================
   VANTAGE — Design System v2
   Premium dark-mode SaaS for TikTok Shop product intelligence
   ============================================================================= */

/* 1. TOKENS ================================================================ */
@import url('https://api.fontshare.com/v2/css?f[]=cabinet-grotesk@700,800&f[]=satoshi@400,500,700&display=swap');

:root {
  /* Spacing — 4px grid */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-5:20px; --space-6:24px; --space-7:28px; --space-8:32px;
  --space-10:40px; --space-12:48px; --space-14:56px; --space-16:64px;

  /* === LIGHT MODE (default for app) === */
  --bg-base:#f9f0f1;           /* warm rose tint — the "gap" color */
  --bg-surface:#ffffff;         /* cards, sidebar, topbar stay white */
  --bg-elevated:#fef7f7;        /* slightly warm white for nested elements */
  --bg-hover:#f5eaeb;           /* hover state — warm */
  --bg-active:#eddfe0;          /* active/pressed */

  --border:rgba(180,60,80,0.08);  /* warm-tinted borders */
  --border-strong:rgba(180,60,80,0.14);

  --text-primary:#0f1117;
  --text-secondary:#4b5563;
  --text-muted:#6b7280;
  --text-faint:#9ca3af;

  --accent:#e8384d;
  --accent-hover:#cc2e42;
  --accent-glow:rgba(232,56,77,0.08);

  --teal:#0d9488;
  --teal-dim:rgba(13,148,136,0.08);

  --gold:#d97706;
  --gold-dim:rgba(217,119,6,0.08);
  --success:#059669;
  --success-dim:rgba(5,150,105,0.08);
  --warning:#ea580c;
  --warning-dim:rgba(234,88,12,0.08);
  --danger:#dc2626;
  --danger-dim:rgba(220,38,38,0.08);

  --shadow-sm:0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:0 4px 12px rgba(0,0,0,0.08),0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg:0 12px 32px rgba(0,0,0,0.10),0 4px 8px rgba(0,0,0,0.04);
}

/* === DARK MODE (landing page + toggle) === */
[data-theme="dark"] {
  --bg-base:#0c0d10;
  --bg-surface:#13141a;
  --bg-elevated:#1a1b22;
  --bg-hover:#22232c;
  --bg-active:#2a2b35;

  --border:rgba(255,255,255,0.07);
  --border-strong:rgba(255,255,255,0.13);

  --text-primary:#f4f2ef;
  --text-secondary:#b8b5af;
  --text-muted:#8d8a84;
  --text-faint:#5e5b56;

  --accent:#ff5272;
  --accent-hover:#ff3458;
  --accent-glow:rgba(255,82,114,0.14);

  --teal:#36d9c4;
  --teal-dim:rgba(54,217,196,0.12);

  --gold:#f5a623;
  --gold-dim:rgba(245,166,35,0.12);
  --success:#5ee89c;
  --success-dim:rgba(94,232,156,0.12);
  --warning:#fb923c;
  --warning-dim:rgba(251,146,60,0.12);
  --danger:#ff6b6b;
  --danger-dim:rgba(255,107,107,0.12);

  --shadow-sm:0 1px 3px rgba(0,0,0,0.6);
  --shadow-md:0 4px 16px rgba(0,0,0,0.5);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.7);
}

:root {
  /* Radius */
  --radius-sm:6px;
  --radius:8px;
  --radius-lg:12px;
  --radius-xl:16px;
  --radius-full:9999px;

  /* Typography */
  --font-display:'Cabinet Grotesk','Satoshi',system-ui,sans-serif;
  --font-body:'Satoshi',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --text-xs:.75rem; --text-sm:.8125rem; --text-base:.9375rem;
  --text-lg:1.125rem; --text-xl:1.25rem; --text-2xl:1.5rem;
  --text-3xl:2rem; --text-4xl:2.5rem; --text-5xl:3.25rem;

  /* Layout */
  --sidebar-w:240px;
  --topbar-h:56px;
  --content-max:1200px;

  /* Motion */
  --ease:cubic-bezier(.16,1,.3,1);
  --dur-fast:120ms;
  --dur:180ms;
  --dur-slow:320ms;
}

/* 2. RESET + TYPOGRAPHY ==================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}
body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.5;color:var(--text-primary);background:var(--bg-base);min-height:100vh;overflow-x:hidden}
a{color:var(--accent);text-decoration:none;transition:color var(--dur-fast)}
a:hover{color:var(--accent-hover)}
img{max-width:100%;display:block}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.15;color:var(--text-primary)}

.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}
.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}
.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-faint{color:var(--text-faint)}.text-accent{color:var(--accent)}.text-teal{color:var(--teal)}
.font-display{font-family:var(--font-display)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}
.line-clamp-1{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* 3. LAYOUT ================================================================ */

/* App shell */
.app-shell{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{position:fixed;top:8px;left:8px;bottom:8px;width:calc(var(--sidebar-w) - 16px);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;z-index:100;overflow-y:auto;box-shadow:var(--shadow-sm)}
.sidebar-logo{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5);height:var(--topbar-h);border-bottom:1px solid var(--border)}
.sidebar-logo svg{flex-shrink:0}
.sidebar-wordmark{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary),var(--text-muted));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.sidebar-nav{flex:1;padding:var(--space-3)}
.sidebar-section{padding:var(--space-4) var(--space-4) var(--space-2);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}
.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;transition:all var(--dur-fast);border-left:2px solid transparent;margin-bottom:2px}
.sidebar-link:hover{color:var(--text-primary);background:var(--bg-hover)}
.sidebar-link.active{color:var(--accent);background:var(--accent-glow);border-left-color:var(--accent)}
.sidebar-link .lucide{width:20px;height:20px;flex-shrink:0}

.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border)}
.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius);transition:background var(--dur-fast)}
.sidebar-user:hover{background:var(--bg-hover)}

/* Avatar */
.avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--accent-glow);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;flex-shrink:0}
.avatar-lg{width:48px;height:48px;font-size:var(--text-base)}
.avatar img{width:100%;height:100%;border-radius:inherit;object-fit:cover}

.user-meta{overflow:hidden}
.user-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Main area */
.main-area{flex:1;margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column}

/* Topbar */
.topbar{position:sticky;top:0;height:calc(var(--topbar-h) + env(safe-area-inset-top,0px));padding-top:env(safe-area-inset-top,0px);display:flex;align-items:center;gap:var(--space-4);padding-left:var(--space-6);padding-right:var(--space-6);background:var(--bg-surface);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:50}
.topbar-search{flex:1;max-width:420px;position:relative}
.topbar-search .lucide{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted);pointer-events:none}
.topbar-search .input{padding-left:40px;height:40px;background:var(--bg-surface)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:var(--space-3)}

/* Page content */
.page-content{flex:1;padding:var(--space-6);max-width:var(--content-max);width:100%;margin:0 auto}
.page-header{margin-bottom:var(--space-6)}
.page-title{font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-1)}
.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary)}

/* 4. COMPONENTS ============================================================ */

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:44px;padding:0 20px;border-radius:var(--radius);font-size:14px;font-weight:600;transition:all var(--dur) var(--ease);white-space:nowrap;user-select:none;position:relative;overflow:hidden}
.btn .lucide{width:18px;height:18px}
.btn:disabled,.btn.loading{opacity:.55;pointer-events:none}
.btn .btn-spinner{display:none;width:18px;height:18px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}
.btn.loading .btn-label{visibility:hidden}
.btn.loading .btn-spinner{display:block;position:absolute}
@keyframes spin{to{transform:rotate(360deg)}}

.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 20px rgba(255,77,109,.3)}
.btn-primary:active{transform:translateY(0);box-shadow:none}

.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-strong)}
.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-strong)}

.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(248,113,113,.2)}
.btn-danger:hover{background:rgba(248,113,113,.2)}

.btn-sm{height:36px;padding:0 14px;font-size:var(--text-xs)}
.btn-lg{height:52px;padding:0 var(--space-8);font-size:var(--text-base);border-radius:var(--radius-lg)}
.btn-icon{width:44px;height:44px;padding:0}
.btn-icon.btn-sm{width:36px;height:36px}

/* Cards */
.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--dur) var(--ease)}
.card-hover:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-md)}

/* Inputs */
.input,.select,.textarea{width:100%;height:44px;padding:0 14px;background:var(--bg-base);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text-primary);font-size:var(--text-sm);transition:border-color var(--dur-fast),box-shadow var(--dur-fast);outline:none}
.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.input::placeholder{color:var(--text-muted)}
.textarea{height:auto;min-height:100px;resize:vertical;padding:10px 14px}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a8885' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;cursor:pointer}
.input-group{display:flex;flex-direction:column;gap:var(--space-2)}
.input-label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;line-height:1.4}
.badge-accent{background:var(--accent-glow);color:var(--accent)}
.badge-teal{background:var(--teal-dim);color:var(--teal)}
.badge-green{background:var(--success-dim);color:var(--success)}
.badge-gold{background:var(--gold-dim);color:var(--gold)}
.badge-red{background:var(--danger-dim);color:var(--danger)}
.badge-muted{background:var(--bg-hover);color:var(--text-secondary)}

/* Tables */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}
.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}
.table th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-elevated);border-bottom:1px solid var(--border);white-space:nowrap}
.table th.sortable{cursor:pointer;user-select:none}.table th.sortable:hover{color:var(--text-muted)}
.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);vertical-align:middle}
.table tbody tr{transition:background var(--dur-fast)}.table tbody tr:hover{background:var(--bg-hover)}
.table tbody tr:last-child td{border-bottom:none}

/* Tabs */
.tabs{display:flex;gap:var(--space-1);border-bottom:1px solid var(--border);margin-bottom:var(--space-6)}
.tab{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all var(--dur-fast)}
.tab:hover{color:var(--text-primary)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-content{display:none}.tab-content.active{display:block}

/* Pill tabs (date range, etc) */
.pill-tabs{display:flex;gap:2px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:3px;width:fit-content}
.pill-tab{padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--dur-fast)}
.pill-tab:hover{color:var(--text-primary)}
.pill-tab.active{background:var(--accent);color:#fff}

/* Toggle switch */
.toggle{position:relative;display:inline-block;width:44px;height:24px;cursor:pointer}
.toggle input{display:none}
.toggle-track{position:absolute;inset:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-full);transition:background var(--dur)}
.toggle input:checked+.toggle-track{background:var(--accent);border-color:var(--accent)}
.toggle-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform var(--dur) var(--ease);pointer-events:none}
.toggle input:checked~.toggle-knob{transform:translateX(20px)}

/* 5. STAT CARDS ============================================================ */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}
.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--dur) var(--ease)}
.stat-card--link{text-decoration:none;cursor:pointer;display:block}
.stat-card--link:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.stat-hint{font-size:11px;color:var(--text-faint);margin-top:6px;opacity:0;transition:opacity var(--dur)}
.stat-card--link:hover .stat-hint{opacity:1}
.stat-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--space-2)}
.stat-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:800;line-height:1;color:var(--text-primary)}
.stat-trend{display:inline-flex;align-items:center;gap:var(--space-1);margin-top:var(--space-2);font-size:var(--text-xs);font-weight:600}
.stat-trend.up{color:var(--success)}.stat-trend.down{color:var(--danger)}

/* 6. PRODUCT CARDS ========================================================= */
.product-grid{column-count:3;column-gap:var(--space-4)}
.product-card{break-inside:avoid;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-4);transition:all var(--dur) var(--ease)}
.product-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.product-card-img{position:relative;aspect-ratio:1;background:var(--bg-elevated);overflow:hidden}
.product-card-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease)}
.product-card:hover .product-card-img img{transform:scale(1.04)}
.product-card-img-fallback{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-muted);font-size:12px}
.product-card-img-fallback .lucide{width:32px;height:32px}

.badge-overlay-tl{position:absolute;top:var(--space-3);left:var(--space-3)}
.badge-overlay-tr{position:absolute;top:var(--space-3);right:var(--space-3)}

.product-card-body{padding:var(--space-4)}
.product-card-name{font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.product-card-commission{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:var(--accent);margin-bottom:2px}
.product-card-price{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-3)}

.product-card-gmv{margin-bottom:var(--space-4)}
.product-card-gmv-label{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:4px}
.product-card-gmv-bar{height:4px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden}
.product-card-gmv-fill{height:100%;background:var(--teal);border-radius:var(--radius-full);transition:width var(--dur-slow) var(--ease)}

.product-card-stats{display:flex;gap:var(--space-3);margin:var(--space-3) 0;padding:var(--space-3) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.product-card-stat{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary)}
.product-card-stat i{color:var(--text-muted)}
.product-card-stat small{color:var(--text-muted)}

.product-card-actions{display:flex;gap:var(--space-2)}
.product-card-actions .btn{flex:1;height:36px;font-size:var(--text-xs)}

/* Horizontal scroll row */
.scroll-row{display:flex;gap:var(--space-4);overflow-x:auto;padding-bottom:var(--space-3);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;position:relative}
.scroll-row::-webkit-scrollbar{height:4px}.scroll-row::-webkit-scrollbar-track{background:transparent}.scroll-row::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:var(--radius-full)}
.scroll-card{flex:0 0 220px;scroll-snap-align:start}

/* Fade gradient on scroll row right edge */
.scroll-row-wrap{position:relative}
.scroll-row-wrap::after{content:'';position:absolute;top:0;right:0;bottom:0;width:60px;background:linear-gradient(to right,transparent,var(--bg-base));pointer-events:none;z-index:2}
.scroll-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm);color:var(--text-muted);transition:all var(--dur-fast)}
.scroll-arrow:hover{color:var(--text-primary);box-shadow:var(--shadow-md)}
.scroll-arrow--left{left:-8px}
.scroll-arrow--right{right:-8px}
@media(max-width:768px){.scroll-arrow{display:none}}

/* 7. SECTION HEADERS ======================================================= */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}
.section-title{font-size:var(--text-lg);font-weight:700}
.section-link{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-1)}
.section-link:hover{color:var(--text-primary)}

/* 8. FILTER BAR ============================================================ */
.filter-bar{position:sticky;top:var(--topbar-h);z-index:40;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-5);box-shadow:var(--shadow-sm)}

/* Filter card (products page) */
.filter-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:var(--space-5);box-shadow:var(--shadow-sm)}
.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.filter-input{height:36px;padding:0 10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:border-color var(--dur-fast)}
.filter-input:focus{border-color:var(--accent)}
.filter-input::placeholder{color:var(--text-faint)}
select.filter-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px;cursor:pointer}
.filter-actions{display:flex;align-items:center;gap:8px}
.filter-count-label{margin-left:auto;font-size:13px;color:var(--text-muted);font-weight:500}
.filter-bar .input,.filter-bar .select{width:auto;min-width:160px;height:40px;background:var(--bg-surface)}
.filter-count{font-size:var(--text-sm);color:var(--text-secondary);margin-left:auto;white-space:nowrap}

/* 9. DETAIL LAYOUT ========================================================= */
.detail-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--space-8)}
.detail-back{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-5)}.detail-back:hover{color:var(--text-primary)}
.detail-back .lucide{width:16px;height:16px}
.detail-image{width:100%;aspect-ratio:1;border-radius:var(--radius-lg);background:var(--bg-elevated);overflow:hidden;margin-bottom:var(--space-5)}
.detail-image img{width:100%;height:100%;object-fit:cover}
.detail-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-4)}

/* 10. CHART COMPONENTS ===================================================== */
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
.chart-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5)}
.chart-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-4)}
.chart-wrap{position:relative;height:240px}

/* 11. COMMISSION CALCULATOR ================================================ */
.calc-widget{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5)}
.calc-widget-title{font-size:var(--text-sm);font-weight:600;color:var(--text-muted);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}
.calc-result{margin-top:var(--space-4);padding:var(--space-4);background:var(--accent-glow);border-radius:var(--radius);text-align:center}
.calc-result-value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--accent)}
.calc-result-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}

/* 12. VIDEO CARDS ========================================================== */
.video-card{display:flex;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius);transition:background var(--dur-fast)}
.video-card:hover{background:var(--bg-hover)}
.video-thumb{width:72px;height:72px;border-radius:var(--radius);background:var(--bg-elevated);overflow:hidden;flex-shrink:0;position:relative}
.video-thumb img{width:100%;height:100%;object-fit:cover}
.video-creator{font-size:var(--text-sm);font-weight:600;color:var(--accent);margin-bottom:2px}
.video-views{font-size:var(--text-xs);color:var(--text-muted)}

/* 13. PAGINATION =========================================================== */
.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-1);margin-top:var(--space-6)}
.page-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;color:var(--text-muted);transition:all var(--dur-fast)}
.page-btn:hover{background:var(--bg-hover);color:var(--text-primary)}
.page-btn.active{background:var(--accent);color:#fff}
.page-btn:disabled{opacity:.3;cursor:not-allowed}

/* 14. EMPTY STATES ========================================================= */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-16) var(--space-6)}
.empty-icon{width:80px;height:80px;margin-bottom:var(--space-5);color:var(--text-muted)}
.empty-title{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-2)}
.empty-desc{font-size:var(--text-sm);color:var(--text-secondary);max-width:360px;margin-bottom:var(--space-5)}

/* 15. SKELETON LOADERS ===================================================== */
.skeleton{background:var(--bg-elevated);border-radius:var(--radius);position:relative;overflow:hidden}
.skeleton::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 50%,transparent 100%);animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-text:last-child{width:60%}
.skeleton-heading{height:24px;width:40%;margin-bottom:var(--space-4)}
.skeleton-card{height:200px}
.skeleton-avatar{width:32px;height:32px;border-radius:var(--radius-full)}

/* 16. FLASH / TOAST MESSAGES =============================================== */
.flash-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}
.flash-msg{padding:var(--space-3) var(--space-5);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;pointer-events:auto;animation:flashIn .3s var(--ease) forwards;display:flex;align-items:center;gap:var(--space-3);box-shadow:var(--shadow-lg);max-width:400px;background:var(--bg-surface)}
.flash-msg.success{border:1px solid rgba(74,222,128,.3);color:var(--success)}
.flash-msg.error{border:1px solid rgba(248,113,113,.3);color:var(--danger)}
.flash-msg.info{border:1px solid rgba(45,212,191,.3);color:var(--teal)}
.flash-msg.out{animation:flashOut .3s var(--ease) forwards}
@keyframes flashIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes flashOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(40px)}}
.flash-close{margin-left:auto;opacity:.5;cursor:pointer;padding:2px}.flash-close:hover{opacity:1}

/* 17. CONFIRM MODAL ======================================================== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;visibility:hidden;transition:all var(--dur)}
.modal-overlay.active{opacity:1;visibility:visible}
.modal-dialog{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);max-width:400px;width:90%;box-shadow:var(--shadow-lg)}
.modal-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}
.modal-desc{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-6)}
.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end}

/* 18. RANK BADGES ========================================================== */
.rank-badge{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700}
.rank-1{background:linear-gradient(135deg,#f59e0b,#d97706);color:#000}
.rank-2{background:linear-gradient(135deg,#94a3b8,#64748b);color:#000}
.rank-3{background:linear-gradient(135deg,#d97706,#92400e);color:#fff}
.rank-default{background:var(--bg-hover);color:var(--text-muted)}

/* =========================================================================
   PAGE-SPECIFIC STYLES
   ========================================================================= */

/* PUBLIC LAYOUT */
.public-body{background:var(--bg-base)}
.public-nav{position:fixed;top:0;left:0;right:0;height:64px;display:flex;align-items:center;padding:0 var(--space-8);background:rgba(13,13,15,.7);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:100}
.public-nav-logo{display:flex;align-items:center;gap:var(--space-3)}
.public-nav-right{margin-left:auto;display:flex;align-items:center;gap:var(--space-6)}
.public-nav-right a{font-size:var(--text-sm);font-weight:500;color:var(--text-muted)}.public-nav-right a:hover{color:var(--text-primary)}
.public-footer{padding:var(--space-8);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;max-width:1100px;margin:0 auto}
.public-footer-links{display:flex;gap:var(--space-6)}
.public-footer-links a{font-size:var(--text-sm);color:var(--text-faint)}.public-footer-links a:hover{color:var(--text-muted)}

/* HERO */
.hero{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-12);align-items:center;padding:140px var(--space-8) var(--space-16);max-width:1100px;margin:0 auto}
.hero-eyebrow{display:inline-flex;align-items:center;gap:var(--space-2);padding:4px 12px;border-radius:var(--radius-full);background:var(--teal-dim);color:var(--teal);font-size:var(--text-xs);font-weight:600;margin-bottom:var(--space-5)}
.hero-eyebrow .lucide{width:14px;height:14px}
.hero-title{font-family:var(--font-display);font-size:var(--text-5xl);font-weight:800;letter-spacing:-.03em;line-height:1.08;margin-bottom:var(--space-5)}
.hero-sub{font-size:var(--text-lg);color:var(--text-muted);max-width:55ch;line-height:1.65;margin-bottom:var(--space-8)}
.hero-ctas{display:flex;gap:var(--space-4);flex-wrap:wrap}

/* Mini dashboard mockup in hero */
.hero-mockup{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-lg)}
.mockup-row{display:flex;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--border);align-items:center}
.mockup-row:last-child{border-bottom:none}
.mockup-dot{width:36px;height:36px;border-radius:var(--radius);background:var(--bg-elevated);flex-shrink:0}
.mockup-lines{flex:1}
.mockup-line{height:8px;border-radius:4px;background:var(--bg-elevated);margin-bottom:6px}
.mockup-line:last-child{width:60%;margin-bottom:0}
.mockup-badge-sm{padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:700}

/* Social proof */
.social-proof{padding:var(--space-8);text-align:center;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;justify-content:center;gap:var(--space-10);flex-wrap:wrap}
.social-stat{font-size:var(--text-sm);color:var(--text-faint);font-weight:500}
.social-stat strong{color:var(--text-muted);font-weight:700}

/* Features */
.features{padding:var(--space-16) var(--space-8);max-width:1100px;margin:0 auto}
.features-row{display:grid;gap:var(--space-5);margin-bottom:var(--space-5)}
.features-row-asym{grid-template-columns:1.2fr .8fr}
.features-row-3{grid-template-columns:repeat(3,1fr)}

.feature-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6)}
.feature-card-lg{padding:var(--space-8);min-height:340px;display:flex;flex-direction:column;justify-content:flex-end}
.feature-icon{width:40px;height:40px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4)}
.feature-icon .lucide{width:20px;height:20px}
.feature-icon.accent{background:var(--accent-glow);color:var(--accent)}
.feature-icon.teal{background:var(--teal-dim);color:var(--teal)}
.feature-icon.gold{background:var(--gold-dim);color:var(--gold)}
.feature-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}
.feature-desc{font-size:var(--text-sm);color:var(--text-muted);line-height:1.65}

/* Pricing */
.pricing{padding:var(--space-16) var(--space-8);max-width:480px;margin:0 auto;text-align:center}
.pricing-heading{font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-2)}
.pricing-sub{color:var(--text-muted);margin-bottom:var(--space-8)}
.pricing-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);text-align:left;box-shadow:0 0 60px -12px rgba(255,77,109,.08)}
.pricing-amount{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:800}
.pricing-amount span{font-size:var(--text-base);font-weight:500;color:var(--text-muted)}
.pricing-features{margin:var(--space-6) 0;display:flex;flex-direction:column;gap:var(--space-3)}
.pricing-feature{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-muted)}
.pricing-feature .lucide{width:18px;height:18px;color:var(--teal);flex-shrink:0}
.coupon-pill{margin-top:var(--space-5);padding:var(--space-3) var(--space-4);border:1px dashed var(--accent);border-radius:var(--radius);background:var(--accent-glow);text-align:center}
.coupon-code{font-family:var(--font-display);font-weight:800;color:var(--accent);font-size:var(--text-lg);letter-spacing:.04em}
.coupon-desc{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}

/* AUTH PAGE */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:var(--bg-base);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E")}
.auth-card{width:100%;max-width:420px}
.auth-logo{display:flex;align-items:center;gap:var(--space-3);justify-content:center;margin-bottom:var(--space-8)}
.auth-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-lg)}
.auth-form .input-group{margin-bottom:var(--space-5)}
.auth-form .btn{width:100%;margin-top:var(--space-4)}
.auth-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-6) 0;color:var(--text-faint);font-size:var(--text-xs)}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-footer{text-align:center;margin-top:var(--space-5);font-size:var(--text-sm);color:var(--text-muted)}

/* SUBSCRIBE PAGE */
.subscribe-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-10);max-width:900px;margin:0 auto;align-items:start}
.subscribe-features{padding-top:var(--space-6)}
.subscribe-features h2{font-size:var(--text-2xl);margin-bottom:var(--space-6)}
.subscribe-feature-item{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4);font-size:var(--text-sm);color:var(--text-muted)}
.subscribe-feature-item .lucide{width:20px;height:20px;color:var(--teal);flex-shrink:0;margin-top:2px}
.subscribe-payment{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:0 0 60px -12px rgba(255,77,109,.08)}
.coupon-row{display:flex;gap:var(--space-2);margin-top:var(--space-5)}
.coupon-row .input{flex:1}
.coupon-result{margin-top:var(--space-3);font-size:var(--text-sm);font-weight:500}
.coupon-result.valid{color:var(--success)}.coupon-result.invalid{color:var(--danger)}

/* SETTINGS VERTICAL TABS */
.settings-layout{display:grid;grid-template-columns:200px 1fr;gap:var(--space-8)}
.settings-tabs{display:flex;flex-direction:column;gap:2px}
.settings-tab{padding:var(--space-3) var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;color:var(--text-muted);cursor:pointer;transition:all var(--dur-fast);text-align:left}
.settings-tab:hover{color:var(--text-primary);background:var(--bg-hover)}
.settings-tab.active{color:var(--accent);background:var(--accent-glow)}

/* 19. MOBILE TAB BAR ======================================================= */
.mob-bar{display:none}

@media(max-width:768px){
.mob-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--bg-surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);height:calc(64px + env(safe-area-inset-bottom));align-items:flex-start}
.mob-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 4px 6px;text-decoration:none;color:var(--text-faint);min-height:56px;-webkit-tap-highlight-color:transparent;transition:color 150ms}
.mob-tab span{font-size:10px;font-weight:500;line-height:1;margin-top:3px}
.mob-tab:active{opacity:.7}
.mob-tab--active{color:var(--accent)}
.mob-tab--center{margin-top:-14px}
.mob-tab-zap{background:var(--accent);border-radius:14px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(232,56,77,.4);color:#fff;margin-bottom:2px}
.mob-tab-zap svg{stroke:#fff}
.mob-tab--center span{color:var(--accent);font-weight:600}

/* Hide sidebar, adjust layout */
.sidebar{display:none !important}
.main-area{margin-left:0 !important;padding-bottom:calc(80px + env(safe-area-inset-bottom)) !important}
.upgrade-fab{bottom:calc(80px + env(safe-area-inset-bottom) + 12px) !important}
.chat-fab{bottom:calc(80px + env(safe-area-inset-bottom) + 12px) !important}
.chat-drawer{bottom:calc(140px + env(safe-area-inset-bottom)) !important}

/* Compact topbar */
.topbar{height:48px;padding:0 var(--space-4)}
.topbar-search{max-width:none}

/* Single column products */
.product-grid{column-count:1 !important}
.product-table-wrap{font-size:12px}

/* Stat grid */
.stat-grid{grid-template-columns:1fr 1fr !important;gap:var(--space-3) !important}

/* Filter card mobile */
.filter-card{padding:12px}
.filter-row{flex-direction:column;gap:6px}
.filter-input{width:100% !important;min-width:0 !important}
.filter-actions{flex-wrap:wrap}

/* Detail layout single col */
.detail-layout{grid-template-columns:1fr !important}

/* Chart grid single col */
.chart-grid{grid-template-columns:1fr !important}
}

/* 20. ANIMATIONS =========================================================== */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.anim-fade-in{animation:fadeIn .4s var(--ease) forwards}
.anim-slide-up{animation:slideUp .5s var(--ease) forwards}
.anim-pulse{animation:pulse 2s ease-in-out infinite}

/* 21. RESPONSIVE =========================================================== */
@media(max-width:1024px){
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .product-grid{column-count:2}
  .chart-grid{grid-template-columns:1fr}
  .detail-layout{grid-template-columns:1fr}
  .hero{grid-template-columns:1fr;padding-top:120px}
  .hero-mockup{display:none}
  .features-row-asym,.features-row-3{grid-template-columns:1fr}
  .subscribe-layout{grid-template-columns:1fr}
  .settings-layout{grid-template-columns:1fr}
  .settings-tabs{flex-direction:row;overflow-x:auto}
}

@media(max-width:768px){
  .page-content{padding:var(--space-4)}
  .hero{padding:100px var(--space-5) var(--space-10)}
  .hero-title{font-size:var(--text-3xl)}
  .hero-sub{font-size:var(--text-base)}
  .public-nav{padding:0 var(--space-4)}
  .public-nav-right{gap:var(--space-3)}
  .social-proof{flex-direction:column;gap:var(--space-4)}
}

@media(max-width:480px){
  .stat-grid{grid-template-columns:1fr}
  .hero-ctas{flex-direction:column;align-items:stretch}
}

/* 22. UTILITIES ============================================================ */
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}
.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}
.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}
.w-full{width:100%}.text-center{text-align:center}
.hidden{display:none !important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* 23. UPGRADE FAB + BANNER ================================================= */
.upgrade-fab{position:fixed;right:24px;bottom:32px;z-index:100;display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--accent);color:#fff;font-weight:600;font-size:14px;border-radius:var(--radius-full);text-decoration:none;box-shadow:0 4px 20px rgba(255,77,109,.45);transition:transform var(--dur) var(--ease),box-shadow var(--dur) ease}
.upgrade-fab:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(255,77,109,.55);color:#fff}
.upgrade-fab:active{transform:translateY(0)}
.upgrade-fab i{width:16px;height:16px}
@media(max-width:767px){.upgrade-fab{bottom:80px;right:16px}}

.upgrade-banner{display:flex;align-items:center;gap:10px;padding:10px 20px;background:rgba(255,77,109,.1);border-bottom:1px solid rgba(255,77,109,.2);font-size:14px;color:var(--text-primary)}
.upgrade-banner__cta{margin-left:auto;color:var(--accent);font-weight:600;text-decoration:none;white-space:nowrap}
.upgrade-banner__cta:hover{text-decoration:underline}

/* 27. SCORE RING =========================================================== */
.score-ring-wrap{position:relative;width:44px;height:44px;flex-shrink:0}
.score-ring{position:absolute;top:0;left:0}
.score-number{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;color:var(--text-primary)}

/* 28. CATEGORY GRADIENT PLACEHOLDERS ======================================= */
.product-img-placeholder{border-radius:var(--radius);width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:rgba(255,255,255,.5)}
.cat-beauty{background:linear-gradient(135deg,#f953c6,#b91d73)}
.cat-electronics{background:linear-gradient(135deg,#4776e6,#1cb5e0)}
.cat-fashion{background:linear-gradient(135deg,#f7971e,#ffd200)}
.cat-home{background:linear-gradient(135deg,#56ab2f,#a8e063)}
.cat-health{background:linear-gradient(135deg,#11998e,#38ef7d)}
.cat-food{background:linear-gradient(135deg,#f46b45,#eea849)}
.cat-sports{background:linear-gradient(135deg,#396afc,#2948ff)}
.cat-pets{background:linear-gradient(135deg,#f7971e,#ff6b6b)}
.cat-default{background:linear-gradient(135deg,#434343,#2c2c2c)}

/* 29. TAP BADGE + CALLOUT ================================================== */
.tap-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:var(--teal);background:var(--teal-dim);border:1px solid rgba(54,217,196,.25);border-radius:var(--radius-full);padding:3px 8px}

.tap-callout{background:linear-gradient(135deg,rgba(54,217,196,.06),rgba(54,217,196,.02));border:1px solid rgba(54,217,196,.25);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:24px}
.tap-callout__header{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.tap-callout__title{font-size:14px;font-weight:700;color:var(--teal)}
.tap-callout__partner{font-size:12px;color:var(--text-muted);margin-left:auto}
.tap-callout__expiry{font-size:12px;color:var(--text-muted);margin:10px 0 14px}
.tap-callout__rates{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.tap-rate{display:flex;flex-direction:column;gap:2px}
.tap-rate-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.tap-rate-value{font-size:24px;font-weight:800;color:var(--text-primary)}
.tap-rate-value--highlight{color:var(--teal)}
.tap-rate-arrow{font-size:18px;color:var(--text-faint)}

.btn-tap-copy{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--teal-dim);border:1px solid rgba(54,217,196,.3);border-radius:var(--radius);color:var(--teal);font-size:13px;font-weight:600;cursor:pointer;transition:background var(--dur)}
.btn-tap-copy:hover{background:rgba(54,217,196,.2)}

/* 30. NAV BADGE ============================================================ */
.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 5px}

/* 31. USER TIER BADGE ====================================================== */
.user-tier-badge{font-size:9px;font-weight:800;letter-spacing:.08em;padding:2px 6px;border-radius:4px}
.user-tier-badge--pro{background:var(--accent-glow);color:var(--accent);border:1px solid rgba(255,82,114,.3)}
.user-tier-badge--free{background:rgba(255,255,255,.06);color:var(--text-muted);border:1px solid var(--border)}

/* 32. TAP PRODUCT SEARCH DROPDOWN ========================================== */
.tap-product-dropdown{position:absolute;top:100%;left:0;right:0;max-height:280px;overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius);z-index:50;box-shadow:var(--shadow-lg);margin-top:4px}
.tap-product-option{padding:10px 14px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);transition:background var(--dur-fast)}
.tap-product-option:hover{background:var(--bg-hover)}
.tap-product-option:last-child{border-bottom:none}

/* 33. STATS PANEL (Product Detail) ========================================= */
.stats-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.stats-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--bg-base)}
.stats-tab{flex:1;padding:12px 8px;font-size:13px;font-weight:500;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--dur-fast)}
.stats-tab:hover{color:var(--text-primary);background:rgba(255,255,255,.02)}
.stats-tab--active{color:var(--accent);border-bottom-color:var(--accent)}

.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border)}
.stat-card-mini{background:var(--bg-surface);padding:16px 18px;display:flex;flex-direction:column;gap:3px}
.stat-card-mini .stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}
.stat-card-mini .stat-value{font-size:20px;font-weight:700;color:var(--text-primary);line-height:1.2}
.stat-delta{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:500;margin-top:2px}
.stat-delta--up{color:var(--success)}
.stat-delta--down{color:var(--danger)}

.stats-commission-row{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border);background:var(--bg-base)}
.commission-highlight{padding:12px 18px;display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--border)}
.commission-highlight:last-child{border-right:none}
.commission-highlight__label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-weight:600}
.commission-highlight__value{font-size:16px;font-weight:700;color:var(--accent)}

/* 24. FEATURES SECTION (Landing Page v2) =================================== */
/* Landing section backgrounds */
.landing-section--alt{background:rgba(255,255,255,0.03)}
.landing-section--dark{background:#0a0a0c}

.features-section{padding:clamp(64px,8vw,120px) 0;background:#0e0e10}
.features-container{max-width:1100px;margin:0 auto;padding:0 24px}
.features-header{margin-bottom:56px}
.features-eyebrow{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.features-title{font-size:clamp(28px,3.5vw,44px);font-weight:700;line-height:1.15;color:var(--text-primary)}

/* Feature Hero */
.feature-hero{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px;margin-bottom:24px}
@media(max-width:768px){.feature-hero{grid-template-columns:1fr;padding:28px}}
.feature-tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);background:var(--teal-dim);border:1px solid rgba(45,212,191,.2);border-radius:var(--radius-full);padding:3px 10px;margin-bottom:16px}
.feature-hero__content h3{font-size:clamp(20px,2vw,26px);font-weight:700;color:var(--text-primary);margin-bottom:12px;line-height:1.3}
.feature-hero__content p{font-size:15px;color:var(--text-muted);line-height:1.7;margin-bottom:20px}
.feature-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.feature-list li{display:flex;align-items:center;gap:10px;font-size:14px;color:#c5c3bf}
.feature-list li i{width:16px;height:16px;color:var(--teal);flex-shrink:0}

/* Product Card Mockup */
.mockup-card-stack{display:flex;flex-direction:column;gap:10px}
.mockup-product-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;display:flex;gap:12px;padding:12px;align-items:flex-start}
.mockup-product-card--2{opacity:.85;transform:scale(.98)}
.mockup-product-card--3{opacity:.7;transform:scale(.96)}
.mockup-img{width:52px;height:52px;border-radius:var(--radius);flex-shrink:0}
.mockup-img--1{background:linear-gradient(135deg,#ff4d6d,#ff8a65)}
.mockup-img--2{background:linear-gradient(135deg,#2dd4bf,#7c3aed)}
.mockup-img--3{background:linear-gradient(135deg,#fbbf24,#f97316)}
.mockup-card-body{flex:1;min-width:0}
.mockup-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);display:inline-block;margin-bottom:4px}
.mockup-badge--hot{background:var(--accent-glow);color:var(--accent)}
.mockup-badge--warm{background:var(--gold-dim);color:var(--gold)}
.mockup-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mockup-meta{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px}
.mockup-commission{color:var(--accent);font-weight:600}
.mockup-price{color:var(--text-muted)}
.mockup-bar{height:3px;background:var(--border);border-radius:var(--radius-full)}
.mockup-bar-fill{height:100%;background:linear-gradient(90deg,#ff4d6d,#ff8a65);border-radius:var(--radius-full)}

/* Features Grid (below hero) */
.features-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;margin-bottom:24px}
@media(max-width:768px){.features-grid{grid-template-columns:1fr}}
.features-stack{display:flex;flex-direction:column;gap:24px}
.feature-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.feature-card--large{padding:32px}
.feature-card .feature-icon,.feature-discord-banner .feature-icon{width:22px;height:22px;color:var(--accent);margin-bottom:14px}
.feature-card h3{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:10px}
.feature-card p{font-size:14px;color:var(--text-muted);line-height:1.7}

/* Mini Calc Mockup */
.mini-calc-mockup{margin-top:20px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.calc-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text-muted);padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.calc-row:last-child{border-bottom:none}
.calc-row--total{padding-top:10px}
.calc-value{color:var(--text-primary);font-weight:500}
.calc-value--highlight{color:var(--teal);font-weight:700;font-size:15px}

/* Discord Banner */
.feature-discord-banner{background:linear-gradient(135deg,#141416,#1a1a2e);border:1px solid rgba(88,101,242,.3);border-radius:var(--radius-lg);padding:32px 40px;display:flex;align-items:center;justify-content:space-between;gap:32px}
@media(max-width:768px){.feature-discord-banner{flex-direction:column;padding:24px}}
.feature-discord-banner__text{display:flex;align-items:flex-start;gap:16px}
.feature-discord-banner__text .feature-icon{color:#5865f2;margin-bottom:0;flex-shrink:0;margin-top:2px}
.feature-discord-banner__text h3{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:6px}
.feature-discord-banner__text p{font-size:14px;color:var(--text-muted);line-height:1.7;max-width:400px}
.feature-discord-banner__text code{background:rgba(255,255,255,.1);padding:2px 6px;border-radius:4px;font-size:13px;color:var(--text-primary)}

.discord-msg-mockup{display:flex;gap:12px;align-items:flex-start;background:#36393f;border-radius:var(--radius);padding:12px 16px;min-width:280px}
.discord-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#5865f2,#2dd4bf);flex-shrink:0}
.discord-name{display:block;font-size:13px;font-weight:700;color:#5865f2;margin-bottom:4px}
.discord-bubble{font-size:13px;color:#dcddde;line-height:1.5}
.discord-bubble a{color:#5865f2}

/* 25. PRICING SECTION (Landing Page v2) ==================================== */
.pricing-section{padding:clamp(64px,8vw,120px) 0;background:var(--bg-surface)}
.pricing-container{max-width:1000px;margin:0 auto;padding:0 24px}
.pricing-header{margin-bottom:48px}
.pricing-sub{font-size:16px;color:var(--text-muted);margin-top:12px;max-width:480px}
.pricing-layout{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start}
@media(max-width:768px){.pricing-layout{grid-template-columns:1fr}}

.pricing-card{background:var(--bg-elevated);border:1px solid rgba(255,77,109,.3);border-radius:var(--radius-xl);padding:36px;box-shadow:0 0 40px rgba(255,77,109,.06)}
.pricing-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}
.pricing-plan-name{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.pricing-price{display:flex;align-items:baseline;gap:4px}
.pricing-amount{font-size:40px;font-weight:800;color:var(--text-primary);line-height:1}
.pricing-period{font-size:15px;color:var(--text-muted)}
.pricing-badge{font-size:11px;font-weight:700;color:var(--accent);background:var(--accent-glow);border:1px solid rgba(255,77,109,.3);border-radius:var(--radius-full);padding:4px 10px;white-space:nowrap}
.pricing-coupon-callout{display:flex;align-items:center;gap:8px;background:var(--teal-dim);border:1px solid rgba(45,212,191,.2);border-radius:var(--radius);padding:10px 14px;font-size:13px;color:var(--teal);margin-bottom:24px}
.pricing-coupon-callout i{width:14px;height:14px;flex-shrink:0}
.pricing-coupon-callout strong{color:var(--text-primary)}

.pricing-features{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.pricing-features li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#c5c3bf;line-height:1.5}
.pricing-features li i{width:16px;height:16px;color:var(--teal);flex-shrink:0;margin-top:2px}
.pricing-features code{background:rgba(255,255,255,.08);padding:1px 5px;border-radius:4px;font-size:12px}

.btn-pricing-cta{display:block;width:100%;text-align:center;padding:14px 24px;background:var(--accent);color:#fff;font-weight:700;font-size:15px;border-radius:10px;text-decoration:none;transition:background var(--dur) ease,transform var(--dur) ease;margin-bottom:12px}
.btn-pricing-cta:hover{background:var(--accent-hover);transform:translateY(-1px);color:#fff}
.pricing-card__note{font-size:12px;color:var(--text-faint);text-align:center}

/* Value Props */
.pricing-value-props{display:flex;flex-direction:column;gap:20px}
.value-prop{display:flex;gap:14px;align-items:flex-start}
.value-prop i{width:20px;height:20px;color:var(--accent);flex-shrink:0;margin-top:2px}
.value-prop strong{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}
.value-prop p{font-size:13px;color:var(--text-muted);line-height:1.6;margin:0}

/* 26. ADMIN SCAN STATUS ==================================================== */
.scan-status-box{padding:14px 18px;border-radius:var(--radius);font-size:var(--text-sm);line-height:1.6}
.scan-status-info{background:var(--teal-dim);border:1px solid rgba(45,212,191,.2);color:var(--teal)}
.scan-status-success{background:var(--success-dim);border:1px solid rgba(74,222,128,.2);color:var(--success)}
.scan-status-error{background:var(--danger-dim);border:1px solid rgba(248,113,113,.2);color:var(--danger)}

/* 34. VIEW TOGGLE ========================================================== */
.view-toggle{display:flex;gap:2px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:2px}
.view-toggle-btn{padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all var(--dur-fast);display:flex;align-items:center}
.view-toggle-btn:hover{color:var(--text-primary)}
.view-toggle-btn.active{background:var(--accent);color:#fff}
.view-toggle-btn .lucide{width:16px;height:16px}

/* 35. PRODUCT TABLE VIEW =================================================== */
.product-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-surface);box-shadow:var(--shadow-sm)}
.product-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
.product-table th{text-align:left;padding:11px 14px;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-elevated);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;z-index:2}
.th-sort{color:var(--text-muted);text-decoration:none;cursor:pointer;transition:color var(--dur-fast)}.th-sort:hover{color:var(--text-primary)}.th-sort--active{color:var(--accent);font-weight:700}
.product-table td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-primary)}
.product-table tbody tr{transition:background 100ms ease}
.product-table tbody tr:hover{background:var(--bg-hover)}
.product-table tbody tr:last-child td{border-bottom:none}
.product-table .product-row-name{display:flex;align-items:center;gap:12px;min-width:240px}
.product-row-thumb{width:48px;height:48px;border-radius:var(--radius);object-fit:cover;background:var(--bg-elevated);flex-shrink:0;border:1px solid var(--border)}
.product-row-thumb-fallback{width:48px;height:48px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:rgba(255,255,255,.5);flex-shrink:0}
.product-table .commission-cell{color:var(--accent);font-weight:700;font-size:15px}
.product-table .growth-badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:var(--radius-full)}
.growth-badge--up{background:var(--success-dim);color:var(--success)}
.growth-badge--down{background:var(--danger-dim);color:var(--danger)}
.growth-badge--flat{background:transparent;color:var(--text-faint)}

/* 36. FEE CALCULATOR ======================================================= */
.fee-calc{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5)}
.fee-calc-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}
.fee-calc-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:var(--text-sm)}
.fee-calc-row:last-child{border-bottom:none}
.fee-calc-row .label{color:var(--text-muted)}
.fee-calc-row .value{font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}
.fee-calc-row .value.highlight{color:var(--teal);font-size:var(--text-lg)}
.fee-calc-inputs{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-4)}

/* 37. PAYWALL OVERLAY ====================================================== */
.paywall-overlay{position:relative;margin-top:-60px;padding-top:80px;background:linear-gradient(to bottom,transparent 0%,var(--bg-base) 40%);text-align:center;padding-bottom:var(--space-8)}
.paywall-card{display:inline-flex;flex-direction:column;align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:32px 40px;box-shadow:var(--shadow-md);max-width:420px}

/* Free user table blur (rows 6+) */
.product-table tbody tr:nth-child(n+6) .free-blur{filter:blur(6px);user-select:none;pointer-events:none}

/* 38. THEME TOGGLE ========================================================= */
.theme-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;color:var(--text-muted);transition:all var(--dur-fast)}
.theme-toggle:hover{color:var(--text-primary);background:var(--bg-hover)}

/* 38. AI CHAT WIDGET ======================================================= */
.chat-fab{position:fixed;bottom:24px;right:24px;z-index:200;width:52px;height:52px;border-radius:var(--radius-full);background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(232,56,77,.35);cursor:pointer;transition:all var(--dur) var(--ease);border:none}
.chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(232,56,77,.45)}
.chat-fab .lucide{width:24px;height:24px}
@media(max-width:767px){.chat-fab{bottom:80px}}

.chat-drawer{position:fixed;bottom:88px;right:24px;z-index:200;width:380px;max-height:520px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);display:none;flex-direction:column;overflow:hidden}
.chat-drawer.open{display:flex}
@media(max-width:480px){.chat-drawer{right:8px;left:8px;width:auto;bottom:80px;max-height:70vh}}

.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:200px;max-height:340px}
.chat-msg{padding:10px 14px;border-radius:var(--radius-lg);font-size:var(--text-sm);line-height:1.55;max-width:90%;word-wrap:break-word}
.chat-msg--ai{background:var(--bg-elevated);color:var(--text-primary);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg--user{background:var(--accent);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-msg--loading{color:var(--text-muted);font-style:italic}
.chat-input-wrap{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}
.chat-input-wrap .input{flex:1}

/* 39. FAVORITE / WATCHLIST BUTTON ========================================== */
.fav-btn{position:absolute;bottom:8px;right:8px;z-index:5;width:32px;height:32px;border-radius:var(--radius-full);background:rgba(0,0,0,0.45);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--dur-fast);border:none;color:rgba(255,255,255,0.7)}
.fav-btn:hover{background:rgba(0,0,0,0.6);color:#fff;transform:scale(1.1)}
.fav-btn.active{color:var(--accent);background:rgba(232,56,77,0.2)}
.fav-btn .lucide{width:16px;height:16px}

/* Inline favorite button for table rows */
.fav-btn-inline{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;background:transparent;color:var(--text-faint);transition:all var(--dur-fast)}
.fav-btn-inline:hover{color:var(--accent);background:var(--accent-glow)}
.fav-btn-inline.active{color:var(--accent)}

/* 40. CAMPAIGN ANNOUNCEMENT BANNER ======================================== */
.campaign-banner{overflow:hidden;max-height:44px;transition:all .3s ease}
.campaign-banner__inner{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-4);height:44px;font-size:13px;font-weight:500;color:#fff;position:relative}
.campaign-banner__icon{flex-shrink:0;display:flex;align-items:center;opacity:.9}
.campaign-banner__marquee{flex:1;overflow:hidden;position:relative;mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.campaign-banner__track{display:flex;gap:var(--space-16);white-space:nowrap;animation:marquee 25s linear infinite}
.campaign-banner__track:hover{animation-play-state:paused}
.campaign-banner__text{display:inline-flex;gap:var(--space-2);align-items:center}
.campaign-banner__text strong{font-weight:800;letter-spacing:.02em}
.campaign-banner__link{color:inherit;text-decoration:underline;text-underline-offset:2px;font-weight:700;margin-left:var(--space-2);opacity:.9;transition:opacity .2s}
.campaign-banner__link:hover{opacity:1}
.campaign-banner__right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}
.campaign-banner__countdown{font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;background:rgba(0,0,0,.2);padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.03em}
.campaign-banner__close{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;display:flex;align-items:center;padding:4px;border-radius:var(--radius-full);transition:all .2s}
.campaign-banner__close:hover{color:#fff;background:rgba(255,255,255,.15)}

@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* Color schemes */
.campaign-banner--fire{background:linear-gradient(135deg,#e8384d 0%,#f97316 50%,#e8384d 100%);background-size:200% 200%;animation:bannerShimmer 4s ease infinite}
.campaign-banner--gold{background:linear-gradient(135deg,#d97706 0%,#f59e0b 50%,#d97706 100%);background-size:200% 200%;animation:bannerShimmer 4s ease infinite}
.campaign-banner--teal{background:linear-gradient(135deg,#0d9488 0%,#2dd4bf 50%,#0d9488 100%);background-size:200% 200%;animation:bannerShimmer 4s ease infinite}
.campaign-banner--purple{background:linear-gradient(135deg,#7c3aed 0%,#a78bfa 50%,#7c3aed 100%);background-size:200% 200%;animation:bannerShimmer 4s ease infinite}
.campaign-banner--coral{background:linear-gradient(135deg,#e8384d 0%,#f472b6 50%,#e8384d 100%);background-size:200% 200%;animation:bannerShimmer 4s ease infinite}

@keyframes bannerShimmer{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* Admin campaign page helpers */
.campaign-scheme-dot{width:10px;height:10px;border-radius:var(--radius-full);display:inline-block;margin-right:4px;vertical-align:middle}
.campaign-scheme-dot--fire{background:#e8384d}
.campaign-scheme-dot--gold{background:#d97706}
.campaign-scheme-dot--teal{background:#0d9488}
.campaign-scheme-dot--purple{background:#7c3aed}
.campaign-scheme-dot--coral{background:#f472b6}

.status-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);letter-spacing:.05em;text-transform:uppercase}
.status-badge--live{background:rgba(13,148,136,.15);color:#0d9488}
.status-badge--upcoming{background:rgba(217,119,6,.15);color:#d97706}
.status-badge--active{background:rgba(37,99,235,.15);color:#2563eb}
.status-badge--off{background:rgba(156,163,175,.15);color:#9ca3af}

/* Mobile: smaller banner */
@media(max-width:768px){
  .campaign-banner__inner{height:38px;font-size:12px;padding:0 var(--space-3)}
  .campaign-banner{max-height:38px}
  .campaign-banner__countdown{font-size:10px;padding:2px 6px}
}

/* 41. SKIP LINK ============================================================ */
.skip-link{position:absolute;top:-100px;left:16px;background:var(--accent);color:#fff;padding:8px 16px;border-radius:var(--radius);font-weight:700;font-size:14px;z-index:9999;transition:top .2s}
.skip-link:focus{top:16px}

/* 42. FOCUS VISIBLE STYLES ================================================= */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}
button:focus-visible,a:focus-visible,.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--teal);outline-offset:0}

/* 43. HOW IT WORKS GRID (landing) ========================================== */
.how-it-works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;text-align:left}
@media(max-width:768px){.how-it-works-grid{grid-template-columns:1fr;gap:24px}}

/* 44. TESTIMONIALS ========================================================= */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:24px;text-align:left}
.testimonial-quote{font-size:14px;color:var(--text-secondary);line-height:1.7;margin-bottom:16px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}
.testimonial-author strong{display:block;font-size:13px;color:var(--text-primary)}
.testimonial-author span{font-size:11px;color:var(--text-faint)}
@media(max-width:768px){.testimonials-grid{grid-template-columns:1fr;gap:16px}}

/* 45. FAQ ACCORDION ======================================================== */
.faq-list{display:flex;flex-direction:column;gap:0}
.faq-item{border-bottom:1px solid rgba(255,255,255,0.08);padding:0}
.faq-question{font-size:15px;font-weight:600;color:var(--text-primary);padding:16px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-question::after{content:'+';font-size:20px;font-weight:400;color:var(--text-faint);transition:transform .2s}
.faq-item[open] .faq-question::after{content:'-'}
.faq-answer{font-size:14px;color:var(--text-muted);line-height:1.7;padding:0 0 16px}
.faq-question::-webkit-details-marker{display:none}

/* 46. MOBILE FILTER IMPROVEMENTS =========================================== */
@media(max-width:768px){
  .filter-card{padding:var(--space-3)}
  .filter-row{flex-direction:column;gap:var(--space-2)}
  .filter-row .filter-input{width:100%!important;min-width:0!important}
  .filter-actions{flex-wrap:wrap;gap:var(--space-2)}
}

/* 47. MOBILE BOTTOM NAV CONTENT PADDING ==================================== */
@media(max-width:768px){
  .page-content{padding-bottom:100px}
}

/* 48. LANDING TRENDING TABLE MOBILE ======================================== */
@media(max-width:640px){
  [style*="grid-template-columns:40px 1fr 80px 80px 80px"]{
    grid-template-columns:28px 1fr 60px 60px!important;
    font-size:11px!important;
  }
}

/* 49. BRAND HUNTER PREMIUM STYLES ========================================= */

/* Brand avatar fallback (letter circle — like Discord avatars) */
.brand-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),#d97706);color:#fff;font-size:32px;font-weight:800;font-family:var(--font-display);letter-spacing:-.02em}

/* Brand detail header avatar fallback */
.brand-header-avatar-fallback{width:64px;height:64px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent),#d97706);display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:800;font-family:var(--font-display);border:2px solid var(--border);flex-shrink:0}

/* Hidden Gem badge (card overlay) */
.brand-gem-badge{position:absolute;bottom:8px;right:8px;background:linear-gradient(135deg,#d97706,#f59e0b);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--radius);letter-spacing:.03em;box-shadow:0 2px 8px rgba(217,119,6,.4);animation:gemShimmer 3s ease infinite;background-size:200% 200%}

/* Hidden Gem inline badge (detail header) */
.brand-gem-badge-inline{display:inline-flex;align-items:center;gap:2px;background:linear-gradient(135deg,#d97706,#f59e0b);color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:var(--radius);letter-spacing:.03em;animation:gemShimmer 3s ease infinite;background-size:200% 200%}

@keyframes gemShimmer{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* Brand letter avatar (compact, for tables and lists) */
.brand-letter-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent),#d97706);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px;font-family:var(--font-display);flex-shrink:0}

/* 50. BRAND HUNTER v2 — SCAN UI =========================================== */

/* Page range radio buttons */
.scan-range-group{display:flex;gap:var(--space-2);flex-wrap:wrap;margin:var(--space-4) 0}
.scan-range-opt{position:relative}
.scan-range-opt input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.scan-range-opt label{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--dur-fast)}
.scan-range-opt input:checked+label{border-color:var(--accent);background:var(--accent-glow);color:var(--accent)}
.scan-range-opt:hover label{border-color:var(--border-strong)}

/* Gold shimmer for Hidden Gems option */
.scan-range--gem input:checked+label{border-color:#d97706;background:rgba(217,119,6,.1);color:#d97706}
.scan-range--gem label{border-color:rgba(217,119,6,.3);animation:gemBorderPulse 3s ease infinite}
@keyframes gemBorderPulse{
  0%,100%{border-color:rgba(217,119,6,.3)}
  50%{border-color:rgba(217,119,6,.6)}
}

/* Custom range inputs */
.scan-custom-inputs{display:none;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}
.scan-custom-inputs.visible{display:flex}
.scan-custom-inputs input{width:70px}

/* Scan progress bar */
.scan-progress{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-6)}
.scan-progress__info{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3);font-size:13px;font-weight:600}
.scan-progress__bar{height:8px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden}
.scan-progress__fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--accent),#f97316,var(--teal));background-size:200% 100%;animation:scanBarShimmer 2s linear infinite;transition:width .5s ease}
@keyframes scanBarShimmer{
  0%{background-position:200% 0}
  100%{background-position:0 0}
}
.scan-progress__detail{font-size:12px;color:var(--text-muted);margin-top:var(--space-2);font-variant-numeric:tabular-nums}

/* Brand search dropdown */
.brand-search-wrap{position:relative}
.brand-search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);max-height:240px;overflow-y:auto;z-index:20;box-shadow:var(--shadow-lg);display:none}
.brand-search-dropdown.visible{display:block}
.brand-search-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--dur-fast);font-size:13px}
.brand-search-item:hover{background:var(--bg-hover)}
.brand-search-item__avatar{width:32px;height:32px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent),#d97706);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;overflow:hidden;flex-shrink:0}
.brand-search-item__avatar img{width:100%;height:100%;object-fit:cover}
.brand-search-item__info{min-width:0}
.brand-search-item__name{font-weight:600;color:var(--text-primary)}
.brand-search-item__cat{font-size:11px;color:var(--text-faint)}

/* 51. FREEMIUM BLUR (non-subscriber data gating) ========================= */
.blurred-data{filter:blur(5px);user-select:none;pointer-events:none;display:inline-block;min-width:2ch}
.freemium-gate{background:var(--bg-surface);border:1px solid var(--accent);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}
.freemium-gate__text{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}
.freemium-gate__text strong{color:var(--text-primary)}
.freemium-gate__cta{flex-shrink:0}

/* 52. TRENDING PREVIEW TABLE (landing page) =============================== */
.trending-preview-grid{display:grid;grid-template-columns:40px 1fr 80px 80px 80px;gap:0}
@media(max-width:640px){.trending-preview-grid{grid-template-columns:28px 1fr 60px 60px;font-size:11px}.trending-preview-grid .tp-col-videos{display:none}}
