:root {
  --primary: #635bff;
  --secondary: #12c2e9;
  --accent: #b065ff;
  --max: 1520px;
  --bg: #f4f7fb;
  --bg-2: #eef3fb;
  --panel: rgba(255, 255, 255, 0.82);
  --panel-strong: #ffffff;
  --panel-soft: rgba(255, 255, 255, 0.58);
  --ink: #0f172a;
  --muted: #667085;
  --muted-strong: #2b3445;
  --border: rgba(15, 23, 42, 0.08);
  --border-strong: rgba(15, 23, 42, 0.14);
  --shadow: 0 24px 70px rgba(15, 23, 42, 0.12);
  --shadow-soft: 0 12px 36px rgba(15, 23, 42, 0.08);
  --radius-xl: 34px;
  --radius-lg: 26px;
  --radius-md: 20px;
  --radius-sm: 16px;
}

.dark-theme {
  --bg: #060b16;
  --bg-2: #0b1221;
  --panel: rgba(15, 23, 42, 0.72);
  --panel-strong: #0f172a;
  --panel-soft: rgba(15, 23, 42, 0.46);
  --ink: #edf2ff;
  --muted: #95a2c0;
  --muted-strong: #d9e2ff;
  --border: rgba(255, 255, 255, 0.08);
  --border-strong: rgba(255, 255, 255, 0.14);
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.4);
  --shadow-soft: 0 12px 36px rgba(0, 0, 0, 0.26);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 8% 12%, color-mix(in srgb, var(--primary) 18%, transparent), transparent 26%),
    radial-gradient(circle at 92% 10%, color-mix(in srgb, var(--secondary) 14%, transparent), transparent 22%),
    radial-gradient(circle at 72% 82%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 20%),
    linear-gradient(180deg, var(--bg-2), var(--bg));
  overflow-x: hidden;
}
body.modal-open { overflow: hidden; }

.page-noise {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: .038;
  background-image: radial-gradient(rgba(255,255,255,.7) 1px, transparent 1px);
  background-size: 18px 18px;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }

.container {
  width: min(calc(100% - 28px), 1260px);
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.container.wide { width: min(calc(100% - 28px), var(--max)); }
.section { padding: 34px 0; }
.section-spaced { padding-top: 52px; padding-bottom: 52px; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 60;
  backdrop-filter: blur(18px);
  background: color-mix(in srgb, var(--bg) 84%, transparent);
  border-bottom: 1px solid var(--border);
}

.nav-wrap {
  min-height: 86px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.brand-mark {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  color: white;
  font-weight: 900;
  letter-spacing: .04em;
  box-shadow: var(--shadow-soft);
}
.brand-mark.small-mark { width: 42px; height: 42px; border-radius: 14px; }
.brand-copy { display: flex; flex-direction: column; line-height: 1.05; }
.brand-copy strong { font-size: .95rem; }
.brand-copy small { color: var(--muted); font-size: .76rem; }

.site-nav {
  display: flex;
  align-items: center;
  gap: 24px;
}
.site-nav a {
  position: relative;
  color: var(--muted);
  font-weight: 600;
}
.site-nav a:hover,
.site-nav a.active { color: var(--ink); }
.site-nav a.active::after,
.site-nav a:hover::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -10px;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
}

.nav-actions { display: flex; align-items: center; gap: 10px; }
.theme-toggle,
.menu-toggle,
.modal-close {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--panel);
  color: var(--ink);
}
.menu-toggle { display: none; }
.desktop-only { display: inline-flex; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 20px;
  border-radius: 16px;
  border: 1px solid transparent;
  font-weight: 700;
  transition: transform .26s ease, box-shadow .26s ease, border-color .26s ease, background .26s ease;
}
.btn { position: relative; overflow: hidden; }
.btn::after { content: ''; position: absolute; inset: -130% auto -130% -30%; width: 42%; transform: rotate(18deg) translateX(-170%); background: linear-gradient(90deg, transparent, rgba(255,255,255,.34), transparent); transition: transform .75s ease; }
.btn:hover { transform: translateY(-2px); }
.btn:hover::after { transform: rotate(18deg) translateX(420%); }
.btn-primary {
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: white;
  box-shadow: var(--shadow-soft);
}
.btn-soft {
  background: var(--panel);
  color: var(--ink);
  border-color: var(--border);
}
.btn-ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--border-strong);
}
.btn-sm { padding: 10px 16px; font-size: .92rem; }
.btn-xs { padding: 8px 12px; font-size: .82rem; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 72%, transparent);
}

.hero-section { padding-top: 54px; }
.hero-minimal { padding-bottom: 24px; }
.compact-metrics { max-width: 720px; }
.compact-metrics article { animation: floatSoft 8s ease-in-out infinite; }
.compact-metrics article:nth-child(2) { animation-delay: -.8s; }
.compact-metrics article:nth-child(3) { animation-delay: -1.6s; }
.hero-grid,
.split-grid,
.catalog-grid,
.product-layout,
.contact-shell,
.detail-grid,
.admin-layout,
.admin-products-layout {
  display: grid;
  gap: 24px;
}
.hero-grid { grid-template-columns: minmax(0, 1fr) minmax(560px, .96fr); align-items: center; }
.catalog-grid { grid-template-columns: 1.02fr .98fr; align-items: end; }
.split-grid.slim-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.contact-shell { grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr); }
.product-layout { grid-template-columns: minmax(0, 1.2fr) minmax(320px, .58fr); align-items: start; }
.detail-grid.two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-layout { grid-template-columns: 270px minmax(0, 1fr); align-items: start; }
.admin-products-layout { grid-template-columns: 260px minmax(0, 1fr); align-items: start; }

.hero-copy h1,
.catalog-copy h1,
.partnership-hero h1,
.product-headline-row h1,
.info-panel h1,
.info-panel h2,
.contact-panel h2,
.auth-card h1,
.section-head h2 {
  margin: 14px 0 12px;
  font-size: clamp(2.25rem, 5.2vw, 4.9rem);
  line-height: .95;
  letter-spacing: -.05em;
}
.section-head h2,
.info-panel h2,
.contact-panel h2,
.compact-head h2 { font-size: clamp(1.6rem, 3vw, 2.6rem); line-height: 1.02; }
.hero-lead,
.section-copy,
.info-panel p,
.contact-panel p,
.product-tagline,
.auth-card p,
.modal-content p { color: var(--muted); line-height: 1.75; font-size: 1rem; }
.hero-lead { max-width: 680px; }
.hero-lead.compact { max-width: none; }
.hero-actions,
.form-actions,
.modal-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }

.hero-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 28px;
}
.hero-metrics article,
.contact-list div,
.price-stack div,
.modal-stat-grid div,
.admin-sidebar-stats article,
.stat-tile,
.filter-panel,
.info-panel,
.contact-card,
.contact-panel,
.detail-card,
.side-card,
.hero-frame,
.product-card,
.auth-card,
.admin-card,
.sticky-card,
.empty-card,
.glass-card {
  background: var(--panel);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px);
}
.hero-metrics article,
.contact-list div,
.price-stack div,
.modal-stat-grid div,
.admin-sidebar-stats article {
  padding: 16px 18px;
  border-radius: 18px;
}
.hero-metrics strong,
.contact-list strong,
.price-stack strong,
.modal-stat-grid strong,
.admin-sidebar-stats strong {
  display: block;
  font-size: 1rem;
  margin-bottom: 4px;
}
.hero-metrics span,
.contact-list span,
.price-stack span,
.modal-stat-grid span,
.admin-sidebar-stats span { color: var(--muted); font-size: .83rem; }

.hero-visual { position: relative; min-height: 560px; }
.hero-halo {
  position: absolute;
  border-radius: 999px;
  filter: blur(16px);
  pointer-events: none;
  animation: float 8s ease-in-out infinite;
}
.hero-halo-a {
  top: 30px;
  right: 30px;
  width: 190px;
  height: 190px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 60%, transparent), transparent);
}
.hero-halo-b {
  left: 24px;
  bottom: 38px;
  width: 140px;
  height: 140px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--secondary) 60%, transparent), transparent);
  animation-delay: -2s;
}
.hero-frame {
  position: absolute;
  inset: 24px 0 0;
  border-radius: var(--radius-xl);
  padding: 18px;
  overflow: hidden;
}
.frame-top { display: flex; gap: 8px; padding-bottom: 14px; }
.frame-top span { width: 10px; height: 10px; border-radius: 999px; background: color-mix(in srgb, var(--muted) 45%, transparent); }
.hero-stage {
  position: relative;
  min-height: 450px;
  border-radius: calc(var(--radius-xl) - 6px);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 88%, transparent), color-mix(in srgb, var(--panel-soft) 70%, transparent));
  border: 1px solid var(--border);
  overflow: hidden;
}
.hero-shot-shell {
  position: absolute;
  inset: 18px;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(145deg, color-mix(in srgb, var(--primary) 18%, transparent), transparent 52%);
}
.hero-shot-shell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-floating-card {
  position: absolute;
  padding: 14px 16px;
  border-radius: 20px;
  background: color-mix(in srgb, var(--panel-strong) 84%, transparent);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  max-width: 240px;
}
.hero-floating-card span,
.hero-floating-card small { display: block; color: var(--muted); font-size: .82rem; }
.hero-floating-card strong { display: block; margin-top: 4px; }
.top-card { top: 22px; left: 22px; }
.bottom-card { right: 22px; bottom: 22px; }
.hero-placeholder { padding: 34px; }
.placeholder-line { height: 18px; width: 48%; border-radius: 999px; background: color-mix(in srgb, var(--muted) 16%, transparent); margin-bottom: 14px; }
.placeholder-line.wide { width: 72%; height: 24px; }
.placeholder-panel { margin-top: 26px; min-height: 300px; border-radius: 22px; background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 18%, transparent), color-mix(in srgb, var(--secondary) 10%, transparent)); }

.strip-section { padding: 8px 0 0; }
.strip-track {
  display: flex;
  gap: 12px;
  overflow: auto;
  padding: 6px 0 6px 2px;
  scrollbar-width: none;
}
.strip-track::-webkit-scrollbar { display: none; }
.strip-pill,
.detail-pills span,
.feature-chip,
.tag,
.mini-meta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 76%, transparent);
  color: var(--ink);
  white-space: nowrap;
}
.strip-pill { animation: floatSoft 7s ease-in-out infinite; }
.strip-pill:nth-child(3n) { animation-delay: -.8s; }
.strip-pill:nth-child(4n) { animation-delay: -1.6s; }

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 24px;
}
.text-link { color: var(--primary); font-weight: 700; }

.product-grid.two-up {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}
.featured-grid > .product-card:first-child {
  grid-column: auto;
  display: block;
}
.featured-grid > .product-card:first-child .product-cover { aspect-ratio: 16 / 10; min-height: 0; }
.featured-grid > .product-card:first-child .product-body { justify-content: flex-start; }
.clean-grid { align-items: stretch; }
.catalog-focus-section .product-grid { margin-top: 8px; }
.full-section-head { width: min(calc(100% - 12px), var(--max)); }
.full-width-zone { width: min(calc(100% - 8px), var(--max)); }
.products-shell { display: grid; gap: 18px; }
.search-panel {
  position: relative;
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 30px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 90%, transparent), color-mix(in srgb, var(--panel) 92%, transparent));
}
.search-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 22%, transparent), color-mix(in srgb, var(--secondary) 12%, transparent), transparent 75%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}

.search-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
}
.search-field,
.filter-select {
  display: grid;
  gap: 8px;
}
.search-wide { grid-column: 1 / span 1; }
.search-input-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  min-height: 56px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 88%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25);
  transition: border-color .24s ease, box-shadow .24s ease, transform .24s ease;
}
.search-input-wrap:focus-within {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 12%, transparent), var(--shadow-soft);
  transform: translateY(-1px);
}
.search-icon {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary) 11%, transparent);
  color: var(--primary);
  font-size: 1rem;
  font-weight: 700;
}
.search-input-wrap input {
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
}
.filter-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
}
.filter-select select {
  min-height: 52px;
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel-strong) 88%, transparent);
}
.reset-btn { min-height: 52px; }
.results-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 8px 2px 0;
}
.results-bar strong {
  font-size: 1rem;
  letter-spacing: -.01em;
}
.results-bar span {
  color: var(--muted);
  font-size: .88rem;
}
.cta-band {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) auto auto;
  gap: 20px;
  align-items: center;
  padding: 28px;
  border-radius: 32px;
  background: linear-gradient(140deg, color-mix(in srgb, var(--panel-strong) 92%, transparent), color-mix(in srgb, var(--panel) 88%, transparent));
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
}
.cta-band::before {
  content: '';
  position: absolute;
  inset: -40% auto -40% -10%;
  width: 34%;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--primary) 12%, transparent), transparent);
  transform: rotate(12deg);
  animation: sweep 11s linear infinite;
}
.cta-band-copy,
.cta-band-meta,
.cta-band-actions { position: relative; z-index: 1; }
.cta-band-copy h2 { margin: 12px 0 10px; }
.cta-band-copy p { margin: 0; color: var(--muted); }
.cta-band-meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  color: var(--muted);
  font-size: .9rem;
}
.cta-band-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}
.hero-frame-clean,
.hero-stage-clean {
  box-shadow: var(--shadow);
}
.hero-stage-clean::after {
  content: '';
  position: absolute;
  inset: auto -16% -34% auto;
  width: 50%;
  aspect-ratio: 1;
  border-radius: 999px;
  background: radial-gradient(circle, color-mix(in srgb, var(--secondary) 24%, transparent), transparent 64%);
  animation: pulseGlow 8s ease-in-out infinite;
}
.hero-shot-clean::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.14), transparent 36%, transparent 64%, rgba(255,255,255,.06));
  z-index: 1;
  pointer-events: none;
}
.hero-shot-clean img { position: relative; z-index: 0; }
.soft-float { animation: floatSoft 6.5s ease-in-out infinite; }
.soft-float.delay-2 { animation-delay: -1.2s; }
.compact-copy h1 { margin-bottom: 10px; }
.compact-copy .section-copy { max-width: 700px; }
.compact-section-head { margin-bottom: 18px; }
.products-grid-section { padding-top: 22px; }


.product-card {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  transform-style: preserve-3d;
  transition: transform .28s ease, box-shadow .3s ease, border-color .3s ease;
}
.product-card::before {
  content: '';
  position: absolute;
  inset: -20% auto auto -30%;
  width: 48%;
  height: 150%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
  transform: rotate(16deg) translateX(-220%);
  transition: transform .9s ease, opacity .3s ease;
  opacity: 0;
  pointer-events: none;
}
.product-card::after {
  content: '';
  position: absolute;
  inset: auto 0 0 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--primary) 42%, transparent), transparent);
  transform: scaleX(.4);
  opacity: 0;
  transition: opacity .3s ease, transform .3s ease;
}
.product-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
  border-color: color-mix(in srgb, var(--primary) 20%, var(--border));
}
.product-card:hover::before { transform: rotate(16deg) translateX(360%); opacity: 1; }
.product-card:hover::after { opacity: 1; transform: scaleX(1); }
.product-cover {
  position: relative;
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 12%, transparent), color-mix(in srgb, var(--secondary) 8%, transparent));
}
.product-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .55s ease;
}
.product-card:hover .product-cover img { transform: scale(1.03); }
.product-body {
  padding: 16px 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.product-tagline {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.8em;
}
.product-meta-row,
.price-inline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.product-body h3 { margin: 0; font-size: 1.2rem; letter-spacing: -.02em; }
.product-tagline { margin: 0; }
.price-inline div span,
.price-inline small { color: var(--muted); font-size: .84rem; }
.price-inline strong { display: block; margin-top: 2px; font-size: 1.05rem; }
.split-actions { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.status-chip {
  position: absolute;
  right: 14px;
  top: 14px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  padding: 9px 12px;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 700;
  color: white;
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(12px);
}
.inline-chip { position: static; }
.status-chip.live { background: rgba(16, 185, 129, .88); }
.status-chip.pilot-ready { background: rgba(99, 91, 255, .9); }
.status-chip.demo { background: rgba(245, 158, 11, .88); }
.status-chip.seeking-partner { background: rgba(239, 68, 68, .88); }

.info-panel,
.contact-card,
.contact-panel,
.detail-card,
.side-card,
.filter-panel,
.auth-card,
.admin-card { border-radius: 28px; padding: 26px; }
.accent-panel { background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 88%, transparent), color-mix(in srgb, var(--primary) 12%, transparent)); }
.simple-list { margin: 0; padding-left: 1.2rem; display: grid; gap: 12px; color: var(--muted); }
.contact-list { display: grid; gap: 12px; margin-top: 22px; }
.contact-card,
.filter-panel { padding: 22px; }
.single-column-wrap { display: grid; }
.wide-card { max-width: 980px; margin-inline: auto; width: 100%; }

.products-hero { padding-top: 42px; }
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.form-grid.compact-grid { align-items: end; }
.lead-form { display: grid; gap: 14px; }
.lead-form label { display: grid; gap: 8px; }
.lead-form span { color: var(--muted); font-size: .84rem; font-weight: 600; }
.lead-form input,
.lead-form select,
.lead-form textarea {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 84%, transparent);
  color: var(--ink);
  outline: none;
  transition: border-color .22s ease, box-shadow .22s ease, background .22s ease;
}
.lead-form input:focus,
.lead-form select:focus,
.lead-form textarea:focus {
  border-color: color-mix(in srgb, var(--primary) 45%, var(--border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 14%, transparent);
}
.compact-actions { margin-top: 6px; }
.compact-head { margin-bottom: 10px; }
.compact-head h2 { margin: 10px 0 0; }
.empty-card { padding: 40px; text-align: center; border-radius: 28px; }

.product-headline-row {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: start;
}
.hero-image-card {
  padding: 12px;
  border-radius: 30px;
  background: var(--panel);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
}
.hero-image-card img {
  width: 100%;
  border-radius: 22px;
  object-fit: cover;
  cursor: zoom-in;
}
.thumb-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.thumb {
  padding: 6px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--panel);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.thumb img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 12px;
}
.thumb.active,
.thumb:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--primary) 40%, var(--border));
  box-shadow: var(--shadow-soft);
}
.sticky-card { position: sticky; top: 108px; }
.detail-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.detail-pills.large-pills { margin-top: 20px; }
.stacked-actions { display: grid; }
.chip-list { display: flex; flex-wrap: wrap; gap: 12px; }
.feature-chip { background: color-mix(in srgb, var(--secondary) 9%, var(--panel-strong)); }
.feature-chip.alt { background: color-mix(in srgb, var(--accent) 10%, var(--panel-strong)); }

.site-footer { padding: 28px 0 38px; }
.footer-wrap,
.footer-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
}
.footer-wrap {
  padding-top: 18px;
  border-top: 1px solid var(--border);
}
.footer-wrap p,
.footer-meta span,
.footer-meta a { color: var(--muted); }
.footer-links { display: flex; gap: 18px; }
.footer-links a { color: var(--muted); font-weight: 600; }
.footer-meta { padding-top: 12px; }

.flash-wrap { margin-top: 18px; }
.flash {
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
}
.flash-success { background: rgba(16, 185, 129, .12); color: #047857; border-color: rgba(16, 185, 129, .18); }
.flash-error { background: rgba(239, 68, 68, .12); color: #b91c1c; border-color: rgba(239, 68, 68, .18); }
.dark-theme .flash-success { color: #9ae6b4; }
.dark-theme .flash-error { color: #fca5a5; }

.modal-shell {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .24s ease, visibility .24s ease;
  z-index: 120;
}
.modal-shell.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 10, 20, .62);
  backdrop-filter: blur(12px);
}
.modal-card,
.lightbox-card {
  position: relative;
  z-index: 2;
  width: min(100%, 1040px);
  border-radius: 32px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 92%, transparent);
  box-shadow: var(--shadow);
  overflow: hidden;
  max-height: min(92vh, 920px);
  transform: translateY(18px) scale(.96);
  transition: transform .28s ease, opacity .28s ease;
}
.modal-shell.is-open .modal-card,
.modal-shell.is-open .lightbox-card { transform: translateY(0) scale(1); }
.modal-card { padding: 16px; overflow: auto; scrollbar-width: thin; }
.modal-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, .96fr);
  gap: 16px;
}
.modal-visual {
  background: linear-gradient(145deg, color-mix(in srgb, var(--primary) 18%, transparent), transparent 46%);
  border-radius: 24px;
  overflow: hidden;
  min-height: 360px;
}
.modal-visual img,
.lightbox-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.modal-content { padding: 16px 10px 12px 6px; }
.modal-content h3 { margin: 10px 0 10px; font-size: 2rem; letter-spacing: -.03em; }
.modal-kicker { color: var(--primary); font-weight: 700; }
.modal-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}
.lightbox-card {
  max-width: min(96vw, 1320px);
  max-height: 90vh;
  padding: 14px;
}
.lightbox-card img { border-radius: 20px; max-height: calc(90vh - 28px); }
.modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
}

.admin-body { background: linear-gradient(180deg, var(--bg-2), var(--bg)); }
.admin-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(18px);
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  border-bottom: 1px solid var(--border);
}
.admin-topbar-inner {
  min-height: 82px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.admin-branding { display: inline-flex; align-items: center; gap: 12px; }
.admin-branding small,
.admin-card-head p,
.admin-note { color: var(--muted); }
.admin-layout { padding: 30px 0 48px; }
.admin-sidebar {
  padding: 18px;
  border-radius: 28px;
  background: var(--panel);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
}
.admin-nav { display: grid; gap: 8px; }
.admin-nav a {
  padding: 12px 14px;
  border-radius: 14px;
  color: var(--muted);
  font-weight: 700;
}
.admin-nav a:hover { background: color-mix(in srgb, var(--primary) 10%, transparent); color: var(--ink); }
.admin-sidebar-stats { display: grid; gap: 10px; margin-top: 18px; }
.admin-content { display: grid; gap: 20px; }
.admin-card { display: grid; gap: 18px; }
.admin-section { padding: 26px; }
.admin-card-head { display: flex; justify-content: space-between; gap: 16px; align-items: end; }
.admin-card-head h2 { margin: 0; font-size: 1.45rem; }
.admin-card-head h3 { margin: 0; font-size: 1.1rem; }
.admin-form-group { display: grid; gap: 14px; padding-top: 8px; border-top: 1px solid var(--border); }
.admin-form-group:first-of-type { border-top: 0; padding-top: 0; }
.admin-form-group h3 { margin: 0; font-size: 1rem; }
.three-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.two-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.checkbox-line {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  align-self: end;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 84%, transparent);
}
.checkbox-line input { width: auto !important; }
.admin-list {
  display: grid;
  gap: 10px;
  max-height: 880px;
  overflow: auto;
}
.admin-product-item {
  display: grid;
  gap: 4px;
  text-align: left;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 84%, transparent);
  color: var(--muted);
  transition: transform .22s ease, border-color .22s ease, color .22s ease;
}
.admin-product-item strong { color: var(--ink); }
.admin-product-item small { color: var(--muted); }
.admin-product-item:hover,
.admin-product-item.active {
  transform: translateY(-1px);
  color: var(--ink);
  border-color: color-mix(in srgb, var(--primary) 38%, var(--border));
  box-shadow: var(--shadow-soft);
}
.admin-editor-stack { display: grid; gap: 18px; }
.code-area {
  min-height: 320px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: .86rem;
}
.lead-table-wrap { overflow: auto; }
.lead-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 980px;
}
.lead-table th,
.lead-table td {
  padding: 14px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.lead-table th { color: var(--muted); font-size: .82rem; text-transform: uppercase; letter-spacing: .05em; }
.message-cell { max-width: 360px; white-space: normal; color: var(--muted); }

.auth-body { display: grid; place-items: center; }
.auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 28px;
}
.auth-card {
  width: min(100%, 480px);
  padding: 28px;
  border-radius: 28px;
}
.auth-note { margin-top: 8px; color: var(--muted); }

.reveal {
  opacity: 0;
  transform: translateY(22px) scale(.99);
  transition: opacity .72s ease, transform .72s ease;
}
.reveal.is-visible { opacity: 1; transform: translateY(0) scale(1); }
.product-grid .product-card:nth-child(2) { transition-delay: .04s; }
.product-grid .product-card:nth-child(3) { transition-delay: .08s; }
.product-grid .product-card:nth-child(4) { transition-delay: .12s; }
.product-grid .product-card:nth-child(5) { transition-delay: .16s; }
.product-grid .product-card:nth-child(6) { transition-delay: .2s; }
.reveal-delay-1 { transition-delay: .12s; }
.reveal-delay-2 { transition-delay: .24s; }

@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
}

@keyframes floatSoft {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-5px); }
}

@keyframes sweep {
  0% { transform: rotate(12deg) translateX(-140%); }
  100% { transform: rotate(12deg) translateX(360%); }
}

@keyframes pulseGlow {
  0%, 100% { opacity: .55; transform: scale(1); }
  50% { opacity: .95; transform: scale(1.08); }
}

@media (max-width: 1280px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-visual { min-height: auto; }
  .hero-frame { position: relative; inset: auto; }
  .catalog-grid,
  .contact-shell,
  .product-layout,
  .admin-layout,
  .admin-products-layout,
  .split-grid.slim-grid,
  .detail-grid.two-up,
  .modal-grid { grid-template-columns: 1fr; }
  .sticky-card { position: static; }
  .featured-grid > .product-card:first-child { grid-column: span 1; display: block; }
}

@media (max-width: 920px) {
  .site-nav {
    position: absolute;
    top: 82px;
    left: 14px;
    right: 14px;
    display: none;
    flex-direction: column;
    gap: 14px;
    padding: 18px;
    border-radius: 20px;
    background: var(--panel-strong);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
  }
  .site-nav.open { display: flex; }
  .menu-toggle { display: inline-grid; place-items: center; }
  .desktop-only { display: none; }
  .site-nav a.active::after,
  .site-nav a:hover::after { display: none; }
  .hero-metrics,
  .form-grid,
  .thumb-row,
  .modal-stat-grid,
  .three-grid,
  .two-grid { grid-template-columns: 1fr; }
  .product-grid.two-up { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
  .split-actions { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .search-toolbar, .filter-toolbar, .cta-band { grid-template-columns: 1fr; }
  .cta-band-actions { justify-content: flex-start; }
  .results-bar { flex-direction: column; align-items: flex-start; }
  .product-headline-row { flex-direction: column; }
  .footer-wrap,
  .footer-meta { flex-direction: column; align-items: start; }
  .lightbox-card { max-width: 96vw; }
}

@media (max-width: 640px) {
  .hero-copy h1,
  .catalog-copy h1,
  .partnership-hero h1,
  .product-headline-row h1,
  .info-panel h1 { font-size: clamp(2rem, 11vw, 3.2rem); }
  .product-body { padding: 14px 14px 16px; gap: 10px; }
  .product-body h3 { font-size: 1rem; }
  .product-tagline { min-height: 2.5em; font-size: .88rem; }
  .price-inline strong { font-size: .94rem; }
  .price-inline small, .price-inline div span, .mini-meta { font-size: .74rem; }
  .split-actions .btn { min-height: 40px; padding: 9px 10px; font-size: .8rem; }
  .section-head { flex-direction: column; align-items: start; }
  .hero-section { padding-top: 34px; }
  .hero-frame,
  .info-panel,
  .contact-card,
  .contact-panel,
  .detail-card,
  .side-card,
  .auth-card,
  .admin-card { padding: 20px; }
  .modal-card { padding: 12px; }
}

@media (prefers-reduced-motion: reduce) {
  .product-card, .hero-frame, .search-panel, .cta-band, .strip-pill, .hero-halo, .compact-metrics article { animation: none !important; transition: none !important; transform: none !important; }
}


/* --- Refinements: logo, investor metrics, cleaner layouts --- */
.brand-logo-shell {
  width: 50px;
  height: 50px;
  border-radius: 18px;
  display: inline-grid;
  place-items: center;
  padding: 8px;
  background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}
.brand-logo-shell.admin-logo-shell { width: 42px; height: 42px; border-radius: 14px; }
.brand-logo { width: 100%; height: 100%; object-fit: contain; }
.logo-preview-card {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-height: 88px;
  padding: 18px;
  border-radius: 20px;
  border: 1px dashed var(--border-strong);
  background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
}
.logo-preview-card img { max-width: 180px; max-height: 52px; object-fit: contain; }

.filter-select select,
.lead-form select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2395a2c0' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 46px !important;
}
.filter-select select option,
.lead-form select option {
  background: var(--panel-strong);
  color: var(--ink);
}
.dark-theme .filter-select select option,
.dark-theme .lead-form select option {
  background: #0f172a;
  color: #edf2ff;
}
.search-panel {
  gap: 12px;
  padding: 16px;
  border-radius: 28px;
}
.search-toolbar,
.filter-toolbar {
  gap: 12px;
}
.results-bar {
  padding: 0 4px;
}

.product-main { display: grid; gap: 18px; align-content: start; }
.product-layout-balanced { align-items: start; }
.inline-detail-grid { margin-top: 6px; }
.side-stack-card {
  display: grid;
  gap: 18px;
}
.compact-price-stack {
  gap: 12px;
}
.compact-price-stack div { border-radius: 20px; }
.investor-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 92%, transparent), color-mix(in srgb, var(--primary) 7%, transparent));
  border: 1px solid var(--border);
}
.investor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 12px;
}
.investor-grid div,
.revenue-strip span {
  padding: 13px 14px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 80%, transparent);
}
.investor-grid strong,
.revenue-strip strong {
  display: block;
  margin-top: 4px;
  font-size: .98rem;
}
.investor-grid span,
.revenue-strip span {
  color: var(--muted);
  font-size: .8rem;
}
.investor-note,
.modal-note {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
  font-size: .9rem;
}
.compact-pills { margin-top: 0; }
.tight-stack-actions { margin-top: 0; }
.revenue-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.compact-revenue-strip {
  margin-top: 2px;
}
.compact-revenue-strip span strong { margin-top: 2px; }
.adaptive-thumbs {
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.partnership-shell { display: grid; gap: 18px; }
.partnership-hero-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: end;
}
.partnership-actions-block {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
}
.partnership-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  padding: 18px;
  border-radius: 28px;
  background: var(--panel);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
}
.partnership-band > div {
  padding: 16px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
}
.band-kicker {
  display: block;
  color: var(--primary);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.partnership-band strong { display: block; font-size: 1.08rem; margin-bottom: 4px; }
.partnership-band small { color: var(--muted); line-height: 1.6; display: block; }
.compact-modal-card {
  width: min(100%, 720px);
}
.partnership-modal-card { width: min(100%, 760px); }
.compact-modal-content {
  padding: 14px 8px 10px;
}
.compact-modal-content h3 {
  margin: 12px 0 10px;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  line-height: 1;
  letter-spacing: -.04em;
}

.modal-stat-grid.investor-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.modal-note:empty { display: none; }

.product-grid.two-up.catalog-cards,
.product-grid.two-up.clean-grid {
  align-items: stretch;
}
.product-grid.two-up .product-card { height: 100%; }
.product-body { height: 100%; }
.card-actions.split-actions { margin-top: auto; }

@media (max-width: 1280px) {
  .partnership-hero-card { grid-template-columns: 1fr; align-items: start; }
  .partnership-actions-block { justify-content: flex-start; }
}

@media (max-width: 920px) {
  .revenue-strip,
  .modal-stat-grid.investor-grid,
  .investor-grid,
  .partnership-band {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .revenue-strip,
  .modal-stat-grid.investor-grid,
  .investor-grid,
  .partnership-band,
  .partnership-hero-card {
    grid-template-columns: 1fr;
  }
  .brand-logo-shell { width: 46px; height: 46px; }
  .compact-modal-card,
  .partnership-modal-card { width: min(100%, 100%); }
}


/* --- Final refinements: cleaner partnership page, stronger selects, safer modals --- */
.filter-select span,
.search-field span {
  color: var(--muted-strong);
}
.search-panel-clean {
  padding: 18px;
  border-radius: 30px;
}
.catalog-filter-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(210px, .72fr) minmax(210px, .72fr) auto;
  gap: 14px;
  align-items: end;
}
.compact-products-shell {
  gap: 18px;
}
.compact-catalog-copy .section-copy {
  max-width: 560px;
}
.compact-results-bar {
  padding: 0 4px;
}
.compact-filter-field {
  min-width: 0;
}
.filter-actions {
  display: flex;
  align-items: end;
  gap: 12px;
}
.filter-actions .btn {
  min-height: 56px;
}
.select-shell {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 56px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 88%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
  transition: border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}
.select-shell::after {
  content: '';
  position: absolute;
  right: 18px;
  width: 10px;
  height: 10px;
  border-right: 2px solid color-mix(in srgb, var(--ink) 70%, transparent);
  border-bottom: 2px solid color-mix(in srgb, var(--ink) 70%, transparent);
  transform: rotate(45deg) translateY(-2px);
  pointer-events: none;
}
.select-shell:focus-within {
  border-color: color-mix(in srgb, var(--primary) 44%, var(--border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 12%, transparent), var(--shadow-soft);
  transform: translateY(-1px);
}
.select-shell select {
  width: 100%;
  min-height: 56px;
  border: 0 !important;
  outline: none;
  background: transparent !important;
  background-image: none !important;
  color: var(--ink) !important;
  -webkit-text-fill-color: var(--ink) !important;
  padding: 0 44px 0 16px !important;
  box-shadow: none !important;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
}
.filter-select select,
.lead-form select {
  color-scheme: light;
}
.dark-theme .filter-select select,
.dark-theme .lead-form select,
.dark-theme .select-shell select {
  color-scheme: dark;
}
.select-shell select option,
.filter-select select option,
.lead-form select option {
  background: #ffffff;
  color: #0f172a;
}
.dark-theme .select-shell select option,
.dark-theme .filter-select select option,
.dark-theme .lead-form select option {
  background: #0f172a;
  color: #edf2ff;
}
.lead-select-shell {
  min-height: 52px;
}
.lead-select-shell select {
  min-height: 52px;
}

.partnership-clean-shell {
  display: grid;
  gap: 18px;
}
.conversation-card {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, .88fr);
  gap: 20px;
  padding: 22px;
  border-radius: 32px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 90%, transparent), color-mix(in srgb, var(--panel) 84%, transparent));
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
}
.conversation-copy {
  padding: 10px 10px 10px 8px;
}
.conversation-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}
.conversation-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}
.conversation-strip span {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 74%, transparent);
  color: var(--ink);
  font-size: .86rem;
  font-weight: 600;
}
.conversation-board {
  position: relative;
  display: grid;
  gap: 14px;
  padding: 20px;
  border-radius: 28px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 86%, transparent), color-mix(in srgb, var(--primary) 8%, transparent));
  overflow: hidden;
}
.conversation-board::before {
  content: '';
  position: absolute;
  inset: -20% auto auto -10%;
  width: 60%;
  height: 180%;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--primary) 10%, transparent), transparent);
  transform: rotate(16deg);
  animation: sweep 12s linear infinite;
  pointer-events: none;
}
.board-kicker {
  position: relative;
  z-index: 1;
  color: var(--primary);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.conversation-points {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
}
.conversation-step {
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 78%, transparent);
}
.conversation-step strong {
  display: block;
  margin-bottom: 6px;
  font-size: 1rem;
}
.conversation-step p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
  font-size: .92rem;
}
.conversation-note {
  position: relative;
  z-index: 1;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  color: var(--muted);
  line-height: 1.7;
  font-size: .92rem;
}
.partnership-modal-card {
  width: min(100%, 920px);
}
.partnership-modal-layout {
  display: grid;
  grid-template-columns: minmax(260px, .82fr) minmax(0, 1.18fr);
  gap: 16px;
}
.partnership-modal-aside {
  display: grid;
  gap: 14px;
  align-content: start;
  padding: 22px;
  border-radius: 24px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 88%, transparent), color-mix(in srgb, var(--primary) 7%, transparent));
}
.partnership-modal-aside h3,
.partnership-form-panel h3 {
  margin: 10px 0 8px;
  font-size: clamp(1.45rem, 2.4vw, 2.2rem);
  line-height: 1.02;
  letter-spacing: -.04em;
}
.partnership-modal-aside p,
.partnership-form-panel p {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
}
.partnership-mini-list {
  display: grid;
  gap: 12px;
}
.partnership-mini-list div {
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 76%, transparent);
}
.partnership-mini-list span {
  display: block;
  color: var(--muted);
  font-size: .8rem;
  margin-bottom: 4px;
}
.partnership-mini-list strong {
  display: block;
  font-size: .95rem;
  line-height: 1.5;
}
.partnership-form-panel {
  display: grid;
  gap: 14px;
  padding: 10px 8px 6px 6px;
}

@media (max-width: 1280px) {
  .catalog-filter-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
  .search-field.search-wide {
    grid-column: 1 / -1;
  }
  .filter-actions {
    grid-column: 1 / -1;
  }
}

@media (max-width: 920px) {
  .catalog-filter-grid,
  .conversation-card,
  .partnership-modal-layout {
    grid-template-columns: 1fr;
  }
  .filter-actions {
    justify-content: stretch;
  }
  .filter-actions .btn {
    flex: 1 1 0;
  }
  .conversation-copy {
    padding: 2px;
  }
}

@media (max-width: 640px) {
  .catalog-filter-grid {
    grid-template-columns: 1fr;
  }
  .filter-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .partnership-modal-aside,
  .partnership-form-panel {
    padding-inline: 4px;
  }
  .conversation-card {
    padding: 18px;
  }
}


.tag {
  background: color-mix(in srgb, var(--primary) 14%, var(--panel-strong));
  color: var(--muted-strong);
  font-weight: 700;
}
.mini-meta {
  color: var(--muted-strong);
}
.dark-theme .tag {
  background: color-mix(in srgb, var(--primary) 18%, #111b2f);
  color: #f5f7ff;
}


/* --- Cleanup pass: preview/open restored, cleaner partner page, ROI removed --- */
.single-clean-revenue {
  grid-template-columns: 1fr;
}
.single-clean-revenue span {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.single-clean-revenue strong {
  margin-top: 0;
}
.card-actions.split-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.card-actions.split-actions .btn {
  min-height: 44px;
}
.modal-actions .btn {
  min-height: 46px;
}
.partnership-minimal-shell {
  display: grid;
}
.partnership-hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, .95fr);
  gap: 20px;
  padding: 22px;
  border-radius: 32px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 90%, transparent), color-mix(in srgb, var(--panel) 84%, transparent));
  border: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
}
.partnership-copy {
  display: grid;
  align-content: center;
  gap: 12px;
  padding: 8px 6px;
}
.partnership-copy p {
  margin: 0;
  color: var(--muted);
  line-height: 1.75;
  max-width: 62ch;
}
.partnership-lane-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.lane-card {
  display: grid;
  gap: 6px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 80%, transparent);
}
.lane-kicker {
  color: var(--primary);
  font-size: .76rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.lane-card strong {
  font-size: 1rem;
}
.lane-card small {
  color: var(--muted);
  line-height: 1.6;
}
.partnership-clean-modal {
  width: min(100%, 720px);
}
.partnership-form-panel.only-panel {
  padding: 8px 8px 6px;
}
.partnership-form-panel.only-panel h3 {
  margin: 10px 0 8px;
  font-size: clamp(1.8rem, 4vw, 2.5rem);
  line-height: 1;
  letter-spacing: -.04em;
}
.partnership-form-panel.only-panel p {
  margin: 0 0 6px;
}
@media (max-width: 920px) {
  .partnership-hero-panel {
    grid-template-columns: 1fr;
  }
}

/* --- Refresh: preview buttons + typed hero + richer preview modal --- */
.card-actions.split-actions {
  position: relative;
  z-index: 2;
}
.card-actions.split-actions .btn {
  display: inline-flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  align-items: center;
  justify-content: center;
}
.card-actions.split-actions .quick-view {
  border-color: color-mix(in srgb, var(--primary) 26%, var(--border));
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 86%, transparent), color-mix(in srgb, var(--primary) 8%, transparent));
}
.card-actions.split-actions .quick-view:hover {
  border-color: color-mix(in srgb, var(--primary) 42%, var(--border));
}

.hero-copy .typing-target {
  display: block;
  position: relative;
}
.hero-copy h1.typing-target {
  width: 100%;
}
.typing-target-lead {
  display: block;
}
.typing-target.is-typing::after,
.typing-target.typing-done::after {
  content: '';
  display: inline-block;
  width: 2px;
  height: 1.02em;
  margin-left: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--secondary), var(--accent));
  vertical-align: -0.08em;
  animation: caretBlink .9s steps(1) infinite;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--primary) 16%, transparent), 0 0 18px color-mix(in srgb, var(--secondary) 20%, transparent);
}
.typing-target.typing-complete::after {
  display: none;
}

.preview-modal-grid {
  align-items: stretch;
}
.modal-preview-stack {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 12px;
  padding: 12px;
}
.modal-thumb-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.modal-thumb {
  padding: 5px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--panel-strong) 82%, transparent);
  transition: transform .24s ease, border-color .24s ease, box-shadow .24s ease;
}
.modal-thumb img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 12px;
}
.modal-thumb:hover,
.modal-thumb.active {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--primary) 44%, var(--border));
  box-shadow: var(--shadow-soft);
}
.modal-thumb-row[hidden] {
  display: none;
}

@keyframes caretBlink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}

@media (max-width: 920px) {
  .modal-thumb-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .modal-thumb-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


/* --- Rotating headline + stronger card actions --- */
.typing-rotator {
  min-height: 1.18em;
  max-width: 12ch;
}
.hero-copy .hero-lead {
  max-width: 62ch;
}
.card-actions.split-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.card-actions.split-actions .btn {
  font-weight: 700;
  letter-spacing: -.01em;
}
.card-actions.split-actions .card-open {
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: #fff;
}
@media (max-width: 820px) {
  .typing-rotator {
    max-width: 100%;
  }
}


/* --- final refinement: visible card actions, smaller rotating hero, fuller footer, hero carousel --- */
.hero-copy .hero-rotating-title {
  font-size: clamp(2rem, 4.2vw, 3.7rem);
  line-height: .98;
  letter-spacing: -.045em;
  max-width: 11.8ch;
}
.typing-rotator {
  min-height: 1.22em;
  max-width: 11.8ch;
}
.hero-carousel-stage {
  isolation: isolate;
}
.hero-carousel-image {
  transition: opacity .28s ease, transform .5s ease, filter .3s ease;
}
.hero-carousel-image.is-swapping {
  opacity: .58;
  transform: scale(1.02);
  filter: saturate(.92);
}
.hero-shot-shell.carousel-shell::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,12,24,0) 48%, rgba(7,12,24,.18) 100%);
  pointer-events: none;
}
.hero-rotator-card {
  position: absolute;
  left: 50%;
  bottom: 26px;
  transform: translateX(-50%);
  min-width: min(76%, 320px);
  max-width: 360px;
  padding: 16px 18px;
  border-radius: 22px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 90%, transparent), color-mix(in srgb, var(--panel) 88%, transparent));
  border: 1px solid color-mix(in srgb, var(--primary) 20%, var(--border));
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  z-index: 3;
}
.hero-rotator-kicker {
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--primary);
  font-weight: 800;
}
.hero-rotator-card strong {
  display: block;
  margin-top: 8px;
  font-size: 1.06rem;
  letter-spacing: -.02em;
}
.hero-rotator-card span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: .9rem;
}
.hero-rotator-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-weight: 700;
  color: var(--ink);
}
.hero-rotator-link:hover { color: var(--primary); }
.hero-rotator-dots {
  position: absolute;
  left: 24px;
  bottom: 24px;
  display: flex;
  gap: 8px;
  z-index: 4;
}
.hero-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 0;
  background: color-mix(in srgb, var(--muted) 28%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--border-strong) 90%, transparent);
  transition: transform .24s ease, background .24s ease, width .24s ease;
}
.hero-dot.active {
  width: 28px;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
}
.hero-info-pill,
.hero-price-pill {
  z-index: 4;
}
.hero-info-pill strong,
.hero-price-pill strong {
  color: var(--ink);
}
.always-on-actions {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: auto;
}
.always-on-actions .btn {
  min-height: 46px;
  width: 100%;
  padding: 11px 12px;
  gap: 8px;
  border-radius: 16px;
  font-weight: 800;
  font-size: .9rem;
  letter-spacing: -.01em;
}
.always-on-actions .btn-icon {
  font-size: .94rem;
  line-height: 1;
  opacity: .9;
}
.card-actions.split-actions .quick-view,
.always-on-actions .quick-view {
  color: var(--ink);
  border-color: color-mix(in srgb, var(--primary) 28%, var(--border));
  background: linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 92%, transparent), color-mix(in srgb, var(--primary) 8%, transparent));
}
.card-actions.split-actions .card-open,
.always-on-actions .card-open {
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: #fff;
  border-color: transparent;
  box-shadow: 0 12px 30px color-mix(in srgb, var(--primary) 22%, transparent);
}
.image-fallback-card {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  padding: 22px;
  text-align: center;
  font-weight: 800;
  font-size: 1.1rem;
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
}
.site-footer {
  position: relative;
  overflow: hidden;
  margin-top: 36px;
  padding: 32px 0 42px;
  background:
    radial-gradient(circle at 12% 20%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 28%),
    radial-gradient(circle at 88% 24%, color-mix(in srgb, var(--secondary) 12%, transparent), transparent 26%),
    linear-gradient(180deg, color-mix(in srgb, var(--panel-strong) 94%, transparent), color-mix(in srgb, var(--panel) 98%, transparent));
  border-top: 1px solid var(--border);
}
.site-footer-backdrop {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.03), transparent);
  pointer-events: none;
}
.footer-wrap-full {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 20px;
  padding-top: 0;
  border-top: 0;
}
.footer-brand-block strong {
  display: block;
  font-size: 1.02rem;
}
.footer-brand-block p {
  margin: 8px 0 0;
  max-width: 520px;
}
.footer-meta-full {
  position: relative;
  z-index: 1;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.footer-whatsapp { white-space: nowrap; }
@media (max-width: 1180px) {
  .hero-copy .hero-rotating-title {
    max-width: 100%;
  }
}
@media (max-width: 920px) {
  .footer-wrap-full {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }
  .hero-rotator-card {
    left: 18px;
    right: 18px;
    bottom: 22px;
    transform: none;
    min-width: 0;
    max-width: none;
  }
  .hero-rotator-dots {
    left: 18px;
    top: 18px;
    bottom: auto;
  }
}
@media (max-width: 640px) {
  .hero-copy .hero-rotating-title {
    font-size: clamp(1.7rem, 8.8vw, 2.55rem);
  }
  .typing-rotator {
    max-width: 100%;
  }
  .always-on-actions .btn {
    min-height: 42px;
    font-size: .82rem;
  }
  .footer-links { flex-wrap: wrap; }
}
