.elementor-kit-11326{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-11326 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* Bazooka — Logo header sizing (force 22px height for SVG logo) */
.ast-site-identity .site-logo-img img,
.site-branding .custom-logo,
.ast-header-break-point .site-logo-img img,
.site-branding .custom-logo-link img {
  height: 22px !important;
  width: auto !important;
  max-width: none !important;
  max-height: 22px !important;
  object-fit: contain !important;
}

/* Bazooka — Hide site title next to logo (logo SVG already contains the wordmark) */
.ast-site-title-wrap,
.site-title,
.site-branding .site-title,
.ast-site-identity .site-title,
.site-description {
  display: none !important;
  visibility: hidden !important;
}

/* @bzk:tokens:start */
/* ============================================
   BAZOOKA — Tokens & decorative CSS
   (injecté dans Elementor Kit custom_css)
   Tout ce qui n'est pas paramétrable via Astra Customizer.
   Préfixe `--bzk-` / `.bzk-` pour ne pas marcher sur les vars natives.
   ============================================ */

:root {
  /* ---- Radii (Astra ne gère que le radius bouton) ---- */
  --bzk-radius-sm: 8px;
  --bzk-radius:    14px;
  --bzk-radius-lg: 22px;
  --bzk-radius-xl: 32px;

  /* ---- Shadows (4 niveaux + variante rouge) ---- */
  --bzk-shadow-sm:  0 1px 2px rgba(5,10,8,.04), 0 4px 14px -6px rgba(5,10,8,.08);
  --bzk-shadow:     0 2px 6px rgba(5,10,8,.05), 0 18px 40px -18px rgba(5,10,8,.15);
  --bzk-shadow-lg:  0 8px 20px rgba(5,10,8,.07), 0 40px 80px -30px rgba(5,10,8,.25);
  --bzk-shadow-red: 0 10px 40px -10px rgba(233,14,69,.45);

  /* ---- Opacités vertes (color-0 = #00CC63) ---- */
  --bzk-green-soft:   rgba(0,204,99,.08);
  --bzk-green-border: rgba(0,204,99,.15);
  --bzk-green-pulse:  rgba(0,204,99,.18);
  --bzk-green-glow:   rgba(0,204,99,.35);

  /* ---- Opacités rouges (color-8 = #E90E45) ---- */
  --bzk-red-soft:   rgba(233,14,69,.08);
  --bzk-red-border: rgba(233,14,69,.15);
  --bzk-red-pulse:  rgba(233,14,69,.18);
  --bzk-red-glow:   rgba(233,14,69,.35);
  --bzk-red-deep:   rgba(233,14,69,.45);

  /* ---- Backgrounds dark (hors palette Astra) ---- */
  --bzk-dark:    #0a0c0e;
  --bzk-dark-2:  #111418;
  --bzk-dark-3:  #1a1e24;

  /* ---- Lignes / borders alpha ---- */
  --bzk-line:      rgba(5,10,8,.08);
  --bzk-line-2:    rgba(5,10,8,.12);
  --bzk-line-dark: rgba(255,255,255,.08);

  /* ---- Variantes hiérarchiques noir/gris (compléments à color-2/3/7) ---- */
  --bzk-ink-soft:  #1a1f22;
  --bzk-ink-faint: #6b7075;

  /* ---- Paper alternatif (3e nuance crème, ≠ color-4) ---- */
  --bzk-paper-off: #f4f1eb;

  /* ---- Font mono (pas dans Astra customizer) ---- */
  --bzk-font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
}

/* ============================================
   DÉCORS — Glows lumineux (Hero, sections sombres)
   ============================================ */
.bzk-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: .55;
  pointer-events: none;
  z-index: -1;
}
.bzk-glow-red-1   { width: 600px; height: 600px; background: radial-gradient(circle, var(--bzk-red-glow), transparent 60%); top: -200px; right: -150px; }
.bzk-glow-red-2   { width: 500px; height: 500px; background: radial-gradient(circle, rgba(233,14,69,.20), transparent 60%); bottom: -200px; left: -150px; }
.bzk-glow-green-1 { width: 600px; height: 600px; background: radial-gradient(circle, var(--bzk-green-glow), transparent 60%); top: -200px; right: -150px; }
.bzk-glow-green-2 { width: 500px; height: 500px; background: radial-gradient(circle, rgba(0,204,99,.20), transparent 60%); bottom: -200px; left: -150px; }

/* ============================================
   DÉCORS — Grid masquée (background pattern subtil)
   ============================================ */
.bzk-grid-mask {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(5,10,8,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(5,10,8,.03) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, black 40%, transparent 100%);
          mask-image: radial-gradient(ellipse 80% 60% at 50% 40%, black 40%, transparent 100%);
  pointer-events: none;
}
.bzk-grid-mask-dark {
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
}

/* ============================================
   COMPOSANTS — Eyebrow (pill avec dot pulsant)
   ============================================ */
.bzk-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px; font-weight: 600; letter-spacing: .02em;
}
.bzk-eyebrow-green { background: var(--bzk-green-soft); color: var(--ast-global-color-0); border: 1px solid var(--bzk-green-border); }
.bzk-eyebrow-red   { background: var(--bzk-red-soft);   color: var(--ast-global-color-8); border: 1px solid var(--bzk-red-border); }
.bzk-eyebrow-light { background: var(--bzk-red-border); color: var(--ast-global-color-8); border: 1px solid rgba(233,14,69,.30); }
.bzk-eyebrow .bzk-dot { width: 6px; height: 6px; border-radius: 50%; }
.bzk-eyebrow-green .bzk-dot { background: var(--ast-global-color-0); box-shadow: 0 0 0 4px var(--bzk-green-pulse); }
.bzk-eyebrow-red   .bzk-dot { background: var(--ast-global-color-8); box-shadow: 0 0 0 4px var(--bzk-red-pulse); }

/* ============================================
   COMPOSANTS — Section sombre (dashboard, pricing dark)
   ============================================ */
.bzk-section-dark {
  background: var(--bzk-dark);
  color: var(--ast-global-color-5);
  position: relative;
  overflow: hidden;
}
.bzk-section-dark::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(233,14,69,.25), transparent 65%);
  filter: blur(60px);
  pointer-events: none;
}
.bzk-section-dark::after {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, black 30%, transparent 100%);
          mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, black 30%, transparent 100%);
  pointer-events: none;
}
.bzk-section-dark > * { position: relative; z-index: 1; }

/* ============================================
   HOVERS — Boutons (lift + glow rouge)
   Ciblage : widget Elementor `button` standard
   ============================================ */
.elementor-widget-button .elementor-button {
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.elementor-widget-button .elementor-button:hover {
  transform: translateY(-1px);
}
/* Bouton CTA primaire (vert) — soulèvement subtil avec glow vert */
.elementor-widget-button:not(.bzk-btn-red):not(.bzk-btn-dark):not(.bzk-btn-outline) .elementor-button:hover {
  box-shadow: 0 1px 0 rgba(255,255,255,.15) inset, 0 14px 32px -10px rgba(0,168,82,.55);
}
/* Variante rouge (à appliquer via CSS class du widget : bzk-btn-red) */
.bzk-btn-red .elementor-button {
  background: var(--ast-global-color-8) !important;
  color: var(--ast-global-color-5) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.15) inset, 0 8px 22px -8px var(--bzk-red-deep);
}
.bzk-btn-red .elementor-button:hover {
  background: #d00a3d !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.15) inset, 0 14px 32px -10px rgba(233,14,69,.7);
}
/* Variante dark */
.bzk-btn-dark .elementor-button {
  background: var(--ast-global-color-2) !important;
  color: var(--ast-global-color-5) !important;
}
.bzk-btn-dark .elementor-button:hover {
  background: #000 !important;
}
/* Variante outline */
.bzk-btn-outline .elementor-button {
  border: 1px solid var(--bzk-line-2) !important;
  background: var(--ast-global-color-5) !important;
  color: var(--ast-global-color-2) !important;
}
.bzk-btn-outline .elementor-button:hover {
  background: var(--ast-global-color-2) !important;
  color: var(--ast-global-color-5) !important;
  border-color: var(--ast-global-color-2) !important;
}
/* Variante ghost (link-only) */
.bzk-btn-ghost .elementor-button {
  background: transparent !important;
  color: var(--ast-global-color-2) !important;
}
.bzk-btn-ghost .elementor-button:hover {
  background: rgba(5,10,8,.05) !important;
}

/* ============================================
   HOVERS — Cartes "avantage" (.bzk-adv-card)
   Class à appliquer sur le container Elementor.
   ============================================ */
.bzk-adv-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--bzk-line);
  border-radius: var(--bzk-radius-lg);
  transition: border-color .2s, transform .2s, box-shadow .2s;
}
.bzk-adv-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: var(--ast-global-color-8);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s ease;
}
.bzk-adv-card:hover {
  border-color: transparent;
  transform: translateY(-4px);
  box-shadow: var(--bzk-shadow);
}
.bzk-adv-card:hover::before { transform: scaleX(1); }

/* ============================================
   HOVERS — Cartes feature (dark grid)
   ============================================ */
.bzk-feat-card {
  background: var(--bzk-dark-2);
  border: 1px solid var(--bzk-line-dark);
  border-radius: var(--bzk-radius-lg);
  transition: transform .2s ease, border-color .2s ease;
}
.bzk-feat-card:hover {
  transform: translateY(-3px);
  border-color: rgba(233,14,69,.3);
}
.bzk-feat-card-lg {
  background: linear-gradient(135deg, var(--bzk-dark-3), var(--bzk-dark));
}

/* ============================================
   HOVERS — Cartes prix
   ============================================ */
.bzk-price-card {
  background: var(--bzk-dark-2);
  border: 1px solid var(--bzk-line-dark);
  border-radius: var(--bzk-radius-lg);
  color: var(--ast-global-color-5);
  transition: transform .25s ease, border-color .25s ease;
}
.bzk-price-card:hover {
  transform: translateY(-4px);
  border-color: rgba(233,14,69,.3);
}
.bzk-price-card-featured {
  background: linear-gradient(180deg, #1d141a, #0e0b0d);
  border-color: rgba(233,14,69,.5);
  box-shadow: 0 40px 80px -30px rgba(233,14,69,.4);
}

/* ============================================
   HOVERS — Cartes affiliées (Hero mockup boxes)
   ============================================ */
.bzk-aff-card {
  background: var(--ast-global-color-5);
  border: 1px solid var(--bzk-line);
  border-radius: 18px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 10px 30px -12px rgba(5,10,8,.12),
    0 2px 6px -2px rgba(5,10,8,.06);
  transition: transform .35s cubic-bezier(.22,.61,.36,1), box-shadow .35s;
}
.bzk-aff-card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 20px 40px -14px var(--bzk-red-glow),
    0 4px 10px -2px rgba(5,10,8,.08);
}

/* ============================================
   COMPOSANTS — Step connector (pointillés horizontaux)
   ============================================ */
.bzk-step-connector {
  height: 2px;
  background: repeating-linear-gradient(90deg, var(--bzk-line-2) 0 6px, transparent 6px 12px);
}

/* ============================================
   COMPOSANTS — Marquee défilant (font-mono)
   ============================================ */
.bzk-marquee {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
          mask-image: linear-gradient(90deg, transparent, black 10%, black 90%, transparent);
}
.bzk-marquee-track {
  display: flex; gap: 32px; white-space: nowrap;
  animation: bzk-marquee-scroll 40s linear infinite;
  font-family: var(--bzk-font-mono);
  font-size: 13px;
  font-weight: 500;
  color: var(--bzk-ink-faint);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.bzk-marquee-track > *:nth-child(even) { color: var(--ast-global-color-8); }

/* ============================================
   COMPOSANTS — Code inline (font-mono, fond crème, accent rouge)
   ============================================ */
.bzk-code,
.bzk-faq-body code {
  font-family: var(--bzk-font-mono);
  font-size: 13.5px;
  background: var(--bzk-paper-off);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--ast-global-color-8);
}

/* ============================================
   COMPOSANTS — Highlight souligné sur titre h1
   .bzk-display-em — applique sur un <span> ou <em> dans un h1
   ============================================ */
.bzk-display-em {
  position: relative;
  font-style: normal;
  color: var(--ast-global-color-8);
  font-weight: 800;
}
.bzk-display-em::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 4%;
  height: 14%;
  background: rgba(233,14,69,.14);
  z-index: -1;
  border-radius: 2px;
}

/* ============================================
   COMPOSANTS — Stats big (chiffres énormes type 91%, +47%)
   ============================================ */
.bzk-stat-big {
  font-family: 'Inter Tight', sans-serif;
  font-weight: 900;
  font-size: 68px;
  line-height: 1;
  color: var(--ast-global-color-8);
  letter-spacing: -.04em;
}
.bzk-stat-big-unit { font-size: 36px; }
.bzk-stat-key {
  font-size: 12px;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 600;
}

/* ============================================
   COMPOSANTS — Carousel testimonials dots
   ============================================ */
.bzk-testi-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--bzk-line-2);
  transition: background .2s, width .2s;
  cursor: pointer;
}
.bzk-testi-dot.active {
  background: var(--ast-global-color-8);
  width: 24px;
  border-radius: 4px;
}

/* ============================================
   COMPOSANTS — FAQ accordion (style)
   ============================================ */
.bzk-faq-item {
  background: var(--ast-global-color-5);
  border: 1px solid var(--bzk-line);
  border-radius: var(--bzk-radius);
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.bzk-faq-item[open] {
  border-color: var(--bzk-line-2);
  box-shadow: var(--bzk-shadow-sm);
}
.bzk-faq-plus { position: relative; width: 20px; height: 20px; flex-shrink: 0; }
.bzk-faq-plus::before, .bzk-faq-plus::after {
  content: '';
  position: absolute;
  background: var(--ast-global-color-2);
  border-radius: 2px;
  transition: transform .2s, background .2s;
}
.bzk-faq-plus::before { top: 9px; left: 0; width: 20px; height: 2px; }
.bzk-faq-plus::after  { top: 0; left: 9px; width: 2px; height: 20px; }
.bzk-faq-item[open] .bzk-faq-plus::before { background: var(--ast-global-color-8); }
.bzk-faq-item[open] .bzk-faq-plus::after  { background: var(--ast-global-color-8); transform: rotate(90deg); }

/* ============================================
   COMPOSANTS — Final CTA (dark with red glow)
   ============================================ */
.bzk-final-cta {
  position: relative;
  background: var(--ast-global-color-2);
  color: var(--ast-global-color-5);
  border-radius: var(--bzk-radius-xl);
  overflow: hidden;
  isolation: isolate;
}
.bzk-final-cta::before {
  content: '';
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse 70% 50% at 50% 20%, rgba(233,14,69,.45), transparent 60%),
    radial-gradient(ellipse 40% 60% at 80% 80%, rgba(233,14,69,.20), transparent 60%);
}

/* ============================================
   ANIMATIONS — Float, pulse, scroll
   ============================================ */
@keyframes bzk-float    { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
@keyframes bzk-pulse    { 50% { box-shadow: 0 0 0 8px rgba(233,14,69,0); } }
@keyframes bzk-marquee-scroll { to { transform: translateX(-50%); } }
@keyframes bzk-aff-float { 0%, 100% { transform: translateY(var(--y0, 0)); } 50% { transform: translateY(calc(var(--y0, 0) - 6px)); } }

.bzk-float { animation: bzk-float 6s ease-in-out infinite; }
.bzk-aff-card-1 { --y0: -6px; animation: bzk-aff-float 7s   ease-in-out         infinite; }
.bzk-aff-card-2 { --y0: 12px; animation: bzk-aff-float 7s   ease-in-out .5s     infinite reverse; }
.bzk-aff-card-3 { --y0: 10px; animation: bzk-aff-float 7.5s ease-in-out .2s     infinite; }
.bzk-aff-card-4 { --y0: -4px; animation: bzk-aff-float 8s   ease-in-out .8s     infinite reverse; }
.bzk-aff-card:hover { animation-play-state: paused; }

/* ============================================
   COMPOSANTS — Callout rouge (CTA mid-page)
   ============================================ */
.bzk-callout {
  background: var(--ast-global-color-8);
  color: var(--ast-global-color-5);
  border-radius: var(--bzk-radius-xl);
  position: relative;
  overflow: hidden;
}
.bzk-ring {
  position: absolute;
  border: 2px solid rgba(255,255,255,.25);
  border-radius: 50%;
}
.bzk-ring-1 { width: 320px; height: 320px; top: 0;   right: -60px; border-color: rgba(255,255,255,.18); }
.bzk-ring-2 { width: 220px; height: 220px; top: 50px;  right: -10px; border-color: rgba(255,255,255,.32); }
.bzk-ring-3 {
  width: 120px; height: 120px; top: 100px; right: 40px;
  background: var(--ast-global-color-5); border: 0;
  box-shadow: 0 0 0 10px rgba(255,255,255,.15);
}

/* ============================================
   UTILS — Mode plein écran (sections en bleed)
   À appliquer sur un container Elementor pour casser la max-width 1240
   ============================================ */
.bzk-fullbleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  max-width: none !important;
}

/* ============================================
   FIX ASTRA — Wrapper .ast-container qui boxe les pages Elementor
   ============================================
   Astra inject un `<div class="ast-container">` autour du contenu de toute
   page, y compris les pages Elementor avec le template `elementor_header_footer`.
   Ce wrapper a un max-width (~1240px) et un padding horizontal qui empêchent
   les sections Elementor (`e-con-full`, `bzk-section-dark`, callouts edge-to-edge)
   d'occuper toute la largeur de la fenêtre.

   Solution : sur toute page avec body.elementor-page, neutraliser le wrapper.
   Le header/footer Astra restent boxés normalement (eux sont AVANT le content).
   ============================================ */
body.elementor-page #content > .ast-container,
body.elementor-template-full-width #content > .ast-container {
  max-width: none;
  padding-left: 0;
  padding-right: 0;
}

/* ============================================
   THEME OVERRIDES — Suite multi-produits Bazooka
   ============================================
   Architecture : Bazooka (umbrella, vert) + sous-produits par couleur.
   Chaque page dédiée à un sous-produit applique sa classe sur un container
   racine. Les enfants héritent des nouvelles valeurs de --ast-global-color-N.

   - Umbrella (default, vert)             : aucune classe — palette Astra brute
   - Bazooka Shopping (rouge, plugin live): `.bzk-theme-shopping`
   - Bazooka Love (rose, futur)           : `.bzk-theme-love` (placeholder)
   - Bazooka Travel (bleu, futur)         : `.bzk-theme-travel` (placeholder)

   Note : on ne touche PAS aux variables CSS globales d'Astra dans le :root —
   on les redéfinit uniquement dans le scope du wrapper de la page produit.
   Les vars `--bzk-green-*` et `--bzk-red-*` du fichier restent inchangées
   (elles servent de constantes neutres).
   ============================================ */

/* ---- Bazooka Shopping (rouge primaire) ---- */
.bzk-theme-shopping {
  --ast-global-color-0: #E90E45;  /* primaire → rouge */
  --ast-global-color-1: #d00a3d;  /* hover → rouge foncé */
  --ast-global-color-8: #00CC63;  /* l'ancien primaire (vert) devient l'accent */
}
/* Bouton primaire en mode shopping : glow rouge au lieu du vert */
.bzk-theme-shopping .elementor-widget-button:not(.bzk-btn-red):not(.bzk-btn-dark):not(.bzk-btn-outline) .elementor-button:hover {
  box-shadow: 0 1px 0 rgba(255,255,255,.15) inset, 0 14px 32px -10px rgba(233,14,69,.7);
}

/* ---- Bazooka Love (rose primaire) — placeholder, à calibrer ---- */
.bzk-theme-love {
  --ast-global-color-0: #FF4D8D;  /* à confirmer quand le plugin Love sortira */
  --ast-global-color-1: #E63D78;
  --ast-global-color-8: #00CC63;
}

/* ---- Bazooka Travel (bleu primaire) — placeholder, à calibrer ---- */
.bzk-theme-travel {
  --ast-global-color-0: #0085FF;  /* à confirmer quand le plugin Travel sortira */
  --ast-global-color-1: #0070D9;
  --ast-global-color-8: #00CC63;
}

/* ============================================
   HERO TEASER SLIDER — Bazooka Lab (3 slides)
   Slide 1 : Bazooka Shopping (révélé) — produits + bulles
   Slide 2 : R&D mystère (nom censuré)
   Slide 3 : Vision manifesto (pills)
   Frame chrome en vert (umbrella). Le markup et le JS sont
   embarqués dans un widget `html` Elementor.
   ============================================ */

.bzk-teaser-stage {
  position: relative;
  align-self: start;
  isolation: isolate;
  padding: 18px 4px 40px;
}
.bzk-teaser-bg {
  position: absolute; inset: -30px -40px; z-index: -1; pointer-events: none;
}
.bzk-teaser-bg::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(5,10,8,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(5,10,8,.04) 1px, transparent 1px);
  background-size: 34px 34px;
  -webkit-mask-image: radial-gradient(60% 60% at 50% 50%, #000 30%, transparent 80%);
          mask-image: radial-gradient(60% 60% at 50% 50%, #000 30%, transparent 80%);
}
.bzk-teaser-frame {
  position: relative;
  background: var(--ast-global-color-5);
  border: 1px solid var(--bzk-line);
  border-radius: 24px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 24px 60px -24px rgba(5,10,8,.18),
    0 6px 18px -10px rgba(5,10,8,.08);
  overflow: hidden;
}
.bzk-teaser-frame-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--bzk-line);
  background: linear-gradient(180deg, #fafaf7, var(--ast-global-color-5));
}
.bzk-teaser-status {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--bzk-font-mono);
  font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--bzk-ink-faint); font-weight: 600;
}
.bzk-teaser-status-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ast-global-color-0);
  box-shadow: 0 0 0 4px var(--bzk-green-pulse);
  animation: bzk-teaser-pulse 2.4s ease-in-out infinite;
}
@keyframes bzk-teaser-pulse {
  0%, 100% { box-shadow: 0 0 0 4px var(--bzk-green-pulse); }
  50%      { box-shadow: 0 0 0 8px rgba(0,204,99,0); }
}
.bzk-teaser-frame-id {
  font-family: var(--bzk-font-mono);
  font-size: 11px; letter-spacing: .04em;
  color: var(--bzk-ink-faint);
  font-variant-numeric: tabular-nums;
}
.bzk-teaser-track { position: relative; height: 540px; }
.bzk-teaser-slide {
  position: absolute; inset: 0;
  display: grid; grid-template-rows: 1fr auto;
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity .55s cubic-bezier(.2,.8,.2,1), transform .55s cubic-bezier(.2,.8,.2,1), visibility 0s linear .55s;
}
.bzk-teaser-slide.is-active {
  opacity: 1; visibility: visible; transform: translateY(0);
  transition: opacity .55s cubic-bezier(.2,.8,.2,1), transform .55s cubic-bezier(.2,.8,.2,1), visibility 0s;
}
.bzk-teaser-tag {
  position: absolute; top: 16px; left: 18px; z-index: 3;
  font-family: var(--bzk-font-mono);
  font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; font-weight: 700;
  padding: 6px 10px; border-radius: 999px;
  background: var(--bzk-green-soft);
  color: var(--ast-global-color-1);
  border: 1px solid var(--bzk-green-border);
}
.bzk-teaser-slide:not(.is-revealed) .bzk-teaser-tag {
  background: rgba(20,20,20,.06);
  color: #1a1a1a;
  border-color: rgba(20,20,20,.12);
}
.bzk-teaser-art {
  position: relative; overflow: hidden;
  background: linear-gradient(180deg, #fafaf7, #f3f3ee);
}
.bzk-teaser-art-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(5,10,8,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(5,10,8,.05) 1px, transparent 1px);
  background-size: 28px 28px;
  -webkit-mask-image: radial-gradient(80% 80% at 50% 50%, #000 30%, transparent 90%);
          mask-image: radial-gradient(80% 80% at 50% 50%, #000 30%, transparent 90%);
}
.bzk-teaser-art-shopping { background: linear-gradient(180deg, var(--ast-global-color-5), #fafaf7); padding: 14px; }
/* slide 1 mini affiliate cards (real product cards) */
.bzk-aff-mini {
  position: absolute;
  background: var(--ast-global-color-5);
  border: 1px solid var(--bzk-line);
  border-radius: 14px;
  padding: 10px 12px;
  display: grid; grid-template-columns: 56px 1fr; gap: 12px;
  align-items: center;
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 14px 32px -16px rgba(5,10,8,.18),
    0 2px 6px -2px rgba(5,10,8,.06);
  width: 280px; z-index: 2;
}
.bzk-aff-mini-1 { top: 18px;  left: 14px; }
.bzk-aff-mini-2 { top: 138px; left: 70px; z-index: 3; }
.bzk-aff-mini-3 { top: 258px; left: 26px; }
.bzk-aff-mini-img { width: 56px; height: 56px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.bzk-aff-mini-img img { width: 100%; height: 100%; object-fit: contain; }
.bzk-aff-mini-body { min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.bzk-aff-mini-title {
  font-family: 'Inter Tight', sans-serif; font-weight: 700; font-size: 12.5px; line-height: 1.25;
  color: var(--ast-global-color-8); letter-spacing: -.005em;
  display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden;
}
.bzk-aff-mini-row { display: flex; align-items: baseline; gap: 8px; }
.bzk-aff-mini-old { font-size: 11px; color: var(--bzk-ink-faint); text-decoration: line-through; font-weight: 500; }
.bzk-aff-mini-price { font-family: 'Inter Tight', sans-serif; font-weight: 800; font-size: 16px; color: var(--ast-global-color-2); letter-spacing: -.02em; }
.bzk-aff-mini-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 2px; }
.bzk-aff-mini-cta {
  display: inline-flex; align-items: center; padding: 5px 11px;
  background: var(--ast-global-color-8); color: var(--ast-global-color-5);
  font-family: 'Inter Tight', sans-serif; font-weight: 600; font-size: 11px;
  border-radius: 999px; letter-spacing: -.005em;
  box-shadow: 0 4px 10px -4px var(--bzk-red-deep);
}
.bzk-aff-mini-merchant { height: 16px; width: auto; object-fit: contain; opacity: .9; }
/* slide 1 info bubbles */
.bzk-aff-bubble {
  position: absolute; display: flex; align-items: center; gap: 8px;
  padding: 7px 11px;
  background: #FDECF0; border: 1px solid #FACBD6;
  border-radius: 12px;
  box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 12px 24px -12px rgba(5,10,8,.16);
  z-index: 4;
  animation: bzk-teaser-float 6s ease-in-out infinite;
}
.bzk-aff-bubble-prix   { top: 86px;  right: 14px; animation-delay: .2s; }
.bzk-aff-bubble-design { top: 196px; right: 6px;  animation-delay: .8s; }
.bzk-aff-bubble-seo    { top: 304px; right: 20px; animation-delay: 1.2s; }
.bzk-aff-bubble-ico {
  width: 26px; height: 26px; border-radius: 7px;
  background: var(--ast-global-color-8); color: var(--ast-global-color-5);
  display: flex; align-items: center; justify-content: center;
}
.bzk-aff-bubble-k { font-size: 9px; color: var(--bzk-ink-faint); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; line-height: 1; }
.bzk-aff-bubble-v { font-family: 'Inter Tight', sans-serif; font-weight: 700; font-size: 11.5px; margin-top: 2px; color: var(--ast-global-color-8); line-height: 1.1; }
/* Slide 2 — Mystery */
.bzk-teaser-art-mystery   { background: linear-gradient(135deg, #1c1f2a 0%, #25293a 50%, #1c1f2a 100%); color: rgba(255,255,255,.6); }
.bzk-teaser-art-mystery .bzk-teaser-art-grid {
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
}
.bzk-teaser-art-shape { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 60%; max-width: 280px; color: var(--ast-global-color-5); opacity: .9; }
.bzk-teaser-art-noise {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.06) 0%, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.04) 0%, transparent 40%);
  pointer-events: none;
}
.bzk-teaser-name-redacted {
  display: inline-block;
  background: linear-gradient(90deg, #1a1a1a 0%, #2a2a2a 100%);
  color: transparent; padding: 0 8px; margin-left: 4px;
  border-radius: 4px;
  font-family: var(--bzk-font-mono);
  font-size: 18px; letter-spacing: .04em; vertical-align: 1px;
  user-select: none;
}
/* Slide 3 — Manifesto */
.bzk-teaser-art-manifesto { background: linear-gradient(135deg, #fafaf7 0%, #f3f3ee 100%); }
.bzk-teaser-manifesto-stack {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; padding: 30px;
}
.bzk-teaser-mn-pill {
  font-family: 'Inter Tight', sans-serif; font-weight: 700; font-size: 17px;
  letter-spacing: -.01em;
  padding: 8px 18px;
  background: var(--ast-global-color-5); border: 1px solid var(--bzk-line);
  border-radius: 999px;
  color: rgba(5,10,8,.55);
  box-shadow: 0 8px 20px -10px rgba(5,10,8,.12);
  transform: rotate(-2deg);
}
.bzk-teaser-mn-pill-2 { transform: rotate(1.5deg); margin-left: 40px; }
.bzk-teaser-mn-pill-3 { transform: rotate(-1deg);  margin-right: 30px; }
.bzk-teaser-mn-pill-4 { transform: rotate(2deg);   margin-left: 20px; }
/* meta footer of each slide */
.bzk-teaser-meta {
  position: relative;
  padding: 22px 24px 24px;
  background: var(--ast-global-color-5);
  border-top: 1px solid var(--bzk-line);
}
.bzk-teaser-name {
  font-family: 'Inter Tight', sans-serif; font-weight: 800; font-size: 24px;
  letter-spacing: -.025em; color: var(--ast-global-color-2); line-height: 1.1;
}
.bzk-teaser-name-prefix       { color: var(--ast-global-color-2); }
.bzk-teaser-name-suffix-red   { color: var(--ast-global-color-8) !important; }
.bzk-teaser-desc {
  margin-top: 6px; font-size: 14px; line-height: 1.5;
  color: var(--bzk-ink-faint); max-width: 44ch;
}
/* Controls */
.bzk-teaser-controls {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px;
  border-top: 1px solid var(--bzk-line);
  background: #fafaf7;
}
.bzk-teaser-arrow {
  width: 32px; height: 32px; border-radius: 50%;
  border: 1px solid var(--bzk-line);
  background: var(--ast-global-color-5);
  color: var(--ast-global-color-2);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .2s, border-color .2s, transform .2s, color .2s;
}
.bzk-teaser-arrow:hover {
  background: var(--ast-global-color-2);
  color: var(--ast-global-color-5);
  border-color: var(--ast-global-color-2);
}
.bzk-teaser-arrow:active { transform: scale(.94); }
.bzk-teaser-dots { display: flex; gap: 8px; }
.bzk-teaser-dot {
  width: 8px; height: 8px; border-radius: 50%;
  border: none; background: rgba(5,10,8,.18);
  cursor: pointer; padding: 0;
  transition: background .25s, transform .25s, width .25s;
}
.bzk-teaser-dot:hover { background: rgba(5,10,8,.32); }
.bzk-teaser-dot.is-active {
  width: 22px; border-radius: 4px;
  background: var(--ast-global-color-0);
}
/* Floating chips around the frame */
.bzk-teaser-chip {
  position: absolute; display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: var(--ast-global-color-5);
  border: 1px solid var(--bzk-line); border-radius: 14px;
  box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 16px 36px -12px rgba(5,10,8,.16);
  z-index: 3;
  animation: bzk-teaser-float 6s ease-in-out infinite;
}
.bzk-teaser-chip-1 { top: -22px; left: -28px; animation-delay: .2s; }
.bzk-teaser-chip-2 { top: 38%;   right: -36px; animation-delay: .8s; }
.bzk-teaser-chip-3 { bottom: 24px; left: -34px; animation-delay: 1.2s; }
.bzk-teaser-chip-ico {
  width: 30px; height: 30px; border-radius: 9px;
  background: var(--ast-global-color-0); color: var(--ast-global-color-5);
  display: flex; align-items: center; justify-content: center;
}
.bzk-teaser-chip-ico-soon   { background: #1a1a1a; }
.bzk-teaser-chip-ico-secret { background: var(--ast-global-color-8); }
.bzk-teaser-chip-k { font-size: 10px; color: var(--bzk-ink-faint); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; }
.bzk-teaser-chip-v { font-family: 'Inter Tight', sans-serif; font-weight: 700; font-size: 13px; margin-top: 1px; color: var(--ast-global-color-2); }

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

@media (max-width: 1080px) {
  .bzk-teaser-stage { max-width: 640px; margin: 0 auto; }
  .bzk-teaser-track { height: 520px; }
  .bzk-teaser-chip-1 { left: 8px; top: -18px; }
  .bzk-teaser-chip-2 { right: 8px; }
  .bzk-teaser-chip-3 { left: 8px; }
}
@media (max-width: 560px) {
  .bzk-teaser-track { height: 500px; }
  .bzk-teaser-name { font-size: 20px; }
  .bzk-aff-mini { width: 240px; }
  .bzk-aff-mini-1 { left: 8px; }
  .bzk-aff-mini-2 { left: 40px; }
  .bzk-aff-mini-3 { left: 14px; }
  .bzk-teaser-chip { padding: 8px 10px; gap: 8px; }
  .bzk-teaser-chip-ico { width: 26px; height: 26px; }
  .bzk-teaser-chip-2 { right: -8px; }
  .bzk-teaser-chip-3 { display: none; }
}
/* @bzk:tokens:end *//* End custom CSS */