/* ============================================================
   Bestfinds.vip — style.css
   ============================================================ */

/* ── RESET ── */
*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden;overscroll-behavior-x:none}
body{overflow-x:hidden;overscroll-behavior-x:none;max-width:100vw}

/* ── DESIGN TOKENS ── */
:root{
  /* Base palette */
  --bg:#07070f;
  --surface:rgba(255,255,255,.04);
  --border:rgba(255,255,255,.08);
  --border-hover:rgba(255,255,255,.16);
  --muted:rgba(255,255,255,.45);
  --hint:rgba(255,255,255,.22);
  /* Text scale */
  --text:#fff;
  --text-strong:rgba(255,255,255,.9);
  --text-mid:rgba(255,255,255,.8);
  --text-faint:rgba(255,255,255,.26);
  /* Surfaces */
  --card-bg:rgba(255,255,255,.04);
  --hover-card:rgba(255,255,255,.065);
  --header-bg:rgba(7,7,15,.82);
  --topbar-bg:rgba(7,7,15,.88);
  /* Misc */
  --grid-line:rgba(255,255,255,.022);
  --outline:rgba(0,0,0,.55);
  --inset-glow:rgba(255,255,255,.06);
  /* Buttons */
  --btn-bg:rgba(255,255,255,.055);
  --btn-border:rgba(255,255,255,.07);
  --btn-color:rgba(255,255,255,.48);
  --btn-hover-bg:rgba(255,255,255,.11);
  --btn-hover-color:#fff;
  --btn-hover-border:rgba(255,255,255,.14);
  /* Gradient text helpers */
  --h1-from:#fff;
  --h1-to:rgba(255,255,255,.5);
  --logo-from:#fff;
  --logo-to:rgba(255,255,255,.75);
  --logo-sub:rgba(255,255,255,.26);
  /* Interactions */
  --search-input:#fff;
  --pill-tag-color:rgba(255,255,255,.45);
  --spinner-border:rgba(255,255,255,.22);
  --spinner-top:#fff;
  /* Agent accent (overridden by JS) */
  --accent:#8b5cf6;
  --accent2:#06b6d4;
  --accent-rgb:139,92,246;
  --accent-glow:rgba(139,92,246,.09);
  --accent-border:rgba(139,92,246,.28);
  --accent-surface:rgba(139,92,246,.1);
  --accent-active-bg:rgba(139,92,246,.14);
  --accent-active-border:rgba(139,92,246,.42);
  --accent-active-color:#c4b5fd;
  --accent-dot:#8b5cf6;
}

/* ── LIGHT MODE ── */
body.light{
  --bg:#f1f1f7;
  --surface:rgba(0,0,0,.045);
  --border:rgba(0,0,0,.09);
  --border-hover:rgba(0,0,0,.2);
  --muted:rgba(0,0,0,.48);
  --hint:rgba(0,0,0,.32);
  --text:#0c0c1a;
  --text-strong:rgba(0,0,0,.87);
  --text-mid:rgba(0,0,0,.7);
  --text-faint:rgba(0,0,0,.33);
  --card-bg:#ffffff;
  --hover-card:#ffffff;
  --header-bg:rgba(238,238,248,.94);
  --topbar-bg:rgba(238,238,248,.97);
  --grid-line:rgba(0,0,0,.04);
  --outline:rgba(0,0,0,.14);
  --inset-glow:rgba(0,0,0,.03);
  --btn-bg:rgba(0,0,0,.055);
  --btn-border:rgba(0,0,0,.09);
  --btn-color:rgba(0,0,0,.52);
  --btn-hover-bg:rgba(0,0,0,.09);
  --btn-hover-color:#0c0c1a;
  --btn-hover-border:rgba(0,0,0,.18);
  --h1-from:#0c0c1a;
  --h1-to:rgba(0,0,0,.58);
  --logo-from:#0c0c1a;
  --logo-to:rgba(0,0,0,.62);
  --logo-sub:rgba(0,0,0,.32);
  --search-input:#0c0c1a;
  --pill-tag-color:rgba(0,0,0,.44);
  --spinner-border:rgba(0,0,0,.14);
  --spinner-top:#0c0c1a;
}

/* ── BASE ── */
body{
  background:var(--bg);color:var(--text);
  font-family:'DM Sans',system-ui,sans-serif;
  font-size:14px;min-height:100vh;
  transition:background .3s,color .3s;
}

/* ── DECORATIVE LAYER ── */
.grid-bg{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(var(--grid-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:38px 38px;
}
.glow{
  position:fixed;top:-120px;left:50%;
  transform:translateX(-50%);
  width:900px;height:560px;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse,var(--accent-glow) 0%,transparent 70%);
  transition:background .4s;
}
.fade-overlay{
  position:fixed;inset:0;z-index:999;
  background:var(--bg);opacity:0;pointer-events:none;
  transition:opacity .28s;
}
.fade-overlay.on{opacity:1;pointer-events:all}

/* ── SCREENS ── */
.screen{
  position:fixed;inset:0;z-index:1;
  display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;
  transition:opacity .35s ease,transform .35s ease;
}
.screen.hidden{opacity:0;pointer-events:none;transform:translateY(14px)}

/* ── ANIMATIONS ── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── SHARED: LOGO ── */
.logo{
  display:flex;align-items:center;gap:10px;
  color:var(--text);user-select:none;cursor:pointer;
  text-decoration:none;
}
.logo-mark{width:34px;height:34px;flex-shrink:0}
.logo-mark svg{width:34px;height:34px;display:block}
.logo-wordmark{display:flex;flex-direction:column;line-height:1}
.logo-name{
  font-size:15px;font-weight:800;letter-spacing:-.4px;
  background:linear-gradient(120deg,var(--logo-from),var(--logo-to));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.logo-name em{
  background:linear-gradient(120deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;font-style:normal;
}
.logo-sub{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--logo-sub);margin-top:2px}
body.light .logo-name{background:linear-gradient(120deg,#0d0d18,rgba(0,0,0,.65));-webkit-background-clip:text;-webkit-text-fill-color:transparent}

/* ── SHARED: DOT ── */
.dot{width:6px;height:6px;border-radius:50%;background:#4ade80;animation:pulse 2s infinite}

/* ── SHARED: ICON BUTTON ── */
.icon-btn{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:var(--surface);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--muted);font-size:14px;
  transition:color .15s,border-color .15s;user-select:none;
}
.icon-btn:hover{color:var(--text);border-color:var(--border-hover)}

/* ── SHARED: GRADIENT TEXT ── */
.grad-accent{
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ============================================================
   SCREEN 1 — AGENT SELECT
   ============================================================ */
.s1-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;position:sticky;top:0;z-index:10;
  background:var(--header-bg);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
}
.pill{
  display:flex;align-items:center;gap:6px;
  padding:5px 14px;border-radius:20px;
  background:var(--surface);border:1px solid var(--border);
  font-size:11px;color:var(--muted);
}
.s1-hero{text-align:center;padding:52px 24px 32px}
.tag-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 16px;border-radius:20px;margin-bottom:22px;
  background:var(--surface);border:1px solid var(--accent-border);
  font-size:11px;color:var(--pill-tag-color);
}
h1{
  font-size:clamp(30px,5vw,58px);font-weight:800;line-height:1.12;
  background:linear-gradient(135deg,var(--h1-from),var(--h1-to));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.s1-hero p{color:var(--muted);font-size:15px;margin-top:12px;max-width:400px;margin-inline:auto}

/* Agent grid */
.agent-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));
  gap:12px;padding:0 28px 60px;max-width:1060px;margin:0 auto;width:100%;
}
.agent-card{
  position:relative;
  background:linear-gradient(145deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;padding:22px 14px 16px;
  text-align:center;cursor:pointer;
  transition:border-color .2s,background .2s,transform .2s,box-shadow .2s;
}
.agent-card:hover{
  border-color:rgba(var(--accent-rgb),.5);
  background:linear-gradient(145deg,rgba(var(--accent-rgb),.1),rgba(255,255,255,.025));
  transform:translateY(-4px);box-shadow:0 16px 36px rgba(0,0,0,.22);
}
.agent-card.selecting{
  border-color:var(--accent)!important;
  box-shadow:0 0 0 1px rgba(var(--accent-rgb),.32),0 20px 50px rgba(var(--accent-rgb),.15);
}
.agent-card.current{border-color:rgba(var(--accent-rgb),.38)}
.agent-logo-wrap{
  width:64px;height:64px;border-radius:18px;
  margin:0 auto 14px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  padding:7px;background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.11);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.025);
  transition:box-shadow .22s,transform .22s;
}
.agent-logo-wrap img{width:100%!important;height:100%!important;border-radius:12px;object-fit:contain!important}
.agent-logo-wrap > div{max-width:100%;max-height:100%;border-radius:12px!important}
.agent-card:hover .agent-logo-wrap{transform:scale(1.04);box-shadow:inset 0 0 0 1px var(--inset-glow),0 10px 32px rgba(0,0,0,.45)}
.agent-name{font-size:13px;font-weight:700;margin-bottom:12px;color:var(--text-strong)}
.agent-card-main{min-width:0}
.agent-btn{
  width:100%;padding:8px;border-radius:12px;
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);
  color:var(--btn-color);font-size:11px;cursor:pointer;
  font-family:inherit;display:flex;align-items:center;justify-content:center;gap:5px;
  transition:background .15s,color .15s,border-color .15s;
}
.agent-btn:hover{background:var(--btn-hover-bg);color:var(--btn-hover-color);border-color:var(--btn-hover-border)}
.agent-card.selecting .agent-btn{background:var(--accent-surface);color:var(--accent-active-color);border-color:var(--accent-border)}
.spinner{
  width:11px;height:11px;border-radius:50%;display:none;
  border:1.5px solid var(--spinner-border);border-top-color:var(--spinner-top);
  animation:spin .6s linear infinite;
}
.agent-card.selecting .spinner{display:block}
.agent-card.selecting .arrow-txt{display:none}
.agent-card.recommended{
  border-color:rgba(253,224,71,.62);
  background:linear-gradient(145deg,rgba(253,224,71,.105),rgba(255,255,255,.025));
  box-shadow:0 0 0 1px rgba(253,224,71,.1),0 16px 38px rgba(0,0,0,.24);
}
.agent-recommended{
  position:absolute;top:9px;right:9px;
  padding:4px 8px;border-radius:999px;
  background:linear-gradient(135deg,rgba(253,224,71,.24),rgba(245,158,11,.14));
  border:1px solid rgba(253,224,71,.55);
  color:#fef08a;font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;
  box-shadow:0 4px 14px rgba(245,158,11,.1);
}
.agent-rating{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin:-5px 0 10px;color:#fde047;font-size:11px;
}
.agent-stars{letter-spacing:1px}

/* Agent switcher modal */
body.modal-open,body.mobile-menu-open{overflow:hidden}
.agent-modal{
  position:fixed;inset:0;z-index:20000;isolation:isolate;
  display:flex;align-items:center;justify-content:center;
  padding:24px;background:rgba(2,2,8,.56);
  backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);
  opacity:0;pointer-events:none;
  transition:opacity .2s ease;
}
.agent-modal.open{opacity:1;pointer-events:auto}
.agent-modal-panel{
  width:min(1040px,calc(100vw - 64px));max-height:min(780px,calc(100vh - 72px));
  overflow-y:auto;border:1px solid var(--border);border-radius:24px;
  background:
    radial-gradient(circle at 10% 0%,rgba(var(--accent-rgb),.12),transparent 28%),
    linear-gradient(160deg,#10101c 0%,#080810 70%);
  box-shadow:0 35px 100px rgba(0,0,0,.78),0 0 0 1px rgba(255,255,255,.035);
  transform:translateY(12px) scale(.98);transition:transform .2s ease;
}
.agent-modal.open .agent-modal-panel{transform:translateY(0) scale(1)}
.agent-modal-header{
  display:flex;align-items:flex-start;justify-content:space-between;gap:20px;
  padding:26px 28px 12px;
}
.agent-modal-heading{display:flex;align-items:flex-start;gap:14px}
.agent-modal-icon{
  display:flex;align-items:center;justify-content:center;
  width:44px;height:44px;flex-shrink:0;
}
.agent-modal-icon svg{width:44px;height:44px}
.agent-modal-kicker{
  color:var(--accent);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;
}
.agent-modal-header h2{margin-top:5px;font-size:25px;letter-spacing:-.45px;color:var(--text-strong)}
.agent-modal-header p{margin-top:6px;color:var(--muted);font-size:13px;line-height:1.5}
.agent-modal-close{
  width:34px;height:34px;flex-shrink:0;border-radius:10px;
  border:1px solid var(--border);background:var(--surface);
  color:var(--text-mid);font-size:22px;line-height:1;cursor:pointer;
}
.agent-modal-close:hover{border-color:var(--border-hover);color:var(--text)}
.agent-modal-note{
  display:flex;align-items:center;gap:8px;
  margin:3px 28px 12px;padding:9px 12px;border-radius:11px;
  background:rgba(253,224,71,.06);border:1px solid rgba(253,224,71,.16);
  color:rgba(254,240,138,.78);font-size:11px;
}
.agent-note-dot{width:6px;height:6px;flex-shrink:0;border-radius:50%;background:#fde047;box-shadow:0 0 12px rgba(253,224,71,.7)}
.agent-modal-grid{max-width:none;padding:4px 28px 28px}

/* ============================================================
   SCREEN 2 — PLATFORM
   ============================================================ */

/* Topbar */
.topbar{
  display:flex;align-items:center;gap:10px;padding:10px 24px;
  position:sticky;top:0;z-index:100;overflow:visible;flex-shrink:0;
  background:rgba(7,7,15,.82);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
}
.mobile-menu-btn,.mobile-home-btn{display:none}
.topbar>.logo{order:1;margin-right:18px}
.header-search{order:2}
.spacer{order:3}
.topbar-actions{order:4}
.agent-switcher{order:5}
.spacer{display:none}
.topbar-actions{
  display:flex;align-items:center;gap:8px;padding:0;
  border:none;border-radius:0;background:transparent;
}
.topbar-actions .currency-btn,.topbar-actions .icon-btn{height:44px;border-radius:13px}
.topbar-actions .icon-btn{width:44px}

/* Active agent chip */
.agent-switcher{position:relative;flex-shrink:0}
.agent-display{
  display:flex;align-items:center;gap:9px;padding:8px 12px 8px 8px;
  border-radius:13px;background:rgba(15,23,42,.68);border:1px solid rgba(148,163,184,.18);
  color:var(--text);cursor:pointer;font-family:inherit;text-align:left;
  transition:border-color .18s,background .18s,transform .18s;
}
.agent-display:hover{border-color:var(--accent-border);background:var(--accent-surface);transform:translateY(-1px)}
.agent-display.open{border-color:var(--accent-border);background:var(--accent-surface)}
.agent-display.open .agent-display-chevron{transform:rotate(180deg)}
.agent-display-logo{
  width:30px;height:30px;border-radius:9px;overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--outline);box-shadow:inset 0 0 0 1px var(--inset-glow);
}
.agent-display-logo img{width:30px;height:30px;object-fit:cover;display:block}
.fb-chip{
  display:none;width:30px;height:30px;border-radius:9px;
  align-items:center;justify-content:center;
  font-weight:800;font-size:10px;color:#fff;
}
.agent-display-copy{display:flex;flex-direction:column;gap:1px;min-width:72px;line-height:1.05}
.agent-display-label{font-size:8px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--hint)}
.agent-display-name{font-size:12px;font-weight:700;color:var(--text-strong)}
.agent-display-chevron{width:11px;height:11px;color:var(--hint);flex-shrink:0;transition:transform .18s}
.header-agent-menu{
  position:absolute;top:calc(100% + 8px);left:0;width:220px;
  z-index:9500;padding:8px;border-radius:16px;
  background:linear-gradient(180deg,#131b2e,#090e1c);
  border:1px solid rgba(148,163,184,.22);
  box-shadow:0 24px 70px rgba(0,0,0,.62),inset 0 1px 0 rgba(255,255,255,.05);
  opacity:0;transform:translateY(8px) scale(.97);
  pointer-events:none;transition:opacity .18s,transform .18s;
  max-height:min(420px,calc(100vh - 110px));overflow-y:auto;
}
.header-agent-menu.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.header-agent-option{
  width:100%;display:flex;align-items:center;gap:10px;
  padding:8px 9px;border:none;border-radius:11px;background:transparent;
  color:#c8d1df;font-size:13px;font-weight:600;font-family:inherit;
  cursor:pointer;text-align:left;transition:background .14s,color .14s;
}
.header-agent-option:hover{background:rgba(255,255,255,.07);color:#fff}
.header-agent-option.active{background:rgba(var(--accent-rgb),.12);color:var(--text-strong)}
.header-agent-logo{
  width:24px;height:24px;border-radius:8px;overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
}
.header-agent-logo img{width:20px!important;height:20px!important;object-fit:contain!important;border-radius:6px}
.header-agent-logo > div{width:20px!important;height:20px!important;border-radius:6px!important;font-size:8px!important}
.header-agent-check{margin-left:auto;color:var(--accent);font-size:12px}

.header-search{
  flex:1;max-width:none;min-width:220px;
  display:flex;align-items:center;gap:8px;
  padding:8px 8px 8px 14px;border-radius:14px;
  background:rgba(15,23,42,.52);border:1px solid rgba(148,163,184,.16);
  transition:border-color .18s,background .18s,box-shadow .18s;
}
.header-search:focus-within{
  border-color:rgba(var(--accent-rgb),.45);
  background:rgba(var(--accent-rgb),.055);
  box-shadow:0 0 0 1px rgba(var(--accent-rgb),.12);
}
.header-search-icon{color:var(--hint);font-size:13px}
.header-search input{
  flex:1;min-width:0;background:transparent;border:none;outline:none;
  color:var(--text);font-size:13px;font-family:inherit;
}
.header-search input::placeholder{color:var(--hint)}
.header-search button{
  padding:6px 14px;border-radius:11px;border:none;
  color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));
  font-size:11px;font-weight:700;font-family:inherit;cursor:pointer;
}

.mobile-side-menu{display:none}

/* Platform body */
.platform-body{flex:1;padding:0 24px 40px;max-width:1200px;margin:0 auto;width:100%}

/* Hero search */
.hero-search{padding:28px 0 16px;text-align:center}
.hero-title{font-size:clamp(18px,2.8vw,30px);font-weight:800}
.search-wrap{
  max-width:490px;margin:14px auto 0;
  display:flex;align-items:center;gap:10px;
  padding:9px 13px;border-radius:16px;
  background:var(--surface);border:1px solid var(--border);
  transition:border-color .2s,box-shadow .2s;
}
.search-wrap:focus-within{
  border-color:rgba(var(--accent-rgb),.45);
  box-shadow:0 0 0 1px rgba(var(--accent-rgb),.18);
}
.search-icon{color:var(--hint);font-size:16px;flex-shrink:0}
.search-wrap input{
  flex:1;background:none;border:none;outline:none;
  color:var(--search-input);font-size:14px;font-family:inherit;min-width:0;
}
.search-wrap input::placeholder{color:var(--hint)}
.search-btn{
  padding:6px 18px;border-radius:11px;border:none;
  color:#fff;font-size:12px;font-weight:600;white-space:nowrap;
  cursor:pointer;font-family:inherit;flex-shrink:0;
  transition:opacity .15s;
}
.search-btn:hover{opacity:.82}
.trending-row{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:11px}
.trend-pill{
  padding:4px 12px;border-radius:20px;cursor:pointer;
  background:var(--surface);border:1px solid var(--border);
  font-size:11px;color:var(--muted);transition:color .15s,border-color .15s;
}
.trend-pill:hover{color:var(--text);border-color:var(--border-hover)}

/* ── CATEGORIES — STORY STYLE ── */
.section-label{
  font-size:10px;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);margin-bottom:14px;
}
/* Scrollable story row */
/* ══════════════════════════════════════════
   CATEGORY SLIDER
══════════════════════════════════════════ */

/* ── Discover headline (below slider) ── */
.discover-headline{
  display:flex;align-items:baseline;gap:8px;
  margin-top:14px;
  margin-bottom:0;
  flex-wrap:wrap;
}

.search-results-head{
  display:none;margin:34px 0 8px;padding:24px 26px;border-radius:20px;
  border:1px solid var(--border);
  background:
    radial-gradient(circle at 92% 0%,rgba(var(--accent-rgb),.16),transparent 34%),
    linear-gradient(145deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
}
body.search-results-mode .search-results-head{display:block}
body.search-results-mode .hero-search,
body.search-results-mode .section-label,
body.search-results-mode .cats-outer,
body.search-results-mode .discover-headline{display:none}
.search-results-back{
  display:inline-flex;align-items:center;gap:5px;margin-bottom:22px;padding:0;
  border:0;background:transparent;color:var(--muted);font:inherit;font-size:12px;cursor:pointer;
}
.search-results-back:hover{color:var(--text)}
.search-results-back svg{width:13px;height:13px}
.search-results-kicker{
  color:var(--accent);font-size:10px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;
}
.search-results-head h2{margin-top:7px;color:var(--text-strong);font-size:30px;letter-spacing:-.6px}
.search-results-head h2 span{color:var(--accent)}
.search-results-head p{margin-top:7px;color:var(--muted);font-size:13px}
.search-results-search{
  display:flex;align-items:center;gap:9px;max-width:620px;margin-top:20px;
  padding:7px 8px 7px 13px;border:1px solid var(--border);border-radius:14px;
  background:var(--surface);
}
.search-results-search span{color:var(--hint)}
.search-results-search input{
  flex:1;min-width:0;border:0;outline:0;background:transparent;color:var(--text);
  font:inherit;font-size:13px;
}
.search-results-search button{
  padding:7px 16px;border:0;border-radius:10px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;
  font:inherit;font-size:12px;font-weight:700;cursor:pointer;
}
body.search-results-mode .filter-bar{margin-top:14px}
.discover-verb{
  font-size:clamp(18px,2.5vw,26px);
  font-weight:800;
  color:var(--text);
}
.discover-count{
  font-size:clamp(22px,3vw,34px);
  font-weight:800;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  font-variant-numeric:tabular-nums;
}
.discover-cat{
  font-size:clamp(18px,2.5vw,26px);
  font-weight:800;
  color:var(--text);
}

/* ── Outer layout ── */
.cats-outer{
  display:flex;
  align-items:center;
  gap:0;
  margin-top:0;
  overflow:visible;
}

/* ── Pinned "All" — no extra padding, aligns with scroll track ── */
.cats-pinned{
  flex-shrink:0;
  display:flex;
  align-items:center;
  padding:0;
  margin-right:8px;
}
.cats-pinned::after{
  content:'';
  width:1px;
  height:52px;
  background:var(--border);
  margin-left:10px;
  flex-shrink:0;
}

/* ── Discover headline ── */
.discover-headline{
  display:flex;
  align-items:baseline;
  gap:8px;
  margin-top:14px;
  flex-wrap:wrap;
}

/* ── Arrow buttons ── */
.cats-arrow{
  flex-shrink:0;
  width:36px;height:36px;border-radius:50%;
  background:var(--surface);
  border:1px solid var(--border);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:var(--text);font-size:14px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  /* Push arrow up so it centers on the RING, not the whole card incl. label.
     Label is ~24px, so shift up by 12px (half of label height) */
  margin-bottom:24px;
  transition:background .18s,border-color .18s,transform .18s,box-shadow .18s;
  box-shadow:0 2px 10px rgba(0,0,0,.3);
  user-select:none;
}
#catsLeft{ margin-right:6px; }
#catsRight{ margin-left:6px; }

.cats-arrow:hover{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
  transform:scale(1.08);
  box-shadow:0 4px 20px rgba(var(--accent-rgb),.5);
}
.cats-arrow:active{transform:scale(.95)}
.cats-arrow[hidden]{
  opacity:0;
  pointer-events:none;
  visibility:hidden;
}

/* ── Scroll track ── */
.cats-scroll-wrap{
  flex:1;
  min-width:0;
  overflow-x:auto;
  overflow-y:visible;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  -ms-overflow-style:none;
  padding:0;
}
.cats-scroll-wrap::-webkit-scrollbar{display:none}

/* ── Inner flex row ── */
.cats-grid{
  display:flex;
  gap:14px;
  width:max-content;
  padding:8px 4px 12px;
  align-items:center;
}

/* Responsive */
@media(max-width:700px){
  .cats-arrow{width:30px;height:30px;font-size:13px}
  .cats-outer{gap:6px}
}
@media(max-width:480px){
  .cats-arrow[hidden]{display:none} /* fully remove on tiny screens */
}

.cat-story{
  display:inline-flex;flex-direction:column;align-items:center;
  gap:9px;cursor:pointer;flex-shrink:0;user-select:none;
  background:none;border:none;
  padding:0;
  vertical-align:top;
  transition:transform .18s;
}
.cat-story:hover{transform:translateY(-3px)}

/* The circle — everything lives here, nothing escapes */
.cat-story-ring{
  width:76px;height:76px;border-radius:50%;
  position:relative;flex-shrink:0;
  background:transparent;
  box-shadow:0 0 0 2px rgba(255,255,255,.12);
  transition:box-shadow .25s;
}
body.light .cat-story-ring{box-shadow:0 0 0 2px rgba(0,0,0,.1)}

/* Active: agent-colored glow ring */
.cat-story.active .cat-story-ring{
  box-shadow:
    0 0 0 3px var(--accent),
    0 8px 28px rgba(var(--accent-rgb),.5);
}

/* Image bubble — perfectly round, agent-tinted bg, NO white box */
.cat-story-img-wrap{
  position:absolute;inset:0;
  border-radius:50%;
  overflow:hidden;
  isolation:isolate;
}
.cat-story-img{
  width:100%;height:100%;
  object-fit:contain;
  display:block;
  padding:6px;
  transition:transform .3s ease;
}
.cat-story:hover .cat-story-img{transform:scale(1.1)}

/* "All" special gradient circle */
.cat-story-all{
  position:absolute;inset:0;
  border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  display:flex;align-items:center;justify-content:center;
  font-size:26px;
}

/* Label */
.cat-story-label{
  font-size:11px;font-weight:500;color:var(--text-mid);
  text-align:center;line-height:1.25;
  max-width:78px;word-break:break-word;
  transition:color .18s;
}
.cat-story.active .cat-story-label{
  color:var(--accent-active-color);font-weight:700;
}

/* Filter bar */
.filter-bar{display:flex;align-items:center;justify-content:space-between;margin:14px 0 0;gap:10px;flex-wrap:wrap}
.filter-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.count-text{display:none}
.fd-wrap{position:relative}
.fd-btn{
  display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:12px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text-mid);font-size:13px;font-weight:500;
  cursor:pointer;white-space:nowrap;user-select:none;font-family:inherit;
  transition:border-color .15s,background .15s,color .15s;
}
.fd-btn:hover{border-color:var(--border-hover);color:var(--text)}
.fd-btn.active{background:var(--accent-active-bg);border-color:var(--accent-active-border);color:var(--accent-active-color)}
.fd-chev{width:10px;height:10px;flex-shrink:0;opacity:.55;transition:transform .2s}
.fd-btn.active .fd-chev{transform:rotate(180deg);opacity:1}
.fd-divider{width:1px;height:24px;background:var(--border);margin:0 4px}
.fd-clear{
  padding:8px 14px;border-radius:12px;border:1px solid var(--border);
  background:transparent;color:var(--muted);font-size:13px;font-weight:500;
  cursor:pointer;font-family:inherit;white-space:nowrap;
  transition:border-color .15s,color .15s,background .15s;
}
.fd-clear:hover{border-color:rgba(239,68,68,.4);color:#f87171;background:rgba(239,68,68,.06)}

/* Filter dropdown */
.fd-dropdown{
  position:fixed;min-width:260px;z-index:9000;
  background:var(--topbar-bg);border:1px solid var(--border);border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.3),0 4px 16px rgba(0,0,0,.15);
  backdrop-filter:blur(24px);
  opacity:0;transform:translateY(8px) scale(.97);
  pointer-events:none;transition:opacity .18s,transform .18s;
}
.fd-dropdown.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.fd-dd-inner{padding:16px 18px}
.fd-dd-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.fd-dd-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.fd-dd-val{font-size:12px;font-weight:700;color:var(--accent)}

/* Price slider */
.slider-wrap{position:relative;height:26px;margin-bottom:14px}
.slider-track{
  position:absolute;top:50%;left:0;right:0;height:4px;
  border-radius:2px;background:var(--border);transform:translateY(-50%);
}
.slider-range{
  position:absolute;height:100%;border-radius:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
}
.range-input{
  position:absolute;top:50%;width:100%;height:4px;
  -webkit-appearance:none;background:transparent;outline:none;
  transform:translateY(-50%);pointer-events:none;
}
.range-input::-webkit-slider-thumb{
  -webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:#fff;border:2.5px solid var(--accent);
  cursor:pointer;pointer-events:all;
  box-shadow:0 2px 8px rgba(0,0,0,.25);transition:transform .15s;
}
.range-input::-webkit-slider-thumb:hover{transform:scale(1.18)}
.range-input::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:2.5px solid var(--accent);
  cursor:pointer;pointer-events:all;
}
.fd-presets{display:flex;flex-wrap:wrap;gap:5px}
.fd-preset{
  padding:5px 11px;border-radius:9px;font-size:11px;
  background:var(--btn-bg);border:1px solid var(--border);
  color:var(--muted);cursor:pointer;font-family:inherit;
  transition:background .14s,border-color .14s,color .14s;
}
.fd-preset:hover{background:var(--accent-surface);border-color:var(--accent-border);color:var(--accent-active-color)}

/* Sort list */
.fd-sort-list{padding:8px}
.fd-sort-opt{
  display:flex;align-items:center;width:100%;
  padding:9px 12px;border-radius:10px;
  background:transparent;border:none;
  color:var(--text-mid);font-size:13px;
  cursor:pointer;font-family:inherit;text-align:left;
  transition:background .13s,color .13s;
}
.fd-sort-opt:hover{background:var(--surface);color:var(--text)}
.fd-sort-opt.active{background:var(--accent-active-bg);color:var(--accent-active-color);font-weight:600}

/* Product grid */
.product-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:14px;margin-top:14px;
}
.prod-card{
  display:flex;flex-direction:column;
  background:var(--card-bg);border:1px solid var(--border);border-radius:18px;
  overflow:hidden;cursor:pointer;
  transition:border-color .22s,transform .22s,box-shadow .22s;
}
.prod-card:hover{border-color:var(--border-hover);transform:translateY(-3px);box-shadow:0 14px 42px rgba(0,0,0,.28)}
.prod-img-wrap{position:relative;overflow:hidden;aspect-ratio:1;flex-shrink:0}
.prod-img{
  width:100%;height:100%;object-fit:cover;display:block;
  background:linear-gradient(135deg,rgba(var(--accent-rgb),.12),rgba(255,255,255,.04));
  opacity:0;
  transition:opacity .22s ease,transform .5s cubic-bezier(.25,.46,.45,.94);
}
.prod-img.loaded{opacity:1}
.prod-img.load-error{opacity:.18}
.prod-card:hover .prod-img{transform:scale(1.06)}
.prod-overlay{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.65);opacity:0;transition:opacity .22s;
}
.prod-card:hover .prod-overlay{opacity:1}
.overlay-link{
  padding:9px 18px;border-radius:11px;border:none;
  color:#fff;font-size:12px;font-weight:600;cursor:pointer;
  font-family:inherit;white-space:nowrap;
}
.prod-info{flex:1;display:flex;flex-direction:column;padding:12px 14px 14px}
.prod-brand{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--hint);margin-bottom:4px}
.prod-title{
  flex:1;font-size:13px;color:var(--text-mid);line-height:1.4;margin-bottom:10px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.prod-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.prod-price{font-weight:700;font-size:15px}
.prod-eur{font-size:11px;color:var(--hint);margin-left:6px}
.agent-mini-logo{width:24px;height:24px;border-radius:7px;overflow:hidden;flex-shrink:0;border:1px solid var(--outline)}
.agent-mini-logo img{width:24px;height:24px;object-fit:cover;display:block}
.no-results{text-align:center;padding:60px 20px;color:var(--muted);grid-column:1/-1}
.load-more-wrap{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:28px 0 4px;
}
.load-more-wrap[hidden]{display:none}
.load-more-status{font-size:12px;color:var(--muted)}
.load-more-btn{
  padding:10px 24px;border-radius:12px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  border:1px solid var(--accent-border);
  color:#fff;font-size:13px;font-weight:700;
  cursor:pointer;font-family:inherit;
  box-shadow:0 8px 22px rgba(var(--accent-rgb),.22);
  transition:transform .16s,box-shadow .16s,opacity .16s;
}
.load-more-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(var(--accent-rgb),.3)}
.load-more-btn:active{transform:translateY(0)}
.load-more-btn:disabled{cursor:wait;opacity:.65;transform:none}

/* ── CURRENCY SWITCHER ── */
.currency-switcher{position:relative;flex-shrink:0;z-index:500}
.currency-btn{
  display:inline-flex;align-items:center;gap:6px;padding:7px 12px;
  border-radius:12px;background:var(--surface);border:1px solid var(--border);
  color:var(--text-strong);font-size:12px;font-weight:600;
  cursor:pointer;font-family:inherit;user-select:none;white-space:nowrap;
  transition:border-color .18s,background .18s;
}
.currency-btn:hover,.currency-btn.open{border-color:var(--border-hover);background:var(--hover-card)}
.cb-symbol{
  font-size:14px;font-weight:700;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.cb-code{font-size:11px;color:var(--muted);letter-spacing:.04em}
.cb-chevron{width:11px;height:11px;color:var(--hint);flex-shrink:0;transition:transform .2s}
.currency-btn.open .cb-chevron{transform:rotate(180deg)}
.currency-dropdown{
  position:fixed;width:176px;z-index:9999;
  background:var(--topbar-bg);border:1px solid var(--border);border-radius:16px;padding:6px;
  box-shadow:0 24px 64px rgba(0,0,0,.5),0 4px 16px rgba(0,0,0,.3);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  opacity:0;transform:translateY(8px) scale(.97);transform-origin:top right;
  pointer-events:none;transition:opacity .18s,transform .18s;
}
.currency-dropdown.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.currency-option{
  display:flex;align-items:center;gap:10px;padding:8px 10px;
  border-radius:10px;cursor:pointer;color:var(--text-mid);font-size:12px;
  transition:background .14s;
}
.currency-option:hover{background:var(--surface)}
.currency-option.active{background:var(--accent-active-bg)}
.co-symbol{
  width:28px;height:28px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:var(--text-strong);
  background:var(--surface);border:1px solid var(--border);
}
.currency-option.active .co-symbol{background:var(--accent-surface);border-color:rgba(var(--accent-rgb),.35);color:var(--accent)}
.co-info{display:flex;flex-direction:column;gap:1px}
.co-code{font-weight:700;font-size:12px;letter-spacing:.03em;color:var(--text)}
.co-name{font-size:10px;color:var(--muted)}
.co-check{margin-left:auto;font-size:12px;opacity:0;color:var(--accent)}
.currency-option.active .co-check{opacity:1}

/* ── LIGHT MODE OVERRIDES ── */
body.light .agent-display{background:rgba(255,255,255,.85);border-color:rgba(0,0,0,.1)}
body.light .topbar{background:rgba(241,241,247,.92);border-bottom-color:rgba(0,0,0,.08)}
body.light .topbar-actions{background:transparent}
body.light .header-agent-menu{
  background:#fff;border-color:rgba(0,0,0,.1);
  box-shadow:0 12px 40px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.07)
}
body.light .header-search{background:rgba(255,255,255,.85);border-color:rgba(0,0,0,.1)}
body.light .mobile-menu-panel{
  background:#fff;border-right-color:rgba(0,0,0,.08);
  box-shadow:12px 0 40px rgba(0,0,0,.1)
}
body.light .mobile-menu-panel .mobile-menu-head{border-bottom-color:rgba(0,0,0,.08)}
body.light .mobile-menu-panel .mobile-menu-search{
  background:#f3f3f9;border-color:rgba(0,0,0,.1);color:#0c0c1a
}
body.light .mobile-menu-panel .mobile-menu-search input::placeholder{color:rgba(0,0,0,.35)}
body.light .mobile-menu-panel .mobile-menu-quick{border-color:rgba(0,0,0,.08)}
body.light .mobile-menu-panel .mobile-menu-quick button{
  background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.09)
}
body.light .mobile-menu-panel .mobile-menu-nav button,
body.light .mobile-menu-panel .mobile-menu-cats button{
  background:#f8f8fc;border-color:rgba(0,0,0,.09);color:#0c0c1a
}
body.light .mobile-menu-panel .mobile-menu-nav span,
body.light .mobile-menu-panel .mobile-menu-cats span{
  color:var(--accent)
}
body.light .mobile-menu-panel .mobile-menu-quick button{
  color:#0c0c1a
}
body.light .mobile-menu-panel .mobile-menu-quick span{
  color:var(--accent)
}
body.light .mobile-menu-panel .mobile-menu-agent{
  background:#f3f3f9;border-color:rgba(0,0,0,.1);color:#0c0c1a
}
body.light .mobile-menu-panel .mobile-menu-agent small{
  color:rgba(0,0,0,.45)
}
body.light .mobile-menu-panel .mobile-menu-head h3{
  color:#0c0c1a
}
body.light .mobile-menu-panel .mobile-menu-head-actions button{
  background:#f3f3f9;border-color:rgba(0,0,0,.1);color:#0c0c1a
}
body.light .mobile-home-btn{background:rgba(255,255,255,.85);border-color:rgba(0,0,0,.1)}
body.light .currency-btn{background:rgba(255,255,255,.85);border-color:rgba(0,0,0,.1)}
body.light .agent-card{
  background:linear-gradient(145deg,rgba(0,0,0,.025),rgba(0,0,0,.01));
  border-color:rgba(0,0,0,.09);
  box-shadow:0 1px 6px rgba(0,0,0,.06)
}
body.light .agent-card:hover{
  border-color:rgba(var(--accent-rgb),.4);
  background:linear-gradient(145deg,rgba(var(--accent-rgb),.07),rgba(0,0,0,.01));
  box-shadow:0 8px 24px rgba(0,0,0,.1)
}
body.light .agent-logo-wrap{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.09)}
body.light .agent-btn{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.1)}
body.light .agent-modal-panel{
  background:#fff;
  box-shadow:0 20px 60px rgba(0,0,0,.14),0 0 0 1px rgba(0,0,0,.07)
}
body.light .agent-modal{background:rgba(0,0,0,.35)}
body.light .agent-modal-header h2{color:#0c0c1a}
body.light .agent-modal-header p{color:rgba(0,0,0,.5)}
body.light .agent-modal-note{
  background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.25);
  color:rgba(146,64,14,.85)
}
body.light .agent-modal-close{background:#f3f3f9;border-color:rgba(0,0,0,.1);color:#0c0c1a}
body.light .agent-modal-grid .agent-btn{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.1);color:rgba(0,0,0,.55)}
body.light .agent-card.recommended{
  border-color:rgba(245,158,11,.5);
  background:linear-gradient(145deg,rgba(245,158,11,.08),rgba(255,255,255,.5))
}
body.light .fd-dropdown{
  background:rgba(241,241,247,.98);
  box-shadow:0 12px 40px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.06)
}
body.light .search-results-search{background:rgba(255,255,255,.85)}
body.light .search-wrap{background:rgba(255,255,255,.9)}
body.light .cat-pill{background:rgba(255,255,255,.8)}
body.light .trend-pill{background:rgba(255,255,255,.8)}
body.light .icon-btn{background:rgba(255,255,255,.75);border-color:rgba(0,0,0,.1);color:var(--muted)}
body.light .prod-card{
  box-shadow:0 1px 6px rgba(0,0,0,.07),0 0 0 1px rgba(0,0,0,.05)
}
body.light .prod-card:hover{
  box-shadow:0 8px 28px rgba(0,0,0,.11),0 0 0 1px rgba(0,0,0,.07)
}
body.light .search-results-head{
  background:linear-gradient(145deg,rgba(var(--accent-rgb),.07),rgba(255,255,255,.5));
  border-color:rgba(var(--accent-rgb),.15)
}
body.light .skeleton{
  background:linear-gradient(90deg,rgba(0,0,0,.06) 25%,rgba(0,0,0,.1) 50%,rgba(0,0,0,.06) 75%);
  background-size:200% 100%
}
body.light .cat-story-ring{box-shadow:0 0 0 2px rgba(0,0,0,.1)}
body.light .cats-pinned::after{background:rgba(0,0,0,.08)}
body.light .mobile-menu-scrim{background:rgba(0,0,0,.28)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .product-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:700px){
  .s1-header{padding:12px 16px}
  .s1-hero{padding:32px 16px 20px}
  .agent-grid{padding:0 14px 40px;grid-template-columns:repeat(2,1fr);gap:10px}
  h1{font-size:28px}
  .topbar{padding:8px 8px;gap:7px;top:0}
  .topbar>.logo{display:none}
  .mobile-menu-btn{
    order:1;display:flex;width:36px;height:36px;flex-shrink:0;
    flex-direction:column;align-items:center;justify-content:center;gap:5px;
    border:0;background:transparent;color:var(--text);cursor:pointer;
  }
  .mobile-menu-btn span{width:20px;height:2px;border-radius:99px;background:currentColor}
  .mobile-home-btn{
    order:2;display:flex;align-items:center;justify-content:center;
    width:44px;height:44px;flex-shrink:0;border-radius:14px;
    background:rgba(15,23,42,.72);border:1px solid rgba(148,163,184,.24);
    color:var(--text);cursor:pointer;
  }
  .mobile-home-btn svg{width:21px;height:21px}
  .header-search{
    order:3;display:flex;min-width:0;flex:1;padding:0 10px;height:44px;
    border-radius:13px;background:rgba(15,23,42,.62);gap:7px;
  }
  .header-search button{display:none}
  .header-search input{font-size:13px}
  .topbar-actions{order:4;gap:6px}
  .agent-switcher{order:5}
  #themeToggle{display:none}
  .logo-sub{display:none}
  .spacer{display:none}
  .platform-body{padding:0 14px 32px}
  .hero-search{padding:18px 0 12px}
  .search-results-head{margin:18px 0 4px;padding:18px 16px;border-radius:16px}
  .search-results-back{margin-bottom:16px}
  .search-results-head h2{font-size:23px;line-height:1.15}
  .search-results-search{margin-top:15px}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:9px}
  .filter-bar{flex-direction:column;align-items:flex-start}
  .filter-right{width:100%;justify-content:flex-end}
  .fd-btn{font-size:12px;padding:7px 11px}
  .cats-grid{gap:10px}
  .cat-story-ring{width:64px;height:64px}
  .cat-story-label{font-size:10px;max-width:66px}
  .agent-modal{padding:20px}
  .agent-modal-panel{width:min(390px,calc(100vw - 32px));max-height:min(720px,calc(100vh - 52px));border-radius:18px}
  .agent-modal-header{padding:17px 16px 8px}
  .agent-modal-heading{gap:10px}
  .agent-modal-icon{width:38px;height:38px}
  .agent-modal-icon svg{width:38px;height:38px}
  .agent-modal-header h2{margin-top:3px;font-size:19px;line-height:1.12}
  .agent-modal-header p{margin-top:5px;font-size:11px;line-height:1.4}
  .agent-modal-kicker{font-size:8px}
  .agent-modal-close{width:30px;height:30px;border-radius:9px;font-size:19px}
  .agent-modal-note{margin:4px 14px 9px;padding:8px 10px;font-size:10px;line-height:1.35}
  .agent-modal-grid{display:flex;flex-direction:column;padding:3px 14px 16px;gap:8px}
  .agent-modal-grid .agent-card{
    display:flex;align-items:center;gap:11px;
    min-height:66px;padding:9px 11px;border-radius:14px;text-align:left;
  }
  .agent-modal-grid .agent-card:hover{transform:none}
  .agent-modal-grid .agent-logo-wrap{
    width:46px;height:46px;flex-shrink:0;margin:0;padding:5px;border-radius:13px;
  }
  .agent-modal-grid .agent-logo-wrap img{border-radius:10px}
  .agent-modal-grid .agent-name{margin:0 0 5px;font-size:13px}
  .agent-modal-grid .agent-rating{justify-content:flex-start;margin:0;font-size:12px}
  .agent-modal-grid .agent-btn{
    width:auto;min-width:34px;height:34px;margin-left:auto;padding:0 9px;border-radius:10px;
    background:rgba(255,255,255,.055);
  }
  .agent-modal-grid .arrow-txt{font-size:0}
  .agent-modal-grid .arrow-txt::after{content:'→';font-size:16px}
  .agent-modal-grid .agent-recommended{top:7px;right:52px}

  .mobile-side-menu{
    display:block;position:fixed;inset:0;z-index:21000;
    pointer-events:none;visibility:hidden;
  }
  .mobile-side-menu.open{pointer-events:auto;visibility:visible}
  .mobile-menu-scrim{
    position:absolute;inset:0;background:rgba(2,6,23,.62);
    opacity:0;transition:opacity .2s ease;backdrop-filter:blur(3px);
  }
  .mobile-side-menu.open .mobile-menu-scrim{opacity:1}
  .mobile-menu-panel{
    position:absolute;top:0;left:0;width:min(335px,91vw);height:100%;
    padding:14px 11px 24px;
    background:
      radial-gradient(circle at 12% 0%,rgba(var(--accent-rgb),.11),transparent 26%),
      linear-gradient(180deg,#0a0a16,#060610);
    border-right:1px solid rgba(148,163,184,.18);
    box-shadow:24px 0 80px rgba(0,0,0,.55);
    transform:translateX(-105%);transition:transform .24s ease;
    overflow-y:auto;
  }
  .mobile-side-menu.open .mobile-menu-panel{transform:translateX(0)}
  .mobile-menu-head{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    padding:0 0 13px;border-bottom:1px solid rgba(148,163,184,.16);
  }
  .mobile-menu-head h3{font-size:19px;line-height:1}
  .mobile-menu-head-actions{display:flex;gap:8px}
  .mobile-menu-head-actions button{
    display:flex;align-items:center;justify-content:center;width:40px;height:40px;
    border-radius:11px;border:1px solid rgba(148,163,184,.22);
    background:rgba(255,255,255,.025);color:var(--text);cursor:pointer;
  }
  .mobile-menu-head-actions svg{width:19px;height:19px}
  .mobile-menu-search{
    display:flex;align-items:center;gap:8px;margin:16px 0;padding:0 8px 0 14px;height:40px;
    border-radius:999px;border:1px solid rgba(148,163,184,.22);
    background:rgba(255,255,255,.07);color:var(--text);
  }
  .mobile-menu-search input{
    flex:1;min-width:0;border:0;outline:0;background:transparent;
    color:var(--text);font:inherit;font-size:13px;
  }
  .mobile-menu-search input::placeholder{color:#9fb0c8}
  .mobile-menu-search button{
    display:flex;align-items:center;justify-content:center;width:28px;height:28px;
    border:0;background:transparent;color:#d8e4f5;cursor:pointer;
  }
  .mobile-menu-search svg{width:17px;height:17px}
  .mobile-menu-quick{
    display:grid;grid-template-columns:1fr 1fr;gap:8px;
    margin-bottom:14px;padding:15px 0;border-top:1px solid rgba(148,163,184,.16);
    border-bottom:1px solid rgba(148,163,184,.16);
  }
  .mobile-menu-quick button{
    min-height:56px;padding:8px 5px;border:1px solid rgba(148,163,184,.24);
    border-radius:12px;background:rgba(255,255,255,.035);color:var(--text);font:inherit;
    font-size:10px;cursor:pointer;
  }
  .mobile-menu-quick span{display:block;margin-bottom:4px;color:#fff;font-size:19px;line-height:1}
  .mobile-menu-agent{
    width:100%;display:flex;align-items:center;gap:12px;margin-bottom:16px;
    padding:10px;border-radius:13px;border:1px solid rgba(148,163,184,.22);
    background:rgba(255,255,255,.04);color:var(--text);font-family:inherit;text-align:left;
  }
  .mobile-menu-agent-logo{
    width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;
    overflow:hidden;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);flex-shrink:0;
  }
  .mobile-menu-agent-logo img{width:28px!important;height:28px!important;object-fit:contain!important;border-radius:8px}
  .mobile-menu-agent strong{display:block;font-size:14px}
  .mobile-menu-agent small{display:block;margin-top:2px;color:var(--muted);font-size:11px}
  .mobile-menu-nav,.mobile-menu-cats{display:grid;gap:8px}
  .mobile-menu-nav button,.mobile-menu-cats button{
    width:100%;display:flex;align-items:center;gap:12px;min-height:50px;
    border:1px solid rgba(255,255,255,.1);border-radius:13px;
    background:linear-gradient(135deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
    color:var(--text-strong);padding:11px 14px;text-align:left;
    font-family:inherit;font-size:14px;font-weight:800;
  }
  .mobile-menu-nav{margin-bottom:8px}
  .mobile-menu-nav span,.mobile-menu-cats span{width:22px;color:var(--accent);font-size:17px;text-align:center;flex-shrink:0}
  .mobile-menu-nav button:active,.mobile-menu-cats button:active{background:rgba(var(--accent-rgb),.12)}
  .mobile-menu-cats button.active{
    border-color:rgba(var(--accent-rgb),.48);color:var(--text);
    background:linear-gradient(135deg,rgba(var(--accent-rgb),.2),rgba(var(--accent-rgb),.08));
    box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.1);
  }
}
@media(max-width:480px){
  .agent-display{height:44px;padding:0 8px;gap:0;border-radius:13px}
  .agent-display-copy,.agent-display-chevron{display:none}
  .agent-display-logo,.agent-display-logo img,.fb-chip{width:28px;height:28px}
  .logo-name{font-size:13px}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .agent-grid{grid-template-columns:repeat(2,1fr)}
  .cb-code,.cb-chevron{display:none}
  .currency-btn{height:44px;padding:0 10px;border-radius:13px;background:rgba(15,23,42,.72);border-color:rgba(148,163,184,.22)}
  .icon-btn{width:32px;height:32px;border-radius:10px}
  .hero-title{font-size:18px}
  .trending-row{display:none}
}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.site-footer{
  margin-top:64px;
  border-top:1px solid var(--border);
  padding:48px 0 32px;
}
.footer-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
}

/* Brand */
.footer-brand{
  display:flex;align-items:center;gap:10px;
  margin-bottom:32px;
}
.footer-brand-name{
  font-size:16px;font-weight:800;letter-spacing:-.3px;
  background:linear-gradient(120deg,var(--logo-from),var(--logo-to));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.footer-brand-name em{
  background:linear-gradient(120deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;font-style:normal;
}

/* Disclaimer blocks grid */
.footer-disclaimer{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:24px;
  margin-bottom:40px;
}
.footer-block{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px 20px;
}
.footer-block h4{
  font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--text);
  margin-bottom:8px;
}
.footer-block p{
  font-size:12px;line-height:1.65;
  color:var(--muted);
}
.footer-block--important{
  border-color:rgba(251,146,60,.25);
  background:rgba(251,146,60,.05);
}
.footer-block--important h4{
  color:#fb923c;
}
.footer-block--important p{
  color:rgba(255,255,255,.55);
}
body.light .footer-block--important p{
  color:rgba(0,0,0,.5);
}

/* Bottom bar */
.footer-bottom{
  border-top:1px solid var(--border);
  padding-top:20px;
  font-size:11px;
  color:var(--hint);
  text-align:center;
}

@media(max-width:700px){
  .footer-disclaimer{grid-template-columns:1fr}
  .site-footer{margin-top:40px;padding:32px 0 24px}
}

/* ══════════════════════════════════════════
   ANNOUNCEMENT BAR
══════════════════════════════════════════ */
.announce-bar{
  width:100%;
  background:linear-gradient(90deg,var(--accent) 0%,var(--accent2) 100%);
  overflow:hidden;
  height:0;
  opacity:0;
  transition:height .4s ease, opacity .4s ease;
  flex-shrink:0;
  position:relative;
  z-index:99;
}
.announce-bar.visible{
  height:38px;
  opacity:1;
}
.announce-track{
  display:flex;
  align-items:center;
  justify-content:center;
  height:38px;
  /* The slide-in animation */
  animation:announceSlide 0.5s cubic-bezier(.25,.46,.45,.94) both;
}
@keyframes announceSlide{
  from{transform:translateX(-32px);opacity:0}
  to{transform:translateX(0);opacity:1}
}
.announce-msg{
  display:flex;align-items:center;gap:14px;
  white-space:nowrap;
}
.announce-text{
  font-size:13px;font-weight:500;
  color:rgba(255,255,255,.95);
  letter-spacing:.01em;
}
.announce-text strong{
  font-weight:800;color:#fff;
}
.announce-cta{
  padding:4px 14px;border-radius:20px;
  background:rgba(255,255,255,.22);
  border:1.5px solid rgba(255,255,255,.5);
  color:#fff;font-size:12px;font-weight:700;
  cursor:pointer;font-family:inherit;
  transition:background .15s,transform .15s;
  white-space:nowrap;
  letter-spacing:.03em;
}
.announce-cta:hover{
  background:rgba(255,255,255,.35);
  transform:scale(1.04);
}
.announce-cta:active{transform:scale(.97)}

@media(max-width:480px){
  .announce-text{font-size:11px}
  .announce-msg{gap:8px}
  .announce-cta{font-size:11px;padding:3px 10px}
}

/* ── SKELETON LOADER ── */
/* Signup offer popup */
.signup-popup{
  position:fixed;inset:0;z-index:23000;
  display:flex;align-items:center;justify-content:center;padding:18px;
  background:rgba(2,2,8,.62);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);
  opacity:0;pointer-events:none;transition:opacity .22s ease;
}
.signup-popup.open{opacity:1;pointer-events:auto}
.signup-popup-panel{
  position:relative;width:min(470px,calc(100vw - 28px));
  padding:28px 24px 22px;border-radius:22px;text-align:center;
  border:1px solid rgba(255,255,255,.1);
  background:
    radial-gradient(circle at 50% -10%,rgba(var(--accent-rgb),.16),transparent 34%),
    linear-gradient(160deg,#10101b,#07070d 74%);
  box-shadow:0 30px 90px rgba(0,0,0,.72),0 0 0 1px rgba(255,255,255,.025);
  transform:translateY(12px) scale(.98);transition:transform .22s ease;
}
.signup-popup.open .signup-popup-panel{transform:translateY(0) scale(1)}
.signup-popup-close{
  position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;
  border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.035);
  color:var(--text-mid);font-size:15px;cursor:pointer;
}
.signup-popup-close:hover{border-color:var(--border-hover);color:#fff}
.signup-popup-kicker{
  padding-right:20px;color:var(--accent);font-size:9px;font-weight:800;
  letter-spacing:.36em;text-transform:uppercase;
}
.signup-popup h2{
  max-width:390px;margin:12px auto 0;color:var(--text-strong);
  font-size:25px;line-height:1.12;letter-spacing:-.55px;
}
.signup-popup p{
  max-width:400px;margin:13px auto 0;color:var(--muted);
  font-size:14px;line-height:1.5;
}
.signup-popup-cta{
  width:100%;margin-top:20px;padding:13px 18px;border:0;border-radius:999px;
  background:linear-gradient(100deg,var(--accent),var(--accent2));
  color:#fff;font:inherit;font-size:14px;font-weight:800;cursor:pointer;
  box-shadow:0 12px 26px rgba(var(--accent-rgb),.28);
  transition:transform .16s,filter .16s;
}
.signup-popup-cta:hover{filter:brightness(1.08);transform:translateY(-1px)}
.signup-popup-later{
  display:flex;align-items:center;gap:10px;margin-top:18px;
  color:var(--muted);font-size:11px;
}
.signup-popup-later span{height:1px;flex:1;background:var(--border)}
.signup-popup-optout{
  display:inline-flex;align-items:center;gap:8px;margin-top:14px;
  color:var(--muted);font-size:12px;cursor:pointer;
}
.signup-popup-optout input{width:13px;height:13px;accent-color:var(--accent)}
body.light .signup-popup-panel{background:#fff}
@media(max-width:480px){
  .signup-popup-panel{padding:26px 18px 19px;border-radius:18px}
  .signup-popup h2{font-size:22px}
  .signup-popup p{font-size:13px}
}

.skeleton{
  background:linear-gradient(90deg,var(--surface) 25%,rgba(255,255,255,.08) 50%,var(--surface) 75%);
  background-size:200% 100%;
  animation:skeleton-wave 1.4s ease infinite;
}
@keyframes skeleton-wave{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.skeleton-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  width:100%;
}
.skeleton-card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
}
@media(max-width:900px){.skeleton-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.skeleton-grid{grid-template-columns:repeat(2,1fr)}}
