/* =====================================================================
   Bazaar Slovenia ??? site.css
   Final unified design layer. Loaded LAST so it wins the cascade.
   No !important wars: relies on specificity from .home-page, .catalog-page, etc.
   ===================================================================== */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap");

/* ----- 1. Design tokens ----- */
:root {
  --c-bg: #f6f7fb;
  --c-surface: #ffffff;
  --c-surface-2: #f1f3f9;
  --c-surface-3: #e9ecf3;
  --c-text: #0f172a;
  --c-text-soft: #475467;
  --c-muted: #6b7280;
  --c-border: #e4e7ee;
  --c-border-strong: #d4d8e1;
  --c-primary: #ff4f33;
  --c-primary-strong: #e23f24;
  --c-primary-soft: #ffe9e3;
  --c-accent: #1f2a44;
  --c-success: #16a34a;
  --c-warning: #f59e0b;

  --radius-xs: 6px;
  --radius-sm: 10px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-pill: 999px;

  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
  --shadow-md: 0 6px 20px rgba(15, 23, 42, 0.06);
  --shadow-lg: 0 18px 40px rgba(15, 23, 42, 0.08);
  --shadow-primary: 0 12px 28px rgba(255, 79, 51, 0.22);

  --ring: 0 0 0 4px rgba(255, 79, 51, 0.18);

  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4rem;
}

:root[data-theme="dark"] {
  --c-bg: #0e1422;
  --c-surface: #182032;
  --c-surface-2: #1f2942;
  --c-surface-3: #29345a;
  --c-text: #eef2fb;
  --c-text-soft: #c2cadd;
  --c-muted: #8c97b1;
  --c-border: #2b3656;
  --c-border-strong: #3a466a;
  --c-primary: #ff6d50;
  --c-primary-strong: #ff8870;
  --c-primary-soft: rgba(255, 109, 80, 0.14);
  --c-accent: #f3f5fb;

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 10px 28px rgba(0, 0, 0, 0.45);
  --shadow-lg: 0 24px 54px rgba(0, 0, 0, 0.55);
  --shadow-primary: 0 14px 32px rgba(255, 109, 80, 0.32);
  --ring: 0 0 0 4px rgba(255, 109, 80, 0.28);
}

/* ----- 2. Base ----- */
html {
  scroll-behavior: smooth;
  overflow-x: clip;
}
body {
  overflow-x: clip;
}

body.home-page,
body.catalog-page,
body.about-page,
body.contact-page,
body.error-page,
body.sitemap-page {
  margin: 0;
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  background: var(--c-bg) !important;
  background-image: none !important;
  color: var(--c-text) !important;
  font-feature-settings: "ss01", "cv11";
  letter-spacing: -0.005em;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.home-page h1,
body.home-page h2,
body.home-page h3,
body.catalog-page h1,
body.catalog-page h2,
body.catalog-page h3,
body.about-page h1,
body.about-page h2,
body.about-page h3,
body.contact-page h1,
body.contact-page h2,
body.contact-page h3 {
  color: var(--c-text);
  letter-spacing: -0.022em;
  font-weight: 700;
  margin: 0 0 var(--space-3);
}

body.home-page p,
body.catalog-page p,
body.about-page p,
body.contact-page p {
  color: var(--c-text-soft);
  margin: 0 0 var(--space-3);
}

body.home-page .container,
body.catalog-page .container,
body.about-page .container,
body.contact-page .container {
  width: min(1200px, 92vw);
  margin-inline: auto;
}

/* ----- 3. Header ----- */
body.home-page .site-header.site-header-main,
body.catalog-page .site-header.site-header-main,
body.about-page .site-header.site-header-main,
body.contact-page .site-header.site-header-main {
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-border);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  padding: 0;
}

body.home-page .nav-wrap,
body.catalog-page .nav-wrap,
body.about-page .nav-wrap,
body.contact-page .nav-wrap {
  display: grid;
  grid-template-columns: auto minmax(160px, 1fr) auto;
  align-items: center;
  gap: 1rem 1.5rem;
  min-height: 72px;
}

body.home-page .nav-cluster,
body.catalog-page .nav-cluster,
body.about-page .nav-cluster,
body.contact-page .nav-cluster {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.35rem 0.75rem;
  flex-wrap: wrap;
}

body.home-page .brand-title,
body.catalog-page .brand-title,
body.about-page .brand-title,
body.contact-page .brand-title {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: var(--c-text);
  font-weight: 700;
  letter-spacing: -0.01em;
}

body.home-page .brand-text,
body.catalog-page .brand-text,
body.about-page .brand-text,
body.contact-page .brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
  gap: 0.06rem;
}

body.home-page .brand-text-main,
body.catalog-page .brand-text-main,
body.about-page .brand-text-main,
body.contact-page .brand-text-main {
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--c-text);
}

body.home-page .brand-text-sub,
body.catalog-page .brand-text-sub,
body.about-page .brand-text-sub,
body.contact-page .brand-text-sub {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-text-soft);
}

body.home-page .brand-logo,
body.catalog-page .brand-logo,
body.about-page .brand-logo,
body.contact-page .brand-logo {
  width: 40px;
  height: 40px;
  object-fit: contain;
  flex-shrink: 0;
}

body.home-page .site-nav,
body.catalog-page .site-nav,
body.about-page .site-nav,
body.contact-page .site-nav {
  display: flex;
  align-items: center;
  gap: 0.05rem;
  justify-content: flex-end;
  padding: 0;
  background: transparent;
  border: 0;
  flex-wrap: wrap;
}

body.home-page .site-nav a,
body.catalog-page .site-nav a,
body.about-page .site-nav a,
body.contact-page .site-nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: var(--c-text);
  font-weight: 500;
  font-size: 0.9rem;
  padding: 0.45rem 0.65rem;
  border-radius: var(--radius-sm);
  transition: color 0.18s ease, background 0.18s ease;
}

body.home-page .site-nav a:hover,
body.catalog-page .site-nav a:hover,
body.about-page .site-nav a:hover,
body.contact-page .site-nav a:hover {
  color: var(--c-primary);
  background: transparent;
}

body.home-page .site-nav a.active,
body.catalog-page .site-nav a.active,
body.about-page .site-nav a.active,
body.contact-page .site-nav a.active {
  color: var(--c-primary);
  background: transparent;
  font-weight: 600;
}

body.home-page .site-nav a.active::after,
body.catalog-page .site-nav a.active::after,
body.about-page .site-nav a.active::after,
body.contact-page .site-nav a.active::after {
  content: "";
  position: absolute;
  bottom: 2px;
  left: 0.65rem;
  right: 0.65rem;
  height: 2px;
  border-radius: var(--radius-pill);
  background: var(--c-primary);
  transform: none;
}

/* Header search ??? pill + red submit (reference layout) */
body.home-page .header-search.nav-search,
body.catalog-page .header-search.nav-search,
body.about-page .header-search.nav-search,
body.contact-page .header-search.nav-search {
  display: flex;
  align-items: stretch;
  width: 100%;
  max-width: min(440px, 100%);
  margin: 0 auto;
  justify-self: center;
  background: #eef0f4;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
  padding: 3px 3px 3px 0.85rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
  transition: box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

:root[data-theme="dark"] body.home-page .header-search.nav-search,
:root[data-theme="dark"] body.catalog-page .header-search.nav-search,
:root[data-theme="dark"] body.about-page .header-search.nav-search,
:root[data-theme="dark"] body.contact-page .header-search.nav-search {
  background: var(--c-surface-2);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

body.home-page .header-search.nav-search:focus-within,
body.catalog-page .header-search.nav-search:focus-within,
body.about-page .header-search.nav-search:focus-within,
body.contact-page .header-search.nav-search:focus-within {
  border-color: color-mix(in srgb, var(--c-primary) 45%, var(--c-border));
  box-shadow: var(--ring), inset 0 1px 0 rgba(255, 255, 255, 0.65);
  background: var(--c-surface);
}

body.home-page .header-search-toggle,
body.catalog-page .header-search-toggle,
body.about-page .header-search-toggle,
body.contact-page .header-search-toggle {
  display: none;
}

body.home-page .header-search-form,
body.catalog-page .header-search-form,
body.about-page .header-search-form,
body.contact-page .header-search-form {
  display: flex;
  align-items: stretch;
  flex: 1;
  min-width: 0;
  margin: 0;
  gap: 0.35rem;
}

body.home-page .header-search-input,
body.catalog-page .header-search-input,
body.about-page .header-search-input,
body.contact-page .header-search-input {
  flex: 1;
  min-width: 0;
  border: 0;
  background: transparent;
  outline: none;
  color: var(--c-text);
  font: inherit;
  font-size: 0.92rem;
  padding: 0.55rem 0.35rem 0.55rem 0;
  width: auto;
  opacity: 1;
}

body.home-page .header-search-input::placeholder,
body.catalog-page .header-search-input::placeholder,
body.about-page .header-search-input::placeholder,
body.contact-page .header-search-input::placeholder {
  color: var(--c-muted);
}

body.home-page .header-search-submit,
body.catalog-page .header-search-submit,
body.about-page .header-search-submit,
body.contact-page .header-search-submit {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: var(--radius-pill);
  background: var(--c-primary)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E")
    center / 20px no-repeat;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(255, 79, 51, 0.35);
  transition: background 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

body.home-page .header-search-submit:hover,
body.catalog-page .header-search-submit:hover,
body.about-page .header-search-submit:hover,
body.contact-page .header-search-submit:hover {
  background: var(--c-primary-strong);
  transform: scale(1.03);
  box-shadow: 0 6px 18px rgba(255, 79, 51, 0.42);
}

body.home-page .header-search-submit:active,
body.catalog-page .header-search-submit:active,
body.about-page .header-search-submit:active,
body.contact-page .header-search-submit:active {
  transform: scale(0.98);
}

/* Legacy expand-to-open: keep input visible when toggle exists */
body.home-page .header-search.is-open .header-search-input,
body.catalog-page .header-search.is-open .header-search-input,
body.about-page .header-search.is-open .header-search-input,
body.contact-page .header-search.is-open .header-search-input {
  width: auto;
  opacity: 1;
}

body.home-page .actions,
body.catalog-page .actions,
body.about-page .actions,
body.contact-page .actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex-wrap: wrap;
}

/* Theme toggle */
body.home-page #themeToggleBtn.theme-toggle,
body.catalog-page #themeToggleBtn.theme-toggle,
body.about-page #themeToggleBtn.theme-toggle,
body.contact-page #themeToggleBtn.theme-toggle {
  width: 38px;
  height: 38px;
  min-width: 0;
  padding: 0;
  border-radius: var(--radius-pill);
  border: 1px solid var(--c-border);
  background: var(--c-surface-2);
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

body.home-page #themeToggleBtn.theme-toggle:hover,
body.catalog-page #themeToggleBtn.theme-toggle:hover,
body.about-page #themeToggleBtn.theme-toggle:hover,
body.contact-page #themeToggleBtn.theme-toggle:hover {
  background: var(--c-surface-3);
  border-color: var(--c-border-strong);
}

body.home-page .theme-icon,
body.catalog-page .theme-icon,
body.about-page .theme-icon,
body.contact-page .theme-icon {
  width: 18px;
  height: 18px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
}

body.home-page .theme-icon.moon,
body.catalog-page .theme-icon.moon,
body.about-page .theme-icon.moon,
body.contact-page .theme-icon.moon {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23475467' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z'/%3E%3C/svg%3E");
}

body.home-page .theme-icon.sun,
body.catalog-page .theme-icon.sun,
body.about-page .theme-icon.sun,
body.contact-page .theme-icon.sun {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffd166' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3Cpath d='M12 2v2M12 20v2M4.93 4.93l1.41 1.41M17.66 17.66l1.41 1.41M2 12h2M20 12h2M4.93 19.07l1.41-1.41M17.66 6.34l1.41-1.41'/%3E%3C/svg%3E");
}

/* ----- 4. Buttons ----- */
body.home-page .btn-primary,
body.catalog-page .btn-primary,
body.about-page .btn-primary,
body.contact-page .btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--c-primary);
  color: #fff;
  border: 0;
  border-radius: var(--radius-sm);
  font: inherit;
  font-weight: 600;
  font-size: 0.92rem;
  padding: 0.65rem 1.1rem;
  min-height: 42px;
  cursor: pointer;
  text-decoration: none;
  box-shadow: var(--shadow-primary);
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

body.home-page .btn-primary:hover,
body.catalog-page .btn-primary:hover,
body.about-page .btn-primary:hover,
body.contact-page .btn-primary:hover {
  background: var(--c-primary-strong);
  transform: translateY(-1px);
  box-shadow: 0 16px 32px rgba(255, 79, 51, 0.28);
}

body.home-page .btn-primary:active,
body.catalog-page .btn-primary:active,
body.about-page .btn-primary:active,
body.contact-page .btn-primary:active {
  transform: translateY(0);
}

body.home-page .btn-secondary,
body.catalog-page .btn-secondary,
body.about-page .btn-secondary,
body.contact-page .btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: var(--c-surface);
  color: var(--c-text);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  font: inherit;
  font-weight: 600;
  font-size: 0.9rem;
  padding: 0.6rem 1rem;
  min-height: 40px;
  cursor: pointer;
  text-decoration: none;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

body.home-page .btn-secondary:hover,
body.catalog-page .btn-secondary:hover,
body.about-page .btn-secondary:hover,
body.contact-page .btn-secondary:hover {
  border-color: var(--c-border-strong);
  background: var(--c-surface-2);
  transform: translateY(-1px);
}

body.home-page .link-btn,
body.catalog-page .link-btn,
body.about-page .link-btn,
body.contact-page .link-btn {
  text-decoration: none;
}

/* ----- 5. Leanpay strip ----- */
body.home-page .leanpay-strip,
body.catalog-page .leanpay-strip,
body.about-page .leanpay-strip,
body.contact-page .leanpay-strip,
body.product-page .leanpay-strip {
  background: linear-gradient(90deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  color: #fff;
  padding: 0.55rem 0;
  border: 0;
}

body.home-page .leanpay-strip .container,
body.catalog-page .leanpay-strip .container,
body.about-page .leanpay-strip .container,
body.contact-page .leanpay-strip .container,
body.product-page .leanpay-strip .container,
body.product-page .leanpay-strip .leanpay-track {
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.4rem 1.4rem;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 600;
}

body.home-page .leanpay-strip strong,
body.catalog-page .leanpay-strip strong,
body.about-page .leanpay-strip strong,
body.contact-page .leanpay-strip strong,
body.product-page .leanpay-strip strong {
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}

body.home-page .leanpay-strip span,
body.catalog-page .leanpay-strip span,
body.about-page .leanpay-strip span,
body.contact-page .leanpay-strip span,
body.product-page .leanpay-strip span {
  position: relative;
  opacity: 0.92;
  color: #fff;
}

body.home-page .leanpay-strip span::before,
body.catalog-page .leanpay-strip span::before,
body.about-page .leanpay-strip span::before,
body.contact-page .leanpay-strip span::before {
  content: "";
  position: absolute;
  left: -0.85rem;
  top: 50%;
  width: 4px;
  height: 4px;
  background: rgba(255, 255, 255, 0.55);
  border-radius: var(--radius-pill);
  transform: translateY(-50%);
}

/* ----- 6. Section spacing ----- */
body.home-page main.container,
body.catalog-page main.container,
body.about-page main.container,
body.contact-page main.container {
  padding-block: var(--space-6);
  display: grid;
  gap: var(--space-5);
}

/* ----- 7. Home: hero ----- */
body.home-page .home-hero {
  position: relative;
  background:
    radial-gradient(900px circle at 90% 0%, color-mix(in srgb, var(--c-primary) 14%, transparent), transparent 55%),
    radial-gradient(700px circle at 0% 100%, color-mix(in srgb, var(--c-primary) 7%, transparent), transparent 50%),
    var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.2rem, 4vw, 2.4rem);
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: var(--space-5);
  align-items: center;
  box-shadow: var(--shadow-md);
  overflow: hidden;
}

body.home-page .home-kicker {
  display: inline-block;
  margin: 0 0 var(--space-3);
  padding: 0.3rem 0.65rem;
  background: var(--c-primary-soft);
  color: var(--c-primary-strong);
  border: 1px solid color-mix(in srgb, var(--c-primary) 30%, transparent);
  border-radius: var(--radius-pill);
  font-size: 0.74rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

body.home-page .home-hero h1 {
  font-size: clamp(2.1rem, 4.6vw, 3.4rem);
  font-weight: 800;
  line-height: 1.04;
  margin-bottom: var(--space-3);
  background: linear-gradient(180deg, var(--c-text) 0%, color-mix(in srgb, var(--c-text) 70%, var(--c-primary)) 110%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

body.home-page .home-hero-copy > p {
  font-size: 1.05rem;
  max-width: 56ch;
  color: var(--c-text-soft);
  margin-bottom: var(--space-4);
}

body.home-page .home-hero-copy .hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 var(--space-4);
}

body.home-page .hero-tags span {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.32rem 0.7rem;
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--c-text-soft);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
}

body.home-page .hero-tags span::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--c-primary);
}

body.home-page .home-hero-copy .actions {
  margin-top: var(--space-2);
}

body.home-page .home-hero-side {
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(1.25rem, 3vw, 2rem);
  min-height: 260px;
  position: relative;
  overflow: hidden;
}

@media (max-width: 880px) {
  body.home-page .home-hero {
    grid-template-columns: 1fr;
  }

  body.home-page .home-hero-side {
    min-height: 200px;
  }
}

/* ----- 8. Home: sections ----- */
body.home-page .hp-section {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.2rem, 3vw, 2rem);
  box-shadow: var(--shadow-sm);
}

body.home-page .hp-section .hp-eyebrow,
body.home-page .hp-section .hp-head .hp-eyebrow {
  margin: 0 0 var(--space-2);
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-primary);
}

body.home-page .hp-section h2 {
  font-size: clamp(1.5rem, 2.6vw, 2.05rem);
  margin: 0 0 var(--space-2);
}

body.home-page .hp-section .hp-head > p,
body.home-page .hp-section .home-band-head > p,
body.home-page .hp-showcase-copy > p {
  margin: 0 0 var(--space-4);
  color: var(--c-text-soft);
  max-width: 60ch;
}

/* Featured cats */
body.home-page .featured-cats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}

body.home-page .cat-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

body.home-page .cat-card::before {
  content: "";
  display: block;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-sm);
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  margin-bottom: var(--space-2);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 9l9-6 9 6'/%3E%3Cpath d='M5 9v11h14V9'/%3E%3Cpath d='M9 21v-7h6v7'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}

body.home-page .cat-card h3 {
  margin: 0;
  font-size: 1.05rem;
}

body.home-page .cat-card p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--c-text-soft);
}

body.home-page .cat-card a {
  margin-top: auto;
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--c-primary);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding-top: var(--space-2);
}

body.home-page .cat-card a::after {
  content: "\2192";
  transition: transform 0.18s ease;
}

body.home-page .cat-card:hover {
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border));
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

body.home-page .cat-card:hover a::after {
  transform: translateX(3px);
}

@media (max-width: 980px) {
  body.home-page .featured-cats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 540px) {
  body.home-page .featured-cats-grid {
    grid-template-columns: 1fr;
  }
}

/* Showcase */
body.home-page .hp-showcase {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: var(--space-5);
  align-items: start;
}

body.home-page .hp-steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
}

body.home-page .hp-steps li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.8rem;
  padding: var(--space-3) var(--space-4);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  align-items: center;
}

body.home-page .hp-steps li strong {
  font-size: 0.95rem;
  color: var(--c-text);
}

body.home-page .hp-steps li span {
  display: block;
  grid-column: 2;
  font-size: 0.88rem;
  color: var(--c-text-soft);
}

@media (max-width: 880px) {
  body.home-page .hp-showcase {
    grid-template-columns: 1fr;
  }
}

/* Highlight */
body.home-page .hp-highlight-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}

body.home-page .hp-highlight-grid article {
  padding: var(--space-4);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
}

body.home-page .hp-stat {
  margin: 0 0 var(--space-2);
  font-size: 1rem;
  font-weight: 700;
  color: var(--c-primary);
  letter-spacing: 0.06em;
}

body.home-page .hp-highlight-grid h3 {
  margin: 0 0 var(--space-2);
  font-size: 1rem;
}

body.home-page .hp-highlight-grid p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--c-text-soft);
}

@media (max-width: 880px) {
  body.home-page .hp-highlight-grid {
    grid-template-columns: 1fr;
  }
}

/* Strip */
body.home-page .home-strip {
  background:
    linear-gradient(120deg, color-mix(in srgb, var(--c-primary) 7%, var(--c-surface)) 0%, var(--c-surface) 100%);
}

body.home-page .home-strip-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-4);
  align-items: center;
}

body.home-page .home-strip-grid h3 {
  margin: 0 0 var(--space-2);
  font-size: 1.25rem;
}

body.home-page .home-strip-grid p {
  margin: 0;
  color: var(--c-text-soft);
}

@media (max-width: 720px) {
  body.home-page .home-strip-grid {
    grid-template-columns: 1fr;
  }
}

/* FAQ */
body.home-page .hp-faq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

body.home-page .hp-faq-grid details {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

body.home-page .hp-faq-grid details[open] {
  border-color: color-mix(in srgb, var(--c-primary) 30%, var(--c-border));
  box-shadow: var(--shadow-sm);
}

body.home-page .hp-faq-grid summary {
  list-style: none;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--c-text);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}

body.home-page .hp-faq-grid summary::-webkit-details-marker {
  display: none;
}

body.home-page .hp-faq-grid summary::after {
  content: "+";
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--c-primary);
  transition: transform 0.18s ease;
  flex-shrink: 0;
}

body.home-page .hp-faq-grid details[open] summary::after {
  transform: rotate(45deg);
}

body.home-page .hp-faq-grid details p {
  margin: var(--space-3) 0 0;
  color: var(--c-text-soft);
  font-size: 0.92rem;
}

@media (max-width: 720px) {
  body.home-page .hp-faq-grid {
    grid-template-columns: 1fr;
  }
}

/* ----- 9. Catalog page ----- */
body.catalog-page .catalog-hero {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  display: block;
}

body.catalog-page .catalog-breadcrumb {
  margin: 0 0 var(--space-2);
  font-size: 0.82rem;
  color: var(--c-muted);
}

body.catalog-page .catalog-title {
  margin: 0;
  font-size: clamp(1.7rem, 3.6vw, 2.5rem);
  font-weight: 800;
  line-height: 1.1;
}

body.catalog-page .toolbar-wrap {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
}

body.catalog-page .toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1.3fr) minmax(160px, 1fr) minmax(160px, 1fr);
  gap: var(--space-3);
  background: transparent;
  border: 0;
  padding: 0;
}

body.catalog-page .toolbar input,
body.catalog-page .toolbar select {
  width: 100%;
  min-height: 44px;
  padding: 0.55rem 0.9rem;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  color: var(--c-text);
  font: inherit;
  font-size: 0.92rem;
  outline: 0;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

body.catalog-page .toolbar input:focus,
body.catalog-page .toolbar select:focus {
  border-color: var(--c-primary);
  background: var(--c-surface);
  box-shadow: var(--ring);
}

body.catalog-page .toolbar input[type="search"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 0.85rem center;
  padding-left: 2.4rem;
}

body.catalog-page .result-count {
  margin: 0;
  font-size: 0.88rem;
  color: var(--c-muted);
}

body.catalog-page .product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-4);
}

body.catalog-page .product-grid.is-switching {
  opacity: 0.7;
  transition: opacity 0.18s ease;
}

body.catalog-page .product-grid .card {
  display: grid;
  grid-template-rows: auto auto auto auto auto auto;
  gap: var(--space-2);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  box-shadow: var(--shadow-sm);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

body.catalog-page .product-grid .card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in srgb, var(--c-primary) 25%, var(--c-border));
}

body.catalog-page .card-image {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-sm);
  background: var(--c-surface-2);
  object-fit: cover;
  display: block;
}

body.catalog-page .card-image.placeholder {
  display: grid;
  place-items: center;
  font-size: 0.82rem;
  color: var(--c-muted);
  background: linear-gradient(135deg, var(--c-surface-2) 25%, transparent 25%, transparent 50%, var(--c-surface-2) 50%, var(--c-surface-2) 75%, transparent 75%, transparent);
  background-size: 16px 16px;
  border: 1px dashed var(--c-border-strong);
}

body.catalog-page .card .category {
  display: inline-block;
  align-self: start;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-primary);
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  padding: 0.2rem 0.55rem;
  border-radius: var(--radius-pill);
  width: fit-content;
}

body.catalog-page .card h3 {
  margin: 0;
  font-size: 1rem;
  line-height: 1.3;
  color: var(--c-text);
}

body.catalog-page .card .price {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--c-text);
}

body.catalog-page .card-description {
  margin: 0;
  font-size: 0.86rem;
  color: var(--c-text-soft);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

body.catalog-page .card button {
  margin-top: var(--space-2);
  padding: 0.55rem 0.9rem;
  background: var(--c-surface-2);
  color: var(--c-text);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  min-height: 38px;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

body.catalog-page .card button:hover {
  background: var(--c-primary);
  color: #fff;
  border-color: var(--c-primary);
}

body.catalog-page .empty-state {
  grid-column: 1 / -1;
  padding: var(--space-7) var(--space-4);
  text-align: center;
  color: var(--c-muted);
  background: var(--c-surface);
  border: 1px dashed var(--c-border-strong);
  border-radius: var(--radius-md);
}

body.catalog-page .catalog-footer:has(> #loadMoreBtn[hidden]),
body.catalog-page .catalog-footer:not(:has(> #loadMoreBtn:not([hidden]))) {
  display: none !important;
}
body.catalog-page .catalog-footer {
  display: flex;
  justify-content: center;
  padding: var(--space-3) 0 0;
}

body.catalog-page #loadMoreBtn {
  min-width: 220px;
}

/* Skeleton cards */
body.catalog-page .skeleton-card {
  pointer-events: none;
}

body.catalog-page .skeleton {
  background: linear-gradient(90deg, var(--c-surface-2) 0%, var(--c-surface-3) 50%, var(--c-surface-2) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.4s linear infinite;
  border-radius: var(--radius-sm);
}

body.catalog-page .skeleton-tag {
  width: 64px;
  height: 18px;
}

body.catalog-page .skeleton-title {
  height: 18px;
  width: 80%;
}

body.catalog-page .skeleton-price {
  height: 22px;
  width: 40%;
}

body.catalog-page .skeleton-line {
  height: 12px;
}

body.catalog-page .skeleton-line.short {
  width: 60%;
}

body.catalog-page .skeleton-button {
  height: 38px;
  margin-top: var(--space-2);
}

@keyframes shimmer {
  from { background-position: -200% 0; }
  to { background-position: 200% 0; }
}

@media (max-width: 720px) {
  body.catalog-page .toolbar {
    grid-template-columns: 1fr;
  }
}

/* Product dialog */
body.catalog-page .product-dialog {
  border: 1px solid var(--c-border);
  background: var(--c-surface);
  color: var(--c-text);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  width: min(620px, 92vw);
  box-shadow: var(--shadow-lg);
}

body.catalog-page .product-dialog::backdrop {
  background: rgba(15, 23, 42, 0.5);
  backdrop-filter: blur(6px);
}

body.catalog-page .product-dialog .dialog-image {
  width: 100%;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
}

body.catalog-page .product-dialog #closeDialogBtn {
  margin-top: var(--space-4);
  width: 100%;
}

/* ----- 10. About page ----- */
body.about-page .about-hero {
  background:
    radial-gradient(800px circle at 100% 0%, color-mix(in srgb, var(--c-primary) 12%, transparent), transparent 55%),
    var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 4vw, 2.4rem);
  box-shadow: var(--shadow-md);
}

body.about-page .about-kicker {
  display: inline-block;
  margin: 0 0 var(--space-3);
  padding: 0.3rem 0.65rem;
  background: var(--c-primary-soft);
  color: var(--c-primary-strong);
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  border-radius: var(--radius-pill);
  font-size: 0.74rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

body.about-page .about-hero h1 {
  font-size: clamp(1.85rem, 4vw, 2.7rem);
  font-weight: 800;
  margin-bottom: var(--space-3);
}

body.about-page .about-hero-copy > p {
  font-size: 1.03rem;
  color: var(--c-text-soft);
  max-width: 64ch;
  margin: 0 0 var(--space-4);
}

body.about-page .about-hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

body.about-page .about-hero-tags span {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.32rem 0.7rem;
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--c-text-soft);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
}

body.about-page .about-hero-tags span::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--c-primary);
}

body.about-page .about-values,
body.about-page .about-cta {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.2rem, 3vw, 1.8rem);
  box-shadow: var(--shadow-sm);
}

body.about-page .about-section-head .about-kicker {
  margin-bottom: var(--space-2);
}

body.about-page .about-section-head h2 {
  margin: 0 0 var(--space-4);
  font-size: clamp(1.4rem, 2.4vw, 1.85rem);
}

body.about-page .about-values-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}

body.about-page .about-values-grid article {
  padding: var(--space-4);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
}

body.about-page .about-values-grid h3 {
  margin: 0 0 var(--space-2);
  font-size: 1rem;
}

body.about-page .about-values-grid p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--c-text-soft);
}

body.about-page .about-cta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-4);
  align-items: center;
  background: linear-gradient(120deg, color-mix(in srgb, var(--c-primary) 6%, var(--c-surface)) 0%, var(--c-surface) 100%);
}

body.about-page .about-cta h2 {
  margin: 0 0 var(--space-2);
  font-size: clamp(1.2rem, 2.2vw, 1.6rem);
}

body.about-page .about-cta p {
  margin: 0;
  color: var(--c-text-soft);
}

@media (max-width: 980px) {
  body.about-page .about-values-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  body.about-page .about-cta {
    grid-template-columns: 1fr;
  }

  body.about-page .about-values-grid {
    grid-template-columns: 1fr;
  }
}

/* ----- 11. Contact page ----- */
body.contact-page .contact-hero {
  background:
    radial-gradient(800px circle at 0% 0%, color-mix(in srgb, var(--c-primary) 10%, transparent), transparent 55%),
    var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 4vw, 2.4rem);
  box-shadow: var(--shadow-md);
}

body.contact-page .contact-kicker {
  display: inline-block;
  margin: 0 0 var(--space-3);
  padding: 0.3rem 0.65rem;
  background: var(--c-primary-soft);
  color: var(--c-primary-strong);
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  border-radius: var(--radius-pill);
  font-size: 0.74rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

body.contact-page .contact-hero h1 {
  font-size: clamp(1.85rem, 4vw, 2.6rem);
  font-weight: 800;
  margin-bottom: var(--space-3);
}

body.contact-page .contact-hero-copy > p {
  font-size: 1.03rem;
  color: var(--c-text-soft);
  max-width: 64ch;
  margin: 0 0 var(--space-4);
}

body.contact-page .contact-hero-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

body.contact-page .contact-hero-tags span {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.32rem 0.7rem;
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--c-text-soft);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
}

body.contact-page .contact-hero-tags span::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--c-primary);
}

body.contact-page .contact-content-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: var(--space-4);
  background: transparent;
  border: 0;
  padding: 0;
}

body.contact-page .contact-info-card,
body.contact-page .contact-form-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.2rem, 3vw, 1.7rem);
  box-shadow: var(--shadow-sm);
}

body.contact-page .contact-info-card h2,
body.contact-page .contact-form-card h2 {
  margin: 0 0 var(--space-4);
  font-size: clamp(1.2rem, 2vw, 1.55rem);
}

body.contact-page .contact-info-list {
  display: grid;
  gap: var(--space-2);
}

body.contact-page .contact-info-list p {
  margin: 0;
  padding: var(--space-3);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  color: var(--c-text);
}

body.contact-page .contact-info-list p strong {
  color: var(--c-muted);
  font-weight: 600;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  display: block;
  margin-bottom: 0.18rem;
}

body.contact-page .contact-form {
  display: grid;
  gap: var(--space-3);
}

body.contact-page .contact-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

body.contact-page .contact-form label {
  display: block;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--c-text-soft);
  margin-bottom: 0.3rem;
}

body.contact-page .contact-form input,
body.contact-page .contact-form textarea {
  width: 100%;
  min-height: 44px;
  padding: 0.6rem 0.9rem;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  color: var(--c-text);
  font: inherit;
  font-size: 0.92rem;
  outline: 0;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

body.contact-page .contact-form textarea {
  min-height: 140px;
  resize: vertical;
  font-family: inherit;
}

body.contact-page .contact-form input:focus,
body.contact-page .contact-form textarea:focus {
  border-color: var(--c-primary);
  background: var(--c-surface);
  box-shadow: var(--ring);
}

body.contact-page #contactSubmitBtn {
  margin-top: var(--space-2);
  min-width: 200px;
  align-self: start;
  justify-self: start;
}

body.contact-page .contact-form-status {
  margin: 0;
  min-height: 1.2em;
  font-size: 0.88rem;
  color: var(--c-text-soft);
}

body.contact-page .contact-form-status.success {
  color: var(--c-success);
}

body.contact-page .contact-form-status.error {
  color: var(--c-primary-strong);
}

@media (max-width: 880px) {
  body.contact-page .contact-content-grid {
    grid-template-columns: 1fr;
  }

  body.contact-page .contact-form-row {
    grid-template-columns: 1fr;
  }

  body.contact-page #contactSubmitBtn {
    width: 100%;
    justify-self: stretch;
  }
}

/* ----- 12. Toast ----- */
.toast-host {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 1000;
  display: grid;
  gap: 0.5rem;
  pointer-events: none;
}

.toast {
  pointer-events: auto;
  background: var(--c-surface);
  color: var(--c-text);
  border: 1px solid var(--c-border);
  border-left: 4px solid var(--c-primary);
  padding: 0.7rem 0.95rem;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-lg);
  font-size: 0.88rem;
  min-width: 220px;
  max-width: 320px;
  animation: toast-in 0.22s ease;
}

.toast.success { border-left-color: var(--c-success); }
.toast.error { border-left-color: var(--c-primary-strong); }
.toast.info { border-left-color: var(--c-text-soft); }

.toast.hide {
  animation: toast-out 0.22s ease forwards;
}

@keyframes toast-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: none; }
}

@keyframes toast-out {
  from { opacity: 1; transform: none; }
  to { opacity: 0; transform: translateY(8px); }
}

/* ----- 13. Footer (dark ??? reference layout) ----- */
body.home-page .site-footer,
body.catalog-page .site-footer,
body.about-page .site-footer,
body.contact-page .site-footer,
body.error-page .site-footer,
body.sitemap-page .site-footer {
  --fc-bg: #1a1d21;
  --fc-bg-2: #15171a;
  --fc-text: #d8dde4;
  --fc-text-soft: #a4abb6;
  --fc-muted: #7d838d;
  --fc-border: rgba(255, 255, 255, 0.08);
  --fc-link: #d8dde4;
  --fc-link-hover: var(--c-primary);
  position: relative;
  margin-top: var(--space-7);
  background: var(--fc-bg);
  color: var(--fc-text);
  border-top: 0;
  width: 100%;
  padding: 0;
}

:root[data-theme="dark"] body.home-page .site-footer,
:root[data-theme="dark"] body.catalog-page .site-footer,
:root[data-theme="dark"] body.about-page .site-footer,
:root[data-theme="dark"] body.contact-page .site-footer,
:root[data-theme="dark"] body.error-page .site-footer,
:root[data-theme="dark"] body.sitemap-page .site-footer {
  --fc-bg: #0c0d10;
  --fc-bg-2: #08090b;
  --fc-text: #e3e6ec;
  --fc-text-soft: #b0b6c0;
  --fc-muted: #818790;
  --fc-border: rgba(255, 255, 255, 0.06);
  --fc-link: #e3e6ec;
}

/* Footer grid (3 cols: brand+about | nav | contact) */
body.home-page .footer-grid,
body.catalog-page .footer-grid,
body.about-page .footer-grid,
body.contact-page .footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.7fr) minmax(0, 1fr);
  gap: var(--space-6);
  align-items: start;
  padding: var(--space-7) 0 var(--space-6);
}

body.home-page .footer-col,
body.catalog-page .footer-col,
body.about-page .footer-col,
body.contact-page .footer-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* Brand block */
body.home-page .footer-brand,
body.catalog-page .footer-brand,
body.about-page .footer-brand,
body.contact-page .footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: var(--fc-text);
  width: fit-content;
}

body.home-page .footer-brand .brand-text-main,
body.catalog-page .footer-brand .brand-text-main,
body.about-page .footer-brand .brand-text-main,
body.contact-page .footer-brand .brand-text-main {
  font-size: 0.95rem;
  color: var(--fc-text);
  -webkit-text-fill-color: var(--fc-text);
  background: none;
}

body.home-page .footer-brand .brand-text-sub,
body.catalog-page .footer-brand .brand-text-sub,
body.about-page .footer-brand .brand-text-sub,
body.contact-page .footer-brand .brand-text-sub {
  font-size: 0.66rem;
  color: var(--fc-text-soft);
  letter-spacing: 0.16em;
}

body.home-page .footer-brand-logo,
body.catalog-page .footer-brand-logo,
body.about-page .footer-brand-logo,
body.contact-page .footer-brand-logo {
  width: 40px;
  height: 40px;
  filter: drop-shadow(0 6px 16px rgba(255, 79, 51, 0.28));
}

body.home-page .footer-about,
body.catalog-page .footer-about,
body.about-page .footer-about,
body.contact-page .footer-about {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.6;
  color: var(--fc-text-soft);
  max-width: 36ch;
}

/* Nav column */
body.home-page .footer-col-nav,
body.catalog-page .footer-col-nav,
body.about-page .footer-col-nav,
body.contact-page .footer-col-nav {
  gap: 0.6rem;
}

body.home-page .footer-col-nav a,
body.catalog-page .footer-col-nav a,
body.about-page .footer-col-nav a,
body.contact-page .footer-col-nav a {
  position: relative;
  width: fit-content;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--fc-link);
  text-decoration: none;
  padding: 0.05rem 0;
  transition: color 0.18s ease, transform 0.18s ease;
}

body.home-page .footer-col-nav a:hover,
body.catalog-page .footer-col-nav a:hover,
body.about-page .footer-col-nav a:hover,
body.contact-page .footer-col-nav a:hover {
  color: var(--fc-link-hover);
  transform: translateX(2px);
}

body.home-page .footer-col-nav a::before,
body.catalog-page .footer-col-nav a::before,
body.about-page .footer-col-nav a::before,
body.contact-page .footer-col-nav a::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 50%;
  width: 4px;
  height: 4px;
  border-radius: var(--radius-pill);
  background: var(--c-primary);
  opacity: 0;
  transform: translateY(-50%) scale(0.6);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

body.home-page .footer-col-nav a:hover::before,
body.catalog-page .footer-col-nav a:hover::before,
body.about-page .footer-col-nav a:hover::before,
body.contact-page .footer-col-nav a:hover::before {
  opacity: 1;
  transform: translateY(-50%) scale(1);
}

/* Contact column */
body.home-page .footer-col-title,
body.catalog-page .footer-col-title,
body.about-page .footer-col-title,
body.contact-page .footer-col-title {
  margin: 0 0 var(--space-2);
  font-size: 1rem;
  font-weight: 700;
  color: var(--fc-text);
  letter-spacing: -0.005em;
}

body.home-page .footer-contact-list,
body.catalog-page .footer-contact-list,
body.about-page .footer-contact-list,
body.contact-page .footer-contact-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.55rem;
}

body.home-page .footer-contact-list li,
body.catalog-page .footer-contact-list li,
body.about-page .footer-contact-list li,
body.contact-page .footer-contact-list li {
  font-size: 0.88rem;
  color: var(--fc-text-soft);
  line-height: 1.5;
}

body.home-page .footer-contact-label,
body.catalog-page .footer-contact-label,
body.about-page .footer-contact-label,
body.contact-page .footer-contact-label {
  color: var(--fc-text);
  font-weight: 600;
  margin-right: 0.25rem;
}

body.home-page .footer-contact-list a,
body.catalog-page .footer-contact-list a,
body.about-page .footer-contact-list a,
body.contact-page .footer-contact-list a {
  color: var(--fc-text-soft);
  text-decoration: none;
  transition: color 0.18s ease;
}

body.home-page .footer-contact-list a:hover,
body.catalog-page .footer-contact-list a:hover,
body.about-page .footer-contact-list a:hover,
body.contact-page .footer-contact-list a:hover {
  color: var(--c-primary);
}

/* Bottom strip ? full-bleed bar + constrained inner */
body.home-page .footer-bottom,
body.catalog-page .footer-bottom,
body.about-page .footer-bottom,
body.contact-page .footer-bottom,
body.error-page .footer-bottom,
body.sitemap-page .footer-bottom {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--fc-border);
  background: var(--fc-bg-2);
  box-sizing: border-box;
}

body.home-page .footer-bottom-inner,
body.catalog-page .footer-bottom-inner,
body.about-page .footer-bottom-inner,
body.contact-page .footer-bottom-inner,
body.error-page .footer-bottom-inner,
body.sitemap-page .footer-bottom-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  padding: var(--space-4) 0;
  text-align: center;
  font-size: 0.8rem;
  color: var(--fc-muted);
}

body.home-page .footer-copy,
body.catalog-page .footer-copy,
body.about-page .footer-copy,
body.contact-page .footer-copy,
body.error-page .footer-copy,
body.sitemap-page .footer-copy {
  color: var(--fc-text-soft);
  font-size: 0.84rem;
  margin: 0;
  text-align: center;
}

body.home-page .footer-credit,
body.catalog-page .footer-credit,
body.about-page .footer-credit,
body.contact-page .footer-credit,
body.error-page .footer-credit,
body.sitemap-page .footer-credit {
  color: var(--fc-muted);
  font-size: 0.8rem;
}

body.home-page .footer-credit-link,
body.catalog-page .footer-credit-link,
body.about-page .footer-credit-link,
body.contact-page .footer-credit-link,
body.error-page .footer-credit-link,
body.sitemap-page .footer-credit-link {
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 0.8rem;
  color: var(--c-primary);
  cursor: pointer;
  padding: 0;
  font-weight: 700;
  text-decoration: none;
  transition: color 0.18s ease;
}

body.home-page .footer-credit-link:hover,
body.catalog-page .footer-credit-link:hover,
body.about-page .footer-credit-link:hover,
body.contact-page .footer-credit-link:hover,
body.error-page .footer-credit-link:hover,
body.sitemap-page .footer-credit-link:hover {
  color: var(--c-primary-strong);
  text-decoration: underline;
}

/* Back-to-top button */
body.home-page .back-to-top,
body.catalog-page .back-to-top,
body.about-page .back-to-top,
body.contact-page .back-to-top {
  position: fixed;
  right: 22px;
  bottom: 22px;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: var(--c-primary);
  color: #fff;
  cursor: pointer;
  display: grid;
  place-items: center;
  box-shadow: 0 12px 28px rgba(255, 79, 51, 0.42);
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: background 0.18s ease, transform 0.22s ease, opacity 0.22s ease, box-shadow 0.18s ease;
  z-index: 60;
}

body.home-page .back-to-top.is-visible,
body.catalog-page .back-to-top.is-visible,
body.about-page .back-to-top.is-visible,
body.contact-page .back-to-top.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

body.home-page .back-to-top:hover,
body.catalog-page .back-to-top:hover,
body.about-page .back-to-top:hover,
body.contact-page .back-to-top:hover {
  background: var(--c-primary-strong);
  transform: translateY(-3px);
  box-shadow: 0 16px 32px rgba(255, 79, 51, 0.5);
}

body.home-page .back-to-top span,
body.catalog-page .back-to-top span,
body.about-page .back-to-top span,
body.contact-page .back-to-top span {
  width: 18px;
  height: 18px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='18 15 12 9 6 15'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px 18px;
}

@media (max-width: 880px) {
  body.home-page .footer-grid,
  body.catalog-page .footer-grid,
  body.about-page .footer-grid,
  body.contact-page .footer-grid {
    grid-template-columns: 1fr 1fr;
  }

  body.home-page .footer-col-brand,
  body.catalog-page .footer-col-brand,
  body.about-page .footer-col-brand,
  body.contact-page .footer-col-brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 600px) {
  body.home-page .footer-grid,
  body.catalog-page .footer-grid,
  body.about-page .footer-grid,
  body.contact-page .footer-grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

  body.home-page .back-to-top,
  body.catalog-page .back-to-top,
  body.about-page .back-to-top,
  body.contact-page .back-to-top {
    right: 16px;
    bottom: 16px;
    width: 44px;
    height: 44px;
  }
}

/* ----- 14. Header mobile ----- */
@media (max-width: 980px) {
  body.home-page .nav-wrap,
  body.catalog-page .nav-wrap,
  body.about-page .nav-wrap,
  body.contact-page .nav-wrap {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    text-align: center;
    row-gap: 0.75rem;
    padding: 0.65rem 0 0.85rem;
  }

  body.home-page .brand-title,
  body.catalog-page .brand-title,
  body.about-page .brand-title,
  body.contact-page .brand-title {
    justify-self: center;
  }

  body.home-page .header-search.nav-search,
  body.catalog-page .header-search.nav-search,
  body.about-page .header-search.nav-search,
  body.contact-page .header-search.nav-search {
    justify-self: stretch;
    max-width: none;
    width: 100%;
  }

  body.home-page .nav-cluster,
  body.catalog-page .nav-cluster,
  body.about-page .nav-cluster,
  body.contact-page .nav-cluster {
    width: 100%;
    justify-content: center;
  }

  body.home-page .site-nav,
  body.catalog-page .site-nav,
  body.about-page .site-nav,
  body.contact-page .site-nav {
    justify-content: center;
  }

  body.home-page .actions,
  body.catalog-page .actions,
  body.about-page .actions,
  body.contact-page .actions {
    justify-content: center;
  }

  body.home-page .footer-nav-row,
  body.catalog-page .footer-nav-row,
  body.about-page .footer-nav-row,
  body.contact-page .footer-nav-row {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  body.home-page .footer-nav,
  body.catalog-page .footer-nav,
  body.about-page .footer-nav,
  body.contact-page .footer-nav {
    justify-content: center;
  }
}

/* ----- 15. Helpers ----- */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* ----- 16. Selection ----- */
::selection {
  background: var(--c-primary);
  color: #fff;
}

/* ----- 17. Focus visible globally ----- */
:where(a, button, input, textarea, select, summary):focus-visible {
  outline: 0;
  box-shadow: var(--ring);
  border-radius: var(--radius-xs);
}

/* =====================================================================
   Pass 15 ??? TIP-TOP polish
   - Theme icon hard-fix (legacy style.css has 4 conflicting rules)
   - Navbar refinement
   - Leanpay strip more visible
   - Product cards alive (animations, primary CTA on hover, image scale)
   ===================================================================== */

/* ---- 18.1 Theme toggle: bullet-proof override ---- */
html body #themeToggleBtn.theme-toggle.btn-secondary,
html body #themeToggleBtn.theme-toggle {
  width: 40px !important;
  height: 40px !important;
  min-width: 40px !important;
  min-height: 40px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  border: 1px solid var(--c-border) !important;
  background: var(--c-surface-2) !important;
  color: var(--c-text) !important;
  display: inline-grid !important;
  place-items: center !important;
  cursor: pointer !important;
  font-size: 0 !important;
  line-height: 1 !important;
  box-shadow: var(--shadow-sm) !important;
  overflow: hidden !important;
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease !important;
}

html body #themeToggleBtn.theme-toggle:hover {
  background: var(--c-surface) !important;
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border)) !important;
  transform: rotate(-12deg) scale(1.04);
}

html body #themeToggleBtn.theme-toggle .theme-icon {
  width: 20px !important;
  height: 20px !important;
  display: inline-block !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: 20px 20px !important;
  background-color: transparent !important;
  border: 0 !important;
  filter: none !important;
  transition: transform 0.25s ease;
}

html body #themeToggleBtn.theme-toggle .theme-icon.moon {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231f2a44' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z'/%3E%3C/svg%3E") !important;
}

html body #themeToggleBtn.theme-toggle .theme-icon.sun {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23ffd166' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3Cpath d='M12 2v2M12 20v2M4.93 4.93l1.41 1.41M17.66 17.66l1.41 1.41M2 12h2M20 12h2M4.93 19.07l1.41-1.41M17.66 6.34l1.41-1.41'/%3E%3C/svg%3E") !important;
}

:root[data-theme="dark"] html body #themeToggleBtn.theme-toggle .theme-icon.moon,
:root[data-theme="dark"] body #themeToggleBtn.theme-toggle .theme-icon.moon {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23e9edf6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z'/%3E%3C/svg%3E") !important;
}

/* ---- 18.2 Navbar refinement (reference layout) ---- */
body.home-page .site-header.site-header-main,
body.catalog-page .site-header.site-header-main,
body.about-page .site-header.site-header-main,
body.contact-page .site-header.site-header-main {
  position: sticky;
  top: 0;
  z-index: 50;
  padding: 0;
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-border);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

body.home-page .nav-wrap,
body.catalog-page .nav-wrap,
body.about-page .nav-wrap,
body.contact-page .nav-wrap {
  min-height: 76px;
  gap: 1rem 1.75rem;
  padding-block: 0.55rem;
}

body.home-page .brand-title,
body.catalog-page .brand-title,
body.about-page .brand-title,
body.contact-page .brand-title {
  font-size: inherit;
  gap: 0.55rem;
}

body.home-page .brand-link:hover .brand-logo,
body.catalog-page .brand-link:hover .brand-logo,
body.about-page .brand-link:hover .brand-logo,
body.contact-page .brand-link:hover .brand-logo {
  transform: rotate(-6deg) scale(1.06);
}

body.home-page .brand-logo,
body.catalog-page .brand-logo,
body.about-page .brand-logo,
body.contact-page .brand-logo {
  filter: drop-shadow(0 4px 12px rgba(255, 79, 51, 0.18));
  transition: transform 0.2s ease;
}

body.home-page .site-nav,
body.catalog-page .site-nav,
body.about-page .site-nav,
body.contact-page .site-nav {
  gap: 0.02rem;
}

body.home-page .site-nav a:not(.header-search-toggle):not(.header-search-input),
body.catalog-page .site-nav a:not(.header-search-toggle):not(.header-search-input),
body.about-page .site-nav a:not(.header-search-toggle):not(.header-search-input),
body.contact-page .site-nav a:not(.header-search-toggle):not(.header-search-input) {
  padding: 0.5rem 0.58rem;
  font-size: 0.9rem;
}

body.home-page .site-nav a:not(.header-search-toggle):not(.header-search-input):hover,
body.catalog-page .site-nav a:not(.header-search-toggle):not(.header-search-input):hover,
body.about-page .site-nav a:not(.header-search-toggle):not(.header-search-input):hover,
body.contact-page .site-nav a:not(.header-search-toggle):not(.header-search-input):hover {
  color: var(--c-primary);
  background: transparent;
}

body.home-page .site-nav a.active,
body.catalog-page .site-nav a.active,
body.about-page .site-nav a.active,
body.contact-page .site-nav a.active {
  color: var(--c-primary);
  background: transparent;
}

body.home-page .site-nav a.active::after,
body.catalog-page .site-nav a.active::after,
body.about-page .site-nav a.active::after,
body.contact-page .site-nav a.active::after {
  bottom: 2px;
  left: 0.58rem;
  right: 0.58rem;
  width: auto;
  transform: none;
}

body.home-page .header-search.nav-search,
body.catalog-page .header-search.nav-search,
body.about-page .header-search.nav-search,
body.contact-page .header-search.nav-search {
  margin-left: 0;
  padding-right: 3px;
}

body.home-page .header-search-input,
body.catalog-page .header-search-input,
body.about-page .header-search-input,
body.contact-page .header-search-input {
  font-size: 0.9rem;
  padding-block: 0.5rem;
}

body.home-page .header-search .header-search-input::placeholder,
body.catalog-page .header-search .header-search-input::placeholder,
body.about-page .header-search .header-search-input::placeholder,
body.contact-page .header-search .header-search-input::placeholder {
  color: var(--c-muted);
}

/* ---- 18.3 Leanpay strip ??? more visible ---- */
body.home-page .leanpay-strip,
body.catalog-page .leanpay-strip,
body.about-page .leanpay-strip,
body.contact-page .leanpay-strip {
  padding: 0.85rem 0;
  background:
    linear-gradient(90deg, var(--c-primary) 0%, var(--c-primary-strong) 60%, var(--c-primary) 100%);
  border-bottom: 1px solid color-mix(in srgb, #000 10%, transparent);
  box-shadow: 0 6px 18px -8px rgba(255, 79, 51, 0.45);
  position: relative;
  overflow: hidden;
}

body.home-page .leanpay-strip::before,
body.catalog-page .leanpay-strip::before,
body.about-page .leanpay-strip::before,
body.contact-page .leanpay-strip::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.06) 0 12px,
      transparent 12px 24px
    );
  pointer-events: none;
}

body.home-page .leanpay-strip .container,
body.catalog-page .leanpay-strip .container,
body.about-page .leanpay-strip .container,
body.contact-page .leanpay-strip .container {
  position: relative;
  font-size: 0.86rem;
  letter-spacing: 0.06em;
  font-weight: 700;
  text-transform: uppercase;
  gap: 0.5rem 1.6rem;
}

body.home-page .leanpay-strip strong,
body.catalog-page .leanpay-strip strong,
body.about-page .leanpay-strip strong,
body.contact-page .leanpay-strip strong {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  font-size: 0.9rem;
}

body.home-page .leanpay-strip strong::before,
body.catalog-page .leanpay-strip strong::before,
body.about-page .leanpay-strip strong::before,
body.contact-page .leanpay-strip strong::before {
  content: "";
  width: 22px;
  height: 16px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='5' width='20' height='14' rx='2'/%3E%3Cpath d='M2 10h20'/%3E%3Cpath d='M6 15h2'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0.95;
}

body.home-page .leanpay-strip span,
body.catalog-page .leanpay-strip span,
body.about-page .leanpay-strip span,
body.contact-page .leanpay-strip span {
  opacity: 1;
  font-weight: 600;
}

body.home-page .leanpay-strip span::before,
body.catalog-page .leanpay-strip span::before,
body.about-page .leanpay-strip span::before,
body.contact-page .leanpay-strip span::before {
  background: rgba(255, 255, 255, 0.7);
  width: 5px;
  height: 5px;
  left: -1rem;
}

/* ---- 18.4 Product cards ??? more alive ---- */
body.catalog-page .product-grid {
  gap: var(--space-5);
}

body.catalog-page .product-grid .card {
  position: relative;
  overflow: hidden;
  padding: 0.6rem 0.6rem 1rem;
  gap: 0.55rem;
  animation: card-in 0.42s ease both;
}

body.catalog-page .product-grid .card:nth-child(1) { animation-delay: 0.02s; }
body.catalog-page .product-grid .card:nth-child(2) { animation-delay: 0.06s; }
body.catalog-page .product-grid .card:nth-child(3) { animation-delay: 0.10s; }
body.catalog-page .product-grid .card:nth-child(4) { animation-delay: 0.14s; }
body.catalog-page .product-grid .card:nth-child(5) { animation-delay: 0.18s; }
body.catalog-page .product-grid .card:nth-child(6) { animation-delay: 0.22s; }

@keyframes card-in {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: none; }
}

body.catalog-page .product-grid .card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 44px -18px rgba(15, 23, 42, 0.22);
  border-color: color-mix(in srgb, var(--c-primary) 40%, var(--c-border));
}

body.catalog-page .product-grid .card > h3,
body.catalog-page .product-grid .card > .price,
body.catalog-page .product-grid .card > .card-description,
body.catalog-page .product-grid .card > .category,
body.catalog-page .product-grid .card > button {
  margin-inline: 0.4rem;
}

body.catalog-page .card-image {
  aspect-ratio: 4 / 3;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--c-surface-2), var(--c-surface-3));
  overflow: hidden;
  transition: transform 0.4s ease;
}

body.catalog-page .product-grid .card:hover .card-image {
  transform: scale(1.025);
}

body.catalog-page .card-image.placeholder {
  position: relative;
  display: grid;
  place-items: center;
  color: transparent;
  background:
    radial-gradient(circle at 30% 20%, color-mix(in srgb, var(--c-primary) 12%, transparent), transparent 55%),
    linear-gradient(135deg, var(--c-surface-2) 0%, var(--c-surface-3) 100%);
  border: 1px solid var(--c-border);
}

body.catalog-page .card-image.placeholder::before {
  content: "";
  width: 56px;
  height: 56px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='56' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 2 3 6v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6l-3-4z'/%3E%3Cline x1='3' y1='6' x2='21' y2='6'/%3E%3Cpath d='M16 10a4 4 0 0 1-8 0'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0.55;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

body.catalog-page .product-grid .card:hover .card-image.placeholder::before {
  transform: scale(1.08) rotate(-3deg);
  opacity: 0.78;
}

body.catalog-page .card-image.placeholder::after {
  content: "Foto v pripravi";
  position: absolute;
  bottom: 0.55rem;
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-muted);
}

body.catalog-page .card .category {
  margin-top: 0.5rem;
  font-size: 0.66rem;
  padding: 0.22rem 0.55rem;
}

body.catalog-page .card h3 {
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

body.catalog-page .card .price {
  font-size: 1.25rem;
  font-weight: 800;
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: -0.01em;
}

body.catalog-page .card-description {
  -webkit-line-clamp: 2;
  font-size: 0.85rem;
  line-height: 1.5;
}

body.catalog-page .card button {
  position: relative;
  background: var(--c-surface);
  border: 1px solid var(--c-border-strong);
  color: var(--c-text);
  font-weight: 700;
  padding-inline: 1rem;
  overflow: hidden;
  transition: background 0.25s ease, color 0.2s ease, border-color 0.2s ease, transform 0.18s ease;
}

body.catalog-page .card button::after {
  content: "\2192";
  font-weight: 700;
  font-size: 1rem;
  transition: transform 0.22s ease;
  margin-left: 0.4rem;
}

body.catalog-page .card button:hover {
  background: var(--c-primary);
  border-color: var(--c-primary);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: var(--shadow-primary);
}

body.catalog-page .card button:hover::after {
  transform: translateX(3px);
}

body.catalog-page .product-grid .card:hover button {
  background: var(--c-primary);
  border-color: var(--c-primary);
  color: #fff;
}

/* Improved skeleton */
body.catalog-page .skeleton-card {
  padding: 0.6rem 0.6rem 1rem;
}

body.catalog-page .skeleton-card .skeleton:first-child {
  aspect-ratio: 4 / 3;
  width: 100%;
  height: auto;
  margin-bottom: 0.4rem;
}

@media (prefers-reduced-motion: reduce) {
  body.catalog-page .product-grid .card,
  body.home-page .brand-link:hover .brand-logo,
  html body #themeToggleBtn.theme-toggle:hover {
    animation: none !important;
    transform: none !important;
  }
}

/* =====================================================================
   Pass 18 ??? Dark/premium polish, in the same language as the new footer
   - Hero polish (kicker dot, larger title, gradient bg)
   - Buttons (primary gradient + glow, secondary clean)
   - Leanpay strip (deeper red, shipping ribbon)
   - Product dialog (premium spacing)
   - Contact form (modern inputs, success/error)
   - Generic section / cta polish
   ===================================================================== */

/* ---- 19.1 Universal kicker (eyebrow) with primary dot ---- */
body.home-page .home-kicker,
body.about-page .about-kicker,
body.contact-page .contact-kicker,
body.home-page .hp-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.32rem 0.75rem 0.32rem 0.55rem;
  background: var(--c-primary-soft);
  color: var(--c-primary-strong);
  border: 1px solid color-mix(in srgb, var(--c-primary) 28%, transparent);
  border-radius: var(--radius-pill);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

body.home-page .home-kicker::before,
body.about-page .about-kicker::before,
body.contact-page .contact-kicker::before,
body.home-page .hp-eyebrow::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--c-primary);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-primary) 18%, transparent);
}

/* ---- 19.2 Hero polish ---- */
body.home-page .home-hero,
body.about-page .about-hero,
body.contact-page .contact-hero,
body.catalog-page .catalog-hero {
  border-radius: var(--radius-lg);
  overflow: hidden;
  isolation: isolate;
}

body.home-page .home-hero::before,
body.about-page .about-hero::before,
body.contact-page .contact-hero::before,
body.catalog-page .catalog-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(600px circle at 92% -10%, color-mix(in srgb, var(--c-primary) 14%, transparent), transparent 55%),
    radial-gradient(500px circle at -10% 110%, color-mix(in srgb, var(--c-primary) 8%, transparent), transparent 55%);
  pointer-events: none;
  opacity: 0.95;
  z-index: 0;
}

body.home-page .home-hero,
body.about-page .about-hero,
body.contact-page .contact-hero,
body.catalog-page .catalog-hero {
  position: relative;
}

body.home-page .home-hero > *,
body.about-page .about-hero > *,
body.contact-page .contact-hero > *,
body.catalog-page .catalog-hero > * {
  position: relative;
  z-index: 1;
}

body.home-page .home-hero h1,
body.about-page .about-hero h1,
body.contact-page .contact-hero h1 {
  font-size: clamp(2rem, 4.4vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.05;
}

body.home-page .home-hero h1 {
  font-size: clamp(2.2rem, 5vw, 3.5rem);
}

body.home-page .home-hero-copy > p,
body.about-page .about-hero-copy > p,
body.contact-page .contact-hero-copy > p {
  font-size: 1.05rem;
  line-height: 1.6;
  max-width: 58ch;
}

body.home-page .hero-tags span,
body.about-page .about-hero-tags span,
body.contact-page .contact-hero-tags span {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-sm);
  padding: 0.4rem 0.85rem;
  font-weight: 500;
}

/* ---- 19.3 Buttons polish ---- */
body.home-page .btn-primary,
body.catalog-page .btn-primary,
body.about-page .btn-primary,
body.contact-page .btn-primary {
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  border: 0;
  font-weight: 700;
  letter-spacing: -0.005em;
  font-size: 0.95rem;
  padding: 0.78rem 1.35rem;
  min-height: 46px;
  border-radius: var(--radius-sm);
  box-shadow:
    0 12px 28px rgba(255, 79, 51, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  position: relative;
  overflow: hidden;
}

body.home-page .btn-primary::after,
body.catalog-page .btn-primary::after,
body.about-page .btn-primary::after,
body.contact-page .btn-primary::after {
  content: "\2192";
  margin-left: 0.35rem;
  transition: transform 0.18s ease;
  font-weight: 700;
}

body.home-page .btn-primary:hover::after,
body.catalog-page .btn-primary:hover::after,
body.about-page .btn-primary:hover::after,
body.contact-page .btn-primary:hover::after {
  transform: translateX(3px);
}

body.home-page .btn-primary:hover,
body.catalog-page .btn-primary:hover,
body.about-page .btn-primary:hover,
body.contact-page .btn-primary:hover {
  background: linear-gradient(180deg, var(--c-primary-strong) 0%, color-mix(in srgb, var(--c-primary-strong) 80%, #000) 100%);
  transform: translateY(-2px);
  box-shadow:
    0 18px 36px rgba(255, 79, 51, 0.36),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

body.home-page .btn-secondary,
body.catalog-page .btn-secondary,
body.about-page .btn-secondary,
body.contact-page .btn-secondary {
  font-weight: 600;
  font-size: 0.92rem;
  padding: 0.72rem 1.2rem;
  min-height: 46px;
  border-color: var(--c-border-strong);
}

body.home-page .btn-secondary:hover,
body.catalog-page .btn-secondary:hover,
body.about-page .btn-secondary:hover,
body.contact-page .btn-secondary:hover {
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border-strong));
  color: var(--c-primary);
}

/* ---- 19.4 Leanpay strip ??? deeper, premium ribbon ---- */
body.home-page .leanpay-strip,
body.catalog-page .leanpay-strip,
body.about-page .leanpay-strip,
body.contact-page .leanpay-strip {
  background:
    radial-gradient(120% 80% at 50% 0%, color-mix(in srgb, #fff 18%, transparent), transparent 55%),
    linear-gradient(95deg, #f0481c 0%, var(--c-primary) 35%, var(--c-primary-strong) 100%);
  padding: 0.8rem 0;
  box-shadow:
    0 -1px 0 rgba(0, 0, 0, 0.05) inset,
    0 8px 24px -10px rgba(255, 79, 51, 0.55);
}

body.home-page .leanpay-strip .container,
body.catalog-page .leanpay-strip .container,
body.about-page .leanpay-strip .container,
body.contact-page .leanpay-strip .container {
  font-size: 0.84rem;
  letter-spacing: 0.08em;
  font-weight: 700;
}

body.home-page .leanpay-strip strong,
body.catalog-page .leanpay-strip strong,
body.about-page .leanpay-strip strong,
body.contact-page .leanpay-strip strong {
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0.1em;
}

/* ---- 19.5 Section card cohesion (home + about + contact panels) ---- */
body.home-page .hp-section,
body.about-page .about-values,
body.about-page .about-cta,
body.contact-page .contact-info-card,
body.contact-page .contact-form-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.6) inset,
    var(--shadow-sm);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body.home-page .hp-section:hover,
body.about-page .about-values:hover,
body.contact-page .contact-info-card:hover,
body.contact-page .contact-form-card:hover {
  border-color: color-mix(in srgb, var(--c-primary) 14%, var(--c-border));
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.6) inset,
    var(--shadow-md);
}

/* Home strip CTA ??? premium dark band */
body.home-page .home-strip {
  background:
    radial-gradient(circle at 90% 50%, color-mix(in srgb, var(--c-primary) 22%, transparent), transparent 55%),
    linear-gradient(120deg, #14171c 0%, #1c2129 100%);
  border-color: rgba(255, 255, 255, 0.06);
  color: #e9edf6;
}

body.home-page .home-strip h3 {
  color: #fff;
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.015em;
}

body.home-page .home-strip p {
  color: #c4cad6;
}

body.home-page .home-strip .btn-secondary {
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.18);
}

body.home-page .home-strip .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.32);
}

/* About CTA ??? premium dark band same family */
body.about-page .about-cta {
  background:
    radial-gradient(circle at 92% 50%, color-mix(in srgb, var(--c-primary) 22%, transparent), transparent 55%),
    linear-gradient(120deg, #14171c 0%, #1c2129 100%);
  border-color: rgba(255, 255, 255, 0.06);
  color: #e9edf6;
}

body.about-page .about-cta h2 {
  color: #fff;
}

body.about-page .about-cta p {
  color: #c4cad6;
}

body.about-page .about-cta .btn-secondary {
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.18);
}

body.about-page .about-cta .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.32);
  color: #fff;
}

/* ---- 19.6 Cat / value / highlight cards ---- */
body.home-page .cat-card,
body.about-page .about-values-grid article,
body.home-page .hp-highlight-grid article {
  border-radius: var(--radius-md);
  transition:
    transform 0.22s ease,
    box-shadow 0.22s ease,
    border-color 0.22s ease,
    background 0.22s ease;
}

body.home-page .cat-card:hover,
body.about-page .about-values-grid article:hover,
body.home-page .hp-highlight-grid article:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--c-primary) 32%, var(--c-border));
  box-shadow: 0 18px 36px -16px rgba(15, 23, 42, 0.18);
  background: color-mix(in srgb, var(--c-primary) 4%, var(--c-surface));
}

body.home-page .hp-stat {
  font-size: 0.85rem;
  letter-spacing: 0.16em;
}

/* ---- 19.7 Steps list shine ---- */
body.home-page .hp-steps li {
  position: relative;
  padding-left: 3.4rem;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  transition: border-color 0.2s ease, transform 0.2s ease;
}

body.home-page .hp-steps li::before {
  content: "";
  position: absolute;
  left: 0.85rem;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: var(--radius-pill);
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 28%, transparent);
}

body.home-page .hp-steps li::after {
  content: "";
  position: absolute;
  left: 1.4rem;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  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='%23ff4f33' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

body.home-page .hp-steps li:hover {
  border-color: color-mix(in srgb, var(--c-primary) 28%, var(--c-border));
  transform: translateY(-1px);
}

body.home-page .hp-steps li strong {
  display: inline-block;
}

body.home-page .hp-steps li strong::first-letter {
  color: var(--c-primary);
}

/* ---- 19.8 Product dialog premium feel ---- */
body.catalog-page .product-dialog {
  padding: 0;
  border: 1px solid var(--c-border);
  background: var(--c-surface);
  border-radius: var(--radius-lg);
  width: min(640px, 94vw);
  max-height: 90vh;
  overflow: hidden;
}

body.catalog-page .product-dialog::backdrop {
  background: rgba(8, 9, 11, 0.55);
  backdrop-filter: blur(8px);
}

body.catalog-page .product-dialog #dialogContent {
  padding: 1.6rem 1.6rem 0;
}

body.catalog-page .product-dialog .dialog-image {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 0;
  margin: 0 0 var(--space-4);
}

body.catalog-page .product-dialog #dialogContent h2 {
  font-size: 1.45rem;
  font-weight: 800;
  letter-spacing: -0.015em;
  margin: 0 0 var(--space-3);
}

body.catalog-page .product-dialog #dialogContent p {
  font-size: 0.94rem;
  line-height: 1.6;
  margin: 0 0 var(--space-2);
}

body.catalog-page .product-dialog #dialogContent p strong {
  color: var(--c-text);
  margin-right: 0.4rem;
}

body.catalog-page .product-dialog #closeDialogBtn {
  width: calc(100% - 3.2rem);
  margin: var(--space-4) 1.6rem 1.6rem;
  min-height: 44px;
}

/* ---- 19.9 Contact form ??? modern inputs ---- */
body.contact-page .contact-form label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-muted);
}

body.contact-page .contact-form input,
body.contact-page .contact-form textarea {
  border-radius: var(--radius-sm);
  border-width: 1px;
  background: var(--c-surface-2);
  font-size: 0.95rem;
  padding: 0.8rem 1rem;
  min-height: 50px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    transform 0.18s ease;
}

:root[data-theme="dark"] body.contact-page .contact-form input,
:root[data-theme="dark"] body.contact-page .contact-form textarea {
  box-shadow: none;
}

body.contact-page .contact-form input:hover,
body.contact-page .contact-form textarea:hover {
  border-color: var(--c-border-strong);
}

body.contact-page .contact-form input:focus,
body.contact-page .contact-form textarea:focus {
  background: var(--c-surface);
  transform: translateY(-1px);
  box-shadow:
    var(--ring),
    inset 0 1px 0 rgba(255, 255, 255, 0.4);
}

body.contact-page #contactSubmitBtn {
  font-size: 0.96rem;
  padding: 0.85rem 1.6rem;
  min-height: 52px;
  min-width: 240px;
}

body.contact-page .contact-form-status {
  padding: 0.4rem 0;
  font-size: 0.92rem;
  font-weight: 500;
}

body.contact-page .contact-form-status.success::before,
body.contact-page .contact-form-status.error::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 0.45rem;
  vertical-align: middle;
  background: currentColor;
}

/* Contact info list ??? uniform tile look */
body.contact-page .contact-info-list p {
  display: grid;
  gap: 0.15rem;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  padding: 0.85rem 1rem;
  font-size: 0.92rem;
  transition: border-color 0.18s ease, transform 0.18s ease;
}

body.contact-page .contact-info-list p:hover {
  border-color: color-mix(in srgb, var(--c-primary) 28%, var(--c-border));
  transform: translateY(-1px);
}

body.contact-page .contact-info-list p strong {
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  font-weight: 700;
}

/* ---- 19.10 FAQ items hover ---- */
body.home-page .hp-faq-grid details:hover {
  border-color: color-mix(in srgb, var(--c-primary) 28%, var(--c-border));
}

/* ---- 19.11 Smooth main fade-in ---- */
body.home-page main.container,
body.catalog-page main.container,
body.about-page main.container,
body.contact-page main.container {
  animation: page-fade-in 0.4s ease both;
}

@keyframes page-fade-in {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: none; }
}

@media (prefers-reduced-motion: reduce) {
  body.home-page main.container,
  body.catalog-page main.container,
  body.about-page main.container,
  body.contact-page main.container {
    animation: none !important;
  }
}

/* =====================================================================
   Pass 19 ??? MEGA visual upgrade
   ===================================================================== */

/* ---- 20.1 Custom scrollbar (Chrome/Edge) ---- */
::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}
::-webkit-scrollbar-track {
  background: var(--c-surface-2);
}
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  border-radius: 999px;
  border: 3px solid var(--c-surface-2);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--c-primary-strong);
  border-width: 2px;
}

/* ---- 20.2 Scroll progress bar ---- */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  z-index: 200;
  pointer-events: none;
  box-shadow: 0 2px 6px rgba(255, 79, 51, 0.45);
  transition: width 0.08s linear;
}

/* ---- 20.3 Reveal on scroll ---- */
[data-reveal] {
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity 0.55s cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 0.55s cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: opacity, transform;
}
[data-reveal].is-revealed {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  [data-reveal] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* ---- 20.4 Header scrolled state ---- */
body.home-page .site-header.is-scrolled,
body.catalog-page .site-header.is-scrolled,
body.about-page .site-header.is-scrolled,
body.contact-page .site-header.is-scrolled {
  box-shadow: 0 6px 22px rgba(15, 23, 42, 0.08);
  backdrop-filter: saturate(140%);
  -webkit-backdrop-filter: saturate(140%);
}

/* ---- 20.5 Mobile drawer ---- */
.nav-toggle {
  display: none;
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
  background: var(--c-surface-2);
  cursor: pointer;
  align-items: center;
  justify-content: center;
}
.nav-toggle-bars {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  width: 18px;
}
.nav-toggle-bars span {
  display: block;
  height: 2px;
  background: var(--c-text);
  border-radius: 2px;
  transition: transform 0.22s ease, opacity 0.22s ease;
}
body.nav-open .nav-toggle-bars span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}
body.nav-open .nav-toggle-bars span:nth-child(2) {
  opacity: 0;
}
body.nav-open .nav-toggle-bars span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

.mobile-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(8, 9, 11, 0.55);
  backdrop-filter: blur(6px);
  z-index: 80;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s ease;
}
body.nav-open .mobile-drawer-overlay {
  opacity: 1;
  pointer-events: auto;
}

.mobile-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(320px, 86vw);
  background: var(--c-surface);
  border-left: 1px solid var(--c-border);
  box-shadow: -20px 0 40px rgba(15, 23, 42, 0.18);
  z-index: 90;
  padding: 96px 1.4rem 1.4rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.32, 0.72, 0.32, 1);
}
body.nav-open .mobile-drawer {
  transform: translateX(0);
}
.mobile-drawer-link {
  position: relative;
  text-decoration: none;
  color: var(--c-text);
  font-size: 1.05rem;
  font-weight: 600;
  padding: 0.85rem 0.95rem;
  border-radius: var(--radius-sm);
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}
.mobile-drawer-link::before {
  content: "";
  position: absolute;
  left: 0.4rem;
  top: 50%;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--c-primary);
  opacity: 0;
  transform: translate(-6px, -50%);
  transition: opacity 0.18s ease, transform 0.18s ease;
}
.mobile-drawer-link:hover,
.mobile-drawer-link.is-active {
  background: var(--c-primary-soft);
  color: var(--c-primary-strong);
  transform: translateX(2px);
}
.mobile-drawer-link.is-active::before,
.mobile-drawer-link:hover::before {
  opacity: 1;
  transform: translate(0, -50%);
}
.mobile-drawer-divider {
  height: 1px;
  background: var(--c-border);
  margin: 0.6rem 0.4rem;
}
.mobile-drawer-meta {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.5rem 0.95rem;
  font-size: 0.92rem;
  color: var(--c-text-soft);
}
.mobile-drawer-meta a {
  color: var(--c-primary);
  text-decoration: none;
  font-weight: 600;
}

@media (max-width: 980px) {
  .nav-toggle { display: inline-flex; }
}

/* ---- 20.6 Brand bar ---- */
body.home-page .brand-bar {
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-border);
}
.brand-bar-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.6rem 1.6rem;
  padding: 0.85rem 0;
}
.brand-bar-label {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-muted);
  font-weight: 700;
  padding-right: 0.5rem;
  border-right: 1px solid var(--c-border-strong);
  margin-right: 0.4rem;
}
.brand-bar-name {
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--c-text-soft);
  opacity: 0.9;
  transition: color 0.18s ease, transform 0.18s ease;
}
.brand-bar-name:hover {
  color: var(--c-primary);
  transform: translateY(-1px);
}
@media (max-width: 720px) {
  .brand-bar-label { display: none; }
}

/* ---- 20.7 Leanpay marquee/pulse ---- */
.leanpay-track {
  position: relative;
}
.leanpay-pulse {
  position: absolute;
  left: -8px;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 6px rgba(255, 255, 255, 0.18);
  animation: leanpay-pulse 1.6s ease-in-out infinite;
}
@keyframes leanpay-pulse {
  0%, 100% { transform: translateY(-50%) scale(1); opacity: 0.85; }
  50% { transform: translateY(-50%) scale(1.18); opacity: 1; }
}
@media (max-width: 720px) {
  .leanpay-pulse { display: none; }
}

/* ---- 20.8 Hero polish ??? gradient text + bullets + orbit ---- */
.text-grad {
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

body.home-page .hero-bullets {
  list-style: none;
  margin: var(--space-4) 0 0;
  padding: 0;
  display: grid;
  gap: 0.5rem;
}
body.home-page .hero-bullets li {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.92rem;
  color: var(--c-text-soft);
}
body.home-page .hero-bullets strong {
  color: var(--c-text);
  font-weight: 700;
  margin-inline: 0.18rem;
}
.hero-bullet-dot {
  display: inline-flex;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--c-primary-soft);
  position: relative;
  flex-shrink: 0;
}
.hero-bullet-dot::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 11px 11px;
}

/* Hero brand panel ? calm layout (no floating pins / orbit) */
body.home-page .home-hero-brand {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  width: 100%;
  max-width: 320px;
  margin: 0 auto;
}
body.home-page .home-hero-brand-glow {
  position: absolute;
  left: 50%;
  top: 28%;
  transform: translate(-50%, -50%);
  width: min(240px, 70vw);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(
    circle at 45% 40%,
    color-mix(in srgb, var(--c-primary) 28%, transparent) 0%,
    color-mix(in srgb, var(--c-primary) 8%, transparent) 45%,
    transparent 70%
  );
  filter: blur(28px);
  pointer-events: none;
  z-index: 0;
  opacity: 0.9;
}
body.home-page .home-hero-brand img {
  position: relative;
  z-index: 1;
  width: min(220px, 72%);
  max-width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 12px 28px color-mix(in srgb, var(--c-primary) 22%, transparent));
}
body.home-page .home-hero-highlights {
  position: relative;
  z-index: 1;
  list-style: none;
  margin: 0;
  padding: 1rem 0 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0;
  border-top: 1px solid var(--c-border);
}
body.home-page .home-hero-highlights li {
  padding: 0 0.75rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--c-text-soft);
  line-height: 1.3;
}
body.home-page .home-hero-highlights li + li {
  border-left: 1px solid var(--c-border);
}
@media (max-width: 420px) {
  body.home-page .home-hero-highlights {
    flex-direction: column;
    gap: 0.45rem;
    padding-top: 0.85rem;
  }
  body.home-page .home-hero-highlights li {
    padding: 0;
    border-left: 0 !important;
  }
}

/* ---- 20.9 Home stats row ---- */
body.home-page .home-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}
body.home-page .home-stat-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
body.home-page .home-stat-card::before {
  content: "";
  position: absolute;
  right: -30px;
  top: -30px;
  width: 80px;
  height: 80px;
  background: radial-gradient(circle, color-mix(in srgb, var(--c-primary) 22%, transparent), transparent 70%);
  border-radius: 50%;
}
body.home-page .home-stat-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--c-primary) 28%, var(--c-border));
  box-shadow: var(--shadow-md);
}
body.home-page .home-stat-num {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  background: linear-gradient(180deg, var(--c-text) 0%, color-mix(in srgb, var(--c-text) 65%, var(--c-primary)) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
}
body.home-page .home-stat-label {
  font-size: 0.85rem;
  color: var(--c-text-soft);
  letter-spacing: -0.005em;
}
@media (max-width: 880px) {
  body.home-page .home-stats { grid-template-columns: repeat(2, 1fr); }
}

/* ---- 20.10 Cat-card icons ---- */
body.home-page .cat-card[data-cat-icon]::before {
  background-position: center;
  background-repeat: no-repeat;
  background-size: 22px 22px;
}
body.home-page .cat-card[data-cat-icon="appliances"]::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='3'/%3E%3Cpath d='M3 9h18'/%3E%3Ccircle cx='8' cy='15' r='2'/%3E%3Ccircle cx='16' cy='15' r='2'/%3E%3C/svg%3E");
}
body.home-page .cat-card[data-cat-icon="garden"]::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22V12'/%3E%3Cpath d='M12 12c-4 0-8 3-8 8 4 0 8-3 8-8z'/%3E%3Cpath d='M12 12c4 0 8 3 8 8-4 0-8-3-8-8z'/%3E%3Cpath d='M12 12c0-4 2-8 6-8-1 4-4 7-6 8z'/%3E%3C/svg%3E");
}
body.home-page .cat-card[data-cat-icon="tools"]::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z'/%3E%3C/svg%3E");
}
body.home-page .cat-card[data-cat-icon="tv"]::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='5' width='20' height='14' rx='2'/%3E%3Cpolyline points='17 2 12 7 7 2'/%3E%3C/svg%3E");
}

/* ---- 20.11 Home trust grid ---- */
body.home-page .home-trust-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}
body.home-page .home-trust-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  transition: border-color 0.2s ease, transform 0.2s ease;
}
body.home-page .home-trust-card:hover {
  border-color: color-mix(in srgb, var(--c-primary) 30%, var(--c-border));
  transform: translateY(-2px);
}
body.home-page .home-trust-icon {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  margin-bottom: var(--space-3);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 22px 22px;
}
body.home-page .home-trust-icon[data-icon="shield"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z'/%3E%3C/svg%3E");
}
body.home-page .home-trust-icon[data-icon="bolt"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='13 2 3 14 12 14 11 22 21 10 12 10 13 2'/%3E%3C/svg%3E");
}
body.home-page .home-trust-icon[data-icon="heart"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78L12 21l8.84-8.61a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E");
}
@media (max-width: 880px) {
  body.home-page .home-trust-grid { grid-template-columns: 1fr; }
}

/* ---- 20.12 Quotes ---- */
body.home-page .home-quotes-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}
body.home-page .home-quote {
  margin: 0;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
body.home-page .home-quote::before {
  content: "\201C";
  position: absolute;
  right: 1rem;
  top: 0.4rem;
  font-size: 4rem;
  line-height: 1;
  color: color-mix(in srgb, var(--c-primary) 25%, transparent);
  font-family: Georgia, serif;
}
body.home-page .home-quote blockquote {
  margin: 0;
  font-size: 0.96rem;
  color: var(--c-text);
  line-height: 1.55;
  font-weight: 500;
}
body.home-page .home-quote figcaption {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin: 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--c-border);
}
.home-quote-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  color: #fff;
  font-weight: 800;
  letter-spacing: 0.02em;
}
.home-quote-name {
  display: block;
  font-weight: 700;
  font-size: 0.92rem;
  color: var(--c-text);
}
.home-quote-role {
  display: block;
  font-size: 0.78rem;
  color: var(--c-muted);
}
@media (max-width: 880px) {
  body.home-page .home-quotes-grid { grid-template-columns: 1fr; }
}

/* ---- 20.13 About ??? stats / timeline / promise ---- */
body.about-page .about-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
  background: transparent;
  border: 0;
  padding: 0;
  box-shadow: none;
}
body.about-page .about-stats:hover {
  background: transparent;
  border: 0;
  box-shadow: none;
}
body.about-page .about-stat {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  transition: border-color 0.2s ease, transform 0.2s ease;
}
body.about-page .about-stat:hover {
  border-color: color-mix(in srgb, var(--c-primary) 30%, var(--c-border));
  transform: translateY(-2px);
}
body.about-page .about-stat-num {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
}
body.about-page .about-stat-label {
  color: var(--c-text-soft);
  font-size: 0.88rem;
}
@media (max-width: 880px) {
  body.about-page .about-stats { grid-template-columns: repeat(2, 1fr); }
}

body.about-page .about-timeline {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 3vw, 2.2rem);
}
body.about-page .timeline-list {
  list-style: none;
  margin: var(--space-4) 0 0;
  padding: 0 0 0 1.4rem;
  position: relative;
  display: grid;
  gap: var(--space-4);
}
body.about-page .timeline-list::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: linear-gradient(180deg, var(--c-primary) 0%, color-mix(in srgb, var(--c-primary) 12%, transparent) 100%);
  border-radius: 2px;
}
body.about-page .timeline-item {
  position: relative;
  padding-left: 1rem;
}
body.about-page .timeline-dot {
  position: absolute;
  left: -1.4rem;
  top: 4px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--c-surface);
  border: 3px solid var(--c-primary);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-primary) 18%, transparent);
}
body.about-page .timeline-year {
  display: inline-block;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  font-weight: 800;
  color: var(--c-primary);
  text-transform: uppercase;
  margin-bottom: 0.3rem;
}
body.about-page .timeline-item h3 {
  margin: 0 0 0.2rem;
  font-size: 1.05rem;
  font-weight: 700;
}
body.about-page .timeline-item p {
  margin: 0;
  color: var(--c-text-soft);
  font-size: 0.92rem;
}

body.about-page .about-promise-card {
  background:
    radial-gradient(circle at 90% 0%, color-mix(in srgb, var(--c-primary) 18%, transparent), transparent 55%),
    var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 3vw, 2.2rem);
}
body.about-page .about-promise-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem 1rem;
  list-style: none;
  margin: var(--space-3) 0 0;
  padding: 0;
}
body.about-page .about-promise-list li {
  position: relative;
  padding-left: 1.5rem;
  font-size: 0.92rem;
  color: var(--c-text);
}
body.about-page .about-promise-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 2px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--c-primary-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center / 12px no-repeat;
}
@media (max-width: 720px) {
  body.about-page .about-promise-list { grid-template-columns: 1fr; }
}

/* ---- 20.14 Contact channels ---- */
body.contact-page .contact-channels {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
  padding: 0;
  border: 0;
  background: transparent;
}
.contact-channel {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 1rem 1.1rem;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.contact-channel:hover {
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border));
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.contact-channel-icon {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 22%, transparent);
  flex-shrink: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 22px 22px;
}
.contact-channel-icon[data-icon="phone"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.37 1.9.72 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.91.35 1.85.59 2.81.72A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E");
}
.contact-channel-icon[data-icon="mail"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='4' width='20' height='16' rx='2'/%3E%3Cpolyline points='22,6 12,13 2,6'/%3E%3C/svg%3E");
}
.contact-channel-icon[data-icon="pin"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13S3 17 3 10a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E");
}
.contact-channel-body {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}
.contact-channel-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-muted);
}
.contact-channel-value {
  font-size: 1rem;
  font-weight: 700;
  color: var(--c-text);
  letter-spacing: -0.01em;
}
.contact-channel-meta {
  font-size: 0.82rem;
  color: var(--c-text-soft);
}
@media (max-width: 880px) {
  body.contact-page .contact-channels { grid-template-columns: 1fr; }
}

body.contact-page .contact-form-lead {
  margin: -0.5rem 0 var(--space-3);
  font-size: 0.92rem;
  color: var(--c-text-soft);
}

body.contact-page .contact-hours {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--c-border);
}
.contact-hours-title {
  margin: 0 0 var(--space-2);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-muted);
}
.contact-hours-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.4rem;
}
.contact-hours-list li {
  display: flex;
  justify-content: space-between;
  font-size: 0.92rem;
  color: var(--c-text);
}
.contact-hours-list .muted {
  color: var(--c-muted);
}

/* ---- 20.15 Catalog hero polish ---- */
body.catalog-page .catalog-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
}
body.catalog-page .catalog-hero-lead {
  margin: var(--space-3) 0 0;
  font-size: 0.95rem;
  color: var(--c-text-soft);
  max-width: 56ch;
}
body.catalog-page .catalog-hero-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.3rem;
  text-align: right;
}
.catalog-meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-success);
  background: color-mix(in srgb, var(--c-success) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--c-success) 30%, transparent);
  padding: 0.25rem 0.7rem;
  border-radius: var(--radius-pill);
}
.catalog-meta-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--c-success);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-success) 22%, transparent);
  animation: leanpay-pulse 1.6s ease-in-out infinite;
}
.catalog-meta-stat {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: -0.02em;
}
.catalog-meta-label {
  color: var(--c-muted);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
}
@media (max-width: 720px) {
  body.catalog-page .catalog-hero-meta {
    align-items: flex-start;
    text-align: left;
  }
}

/* Toolbar hint + live pill */
.toolbar-hint {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  color: var(--c-muted);
  margin-top: var(--space-2);
}
.kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 0.35rem;
  border-radius: 6px;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-bottom-width: 2px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--c-text);
  font-family: ui-monospace, "Menlo", monospace;
}
.catalog-stats-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.6rem;
}
.catalog-live-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-text-soft);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  padding: 0.25rem 0.65rem;
  border-radius: var(--radius-pill);
}
.live-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--c-primary);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-primary) 22%, transparent);
  animation: leanpay-pulse 1.6s ease-in-out infinite;
}

/* ---- 20.16 Product cards ??? badges, rating, wish ---- */
body.catalog-page .product-grid .card {
  padding: 0;
  overflow: visible;
  display: flex;
  flex-direction: column;
}
body.catalog-page .card-media {
  position: relative;
  margin: 0;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  overflow: hidden;
}
body.catalog-page .product-grid .card .card-media .card-image {
  border-radius: 0;
  margin: 0;
}
body.catalog-page .card-badges {
  position: absolute;
  top: 0.6rem;
  left: 0.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  z-index: 2;
  pointer-events: none;
}
.card-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.25rem 0.55rem;
  border-radius: var(--radius-pill);
  color: #fff;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.18);
}
.card-badge-new {
  background: linear-gradient(180deg, #16a34a 0%, #0f8a3d 100%);
}
.card-badge-premium {
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
}
.card-wish {
  position: absolute;
  top: 0.55rem;
  right: 0.55rem;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--c-border);
  background: rgba(255, 255, 255, 0.92);
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 2;
  backdrop-filter: blur(6px);
  transition: background 0.18s ease, transform 0.18s ease, color 0.18s ease;
}
.card-wish span {
  display: block;
  width: 18px;
  height: 18px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23475467' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78L12 21l8.84-8.61a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  transition: filter 0.18s ease;
}
.card-wish:hover {
  background: #fff;
  transform: scale(1.06);
}
.card-wish.is-active {
  background: var(--c-primary);
  border-color: var(--c-primary);
}
.card-wish.is-active span {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='%23ffffff' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78L12 21l8.84-8.61a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E");
}

/* legacy direct-children rules ? kept as fallback for older renders */
body.catalog-page .product-grid .card > h3,
body.catalog-page .product-grid .card > .price,
body.catalog-page .product-grid .card > .card-description,
body.catalog-page .product-grid .card > .card-rating,
body.catalog-page .product-grid .card > .category,
body.catalog-page .product-grid .card > .card-cta {
  margin-inline: 1rem;
}
body.catalog-page .product-grid .card > .category {
  margin-top: 0.85rem;
}
body.catalog-page .product-grid .card > .card-cta {
  margin: var(--space-3) 1rem 1rem;
}

/* New card layout (Pass 21) ? uses .card-body wrapper */
body.catalog-page .product-grid .card .card-body h3 {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.3;
  letter-spacing: -0.01em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
}
body.catalog-page .product-grid .card .card-body .category {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
}
body.catalog-page .product-grid .card .card-body .price {
  margin: 0.1rem 0 0;
  font-size: 1.2rem;
  font-weight: 900;
  background: linear-gradient(180deg, var(--c-primary), var(--c-primary-strong));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.01em;
}
body.catalog-page .product-grid .card .card-body .card-description {
  margin: 0;
  color: var(--c-text-soft);
  font-size: 0.85rem;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
body.catalog-page .product-grid .card .card-body .card-cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.55rem 0.95rem;
  background: var(--c-surface-2);
  color: var(--c-text);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 0.85rem;
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: all 0.18s ease;
  align-self: flex-start;
}
body.catalog-page .product-grid .card .card-body .card-cta::after {
  content: "";
  width: 1em;
  height: 1em;
  flex-shrink: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") center / contain no-repeat;
  transition: transform 0.18s ease;
  border: 0;
  box-shadow: none;
}
body.catalog-page .product-grid .card .card-body .card-cta:hover {
  background: var(--c-primary);
  color: #fff;
  border-color: var(--c-primary);
}
body.catalog-page .product-grid .card .card-body .card-cta:hover::after {
  transform: translateX(2px);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E");
}

.card-rating {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  color: var(--c-text-soft);
  font-weight: 600;
}
.card-rating-stars {
  position: relative;
  display: inline-block;
  width: 84px;
  height: 14px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='84' height='14' viewBox='0 0 84 14'%3E%3Cg fill='%23d4d8e1'%3E%3Cpolygon points='7,1 9,5 13,5.5 10,8.5 11,13 7,11 3,13 4,8.5 1,5.5 5,5'/%3E%3Cpolygon points='24,1 26,5 30,5.5 27,8.5 28,13 24,11 20,13 21,8.5 18,5.5 22,5'/%3E%3Cpolygon points='41,1 43,5 47,5.5 44,8.5 45,13 41,11 37,13 38,8.5 35,5.5 39,5'/%3E%3Cpolygon points='58,1 60,5 64,5.5 61,8.5 62,13 58,11 54,13 55,8.5 52,5.5 56,5'/%3E%3Cpolygon points='75,1 77,5 81,5.5 78,8.5 79,13 75,11 71,13 72,8.5 69,5.5 73,5'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat: no-repeat;
}
.card-rating-fill {
  position: absolute;
  inset: 0;
  width: var(--r, 80%);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='84' height='14' viewBox='0 0 84 14'%3E%3Cg fill='%23ff4f33'%3E%3Cpolygon points='7,1 9,5 13,5.5 10,8.5 11,13 7,11 3,13 4,8.5 1,5.5 5,5'/%3E%3Cpolygon points='24,1 26,5 30,5.5 27,8.5 28,13 24,11 20,13 21,8.5 18,5.5 22,5'/%3E%3Cpolygon points='41,1 43,5 47,5.5 44,8.5 45,13 41,11 37,13 38,8.5 35,5.5 39,5'/%3E%3Cpolygon points='58,1 60,5 64,5.5 61,8.5 62,13 58,11 54,13 55,8.5 52,5.5 56,5'/%3E%3Cpolygon points='75,1 77,5 81,5.5 78,8.5 79,13 75,11 71,13 72,8.5 69,5.5 73,5'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat: no-repeat;
  overflow: hidden;
}
.card-rating-num {
  font-variant-numeric: tabular-nums;
}

/* New empty state */
body.catalog-page .empty-state {
  padding: var(--space-7) var(--space-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
}
.empty-state-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--c-primary-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3Cline x1='8' y1='11' x2='14' y2='11'/%3E%3C/svg%3E") center / 32px no-repeat;
  margin-bottom: 0.5rem;
}
body.catalog-page .empty-state h3 {
  margin: 0;
  font-size: 1.1rem;
}
body.catalog-page .empty-state p {
  margin: 0;
  max-width: 44ch;
}
body.catalog-page .empty-state .btn-secondary {
  margin-top: var(--space-2);
}

/* ===========================================
   PASS 20 ? Cookies, newsletter, view toggle, wishlist, polish
   =========================================== */

/* ----- Skip link (a11y) ----- */
.skip-link {
  position: absolute;
  top: -40px;
  left: 12px;
  background: var(--c-primary);
  color: #fff;
  padding: 0.5rem 0.9rem;
  border-radius: var(--radius-md);
  z-index: 1200;
  font-weight: 700;
  transition: top 0.2s ease;
}
.skip-link:focus {
  top: 12px;
  outline: 2px solid #fff;
  outline-offset: 2px;
}

/* ----- Top loading bar ----- */
.loading-bar {
  position: fixed;
  top: 4px;
  left: 0;
  height: 2px;
  width: 0;
  background: linear-gradient(90deg, var(--c-primary), var(--c-primary-strong));
  box-shadow: 0 0 12px color-mix(in srgb, var(--c-primary) 60%, transparent);
  z-index: 1100;
  pointer-events: none;
  opacity: 0;
  transition: width 0.4s ease, opacity 0.25s ease;
}
.loading-bar.is-active { opacity: 1; }

/* ----- Wishlist button (header) ----- */
.wishlist-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: var(--radius-pill);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  color: var(--c-text);
  text-decoration: none;
  transition: all 0.2s ease;
}
.wishlist-link:hover {
  border-color: var(--c-primary);
  color: var(--c-primary);
  transform: translateY(-1px);
}
.wishlist-icon {
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.wishlist-count {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: 9px;
  background: var(--c-primary);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--c-surface);
  letter-spacing: 0;
  line-height: 1;
  transition: transform 0.18s ease;
}
.wishlist-count.is-empty {
  opacity: 0.45;
  transform: scale(0.85);
}
.mobile-drawer-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  border-radius: 11px;
  background: var(--c-primary);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 800;
}
.mobile-drawer-count.is-empty {
  opacity: 0.4;
}

/* ----- View toggle (grid/list) ----- */
.catalog-stats-actions {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.view-toggle {
  display: inline-flex;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
  padding: 3px;
  gap: 2px;
}
.view-toggle button {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--c-text-soft);
  width: 34px;
  height: 30px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.18s ease;
}
.view-toggle button:hover { color: var(--c-text); }
.view-toggle button.is-active {
  background: var(--c-surface);
  color: var(--c-primary);
  box-shadow: var(--shadow-sm);
}
.view-icon {
  width: 16px;
  height: 16px;
  display: inline-block;
}
.view-icon-grid {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7' rx='1'/%3E%3Crect x='14' y='3' width='7' height='7' rx='1'/%3E%3Crect x='3' y='14' width='7' height='7' rx='1'/%3E%3Crect x='14' y='14' width='7' height='7' rx='1'/%3E%3C/svg%3E") center / contain no-repeat;
}
.view-icon-list {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='8' y1='6' x2='21' y2='6'/%3E%3Cline x1='8' y1='12' x2='21' y2='12'/%3E%3Cline x1='8' y1='18' x2='21' y2='18'/%3E%3Ccircle cx='4' cy='6' r='1.4'/%3E%3Ccircle cx='4' cy='12' r='1.4'/%3E%3Ccircle cx='4' cy='18' r='1.4'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* List view layout */
body.catalog-page #productGrid.is-list-view {
  grid-template-columns: 1fr !important;
}
body.catalog-page #productGrid.is-list-view .card {
  display: grid !important;
  grid-template-columns: 280px 1fr auto;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-3);
}
body.catalog-page #productGrid.is-list-view .card-media {
  height: 180px;
  margin: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
}
body.catalog-page #productGrid.is-list-view .card-description {
  -webkit-line-clamp: 3;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
body.catalog-page #productGrid.is-list-view .card-cta {
  align-self: end;
  white-space: nowrap;
}
@media (max-width: 800px) {
  body.catalog-page #productGrid.is-list-view .card {
    grid-template-columns: 1fr;
  }
  body.catalog-page #productGrid.is-list-view .card-media {
    height: 200px;
  }
}

/* ----- Quick view button on card ----- */
.card-quickview {
  position: absolute;
  inset: auto 12px 12px 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0.5rem 0.9rem;
  background: rgba(0,0,0,0.78);
  color: #fff;
  border: 0;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.22s ease, transform 0.22s ease, background 0.18s ease;
  backdrop-filter: blur(4px);
  z-index: 3;
}
.card-quickview::before {
  content: "";
  width: 14px;
  height: 14px;
  background: 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='%23ffffff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E") center / contain no-repeat;
}
.card-quickview-text { line-height: 1; }
.card-media { position: relative; }
.card:hover .card-quickview {
  opacity: 1;
  transform: translateY(0);
}
.card-quickview:hover {
  background: var(--c-primary-strong);
}
@media (hover: none) {
  .card-quickview { display: none; }
}

/* ----- Newsletter band ----- */
.newsletter-band {
  margin: 0;
  padding: clamp(2.5rem, 6vw, 4rem) 0;
  background:
    radial-gradient(60% 80% at 80% 0%, color-mix(in srgb, var(--c-primary) 22%, transparent), transparent 60%),
    radial-gradient(40% 60% at 0% 100%, color-mix(in srgb, var(--c-primary-strong) 22%, transparent), transparent 60%),
    #0c1226;
  color: #f5f7ff;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.newsletter-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
}
.newsletter-eyebrow {
  margin: 0 0 0.4rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--c-primary) 80%, #fff);
}
.newsletter-copy h2 {
  margin: 0 0 0.5rem;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.2;
  color: #fff;
  letter-spacing: -0.01em;
}
.newsletter-copy p {
  margin: 0;
  color: rgba(245,247,255,0.7);
  max-width: 50ch;
}
.newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.7rem;
  align-items: center;
}
.newsletter-input-wrap {
  position: relative;
}
.newsletter-input-wrap input {
  width: 100%;
  height: 54px;
  padding: 0 1rem 0 3rem;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06);
  color: #fff;
  border-radius: var(--radius-pill);
  font-size: 0.95rem;
  outline: none;
  transition: border 0.2s ease, background 0.2s ease;
}
.newsletter-input-wrap::before {
  content: "";
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' opacity='0.7'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1 .9-2 2-2z'/%3E%3Cpolyline points='22 6 12 13 2 6'/%3E%3C/svg%3E") center / contain no-repeat;
}
.newsletter-input-wrap input::placeholder {
  color: rgba(245,247,255,0.5);
}
.newsletter-input-wrap input:focus {
  border-color: var(--c-primary);
  background: rgba(255,255,255,0.1);
}
.newsletter-form .btn-primary {
  height: 54px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  position: relative;
}
.newsletter-form .btn-primary.is-loading .newsletter-btn-text { visibility: hidden; }
.newsletter-btn-spin {
  display: none;
  position: absolute;
  inset: 0;
  margin: auto;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
.newsletter-form .btn-primary.is-loading .newsletter-btn-spin { display: block; }
@keyframes spin { to { transform: rotate(360deg); } }
.newsletter-status {
  grid-column: 1 / -1;
  margin: 0;
  font-size: 0.85rem;
  color: rgba(245,247,255,0.85);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.newsletter-status.is-shown {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 800px) {
  .newsletter-grid { grid-template-columns: 1fr; }
  .newsletter-form { grid-template-columns: 1fr; }
}

/* ----- Cookies banner ----- */
.cookies-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  padding: 0;
  z-index: 1050;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.32s ease, transform 0.32s ease;
}
.cookies-banner.is-shown {
  opacity: 1;
  transform: translateY(0);
}
.cookies-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-3);
  align-items: center;
  padding: 1rem 1.4rem;
}
.cookies-copy strong {
  display: block;
  font-size: 1rem;
  margin-bottom: 0.2rem;
}
.cookies-copy p {
  margin: 0;
  font-size: 0.88rem;
  color: var(--c-text-soft);
  max-width: 70ch;
}
.cookies-actions {
  display: inline-flex;
  gap: 0.5rem;
}
.cookies-actions .btn-secondary,
.cookies-actions .btn-primary {
  padding: 0.55rem 1.1rem;
  font-size: 0.88rem;
}
@media (max-width: 700px) {
  .cookies-grid { grid-template-columns: 1fr; }
  .cookies-actions { justify-content: flex-end; }
}

/* ----- Dialog enhancements (Pass 20) ----- */
body.catalog-page .product-dialog {
  padding: 0;
  border: 0;
  border-radius: var(--radius-lg);
  max-width: min(720px, 92vw);
  width: 100%;
  overflow: hidden;
  background: var(--c-surface);
  box-shadow: var(--shadow-xl);
}
body.catalog-page .product-dialog #dialogContent {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
body.catalog-page .product-dialog .dialog-image {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  display: block;
}
body.catalog-page .product-dialog .dialog-image-ph {
  background: linear-gradient(135deg, var(--c-surface-2), var(--c-surface));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-text-soft);
}
body.catalog-page .product-dialog .dialog-image-ph::after {
  content: "Bazaar Slovenija";
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-size: 0.85rem;
  color: var(--c-text-soft);
}
body.catalog-page .product-dialog .dialog-body {
  padding: clamp(1.4rem, 2.5vw, 2rem);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.dialog-category {
  display: inline-block;
  align-self: flex-start;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-primary);
  background: var(--c-primary-soft);
  padding: 0.25rem 0.7rem;
  border-radius: var(--radius-pill);
}
body.catalog-page .product-dialog h2 {
  margin: 0;
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  line-height: 1.25;
  letter-spacing: -0.01em;
}
.dialog-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.2rem;
}
.dialog-id {
  font-size: 0.78rem;
  color: var(--c-text-soft);
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  letter-spacing: 0.04em;
}
.dialog-price {
  font-size: clamp(1.6rem, 3vw, 2.1rem);
  font-weight: 900;
  background: linear-gradient(180deg, var(--c-primary), var(--c-primary-strong));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin: 0.2rem 0 0.4rem;
  letter-spacing: -0.01em;
  animation: dialog-price-pop 0.55s cubic-bezier(0.2, 0.8, 0.2, 1.05);
}
@keyframes dialog-price-pop {
  from { opacity: 0; transform: translateY(8px) scale(0.96); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.dialog-description {
  margin: 0;
  color: var(--c-text-soft);
  line-height: 1.55;
  max-height: 9rem;
  overflow: auto;
  padding-right: 4px;
}
.dialog-description::-webkit-scrollbar { width: 6px; }
.dialog-description::-webkit-scrollbar-thumb { background: var(--c-border); border-radius: 3px; }
.dialog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.6rem;
  align-items: center;
}
.dialog-actions .btn-primary { flex: 1 1 200px; }
.dialog-actions .dialog-wish.is-active {
  background: var(--c-primary-soft);
  color: var(--c-primary);
  border-color: var(--c-primary);
}
.dialog-share {
  width: 44px;
  height: 44px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.dialog-share span {
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='18' cy='5' r='3'/%3E%3Ccircle cx='6' cy='12' r='3'/%3E%3Ccircle cx='18' cy='19' r='3'/%3E%3Cline x1='8.59' y1='13.51' x2='15.42' y2='17.49'/%3E%3Cline x1='15.41' y1='6.51' x2='8.59' y2='10.49'/%3E%3C/svg%3E") center / contain no-repeat;
}
.product-dialog-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: 50%;
  background: rgba(0,0,0,0.55) !important;
  color: #fff !important;
  border: 0 !important;
  font-size: 0;
  z-index: 10;
}
.product-dialog-close::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  background: 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='%23ffffff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E") center / contain no-repeat;
}
.product-dialog-close:hover {
  background: var(--c-primary) !important;
}

@media (max-width: 720px) {
  body.catalog-page .product-dialog #dialogContent {
    grid-template-columns: 1fr;
  }
  body.catalog-page .product-dialog .dialog-image {
    min-height: 220px;
    max-height: 260px;
  }
}

/* ----- Card extra polish ----- */
.card .card-image {
  transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.card:hover .card-image {
  transform: scale(1.06);
}
.card .card-media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.18));
  opacity: 0;
  transition: opacity 0.3s ease;
}
.card:hover .card-media::after { opacity: 1; }

/* ----- Header focus ring polish ----- */
.site-header *:focus-visible,
.btn-primary:focus-visible,
.btn-secondary:focus-visible,
.wishlist-link:focus-visible {
  outline: 2px solid var(--c-primary);
  outline-offset: 3px;
  border-radius: var(--radius-md);
}

/* ----- Subtle texture bg under hero ----- */
body.home-page main.home-main::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background-image:
    radial-gradient(1px 1px at 10% 20%, color-mix(in srgb, var(--c-primary) 18%, transparent), transparent 50%),
    radial-gradient(1px 1px at 80% 60%, color-mix(in srgb, var(--c-primary-strong) 14%, transparent), transparent 50%),
    radial-gradient(1px 1px at 30% 90%, color-mix(in srgb, var(--c-primary) 10%, transparent), transparent 50%);
  background-size: 600px 600px, 800px 800px, 700px 700px;
  opacity: 0.6;
}

/* ----- Section dividers ----- */
.hp-section + .hp-section::before {
  content: "";
  display: block;
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--c-border), transparent);
  margin: 0 auto var(--space-5);
  border-radius: 2px;
}

/* ----- 404 page ----- */
body.error-page {
  background:
    radial-gradient(60% 50% at 50% 0%, color-mix(in srgb, var(--c-primary) 12%, transparent), transparent 60%),
    var(--c-bg);
  min-height: 100vh;
}
.error-main {
  padding: clamp(3rem, 8vw, 6rem) 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.error-shell {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
  padding: clamp(2rem, 4vw, 3rem);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
}
.error-eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-primary);
  background: var(--c-primary-soft);
  padding: 0.35rem 0.9rem;
  border-radius: var(--radius-pill);
}
.error-title {
  margin: var(--space-3) 0 var(--space-3);
  font-size: clamp(2rem, 5vw, 3rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
}
.error-lead {
  margin: 0 auto var(--space-5);
  color: var(--c-text-soft);
  max-width: 50ch;
  line-height: 1.6;
}
.error-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  justify-content: center;
}
.error-suggest {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px dashed var(--c-border);
}
.error-suggest-title {
  margin: 0 0 0.6rem;
  font-size: 0.85rem;
  color: var(--c-text-soft);
}
.error-suggest ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  justify-content: center;
}
.error-suggest a {
  display: inline-block;
  padding: 0.4rem 0.9rem;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
  color: var(--c-text);
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 600;
  transition: all 0.18s ease;
}
.error-suggest a:hover {
  border-color: var(--c-primary);
  color: var(--c-primary);
  background: var(--c-primary-soft);
}

/* ----- Header is-scrolled gets a subtle blur layer ----- */
.site-header.site-header-main.is-scrolled {
  background: color-mix(in srgb, var(--c-surface) 88%, transparent);
  backdrop-filter: saturate(140%) blur(10px);
}

/* ----- Header search subtle glow on focus ----- */
.header-search-input:focus {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 22%, transparent) !important;
}

/* ----- Mobile-only newsletter spacing ----- */
@media (max-width: 720px) {
  .cookies-banner { left: 8px; right: 8px; bottom: 8px; }
}

/* ===========================================
   PASS 21 ? Product page, price range, stock, wishlist mode
   =========================================== */

/* ----- Active filter chips ----- */
.active-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  align-items: center;
  margin: 0 0 var(--space-3);
}
.active-filter-chip,
.active-filter-clear {
  appearance: none;
  border: 1px solid var(--c-border);
  background: var(--c-surface);
  color: var(--c-text);
  border-radius: var(--radius-pill);
  padding: 0.35rem 0.85rem;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  transition: all 0.18s ease;
}
.active-filter-chip span {
  font-weight: 800;
  color: var(--c-text-soft);
  font-size: 0.95rem;
  line-height: 1;
}
.active-filter-chip:hover {
  border-color: var(--c-primary);
  color: var(--c-primary);
}
.active-filter-clear {
  background: var(--c-primary-soft);
  color: var(--c-primary);
  border-color: color-mix(in srgb, var(--c-primary) 35%, transparent);
}
.active-filter-clear:hover {
  background: var(--c-primary);
  color: #fff;
}

/* ----- Toolbar price range ----- */
.toolbar-price {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.25rem 0.4rem;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
  flex-shrink: 0;
}
.toolbar-price-input {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0 0.5rem;
  font-size: 0.82rem;
  color: var(--c-text-soft);
}
.toolbar-price-input input {
  width: 64px;
  padding: 0.4rem 0;
  background: transparent !important;
  border: 0 !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  color: var(--c-text) !important;
  outline: none !important;
  text-align: right;
  -moz-appearance: textfield;
}
.toolbar-price-input input::-webkit-outer-spin-button,
.toolbar-price-input input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.toolbar-price-prefix {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-text-soft);
}
.toolbar-price-suffix {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--c-text-soft);
}
.toolbar-price-dash {
  color: var(--c-text-soft);
  font-weight: 700;
}

/* ----- Stock pills ----- */
.product-stock {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.25rem 0.65rem;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  white-space: nowrap;
}
.product-stock-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
}
.product-stock-in {
  color: var(--c-success);
  background: color-mix(in srgb, var(--c-success) 12%, transparent);
  border-color: color-mix(in srgb, var(--c-success) 30%, transparent);
}
.product-stock-in .product-stock-dot {
  background: var(--c-success);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-success) 22%, transparent);
}
.product-stock-low {
  color: #b97a05;
  background: color-mix(in srgb, #f1b75a 24%, transparent);
  border-color: color-mix(in srgb, #f1b75a 50%, transparent);
}
.product-stock-low .product-stock-dot { background: #e6a23c; }
.product-stock-order {
  color: var(--c-text-soft);
  background: var(--c-surface-2);
  border-color: var(--c-border);
}
.product-stock-order .product-stock-dot { background: var(--c-text-soft); }

/* ----- Card body wrapper (Pass 21 layout) ----- */
body.catalog-page .card .card-body {
  padding: 1rem 1rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
body.catalog-page .card .card-meta-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: space-between;
}
/* in list view, body keeps padding tight */
body.catalog-page #productGrid.is-list-view .card-body {
  padding: 0;
}
body.catalog-page #productGrid.is-list-view .card {
  padding: 1rem;
}

/* place wish above quickview */
.card-wish { z-index: 4; }
.card-quickview { z-index: 3; }

/* ----- Wishlist-only banner ----- */
.wishlist-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin: 0 0 var(--space-4);
  padding: 1rem 1.2rem;
  background:
    radial-gradient(60% 80% at 100% 0%, color-mix(in srgb, var(--c-primary) 18%, transparent), transparent 60%),
    var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.wishlist-banner-copy {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}
.wishlist-banner-copy strong { font-size: 1.05rem; display: block; }
.wishlist-banner-copy p { margin: 0.2rem 0 0; color: var(--c-text-soft); font-size: 0.9rem; }
.wishlist-banner-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--c-primary-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E") center / 22px no-repeat;
  flex-shrink: 0;
}
@media (max-width: 700px) {
  .wishlist-banner { flex-direction: column; align-items: flex-start; }
}

body.wishlist-mode .toolbar-wrap,
body.wishlist-mode .active-filters {
  opacity: 0.6;
  pointer-events: none;
  filter: saturate(0.85);
}

/* ----- Product page ----- */
body.product-page main.product-main {
  padding-top: var(--space-4);
  padding-bottom: var(--space-7);
}
.product-crumb {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.85rem;
  color: var(--c-text-soft);
  margin-bottom: var(--space-4);
}
.product-crumb a {
  color: var(--c-text-soft);
  text-decoration: none;
  font-weight: 600;
}
.product-crumb a:hover { color: var(--c-primary); }
.product-crumb-sep { color: var(--c-border); }
.product-crumb-current {
  color: var(--c-text);
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 60ch;
}

.product-shell {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  box-shadow: var(--shadow-sm);
}
@media (max-width: 880px) {
  .product-shell { grid-template-columns: 1fr; }
}

/* gallery */
.product-gallery {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}
.product-gallery-frame {
  position: relative;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 1 / 1;
  cursor: zoom-in;
}
.product-gallery-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: clamp(1rem, 3vw, 2rem);
  display: block;
  transition: opacity 0.3s ease;
}
.product-gallery-frame.is-zooming .product-gallery-image {
  opacity: 0;
}
.product-gallery-zoom {
  position: absolute;
  inset: 0;
  background-repeat: no-repeat;
  background-size: 220%;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.product-gallery-frame.is-zooming .product-gallery-zoom {
  opacity: 1;
}
.product-gallery-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-text-soft);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.product-gallery-caption {
  font-size: 0.78rem;
  color: var(--c-text-soft);
  text-align: center;
  letter-spacing: 0.04em;
}
@media (hover: none) {
  .product-gallery-frame { cursor: default; }
  .product-gallery-caption { display: none; }
}

/* product info */
.product-info {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  align-self: stretch;
}
.product-badges-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  align-items: center;
}
.product-cat-pill {
  display: inline-flex;
  align-items: center;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-primary);
  background: var(--c-primary-soft);
  padding: 0.3rem 0.8rem;
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition: all 0.18s ease;
}
.product-cat-pill:hover {
  background: var(--c-primary);
  color: #fff;
}
.product-id-pill {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--c-text-soft);
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  letter-spacing: 0.04em;
  padding: 0.3rem 0.7rem;
  border-radius: var(--radius-pill);
  border: 1px dashed var(--c-border);
}

.product-title {
  margin: 0.2rem 0 0;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.product-meta-row {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  color: var(--c-text-soft);
  font-size: 0.88rem;
}
.product-meta-sep { color: var(--c-border); }
.product-meta-link { font-weight: 600; }

.product-price-block {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.85rem 1rem;
  background: linear-gradient(135deg, color-mix(in srgb, var(--c-primary) 8%, transparent), var(--c-surface-2));
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
}
.product-price {
  font-size: clamp(1.8rem, 3.4vw, 2.4rem);
  font-weight: 900;
  background: linear-gradient(180deg, var(--c-primary), var(--c-primary-strong));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
  letter-spacing: -0.02em;
}
.product-price-leanpay {
  font-size: 0.82rem;
  color: var(--c-text-soft);
}
.product-price-leanpay strong { color: var(--c-text); font-weight: 800; }

.product-description {
  margin: 0;
  color: var(--c-text-soft);
  line-height: 1.65;
  font-size: 0.95rem;
  white-space: pre-line;
}

.product-key-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.4rem 1rem;
}
.product-key-list li {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.88rem;
  color: var(--c-text);
}
.product-key-icon {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--c-primary-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center / 12px no-repeat;
  flex-shrink: 0;
}
@media (max-width: 600px) {
  .product-key-list { grid-template-columns: 1fr; }
}

.product-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-top: 0.3rem;
}
.product-cta-inquiry {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1 1 240px;
  text-decoration: none;
  justify-content: center;
}
.product-cta-icon {
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 2L11 13'/%3E%3Cpath d='M22 2L15 22 11 13 2 9 22 2z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.product-cta-wish {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}
.product-wish-icon {
  width: 14px;
  height: 14px;
  background: 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='currentColor' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.product-cta-wish.is-active {
  color: var(--c-primary) !important;
  border-color: var(--c-primary) !important;
  background: var(--c-primary-soft) !important;
}
.product-cta-wish.is-active .product-wish-icon {
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='%23ff4f33' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.product-cta-share {
  width: 44px;
  height: 44px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.product-cta-share span {
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='18' cy='5' r='3'/%3E%3Ccircle cx='6' cy='12' r='3'/%3E%3Ccircle cx='18' cy='19' r='3'/%3E%3Cline x1='8.59' y1='13.51' x2='15.42' y2='17.49'/%3E%3Cline x1='15.41' y1='6.51' x2='8.59' y2='10.49'/%3E%3C/svg%3E") center / contain no-repeat;
}

.product-spec-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem 1rem;
  margin: 0;
  padding: 0.85rem 0;
  border-top: 1px solid var(--c-border);
}
.product-spec {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.product-spec dt {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-text-soft);
}
.product-spec dd {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--c-text);
}
@media (max-width: 480px) {
  .product-spec-grid { grid-template-columns: 1fr; }
}

.product-trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem 1.4rem;
  padding-top: 0.6rem;
  border-top: 1px solid var(--c-border);
  font-size: 0.82rem;
  color: var(--c-text-soft);
}
.product-trust { display: inline-flex; align-items: center; gap: 0.4rem; }
.product-trust-ico {
  width: 18px;
  height: 18px;
  display: inline-block;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.product-trust-ico[data-ico="ship"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='1' y='3' width='15' height='13' rx='1'/%3E%3Cpolygon points='16 8 20 8 23 11 23 16 16 16 16 8'/%3E%3Ccircle cx='5.5' cy='18.5' r='2.5'/%3E%3Ccircle cx='18.5' cy='18.5' r='2.5'/%3E%3C/svg%3E");
}
.product-trust-ico[data-ico="back"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1 4 1 10 7 10'/%3E%3Cpath d='M3.51 15a9 9 0 1 0 2.13-9.36L1 10'/%3E%3C/svg%3E");
}
.product-trust-ico[data-ico="lock"] {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");
}

/* product page skeleton */
.product-skeleton {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
}
.skeleton-product-img {
  width: 100%;
  aspect-ratio: 1;
  border-radius: var(--radius-md);
}
.product-skeleton-body { display: flex; flex-direction: column; gap: 0.6rem; }
@media (max-width: 880px) {
  .product-skeleton { grid-template-columns: 1fr; }
}

/* product page error */
.product-error {
  text-align: center;
  padding: clamp(2rem, 6vw, 3.5rem) 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
}
.product-error h2 { margin: 0; font-size: 1.4rem; }
.product-error p { margin: 0; color: var(--c-text-soft); }

/* related */
.product-related {
  margin-top: clamp(2rem, 4vw, 3rem);
}
.product-related-head { margin-bottom: var(--space-4); }
.product-related-head h2 { margin: 0; font-size: clamp(1.2rem, 2vw, 1.5rem); }
.product-related-grid {
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
}

body.product-page main.product-main { padding-bottom: var(--space-7); }

/* ===========================================
   PASS 22 ? Sitemap, print, parsed specs polish
   =========================================== */

/* Sitemap page */
body.sitemap-page main.sitemap-main {
  padding-block: var(--space-6);
  display: grid;
  gap: var(--space-5);
}
.sitemap-hero {
  text-align: center;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: clamp(2rem, 5vw, 3rem);
  box-shadow: var(--shadow-sm);
}
.sitemap-hero h1 {
  margin: 0.4rem 0 0.6rem;
  font-size: clamp(1.6rem, 3.4vw, 2.4rem);
  letter-spacing: -0.02em;
}
.sitemap-hero p {
  margin: 0 auto;
  color: var(--c-text-soft);
  max-width: 60ch;
}
.sitemap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
}
.sitemap-col {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 1.2rem 1.3rem;
  box-shadow: var(--shadow-sm);
  transition: transform 0.18s ease, border-color 0.18s ease;
}
.sitemap-col:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--c-primary) 32%, var(--c-border));
}
.sitemap-col h2 {
  margin: 0 0 0.85rem;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-primary);
}
.sitemap-col ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.sitemap-col a {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.6rem;
  border-radius: var(--radius-md);
  color: var(--c-text);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.92rem;
  transition: all 0.18s ease;
}
.sitemap-col a:hover {
  background: var(--c-primary-soft);
  color: var(--c-primary);
}
.sitemap-col a::before {
  content: "\203A";
  color: var(--c-primary);
  font-weight: 800;
}

/* Print button on product page */
.product-cta-print {
  width: 44px;
  height: 44px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.product-cta-print span {
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 6 2 18 2 18 9'/%3E%3Cpath d='M6 18H4a2 2 0 0 1-2-2v-5a2 2 0 0 1 2-2h16a2 2 0 0 1 2 2v5a2 2 0 0 1-2 2h-2'/%3E%3Crect x='6' y='14' width='12' height='8'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* Print styles ? clean, paper friendly */
@media print {
  .site-header,
  .leanpay-strip,
  .scroll-progress,
  .loading-bar,
  .skip-link,
  .mobile-drawer,
  .mobile-drawer-overlay,
  .cookies-banner,
  .newsletter-band,
  .product-related,
  .back-to-top,
  .toolbar-wrap,
  .active-filters,
  .catalog-stats-row,
  .product-actions,
  .card-quickview,
  .card-wish,
  footer.site-footer,
  .product-trust-row,
  .product-key-list {
    display: none !important;
  }
  body {
    background: #fff !important;
    color: #000 !important;
  }
  .product-shell {
    border: 0 !important;
    box-shadow: none !important;
    grid-template-columns: 1fr !important;
    padding: 0 !important;
  }
  .product-gallery-frame {
    aspect-ratio: 16 / 9;
    border: 1px solid #ddd !important;
    page-break-inside: avoid;
  }
  .product-title {
    font-size: 22pt !important;
  }
  .product-price {
    color: #000 !important;
    -webkit-text-fill-color: #000 !important;
    background: none !important;
  }
  .product-price-block {
    background: #f6f6f6 !important;
    border: 1px solid #ddd !important;
  }
  .product-spec-grid {
    page-break-inside: avoid;
  }
  a {
    color: #000 !important;
    text-decoration: none !important;
  }
}

/* ===========================================
   PASS 23 ? Remove wishlist UI, hide live-filter pill, add Reserve flow
   =========================================== */

/* Hide leftover wishlist artifacts (defensive) */
.wishlist-link,
.wishlist-banner,
.mobile-drawer .mobile-drawer-link .mobile-drawer-count,
.card-wish,
.dialog-wish,
.product-cta-wish {
  display: none !important;
}

/* Hide live-filters pill (defensive) */
.catalog-live-pill { display: none !important; }

/* ----- Card action row (CTA + Reserve) ----- */
body.catalog-page .product-grid .card .card-body .card-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: auto;
  padding-top: 0.4rem;
  flex-wrap: wrap;
}
body.catalog-page .product-grid .card .card-body .card-actions .card-cta {
  margin-top: 0;
  align-self: stretch;
  flex: 0 0 auto;
}
.card-reserve {
  appearance: none;
  border: 1px solid var(--c-primary);
  background: var(--c-primary);
  color: #fff;
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  padding: 0.55rem 1rem;
  border-radius: var(--radius-pill);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex: 1 1 auto;
  justify-content: center;
  transition: all 0.18s ease;
  box-shadow: 0 6px 14px -8px color-mix(in srgb, var(--c-primary) 60%, transparent);
}
.card-reserve:hover {
  background: var(--c-primary-strong);
  border-color: var(--c-primary-strong);
  transform: translateY(-1px);
}
.card-reserve-icon {
  width: 14px;
  height: 14px;
  background: 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='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* In list view stretch buttons in row */
body.catalog-page #productGrid.is-list-view .card-actions {
  justify-content: flex-end;
}

/* ----- Reserve dialog ----- */
.reserve-dialog {
  padding: 0;
  border: 0;
  border-radius: var(--radius-lg);
  max-width: min(560px, 96vw);
  width: 100%;
  background: var(--c-surface);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}
.reserve-dialog::backdrop {
  background: rgba(11, 14, 31, 0.55);
  backdrop-filter: blur(4px);
}
.reserve-dialog-head {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.2rem 1.4rem 1rem;
  border-bottom: 1px solid var(--c-border);
}
.reserve-dialog-head > div { flex: 1; }
.reserve-dialog-head h2 {
  margin: 0.15rem 0 0.4rem;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
}
.reserve-eyebrow {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-primary);
}
.reserve-subtle {
  margin: 0;
  color: var(--c-text-soft);
  font-size: 0.85rem;
  line-height: 1.5;
}
.reserve-dialog-head .product-dialog-close {
  position: static;
  width: 36px;
  height: 36px;
  flex-shrink: 0;
}

.reserve-form {
  padding: 1.2rem 1.4rem 1.4rem;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}
.reserve-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
}
.reserve-form label {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.reserve-form label > span {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--c-text-soft);
}
.reserve-form label > span em {
  color: var(--c-primary);
  font-style: normal;
  font-weight: 800;
}
.reserve-form input,
.reserve-form textarea {
  width: 100%;
  padding: 0.65rem 0.85rem;
  border: 1px solid var(--c-border);
  background: var(--c-surface-2);
  color: var(--c-text);
  border-radius: var(--radius-md);
  font-size: 0.92rem;
  font-family: inherit;
  outline: none;
  transition: border 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}
.reserve-form textarea {
  resize: vertical;
  min-height: 84px;
  line-height: 1.5;
}
.reserve-form input:focus,
.reserve-form textarea:focus {
  border-color: var(--c-primary);
  background: var(--c-surface);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 18%, transparent);
}
.reserve-hint {
  margin: 0.3rem 0 0;
  font-size: 0.78rem;
  color: var(--c-text-soft);
  line-height: 1.55;
  padding: 0.6rem 0.8rem;
  background: color-mix(in srgb, var(--c-primary) 5%, var(--c-surface-2));
  border: 1px dashed color-mix(in srgb, var(--c-primary) 30%, var(--c-border));
  border-radius: var(--radius-md);
}
.reserve-hint a { color: var(--c-primary); font-weight: 700; }
.reserve-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 0.4rem;
}
@media (max-width: 540px) {
  .reserve-form-row { grid-template-columns: 1fr; }
  .reserve-actions { flex-direction: column-reverse; }
  .reserve-actions .btn-primary,
  .reserve-actions .btn-secondary { width: 100%; }
}

/* Reserve icon in product page primary CTA */
.product-cta-icon-reserve {
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* Quick-view dialog reserve replaces previous wishlist secondary */
.dialog-reserve {
  background: var(--c-primary-soft) !important;
  color: var(--c-primary) !important;
  border-color: color-mix(in srgb, var(--c-primary) 35%, transparent) !important;
  font-weight: 800;
}
.dialog-reserve:hover {
  background: var(--c-primary) !important;
  color: #fff !important;
}

/* ===========================================
   PASS 24 ? Button visibility (force overrides) + design polish
   =========================================== */

/* ----- 1. Force CARD action buttons (defeat clean-theme.css !important) ----- */
body.catalog-page .product-grid .card .card-body .card-actions {
  display: flex !important;
  gap: 0.5rem;
  align-items: stretch;
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: 0.5rem;
}

/* Podrobnosti ? clear secondary pill */
body.catalog-page .product-grid .card .card-body .card-actions .card-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.45rem !important;
  padding: 0.6rem 1rem !important;
  background: #fff !important;
  color: var(--c-text) !important;
  border: 1.5px solid var(--c-border-strong) !important;
  border-radius: var(--radius-pill) !important;
  font-weight: 700 !important;
  font-size: 0.86rem !important;
  text-decoration: none !important;
  letter-spacing: 0.02em !important;
  transition: all 0.18s ease !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
  min-height: 40px !important;
  flex: 0 1 auto !important;
}
body.catalog-page .product-grid .card .card-body .card-actions .card-cta::after {
  content: "" !important;
  width: 1em !important;
  height: 1em !important;
  flex-shrink: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") center / contain no-repeat;
  transition: transform 0.18s ease;
  border: 0 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}
body.catalog-page .product-grid .card .card-body .card-actions .card-cta:hover {
  background: var(--c-text) !important;
  color: #fff !important;
  border-color: var(--c-text) !important;
  transform: translateY(-1px);
}
body.catalog-page .product-grid .card .card-body .card-actions .card-cta:hover::after {
  transform: translateX(3px);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E");
}

/* Rezerviraj ? saturated primary, ALWAYS visible */
body.catalog-page .product-grid .card .card-body .card-actions .card-reserve,
body.catalog-page .card-reserve,
.card-reserve {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  padding: 0.6rem 1.05rem !important;
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%) !important;
  color: #fff !important;
  border: 1.5px solid var(--c-primary-strong) !important;
  border-radius: var(--radius-pill) !important;
  font-weight: 800 !important;
  font-size: 0.86rem !important;
  letter-spacing: 0.02em !important;
  cursor: pointer !important;
  transition: all 0.18s ease !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.18) !important;
  box-shadow:
    0 6px 16px -6px color-mix(in srgb, var(--c-primary-strong) 70%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
  min-height: 40px !important;
  flex: 1 1 auto !important;
  text-transform: none !important;
}
body.catalog-page .product-grid .card .card-body .card-actions .card-reserve::after,
body.catalog-page .card-reserve::after,
.card-reserve::after {
  content: "\2192" !important;
  font-weight: 800;
  font-size: 0.95rem;
  display: inline-block;
  transition: transform 0.18s ease;
}
.card-reserve:hover,
body.catalog-page .product-grid .card .card-body .card-actions .card-reserve:hover {
  background: linear-gradient(180deg, #ff6041 0%, #e63d20 100%) !important;
  border-color: #d8351a !important;
  transform: translateY(-1px);
  box-shadow:
    0 10px 22px -8px color-mix(in srgb, var(--c-primary-strong) 80%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22) !important;
}
.card-reserve:hover::after { transform: translateX(3px); }

.card-reserve-icon {
  width: 14px !important;
  height: 14px !important;
  background: 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='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") center / contain no-repeat !important;
}

/* Defuse old "card hover -> orange button" rule that fights us */
body.catalog-page .product-grid .card:hover .card-actions .card-cta {
  background: var(--c-text) !important;
  color: #fff !important;
}
body.catalog-page .product-grid .card:hover .card-actions .card-reserve {
  background: linear-gradient(180deg, #ff6041 0%, #e63d20 100%) !important;
}

/* In list view: actions row right-aligned, both buttons keep size */
body.catalog-page #productGrid.is-list-view .card-actions {
  justify-content: flex-end !important;
}
body.catalog-page #productGrid.is-list-view .card-actions .card-cta,
body.catalog-page #productGrid.is-list-view .card-actions .card-reserve {
  flex: 0 0 auto !important;
}

/* ----- 2. Quick view button ? punchy ----- */
.card-quickview {
  background: rgba(15, 18, 35, 0.88) !important;
  color: #fff !important;
  font-weight: 800 !important;
  letter-spacing: 0.06em !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
}
.card-quickview:hover {
  background: var(--c-primary) !important;
  border-color: var(--c-primary) !important;
}

/* ----- 3. Global btn-primary ? make it impossible to miss ----- */
body.home-page .btn-primary,
body.catalog-page .btn-primary,
body.about-page .btn-primary,
body.contact-page .btn-primary,
body.product-page .btn-primary,
body.sitemap-page .btn-primary,
body.error-page .btn-primary {
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%) !important;
  color: #fff !important;
  border: 1.5px solid var(--c-primary-strong) !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em !important;
  padding: 0.7rem 1.25rem !important;
  min-height: 44px !important;
  border-radius: var(--radius-pill) !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.18) !important;
  box-shadow:
    0 8px 20px -8px color-mix(in srgb, var(--c-primary-strong) 65%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
  transition: all 0.18s ease !important;
}
body.home-page .btn-primary:hover,
body.catalog-page .btn-primary:hover,
body.about-page .btn-primary:hover,
body.contact-page .btn-primary:hover,
body.product-page .btn-primary:hover,
body.sitemap-page .btn-primary:hover,
body.error-page .btn-primary:hover {
  background: linear-gradient(180deg, #ff6041 0%, #e63d20 100%) !important;
  border-color: #d8351a !important;
  transform: translateY(-1px) !important;
  box-shadow:
    0 12px 26px -10px color-mix(in srgb, var(--c-primary-strong) 80%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22) !important;
}

/* ----- 4. Global btn-secondary ? clearer ----- */
body.home-page .btn-secondary,
body.catalog-page .btn-secondary,
body.about-page .btn-secondary,
body.contact-page .btn-secondary,
body.product-page .btn-secondary,
body.sitemap-page .btn-secondary,
body.error-page .btn-secondary {
  background: #fff !important;
  color: var(--c-text) !important;
  border: 1.5px solid var(--c-border-strong) !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em !important;
  padding: 0.65rem 1.15rem !important;
  min-height: 44px !important;
  border-radius: var(--radius-pill) !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
  transition: all 0.18s ease !important;
}
body.home-page .btn-secondary:hover,
body.catalog-page .btn-secondary:hover,
body.about-page .btn-secondary:hover,
body.contact-page .btn-secondary:hover,
body.product-page .btn-secondary:hover,
body.sitemap-page .btn-secondary:hover,
body.error-page .btn-secondary:hover {
  background: var(--c-text) !important;
  color: #fff !important;
  border-color: var(--c-text) !important;
  transform: translateY(-1px) !important;
}

/* Theme toggle button stays icon-only, square */
body .btn-secondary.theme-toggle {
  min-height: auto !important;
  padding: 0 !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 50% !important;
}

/* Header actions stay tight */
.site-header .actions .btn-secondary { padding: 0 !important; }

/* ----- 5. Reserve dialog primary button ? full visual punch ----- */
.reserve-form .btn-primary,
.reserve-actions .btn-primary {
  flex: 1 1 200px;
}

/* ----- 6. Empty state button visibility ----- */
.empty-state .btn-secondary {
  margin-top: 0.6rem;
}

/* ----- 7. Toolbar Reset button (load more) ----- */
#loadMoreBtn { min-width: 200px; }

/* ----- 8. Dark mode adjustments (avoid white-on-white on btn-secondary) ----- */
[data-theme="dark"] body.home-page .btn-secondary,
[data-theme="dark"] body.catalog-page .btn-secondary,
[data-theme="dark"] body.about-page .btn-secondary,
[data-theme="dark"] body.contact-page .btn-secondary,
[data-theme="dark"] body.product-page .btn-secondary,
[data-theme="dark"] body.sitemap-page .btn-secondary,
[data-theme="dark"] body.error-page .btn-secondary {
  background: var(--c-surface) !important;
  color: var(--c-text) !important;
  border-color: var(--c-border-strong) !important;
}
[data-theme="dark"] body.catalog-page .product-grid .card .card-body .card-actions .card-cta {
  background: var(--c-surface) !important;
  color: var(--c-text) !important;
  border-color: var(--c-border-strong) !important;
}
[data-theme="dark"] body.catalog-page .product-grid .card .card-body .card-actions .card-cta::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e9edf6' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") !important;
}
@media (max-width: 360px) {
  body.catalog-page .product-grid .card .card-body .card-actions {
    flex-direction: column;
  }
  body.catalog-page .product-grid .card .card-body .card-actions .card-cta,
  body.catalog-page .product-grid .card .card-body .card-actions .card-reserve {
    width: 100%;
    flex: 1 1 auto !important;
  }
}

/* ===========================================
   PASS 24b ? Reserve success state + dialog polish
   =========================================== */
.reserve-form.is-hidden { display: none !important; }

.reserve-success-host {
  padding: 1.4rem 1.6rem 1.6rem;
  display: flex;
  flex-direction: column;
}

.reserve-success {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  text-align: left;
}

.reserve-success-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--c-primary) 28%, #fff) 0%, color-mix(in srgb, var(--c-primary) 8%, #fff) 70%),
    #fff;
  border: 2px solid color-mix(in srgb, var(--c-primary) 35%, transparent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  position: relative;
}
.reserve-success-icon::after {
  content: "";
  width: 22px;
  height: 22px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 12l5 5L20 6'/%3E%3C/svg%3E") center / contain no-repeat;
}

.reserve-success h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--c-text);
  letter-spacing: -0.01em;
}

.reserve-subtle {
  margin: 0;
  color: var(--c-muted);
  line-height: 1.55;
  font-size: 0.95rem;
}
.reserve-subtle strong {
  color: var(--c-text);
  font-weight: 700;
}

.reserve-success-actions {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin-top: 0.3rem;
}
.reserve-success-actions .btn-primary,
.reserve-success-actions .btn-secondary {
  flex: 1 1 180px;
  text-align: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.reserve-preview {
  border: 1px solid var(--c-border);
  background: var(--c-surface-2);
  border-radius: 12px;
  padding: 0.6rem 0.85rem;
  font-size: 0.88rem;
}
.reserve-preview summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--c-text);
  letter-spacing: 0.01em;
  list-style: none;
}
.reserve-preview summary::-webkit-details-marker { display: none; }
.reserve-preview summary::after {
  content: "\25BE";
  margin-left: 0.4rem;
  color: var(--c-muted);
}
.reserve-preview[open] summary::after { content: "\25B4"; }
.reserve-preview-body {
  margin: 0.6rem 0 0;
  white-space: pre-wrap;
  word-break: break-word;
  color: var(--c-text);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.82rem;
  line-height: 1.55;
  max-height: 220px;
  overflow: auto;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 10px;
  padding: 0.7rem 0.85rem;
}

.reserve-back {
  align-self: flex-start;
  background: transparent;
  border: 0;
  color: var(--c-muted);
  cursor: pointer;
  font-weight: 600;
  padding: 0.3rem 0;
  margin-top: 0.2rem;
  transition: color 0.18s ease;
}
.reserve-back:hover { color: var(--c-text); }

/* Reserve dialog header chip pulse on success */
.reserve-dialog-head.is-success::before {
  background: linear-gradient(135deg, #22c55e 0%, #15803d 100%) !important;
}

/* ===========================================
   PASS 24c ? Cross-page button polish (consistency)
   =========================================== */

/* Hero CTA buttons (home, about, contact, sitemap, 404) */
body.home-page .home-hero-cta .btn-primary,
body.about-page .about-hero .btn-primary,
body.contact-page .contact-hero .btn-primary,
body.sitemap-page .btn-primary,
body.error-page .btn-primary {
  padding: 0.85rem 1.6rem !important;
  font-size: 0.98rem !important;
  letter-spacing: 0.03em !important;
  text-transform: none !important;
  min-height: 50px !important;
}

/* Generic anchor styled as primary should match */
a.btn-primary {
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.45rem !important;
}
a.btn-secondary {
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.45rem !important;
}

/* Subtle pulse hint on Reserve open in product page */
.product-cta-reserve {
  position: relative;
}
.product-cta-reserve::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: linear-gradient(135deg, color-mix(in srgb, var(--c-primary) 32%, transparent), transparent 60%);
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
  z-index: -1;
}
.product-cta-reserve:hover::before { opacity: 1; }

/* ===========================================
   PASS 24d ? Contact form success state
   =========================================== */
.contact-form.is-hidden { display: none !important; }
.contact-success {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  margin-top: 1rem;
  padding: 1.4rem 1.5rem;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
}
.contact-success h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--c-text);
  letter-spacing: -0.01em;
}
.contact-success .reserve-success-icon { align-self: flex-start; }

/* ===========================================
   PASS 25 ? Remove quickview, taller card image
   =========================================== */

/* Defensive: hide any remaining quickview button */
.card-quickview,
.card .card-quickview,
body.catalog-page .card-quickview {
  display: none !important;
}

/* Podalj?aj sliko (4:3 -> 1:1 square ? modern, breathable) */
body.catalog-page .card-image {
  aspect-ratio: 1 / 1 !important;
  border-radius: 14px !important;
}

body.catalog-page .product-grid .card .card-media .card-image {
  aspect-ratio: 1 / 1 !important;
}

/* Placeholder: center icon + label vertically as a balanced stack */
body.catalog-page .card-image.placeholder {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.85rem !important;
  padding: 1rem !important;
}

body.catalog-page .card-image.placeholder::before {
  position: static !important;
  width: 64px !important;
  height: 64px !important;
  opacity: 0.6 !important;
  margin: 0 !important;
}

body.catalog-page .card-image.placeholder::after {
  content: "Foto v pripravi" !important;
  position: static !important;
  bottom: auto !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  color: var(--c-muted) !important;
  opacity: 0.8 !important;
}

/* List view: keep landscape ratio (16:10) ? quadratno bi bilo prevec */
body.catalog-page #productGrid.is-list-view .card-image {
  aspect-ratio: 16 / 11 !important;
}

/* Card hover lift now safer ? image is bigger so no clipping */
body.catalog-page .product-grid .card:hover .card-image {
  transform: scale(1.03) !important;
}

/* ===========================================
   PASS 26 ? Lightbox + product gallery affordance
   =========================================== */

.product-gallery-frame.has-lightbox {
  cursor: zoom-in;
  position: relative;
}

.product-gallery-hint {
  position: absolute;
  bottom: 0.7rem;
  left: 0.7rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.7rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #fff;
  background: rgba(15, 18, 35, 0.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: var(--radius-pill);
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.22s ease, transform 0.22s ease;
}
.product-gallery-frame.has-lightbox:hover .product-gallery-hint,
.product-gallery-frame.has-lightbox:focus-visible .product-gallery-hint {
  opacity: 1;
  transform: translateY(0);
}
.product-gallery-hint-ico {
  width: 14px;
  height: 14px;
  background: 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='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3Cline x1='11' y1='8' x2='11' y2='14'/%3E%3Cline x1='8' y1='11' x2='14' y2='11'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* Overlay */
.lightbox-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 2rem 4rem;
  background: rgba(8, 10, 18, 0.94);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity 0.22s ease;
}
.lightbox-overlay.is-visible { opacity: 1; }

.lightbox-close {
  position: absolute;
  top: 1rem;
  right: 1.2rem;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
  font-size: 1.5rem;
  line-height: 1;
  border-radius: 50%;
  cursor: pointer;
  transition: background 0.18s ease, transform 0.18s ease;
}
.lightbox-close:hover {
  background: rgba(255, 255, 255, 0.18);
  transform: rotate(90deg);
}

.lightbox-stage {
  position: relative;
  max-width: min(1100px, 92vw);
  max-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: zoom-in;
  overflow: hidden;
  border-radius: 14px;
}
.lightbox-stage.is-zoomed { cursor: zoom-out; }

.lightbox-image {
  display: block;
  max-width: 100%;
  max-height: 80vh;
  width: auto;
  height: auto;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
  transition: transform 0.28s ease;
  transform-origin: center center;
}

.lightbox-caption {
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 1rem;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: #fff;
  font-size: 0.84rem;
  letter-spacing: 0.01em;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  max-width: calc(100% - 2rem);
  overflow: hidden;
  text-overflow: ellipsis;
}
.lightbox-caption span {
  font-weight: 700;
}
.lightbox-caption kbd {
  display: inline-block;
  padding: 0.1rem 0.4rem;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 6px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 0.72rem;
  margin-right: 0.3rem;
}

@media (max-width: 600px) {
  .lightbox-overlay { padding: 1rem 1rem 3rem; }
  .lightbox-caption { font-size: 0.75rem; }
}

/* ===========================================
   PASS 27 ? 404 page enhancements
   =========================================== */

body.error-page .error-search {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border-strong);
  border-radius: var(--radius-pill);
  padding: 0.45rem 0.5rem 0.45rem 1.1rem;
  max-width: 560px;
  margin: 1.5rem 0 0.5rem;
  box-shadow: 0 6px 20px -10px rgba(15, 23, 42, 0.18);
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
body.error-page .error-search:focus-within {
  border-color: var(--c-primary);
  box-shadow: 0 8px 28px -8px color-mix(in srgb, var(--c-primary) 30%, transparent);
}
body.error-page .error-search-icon {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") center / contain no-repeat;
}
body.error-page .error-search-input {
  flex: 1 1 auto;
  border: 0;
  background: transparent;
  outline: none;
  font-size: 0.98rem;
  color: var(--c-text);
  padding: 0.4rem 0;
}
body.error-page .error-search-input::placeholder { color: var(--c-muted); }
body.error-page .error-search-btn {
  flex: 0 0 auto;
  min-height: auto !important;
  padding: 0.55rem 1.1rem !important;
}

body.error-page .error-suggest-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.6rem;
}
body.error-page .error-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 0.95rem;
  background: var(--c-surface);
  color: var(--c-text);
  text-decoration: none;
  border: 1.5px solid var(--c-border-strong);
  border-radius: var(--radius-pill);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: all 0.18s ease;
}
body.error-page .error-chip:hover {
  background: var(--c-primary);
  color: #fff;
  border-color: var(--c-primary);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px -6px color-mix(in srgb, var(--c-primary) 50%, transparent);
}

body.error-page .error-quicklinks { margin-top: 1.6rem; }
body.error-page .error-quicklinks-list {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 0.5rem;
  padding: 0;
  margin: 0.6rem 0 0;
}
body.error-page .error-quicklinks-list a {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.7rem 1rem;
  background: var(--c-surface-2);
  color: var(--c-text);
  text-decoration: none;
  border: 1px solid var(--c-border);
  border-radius: 12px;
  font-weight: 600;
  font-size: 0.9rem;
  transition: all 0.18s ease;
}
body.error-page .error-quicklinks-list a:hover {
  background: var(--c-surface);
  border-color: var(--c-primary);
  transform: translateY(-1px);
}
body.error-page .error-quicklink-ico {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  background: currentColor;
  -webkit-mask: var(--ico) center / contain no-repeat;
  mask: var(--ico) center / contain no-repeat;
  color: var(--c-primary);
}
body.error-page .error-quicklink-ico[data-ico="home"]  { --ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 9l9-7 9 7v11a2 2 0 0 1-2 2h-4a2 2 0 0 1-2-2v-5h-2v5a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'/%3E%3C/svg%3E"); }
body.error-page .error-quicklink-ico[data-ico="grid"]  { --ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7'/%3E%3Crect x='14' y='3' width='7' height='7'/%3E%3Crect x='14' y='14' width='7' height='7'/%3E%3Crect x='3' y='14' width='7' height='7'/%3E%3C/svg%3E"); }
body.error-page .error-quicklink-ico[data-ico="info"]  { --ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='16' x2='12' y2='12'/%3E%3Cline x1='12' y1='8' x2='12.01' y2='8'/%3E%3C/svg%3E"); }
body.error-page .error-quicklink-ico[data-ico="mail"]  { --ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'/%3E%3Cpolyline points='22,6 12,13 2,6'/%3E%3C/svg%3E"); }
body.error-page .error-quicklink-ico[data-ico="map"]   { --ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='1 6 1 22 8 18 16 22 23 18 23 2 16 6 8 2 1 6'/%3E%3Cline x1='8' y1='2' x2='8' y2='18'/%3E%3Cline x1='16' y1='6' x2='16' y2='22'/%3E%3C/svg%3E"); }

/* ===========================================
   PASS 27c ? Search autocomplete dropdown (catalog)
   =========================================== */
.search-suggest {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--c-surface);
  border: 1px solid var(--c-border-strong);
  border-radius: 14px;
  box-shadow: var(--shadow-lg);
  padding: 0.5rem;
  z-index: 50;
  display: none;
  max-height: 380px;
  overflow: auto;
}
.search-suggest.is-open { display: block; }
.search-suggest-section {
  padding: 0.4rem 0.4rem 0.2rem;
}
.search-suggest-title {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-muted);
  margin: 0 0 0.3rem;
  padding: 0 0.4rem;
}
.search-suggest-item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.45rem 0.55rem;
  border-radius: 10px;
  background: transparent;
  border: 0;
  width: 100%;
  text-align: left;
  cursor: pointer;
  color: var(--c-text);
  font-size: 0.92rem;
  transition: background 0.15s ease;
}
.search-suggest-item:hover,
.search-suggest-item.is-active {
  background: var(--c-surface-2);
}
.search-suggest-item-meta {
  margin-left: auto;
  color: var(--c-muted);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.search-suggest-item-ico {
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
  opacity: 0.6;
}
.search-suggest-empty {
  padding: 0.8rem 0.6rem;
  color: var(--c-muted);
  font-size: 0.88rem;
  text-align: center;
}
.search-suggest-clear {
  background: transparent;
  border: 0;
  color: var(--c-muted);
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 0.2rem 0.4rem;
  float: right;
  margin-top: -2px;
}
.search-suggest-clear:hover { color: var(--c-primary); }

/* relative positioning on parent */
.toolbar-search { position: relative; }

/* Toolbar search wrapper layout fix */
body.catalog-page .toolbar > .toolbar-search { width: 100%; }
body.catalog-page .toolbar > .toolbar-search input[type="search"] { width: 100%; }

/* ===========================================
   PASS 28 ? Sale badges, discount price, reviews
   =========================================== */

/* Sale badge (red) */
.card-badge.card-badge-sale {
  background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%) !important;
  color: #fff !important;
  border: 1px solid #b91c1c !important;
  box-shadow: 0 4px 12px -4px rgba(220, 38, 38, 0.5);
  font-weight: 800;
  letter-spacing: 0.04em;
  font-size: 0.72rem;
  padding: 0.3rem 0.6rem;
  border-radius: var(--radius-pill);
}

/* Discount price (card) */
.card .price.has-discount,
body.catalog-page .card .price.has-discount {
  display: flex !important;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5rem 0.65rem;
  font-weight: 800;
}
.price-final {
  color: #dc2626;
  font-size: 1.18em;
  font-weight: 800;
}
.price-original {
  color: var(--c-muted);
  font-size: 0.82em;
  font-weight: 600;
  text-decoration: line-through;
  opacity: 0.78;
}
.price-save {
  flex-basis: 100%;
  color: #16a34a;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

/* Discount price (dialog) */
.dialog-price.has-discount {
  display: flex !important;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.7rem 1rem;
}
.dialog-price.has-discount .price-final { font-size: 1.6rem; }

/* Discount price (product page) */
body.product-page .product-price-block.has-discount .product-price-row {
  display: flex;
  align-items: center;
  gap: 0.8rem 1.1rem;
  flex-wrap: wrap;
}
body.product-page .product-price-block.has-discount .product-price {
  color: #dc2626 !important;
}
body.product-page .product-price-original {
  color: var(--c-muted);
  font-weight: 600;
  text-decoration: line-through;
  font-size: 1.15rem;
  opacity: 0.78;
}
body.product-page .product-price-badge {
  background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%);
  color: #fff;
  font-weight: 800;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-pill);
  box-shadow: 0 4px 12px -4px rgba(220, 38, 38, 0.5);
}
body.product-page .product-price-save {
  display: inline-block;
  margin-top: 0.4rem;
  color: #16a34a;
  font-weight: 700;
  font-size: 0.86rem;
  letter-spacing: 0.02em;
}

/* ===========================================
   Reviews section
   =========================================== */
body.product-page .product-reviews {
  margin: 3rem auto 1rem;
  padding: 1.5rem 1.5rem 2rem;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
}

.product-reviews-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1.4rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--c-border);
}
.product-reviews-title {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--c-text);
}
.product-reviews-sub {
  margin: 0.3rem 0 0;
  color: var(--c-muted);
  font-size: 0.92rem;
}
.product-reviews-sub strong {
  color: var(--c-text);
  font-size: 1.15rem;
  font-weight: 800;
}

.product-reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
}

.review-card {
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: 14px;
  padding: 1rem 1.1rem 1.1rem;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.review-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in srgb, var(--c-primary) 25%, var(--c-border));
}

.review-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}
.review-author {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.review-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.95rem;
}
.review-author strong {
  display: block;
  color: var(--c-text);
  font-weight: 700;
  font-size: 0.92rem;
}
.review-author time {
  display: block;
  color: var(--c-muted);
  font-size: 0.78rem;
}

.review-stars {
  color: #f59e0b;
  font-size: 0.95rem;
  letter-spacing: 0.06em;
  position: relative;
  display: inline-block;
}
.review-stars-empty {
  color: var(--c-border-strong);
}

.review-title {
  margin: 0.1rem 0 0.4rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--c-text);
  letter-spacing: -0.005em;
}
.review-body {
  margin: 0;
  color: var(--c-text);
  line-height: 1.55;
  font-size: 0.92rem;
}

/* ===========================================
   PASS 29 - Recently viewed, sticky CTA, FAQ, fallbacks
   =========================================== */

/* ----- Recently viewed grid ----- */
.product-recently-viewed,
.home-recently-viewed {
  margin-top: 2.5rem;
}
.product-recently-viewed .product-rv-head,
.home-recently-viewed .hp-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.product-rv-head h2 {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--c-text);
  letter-spacing: -0.01em;
}

.rv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 0.85rem;
}

.rv-card {
  display: flex;
  flex-direction: column;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 14px;
  text-decoration: none;
  color: var(--c-text);
  overflow: hidden;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.rv-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in srgb, var(--c-primary) 28%, var(--c-border));
}

.rv-card-media {
  position: relative;
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, var(--c-surface-2) 0%, var(--c-surface-3) 100%);
  overflow: hidden;
}
.rv-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.rv-card-ph {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--c-primary) 12%, transparent) 0%, transparent 60%),
    linear-gradient(135deg, var(--c-surface-2), var(--c-surface-3));
}
.rv-card-ph::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 2 3 6v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6l-3-4z'/%3E%3Cline x1='3' y1='6' x2='21' y2='6'/%3E%3Cpath d='M16 10a4 4 0 0 1-8 0'/%3E%3C/svg%3E") center / 36px no-repeat;
  opacity: 0.55;
}
.rv-card-sale {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  box-shadow: 0 4px 12px -4px rgba(220, 38, 38, 0.5);
}

.rv-card-body {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.7rem 0.8rem 0.85rem;
}
.rv-card-cat {
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-muted);
}
.rv-card-title {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--c-text);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  letter-spacing: -0.005em;
}
.rv-card-price {
  margin-top: 0.2rem;
  font-size: 1rem;
  font-weight: 800;
  color: var(--c-primary);
}

.rv-clear-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.85rem;
}
.rv-clear-btn {
  font-size: 0.78rem !important;
  min-height: auto !important;
  padding: 0.4rem 0.85rem !important;
}

/* ----- Sticky mobile CTA on product page ----- */
.product-sticky-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 90;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid var(--c-border);
  box-shadow: 0 -8px 24px -10px rgba(15, 23, 42, 0.15);
  padding: 0.65rem 0;
  transform: translateY(100%);
  transition: transform 0.28s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.product-sticky-cta.is-visible { transform: translateY(0); }
.product-sticky-cta[hidden] {
  display: block !important;
  pointer-events: none;
}

.product-sticky-cta-grid {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}
.product-sticky-cta-info {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-width: 0;
}
.product-sticky-cta-name {
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--c-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: -0.005em;
}
.product-sticky-cta-price {
  font-size: 1rem;
  font-weight: 800;
  color: var(--c-primary);
}
.product-sticky-cta .btn-primary {
  flex: 0 0 auto;
  min-height: 44px !important;
  padding: 0.55rem 1.1rem !important;
}

[data-theme="dark"] .product-sticky-cta {
  background: rgba(20, 24, 36, 0.94);
}

/* Hide sticky CTA on desktop */
@media (min-width: 900px) {
  .product-sticky-cta { display: none !important; }
}

/* Make space for sticky bar so footer credit not covered */
@media (max-width: 899px) {
  body.product-page { padding-bottom: 80px; }
}

/* ----- FAQ on home ----- */
.home-faq-list {
  display: grid;
  gap: 0.7rem;
  max-width: 880px;
  margin: 0 auto;
}
.home-faq-item {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 14px;
  padding: 0;
  overflow: hidden;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
.home-faq-item[open] {
  border-color: color-mix(in srgb, var(--c-primary) 28%, var(--c-border));
  box-shadow: var(--shadow-sm);
}
.home-faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.05rem 1.2rem;
  cursor: pointer;
  font-weight: 700;
  font-size: 1.02rem;
  color: var(--c-text);
  letter-spacing: -0.005em;
  list-style: none;
  transition: background 0.18s ease;
}
.home-faq-item summary::-webkit-details-marker { display: none; }
.home-faq-item summary:hover { background: var(--c-surface-2); }
.home-faq-ico {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  position: relative;
  transition: transform 0.22s ease, background 0.22s ease, border-color 0.22s ease;
}
.home-faq-ico::before,
.home-faq-ico::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  background: var(--c-text);
  border-radius: 1px;
}
.home-faq-ico::before { width: 10px; height: 2px; }
.home-faq-ico::after { width: 2px; height: 10px; transition: transform 0.22s ease; }
.home-faq-item[open] .home-faq-ico {
  background: var(--c-primary);
  border-color: var(--c-primary);
}
.home-faq-item[open] .home-faq-ico::before { background: #fff; }
.home-faq-item[open] .home-faq-ico::after { background: #fff; transform: scaleY(0); }

.home-faq-item p {
  margin: 0;
  padding: 0 1.2rem 1.15rem;
  color: var(--c-text);
  line-height: 1.6;
  font-size: 0.95rem;
}
.home-faq-item p strong { color: var(--c-text); font-weight: 700; }
.home-faq-item p a { color: var(--c-primary); text-decoration: none; font-weight: 600; }
.home-faq-item p a:hover { text-decoration: underline; }

/* ----- Image fallback ----- */
.img-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--c-primary) 10%, transparent), transparent 60%),
    var(--c-surface-2);
  border: 1px dashed var(--c-border);
  color: transparent;
  min-height: 120px;
  border-radius: 10px;
}

/* ----- Newsletter error ----- */
.newsletter-status.is-error { color: #dc2626 !important; font-weight: 700; }

/* ----- RV grid responsive tweak ----- */
@media (max-width: 600px) {
  .rv-grid { grid-template-columns: repeat(2, 1fr); gap: 0.6rem; }
  .rv-card-title { font-size: 0.84rem; }
  .rv-card-price { font-size: 0.92rem; }
}

/* ===========================================
   PASS 30 - Visual fixes (clean-theme overrides)
   =========================================== */

/* ----- hp-steps: orange circle was clipping strong text ----- */
body.home-page .hp-steps li {
  position: relative !important;
  padding: 0.85rem 1.1rem 0.85rem 3.95rem !important;
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 12px !important;
  display: block !important;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
body.home-page .hp-steps li:hover {
  border-color: color-mix(in srgb, var(--c-primary) 28%, var(--c-border)) !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
body.home-page .hp-steps li::before {
  content: "";
  position: absolute;
  left: 0.85rem;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--c-primary-soft, #fef0ec);
  border: 1px solid color-mix(in srgb, var(--c-primary) 28%, transparent);
  z-index: 0;
}
body.home-page .hp-steps li::after {
  content: "";
  position: absolute;
  left: 1.27rem;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  z-index: 1;
}
body.home-page .hp-steps li strong {
  display: block !important;
  margin: 0 0 0.2rem !important;
  font-weight: 800 !important;
  font-size: 0.96rem !important;
  color: var(--c-text) !important;
  letter-spacing: -0.005em;
}
body.home-page .hp-steps li span {
  display: block !important;
  font-size: 0.88rem !important;
  color: var(--c-text-soft) !important;
  line-height: 1.5 !important;
}

/* ----- home-strip: force dark CTA band (was overridden by clean-theme) ----- */
body.home-page .home-strip {
  background:
    radial-gradient(circle at 90% 50%, color-mix(in srgb, var(--c-primary) 22%, transparent), transparent 55%),
    linear-gradient(120deg, #14171c 0%, #1c2129 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  color: #e9edf6 !important;
  padding: clamp(1.6rem, 3.5vw, 2.4rem) clamp(1.5rem, 3vw, 2.4rem) !important;
  border-radius: 16px !important;
}
body.home-page .home-strip h3 {
  color: #ffffff !important;
  font-size: clamp(1.2rem, 2.2vw, 1.55rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.015em !important;
  margin: 0 0 0.4rem !important;
}
body.home-page .home-strip p {
  color: #c4cad6 !important;
  margin: 0 !important;
  line-height: 1.55;
}
body.home-page .home-strip .actions {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}
body.home-page .home-strip .btn-secondary {
  background: rgba(255, 255, 255, 0.06) !important;
  color: #ffffff !important;
  border: 1.5px solid rgba(255, 255, 255, 0.18) !important;
}
body.home-page .home-strip .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: rgba(255, 255, 255, 0.32) !important;
  color: #ffffff !important;
}

/* ----- Newsletter heading on dark band: force white ----- */
.newsletter-band .newsletter-copy h2,
.newsletter-band .newsletter-copy p {
  color: #ffffff !important;
}
.newsletter-band .newsletter-copy h2 {
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
}
.newsletter-band .newsletter-copy p {
  color: rgba(245, 247, 255, 0.78) !important;
}
.newsletter-band .newsletter-eyebrow {
  color: color-mix(in srgb, var(--c-primary) 70%, #fff) !important;
}

/* ----- Newsletter form input on dark: better contrast ----- */
.newsletter-band .newsletter-input-wrap input {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
}
.newsletter-band .newsletter-input-wrap input::placeholder {
  color: rgba(245, 247, 255, 0.55) !important;
}
.newsletter-band .newsletter-input-wrap input:focus {
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: var(--c-primary) !important;
  outline: none;
}

/* ----- hp-highlight: numbers should not push out of frame on small screens ----- */
body.home-page .hp-highlight-grid article {
  padding: 1.2rem 1.1rem !important;
}
body.home-page .hp-stat {
  font-size: 1.1rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.04em !important;
}

/* ----- Footer credit: improve visibility on dark bg ----- */
.site-footer .footer-credit {
  color: rgba(216, 221, 228, 0.72) !important;
}
.site-footer .footer-credit-link {
  color: #ff6041 !important;
  font-weight: 700;
}
.site-footer .footer-credit-link:hover {
  color: #ffffff !important;
}

/* =====================================================================
   About v2 + Contact v2 (2026 refresh)
   ===================================================================== */

body.about-page .about-main-v2,
body.contact-page .contact-main-v2 {
  padding-bottom: var(--space-8);
}

/* --- About --- */
body.about-page .about-v2-hero {
  padding: clamp(2.2rem, 5vw, 3.6rem) 0 clamp(1.8rem, 4vw, 2.6rem);
  background:
    radial-gradient(120% 80% at 100% 0%, color-mix(in srgb, var(--c-primary) 18%, transparent), transparent 55%),
    linear-gradient(165deg, var(--c-surface) 0%, var(--c-surface-2) 100%);
  border-bottom: 1px solid var(--c-border);
}
body.about-page .about-v2-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: clamp(1.2rem, 3vw, 2.4rem);
  align-items: start;
}
body.about-page .about-v2-eyebrow {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-primary-strong);
  margin: 0 0 0.5rem;
}
body.about-page .about-v2-eyebrow.is-muted {
  color: var(--c-text-soft);
}
body.about-page .about-v2-hero-copy h1 {
  font-size: clamp(1.75rem, 3.2vw, 2.35rem);
  margin: 0 0 var(--space-3);
  letter-spacing: -0.03em;
}
body.about-page .about-v2-lead {
  font-size: 1.02rem;
  line-height: 1.65;
  color: var(--c-text-soft);
  max-width: 58ch;
  margin: 0 0 var(--space-4);
}
body.about-page .about-v2-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}
body.about-page .about-v2-pills span {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-pill);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--c-text);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-sm);
}
body.about-page .about-v2-hero-aside {
  display: grid;
  gap: 0.65rem;
}
body.about-page .about-v2-stat-card {
  padding: 1rem 1.1rem;
  border-radius: var(--radius-md);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-sm);
}
body.about-page .about-v2-stat-label {
  display: block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-muted);
  margin-bottom: 0.35rem;
}
body.about-page .about-v2-stat-num {
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--c-text);
}
body.about-page .about-v2-stat-hint {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.82rem;
  color: var(--c-text-soft);
}
body.about-page .about-v2-band {
  margin: var(--space-6) 0;
  padding: clamp(1.6rem, 3vw, 2.2rem) 0;
  background: var(--c-surface);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
}
body.about-page .about-v2-band-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
  gap: clamp(1rem, 2.5vw, 2rem);
  align-items: start;
}
body.about-page .about-v2-band-inner h2 {
  margin: 0 0 var(--space-2);
}
body.about-page .about-v2-band-inner > div > p {
  margin: 0;
  max-width: 52ch;
}
body.about-page .about-v2-band-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.55rem;
}
body.about-page .about-v2-band-list li {
  position: relative;
  padding-left: 1.35rem;
  font-size: 0.92rem;
  color: var(--c-text-soft);
}
body.about-page .about-v2-band-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.45rem;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--c-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 22%, transparent);
}
body.about-page .about-v2-grid-section {
  margin-top: var(--space-6);
}
body.about-page .about-v2-section-head {
  margin-bottom: var(--space-4);
}
body.about-page .about-v2-section-head h2 {
  margin: 0.35rem 0 0;
}
body.about-page .about-v2-bento {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}
body.about-page .about-v2-card {
  padding: 1.15rem 1.2rem;
  border-radius: var(--radius-md);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-sm);
}
body.about-page .about-v2-card h3 {
  margin: 0 0 0.35rem;
  font-size: 1.05rem;
}
body.about-page .about-v2-card p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--c-text-soft);
}
body.about-page .about-v2-card-wide {
  grid-column: span 2;
}
body.about-page .about-v2-timeline-wrap {
  margin: var(--space-7) 0;
  padding: var(--space-6) 0;
  background: var(--c-surface-2);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
}
body.about-page .about-v2-timeline {
  list-style: none;
  margin: var(--space-4) 0 0;
  padding: 0;
  display: grid;
  gap: 1rem;
}
body.about-page .about-v2-timeline li {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 1rem;
  padding: 1rem 1.1rem;
  border-radius: var(--radius-md);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
}
body.about-page .about-v2-tl-year {
  font-weight: 900;
  font-size: 1.05rem;
  color: var(--c-primary-strong);
  letter-spacing: -0.02em;
}
body.about-page .about-v2-timeline h3 {
  margin: 0 0 0.25rem;
  font-size: 1rem;
}
body.about-page .about-v2-timeline p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--c-text-soft);
}
body.about-page .about-v2-cta {
  margin-top: var(--space-6);
  padding: clamp(1.5rem, 3vw, 2rem);
  border-radius: var(--radius-lg);
  background: linear-gradient(120deg, #14171c 0%, #1c2129 100%);
  color: #e9edf6;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.06);
}
body.about-page .about-v2-cta h2 {
  color: #fff;
  margin: 0 0 0.35rem;
}
body.about-page .about-v2-cta p {
  margin: 0;
  color: rgba(233, 237, 246, 0.78);
  max-width: 46ch;
}
body.about-page .about-v2-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

/* --- Contact --- */
body.contact-page .contact-v2-hero {
  padding: clamp(2.2rem, 5vw, 3.4rem) 0;
  background:
    radial-gradient(90% 70% at 0% 0%, color-mix(in srgb, var(--c-primary) 16%, transparent), transparent 50%),
    linear-gradient(180deg, var(--c-surface) 0%, var(--c-bg) 100%);
  border-bottom: 1px solid var(--c-border);
}
body.contact-page .contact-v2-hero-inner {
  max-width: 720px;
}
body.contact-page .contact-v2-eyebrow {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-primary-strong);
  margin: 0 0 0.45rem;
}
body.contact-page .contact-v2-hero h1 {
  font-size: clamp(1.7rem, 3vw, 2.25rem);
  margin: 0 0 var(--space-3);
  letter-spacing: -0.03em;
}
body.contact-page .contact-v2-lead {
  margin: 0 0 var(--space-4);
  font-size: 1.02rem;
  line-height: 1.65;
  color: var(--c-text-soft);
  max-width: 54ch;
}
body.contact-page .contact-v2-quick {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}
body.contact-page .contact-v2-chip {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.15rem;
  padding: 0.65rem 0.95rem;
  min-width: 160px;
  border-radius: var(--radius-md);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  text-decoration: none;
  color: inherit;
  box-shadow: var(--shadow-sm);
  transition: border-color 0.18s ease, transform 0.18s ease;
}
body.contact-page .contact-v2-chip:hover {
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border));
  transform: translateY(-1px);
}
body.contact-page .contact-v2-chip-label {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-muted);
}
body.contact-page .contact-v2-chip-value {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--c-text);
}
body.contact-page .contact-v2-chip-map {
  flex: 1 1 220px;
}
body.contact-page .contact-v2-split {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.75fr);
  gap: clamp(1rem, 2.5vw, 2rem);
  margin-top: var(--space-6);
  align-items: start;
}
body.contact-page .contact-v2-form-card {
  padding: clamp(1.2rem, 2.5vw, 1.6rem);
  border-radius: var(--radius-lg);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-md);
}
body.contact-page .contact-v2-form-card h2 {
  margin: 0 0 0.35rem;
}
body.contact-page .contact-v2-form-lead {
  margin: 0 0 var(--space-4);
  font-size: 0.92rem;
  color: var(--c-text-soft);
}
body.contact-page .contact-v2-form .contact-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}
body.contact-page .contact-v2-aside {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
body.contact-page .contact-v2-aside-card {
  padding: 1rem 1.1rem;
  border-radius: var(--radius-md);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
}
body.contact-page .contact-v2-aside-card h3 {
  margin: 0 0 0.5rem;
  font-size: 0.88rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-muted);
}
body.contact-page .contact-v2-aside-text {
  margin: 0 0 0.35rem;
  font-size: 0.88rem;
  color: var(--c-text);
}
body.contact-page .contact-v2-aside-text.muted {
  color: var(--c-text-soft);
}
body.contact-page .contact-v2-hours {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.4rem;
  font-size: 0.9rem;
}
body.contact-page .contact-v2-hours li {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  color: var(--c-text-soft);
}
body.contact-page .contact-v2-hours span:last-child {
  font-weight: 700;
  color: var(--c-text);
}
body.contact-page .contact-v2-hours li.is-closed span,
body.contact-page .contact-v2-hours li.is-closed span:last-child {
  color: var(--c-muted);
  font-weight: 500;
  text-decoration: line-through;
  text-decoration-color: color-mix(in srgb, var(--c-muted) 35%, transparent);
}
body.contact-page .contact-v2-hours li.is-closed span:first-child {
  text-decoration: none;
}
body.contact-page .contact-v2-map-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem 1rem;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 0.86rem;
  text-decoration: none;
  color: #fff;
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  border: 1px solid var(--c-primary-strong);
}
body.contact-page .contact-v2-map-link:hover {
  filter: brightness(1.05);
}

@media (max-width: 900px) {
  body.about-page .about-v2-hero-grid,
  body.about-page .about-v2-band-inner,
  body.about-page .about-v2-bento {
    grid-template-columns: 1fr;
  }
  body.about-page .about-v2-card-wide {
    grid-column: span 1;
  }
  body.about-page .about-v2-timeline li {
    grid-template-columns: 1fr;
  }
  body.contact-page .contact-v2-split {
    grid-template-columns: 1fr;
  }
  body.contact-page .contact-v2-form .contact-form-row {
    grid-template-columns: 1fr;
  }
}

/* =====================================================================
   PASS 31 ? Final unified design pass (after removing clean-theme.css)
   Goals:
   - Consistent header / footer / body across ALL pages
   - Coverage for product, error, sitemap pages
   - Clean dark theme behaviour, no leftover gradient clashes
   ===================================================================== */

html, body {
  background: var(--c-bg);
  color: var(--c-text);
}

/* Apply primary look to ALL site pages (admin pages excluded) */
body.home-page,
body.catalog-page,
body.about-page,
body.contact-page,
body.product-page,
body.error-page,
body.sitemap-page {
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* Header ? same look everywhere */
body.home-page .site-header.site-header-main,
body.catalog-page .site-header.site-header-main,
body.about-page .site-header.site-header-main,
body.contact-page .site-header.site-header-main,
body.product-page .site-header.site-header-main,
body.error-page .site-header.site-header-main,
body.sitemap-page .site-header.site-header-main {
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-border);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

/* Container width consistent everywhere */
body.product-page .container,
body.error-page .container,
body.sitemap-page .container {
  width: min(1200px, 92vw);
  margin-inline: auto;
}

/* Headings tokens for product/error/sitemap pages */
body.product-page h1,
body.product-page h2,
body.product-page h3,
body.error-page h1,
body.error-page h2,
body.error-page h3,
body.sitemap-page h1,
body.sitemap-page h2,
body.sitemap-page h3 {
  color: var(--c-text);
  letter-spacing: -0.022em;
  font-weight: 700;
}
body.product-page p,
body.error-page p,
body.sitemap-page p {
  color: var(--c-text-soft);
}

/* Site nav ? same on all pages */
body.product-page .site-nav a,
body.error-page .site-nav a,
body.sitemap-page .site-nav a {
  color: var(--c-text);
  text-decoration: none;
  padding: 0.5rem 0.85rem;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: 0.92rem;
  transition: background 0.18s ease, color 0.18s ease;
}
body.product-page .site-nav a:hover,
body.error-page .site-nav a:hover,
body.sitemap-page .site-nav a:hover {
  background: var(--c-surface-2);
}
body.product-page .site-nav a.active,
body.error-page .site-nav a.active,
body.sitemap-page .site-nav a.active {
  color: var(--c-primary);
  background: var(--c-primary-soft);
}

/* Step list ? guarantee enough left padding so number + check never clip */
body.home-page .hp-showcase .hp-steps li,
body.home-page .hp-section .hp-steps li,
body.home-page .hp-steps li {
  position: relative !important;
  padding: 1rem 1.1rem 1rem 4.2rem !important;
  margin: 0 0 0.55rem !important;
  display: block !important;
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
  list-style: none !important;
  gap: 0 !important;
}
body.home-page .hp-showcase .hp-steps li::before,
body.home-page .hp-section .hp-steps li::before,
body.home-page .hp-steps li::before {
  content: "" !important;
  position: absolute !important;
  left: 0.95rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  background: var(--c-primary-soft, #ffe9e3) !important;
  border: 1px solid color-mix(in srgb, var(--c-primary) 28%, transparent) !important;
}
body.home-page .hp-showcase .hp-steps li::after,
body.home-page .hp-section .hp-steps li::after,
body.home-page .hp-steps li::after {
  content: "" !important;
  position: absolute !important;
  left: 1.45rem !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 16px !important;
  height: 16px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
}
body.home-page .hp-showcase .hp-steps li strong,
body.home-page .hp-section .hp-steps li strong,
body.home-page .hp-steps li strong {
  display: block !important;
  margin: 0 0 0.2rem !important;
  padding: 0 !important;
  font-weight: 800 !important;
  font-size: 0.96rem !important;
  color: var(--c-text) !important;
  letter-spacing: -0.005em;
}
body.home-page .hp-showcase .hp-steps li span,
body.home-page .hp-section .hp-steps li span,
body.home-page .hp-steps li span {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 0.9rem !important;
  color: var(--c-text-soft) !important;
  line-height: 1.55 !important;
}
body.home-page .hp-steps {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Sitemap page polish */
body.sitemap-page main.sitemap-main {
  padding: clamp(2rem, 5vw, 3.2rem) 0 var(--space-7);
}
body.sitemap-page .sitemap-hero {
  padding: clamp(1.4rem, 3vw, 2rem);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(80% 70% at 0% 0%, color-mix(in srgb, var(--c-primary) 14%, transparent), transparent 50%),
    var(--c-surface);
  border: 1px solid var(--c-border);
  margin-bottom: var(--space-5);
}
body.sitemap-page .sitemap-hero h1 {
  font-size: clamp(1.7rem, 3vw, 2.2rem);
  margin: 0.4rem 0 0.5rem;
}
body.sitemap-page .sitemap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75rem;
}
body.sitemap-page .sitemap-col {
  padding: 1.1rem 1.2rem;
  border-radius: var(--radius-md);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
}
body.sitemap-page .sitemap-col h2 {
  margin: 0 0 0.6rem;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-muted);
}
body.sitemap-page .sitemap-col ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.35rem;
}
body.sitemap-page .sitemap-col a {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.55rem;
  border-radius: var(--radius-sm);
  color: var(--c-text);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.92rem;
  transition: background 0.18s ease, color 0.18s ease;
}
body.sitemap-page .sitemap-col a:hover {
  background: var(--c-surface-2);
  color: var(--c-primary);
}

/* 404 page polish (selectors live earlier in file too ? these are corrections) */
body.error-page main.error-main {
  padding: clamp(2.5rem, 6vw, 4.5rem) 0;
}

/* Newsletter band ? guarantee dark background even without clean-theme */
.newsletter-band {
  background:
    radial-gradient(120% 80% at 100% 0%, color-mix(in srgb, var(--c-primary) 22%, transparent), transparent 55%),
    linear-gradient(120deg, #14171c 0%, #1c2129 100%);
  color: #e9edf6;
  padding: clamp(2rem, 5vw, 3rem) 0;
  margin-top: var(--space-6);
}

/* Mobile drawer base styling so it works on every page */
.mobile-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 90;
}
.mobile-drawer-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}
.mobile-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(320px, 80vw);
  background: var(--c-surface);
  border-left: 1px solid var(--c-border);
  padding: 1.25rem 1rem;
  transform: translateX(100%);
  transition: transform 0.25s ease;
  z-index: 95;
  display: none;
}
.mobile-drawer.is-open {
  transform: translateX(0);
  display: block;
}

/* Dark theme adjustments ? make sure body, surfaces, header, drawer, newsletter all read clean */
:root[data-theme="dark"] body.home-page,
:root[data-theme="dark"] body.catalog-page,
:root[data-theme="dark"] body.about-page,
:root[data-theme="dark"] body.contact-page,
:root[data-theme="dark"] body.product-page,
:root[data-theme="dark"] body.error-page,
:root[data-theme="dark"] body.sitemap-page {
  background: var(--c-bg);
  color: var(--c-text);
}
:root[data-theme="dark"] body.home-page .site-header.site-header-main,
:root[data-theme="dark"] body.catalog-page .site-header.site-header-main,
:root[data-theme="dark"] body.about-page .site-header.site-header-main,
:root[data-theme="dark"] body.contact-page .site-header.site-header-main,
:root[data-theme="dark"] body.product-page .site-header.site-header-main,
:root[data-theme="dark"] body.error-page .site-header.site-header-main,
:root[data-theme="dark"] body.sitemap-page .site-header.site-header-main {
  background: var(--c-surface);
  border-bottom-color: var(--c-border);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.35);
}
:root[data-theme="dark"] .mobile-drawer {
  background: var(--c-surface);
  border-left-color: var(--c-border);
}
:root[data-theme="dark"] body.about-page .about-v2-hero,
:root[data-theme="dark"] body.contact-page .contact-v2-hero {
  background:
    radial-gradient(120% 80% at 100% 0%, color-mix(in srgb, var(--c-primary) 18%, transparent), transparent 55%),
    linear-gradient(165deg, var(--c-surface) 0%, var(--c-surface-2) 100%);
  border-bottom-color: var(--c-border);
}
:root[data-theme="dark"] body.about-page .about-v2-band,
:root[data-theme="dark"] body.about-page .about-v2-timeline-wrap {
  background: var(--c-surface);
  border-color: var(--c-border);
}
:root[data-theme="dark"] body.about-page .about-v2-card,
:root[data-theme="dark"] body.about-page .about-v2-stat-card,
:root[data-theme="dark"] body.about-page .about-v2-timeline li,
:root[data-theme="dark"] body.contact-page .contact-v2-form-card,
:root[data-theme="dark"] body.contact-page .contact-v2-aside-card,
:root[data-theme="dark"] body.contact-page .contact-v2-chip,
:root[data-theme="dark"] body.sitemap-page .sitemap-col,
:root[data-theme="dark"] body.sitemap-page .sitemap-hero {
  background: var(--c-surface);
  border-color: var(--c-border);
}

/* Ensure focus visible on dark theme */
:root[data-theme="dark"] :focus-visible {
  outline: 2px solid var(--c-primary);
  outline-offset: 2px;
}

/* Theme toggle icon: clean sun/moon shapes regardless of layer */
#themeToggleBtn .theme-icon {
  width: 18px;
  height: 18px;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
#themeToggleBtn .theme-icon.moon {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z'/%3E%3C/svg%3E");
}
#themeToggleBtn .theme-icon.sun {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f4f6fb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3Cpath d='M12 2v2'/%3E%3Cpath d='M12 20v2'/%3E%3Cpath d='M4.93 4.93l1.41 1.41'/%3E%3Cpath d='M17.66 17.66l1.41 1.41'/%3E%3Cpath d='M2 12h2'/%3E%3Cpath d='M20 12h2'/%3E%3Cpath d='M4.93 19.07l1.41-1.41'/%3E%3Cpath d='M17.66 6.34l1.41-1.41'/%3E%3C/svg%3E");
}

/* Scroll progress bar should not bleed colour into Leanpay strip below */
.scroll-progress {
  height: 3px;
  z-index: 200;
}
.leanpay-strip {
  position: relative;
  z-index: 1;
}

/* =====================================================================
   PASS 32 ? Homepage symmetry & polish
   - consistent vertical rhythm between sections
   - balanced grids (4 / 4 / 3 / 3 with auto-fit)
   - centered section heads where appropriate
   - hp-showcase: copy on top, steps in 2-col grid below
   - home-strip: prominent dark CTA band
   ===================================================================== */

/* Outer width: keep 1120px (symmetric on most screens) */
body.home-page main.home-main {
  width: min(1140px, 92vw) !important;
  margin-inline: auto !important;
  padding-block: clamp(1rem, 3vw, 1.6rem) clamp(1.5rem, 4vw, 2.2rem) !important;
  display: grid !important;
  gap: clamp(1rem, 2.4vw, 1.6rem) !important;
}

/* Section base ? equal padding everywhere, soft shadow */
body.home-page main.home-main > .hp-section,
body.home-page main.home-main > .home-band,
body.home-page main.home-main > .home-stats {
  margin: 0 !important;
}
body.home-page .hp-section {
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 18px !important;
  padding: clamp(1.4rem, 3.4vw, 2.2rem) clamp(1.4rem, 3.4vw, 2.2rem) !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
}

/* Section head ? centered titles for editorial sections */
body.home-page .hp-section .hp-head,
body.home-page .hp-section .home-band-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--space-5);
}
body.home-page .hp-section .hp-head .hp-eyebrow,
body.home-page .hp-section .home-band-head .hp-eyebrow {
  display: inline-block;
  margin: 0 0 0.6rem;
  padding: 0.3rem 0.8rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-primary-strong);
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 28%, transparent);
  border-radius: 999px;
}
body.home-page .hp-section .hp-head h2,
body.home-page .hp-section .home-band-head h2 {
  font-size: clamp(1.55rem, 3vw, 2.1rem) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.025em !important;
  margin: 0 0 0.6rem !important;
}
body.home-page .hp-section .hp-head > p,
body.home-page .hp-section .home-band-head > p {
  margin: 0 auto !important;
  color: var(--c-text-soft);
  max-width: 60ch;
  font-size: 0.98rem;
  line-height: 1.6;
}

/* Hero ? balanced 1:1 columns, vertical center */
body.home-page .home-hero {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr) !important;
  align-items: center !important;
  padding: clamp(1.6rem, 4vw, 2.4rem) clamp(1.6rem, 4vw, 2.6rem) !important;
}
body.home-page .home-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
body.home-page .home-hero-copy h1 {
  margin: 0 0 0.6rem !important;
}
body.home-page .home-hero-copy > p {
  margin: 0 0 1rem !important;
  font-size: 1.04rem !important;
}
body.home-page .home-hero .actions {
  display: flex;
  gap: 0.55rem;
  flex-wrap: wrap;
  margin-top: 0.4rem;
}
body.home-page .home-hero-side {
  min-height: 320px !important;
}

/* Stats ? 4 equal cards centered */
body.home-page .home-stats {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0.9rem !important;
}
body.home-page .home-stat-card {
  align-items: flex-start;
  padding: 1.2rem 1.25rem !important;
  text-align: left;
}

/* Featured cats ? 4 equal columns */
body.home-page .featured-cats-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0.9rem !important;
}
body.home-page .cat-card {
  padding: 1.25rem !important;
  min-height: 200px;
}

/* Trust ? 3 equal centered cards */
body.home-page .home-trust-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0.9rem !important;
}
body.home-page .home-trust-card {
  text-align: center;
  padding: 1.5rem 1.25rem !important;
  display: flex;
  flex-direction: column;
  align-items: center;
}
body.home-page .home-trust-card .home-trust-icon {
  margin: 0 auto 0.85rem !important;
}
body.home-page .home-trust-card h3 {
  margin: 0 0 0.4rem !important;
}
body.home-page .home-trust-card p {
  margin: 0 !important;
  max-width: 28ch;
}

/* Showcase ? head centered, then 2x2 steps */
body.home-page .hp-showcase {
  display: block !important;
}
body.home-page .hp-showcase-copy {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--space-5);
}
body.home-page .hp-showcase-copy .hp-eyebrow {
  display: inline-block;
  margin: 0 0 0.6rem;
  padding: 0.3rem 0.8rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-primary-strong);
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 28%, transparent);
  border-radius: 999px;
}
body.home-page .hp-showcase-copy h2 {
  font-size: clamp(1.55rem, 3vw, 2.1rem) !important;
  letter-spacing: -0.025em !important;
  margin: 0 0 0.6rem !important;
}
body.home-page .hp-showcase-copy > p {
  margin: 0 auto !important;
  color: var(--c-text-soft);
  max-width: 60ch;
}
body.home-page .hp-steps {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 0.7rem !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Highlight ? 3 cards, big numbered */
body.home-page .hp-highlight-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0.9rem !important;
}
body.home-page .hp-highlight-grid article {
  padding: 1.4rem 1.25rem !important;
  text-align: center;
}
body.home-page .hp-highlight-grid .hp-stat {
  font-size: 1.4rem !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 0.6rem !important;
}
body.home-page .hp-highlight-grid h3 {
  margin: 0 0 0.4rem !important;
  font-size: 1.05rem !important;
}
body.home-page .hp-highlight-grid p {
  margin: 0 auto !important;
  max-width: 32ch;
}

/* Home strip ? saturated dark CTA band, content centered */
body.home-page .home-strip {
  background:
    radial-gradient(80% 60% at 100% 0%, color-mix(in srgb, var(--c-primary) 28%, transparent), transparent 55%),
    linear-gradient(120deg, #14171c 0%, #1c2129 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  color: #e9edf6 !important;
  padding: clamp(1.8rem, 4vw, 2.6rem) clamp(1.6rem, 4vw, 2.4rem) !important;
}
body.home-page .home-strip-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.2fr) auto !important;
  gap: 1.4rem !important;
  align-items: center !important;
}
body.home-page .home-strip-grid h3 {
  color: #ffffff !important;
  font-size: clamp(1.2rem, 2.4vw, 1.55rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.015em !important;
  margin: 0 0 0.4rem !important;
}
body.home-page .home-strip-grid p {
  color: #c4cad6 !important;
  margin: 0 !important;
  line-height: 1.55;
  max-width: 56ch;
}
body.home-page .home-strip-grid .actions {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
body.home-page .home-strip-grid .btn-secondary {
  background: rgba(255, 255, 255, 0.06) !important;
  color: #ffffff !important;
  border: 1.5px solid rgba(255, 255, 255, 0.18) !important;
}
body.home-page .home-strip-grid .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: rgba(255, 255, 255, 0.32) !important;
  color: #ffffff !important;
}

/* Quotes ? 3 equal cards */
body.home-page .home-quotes-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 0.9rem !important;
}
body.home-page .home-quote {
  padding: 1.5rem 1.35rem !important;
}

/* FAQ ? centered, max width */
body.home-page .home-faq {
  text-align: left;
}
body.home-page .home-faq .home-faq-list {
  max-width: 800px;
  margin: 0 auto;
}

/* Brand bar ? properly distributed */
body.home-page .brand-bar-grid {
  justify-content: center;
  gap: 0.6rem 1.4rem;
  padding: 0.85rem 0;
}

/* Mobile responsive ? collapse grids */
@media (max-width: 980px) {
  body.home-page .home-hero {
    grid-template-columns: 1fr !important;
  }
  body.home-page .home-stats,
  body.home-page .featured-cats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  body.home-page .home-trust-grid,
  body.home-page .hp-highlight-grid,
  body.home-page .home-quotes-grid {
    grid-template-columns: 1fr !important;
  }
  body.home-page .home-strip-grid {
    grid-template-columns: 1fr !important;
  }
  body.home-page .home-strip-grid .actions {
    justify-content: flex-start;
  }
  body.home-page .hp-steps {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 540px) {
  body.home-page .home-stats,
  body.home-page .featured-cats-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Dark theme adjustments for homepage cards */
:root[data-theme="dark"] body.home-page .hp-section,
:root[data-theme="dark"] body.home-page .home-stat-card,
:root[data-theme="dark"] body.home-page .cat-card,
:root[data-theme="dark"] body.home-page .home-trust-card,
:root[data-theme="dark"] body.home-page .hp-highlight-grid article,
:root[data-theme="dark"] body.home-page .home-quote,
:root[data-theme="dark"] body.home-page .home-faq-item {
  background: var(--c-surface) !important;
  border-color: var(--c-border) !important;
}
:root[data-theme="dark"] body.home-page .home-stat-card::before {
  background: radial-gradient(circle, color-mix(in srgb, var(--c-primary) 30%, transparent), transparent 70%);
}
:root[data-theme="dark"] body.home-page .hp-steps li {
  background: var(--c-surface-2) !important;
  border-color: var(--c-border) !important;
}

/* =====================================================================
   PASS 33 ? Premium polish: hero, cards, catalog, newsletter, footer, UX
   ===================================================================== */

/* ---------- 33.1  Hero ? bigger, calmer, more confident ---------- */
body.home-page .home-hero {
  background:
    radial-gradient(900px circle at 92% 10%, color-mix(in srgb, var(--c-primary) 16%, transparent), transparent 55%),
    radial-gradient(700px circle at 0% 95%, color-mix(in srgb, var(--c-primary) 9%, transparent), transparent 55%),
    var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 22px !important;
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 26px 60px -34px color-mix(in srgb, var(--c-primary) 35%, transparent) !important;
}
body.home-page .home-hero h1 {
  font-size: clamp(2.2rem, 4.8vw, 3.4rem) !important;
  letter-spacing: -0.035em !important;
  line-height: 1.05 !important;
  font-weight: 900 !important;
}
body.home-page .home-hero-copy .hero-tags {
  margin: 0 0 1.1rem !important;
  gap: 0.4rem !important;
}
body.home-page .hero-tags span {
  font-size: 0.76rem !important;
  font-weight: 600 !important;
  padding: 0.32rem 0.7rem 0.32rem 0.6rem !important;
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  color: var(--c-text-soft) !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
}
body.home-page .home-hero .actions .btn-primary {
  box-shadow:
    0 8px 24px -8px color-mix(in srgb, var(--c-primary) 65%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
}
body.home-page .home-hero-side {
  background:
    radial-gradient(120% 100% at 100% 0%, color-mix(in srgb, var(--c-primary) 14%, transparent), transparent 60%),
    var(--c-surface-2) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 18px !important;
  position: relative;
  overflow: hidden;
}
body.home-page .hero-bullets {
  margin-top: 1.1rem !important;
  display: grid !important;
  gap: 0.5rem !important;
}
body.home-page .hero-bullets li {
  font-size: 0.93rem !important;
}

/* ---------- 33.2  Cards ? equal heights + premium hover ---------- */
body.home-page .home-stat-card,
body.home-page .cat-card,
body.home-page .home-trust-card,
body.home-page .hp-highlight-grid article,
body.home-page .home-quote {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 14px;
  transition:
    transform 0.22s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.22s ease,
    border-color 0.22s ease;
}
body.home-page .home-stat-card:hover,
body.home-page .cat-card:hover,
body.home-page .home-trust-card:hover,
body.home-page .hp-highlight-grid article:hover,
body.home-page .home-quote:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--c-primary) 32%, var(--c-border));
  box-shadow: 0 16px 32px -18px rgba(15, 23, 42, 0.18);
}

/* Cat-card icon ? bigger, soft glow */
body.home-page .cat-card::before {
  width: 44px !important;
  height: 44px !important;
  border-radius: 12px !important;
  background-size: 24px 24px !important;
  box-shadow: 0 6px 14px -8px color-mix(in srgb, var(--c-primary) 45%, transparent);
}

/* Trust-card icon ? same treatment */
body.home-page .home-trust-icon {
  width: 56px !important;
  height: 56px !important;
  border-radius: 16px !important;
  background-size: 26px 26px !important;
  box-shadow: 0 6px 14px -8px color-mix(in srgb, var(--c-primary) 45%, transparent);
}

/* Stat-card numbers stand out */
body.home-page .home-stat-num {
  font-size: clamp(1.7rem, 3.2vw, 2.4rem) !important;
  letter-spacing: -0.025em !important;
}
body.home-page .home-stat-label {
  font-size: 0.82rem !important;
  letter-spacing: 0.02em;
}

/* ---------- 33.3  Steps ? elegant card with number badge ---------- */
body.home-page .hp-steps li {
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}
body.home-page .hp-steps li:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--c-primary) 32%, var(--c-border)) !important;
  box-shadow: 0 12px 26px -16px rgba(15, 23, 42, 0.18) !important;
}

/* ---------- 33.4  Quote card refinement ---------- */
body.home-page .home-quote::before {
  font-size: 5rem !important;
  top: -0.15rem !important;
  right: 1.1rem !important;
  color: color-mix(in srgb, var(--c-primary) 20%, transparent) !important;
  font-family: Georgia, serif !important;
}
body.home-page .home-quote blockquote {
  font-size: 0.96rem !important;
  font-weight: 500 !important;
  line-height: 1.6 !important;
}
body.home-page .home-quote-avatar {
  width: 38px !important;
  height: 38px !important;
  font-size: 0.95rem !important;
  box-shadow: 0 4px 10px -4px color-mix(in srgb, var(--c-primary) 50%, transparent);
}

/* ---------- 33.5  FAQ refinement ---------- */
body.home-page .home-faq-item {
  border-radius: 14px !important;
}
body.home-page .home-faq-item summary {
  padding: 1rem 1.1rem !important;
  font-size: 1rem !important;
}
body.home-page .home-faq-item p {
  padding: 0 1.1rem 1.1rem !important;
  color: var(--c-text-soft) !important;
}

/* ---------- 33.6  Brand bar ? softer band ---------- */
body.home-page .brand-bar {
  background:
    linear-gradient(180deg, var(--c-surface) 0%, var(--c-surface-2) 100%) !important;
  border-bottom: 1px solid var(--c-border) !important;
}
body.home-page .brand-bar-name {
  font-size: 0.88rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.04em !important;
  color: color-mix(in srgb, var(--c-text) 65%, var(--c-text-soft)) !important;
  opacity: 0.85;
}
body.home-page .brand-bar-name:hover {
  color: var(--c-primary) !important;
  opacity: 1;
}
body.home-page .brand-bar-label {
  color: var(--c-muted) !important;
  border-right-color: var(--c-border) !important;
}

/* ---------- 33.7  Newsletter ? premium dark band ---------- */
.newsletter-band {
  background:
    radial-gradient(120% 100% at 100% 0%, color-mix(in srgb, var(--c-primary) 30%, transparent), transparent 55%),
    radial-gradient(80% 80% at 0% 100%, color-mix(in srgb, var(--c-primary) 18%, transparent), transparent 55%),
    linear-gradient(120deg, #0f1218 0%, #181d27 100%) !important;
  color: #e9edf6 !important;
  padding: clamp(2.4rem, 5vw, 3.4rem) 0 !important;
  margin: 0 !important;
  border-top: 1px solid color-mix(in srgb, var(--c-primary) 18%, transparent);
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}
.newsletter-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr) !important;
  gap: clamp(1rem, 3vw, 2rem) !important;
  align-items: center !important;
}
.newsletter-band .newsletter-eyebrow {
  font-size: 0.74rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: color-mix(in srgb, var(--c-primary) 65%, #ffffff) !important;
  margin: 0 0 0.4rem !important;
}
.newsletter-band .newsletter-copy h2 {
  font-size: clamp(1.55rem, 3vw, 2rem) !important;
  font-weight: 900 !important;
  color: #ffffff !important;
  letter-spacing: -0.025em !important;
  margin: 0 0 0.55rem !important;
}
.newsletter-band .newsletter-copy p {
  color: rgba(245, 247, 255, 0.78) !important;
  margin: 0 !important;
  font-size: 0.95rem !important;
  max-width: 50ch;
}
.newsletter-band .newsletter-form {
  display: flex !important;
  align-items: center !important;
  gap: 0.55rem !important;
  flex-wrap: wrap !important;
}
.newsletter-band .newsletter-input-wrap {
  flex: 1 1 240px;
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  padding: 0.5rem 0.55rem 0.5rem 0.85rem !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  border-radius: 999px !important;
  transition: border-color 0.18s ease, background 0.18s ease;
}
.newsletter-band .newsletter-input-wrap:focus-within {
  background: rgba(255, 255, 255, 0.14) !important;
  border-color: var(--c-primary) !important;
}
.newsletter-band .newsletter-input-wrap input {
  flex: 1;
  border: 0 !important;
  background: transparent !important;
  color: #fff !important;
  outline: 0 !important;
  font-size: 0.94rem !important;
  padding: 0 0.25rem !important;
  min-height: auto !important;
}
.newsletter-band .newsletter-form .btn-primary {
  padding: 0.7rem 1.2rem !important;
  border-radius: 999px !important;
  font-weight: 800 !important;
  white-space: nowrap;
  box-shadow:
    0 10px 24px -10px color-mix(in srgb, var(--c-primary) 80%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
}
.newsletter-band .newsletter-status {
  flex-basis: 100%;
  margin: 0.2rem 0 0 !important;
  font-size: 0.82rem !important;
  color: rgba(245, 247, 255, 0.7) !important;
}
@media (max-width: 880px) {
  .newsletter-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ---------- 33.8  Footer ? better cols + brand block ---------- */
body.home-page .site-footer .footer-grid,
body.catalog-page .site-footer .footer-grid,
body.about-page .site-footer .footer-grid,
body.contact-page .site-footer .footer-grid,
body.product-page .site-footer .footer-grid,
body.error-page .site-footer .footer-grid,
body.sitemap-page .site-footer .footer-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: clamp(1rem, 3vw, 2.4rem) !important;
  padding: clamp(1.6rem, 3.5vw, 2.4rem) 0 !important;
  align-items: start !important;
}
.site-footer .footer-col-brand .footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: var(--fc-text);
  margin-bottom: 0.6rem;
}
.site-footer .footer-col-brand .footer-about {
  color: var(--fc-text-soft) !important;
  font-size: 0.92rem;
  line-height: 1.55;
  max-width: 36ch;
  margin: 0;
}
.site-footer .footer-col-nav {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.site-footer .footer-col-nav a {
  color: var(--fc-text-soft) !important;
  text-decoration: none;
  font-size: 0.92rem;
  transition: color 0.18s ease;
}
.site-footer .footer-col-nav a:hover {
  color: var(--c-primary) !important;
}
.site-footer .footer-col-title {
  margin: 0 0 0.65rem !important;
  font-size: 0.74rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--fc-text) !important;
}
.site-footer .footer-contact-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.4rem;
}
.site-footer .footer-contact-list li {
  font-size: 0.9rem;
  color: var(--fc-text-soft);
  line-height: 1.5;
}
@media (max-width: 880px) {
  body.home-page .site-footer .footer-grid,
  body.catalog-page .site-footer .footer-grid,
  body.about-page .site-footer .footer-grid,
  body.contact-page .site-footer .footer-grid,
  body.product-page .site-footer .footer-grid,
  body.error-page .site-footer .footer-grid,
  body.sitemap-page .site-footer .footer-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ---------- 33.9  Catalog (products.html) polish ---------- */
body.catalog-page .catalog-hero {
  background:
    radial-gradient(900px circle at 90% 10%, color-mix(in srgb, var(--c-primary) 14%, transparent), transparent 55%),
    var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 22px !important;
  padding: clamp(1.6rem, 4vw, 2.4rem) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, auto) !important;
  gap: 1.5rem !important;
  align-items: center !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
body.catalog-page .catalog-breadcrumb {
  font-size: 0.76rem !important;
  color: var(--c-muted) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  margin: 0 0 0.5rem !important;
}
body.catalog-page .catalog-title {
  font-size: clamp(1.85rem, 3.6vw, 2.6rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.03em !important;
  margin: 0 0 0.6rem !important;
}
body.catalog-page .catalog-hero-lead {
  margin: 0 !important;
  font-size: 1rem !important;
  color: var(--c-text-soft) !important;
  max-width: 56ch;
}
body.catalog-page .catalog-hero-meta {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 0.2rem !important;
}
body.catalog-page .catalog-meta-stat {
  font-size: clamp(2rem, 4vw, 2.8rem) !important;
}
@media (max-width: 720px) {
  body.catalog-page .catalog-hero {
    grid-template-columns: 1fr !important;
  }
  body.catalog-page .catalog-hero-meta {
    align-items: flex-start !important;
  }
}

body.catalog-page .toolbar-wrap {
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 18px !important;
  padding: 1rem 1.1rem !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
body.catalog-page .toolbar {
  display: grid !important;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 0.8fr) minmax(0, 0.8fr) !important;
  gap: 0.6rem !important;
  align-items: center;
}
body.catalog-page .toolbar-search {
  position: relative;
}
body.catalog-page .toolbar input[type="search"],
body.catalog-page .toolbar select,
body.catalog-page .toolbar input[type="number"] {
  height: 44px !important;
  border-radius: 12px !important;
  border: 1px solid var(--c-border) !important;
  background: var(--c-surface) !important;
  padding: 0 0.85rem !important;
  font-size: 0.94rem !important;
  color: var(--c-text) !important;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
body.catalog-page .toolbar input[type="search"]:focus,
body.catalog-page .toolbar select:focus,
body.catalog-page .toolbar input[type="number"]:focus {
  outline: 0 !important;
  border-color: var(--c-primary) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 20%, transparent) !important;
}
body.catalog-page .toolbar-price {
  grid-column: 1 / -1;
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: 12px;
  padding: 0.25rem 0.4rem;
  margin-top: 0.5rem;
}
body.catalog-page .toolbar-price-input {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0 0.5rem;
}
body.catalog-page .toolbar-price-prefix {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-muted);
  font-weight: 700;
}
body.catalog-page .toolbar-price input {
  flex: 1;
  border: 0 !important;
  background: transparent !important;
  height: 36px !important;
  padding: 0 !important;
  text-align: right;
}
body.catalog-page .toolbar-price input:focus {
  box-shadow: none !important;
}
body.catalog-page .toolbar-price-suffix {
  color: var(--c-text-soft);
  font-weight: 700;
}
body.catalog-page .toolbar-price-dash {
  color: var(--c-muted);
  font-weight: 700;
}
body.catalog-page .toolbar-hint {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.45rem !important;
  margin-top: 0.7rem !important;
  font-size: 0.82rem !important;
  color: var(--c-muted) !important;
}
@media (max-width: 720px) {
  body.catalog-page .toolbar {
    grid-template-columns: 1fr !important;
  }
}

body.catalog-page #productGrid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: clamp(0.85rem, 2vw, 1.1rem) !important;
  margin-top: 1.2rem !important;
}
body.catalog-page .product-grid .card {
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 18px !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition:
    transform 0.22s cubic-bezier(0.22, 0.61, 0.36, 1),
    box-shadow 0.22s ease,
    border-color 0.22s ease;
}
body.catalog-page .product-grid .card:hover {
  transform: translateY(-3px) !important;
  border-color: color-mix(in srgb, var(--c-primary) 30%, var(--c-border)) !important;
  box-shadow: 0 22px 44px -22px rgba(15, 23, 42, 0.22) !important;
}
body.catalog-page .product-grid .card-media {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--c-surface-2);
  overflow: hidden;
}
body.catalog-page .product-grid .card-media img,
body.catalog-page .product-grid .card-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.4s ease;
}
body.catalog-page .product-grid .card:hover .card-image {
  transform: scale(1.05);
}
body.catalog-page .product-grid .card-body {
  padding: 1rem 1.1rem 1.1rem !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0.5rem !important;
  flex: 1 1 auto;
}
body.catalog-page .product-grid .card-body .category {
  display: inline-block;
  font-size: 0.7rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--c-primary-strong) !important;
  background: var(--c-primary-soft) !important;
  border-radius: 999px;
  padding: 0.22rem 0.55rem;
  align-self: flex-start;
}
body.catalog-page .product-grid .card-body h3 {
  margin: 0 !important;
  font-size: 1.02rem !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
body.catalog-page .product-grid .card-body .price {
  font-size: 1.2rem !important;
  font-weight: 900 !important;
  color: var(--c-text) !important;
  margin: 0 !important;
}
body.catalog-page .product-grid .card-body .price.has-discount .price-final {
  color: var(--c-primary-strong) !important;
}
body.catalog-page .product-grid .card-body .price-original {
  color: var(--c-muted) !important;
  font-size: 0.85rem;
  margin-left: 0.4rem;
  font-weight: 600;
}
body.catalog-page .product-grid .card-body .price-save {
  display: block;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--c-success);
  margin-top: 0.15rem;
}
body.catalog-page .product-grid .card-body .card-description {
  font-size: 0.86rem !important;
  color: var(--c-text-soft) !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
body.catalog-page .card-badges {
  position: absolute;
  top: 12px;
  left: 12px;
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  z-index: 2;
}
body.catalog-page .card-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.6rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: rgba(15, 23, 42, 0.85);
  color: #fff;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
body.catalog-page .card-badge-sale {
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
}
body.catalog-page .card-badge-new {
  background: linear-gradient(180deg, #16a34a 0%, #0d8a3d 100%);
}
/* Empty state polish (used while no articles yet) */
body.catalog-page .empty-state {
  grid-column: 1 / -1;
  text-align: center;
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 3vw, 2rem);
  background: var(--c-surface);
  border: 1px dashed var(--c-border-strong);
  border-radius: 18px;
}
body.catalog-page .empty-state-icon {
  display: inline-grid;
  place-items: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  margin-bottom: 0.85rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 28px 28px;
}
body.catalog-page .empty-state h3 {
  margin: 0 0 0.45rem;
  font-size: 1.15rem;
}
body.catalog-page .empty-state p {
  margin: 0 auto 1rem;
  max-width: 42ch;
  color: var(--c-text-soft);
}

/* Catalog stats row + view toggle */
body.catalog-page .catalog-stats-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 0.8rem !important;
  margin-top: 1rem !important;
  flex-wrap: wrap;
}
body.catalog-page .result-count {
  margin: 0 !important;
  color: var(--c-text-soft) !important;
  font-size: 0.92rem !important;
}
body.catalog-page .view-toggle {
  display: inline-flex;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 999px;
  padding: 3px;
}
body.catalog-page .view-toggle button {
  width: 38px;
  height: 32px;
  border: 0;
  background: transparent;
  color: var(--c-text-soft);
  border-radius: 999px;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background 0.18s ease, color 0.18s ease;
}
body.catalog-page .view-toggle button:hover {
  color: var(--c-text);
}
body.catalog-page .view-toggle button.is-active {
  background: var(--c-primary-soft);
  color: var(--c-primary-strong);
}

/* ---------- 33.10  Product page polish ---------- */
body.product-page main.product-main {
  width: min(1140px, 92vw) !important;
  margin-inline: auto !important;
  padding-block: clamp(1.5rem, 4vw, 2.4rem) clamp(1.5rem, 4vw, 2.4rem) !important;
}
body.product-page .product-shell {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr) !important;
  gap: clamp(1.2rem, 3vw, 2rem) !important;
  align-items: start;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 22px;
  padding: clamp(1.2rem, 3vw, 2rem);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
body.product-page .product-gallery-frame {
  background: var(--c-surface-2);
  border-radius: 18px;
  border: 1px solid var(--c-border);
  overflow: hidden;
  position: relative;
  aspect-ratio: 4 / 3;
}
body.product-page .product-gallery-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
body.product-page .product-title {
  font-size: clamp(1.6rem, 3vw, 2.2rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.025em !important;
  line-height: 1.15 !important;
  margin: 0.4rem 0 0.5rem !important;
}
body.product-page .product-cat-pill,
body.product-page .product-id-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
body.product-page .product-cat-pill {
  color: var(--c-primary-strong);
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  text-decoration: none;
}
body.product-page .product-id-pill {
  color: var(--c-muted);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  letter-spacing: 0.04em;
}
body.product-page .product-price {
  font-size: clamp(1.8rem, 3.4vw, 2.4rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.025em !important;
}
body.product-page .product-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.55rem !important;
  margin-top: 0.85rem !important;
}
body.product-page .product-spec-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
  gap: 0.7rem !important;
  margin-top: 1.2rem !important;
}
body.product-page .product-spec {
  padding: 0.85rem 1rem !important;
  background: var(--c-surface-2) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 12px !important;
}
body.product-page .product-spec dt {
  font-size: 0.72rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--c-muted) !important;
  margin: 0 0 0.25rem !important;
}
body.product-page .product-spec dd {
  margin: 0 !important;
  font-size: 0.94rem !important;
  font-weight: 700 !important;
  color: var(--c-text) !important;
}
body.product-page .product-key-list {
  list-style: none;
  margin: 1rem 0 0 !important;
  padding: 0 !important;
  display: grid;
  gap: 0.5rem;
}
body.product-page .product-key-list li {
  display: flex !important;
  align-items: center !important;
  gap: 0.55rem !important;
  font-size: 0.92rem !important;
  color: var(--c-text-soft) !important;
}
body.product-page .product-key-icon {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--c-primary-soft);
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  flex-shrink: 0;
}
body.product-page .product-key-icon::after {
  content: "";
  width: 12px;
  height: 12px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff4f33' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center / contain no-repeat;
}
@media (max-width: 880px) {
  body.product-page .product-shell {
    grid-template-columns: 1fr !important;
  }
}

/* ---------- 33.11  Buttons ? confident shape across the site ---------- */
.btn-primary,
.btn-secondary,
.link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.72rem 1.15rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.92rem;
  letter-spacing: 0.01em;
  text-decoration: none;
  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease;
  min-height: 42px;
  white-space: nowrap;
  border: 1px solid transparent;
}
.btn-primary {
  background: linear-gradient(180deg, var(--c-primary) 0%, var(--c-primary-strong) 100%);
  color: #fff;
  border-color: var(--c-primary-strong);
  box-shadow:
    0 8px 20px -10px color-mix(in srgb, var(--c-primary) 60%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.btn-primary:hover {
  transform: translateY(-1px);
  filter: brightness(1.04);
  box-shadow:
    0 12px 28px -12px color-mix(in srgb, var(--c-primary) 70%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}
.btn-secondary {
  background: var(--c-surface);
  color: var(--c-text);
  border-color: var(--c-border-strong);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.btn-secondary:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border-strong));
  background: var(--c-surface-2);
}

/* ---------- 33.12  Focus ring everywhere ---------- */
:focus-visible {
  outline: 2px solid var(--c-primary);
  outline-offset: 2px;
  border-radius: 6px;
}

/* ---------- 33.14  Selection + scrollbar tone ---------- */
::selection {
  background: color-mix(in srgb, var(--c-primary) 35%, transparent);
  color: var(--c-text);
}
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
::-webkit-scrollbar-track {
  background: var(--c-surface-2);
}
::-webkit-scrollbar-thumb {
  background: var(--c-border-strong);
  border-radius: 999px;
  border: 2px solid var(--c-surface-2);
}
::-webkit-scrollbar-thumb:hover {
  background: color-mix(in srgb, var(--c-primary) 50%, var(--c-border-strong));
}

/* ---------- 33.15  Toast notification refinement ---------- */
.toast {
  background: var(--c-surface);
  color: var(--c-text);
  border: 1px solid var(--c-border);
  border-left: 4px solid var(--c-primary);
  border-radius: 12px;
  padding: 0.85rem 1.05rem;
  box-shadow: 0 18px 40px -16px rgba(15, 23, 42, 0.22);
  font-size: 0.92rem;
  font-weight: 600;
}
.toast.success { border-left-color: var(--c-success); }
.toast.error { border-left-color: var(--c-primary-strong); }

/* ---------- 33.16  Skip-link visible on focus ---------- */
.skip-link {
  position: absolute;
  top: -40px;
  left: 12px;
  padding: 0.6rem 1rem;
  background: var(--c-primary);
  color: #fff;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 700;
  z-index: 1000;
  transition: top 0.2s ease;
}
.skip-link:focus {
  top: 12px;
}

/* ---------- 33.17  Dark theme final tweaks ---------- */
:root[data-theme="dark"] body.catalog-page .catalog-hero,
:root[data-theme="dark"] body.catalog-page .toolbar-wrap,
:root[data-theme="dark"] body.catalog-page .product-grid .card,
:root[data-theme="dark"] body.product-page .product-shell,
:root[data-theme="dark"] body.product-page .product-spec {
  background: var(--c-surface);
  border-color: var(--c-border);
}
:root[data-theme="dark"] body.catalog-page .empty-state {
  background: var(--c-surface);
  border-color: var(--c-border-strong);
}
:root[data-theme="dark"] body.catalog-page .product-grid .card-body .category {
  color: color-mix(in srgb, var(--c-primary) 75%, #fff);
  background: color-mix(in srgb, var(--c-primary) 18%, transparent);
}

/* =====================================================================
   PASS 34 ? Header, mobile drawer, leanpay strip, back-to-top polish
   ===================================================================== */

/* Header ? clean glass-on-scroll feel */
.site-header.site-header-main {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--c-surface) 92%, transparent);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--c-border);
}
.site-header .nav-wrap {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  gap: 0.85rem 1.1rem !important;
  align-items: center !important;
  padding-block: 0.65rem !important;
}
.site-header .brand-link {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  text-decoration: none !important;
}
.site-header .brand-text-main {
  font-weight: 900 !important;
  font-size: 1.12rem !important;
  letter-spacing: -0.02em !important;
  color: var(--c-text) !important;
  display: block;
}
.site-header .brand-text-sub {
  font-size: 0.66rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--c-primary-strong) !important;
  display: block;
  margin-top: -0.1rem;
}

/* Header search bar ? pill */
.site-header .header-search-form {
  display: flex !important;
  align-items: center !important;
  gap: 0.4rem !important;
  background: var(--c-surface-2) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 999px !important;
  padding: 0.32rem 0.4rem 0.32rem 0.95rem !important;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}
.site-header .header-search-form:focus-within {
  border-color: var(--c-primary) !important;
  background: var(--c-surface) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 18%, transparent) !important;
}
.site-header .header-search-input {
  flex: 1 !important;
  border: 0 !important;
  background: transparent !important;
  outline: 0 !important;
  font-size: 0.92rem !important;
  color: var(--c-text) !important;
  min-height: 32px !important;
}
.site-header .header-search-submit {
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  border: 0 !important;
  background: var(--c-primary) !important;
  cursor: pointer !important;
  display: grid !important;
  place-items: center !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-size: 16px 16px !important;
  transition: background-color 0.18s ease, transform 0.18s ease;
}
.site-header .header-search-submit:hover {
  background-color: var(--c-primary-strong) !important;
  transform: scale(1.04);
}

/* Site nav ? refined link style */
.site-header .site-nav {
  display: flex !important;
  align-items: center !important;
  gap: 0.2rem !important;
}
.site-header .site-nav a {
  position: relative;
  padding: 0.5rem 0.85rem !important;
  border-radius: 10px !important;
  font-size: 0.92rem !important;
  font-weight: 600 !important;
  color: var(--c-text-soft) !important;
  text-decoration: none !important;
  transition: color 0.18s ease, background 0.18s ease;
}
.site-header .site-nav a:hover {
  color: var(--c-text) !important;
  background: var(--c-surface-2) !important;
}
.site-header .site-nav a.active {
  color: var(--c-primary-strong) !important;
  background: var(--c-primary-soft) !important;
}

/* Header right cluster */
.site-header .actions {
  display: flex !important;
  align-items: center !important;
  gap: 0.45rem !important;
}
.site-header .theme-toggle {
  width: 40px !important;
  height: 40px !important;
  min-height: 40px !important;
  border-radius: 50% !important;
  padding: 0 !important;
  display: grid !important;
  place-items: center !important;
}

/* Responsive header */
@media (max-width: 1080px) {
  .site-header .nav-wrap {
    grid-template-columns: auto 1fr auto !important;
  }
  .site-header .header-search { display: none !important; }
}
@media (max-width: 880px) {
  .site-header .nav-wrap {
    grid-template-columns: auto auto !important;
    justify-content: space-between !important;
  }
  .site-header .site-nav { display: none !important; }
  .site-header .nav-toggle { display: inline-flex !important; }
}

/* Mobile drawer */
.mobile-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: min(320px, 86vw);
  height: 100dvh;
  background: var(--c-surface);
  border-left: 1px solid var(--c-border);
  box-shadow: -28px 0 40px -28px rgba(15, 23, 42, 0.25);
  z-index: 100;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.22, 0.61, 0.36, 1);
  padding: 4.2rem 1.1rem 1.4rem;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.mobile-drawer.is-open {
  transform: translateX(0);
}
.mobile-drawer[aria-hidden="false"] {
  transform: translateX(0);
}
.mobile-drawer-link {
  padding: 0.85rem 0.95rem;
  border-radius: 12px;
  font-weight: 600;
  font-size: 0.98rem;
  color: var(--c-text-soft);
  text-decoration: none;
  border: 1px solid transparent;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.mobile-drawer-link:hover {
  background: var(--c-surface-2);
  color: var(--c-text);
}
.mobile-drawer-link.is-active {
  background: var(--c-primary-soft);
  color: var(--c-primary-strong);
  border-color: color-mix(in srgb, var(--c-primary) 25%, transparent);
}
.mobile-drawer-divider {
  height: 1px;
  background: var(--c-border);
  margin: 0.7rem 0;
}
.mobile-drawer-meta {
  display: grid;
  gap: 0.35rem;
  padding: 0 0.6rem;
  font-size: 0.92rem;
  color: var(--c-text-soft);
}
.mobile-drawer-meta a {
  color: var(--c-primary-strong);
  text-decoration: none;
  font-weight: 700;
}

.mobile-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
  z-index: 99;
}
.mobile-drawer-overlay.is-open,
.mobile-drawer-overlay[aria-hidden="false"] {
  opacity: 1;
  pointer-events: auto;
}
body.nav-open {
  overflow: hidden;
}

/* Leanpay strip ? premium dark band, marquee-like */
.leanpay-strip {
  background: linear-gradient(90deg, #0f1218 0%, #181d27 100%);
  color: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid color-mix(in srgb, var(--c-primary) 18%, transparent);
  padding: 0.55rem 0;
  position: relative;
  z-index: 1;
}
.leanpay-track {
  display: flex !important;
  align-items: center !important;
  gap: 0.85rem 1.4rem !important;
  flex-wrap: wrap !important;
  font-size: 0.84rem !important;
  letter-spacing: 0.01em;
}
.leanpay-track strong {
  color: #fff !important;
  font-weight: 800;
}
.leanpay-track span:not(.leanpay-pulse) {
  color: rgba(255, 255, 255, 0.72) !important;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.leanpay-track span:not(.leanpay-pulse)::before {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--c-primary) 70%, #fff);
  flex-shrink: 0;
}
.leanpay-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--c-primary);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--c-primary) 80%, transparent);
  animation: lpPulse 1.8s ease-out infinite;
}
@keyframes lpPulse {
  0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--c-primary) 70%, transparent); }
  100% { box-shadow: 0 0 0 12px transparent; }
}

/* Back-to-top button */
#backToTop, .back-to-top {
  position: fixed;
  right: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 2rem);
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: 0;
  background: var(--c-primary);
  color: #fff;
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 40;
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity 0.25s ease, transform 0.25s ease, background 0.18s ease;
  box-shadow: 0 14px 28px -10px color-mix(in srgb, var(--c-primary) 60%, transparent);
}
#backToTop.is-visible, .back-to-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
#backToTop:hover, .back-to-top:hover {
  background: var(--c-primary-strong);
}
#backToTop::before, .back-to-top::before {
  content: "";
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='18 15 12 9 6 15'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* Scroll progress bar */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0;
  background: linear-gradient(90deg, var(--c-primary), color-mix(in srgb, var(--c-primary) 65%, #fff));
  z-index: 200;
  transition: width 0.08s linear;
}

/* Dark theme refinements for header + drawer */
:root[data-theme="dark"] .site-header.site-header-main {
  background: color-mix(in srgb, var(--c-surface) 88%, transparent);
}
:root[data-theme="dark"] .site-header .header-search-form {
  background: var(--c-surface-2);
  border-color: var(--c-border);
}
:root[data-theme="dark"] .site-header .nav-toggle {
  background: var(--c-surface-2);
  border-color: var(--c-border);
}
:root[data-theme="dark"] .mobile-drawer {
  background: var(--c-surface);
  border-color: var(--c-border);
}

/* =====================================================================
   PASS 39 ? Final cohesion (user feedback)
   - Remove orange dot marker before eyebrow titles
   - Convert hp-section cards into one flowing page with thin separators
   - Tighter, cleaner header search pill (no glow leak)
   - Theme toggle bullet-proof one-icon rule
   - Centered, accent-on-hover footer
   ===================================================================== */

/* -- 39.1 Eyebrow without the orange dot ----------------------------- */
html body.home-page .home-kicker::before,
html body.about-page .about-kicker::before,
html body.contact-page .contact-kicker::before,
html body.home-page .hp-eyebrow::before,
html body.home-page .hp-section .hp-eyebrow::before,
html body.home-page .hp-section .hp-head .hp-eyebrow::before,
html body.home-page .hp-section .home-band-head .hp-eyebrow::before {
  content: none !important;
  display: none !important;
}
html body.home-page .home-kicker,
html body.about-page .about-kicker,
html body.contact-page .contact-kicker,
html body.home-page .hp-eyebrow,
html body.home-page .hp-section .hp-eyebrow {
  padding: 0.3rem 0.85rem !important;
  gap: 0 !important;
}

/* -- 39.2 One flowing page: invisible section cards + separators ----- */
html body.home-page main.home-main {
  gap: clamp(2rem, 4.4vw, 3.4rem) !important;
}
html body.home-page main.home-main > .hp-section,
html body.home-page main.home-main > .home-band,
html body.home-page main.home-main > .home-stats,
html body.home-page main.home-main > .home-hero {
  position: relative;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-top: clamp(1.6rem, 3.2vw, 2.4rem) !important;
  padding-bottom: clamp(1.6rem, 3.2vw, 2.4rem) !important;
  margin: 0 !important;
  overflow: visible !important;
}

/* Hero keeps its premium glass look but loses heavy borders */
html body.home-page main.home-main > .home-hero {
  background:
    radial-gradient(circle at 12% 8%, color-mix(in srgb, var(--c-primary) 10%, transparent), transparent 55%),
    linear-gradient(170deg, color-mix(in srgb, var(--c-surface-2) 70%, var(--c-surface)), var(--c-surface)) !important;
  border: 1px solid color-mix(in srgb, var(--c-primary) 14%, var(--c-border)) !important;
  border-radius: var(--radius-lg) !important;
  padding: clamp(1.6rem, 4vw, 2.6rem) clamp(1.6rem, 4vw, 2.6rem) !important;
  box-shadow: var(--shadow-md) !important;
}

/* Hairline separator between sections (skip first + hero) */
html body.home-page main.home-main > .hp-section + .hp-section::before,
html body.home-page main.home-main > .home-band + .hp-section::before,
html body.home-page main.home-main > .hp-section + .home-band::before,
html body.home-page main.home-main > .home-band + .home-band::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(100%, 1080px);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--c-border-strong) 18%, var(--c-border-strong) 82%, transparent);
  opacity: 0.65;
}
html body.home-page main.home-main > .home-strip {
  margin: clamp(0.5rem, 2vw, 1.2rem) 0 !important;
  border-radius: var(--radius-lg) !important;
  padding: clamp(1.4rem, 3vw, 2rem) clamp(1.4rem, 3vw, 2rem) !important;
}

/* Drop dark-mode card backgrounds on home sections too */
:root[data-theme="dark"] html body.home-page main.home-main > .hp-section,
:root[data-theme="dark"] html body.home-page main.home-main > .home-band,
:root[data-theme="dark"] html body.home-page main.home-main > .home-stats {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
:root[data-theme="dark"] html body.home-page main.home-main > .home-hero {
  background:
    radial-gradient(circle at 12% 8%, color-mix(in srgb, var(--c-primary) 18%, transparent), transparent 55%),
    linear-gradient(170deg, color-mix(in srgb, var(--c-surface-2) 80%, var(--c-surface)), var(--c-surface)) !important;
  border-color: color-mix(in srgb, var(--c-primary) 22%, var(--c-border-strong)) !important;
}

/* -- 39.3 Clean header search pill (no orange glow bleed) ------------ */
html body .header-search.nav-search {
  background: var(--c-surface-2) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 999px !important;
  padding: 4px 4px 4px 1rem !important;
  box-shadow: none !important;
  height: 44px !important;
  align-items: center !important;
}
:root[data-theme="dark"] html body .header-search.nav-search {
  background: color-mix(in srgb, var(--c-surface-2) 92%, transparent) !important;
}
html body .header-search.nav-search:focus-within {
  border-color: color-mix(in srgb, var(--c-primary) 50%, var(--c-border)) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 18%, transparent) !important;
}
html body .header-search-form {
  align-items: center !important;
  height: 100% !important;
}
html body .header-search-input {
  padding: 0 0.5rem 0 0 !important;
  height: 36px !important;
  line-height: 36px !important;
  font-size: 0.93rem !important;
  background: transparent !important;
}
html body .header-search-submit {
  width: 36px !important;
  height: 36px !important;
  flex: 0 0 36px !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  background: var(--c-primary) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E") center / 16px no-repeat !important;
}
html body .header-search-submit:hover {
  background-color: var(--c-primary-strong) !important;
  transform: none !important;
  box-shadow: none !important;
}

/* -- 39.4 Bullet-proof theme toggle: exactly one icon, centered ------ */
html body #themeToggleBtn.theme-toggle {
  position: relative;
  width: 38px !important;
  height: 38px !important;
  min-width: 0 !important;
  padding: 0 !important;
  display: inline-grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  border: 1px solid var(--c-border) !important;
  background: var(--c-surface-2) !important;
  overflow: hidden;
}
html body #themeToggleBtn.theme-toggle::before,
html body #themeToggleBtn.theme-toggle::after {
  content: none !important;
  display: none !important;
}
html body #themeToggleBtn.theme-toggle > * {
  display: none !important;
}
html body #themeToggleBtn.theme-toggle > .theme-icon {
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 18px 18px !important;
  background-color: transparent !important;
  border: 0 !important;
  filter: none !important;
}

/* -- 39.5 Footer polish: dark, readable, brand color accents -------- */
html body .site-footer {
  background: var(--fc-bg) !important;
  color: var(--fc-text) !important;
  border-top: 0 !important;
  padding-top: clamp(2rem, 4vw, 3rem) !important;
}
html body .site-footer .footer-grid {
  grid-template-columns: 1.2fr 1fr 1fr !important;
  gap: clamp(1.5rem, 4vw, 3rem) !important;
  padding-bottom: clamp(1.6rem, 3vw, 2.4rem) !important;
}
html body .site-footer .footer-brand .brand-text-main {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  background: none !important;
  font-weight: 800;
}
html body .site-footer .footer-brand .brand-text-sub {
  color: var(--fc-text-soft) !important;
}
html body .site-footer .footer-col-title {
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: #ffffff !important;
  margin: 0 0 0.95rem !important;
}
html body .site-footer .footer-col-nav {
  display: flex !important;
  flex-direction: column;
  gap: 0.55rem !important;
}
html body .site-footer .footer-col-nav a {
  color: var(--fc-text) !important;
  text-decoration: none !important;
  font-weight: 500;
  font-size: 0.93rem;
  transition: color 0.15s ease, transform 0.15s ease;
}
html body .site-footer .footer-col-nav a::before {
  display: none !important;
}
html body .site-footer .footer-col-nav a:hover {
  color: var(--c-primary) !important;
  transform: translateX(2px);
}
html body .site-footer .footer-contact-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column;
  gap: 0.55rem !important;
  font-size: 0.92rem;
  color: var(--fc-text) !important;
}
html body .site-footer .footer-contact-list li {
  color: var(--fc-text) !important;
}
html body .site-footer .footer-contact-list a {
  color: var(--fc-text) !important;
  text-decoration: none !important;
  border-bottom: 1px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
}
html body .site-footer .footer-contact-list a:hover {
  color: var(--c-primary) !important;
  border-bottom-color: color-mix(in srgb, var(--c-primary) 50%, transparent);
}
html body .site-footer .footer-contact-label {
  color: var(--fc-text-soft) !important;
  font-size: 0.78rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  margin-right: 0.35rem !important;
  font-weight: 600;
}
html body .site-footer .footer-about {
  margin: 0.7rem 0 0 !important;
  color: var(--fc-text-soft) !important;
  font-size: 0.9rem !important;
  line-height: 1.6 !important;
  max-width: 34ch;
}
html body .site-footer .footer-brand-logo {
  filter: none !important;
}
html body .site-footer .footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
  background: var(--fc-bg-2, #0e1013) !important;
  margin-top: 0 !important;
}
html body .site-footer .footer-bottom-inner {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 0 !important;
  flex-wrap: wrap;
}
html body .site-footer .footer-copy,
html body .site-footer .footer-credit {
  color: var(--fc-text-soft) !important;
  font-size: 0.82rem;
}
html body .site-footer .footer-credit-link {
  color: var(--c-primary) !important;
  text-decoration: none;
  font-weight: 700;
  margin-left: 0.3rem;
}
html body .site-footer .footer-credit-link:hover {
  text-decoration: underline;
}
@media (max-width: 720px) {
  html body .site-footer .footer-grid {
    grid-template-columns: 1fr !important;
  }
  html body .site-footer .footer-bottom-inner {
    flex-direction: column;
    text-align: center;
  }
}

/* =====================================================================
   PASS 41 ? Restore dark home-strip + FAQ polish
   Pass 39 made every .hp-section transparent, but .home-strip is
   actually a dark CTA band ? force it back into a premium dark card.
   ===================================================================== */

/* -- 41.1 Home strip stays a dark band ------------------------------- */
html body.home-page main.home-main > section.home-strip.hp-section {
  background:
    radial-gradient(circle at 88% 50%, color-mix(in srgb, var(--c-primary) 28%, transparent), transparent 55%),
    linear-gradient(120deg, #14171c 0%, #1c2129 100%) !important;
  color: #e9edf6 !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: var(--radius-lg) !important;
  padding: clamp(1.4rem, 3.2vw, 2.2rem) clamp(1.6rem, 4vw, 2.6rem) !important;
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.25),
    0 24px 60px -28px rgba(0, 0, 0, 0.55) !important;
  isolation: isolate;
  overflow: hidden;
  position: relative;
}
html body.home-page main.home-main > section.home-strip.hp-section::before {
  display: none !important;
}
html body.home-page .home-strip .home-strip-grid {
  align-items: center;
  gap: clamp(1rem, 3vw, 2rem);
}
html body.home-page .home-strip h3 {
  color: #ffffff !important;
  font-size: clamp(1.2rem, 2.2vw, 1.55rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  margin: 0 0 0.45rem !important;
  line-height: 1.2 !important;
}
html body.home-page .home-strip p {
  color: #c4cad6 !important;
  margin: 0 !important;
  font-size: 0.96rem;
  line-height: 1.55;
  max-width: 56ch;
}
html body.home-page .home-strip .actions {
  display: inline-flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}
html body.home-page .home-strip .btn-secondary,
html body.home-page .home-strip a.btn-secondary {
  background: rgba(255, 255, 255, 0.06) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255, 255, 255, 0.22) !important;
  backdrop-filter: blur(6px);
}
html body.home-page .home-strip .btn-secondary:hover,
html body.home-page .home-strip a.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
  color: #ffffff !important;
}
html body.home-page .home-strip .btn-primary,
html body.home-page .home-strip a.btn-primary {
  box-shadow: 0 12px 28px -10px color-mix(in srgb, var(--c-primary) 60%, transparent) !important;
}

/* -- 41.2 FAQ items: softer, cleaner ---------------------------------- */
html body.home-page .home-faq-list {
  max-width: 880px;
  margin: 0 auto !important;
}
html body.home-page .home-faq-item {
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 14px !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}
html body.home-page .home-faq-item:hover {
  border-color: color-mix(in srgb, var(--c-primary) 22%, var(--c-border));
  box-shadow: 0 6px 18px -10px rgba(15, 23, 42, 0.18) !important;
}
html body.home-page .home-faq-item[open] {
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border));
  box-shadow: 0 10px 24px -14px rgba(15, 23, 42, 0.25) !important;
}
html body.home-page .home-faq-item summary {
  padding: 1.05rem 1.25rem !important;
  color: var(--c-text) !important;
}
html body.home-page .home-faq-item summary:hover {
  background: color-mix(in srgb, var(--c-primary) 4%, transparent) !important;
}

/* Dark theme strip refinements (already dark, just tighten) */
:root[data-theme="dark"] html body.home-page main.home-main > section.home-strip.hp-section {
  background:
    radial-gradient(circle at 88% 50%, color-mix(in srgb, var(--c-primary) 32%, transparent), transparent 55%),
    linear-gradient(120deg, #0c0e12 0%, #14171c 100%) !important;
  border-color: rgba(255, 255, 255, 0.06) !important;
}
:root[data-theme="dark"] html body.home-page .home-faq-item {
  background: var(--c-surface-2) !important;
  border-color: var(--c-border-strong) !important;
}

/* =====================================================================
   PASS 42 ? NUCLEAR search bar lock-down
   Earlier .site-header .header-search-submit (specificity 0,2,0) was
   beating our html body rules. This block uses html body .site-header
   (0,2,2) so it always wins, and removes every glow / scale / overflow.
   ===================================================================== */

html body .site-header .header-search.nav-search,
html body .site-header.site-header-main .header-search.nav-search {
  display: flex !important;
  align-items: center !important;
  gap: 0 !important;
  width: 100% !important;
  max-width: min(460px, 100%) !important;
  margin: 0 auto !important;
  height: 44px !important;
  padding: 4px !important;
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  overflow: hidden !important;
  position: relative;
  isolation: isolate;
  transition: border-color 0.18s ease, box-shadow 0.18s ease !important;
}
html body .site-header .header-search.nav-search:focus-within {
  border-color: color-mix(in srgb, var(--c-primary) 55%, var(--c-border)) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 16%, transparent) !important;
}

html body .site-header .header-search-form {
  display: flex !important;
  align-items: center !important;
  flex: 1 1 auto !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

html body .site-header .header-search-input {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  width: auto !important;
  height: 36px !important;
  line-height: 36px !important;
  margin: 0 !important;
  padding: 0 0.6rem 0 1rem !important;
  border: 0 !important;
  outline: none !important;
  background: transparent !important;
  color: var(--c-text) !important;
  font: inherit !important;
  font-size: 0.93rem !important;
  box-shadow: none !important;
}
html body .site-header .header-search-input::placeholder {
  color: var(--c-muted) !important;
  opacity: 1 !important;
}

html body .site-header .header-search-submit {
  flex: 0 0 36px !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  max-width: 36px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 50% !important;
  background: var(--c-primary) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3.5-3.5'/%3E%3C/svg%3E") center / 16px 16px no-repeat !important;
  cursor: pointer !important;
  box-shadow: none !important;
  filter: none !important;
  transform: none !important;
  transition: background-color 0.18s ease !important;
}
html body .site-header .header-search-submit:hover,
html body .site-header .header-search-submit:focus,
html body .site-header .header-search-submit:active {
  background-color: var(--c-primary-strong) !important;
  transform: none !important;
  scale: 1 !important;
  box-shadow: none !important;
}

/* Hide the loading-bar overlay entirely (was creating the orange line) */
html body .loading-bar,
html body #loadingBar {
  display: none !important;
}

/* Dark theme search */
:root[data-theme="dark"] html body .site-header .header-search.nav-search {
  background: var(--c-surface-2) !important;
  border-color: var(--c-border) !important;
}

/* =====================================================================
   PASS 44 ? Premium dark theme rebuild
   Goal: softer deep-navy background, defined card surfaces, calmer
   accents, consistent shadows ? no harsh pure black, no over-saturated
   orange against the dark page.
   ===================================================================== */

/* -- 44.1 Body + page base ------------------------------------------- */
:root[data-theme="dark"] html body,
:root[data-theme="dark"] html body.home-page,
:root[data-theme="dark"] html body.catalog-page,
:root[data-theme="dark"] html body.about-page,
:root[data-theme="dark"] html body.contact-page,
:root[data-theme="dark"] html body.product-page,
:root[data-theme="dark"] html body.error-page,
:root[data-theme="dark"] html body.sitemap-page {
  background:
    radial-gradient(1200px 600px at 90% -10%, rgba(255, 109, 80, 0.08), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(58, 70, 106, 0.18), transparent 55%),
    var(--c-bg) !important;
  color: var(--c-text) !important;
}

/* -- 44.2 Header ----------------------------------------------------- */
:root[data-theme="dark"] html body .site-header.site-header-main {
  background: color-mix(in srgb, var(--c-surface) 78%, transparent) !important;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
}
:root[data-theme="dark"] html body .site-header .site-nav a {
  color: var(--c-text-soft) !important;
}
:root[data-theme="dark"] html body .site-header .site-nav a:hover,
:root[data-theme="dark"] html body .site-header .site-nav a.active {
  color: var(--c-primary) !important;
  background: rgba(255, 109, 80, 0.08) !important;
}
:root[data-theme="dark"] html body .site-header .header-search.nav-search {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}
:root[data-theme="dark"] html body .site-header .header-search-input {
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body .site-header .header-search-input::placeholder {
  color: var(--c-muted) !important;
}

/* Theme toggle in dark mode */
:root[data-theme="dark"] html body #themeToggleBtn.theme-toggle {
  background: rgba(255, 255, 255, 0.05) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
}
:root[data-theme="dark"] html body #themeToggleBtn.theme-toggle:hover {
  background: rgba(255, 255, 255, 0.08) !important;
}

/* -- 44.3 Leanpay strip ? darker, less screaming ---------------------- */
:root[data-theme="dark"] html body .leanpay-strip {
  background:
    linear-gradient(95deg, #1a1410 0%, #261812 45%, #2e1d16 100%) !important;
  border-top: 1px solid rgba(255, 109, 80, 0.18) !important;
  border-bottom: 1px solid rgba(255, 109, 80, 0.18) !important;
  box-shadow: inset 0 1px 0 rgba(255, 109, 80, 0.06) !important;
  color: #f6d5cb !important;
}
:root[data-theme="dark"] html body .leanpay-strip::before {
  display: none !important;
}
:root[data-theme="dark"] html body .leanpay-strip strong {
  color: var(--c-primary) !important;
}
:root[data-theme="dark"] html body .leanpay-strip .leanpay-pulse {
  background: var(--c-primary) !important;
}

/* -- 44.4 Home hero ? clean deep-navy card with subtle glow ---------- */
:root[data-theme="dark"] html body.home-page main.home-main > .home-hero {
  background:
    radial-gradient(circle at 12% 8%, rgba(255, 109, 80, 0.18), transparent 55%),
    radial-gradient(circle at 95% 95%, rgba(58, 70, 106, 0.35), transparent 60%),
    linear-gradient(165deg, #1a2236 0%, #131a2c 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.05) inset, var(--shadow-lg) !important;
}
:root[data-theme="dark"] html body.home-page .home-hero h1 {
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body.home-page .home-hero h1 .accent,
:root[data-theme="dark"] html body.home-page .home-hero .home-hero-title .accent {
  color: var(--c-primary) !important;
}
:root[data-theme="dark"] html body.home-page .home-hero-copy > p {
  color: var(--c-text-soft) !important;
}
:root[data-theme="dark"] html body.home-page .hero-bullet-dot {
  background: var(--c-primary) !important;
  box-shadow: 0 0 0 3px rgba(255, 109, 80, 0.18) !important;
}
:root[data-theme="dark"] html body.home-page .home-hero .hp-eyebrow,
:root[data-theme="dark"] html body.home-page .home-hero .home-kicker {
  background: rgba(255, 109, 80, 0.12) !important;
  color: var(--c-primary) !important;
  border-color: rgba(255, 109, 80, 0.28) !important;
}

/* Hero brand card (right side) */
:root[data-theme="dark"] html body.home-page .home-hero-brand,
:root[data-theme="dark"] html body.home-page .hero-logo-box {
  background:
    radial-gradient(circle at 50% 30%, rgba(255, 109, 80, 0.16), transparent 65%),
    linear-gradient(160deg, #1d263c 0%, #141b2e 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset !important;
}
:root[data-theme="dark"] html body.home-page .home-hero-highlights li {
  color: var(--c-text-soft) !important;
  letter-spacing: 0.08em;
}

/* -- 44.5 Featured categories ? card grid clean dark ------------------ */
:root[data-theme="dark"] html body.home-page .featured-cats-grid .cat-card,
:root[data-theme="dark"] html body.home-page .home-band-grid .home-block,
:root[data-theme="dark"] html body.home-page .home-band-grid .cat-card {
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  box-shadow: var(--shadow-sm) !important;
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body.home-page .featured-cats-grid .cat-card:hover,
:root[data-theme="dark"] html body.home-page .home-band-grid .cat-card:hover {
  border-color: color-mix(in srgb, var(--c-primary) 40%, var(--c-border-strong)) !important;
  box-shadow: var(--shadow-md), 0 0 0 1px rgba(255, 109, 80, 0.18) !important;
  transform: translateY(-2px);
}
:root[data-theme="dark"] html body.home-page .featured-cats-grid .cat-card h3,
:root[data-theme="dark"] html body.home-page .home-band-grid h3 {
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body.home-page .featured-cats-grid .cat-card p,
:root[data-theme="dark"] html body.home-page .home-band-grid p {
  color: var(--c-text-soft) !important;
}
:root[data-theme="dark"] html body.home-page .featured-cats-grid .cat-card a,
:root[data-theme="dark"] html body.home-page .home-band-grid a {
  color: var(--c-primary) !important;
}
:root[data-theme="dark"] html body.home-page .cat-card[data-cat-icon]::before,
:root[data-theme="dark"] html body.home-page [data-cat-icon]::before {
  background: rgba(255, 109, 80, 0.16) !important;
  border-color: rgba(255, 109, 80, 0.32) !important;
}

/* -- 44.6 Quotes section ? individual cards, no surrounding box ------- */
:root[data-theme="dark"] html body.home-page main.home-main > .home-quotes.hp-section,
:root[data-theme="dark"] html body.home-page main.home-main > .home-quotes {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
:root[data-theme="dark"] html body.home-page .home-quote {
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  box-shadow: var(--shadow-sm) !important;
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body.home-page .home-quote blockquote {
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body.home-page .home-quote .home-quote-name {
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body.home-page .home-quote .home-quote-role {
  color: var(--c-text-soft) !important;
}
:root[data-theme="dark"] html body.home-page .home-quote .home-quote-avatar {
  background: rgba(255, 109, 80, 0.14) !important;
  color: var(--c-primary) !important;
  border: 1px solid rgba(255, 109, 80, 0.3) !important;
}

/* -- 44.7 Buttons in dark ---------------------------------------------- */
:root[data-theme="dark"] html body .btn-primary {
  background: var(--c-primary) !important;
  color: #fff !important;
  box-shadow: 0 12px 28px -12px rgba(255, 109, 80, 0.55) !important;
}
:root[data-theme="dark"] html body .btn-primary:hover {
  background: var(--c-primary-strong) !important;
}
:root[data-theme="dark"] html body .btn-secondary {
  background: rgba(255, 255, 255, 0.04) !important;
  color: var(--c-text) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
}
:root[data-theme="dark"] html body .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
  color: var(--c-text) !important;
}

/* -- 44.8 Section separator line on dark ------------------------------ */
:root[data-theme="dark"] html body.home-page main.home-main > .hp-section + .hp-section::before,
:root[data-theme="dark"] html body.home-page main.home-main > .home-band + .hp-section::before,
:root[data-theme="dark"] html body.home-page main.home-main > .hp-section + .home-band::before,
:root[data-theme="dark"] html body.home-page main.home-main > .home-band + .home-band::before {
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.08) 18%, rgba(255, 255, 255, 0.08) 82%, transparent) !important;
  opacity: 1 !important;
}

/* -- 44.9 Featured brands strip dark ---------------------------------- */
:root[data-theme="dark"] html body .brand-band,
:root[data-theme="dark"] html body .brands-band,
:root[data-theme="dark"] html body .featured-brands {
  background: rgba(255, 255, 255, 0.02) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
  color: var(--c-text-soft) !important;
}

/* -- 44.10 Footer dark (already dark but make sure contrast holds) ---- */
:root[data-theme="dark"] html body .site-footer {
  background: #0a0f1a !important;
}
:root[data-theme="dark"] html body .site-footer .footer-bottom {
  background: #060a12 !important;
}
:root[data-theme="dark"] html body .site-footer .footer-col-title {
  color: #fff !important;
}
:root[data-theme="dark"] html body .site-footer .footer-brand .brand-text-main {
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
}

/* -- 44.11 Forms (contact page) dark ---------------------------------- */
:root[data-theme="dark"] html body input,
:root[data-theme="dark"] html body textarea,
:root[data-theme="dark"] html body select {
  background: var(--c-surface) !important;
  border-color: var(--c-border) !important;
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body input::placeholder,
:root[data-theme="dark"] html body textarea::placeholder {
  color: var(--c-muted) !important;
}
:root[data-theme="dark"] html body input:focus,
:root[data-theme="dark"] html body textarea:focus,
:root[data-theme="dark"] html body select:focus {
  border-color: color-mix(in srgb, var(--c-primary) 60%, var(--c-border)) !important;
  box-shadow: var(--ring) !important;
}

/* -- 44.12 Catalog product cards in dark ------------------------------ */
:root[data-theme="dark"] html body.catalog-page .product-grid .card {
  background: var(--c-surface) !important;
  border: 1px solid var(--c-border) !important;
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body.catalog-page .product-grid .card:hover {
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border-strong)) !important;
  box-shadow: var(--shadow-md) !important;
}
:root[data-theme="dark"] html body.catalog-page .product-grid .card h3,
:root[data-theme="dark"] html body.catalog-page .product-grid .card .card-title {
  color: var(--c-text) !important;
}
:root[data-theme="dark"] html body.catalog-page .product-grid .card .card-price {
  color: var(--c-primary) !important;
}
:root[data-theme="dark"] html body.catalog-page .product-grid .card .card-cta {
  background: rgba(255, 255, 255, 0.04) !important;
  color: var(--c-text) !important;
  border-color: rgba(255, 255, 255, 0.16) !important;
}
:root[data-theme="dark"] html body.catalog-page .product-grid .card .card-cta:hover {
  background: var(--c-text) !important;
  color: #0e1422 !important;
}
:root[data-theme="dark"] html body.catalog-page .product-grid .card .card-cta::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23eef2fb' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") !important;
}

/* -- 44.13 Scrollbar dark --------------------------------------------- */
:root[data-theme="dark"] html body::-webkit-scrollbar-track {
  background: var(--c-bg);
}
:root[data-theme="dark"] html body::-webkit-scrollbar-thumb {
  background: var(--c-surface-3);
  border-radius: 999px;
}
:root[data-theme="dark"] html body::-webkit-scrollbar-thumb:hover {
  background: var(--c-border-strong);
}

/* =====================================================================
   PASS 45 ? Nuke orphan skip-link
   Old SW cache may serve stale HTML with <a class="skip-link">. Even if
   the source HTML no longer has it, defensively hide any stray element.
   ===================================================================== */
html body .skip-link,
html body a.skip-link,
html body [class*="skip-link"] {
  display: none !important;
  visibility: hidden !important;
  position: absolute !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
  clip-path: inset(100%) !important;
}

/* =====================================================================
   PASS 48 ? About page v3: family-business story + 4-pillar grid
   ===================================================================== */

/* Hero accent in heading */
html body.about-page .about-v2-hero-copy h1 .accent {
  color: var(--c-primary);
}
:root[data-theme="dark"] html body.about-page .about-v2-hero-copy h1 .accent {
  color: var(--c-primary);
}

/* Centered section head variant */
html body.about-page .about-v2-section-head--center {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--space-5);
}
html body.about-page .about-v2-section-head--center .about-v2-eyebrow {
  display: inline-block;
}
html body.about-page .about-v2-section-sub {
  margin: 0.6rem auto 0;
  color: var(--c-text-soft);
  max-width: 60ch;
  font-size: 0.98rem;
  line-height: 1.6;
}

/* -- Story section ---------------------------------------------------- */
html body.about-page .about-v2-story {
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  background:
    radial-gradient(circle at 88% 12%, color-mix(in srgb, var(--c-primary) 10%, transparent), transparent 55%),
    var(--c-surface-2);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  margin: clamp(2rem, 4vw, 3.5rem) 0;
}
html body.about-page .about-v2-story-inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 clamp(1rem, 3vw, 2rem);
}
html body.about-page .about-v2-story-grid {
  display: grid;
  gap: clamp(1.2rem, 2.5vw, 1.8rem);
}
html body.about-page .about-v2-story-lead {
  font-size: clamp(1.2rem, 2vw, 1.45rem);
  line-height: 1.45;
  letter-spacing: -0.01em;
  color: var(--c-text);
  font-weight: 600;
  margin: 0;
}
html body.about-page .about-v2-story-text {
  display: grid;
  gap: 0.9rem;
}
html body.about-page .about-v2-story-text p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--c-text-soft);
}
html body.about-page .about-v2-story-text strong {
  color: var(--c-text);
  font-weight: 700;
}
html body.about-page .about-v2-story-signoff {
  margin-top: 0.5rem !important;
  color: var(--c-text) !important;
  font-style: italic;
  font-weight: 600;
  letter-spacing: 0.01em;
}

:root[data-theme="dark"] html body.about-page .about-v2-story {
  background:
    radial-gradient(circle at 88% 12%, color-mix(in srgb, var(--c-primary) 14%, transparent), transparent 55%),
    var(--c-surface) !important;
  border-color: var(--c-border) !important;
}

/* -- 4 pillars: clean symmetric grid ---------------------------------- */
html body.about-page .about-v2-pillars {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.8rem, 1.5vw, 1.2rem);
  margin: clamp(1.5rem, 3vw, 2.5rem) 0 clamp(2rem, 4vw, 3.5rem);
}
html body.about-page .about-v2-pillar {
  position: relative;
  padding: clamp(1.2rem, 2.4vw, 1.6rem) clamp(1.1rem, 2vw, 1.4rem) clamp(1.2rem, 2.4vw, 1.5rem);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
html body.about-page .about-v2-pillar:hover {
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border));
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}
html body.about-page .about-v2-pillar-num {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  color: var(--c-primary);
  font-feature-settings: "tnum";
  margin-bottom: 0.15rem;
}
html body.about-page .about-v2-pillar h3 {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 800;
  letter-spacing: -0.015em;
  color: var(--c-text);
}
html body.about-page .about-v2-pillar p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--c-text-soft);
}
html body.about-page .about-v2-pillar::before {
  content: "";
  position: absolute;
  top: 0;
  left: clamp(1.1rem, 2vw, 1.4rem);
  width: 36px;
  height: 3px;
  background: linear-gradient(90deg, var(--c-primary), color-mix(in srgb, var(--c-primary) 35%, transparent));
  border-radius: 0 0 999px 999px;
}

:root[data-theme="dark"] html body.about-page .about-v2-pillar {
  background: var(--c-surface) !important;
  border-color: var(--c-border) !important;
}
:root[data-theme="dark"] html body.about-page .about-v2-pillar:hover {
  border-color: color-mix(in srgb, var(--c-primary) 40%, var(--c-border-strong)) !important;
}

@media (max-width: 920px) {
  html body.about-page .about-v2-pillars {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 520px) {
  html body.about-page .about-v2-pillars {
    grid-template-columns: 1fr;
  }
}

/* =====================================================================
   PASS 49 ? Contact page: embedded Google Maps
   ===================================================================== */
html body.contact-page .contact-v2-map-wrap {
  margin: clamp(2rem, 4vw, 3.5rem) auto;
  padding: 0 clamp(1rem, 3vw, 2rem);
}
html body.contact-page .contact-v2-map-wrap .contact-v2-section-head {
  text-align: center;
  margin: 0 auto clamp(1.2rem, 2.5vw, 2rem);
  max-width: 720px;
}
html body.contact-page .contact-v2-map-wrap .contact-v2-section-head h2 {
  margin: 0.4rem 0 0.4rem;
  font-size: clamp(1.4rem, 2.6vw, 1.85rem);
  letter-spacing: -0.02em;
  font-weight: 800;
  color: var(--c-text);
}
html body.contact-page .contact-v2-map-sub {
  margin: 0;
  color: var(--c-text-soft);
  font-size: 0.95rem;
  line-height: 1.55;
  max-width: 56ch;
  margin-inline: auto;
}
html body.contact-page .contact-v2-map-frame {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-md);
  background: var(--c-surface-2);
  isolation: isolate;
}
html body.contact-page .contact-v2-map-frame iframe {
  display: block;
  width: 100%;
  height: clamp(320px, 50vh, 480px);
  border: 0;
  filter: saturate(0.96) contrast(0.98);
}
:root[data-theme="dark"] html body.contact-page .contact-v2-map-frame iframe {
  filter: invert(0.92) hue-rotate(180deg) saturate(0.72) contrast(0.9) brightness(0.95);
}
html body.contact-page .contact-v2-map-overlay-btn {
  position: absolute;
  right: clamp(0.6rem, 1.6vw, 1.1rem);
  bottom: clamp(0.4rem, 1.2vw, 0.7rem);
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.95rem 1.6rem;
  background: var(--c-primary);
  color: #fff;
  border-radius: var(--radius-pill);
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: 0.01em;
  text-decoration: none;
  border: 2px solid #fff;
  box-shadow:
    0 14px 32px -8px color-mix(in srgb, var(--c-primary) 65%, transparent),
    0 2px 6px rgba(15, 23, 42, 0.18);
  z-index: 2;
  transition: background 0.18s ease, transform 0.18s ease;
}
html body.contact-page .contact-v2-map-overlay-btn::before {
  content: "";
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s-7-7.58-7-13a7 7 0 1 1 14 0c0 5.42-7 13-7 13z'/%3E%3Ccircle cx='12' cy='9' r='2.5'/%3E%3C/svg%3E") center/contain no-repeat;
}
@media (max-width: 560px) {
  html body.contact-page .contact-v2-map-overlay-btn {
    right: 0.5rem;
    bottom: 0.35rem;
    padding: 0.8rem 1.2rem;
    font-size: 0.92rem;
  }
}
html body.contact-page .contact-v2-map-overlay-btn:hover {
  background: var(--c-primary-strong);
  transform: translateY(-2px);
}

/* -- 49.2 Inline links inside aside cards ----------------------------- */
html body.contact-page .contact-v2-aside-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dashed color-mix(in srgb, var(--c-primary) 45%, transparent);
  padding-bottom: 1px;
  transition: color 0.15s ease, border-color 0.15s ease;
}
html body.contact-page .contact-v2-aside-link:hover {
  color: var(--c-primary);
  border-bottom-color: var(--c-primary);
}
html body.contact-page .contact-v2-aside-link:focus-visible {
  outline: 2px solid var(--c-primary);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ===========================================================================
   PASS 52 - Card cleanup
   - Refine "Podrobnosti" CTA chevron spacing + visibility
   - Ensure card-media has no leftover floating chips
   =========================================================================== */

/* 52.2 Podrobnosti CTA - clean spacing, balanced chevron */
html body.catalog-page .product-grid .card .card-body .card-actions .card-cta {
  padding: 0.62rem 1.05rem 0.62rem 1.15rem !important;
  gap: 0.55rem !important;
  letter-spacing: 0.01em !important;
  white-space: nowrap !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05) !important;
}
html body.catalog-page .product-grid .card .card-body .card-actions .card-cta::after {
  width: 0.85em !important;
  height: 0.85em !important;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") center / contain no-repeat !important;
  opacity: 0.9 !important;
}
html body.catalog-page .product-grid .card .card-body .card-actions .card-cta:hover::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E") !important;
  opacity: 1 !important;
}

/* 52.3 Card media - no overlay chips other than badges */
html body .card .card-media > :not(img):not(.card-image):not(.card-badges) {
  display: none !important;
}

/* ===========================================================================
   PASS 54 - Catalog card: remove description line
   - User wants no description text on the catalog grid
   =========================================================================== */
html body .card .card-description,
html body.catalog-page .card .card-description,
html body.catalog-page .product-grid .card .card-body .card-description {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ===========================================================================
   PASS 55 - Remove Leanpay strip + trust row + footer credit + back-to-top
   Add dynamic-price disclaimer styling
   =========================================================================== */

/* 55.1 Defensive hide for anything that might come back via cached HTML */
html body .leanpay-strip,
html body .leanpay-track,
html body .leanpay-pulse,
html body .product-trust-row,
html body .product-trust,
html body .product-price-leanpay,
html body .footer-credit,
html body .footer-credit-link,
html body #backToTopBtn,
html body .back-to-top {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* 55.2 Catalog card: price-notice (under price, before actions) */
html body .card .card-body .price-notice {
  display: block;
  margin: 0.35rem 0 0;
  padding: 0;
  font-size: 0.7rem;
  line-height: 1.35;
  font-weight: 600;
  color: var(--c-text-soft, #64748b);
  letter-spacing: 0.01em;
  font-style: italic;
  opacity: 0.85;
}
:root[data-theme="dark"] html body .card .card-body .price-notice {
  color: color-mix(in srgb, var(--c-text, #e2e8f0) 65%, transparent);
}

/* 55.3 Product detail: notice below price block */
html body.product-page .product-price-block .product-price-notice {
  display: block;
  margin-top: 0.55rem;
  padding: 0.45rem 0.7rem;
  font-size: 0.78rem;
  line-height: 1.4;
  font-weight: 600;
  color: var(--c-text-soft, #64748b);
  background: color-mix(in srgb, var(--c-warning, #f59e0b) 8%, var(--c-surface, #fff));
  border: 1px dashed color-mix(in srgb, var(--c-warning, #f59e0b) 35%, var(--c-border, #e2e8f0));
  border-radius: 8px;
  letter-spacing: 0.005em;
  font-style: italic;
  max-width: max-content;
}
:root[data-theme="dark"] html body.product-page .product-price-block .product-price-notice {
  background: rgba(245, 158, 11, 0.08);
  border-color: rgba(245, 158, 11, 0.32);
  color: color-mix(in srgb, var(--c-text, #e2e8f0) 75%, transparent);
}

/* 55.4 Footer-bottom: center the remaining copyright when credit removed */
html body footer.site-footer .footer-bottom-inner {
  justify-content: center !important;
}
html body footer.site-footer .footer-bottom-inner .footer-copy {
  text-align: center;
}

/* ===========================================================================
   PASS 56 - Homepage cleanup + "Naša trgovina" photo carousel
   - User removed: brand-bar, home-kicker eyebrow, hero-bullets, home-hero-side
   - Added: store photo carousel with scroll-snap + prev/next
   =========================================================================== */

/* 56.1 Defensive hide for cached/legacy home elements */
html body.home-page .brand-bar,
html body.home-page .brand-bar-grid,
html body.home-page .brand-bar-label,
html body.home-page .brand-bar-name,
html body.home-page .home-hero .home-kicker,
html body.home-page .home-hero .hero-bullets,
html body.home-page .home-hero .home-hero-side,
html body.home-page .home-hero .hero-logo-box,
html body.home-page .home-hero .home-hero-brand,
html body.home-page .home-hero .home-hero-brand-glow,
html body.home-page .home-hero .home-hero-highlights {
  display: none !important;
}

/* 56.2 Hero becomes single-column centered (no more 2-col grid) */
html body.home-page main.home-main > .home-hero.home-hero-centered,
html body.home-page .home-hero.home-hero-centered {
  display: block !important;
  grid-template-columns: none !important;
  text-align: center;
  max-width: 820px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-block: clamp(2.5rem, 6vw, 4.5rem) !important;
}
html body.home-page .home-hero.home-hero-centered .home-hero-copy {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  gap: 1.25rem;
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 100%;
}
html body.home-page .home-hero.home-hero-centered h1 {
  margin: 0 auto !important;
  font-size: clamp(1.9rem, 4vw, 2.9rem);
  line-height: 1.12;
  letter-spacing: -0.02em;
  text-align: center !important;
  text-wrap: balance;
  -webkit-text-wrap: balance;
  max-width: 18ch;
}
html body.home-page .home-hero.home-hero-centered h1 .text-grad {
  display: block;
  margin-top: 0.15em;
}
@media (max-width: 540px) {
  html body.home-page .home-hero.home-hero-centered h1 {
    font-size: clamp(1.7rem, 7vw, 2.2rem);
    max-width: 14ch;
  }
}
html body.home-page .home-hero.home-hero-centered > .home-hero-copy > p {
  margin: 0 auto !important;
  max-width: 62ch;
  color: var(--c-text-soft, #475569);
  font-size: clamp(1rem, 1.25vw, 1.08rem);
  line-height: 1.55;
  text-align: center !important;
}
html body.home-page .home-hero.home-hero-centered .hero-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 0.45rem 0.6rem;
  margin: 0.15rem auto 0 !important;
}
html body.home-page .home-hero.home-hero-centered .actions {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  gap: 0.7rem;
  margin-top: 0.3rem;
}

/* 56.3 Store carousel: section header */
html body.home-page .home-store {
  margin-top: clamp(2rem, 4vw, 3rem);
}
html body.home-page .home-store .hp-head {
  text-align: center;
  margin-bottom: 1.6rem;
}
html body.home-page .home-store .hp-head > p:last-child {
  max-width: 60ch;
  margin-inline: auto;
  color: var(--c-text-soft, #475569);
}

/* 56.3b Full-bleed strip (break out of .container) — desktop edge-to-edge */
html body.home-page .store-carousel-bleed {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  position: relative;
  box-sizing: border-box;
}

/* 56.4 Carousel wrapper + track */
html body .store-carousel {
  position: relative;
  margin-inline: auto;
  width: 100%;
  max-width: none;
}
html body .store-carousel-track {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 0.5rem 0 1rem;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}
html body .store-carousel-track::-webkit-scrollbar { display: none; }

/* 56.5 Slide: 3-up full-bleed desktop, 2-up tablet, 1-up phone */
html body .store-slide {
  flex: 0 0 calc((100% - 2 * 1rem) / 3);
  margin: 0;
  scroll-snap-align: start;
  border-radius: 14px;
  overflow: hidden;
  background: var(--c-surface-2, #f8fafc);
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.08), 0 1px 3px rgba(15, 23, 42, 0.06);
  transition: transform 0.35s ease, box-shadow 0.35s ease;
}
@media (hover: hover) and (pointer: fine) {
  html body .store-slide:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.12), 0 2px 4px rgba(15, 23, 42, 0.08);
  }
}
html body .store-slide img {
  display: block;
  width: 100%;
  height: clamp(180px, 26vw, 320px);
  object-fit: cover;
  border-radius: inherit;
}

/* Desktop: tighter gap, taller strip, arrows inset from viewport edge */
@media (min-width: 901px) {
  html body .store-carousel-track {
    gap: clamp(0.45rem, 1vw, 0.85rem);
    padding: 0.65rem max(0, env(safe-area-inset-left, 0px)) 1rem max(0, env(safe-area-inset-right, 0px));
  }
  html body .store-slide {
    flex: 0 0 calc((100% - 2 * clamp(0.45rem, 1vw, 0.85rem)) / 3);
    border-radius: clamp(10px, 1vw, 16px);
  }
  html body .store-slide img {
    height: clamp(240px, 32vw, 420px);
  }
  html body .store-carousel-prev {
    left: max(0.5rem, env(safe-area-inset-left, 0px));
  }
  html body .store-carousel-next {
    right: max(0.5rem, env(safe-area-inset-right, 0px));
  }
}

@media (min-width: 601px) and (max-width: 900px) {
  html body .store-carousel-track {
    padding-inline: max(0.5rem, env(safe-area-inset-left, 0px)) max(0.5rem, env(safe-area-inset-right, 0px));
    gap: 0.75rem;
  }
  html body .store-slide {
    flex: 0 0 calc((100% - 0.75rem) / 2);
    scroll-snap-align: start;
  }
  html body .store-slide img {
    height: clamp(200px, 36vw, 280px);
  }
}

/* Phone: one main slide, centered snap, safe areas, no hover arrows (swipe) */
@media (max-width: 600px) {
  html body .store-carousel-track {
    gap: 0.65rem;
    padding: 0.45rem max(0.65rem, env(safe-area-inset-left, 0px)) 0.85rem max(0.65rem, env(safe-area-inset-right, 0px));
    scroll-padding-inline: max(0.65rem, env(safe-area-inset-left, 0px));
  }
  html body .store-slide {
    flex: 0 0 calc(100vw - 2 * max(0.65rem, env(safe-area-inset-left, 0px), env(safe-area-inset-right, 0px)) - 0.65rem);
    max-width: 100%;
    scroll-snap-align: center;
    border-radius: 12px;
  }
  html body .store-slide img {
    height: min(52vw, 260px);
    min-height: 180px;
    max-height: 280px;
  }
  /* PASS 63 — Show arrows on phone (smaller, inside viewport, vertically over slide) */
  html body .store-carousel-arrow {
    display: inline-flex !important;
    width: 38px;
    height: 38px;
    top: 50%;
  }
  html body .store-carousel-prev {
    left: max(0.5rem, env(safe-area-inset-left, 0px)) !important;
  }
  html body .store-carousel-next {
    right: max(0.5rem, env(safe-area-inset-right, 0px)) !important;
  }
  html body .store-carousel-arrow > span {
    width: 12px;
    height: 12px;
  }
  /* PASS 63 — Sliding window of dots: max 3 visible at once */
  html body .store-carousel-dots {
    flex-wrap: nowrap;
  }
  html body .store-carousel-dots > button {
    display: none;
  }
  html body .store-carousel-dots > button.is-window {
    display: inline-block;
  }
  html body .store-carousel-dots > button.is-window-edge {
    transform: scale(0.7);
    opacity: 0.7;
  }
  html body .store-carousel-dots > button.is-window-edge.is-active {
    transform: scale(1.05);
    opacity: 1;
  }
}

/* 56.6 Prev/Next arrows */
html body .store-carousel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--c-border, #e2e8f0);
  background: rgba(255, 255, 255, 0.92);
  color: var(--c-text, #0f172a);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.1), 0 1px 3px rgba(15, 23, 42, 0.05);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}
html body .store-carousel-arrow:hover {
  background: #fff;
  border-color: var(--c-text, #0f172a);
  transform: translateY(-50%) scale(1.05);
}
html body .store-carousel-arrow:active {
  transform: translateY(-50%) scale(0.96);
}
html body .store-carousel-prev { left: -8px; }
html body .store-carousel-next { right: -8px; }
@media (min-width: 1320px) {
  html body .store-carousel-prev { left: -22px; }
  html body .store-carousel-next { right: -22px; }
}
@media (min-width: 901px) {
  html body .store-carousel-prev { left: max(0.5rem, env(safe-area-inset-left, 0px)); }
  html body .store-carousel-next { right: max(0.5rem, env(safe-area-inset-right, 0px)); }
}
html body .store-carousel-arrow > span {
  width: 14px;
  height: 14px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='15 18 9 12 15 6'/%3E%3C/svg%3E") center / contain no-repeat;
}
html body .store-carousel-next > span {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E");
}

/* 56.7 Dots — larger tap targets on touch (phone) */
html body .store-carousel-dots {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 0.5rem;
  padding-inline: max(0.5rem, env(safe-area-inset-left, 0px)) max(0.5rem, env(safe-area-inset-right, 0px));
}
html body .store-carousel-dots > button {
  appearance: none;
  border: 0;
  width: 8px;
  height: 8px;
  padding: 14px;
  box-sizing: content-box;
  border-radius: 50%;
  cursor: pointer;
  background-color: var(--c-border-strong, #cbd5e1);
  background-clip: content-box;
  transition: background-color 0.18s ease, transform 0.18s ease;
}
html body .store-carousel-dots > button.is-active {
  background-color: var(--c-primary, #ff4f33);
  transform: scale(1.15);
}

/* 56.8 CTA below carousel */
html body.home-page .home-store-cta {
  display: flex;
  justify-content: center;
  margin-top: 1.25rem;
}

/* 56.9 Dark theme: arrows + slide bg */
:root[data-theme="dark"] html body .store-slide {
  background: rgba(20, 26, 38, 0.6);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5), 0 1px 3px rgba(0, 0, 0, 0.4);
}
:root[data-theme="dark"] html body .store-carousel-arrow {
  background: rgba(20, 26, 38, 0.85);
  border-color: rgba(255, 255, 255, 0.12);
  color: #fff;
}
:root[data-theme="dark"] html body .store-carousel-arrow:hover {
  background: rgba(20, 26, 38, 0.95);
  border-color: rgba(255, 255, 255, 0.28);
}
:root[data-theme="dark"] html body .store-carousel-arrow > span {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='15 18 9 12 15 6'/%3E%3C/svg%3E");
}
:root[data-theme="dark"] html body .store-carousel-next > span {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E");
}
:root[data-theme="dark"] html body .store-carousel-dots > button.is-active {
  background-color: var(--c-primary, #ff6b4a);
}

/* ===========================================================================
   PASS 59 - Catalog hero: drop "200+ izdelkov" stat card
   - User removed catalog-hero-meta; hero is now single-column, content centered
   - Defensive hide for any cached .catalog-hero-meta DOM
   =========================================================================== */
html body.catalog-page .catalog-hero.catalog-hero-solo {
  grid-template-columns: 1fr !important;
  display: block !important;
  text-align: left;
}
html body.catalog-page .catalog-hero.catalog-hero-solo .catalog-hero-copy {
  max-width: none;
}
html body.catalog-page .catalog-hero.catalog-hero-solo .catalog-hero-lead {
  max-width: 64ch;
}
html body.catalog-page .catalog-hero-meta,
html body.catalog-page .catalog-meta-stat,
html body.catalog-page .catalog-meta-label {
  display: none !important;
  visibility: hidden !important;
}

/* =====================================================================
   PASS 65/70 — Contact form: pravi rounded box-style v karte; brez vidnih
   poljskih linij med polji (uporabnik: "še hujše")
   ===================================================================== */
html body.contact-page .contact-v2-form input,
html body.contact-page .contact-v2-form textarea {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-bottom: 1px solid var(--c-border) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0.5rem 0.1rem !important;
  min-height: 40px !important;
  font-size: 0.96rem !important;
  width: 100% !important;
  resize: none !important;
  transition: border-color 0.18s ease, box-shadow 0.18s ease !important;
}
html body.contact-page .contact-v2-form textarea {
  min-height: 130px !important;
  resize: none !important;
  font-family: inherit !important;
}
html body.contact-page .contact-v2-form input:hover,
html body.contact-page .contact-v2-form textarea:hover {
  background: transparent !important;
  border-bottom-color: var(--c-border-strong) !important;
}
html body.contact-page .contact-v2-form input:focus,
html body.contact-page .contact-v2-form textarea:focus {
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid var(--c-primary) !important;
  box-shadow: 0 1px 0 0 var(--c-primary) !important;
  transform: none !important;
  outline: none !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form input,
:root[data-theme="dark"] html body.contact-page .contact-v2-form textarea {
  border-bottom-color: rgba(255, 255, 255, 0.18) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form input:hover,
:root[data-theme="dark"] html body.contact-page .contact-v2-form textarea:hover {
  border-bottom-color: rgba(255, 255, 255, 0.32) !important;
}

/* =====================================================================
   PASS 80 — Odstranjen dark mode + form align + carousel manjše slike
   ===================================================================== */

/* 80.A  Disable dark theme — force light always */
html {
  color-scheme: light !important;
}
:root[data-theme="dark"],
:root {
  --c-bg: #f6f7fb !important;
  --c-surface: #ffffff !important;
  --c-surface-2: #f8fafc !important;
  --c-surface-3: #eef2f7 !important;
  --c-border: #e2e8f0 !important;
  --c-border-strong: #cbd5e1 !important;
  --c-text: #0f172a !important;
  --c-text-soft: #475569 !important;
  --c-muted: #64748b !important;
}

/* 80.B  Form card align — manj paddinga spodi, ne stretch z auto-margin */
html body.contact-page .contact-v2-split {
  align-items: start !important;
}
html body.contact-page .contact-v2-form-card {
  padding-bottom: clamp(1rem, 2vw, 1.4rem) !important;
}
html body.contact-page .contact-v2-form {
  flex: 0 1 auto !important;
}
html body.contact-page .contact-v2-form-card #contactSubmitBtn {
  margin-top: var(--space-3) !important;
}
html body.contact-page .contact-v2-form-card textarea {
  min-height: 140px !important;
  height: auto !important;
  flex: 0 0 auto !important;
}

/* 80.C  Carousel — manjše slike + boljši scroll-snap (deluje z vsemi 12 slikami) */
html body .store-carousel-track {
  scroll-snap-type: x proximity !important; /* proximity je manj agresiven kot mandatory */
}
html body .store-slide img {
  height: clamp(160px, 22vw, 240px) !important;
}
@media (min-width: 901px) {
  html body .store-slide img {
    height: clamp(180px, 24vw, 280px) !important;
  }
}
@media (min-width: 601px) and (max-width: 900px) {
  html body .store-slide img {
    height: clamp(170px, 30vw, 230px) !important;
  }
}
@media (max-width: 600px) {
  html body .store-slide img {
    height: min(46vw, 220px) !important;
    min-height: 150px !important;
    max-height: 230px !important;
  }
}
/* Manjši gap, jasna scroll-padding-end za dosegljive zadnje slike */
html body .store-carousel-track {
  scroll-padding-inline-end: 1rem !important;
}

/* =====================================================================
   PASS 78 — ZAKLJUČNI POLISH: mobile centriranje + dark theme za objavo
   ===================================================================== */

/* ---------- 78.A  Mobile (≤ 720 px) — vse centrirano in ploščati ---------- */
@media (max-width: 720px) {
  /* Vse sekcijske heading skupine */
  html body .hp-head,
  html body .home-band-head,
  html body .contact-v2-section-head,
  html body .about-v2-hero-grid,
  html body .catalog-hero-content {
    text-align: center !important;
  }
  html body .hp-head > *,
  html body .home-band-head > * {
    margin-left: auto !important;
    margin-right: auto !important;
  }
  html body .hp-head p,
  html body .home-band-head p {
    max-width: 56ch;
  }

  /* Home: Featured kategorije — single column, centriran content */
  html body.home-page .featured-cats-grid,
  html body.home-page .home-band-grid {
    grid-template-columns: 1fr !important;
    gap: 0.85rem !important;
  }
  html body.home-page .cat-card {
    text-align: center !important;
    padding: 1.25rem 1rem !important;
  }
  html body.home-page .cat-card h3,
  html body.home-page .cat-card p {
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 36ch;
  }
  html body.home-page .cat-card a {
    margin: 0.5rem auto 0 !important;
    display: inline-flex !important;
  }

  /* Quotes / vtisi */
  html body.home-page .home-quotes {
    text-align: center !important;
  }
  html body.home-page .home-quotes-grid {
    grid-template-columns: 1fr !important;
  }

  /* Hero CTA gumbi stretch v eno vrsto centrirano */
  html body.home-page .home-hero .actions {
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100%;
    max-width: 320px;
    margin-inline: auto !important;
    gap: 0.55rem !important;
  }
  html body.home-page .home-hero .actions .btn-primary,
  html body.home-page .home-hero .actions .btn-secondary {
    width: 100%;
    justify-content: center !important;
  }

  /* Contact hero centriran, chips stack */
  html body.contact-page .contact-v2-hero-inner {
    text-align: center !important;
  }
  html body.contact-page .contact-v2-hero-inner h1,
  html body.contact-page .contact-v2-hero-inner .contact-v2-lead {
    margin-left: auto !important;
    margin-right: auto !important;
  }
  html body.contact-page .contact-v2-quick {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0.5rem !important;
    max-width: 360px;
    margin-inline: auto !important;
  }
  html body.contact-page .contact-v2-chip {
    text-align: center !important;
    justify-content: center !important;
    align-items: center !important;
  }
  html body.contact-page .contact-v2-chip-label,
  html body.contact-page .contact-v2-chip-value {
    text-align: center !important;
  }

  /* Contact split: form nad aside, oba centrirana */
  html body.contact-page .contact-v2-split {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }
  html body.contact-page .contact-v2-form-card {
    text-align: left !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  html body.contact-page #contactSubmitBtn {
    width: 100% !important;
    justify-content: center !important;
  }
  html body.contact-page .contact-v2-aside-card {
    text-align: center !important;
  }
  html body.contact-page .contact-v2-aside-card .contact-v2-aside-text {
    text-align: center !important;
  }
  html body.contact-page .contact-v2-aside-card h3 {
    text-align: center !important;
  }
  html body.contact-page .contact-v2-hours li {
    justify-content: space-between !important;
  }
  html body.contact-page .contact-v2-map-link {
    text-align: center !important;
    justify-content: center !important;
  }

  /* About page — centriran content */
  html body.about-page .about-v2-hero-grid,
  html body.about-page .about-v2-band-inner,
  html body.about-page .about-v2-bento {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }
  html body.about-page .about-v2-hero-grid > *,
  html body.about-page .about-v2-card,
  html body.about-page .about-v2-stat,
  html body.about-page .about-v2-bento > * {
    text-align: center !important;
  }
  html body.about-page .about-v2-card h3,
  html body.about-page .about-v2-card p {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* Catalog (products) hero — centered */
  html body.catalog-page .catalog-hero,
  html body.catalog-page .catalog-hero-solo {
    text-align: center !important;
  }
  html body.catalog-page .catalog-hero-content {
    margin-inline: auto !important;
  }

  /* Section spacing zmanjšan na telefonu */
  html body main.container,
  html body main.home-main,
  html body main.contact-main-v2,
  html body main.about-main-v2 {
    padding-block: 1.2rem !important;
    gap: 1.4rem !important;
  }

  /* Headings dovolj velikost, ampak ne preveč */
  html body h1 {
    font-size: clamp(1.7rem, 7vw, 2.2rem) !important;
    line-height: 1.15;
  }
  html body h2 {
    font-size: clamp(1.3rem, 5.5vw, 1.7rem) !important;
    line-height: 1.2;
  }
}

/* ---------- 78.B  Dark theme polish za objavo ---------- */
/* Override dark theme variables: nevtralna temna namesto navy */
:root[data-theme="dark"] {
  --c-bg: #0d0f13 !important;
  --c-surface: #15181f !important;
  --c-surface-2: #1a1e26 !important;
  --c-surface-3: #20242d !important;
  --c-border: rgba(255, 255, 255, 0.08) !important;
  --c-border-strong: rgba(255, 255, 255, 0.16) !important;
  --c-text: #e8ecf3 !important;
  --c-text-soft: rgba(255, 255, 255, 0.68) !important;
  --c-muted: rgba(255, 255, 255, 0.5) !important;
}
:root[data-theme="dark"] html body {
  background: #0d0f13 !important;
  background-color: #0d0f13 !important;
  color: #e8ecf3 !important;
}
/* Vse home sekcije naj bodo transparent v dark, brez modre */
:root[data-theme="dark"] html body.home-page main.home-main > .hp-section,
:root[data-theme="dark"] html body.home-page main.home-main > .home-band,
:root[data-theme="dark"] html body.home-page main.home-main > .home-stats,
:root[data-theme="dark"] html body.home-page .home-store,
:root[data-theme="dark"] html body.home-page .home-store.hp-section {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form-card,
:root[data-theme="dark"] html body article.contact-v2-form-card {
  background: #161a22 !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-aside-card {
  background: #161a22 !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
  color: #d8dde6;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-aside-card h3 {
  color: rgba(255, 255, 255, 0.62) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-aside-text {
  color: #d8dde6 !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-aside-text.muted {
  color: rgba(255, 255, 255, 0.55) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-chip {
  background: #161a22 !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
  color: #e8ecf3 !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-chip:hover {
  border-color: var(--c-primary) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-chip-label {
  color: rgba(255, 255, 255, 0.55) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-chip-value {
  color: #e8ecf3 !important;
}
/* Cat cards dark */
:root[data-theme="dark"] html body.home-page .cat-card {
  background: #161a22 !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
  color: #d8dde6;
}
:root[data-theme="dark"] html body.home-page .cat-card h3 {
  color: #e8ecf3 !important;
}
:root[data-theme="dark"] html body.home-page .cat-card p {
  color: rgba(255, 255, 255, 0.6) !important;
}
:root[data-theme="dark"] html body.home-page .cat-card a {
  color: var(--c-primary) !important;
}
:root[data-theme="dark"] html body.home-page .cat-card:hover {
  border-color: var(--c-primary) !important;
  background: #1b2129 !important;
}
/* Home quote cards dark */
:root[data-theme="dark"] html body.home-page .home-quote {
  background: #161a22 !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
  color: #d8dde6;
}
/* Contact hero v dark */
:root[data-theme="dark"] html body.contact-page .contact-v2-hero {
  background: radial-gradient(circle at 0% 0%, rgba(255, 109, 80, 0.10), transparent 55%), #0c0f14 !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-eyebrow {
  color: var(--c-primary) !important;
}
:root[data-theme="dark"] html body.contact-page h1,
:root[data-theme="dark"] html body.contact-page h2 {
  color: #f3f5f9 !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-lead,
:root[data-theme="dark"] html body.contact-page .contact-v2-form-lead {
  color: rgba(255, 255, 255, 0.65) !important;
}
/* Form label dark */
:root[data-theme="dark"] html body.contact-page .contact-v2-form label {
  color: rgba(255, 255, 255, 0.55) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form input,
:root[data-theme="dark"] html body.contact-page .contact-v2-form textarea {
  color: #f3f5f9 !important;
  border-bottom-color: rgba(255, 255, 255, 0.14) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form input:focus,
:root[data-theme="dark"] html body.contact-page .contact-v2-form textarea:focus {
  border-bottom-color: var(--c-primary) !important;
  box-shadow: 0 1px 0 0 var(--c-primary) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form input::placeholder,
:root[data-theme="dark"] html body.contact-page .contact-v2-form textarea::placeholder {
  color: rgba(255, 255, 255, 0.3) !important;
}
/* Hours list dark */
:root[data-theme="dark"] html body.contact-page .contact-v2-hours li {
  color: #d8dde6 !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-hours li.is-closed {
  color: rgba(255, 255, 255, 0.4) !important;
}
/* Leanpay strip dark adjust */
:root[data-theme="dark"] html body .leanpay-strip strong {
  background: rgba(0, 0, 0, 0.35);
}
/* Mobile drawer dark popolnoma temen */
:root[data-theme="dark"] html body .mobile-drawer {
  background: #0e1218 !important;
  border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
}
:root[data-theme="dark"] html body .mobile-drawer-link {
  color: #e8ecf3 !important;
}
:root[data-theme="dark"] html body .mobile-drawer-link:hover,
:root[data-theme="dark"] html body .mobile-drawer-link.is-active {
  color: var(--c-primary) !important;
  background: rgba(255, 109, 80, 0.08) !important;
}
:root[data-theme="dark"] html body .mobile-drawer-meta {
  color: rgba(255, 255, 255, 0.6) !important;
  border-top-color: rgba(255, 255, 255, 0.08) !important;
}

/* =====================================================================
   PASS 77 — Header kompakten 2-row na telefonu + footer-col-nav center
   ===================================================================== */
@media (max-width: 720px) {
  /* Header: 2-row layout (Row 1: brand + actions, Row 2: search) */
  html body .site-header .nav-wrap {
    grid-template-columns: 1fr auto !important;
    grid-template-rows: auto auto !important;
    grid-template-areas:
      "brand actions"
      "search search" !important;
    row-gap: 0.55rem !important;
    column-gap: 0.5rem !important;
    text-align: left !important;
    min-height: 0 !important;
    padding: 0.55rem 0 0.6rem !important;
  }
  html body .site-header .brand-title,
  html body .site-header .brand-link {
    grid-area: brand !important;
    justify-self: start !important;
  }
  html body .site-header .header-search,
  html body .site-header .nav-search {
    grid-area: search !important;
    justify-self: stretch !important;
    width: 100% !important;
    max-width: none !important;
  }
  html body .site-header .nav-cluster {
    grid-area: actions !important;
    width: auto !important;
    justify-self: end !important;
    justify-content: flex-end !important;
    gap: 0.4rem !important;
    flex-wrap: nowrap !important;
  }
  /* Manjši brand text na telefonu, da gre vse v eno vrstico */
  html body .site-header .brand-text-main {
    font-size: 1rem !important;
  }
  html body .site-header .brand-text-sub {
    font-size: 0.62rem !important;
    letter-spacing: 0.16em !important;
  }
  html body .site-header .brand-logo {
    width: 34px !important;
    height: 34px !important;
  }
  /* Search input + button kompaktnejša */
  html body .site-header .header-search-input {
    font-size: 0.92rem !important;
    padding: 0.55rem 0.85rem !important;
  }
  html body .site-header .header-search-submit {
    min-height: 38px !important;
  }
}

/* Footer-col-nav: dodatno utrjeno centriranje (Pass 76 morda izgubil v specifičnosti) */
@media (max-width: 600px) {
  html body .site-footer .footer-col-nav {
    align-items: center !important;
    text-align: center !important;
  }
  html body .site-footer .footer-col-nav a {
    align-self: center !important;
    width: auto !important;
    text-align: center !important;
    padding: 0.3rem 0.8rem !important;
  }
  /* Logo + brand-text v footerju centrirano */
  html body .site-footer .footer-col-brand .footer-brand {
    flex-direction: row !important;
    justify-content: center !important;
  }
}

/* =====================================================================
   PASS 76 — Footer centriranje na mobilni napravi (≤ 600 px)
   ===================================================================== */
@media (max-width: 600px) {
  html body .site-footer .footer-grid {
    text-align: center !important;
    justify-items: center !important;
  }
  html body .site-footer .footer-col {
    align-items: center !important;
    text-align: center !important;
  }
  /* Brand block */
  html body .site-footer .footer-col-brand {
    align-items: center !important;
  }
  html body .site-footer .footer-col-brand .footer-brand,
  html body .site-footer .footer-col-brand .brand-link {
    align-self: center !important;
    justify-content: center !important;
  }
  html body .site-footer .footer-about {
    text-align: center !important;
    margin-inline: auto !important;
    max-width: 36ch;
  }
  /* Nav: linki centrirani v stolpcu */
  html body .site-footer .footer-col-nav {
    align-items: center !important;
  }
  html body .site-footer .footer-col-nav a {
    width: auto !important;
    text-align: center !important;
    padding-left: 0 !important;
  }
  /* Skrij orange dot ::before na mobile (sicer visi levo od centrirane besede) */
  html body .site-footer .footer-col-nav a::before {
    display: none !important;
  }
  /* Kontakt stolpec */
  html body .site-footer .footer-col-contact .footer-col-title {
    text-align: center !important;
  }
  html body .site-footer .footer-contact-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    text-align: center !important;
  }
  html body .site-footer .footer-contact-list li {
    text-align: center !important;
    justify-content: center !important;
  }
  /* Bottom bar */
  html body .site-footer .footer-bottom-inner {
    text-align: center !important;
    align-items: center !important;
  }
}
html body.contact-page .contact-v2-form label {
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--c-text-soft) !important;
  margin-bottom: 0.3rem !important;
  display: block !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form input,
:root[data-theme="dark"] html body.contact-page .contact-v2-form textarea {
  background: rgba(255, 255, 255, 0.05) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form input:hover,
:root[data-theme="dark"] html body.contact-page .contact-v2-form textarea:hover {
  background: rgba(255, 255, 255, 0.08) !important;
}
:root[data-theme="dark"] html body.contact-page .contact-v2-form input:focus,
:root[data-theme="dark"] html body.contact-page .contact-v2-form textarea:focus {
  background: rgba(255, 255, 255, 0.07) !important;
}

/* =====================================================================
   PASS 70/74 — Contact split: enako visok form card kot desni aside stolpec
   PASS 74: VRNJEN outer card outline; skrita morebitna notranja obroba
   ===================================================================== */
html body.contact-page .contact-v2-split {
  align-items: stretch !important;
}
html body.contact-page .contact-v2-form-card,
html body.contact-page article.contact-v2-form-card {
  display: flex !important;
  flex-direction: column !important;
}
/* Skrij vse notranje "boxe": <form>, .contact-form-row, ovojni <div>i okrog label+input */
html body.contact-page .contact-v2-form-card .contact-v2-form,
html body.contact-page .contact-v2-form-card .contact-form,
html body.contact-page .contact-v2-form-card .contact-form-row,
html body.contact-page .contact-v2-form-card .contact-v2-form > div,
html body.contact-page .contact-v2-form-card .contact-v2-form > div > div,
html body.contact-page .contact-v2-form-card .contact-form-row > div {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
}
html body.contact-page .contact-v2-form-card .contact-form,
html body.contact-page .contact-v2-form-card .contact-v2-form {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-3) !important;
}
/* The textarea wrapper div is the LAST `<div>` direct child of the form (the message field) */
html body.contact-page .contact-v2-form-card .contact-v2-form > div:has(> textarea) {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
}
html body.contact-page .contact-v2-form-card textarea {
  flex: 1 1 auto !important;
  min-height: 120px !important;
  height: auto !important;
}
html body.contact-page .contact-v2-form-card #contactSubmitBtn {
  align-self: flex-start;
  margin-top: auto !important;
}
@media (max-width: 880px) {
  html body.contact-page .contact-v2-form-card #contactSubmitBtn {
    align-self: stretch;
    width: 100%;
  }
}

/* =====================================================================
   PASS 68 — Hero "škatla" stran: brez ozadja/okvirja, samo ločilna črta
   ===================================================================== */
html body.home-page main.home-main > .home-hero.home-hero-centered,
html body.home-page .home-hero.home-hero-centered,
html body.home-page .hero.home-hero.home-hero-centered,
html body.home-page section.home-hero.home-hero-centered {
  background: none !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding-block: clamp(2.5rem, 6vw, 4rem) !important;
  padding-inline: 0 !important;
  overflow: visible !important;
  position: relative;
}
html body.home-page main.home-main > .home-hero.home-hero-centered::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: clamp(180px, 30vw, 360px);
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    color-mix(in srgb, var(--c-primary) 32%, transparent) 25%,
    color-mix(in srgb, var(--c-primary) 55%, transparent) 50%,
    color-mix(in srgb, var(--c-primary) 32%, transparent) 75%,
    transparent 100%);
}
:root[data-theme="dark"] html body.home-page main.home-main > .home-hero.home-hero-centered::after {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255, 109, 80, 0.3) 25%,
    rgba(255, 109, 80, 0.55) 50%,
    rgba(255, 109, 80, 0.3) 75%,
    transparent 100%);
}

/* =====================================================================
   PASS 67 — Hero badge "Varen nakup se začne tukaj." + Leanpay strip back
   ===================================================================== */

/* 67.1 Hero kicker badge (above H1, centered, primary pill) */
html body.home-page .home-hero.home-hero-centered .home-hero-badge {
  display: inline-flex !important;
  align-items: center;
  gap: 0.5rem;
  margin: 0 auto 0.65rem !important;
  padding: 0.4rem 0.9rem;
  background: color-mix(in srgb, var(--c-primary) 12%, var(--c-surface));
  color: var(--c-primary-strong);
  border: 1px solid color-mix(in srgb, var(--c-primary) 35%, transparent);
  border-radius: var(--radius-pill);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  text-align: center !important;
  align-self: center;
  width: max-content;
  max-width: 92%;
}
html body.home-page .home-hero.home-hero-centered .home-hero-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--c-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 22%, transparent);
  flex: 0 0 6px;
}
:root[data-theme="dark"] html body.home-page .home-hero.home-hero-centered .home-hero-badge {
  background: rgba(255, 109, 80, 0.12);
  color: #ffb29d;
  border-color: rgba(255, 109, 80, 0.32);
}

/* 67.2 Leanpay strip — restored, modern compact look */
html body .leanpay-strip {
  background: linear-gradient(90deg, var(--c-primary) 0%, var(--c-primary-strong) 55%, var(--c-primary) 100%) !important;
  color: #fff !important;
  padding: 0.55rem 0 !important;
  border-top: 1px solid color-mix(in srgb, #000 8%, transparent) !important;
  border-bottom: 1px solid color-mix(in srgb, #000 12%, transparent) !important;
  box-shadow: 0 4px 14px -6px rgba(255, 79, 51, 0.45) !important;
  position: relative;
  overflow: hidden;
}
html body .leanpay-strip .container {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 0.45rem 1.1rem !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  color: #fff !important;
}
html body .leanpay-strip strong {
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  color: #fff !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.28);
  position: relative;
  padding: 0.1rem 0.45rem;
  background: rgba(0, 0, 0, 0.18);
  border-radius: 4px;
}
html body .leanpay-strip span {
  color: rgba(255, 255, 255, 0.96) !important;
  letter-spacing: 0.07em;
  position: relative;
}
html body .leanpay-strip .leanpay-strip-cta {
  color: #fff !important;
  text-decoration: none !important;
  font-weight: 700 !important;
  padding: 0.25rem 0.7rem;
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: var(--radius-pill);
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
  white-space: nowrap;
}
html body .leanpay-strip .leanpay-strip-cta:hover {
  background: rgba(255, 255, 255, 0.16);
  border-color: rgba(255, 255, 255, 0.85);
  transform: translateY(-1px);
}
@media (max-width: 560px) {
  html body .leanpay-strip {
    padding: 0.45rem 0 !important;
  }
  html body .leanpay-strip .container {
    gap: 0.3rem 0.7rem !important;
    font-size: 0.72rem !important;
  }
  html body .leanpay-strip .leanpay-strip-cta {
    padding: 0.18rem 0.55rem;
    font-size: 0.7rem !important;
  }
}
/* =====================================================================
   PASS 71 — NUCLEAR: hero brez ozadja in badge brez peach pilla
   ===================================================================== */
html body.home-page .home-hero,
html body.home-page section.home-hero,
html body.home-page .hero.home-hero,
html body.home-page main.home-main > .home-hero,
html body.home-page main.home-main > section.home-hero,
html body.home-page .home-hero.home-hero-centered,
html body.home-page main.home-main > .home-hero.home-hero-centered {
  background: none !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
/* KEY FIX: kill ::before pseudo-element radial gradient (line 2667) */
html body.home-page .home-hero::before,
html body.home-page section.home-hero::before,
html body.home-page .home-hero.home-hero-centered::before,
html body.home-page main.home-main > .home-hero::before,
html body.home-page main.home-main > .home-hero.home-hero-centered::before {
  content: none !important;
  display: none !important;
  background: none !important;
  background-image: none !important;
}
/* Badge: ne sme imeti polnila ali oranžnega borderja, samo subtle dot + text */
html body.home-page .home-hero.home-hero-centered .home-hero-badge {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 !important;
  padding: 0 !important;
  color: var(--c-text-soft) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}
html body.home-page .home-hero.home-hero-centered .home-hero-badge-dot {
  background: var(--c-primary) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 18%, transparent) !important;
}
:root[data-theme="dark"] html body.home-page .home-hero.home-hero-centered .home-hero-badge {
  color: rgba(255, 255, 255, 0.7) !important;
}

:root[data-theme="dark"] html body .leanpay-strip {
  background: linear-gradient(90deg, #2a1813 0%, #3a2018 60%, #2a1813 100%) !important;
  border-top-color: rgba(255, 109, 80, 0.22) !important;
  border-bottom-color: rgba(255, 109, 80, 0.22) !important;
  box-shadow: 0 4px 12px -6px rgba(0, 0, 0, 0.6) !important;
}

/* =====================================================================
   PASS 81 — Hitri preskok v katalog (home-cats-quick chips)
   ===================================================================== */
body.home-page .home-cats-quick {
  text-align: center;
}
body.home-page .home-cats-quick .hp-head {
  text-align: center;
  margin-inline: auto;
  max-width: 720px;
}
body.home-page .home-cats-quick-grid {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.4rem, 0.8vw, 0.65rem);
  justify-content: center;
  align-items: center;
  margin-top: clamp(0.8rem, 2vw, 1.4rem);
}
body.home-page .home-cat-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem 1.05rem;
  border-radius: var(--radius-pill, 999px);
  font-size: 0.92rem;
  font-weight: 600;
  text-decoration: none;
  color: var(--c-text, #0f172a);
  background: var(--c-surface, #ffffff);
  border: 1px solid var(--c-border, #e2e8f0);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
  white-space: nowrap;
  line-height: 1.1;
}
body.home-page .home-cat-chip:hover {
  background: var(--c-primary, #ff4f33);
  border-color: var(--c-primary, #ff4f33);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 8px 20px -10px rgba(255, 79, 51, 0.5), 0 2px 4px rgba(15, 23, 42, 0.08);
}
body.home-page .home-cat-chip:focus-visible {
  outline: 2px solid var(--c-primary, #ff4f33);
  outline-offset: 2px;
}
@media (max-width: 600px) {
  body.home-page .home-cats-quick-grid {
    gap: 0.4rem;
  }
  body.home-page .home-cat-chip {
    padding: 0.5rem 0.85rem;
    font-size: 0.86rem;
  }
}

/* =====================================================================
   PASS 80 (final override) — Disable dark mode + form align + carousel
   Mora biti na koncu, da preglasi Pass 70/74 in dark-mode override-e.
   ===================================================================== */

/* A) Dark mode izklop: vse spremenljivke kličejo light vrednosti */
:root,
:root[data-theme="dark"],
html[data-theme="dark"] {
  --c-bg: #f6f7fb !important;
  --c-surface: #ffffff !important;
  --c-surface-2: #f8fafc !important;
  --c-surface-3: #eef2f7 !important;
  --c-border: #e2e8f0 !important;
  --c-border-strong: #cbd5e1 !important;
  --c-text: #0f172a !important;
  --c-text-soft: #475569 !important;
  --c-muted: #64748b !important;
  color-scheme: light !important;
}
html, body {
  background: var(--c-bg) !important;
  color: var(--c-text) !important;
}

/* B) Contact split: oba stolpca enako visoka, gumba poravnana na dnu
   - .contact-v2-split: align-items: stretch (oba stolpca isto višino)
   - .contact-v2-form-card: flex column, padding-bottom usklajen z desnim stolpcem
   - desni stolpec (aside) nima padding-bottom in se konča z Odpri gumbom
   - levi: padding-bottom nastavimo glede na padding-bottom gumba na desni (~0.65rem),
     da je vizualna poravnava buttonov ena z drugo (ne pikselsko, ker je padding-top
     gumba ohranjen, ampak optično usklajeno) */
html body.contact-page .contact-v2-split,
html body.contact-page div.contact-v2-split {
  align-items: stretch !important;
}
html body.contact-page .contact-v2-form-card,
html body.contact-page article.contact-v2-form-card {
  display: flex !important;
  flex-direction: column !important;
  padding-bottom: 0 !important;
}
html body.contact-page .contact-v2-form-card .contact-v2-form,
html body.contact-page .contact-v2-form-card .contact-form {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  padding-bottom: clamp(1.2rem, 2.5vw, 1.6rem) !important;
}
html body.contact-page .contact-v2-form-card textarea {
  flex: 0 0 auto !important;
  min-height: 140px !important;
  height: 140px !important;
  max-height: 220px !important;
  resize: none !important;
}
/* Submit button: prilepi na DNO formke; vse polje nad njim "popolni" prostor */
html body.contact-page .contact-v2-form-card #contactSubmitBtn {
  margin-top: auto !important;
  align-self: flex-start !important;
}
/* Empty status paragraph: 0 height when empty so it doesn't push button up */
html body.contact-page .contact-v2-form-card .contact-form-status:empty {
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: 0 !important;
}
/* Status p mora biti za buttonom in ne sme blokirati margin-top:auto */
html body.contact-page .contact-v2-form-card form > .contact-form-status {
  order: 99 !important;
  margin-top: 0 !important;
}
@media (max-width: 880px) {
  html body.contact-page .contact-v2-form-card #contactSubmitBtn {
    align-self: stretch !important;
    width: 100% !important;
  }
  html body.contact-page .contact-v2-split,
  html body.contact-page div.contact-v2-split {
    align-items: start !important;
  }
  html body.contact-page .contact-v2-form-card,
  html body.contact-page article.contact-v2-form-card {
    padding-bottom: clamp(1rem, 2vw, 1.4rem) !important;
  }
  html body.contact-page .contact-v2-form-card .contact-v2-form,
  html body.contact-page .contact-v2-form-card .contact-form {
    padding-bottom: 0 !important;
  }
}

/* C) Carousel — manjše slike, deluje z vsemi 12 */
html body .store-carousel-track {
  scroll-snap-type: x proximity !important;
  scroll-padding-inline: 0.5rem !important;
}
html body .store-slide img {
  height: clamp(170px, 22vw, 240px) !important;
}
@media (min-width: 901px) {
  html body .store-slide img {
    height: clamp(190px, 24vw, 290px) !important;
  }
}
@media (min-width: 601px) and (max-width: 900px) {
  html body .store-slide img {
    height: clamp(170px, 30vw, 230px) !important;
  }
}
@media (max-width: 600px) {
  html body .store-slide img {
    height: clamp(160px, 46vw, 230px) !important;
  }
}
