/* =============================================
   BLOOM EVENTS × ARTF — CATALOGUE
   Modern dark luxe — fond marbré
   ============================================= */

:root {
  --bg-deep: #0a0a0c;
  --bg: #0f0f12;
  --bg-card: #16161a;
  --bg-elev: #1c1c22;
  --line: rgba(255,255,255,0.08);
  --line-strong: rgba(255,255,255,0.18);
  --fg: #ededef;
  --fg-muted: #8a8f98;
  --fg-subtle: #5c606a;
  --accent: #e74c3c;
  --accent-warm: #f04438;
  --accent-soft: rgba(231,76,60,0.12);
  --gold: #FF5A00;
  --radius: 14px;
  --radius-lg: 20px;
  --radius-pill: 999px;
  --shadow: 0 8px 32px rgba(0,0,0,0.4);
  --shadow-hover: 0 20px 60px rgba(0,0,0,0.6);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --transition: 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.6;
  font-size: 16px;
  overflow-x: hidden;
}

.container { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 4vw; }

/* ============ HEADER ============ */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: rgba(10,10,12,0.7);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--line);
  transition: background var(--transition);
}
.site-header.scrolled { background: rgba(10,10,12,0.95); }
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 4vw;
}
.brand {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; color: var(--fg);
}
.brand-mark {
  display: inline-grid; place-items: center;
  width: 42px; height: 42px;
  background: linear-gradient(135deg, #1c1c22, #0a0a0c);
  border: 1px solid var(--gold);
  border-radius: 50%;
  font-family: var(--font-display);
  font-weight: 500; font-size: 24px;
  color: var(--gold);
  box-shadow: 0 4px 20px rgba(255,90,0,0.2);
}
.brand-wrap { display: flex; flex-direction: column; line-height: 1; gap: 2px; }
.brand-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: 2px;
  color: var(--gold);
}
.brand-sub {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.4em;
  color: var(--fg-muted);
  text-transform: uppercase;
}

.primary-nav { display: flex; gap: 36px; }
.primary-nav a {
  color: var(--fg-muted);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  position: relative;
  transition: color var(--transition);
}
.primary-nav a:hover, .primary-nav a.active { color: var(--fg); }
.primary-nav a.active::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -8px; height: 2px;
  background: var(--accent);
  border-radius: 1px;
}
.primary-nav .nav-phone {
  color: var(--orange);
  font-weight: 700;
  letter-spacing: 0.08em;
}

.nav-toggle {
  display: none;
  background: none; border: 1px solid var(--line-strong);
  width: 40px; height: 40px; border-radius: 8px;
  cursor: pointer; padding: 10px;
}
.nav-toggle span { display: block; height: 2px; background: var(--fg); margin: 4px 0; border-radius: 1px; }

/* ============ HERO ============ */
.hero {
  position: relative;
  min-height: 95vh;
  display: flex; align-items: center;
  overflow: hidden;
  padding-top: 80px;
}
.hero-bg {
  position: absolute; inset: 0;
  background: url('../images/textures/fond-marbre.jpg') center/cover no-repeat;
  background-attachment: fixed;
  filter: brightness(0.5) contrast(1.1);
  z-index: 1;
}
.hero-overlay {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 50%, rgba(231,76,60,0.18), transparent 60%),
    linear-gradient(180deg, rgba(10,10,12,0.85) 0%, rgba(10,10,12,0.4) 30%, rgba(10,10,12,0.95) 100%);
  z-index: 2;
}
.hero-inner { position: relative; z-index: 3; max-width: 900px; }
.eyebrow {
  display: inline-block;
  font-size: 11px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 24px;
  padding: 6px 14px;
  background: var(--accent-soft);
  border: 1px solid rgba(231,76,60,0.25);
  border-radius: var(--radius-pill);
}
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(48px, 8vw, 96px);
  font-weight: 500;
  line-height: 0.95;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
}
.hero-title em {
  font-style: italic;
  color: var(--gold);
  font-weight: 400;
}
.hero-accent {
  background: linear-gradient(135deg, var(--accent), var(--accent-warm));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero-sub {
  font-size: clamp(16px, 1.4vw, 19px);
  color: var(--fg-muted);
  max-width: 620px;
  margin-bottom: 40px;
  line-height: 1.7;
}
.hero-cta { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 64px; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 16px 32px;
  font-family: var(--font-body);
  font-size: 13px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  border-radius: var(--radius-pill);
  text-decoration: none;
  border: none; cursor: pointer;
  transition: all var(--transition);
}
.btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-warm));
  color: #fff;
  box-shadow: 0 8px 24px rgba(231,76,60,0.35);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(231,76,60,0.5); }
.btn-ghost {
  background: transparent;
  color: var(--fg);
  border: 1px solid var(--line-strong);
}
.btn-ghost:hover { background: rgba(255,255,255,0.05); border-color: var(--fg); }

.hero-stats { display: flex; gap: 56px; flex-wrap: wrap; }
.hero-stats > div { display: flex; flex-direction: column; gap: 4px; }
.hero-stats strong {
  font-family: var(--font-display);
  font-size: 42px; font-weight: 500;
  color: var(--fg);
}
.hero-stats span {
  font-size: 11px; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--fg-subtle);
}

/* ============ CAT NAV ============ */
.cat-nav {
  padding: 120px 0 40px;
  background: var(--bg);
}
.section-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 500;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
  text-align: center;
  text-transform: uppercase;
}
.section-title.light { text-align: left; text-transform: none; }
.section-sub {
  text-align: center;
  color: var(--fg-muted);
  margin-bottom: 48px;
  font-size: 15px;
}

.cat-controls {
  display: flex; flex-direction: column; align-items: center; gap: 24px;
  margin-bottom: 48px;
}
.search-wrap {
  position: relative;
  width: 100%; max-width: 540px;
}
.search-wrap svg {
  position: absolute; left: 18px; top: 50%; transform: translateY(-50%);
  color: var(--fg-subtle);
}
.search-wrap input {
  width: 100%;
  padding: 16px 48px 16px 48px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: 15px;
  transition: border-color var(--transition), background var(--transition);
}
.search-wrap input:focus { outline: none; border-color: var(--accent); background: var(--bg-elev); }
.search-wrap input::placeholder { color: var(--fg-subtle); }
.clear-btn {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: var(--line);
  color: var(--fg-muted);
  border: none;
  width: 28px; height: 28px;
  border-radius: 50%;
  font-size: 16px;
  cursor: pointer;
  display: none;
}
.clear-btn.visible { display: block; }
.clear-btn:hover { background: var(--accent); color: #fff; }

.cat-pills { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.pill {
  background: var(--bg-card);
  color: var(--fg-muted);
  border: 1px solid var(--line);
  padding: 10px 18px;
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: 13px; font-weight: 500;
  cursor: pointer;
  transition: all var(--transition);
  display: inline-flex; align-items: center; gap: 8px;
}
.pill:hover { color: var(--fg); border-color: var(--line-strong); }
.pill.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.pill .count {
  background: rgba(255,255,255,0.1);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  font-size: 11px;
}
.pill.active .count { background: rgba(255,255,255,0.25); }

/* ============ GRID ============ */
.catalogue-section { padding: 0 0 120px; background: var(--bg); }
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}
.card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  transition: all var(--transition);
  position: relative;
  display: flex; flex-direction: column;
  animation: fadeUp 0.5s cubic-bezier(0.2, 0.8, 0.2, 1) backwards;
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
.card:hover {
  transform: translateY(-6px);
  border-color: rgba(231,76,60,0.3);
  box-shadow: var(--shadow-hover);
}
.card-img {
  position: relative;
  aspect-ratio: 4 / 3;
  background: #0a0a0c center/cover no-repeat;
  overflow: hidden;
}
.card-img::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.4) 100%);
}
.card-ref {
  position: absolute; top: 14px; left: 14px; right: auto;
  background: rgba(10,10,12,0.72);
  color: rgba(245,245,240,0.78);
  border: 1px solid rgba(245,245,240,0.12);
  font-size: 11px; font-weight: 600; letter-spacing: 0.05em;
  padding: 5px 12px;
  border-radius: var(--radius-pill);
  z-index: 2;
}
.card-body {
  padding: 22px 22px 24px;
  display: flex; flex-direction: column;
  gap: 8px;
  flex: 1;
}
.card-cat {
  font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent);
}
.card-name {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 600;
  line-height: 1.2;
  color: var(--fg);
}
.card-feature-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 1px;
}
.card-feature {
  width: fit-content;
  border: 1px solid rgba(255,90,0,0.34);
  background: rgba(255,90,0,0.1);
  color: rgba(255,158,112,0.96);
  border-radius: 4px;
  padding: 4px 7px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

/* Removed: old BPM ambiance visualizer */
.lab-section {
  display: none !important;
}

.media-protection-on img,
.media-protection-on picture,
.media-protection-on video,
.media-protection-on canvas,
.media-protection-on .card-img,
.media-protection-on .modal-img,
.media-protection-on .pack-media,
.media-protection-on .b-media,
.media-protection-on .person-img-photo,
.media-protection-on .about-img,
.media-protection-on .bg-photo {
  -webkit-user-drag: none;
  -webkit-touch-callout: none;
  user-select: none;
}
.card-cta {
  margin-top: auto;
  padding-top: 14px;
  display: flex; align-items: center; justify-content: space-between;
  color: var(--fg-muted);
  font-size: 12px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.1em;
}
.card-cta svg { transition: transform var(--transition); }
.card:hover .card-cta { color: var(--accent); }
.card:hover .card-cta svg { transform: translateX(4px); }

.empty-state {
  text-align: center;
  padding: 80px 0;
  color: var(--fg-muted);
}

/* ============ ABOUT ============ */
.about { padding: 120px 0; background: var(--bg-deep); position: relative; }
.about::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--line-strong), transparent);
}
.about-inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 80px;
  align-items: center;
}
.about-lead { color: var(--fg-muted); font-size: 17px; margin-bottom: 40px; line-height: 1.8; }
.about-features { display: grid; gap: 20px; }
.feat {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 24px;
  align-items: baseline;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.feat strong {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--fg);
}
.feat span { color: var(--fg-muted); font-size: 15px; }

.about-img {
  aspect-ratio: 3 / 4;
  background: url('../images/textures/fond-marbre.jpg') center/cover no-repeat;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.about-img::after {
  content: 'BLOOM';
  position: absolute;
  inset: 0;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: clamp(80px, 14vw, 160px);
  font-weight: 500;
  color: rgba(255,255,255,0.08);
  letter-spacing: 0.05em;
}

/* ============ CONTACT ============ */
.contact { padding: 120px 0; background: var(--bg); }
.contact-card {
  max-width: 920px; margin: 0 auto;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 64px 56px;
  position: relative;
  overflow: hidden;
}
.contact-card::before {
  content: '';
  position: absolute; top: 0; right: 0; width: 60%; height: 100%;
  background: url('../images/textures/fond-marbre.jpg') center/cover;
  opacity: 0.06;
  z-index: 0;
}
.contact-card > * { position: relative; z-index: 1; }
.contact-lead { color: var(--fg-muted); font-size: 16px; margin-bottom: 36px; max-width: 600px; }

.contact-form { display: grid; gap: 20px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-field { display: grid; gap: 8px; }
.form-field label {
  font-size: 11px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--fg-subtle);
}
.form-field input, .form-field textarea {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 16px;
  color: var(--fg);
  font-family: var(--font-body);
  font-size: 15px;
  transition: border-color var(--transition);
}
.form-field input:focus, .form-field textarea:focus { outline: none; border-color: var(--accent); }
.form-field textarea { resize: vertical; min-height: 100px; }
.form-actions { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 8px; }

/* ============ FOOTER ============ */
.site-footer {
  background: var(--bg-deep);
  border-top: 1px solid var(--line);
  padding: 64px 0 24px;
}
.footer-inner {
  display: grid;
  grid-template-columns: 1.4fr 2fr;
  gap: 60px;
  margin-bottom: 48px;
}
.footer-brand { display: grid; gap: 12px; max-width: 320px; }
.footer-brand .brand-mark, .footer-brand strong {
  font-family: var(--font-display);
}
.footer-brand strong { font-size: 18px; }
.footer-brand p { color: var(--fg-muted); font-size: 14px; line-height: 1.6; }
.footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.footer-cols h4 {
  font-size: 11px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--fg-subtle);
  margin-bottom: 18px;
}
.footer-cols a {
  display: block;
  color: var(--fg-muted);
  text-decoration: none;
  font-size: 14px;
  padding: 4px 0;
  transition: color var(--transition);
}
.footer-cols a:hover { color: var(--accent); }
.footer-bottom {
  padding-top: 24px;
  border-top: 1px solid var(--line);
  color: var(--fg-subtle);
  font-size: 12px;
  text-align: center;
}

/* ============ MODAL ============ */
.modal {
  position: fixed; inset: 0; z-index: 1000;
  display: grid; place-items: center;
  padding: 4vw;
}
.modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.8);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  animation: fadeIn 0.3s;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.modal-card {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  max-width: 900px; width: 100%;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  overflow: hidden;
  animation: scaleIn 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
  box-shadow: 0 40px 100px rgba(0,0,0,0.6);
}
@keyframes scaleIn { from { transform: scale(0.92); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.modal-img {
  aspect-ratio: 1;
  background: #0a0a0c center/cover no-repeat;
}
.modal-body { padding: 48px 40px; display: flex; flex-direction: column; gap: 16px; }
.modal-cat {
  font-size: 11px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent);
}
.modal-body h3 {
  font-family: var(--font-display);
  font-size: 32px; font-weight: 600;
  line-height: 1.1;
}
.modal-full {
  color: var(--fg-muted);
  font-size: 14px;
  line-height: 1.6;
  max-height: 200px;
  overflow-y: auto;
}
.modal-actions { margin-top: auto; padding-top: 24px; }
.modal-close {
  position: absolute; top: 16px; right: 16px;
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--line-strong);
  color: #fff;
  width: 36px; height: 36px;
  border-radius: 50%;
  font-size: 20px;
  cursor: pointer;
  z-index: 2;
  transition: background var(--transition);
}
.modal-close:hover { background: var(--accent); }

/* ============ RESPONSIVE ============ */
@media (max-width: 900px) {
  .primary-nav { display: none; }
  .nav-toggle { display: block; }
  .hero-stats { gap: 28px; }
  .hero-stats strong { font-size: 32px; }
  .about-inner { grid-template-columns: 1fr; gap: 48px; }
  .footer-inner { grid-template-columns: 1fr; gap: 40px; }
  .footer-cols { grid-template-columns: 1fr 1fr; }
  .modal-card { grid-template-columns: 1fr; max-height: 90vh; overflow-y: auto; }
  .modal-img { aspect-ratio: 16/9; }
  .modal-body { padding: 32px 24px; }
  .contact-card { padding: 40px 24px; }
  .form-row { grid-template-columns: 1fr; }
  .feat { grid-template-columns: 1fr; gap: 8px; }
}
@media (max-width: 540px) {
  .grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; }
  .card-body { padding: 14px; }
  .card-name { font-size: 15px; }
  .hero-title { font-size: clamp(38px, 11vw, 56px); }
  .footer-cols { grid-template-columns: 1fr; }
}

/* ============ SCROLL REVEAL ============ */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.9s cubic-bezier(0.2,0.8,0.2,1), transform 0.9s cubic-bezier(0.2,0.8,0.2,1);
  will-change: opacity, transform;
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ============ PACKS ============ */
.packs-section {
  padding: 100px 0 60px;
  background: linear-gradient(180deg, var(--bg) 0%, var(--bg-deep) 100%);
  position: relative;
}
.packs-section .section-sub {
  color: var(--fg-muted);
  font-size: 17px;
  margin: 12px 0 48px;
  max-width: 600px;
}
.packs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
  margin-top: 48px;
}
.pack-card {
  background: linear-gradient(180deg, var(--bg-card) 0%, var(--bg-elev) 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  cursor: pointer;
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  overflow: hidden;
}
.pack-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0;
  transition: opacity var(--transition);
}
.pack-card:hover {
  transform: translateY(-6px);
  border-color: var(--gold);
  box-shadow: var(--shadow-hover);
}
.pack-card:hover::before { opacity: 1; }
.pack-icon {
  font-size: 36px;
  display: block;
  margin-bottom: 8px;
  filter: saturate(0.85);
}
.pack-card h3 {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 500;
  color: var(--fg);
  letter-spacing: 0.02em;
}
.pack-card > p {
  color: var(--fg-muted);
  font-size: 14px;
  line-height: 1.55;
}
.pack-features {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pack-features li {
  font-size: 13px;
  color: var(--fg-muted);
  padding-left: 18px;
  position: relative;
}
.pack-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 7px;
  height: 2px;
  border-radius: 99px;
  background: var(--gold);
  box-shadow: 0 0 10px rgba(255, 90, 0, 0.28);
  transform: translateY(-50%);
}
.pack-cta {
  margin-top: auto;
  padding-top: 16px;
  color: var(--accent);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: color var(--transition), gap var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.pack-card:hover .pack-cta { color: var(--accent-warm); gap: 10px; }

/* ============ HOW IT WORKS ============ */
.how-section {
  padding: 100px 0;
  background: var(--bg-deep);
  border-top: 1px solid var(--line);
}
.how-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 32px;
  margin-top: 56px;
}
.how-step {
  position: relative;
  padding: 32px 28px;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  transition: transform var(--transition), border-color var(--transition);
}
.how-step:hover {
  transform: translateY(-4px);
  border-color: var(--line-strong);
}
.how-num {
  font-family: var(--font-display);
  font-size: 56px;
  font-weight: 500;
  color: var(--gold);
  display: block;
  line-height: 1;
  margin-bottom: 16px;
  opacity: 0.85;
}
.how-step h3 {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 500;
  margin-bottom: 10px;
  color: var(--fg);
}
.how-step p {
  color: var(--fg-muted);
  font-size: 15px;
  line-height: 1.6;
}

/* ============ FAQ ============ */
.faq-section {
  padding: 100px 0;
  background: var(--bg);
}
.faq-list {
  max-width: 820px;
  margin: 48px auto 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.faq-item {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color var(--transition);
}
.faq-item[open] {
  border-color: var(--gold);
  background: var(--bg-elev);
}
.faq-item summary {
  padding: 20px 24px;
  cursor: pointer;
  font-size: 16px;
  font-weight: 500;
  color: var(--fg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  list-style: none;
  transition: color var(--transition);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+';
  font-size: 26px;
  font-weight: 300;
  color: var(--gold);
  transition: transform var(--transition);
  line-height: 1;
}
.faq-item[open] summary::after {
  transform: rotate(45deg);
}
.faq-item summary:hover { color: var(--gold); }
.faq-answer {
  padding: 0 24px 20px;
  color: var(--fg-muted);
  font-size: 15px;
  line-height: 1.7;
}

/* ============ FLOATING ELEMENTS ============ */
.float-btn {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: grid;
  place-items: center;
  text-decoration: none;
  box-shadow: 0 8px 24px rgba(231,76,60,0.4), 0 4px 12px rgba(0,0,0,0.3);
  z-index: 99;
  transition: transform var(--transition), box-shadow var(--transition);
}
.float-btn:hover {
  transform: scale(1.08) translateY(-2px);
  box-shadow: 0 12px 32px rgba(231,76,60,0.55), 0 6px 16px rgba(0,0,0,0.4);
}
.float-mail { right: 24px; bottom: 24px; }
.float-phone { right: 24px; bottom: 86px; }

.scroll-top {
  position: fixed;
  right: 24px;
  bottom: 96px;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(28,28,34,0.85);
  border: 1px solid var(--line-strong);
  color: var(--fg);
  display: grid;
  place-items: center;
  cursor: pointer;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
  z-index: 99;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity var(--transition), visibility var(--transition), transform var(--transition), background var(--transition);
}
.scroll-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.scroll-top:hover { background: var(--gold); color: var(--bg-deep); border-color: var(--gold); }

.sticky-cta-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  background: rgba(10,10,12,0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--line);
  z-index: 98;
  display: none;
  transform: translateY(100%);
  transition: transform var(--transition);
}
.sticky-cta-bar.visible { transform: translateY(0); }
.btn-block { display: block; text-align: center; width: 100%; }

/* ============ COUNTER ANIM ============ */
.hero-stats strong {
  display: inline-block;
  font-variant-numeric: tabular-nums;
}

/* ============ CARD HOVER LIFT ============ */
.card {
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
}
.card:hover .card-img { filter: brightness(1.08); }
.card-img { transition: filter var(--transition); }

/* ============ MOBILE ============ */
@media (max-width: 900px) {
  .packs-section { padding: 70px 0 40px; }
  .how-section { padding: 70px 0; }
  .faq-section { padding: 70px 0; }
  .how-num { font-size: 44px; }
  .pack-card { padding: 24px 22px; }

  .sticky-cta-bar { display: block; }
  /* Décale les boutons flottants au-dessus de la sticky bar */
  .float-mail { bottom: 84px; }
  .float-phone { bottom: 144px; }
  .scroll-top { bottom: 152px; }
  /* Espace bas du body pour pas que le sticky cache le footer */
  body { padding-bottom: 70px; }
}

/* ============ HERO GOLD BLOB & PARALLAX ============ */
.hero-bg {
  will-change: transform;
  transition: transform 0.05s linear;
}
.hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.hero-glow {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 800px;
  height: 800px;
  border-radius: 50%;
  background: radial-gradient(circle at center, rgba(255,90,0,0.18) 0%, rgba(255,90,0,0.06) 30%, transparent 70%);
  filter: blur(40px);
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 2;
  animation: heroGlowFloat 12s ease-in-out infinite;
  will-change: transform;
}
@keyframes heroGlowFloat {
  0%, 100% { transform: translate(-50%, -50%) scale(1); }
  33%      { transform: translate(-40%, -55%) scale(1.08); }
  66%      { transform: translate(-55%, -45%) scale(0.95); }
}
.hero-accent-glow {
  position: absolute;
  bottom: 8%;
  right: -10%;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(231,76,60,0.12) 0%, transparent 60%);
  filter: blur(60px);
  pointer-events: none;
  z-index: 2;
  animation: heroAccentFloat 16s ease-in-out infinite alternate;
}
@keyframes heroAccentFloat {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(-60px, -40px) scale(1.15); }
}

/* Hero inner devient z-index > glow */
.hero-inner { position: relative; z-index: 5; }

/* ============ HERO TITLE LETTER REVEAL ============ */
.hero-title .letter {
  display: inline-block;
  opacity: 0;
  transform: translateY(40px) rotate(8deg);
  animation: letterRise 0.7s cubic-bezier(0.2,0.8,0.2,1) forwards;
  will-change: transform, opacity;
}
.hero-title .letter.space { width: 0.28em; }
@keyframes letterRise {
  to { opacity: 1; transform: translateY(0) rotate(0); }
}

/* ============ MAGNETIC CTA ============ */
.btn-primary, .hero-cta .btn {
  will-change: transform;
  transition: transform 0.25s cubic-bezier(0.2,0.8,0.2,1), background var(--transition), box-shadow var(--transition);
}
.btn-primary {
  position: relative;
  overflow: hidden;
}
.btn-primary::before {
  content: '';
  position: absolute;
  inset: -2px;
  background: conic-gradient(from var(--shine-angle, 0deg), transparent 0deg, var(--gold) 80deg, transparent 160deg);
  opacity: 0;
  transition: opacity 0.3s;
  z-index: -1;
  border-radius: inherit;
  animation: shineRotate 4s linear infinite;
}
.btn-primary:hover::before { opacity: 0.55; }
@property --shine-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
@keyframes shineRotate {
  to { --shine-angle: 360deg; }
}

/* ============ 3D TILT CARDS ============ */
.card {
  transform-style: preserve-3d;
  will-change: transform;
}
.card-img { transform: translateZ(20px); transition: transform var(--transition), filter var(--transition); }
.card-body { transform: translateZ(10px); }
.card-cta { transform: translateZ(15px); }

/* ============ ANIMATED GLOW BORDER ON PACK CARDS ============ */
.pack-card {
  position: relative;
}
.pack-card::after {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(from var(--pack-angle, 0deg), transparent 0%, var(--gold) 25%, transparent 50%, transparent 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
}
.pack-card:hover::after {
  opacity: 1;
  animation: packBorderRotate 3s linear infinite;
}
@property --pack-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
@keyframes packBorderRotate {
  to { --pack-angle: 360deg; }
}

/* ============ MARQUEE LOGOS FOURNISSEURS ============ */
.marquee-section {
  padding: 50px 0 70px;
  background: var(--bg-deep);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
  position: relative;
}
.marquee-section::before,
.marquee-section::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 120px;
  z-index: 2;
  pointer-events: none;
}
.marquee-section::before { left: 0;  background: linear-gradient(to right, var(--bg-deep), transparent); }
.marquee-section::after  { right: 0; background: linear-gradient(to left,  var(--bg-deep), transparent); }
.marquee-label {
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--fg-subtle);
  margin-bottom: 28px;
}
.marquee-track {
  display: flex;
  gap: 64px;
  align-items: center;
  width: max-content;
  animation: marqueeScroll 35s linear infinite;
}
.marquee-track:hover { animation-play-state: paused; }
.marquee-brand {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--fg-muted);
  white-space: nowrap;
  opacity: 0.65;
  transition: color 0.3s, opacity 0.3s;
}
.marquee-brand:hover { color: var(--gold); opacity: 1; }
.marquee-dot {
  width: 5px; height: 5px;
  background: var(--gold);
  border-radius: 50%;
  flex-shrink: 0;
  opacity: 0.5;
}
@keyframes marqueeScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============ CURSOR BLOB ============ */
.cursor-blob {
  position: fixed;
  top: 0; left: 0;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,90,0,0.55), rgba(255,90,0,0) 70%);
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: width 0.25s, height 0.25s, background 0.25s;
  mix-blend-mode: screen;
  will-change: transform;
  display: none;
}
.cursor-blob.active { display: block; }
.cursor-blob.is-hover {
  width: 70px; height: 70px;
  background: radial-gradient(circle, rgba(255,90,0,0.4), rgba(231,76,60,0.1) 60%, transparent);
}
@media (hover: none), (max-width: 900px) {
  .cursor-blob { display: none !important; }
}

/* ============ TEXT SHIMMER (titre hero) ============ */
.hero-accent {
  background: linear-gradient(120deg, var(--accent) 0%, var(--gold) 50%, var(--accent) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: shimmerText 4s ease-in-out infinite;
}
@keyframes shimmerText {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}

/* ============ SECTION FADE-IN MASK ============ */
.packs-section, .how-section, .faq-section, .marquee-section, .contact {
  position: relative;
}

/* ============ HOVER GLOW ON STATS ============ */
.hero-stats div {
  transition: transform 0.4s cubic-bezier(0.2,0.8,0.2,1);
}
.hero-stats div:hover {
  transform: translateY(-4px);
}
.hero-stats strong {
  background: linear-gradient(180deg, var(--fg), var(--gold));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 2px 8px rgba(255,90,0,0.2));
}

/* ============ RIPPLE on click ============ */
.btn { position: relative; overflow: hidden; }
.btn .ripple {
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,0.4);
  transform: scale(0);
  animation: rippleAnim 0.7s ease-out;
  pointer-events: none;
}
@keyframes rippleAnim {
  to { transform: scale(4); opacity: 0; }
}


/* ============ CARD PRICE BADGE ============ */
.card-img { position: relative; }
.card-price {
  position: absolute;
  top: 12px;
  right: 12px;
  background: rgba(10,10,12,0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--gold);
  color: var(--gold);
  padding: 6px 12px;
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1;
  z-index: 3;
  box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}
.card-price strong {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--gold);
}
.card-price em {
  font-style: normal;
  font-size: 10px;
  font-weight: 500;
  color: var(--fg-muted);
  margin-left: 2px;
}
.card-price-quote {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-color: var(--line-strong);
  color: var(--fg-muted);
}

/* ============================================
   ARTF — LAB POLISH v2 (icons, lab, effects)
   ============================================ */

:root {
  --ease-soft: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --gold-2: #ff9148;
}

/* ============ Scroll progress bar (top) ============ */
.scroll-progress {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), var(--gold-2));
  transform-origin: 0 50%;
  transform: scaleX(0);
  z-index: 100;
  pointer-events: none;
  box-shadow: 0 0 12px rgba(255, 90, 0, 0.6);
}

/* ============ Hero particles canvas ============ */
.hero { position: relative; overflow: hidden; }
.hero-particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: screen;
  opacity: 0.9;
  mask-image: linear-gradient(to bottom, black 0%, black 75%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, black 0%, black 75%, transparent 100%);
}
.hero-inner { position: relative; z-index: 2; }

/* ============ Pack icons (SVG remplace emoji) ============ */
.pack-icon--svg {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 56px; height: 56px;
  border-radius: 14px;
  border: 1px solid var(--line-strong);
  background: linear-gradient(135deg, rgba(255,90,0,0.18), rgba(255,90,0,0.04));
  color: var(--gold);
  margin-bottom: 16px;
  transition: transform 0.4s var(--ease-soft), border-color 0.3s;
}
.pack-icon--svg svg { width: 28px; height: 28px; }
.pack-card:hover .pack-icon--svg {
  transform: translateY(-3px) rotate(-3deg);
  border-color: var(--gold);
}

/* ============ How icons ============ */
.how-step { position: relative; }
.how-icon {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 44px; height: 44px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: rgba(255,90,0,0.06);
  color: var(--gold);
  margin-bottom: 14px;
}
.how-icon svg { width: 22px; height: 22px; }

/* ============ Pill icons ============ */
.pill-icon {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 16px; height: 16px;
  margin-right: 6px;
  vertical-align: middle;
  color: var(--gold);
  opacity: 0.75;
  transition: opacity 0.3s, transform 0.3s var(--ease-soft);
}
.pill-icon svg { width: 14px; height: 14px; }
.pill:hover .pill-icon { opacity: 1; transform: translateY(-1px); }
.pill.active .pill-icon { opacity: 1; }

/* ============ Results count ============ */
.results-count {
  margin-top: 14px;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
  text-align: center;
}
.results-count #resultsCount { color: var(--gold); font-weight: 600; }

/* ============ Nav active (scroll-spy) ============ */
.primary-nav a {
  position: relative;
  transition: color 0.2s;
}
.primary-nav a::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -6px;
  height: 1px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: 0 50%;
  transition: transform 0.4s var(--ease-soft);
}
.primary-nav a.active,
.primary-nav a:hover { color: var(--gold); }
.primary-nav a.active::after,
.primary-nav a:hover::after { transform: scaleX(1); }

/* ============ Nav mobile drawer ============ */
.nav-toggle { display: none; }
@media (max-width: 900px) {
  .nav-toggle {
    display: inline-flex; flex-direction: column;
    gap: 4px; padding: 10px;
    background: transparent; border: 1px solid var(--line-strong);
    border-radius: 10px; cursor: pointer;
  }
  .nav-toggle span {
    width: 20px; height: 1.5px;
    background: var(--fg);
    transition: transform 0.3s, opacity 0.3s;
  }
  .nav-toggle.open span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2) { opacity: 0; }
  .nav-toggle.open span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }
  .primary-nav {
    display: flex !important;
    position: fixed;
    top: 70px; right: 0; left: 0;
    flex-direction: column;
    gap: 0;
    padding: 20px 24px 24px;
    background: rgba(15, 15, 18, 0.96);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--line);
    transform: translateY(-110%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: transform 0.4s var(--ease-soft);
    z-index: 99;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.42);
  }
  .primary-nav.open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  .primary-nav a { padding: 14px 0; font-size: 18px; }
  .primary-nav .nav-phone {
    margin-top: 6px;
    color: var(--gold);
    font-size: 16px;
  }
  .primary-nav a::after { display: none; }
}

/* ============ Ripple click effect ============ */
.btn, .pack-card, .pill { position: relative; overflow: hidden; }
.ripple {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 90, 0, 0.45) 0%, transparent 70%);
  transform: scale(0);
  animation: ripple-anim 700ms var(--ease-out) forwards;
  pointer-events: none;
  z-index: 0;
}
@keyframes ripple-anim {
  to { transform: scale(1); opacity: 0; }
}
.pack-card > *, .btn > *, .pill > * { position: relative; z-index: 1; }

/* ============ LAB SECTION ============ */
.lab-section {
  background: linear-gradient(180deg, var(--bg) 0%, var(--bg-deep) 100%);
  padding: 100px 0 80px;
  position: relative;
}
.lab-section::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 200px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0.5;
}
.lab-presets {
  display: flex; flex-wrap: wrap; gap: 10px;
  justify-content: center;
  margin: 36px 0 28px;
}
.lab-preset {
  padding: 10px 22px;
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--fg-muted);
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: all 0.3s var(--ease-soft);
}
.lab-preset:hover {
  color: var(--fg);
  border-color: var(--fg-muted);
}
.lab-preset.active {
  background: linear-gradient(135deg, rgba(255,90,0,0.22), rgba(255,90,0,0.06));
  border-color: var(--gold);
  color: var(--gold);
  box-shadow: 0 0 24px rgba(255,90,0,0.15);
}
.lab-stage {
  max-width: 720px;
  margin: 0 auto;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.3));
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  padding: 28px;
  position: relative;
  overflow: hidden;
}
.lab-stage::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top, rgba(255,90,0,0.08), transparent 60%);
  pointer-events: none;
}
.lab-lights {
  display: flex; justify-content: center; gap: 14px;
  margin-bottom: 20px;
  min-height: 18px;
}
.lab-light {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--gold-2);
  box-shadow: 0 0 16px rgba(255, 145, 72, 0.8);
  animation: lab-pulse 1.8s ease-in-out infinite;
}
@keyframes lab-pulse {
  0%, 100% { opacity: 0.4; transform: scale(0.85); }
  50% { opacity: 1; transform: scale(1.1); }
}
.lab-eq {
  display: block;
  width: 100%;
  height: 160px;
  max-width: 600px;
  margin: 0 auto;
}
.lab-bar { transition: height 0.08s linear, y 0.08s linear; }
.lab-info {
  display: flex; flex-direction: column; align-items: center;
  gap: 6px;
  margin-top: 24px;
  text-align: center;
  padding: 0 16px;
}
.lab-info strong {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  color: var(--gold);
}
.lab-info span {
  font-size: 14px;
  color: var(--fg-muted);
  max-width: 460px;
}
.lab-cta {
  display: flex; justify-content: center;
  margin-top: 36px;
}

/* ============ Card grid micro-anim ============ */
.card { transition: transform 0.45s var(--ease-soft), box-shadow 0.4s, border-color 0.3s; }
.card:focus-visible { outline: 2px solid var(--gold); outline-offset: 4px; }

/* Accessibilité — focus visible partout */
.btn:focus-visible,
.pill:focus-visible,
.pack-card:focus-visible,
.lab-preset:focus-visible,
input:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001s !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001s !important;
    scroll-behavior: auto !important;
  }
  .scroll-progress, .hero-particles { display: none !important; }
  .lab-light { animation: none; opacity: 0.8; }
}

/* ============================================
   ARTF V3 — INTEGRATION FUTURISTE ORANGE
   ============================================ */

:root {
  --orange: #FF5A00;
  --orange-bright: #ff8c4a;
  --orange-hot: #ffb04d;
  --orange-deep: #cc4400;
  --silver: #dadae0;
  --silver-dark: #7a7a85;
}

/* ============ HERO STAGE LIGHTS ============ */
.hero { position:relative; overflow:hidden; background:#06060a !important }
.hero-stage-lights {
  position:absolute; inset:0;
  pointer-events:none;
  z-index:1;
  mask-image:linear-gradient(180deg, black 0%, black 85%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, black 0%, black 85%, transparent 100%);
}
/* Sol perspective sous le hero */
.hero::after {
  content:''; position:absolute; left:0; right:0; bottom:0; height:35%;
  background:
    linear-gradient(180deg, transparent, rgba(255,90,0,0.05) 60%, rgba(255,90,0,0.12)),
    repeating-linear-gradient(90deg, transparent 0, transparent 79px, rgba(255,90,0,0.18) 79px, rgba(255,90,0,0.18) 80px);
  pointer-events:none; z-index:1;
  mask-image:linear-gradient(180deg, transparent, black 30%);
  -webkit-mask-image:linear-gradient(180deg, transparent, black 30%);
  transform-origin:50% 0; perspective:600px;
}
.hero-inner { position:relative; z-index:3 }
/* Hide les glows superflus de v2 */
.hero-glow, .hero-accent-glow { display:none !important }

/* Titre hero argent métallique */
.hero-title {
  background:linear-gradient(180deg, #fff 0%, var(--silver) 50%, var(--silver-dark) 100%);
  -webkit-background-clip:text; background-clip:text;
  color:transparent !important;
  filter:drop-shadow(0 0 30px rgba(255,90,0,0.15));
}
.hero-title em, .hero-title .hero-accent {
  font-style:italic;
  background:linear-gradient(180deg, var(--orange-bright), var(--orange) 50%, var(--orange-deep));
  -webkit-background-clip:text; background-clip:text;
  color:transparent !important;
}

/* ============ CARTES HOLOGRAPHIQUES ============ */
.card {
  transform-style:preserve-3d;
  transition:transform 0.15s ease-out, box-shadow 0.3s, border-color 0.3s;
  will-change:transform;
}
.holo-glow {
  position:absolute; inset:-2px; border-radius:18px; opacity:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,90,0,0.55), transparent 50%);
  transition:opacity 0.3s;
  pointer-events:none; z-index:0; filter:blur(20px);
}
.card:hover .holo-glow { opacity:1 }
.holo-ring {
  position:absolute; inset:0; border-radius:14px; pointer-events:none; opacity:0; transition:opacity 0.3s;
  box-shadow:inset 0 0 0 1px rgba(255,90,0,0.5), inset 0 0 30px rgba(255,90,0,0.08);
  z-index:2;
}
.card:hover .holo-ring { opacity:1 }
.holo-scan {
  position:absolute; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--orange) 50%, transparent);
  opacity:0; pointer-events:none; z-index:3;
  box-shadow:0 0 10px rgba(255,90,0,0.8);
}
.card:hover .holo-scan { animation:holo-scan-anim 1.8s linear infinite }
@keyframes holo-scan-anim {
  0%   { top:0; opacity:0 }
  10%  { opacity:1 }
  90%  { opacity:1 }
  100% { top:100%; opacity:0 }
}
/* Sweep reflet sur card-img */
.card .card-img { position:relative; overflow:hidden; }
.card .card-img::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(115deg, transparent 30%, rgba(255,90,0,0.3) 50%, transparent 70%);
  transform:translateX(-100%); transition:transform 0.7s cubic-bezier(0.22,1,0.36,1);
  pointer-events:none; z-index:2;
}
.card:hover .card-img::before { transform:translateX(100%) }

/* ============ BOUTONS METAL FIRE ============ */
.btn-primary, .btn.btn-primary {
  position:relative !important;
  background:linear-gradient(180deg, var(--orange-bright) 0%, var(--orange) 40%, var(--orange-deep) 100%) !important;
  color:#fff !important;
  border:none !important;
  border-radius:50px !important;
  font-weight:700 !important;
  letter-spacing:0.15em;
  text-transform:uppercase;
  font-size:13px !important;
  box-shadow:
    0 2px 0 #6b1f00,
    0 4px 0 #4a1500,
    0 10px 30px rgba(255,90,0,0.4),
    inset 0 1px 0 rgba(255,255,255,0.4) !important;
  transform:translateY(0);
  transition:transform 0.15s, box-shadow 0.15s !important;
  isolation:isolate;
}
.btn-primary:hover {
  transform:translateY(-3px) !important;
  box-shadow:
    0 5px 0 #6b1f00,
    0 7px 0 #4a1500,
    0 16px 36px rgba(255,90,0,0.55),
    inset 0 1px 0 rgba(255,255,255,0.5) !important;
}
.btn-primary:active { transform:translateY(2px) !important; box-shadow:0 0 0 #6b1f00, 0 2px 0 #4a1500, 0 4px 12px rgba(255,90,0,0.4) !important }

/* Bouton ghost (secondaire) — outline orange */
.btn-ghost, .btn.btn-ghost {
  background:transparent !important;
  color:#fff !important;
  border:1.5px solid rgba(255,140,74,0.5) !important;
  border-radius:50px !important;
  font-weight:600 !important;
  letter-spacing:0.15em;
  text-transform:uppercase;
  font-size:13px !important;
  transition:background 0.3s, border-color 0.3s, color 0.3s !important;
}
.btn-ghost:hover { background:rgba(255,90,0,0.12) !important; border-color:var(--orange-bright) !important; color:var(--orange-bright) !important }

/* Variant Fire avec flammes (utilisé sur lab CTA) */
.btn-fire { position:relative; display:inline-block; padding:0 !important; background:none !important; border:none !important; box-shadow:none !important }
.btn-fire-inner {
  display:inline-block; padding:18px 36px;
  background:linear-gradient(180deg, var(--orange-bright) 0%, var(--orange) 40%, var(--orange-deep) 100%);
  color:#fff; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; font-size:13px;
  border-radius:50px;
  box-shadow:
    0 2px 0 #6b1f00,
    0 4px 0 #4a1500,
    0 10px 30px rgba(255,90,0,0.4),
    inset 0 1px 0 rgba(255,255,255,0.4);
  transition:transform 0.15s, box-shadow 0.15s;
}
.btn-fire:hover .btn-fire-inner {
  transform:translateY(-3px);
  box-shadow: 0 5px 0 #6b1f00, 0 7px 0 #4a1500, 0 16px 36px rgba(255,90,0,0.6), inset 0 1px 0 rgba(255,255,255,0.5);
}
.btn-fire-flames { position:absolute; left:0; right:0; bottom:100%; height:70px; pointer-events:none; opacity:0; transition:opacity 0.2s; z-index:-1 }
.btn-fire:hover .btn-fire-flames { opacity:1 }
.flame {
  position:absolute; bottom:0; width:18px; height:50px;
  background:radial-gradient(ellipse at 50% 100%, var(--orange-hot) 0%, var(--orange) 40%, transparent 70%);
  border-radius:50% 50% 20% 20%;
  filter:blur(2px);
  animation:flame-flicker 0.35s ease-in-out infinite alternate;
  transform-origin:bottom center;
}
@keyframes flame-flicker {
  0%   { transform:scaleY(1) scaleX(1) translateY(0); opacity:0.9 }
  100% { transform:scaleY(1.3) scaleX(0.85) translateY(-6px); opacity:0.6 }
}

/* ============ LAB EQUALIZER FULL ============ */
.lab-section {
  background:linear-gradient(180deg, var(--bg) 0%, #050507 100%);
  padding:100px 0 80px;
  position:relative;
  overflow:hidden;
}
.lab-section::before {
  content:''; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:200px; height:1px;
  background:linear-gradient(90deg, transparent, var(--orange), transparent);
  opacity:0.6;
}
.lab-section .section-title em { font-style:italic; color:var(--orange) }
.lab-presets {
  display:flex; flex-wrap:wrap; gap:10px;
  justify-content:center; margin:36px 0 36px;
}
.lab-preset {
  padding:10px 22px;
  background:transparent;
  border:1px solid var(--line-strong);
  color:var(--fg-muted);
  border-radius:var(--radius-pill);
  font-family:var(--font-body);
  font-size:12px; font-weight:600;
  letter-spacing:0.1em;
  cursor:pointer;
  transition:all 0.3s var(--ease-soft);
}
.lab-preset:hover { color:var(--fg); border-color:var(--fg-muted) }
.lab-preset.active {
  background:linear-gradient(135deg, rgba(255,90,0,0.25), rgba(255,90,0,0.08));
  border-color:var(--orange);
  color:var(--orange-bright);
  box-shadow:0 0 24px rgba(255,90,0,0.2);
}
.lab-eq-wrap {
  position:relative;
  max-width:900px; margin:0 auto;
  height:260px;
  background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.4));
  border:1px solid var(--line-strong);
  border-radius:var(--radius-lg);
  padding:20px;
  overflow:hidden;
}
.lab-bpm {
  position:absolute; top:14px; right:18px; z-index:3;
  font-family:'JetBrains Mono', monospace;
  font-size:11px; color:var(--fg-muted); letter-spacing:0.2em;
}
.lab-bpm strong { color:var(--orange-bright); font-weight:700; font-size:14px; margin-left:4px }
.lab-eq {
  position:absolute; inset:20px;
  display:flex; align-items:flex-end; gap:4px;
  z-index:1;
}
.lab-bar {
  flex:1;
  background:linear-gradient(180deg,
    var(--orange-hot) 0%,
    var(--orange) 30%,
    var(--orange-deep) 70%,
    #8a2e00 100%);
  border-radius:2px 2px 0 0;
  height:5%;
  box-shadow:0 -4px 12px rgba(255,90,0,0.4);
  transition:none;
}
.lab-floor {
  position:absolute; left:0; right:0; bottom:0; height:30%;
  background:linear-gradient(180deg, transparent, rgba(255,90,0,0.08));
  pointer-events:none; z-index:2;
}
.lab-flash {
  position:absolute; inset:0; background:rgba(255,90,0,0); pointer-events:none; z-index:3;
  transition:background 0.1s;
}
.lab-flash.on { background:rgba(255,90,0,0.04) }
.lab-info {
  display:flex; flex-direction:column; align-items:center;
  gap:6px; margin-top:28px; text-align:center; padding:0 16px;
}
.lab-info strong { font-family:var(--font-display); font-size:22px; font-weight:500; color:var(--orange-bright) }
.lab-info span { font-size:14px; color:var(--fg-muted); max-width:520px }
.lab-cta { display:flex; justify-content:center; margin-top:32px }
/* Hide old lab elements */
.lab-stage, .lab-lights { display:none !important }

/* ============ CURSEUR LIQUID MAGNETIC ============ */
@media (hover:hover) and (pointer:fine) {
  html.lc-on, html.lc-on * { cursor:none !important }
  html.lc-on input, html.lc-on textarea, html.lc-on select { cursor:text !important }
}
.lc-cursor {
  position:fixed; top:0; left:0; pointer-events:none; z-index:9999;
  width:36px; height:36px; margin:-18px 0 0 -18px;
  border:1.5px solid var(--orange);
  border-radius:50%;
  mix-blend-mode:exclusion;
  transition:width 0.35s cubic-bezier(0.22,1,0.36,1), height 0.35s cubic-bezier(0.22,1,0.36,1), margin 0.35s cubic-bezier(0.22,1,0.36,1), border-radius 0.35s cubic-bezier(0.22,1,0.36,1), background 0.35s, opacity 0.3s;
}
.lc-dot {
  position:fixed; top:0; left:0; pointer-events:none; z-index:9999;
  width:6px; height:6px; margin:-3px 0 0 -3px; border-radius:50%; background:var(--orange);
}
.lc-cursor.lc-hover-btn  { width:140%; height:140%; margin:-25px 0 0 -25px; background:rgba(255,90,0,0.2); border-color:transparent }
.lc-cursor.lc-hover-text { width:80px; height:80px; margin:-40px 0 0 -40px; background:rgba(255,90,0,0.08); border-color:var(--orange) }
.lc-cursor.lc-hover-text::before { content:'LIRE'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:var(--orange); font-size:10px; letter-spacing:0.2em; font-weight:700 }
.lc-cursor.lc-hover-card { width:70px; height:70px; margin:-35px 0 0 -35px; background:rgba(255,90,0,0.15); border-radius:12px }
.lc-trail {
  position:fixed; pointer-events:none; z-index:9998;
  width:4px; height:4px; margin:-2px 0 0 -2px; border-radius:50%; background:var(--orange); opacity:0.3;
}
/* Hide old cursor blob if any */
#cursorBlob, .cursor-blob { display:none !important }

@media (prefers-reduced-motion:reduce) {
  .hero-stage-lights, .lc-cursor, .lc-dot, .lc-trail { display:none !important }
  .lab-bar, .holo-scan, .flame { animation:none !important }
  html.lc-on, html.lc-on * { cursor:auto !important }
}

/* ============================================
   ARTF V3.1 — GLITCH + MARQUEE BRUTALIST + LOGO SVG
   ============================================ */

/* ============ GLITCH HERO TITLE ============ */
.hero-title { min-height:1.05em; }
.glitch-char {
  display:inline-block;
  position:relative;
  opacity:0;
  min-width:0.2em;
}
.glitch-char.visible { opacity:1; }
.glitch-char.glitching {
  color:transparent !important;
  -webkit-text-fill-color:transparent;
  background:linear-gradient(180deg, var(--orange-bright), var(--orange), var(--orange-deep));
  -webkit-background-clip:text; background-clip:text;
}
.glitch-char.glitching::before,
.glitch-char.glitching::after {
  content:attr(data-char);
  position:absolute; left:0; top:0;
  mix-blend-mode:screen;
  background:none !important;
  -webkit-background-clip:initial; background-clip:initial;
}
.glitch-char.glitching::before { color:#ff3399; transform:translate(-2px, 1px); opacity:0.7 }
.glitch-char.glitching::after  { color:#00d4ff; transform:translate(2px, -1px);  opacity:0.7 }

/* ============ LOGO BRAND SVG ============ */
.brand-mark-svg {
  display:inline-flex !important;
  align-items:center; justify-content:center;
  width:42px !important; height:42px !important;
  background:transparent !important;
  border:none !important;
  padding:0 !important;
}
.brand-mark-svg svg {
  display:block;
  filter:drop-shadow(0 4px 12px rgba(255,90,0,0.18));
}
.brand .artf-picto-official { color:#f5f5f0; transition:transform 0.5s cubic-bezier(0.22,1,0.36,1) }
.brand:hover .artf-picto-official { transform:rotate(-3deg) scale(1.05) }
.brand-name { letter-spacing:0.05em }
.brand-sub { color:var(--orange) !important; letter-spacing:0.3em; font-weight:600 }

/* ============ MARQUEE BRUTALIST ============ */
.marquee-brutalist {
  overflow:hidden;
  padding:0;
  background:var(--orange);
  color:#000;
  font-family:'Helvetica Neue', Arial Black, sans-serif;
  font-weight:900;
  font-size:18px;
  letter-spacing:0.05em;
  text-transform:uppercase;
  border-top:2px solid #000;
  border-bottom:2px solid #000;
  margin:0;
}
.marquee-brutalist.marquee-dark {
  background:#000;
  color:var(--orange);
  border-top:none;
  border-bottom:1px solid rgba(255,90,0,0.4);
}
.marquee-track-brutalist {
  display:flex;
  gap:48px;
  white-space:nowrap;
  animation:mb-scroll 32s linear infinite;
  padding:14px 0;
}
.marquee-track-brutalist.reverse {
  animation-direction:reverse;
  animation-duration:38s;
}
.mb-item { padding-left:48px; flex-shrink:0 }
@keyframes mb-scroll {
  from { transform:translateX(0) }
  to   { transform:translateX(-50%) }
}

/* ============ BOUTONS FIRE GLOBAUX ============ */
/* Le hero CTA + tous les .btn-primary ont déjà le style metal */
/* On rajoute juste les flammes au survol sur les CTA majeurs */
.hero-cta .btn-primary, .contact-form .btn-primary, .lab-cta .btn-primary {
  position:relative;
  isolation:isolate;
}
.hero-cta .btn-primary::after,
.contact-form .btn-primary::after,
.lab-cta .btn-primary::after {
  content:'';
  position:absolute; left:10%; right:10%; bottom:100%;
  height:60px;
  background:
    radial-gradient(ellipse 18% 100% at 15% 100%, var(--orange-hot), transparent 70%),
    radial-gradient(ellipse 18% 100% at 38% 100%, var(--orange), transparent 70%),
    radial-gradient(ellipse 18% 100% at 62% 100%, var(--orange-bright), transparent 70%),
    radial-gradient(ellipse 18% 100% at 85% 100%, var(--orange), transparent 70%);
  filter:blur(3px);
  opacity:0;
  transition:opacity 0.25s;
  pointer-events:none;
  animation:cta-flame-float 0.4s ease-in-out infinite alternate;
  z-index:-1;
}
.hero-cta .btn-primary:hover::after,
.contact-form .btn-primary:hover::after,
.lab-cta .btn-primary:hover::after {
  opacity:0.9;
}
@keyframes cta-flame-float {
  0%   { transform:translateY(0) scaleY(1) }
  100% { transform:translateY(-6px) scaleY(1.15) }
}

/* ============ HERO BG (force noir profond) ============ */
.hero { background:#06060a; }
.hero-bg { display:none !important }
.hero-overlay { background:linear-gradient(180deg, transparent, rgba(0,0,0,0.4)) !important }

/* ============ STATUS LINE HERO ============ */
.hero-inner::before {
  content:'▸ SYSTEM ONLINE · ARTF · STRASBOURG';
  position:absolute;
  top:-50px; left:50%; transform:translateX(-50%);
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.3em;
  color:var(--orange);
  opacity:0.6;
  white-space:nowrap;
}
.hero-inner { position:relative; padding-top:50px }

/* ============================================
   ARTF V4 — BRAND KIT OFFICIEL
   Rajdhani (titres) + Montserrat (corps)
   Couleurs : #FF5A00 / #0A0A0A / #151515 / #2A2A2A
   ============================================ */

:root {
  --orange: #FF5A00;
  --orange-bright: #ff8c4a;
  --orange-hot: #ffb04d;
  --orange-deep: #cc4400;
  --noir-profond: #0A0A0A;
  --gris-ardoise: #151515;
  --gris-fonce: #2A2A2A;
  --silver: #dadae0;
  --silver-dark: #7a7a85;
  --font-display: 'Rajdhani', 'Helvetica Neue', sans-serif;
  --font-body: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

/* Override la palette de base */
body {
  font-family:'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif !important;
  background:#0A0A0A !important;
}
.hero { background:#0A0A0A !important }

/* ========== TYPOGRAPHIES ========== */
h1, h2, h3, h4,
.section-title, .hero-title,
.brand-name, .brand-sub {
  font-family:'Rajdhani', 'Helvetica Neue', sans-serif !important;
  font-weight:700 !important;
  letter-spacing:0.01em !important;
}
.hero-title { font-weight:700 !important; letter-spacing:-0.02em !important }
.hero-title em, .hero-title .hero-accent { font-style:normal !important; font-weight:700 !important }

.eyebrow, .marquee-label, .results-count, .card-cat, .pill, .pack-cta, .how-num {
  font-family:'Montserrat', sans-serif !important;
  font-weight:600 !important;
  letter-spacing:0.25em !important;
  text-transform:uppercase;
}
.btn, .btn-primary, .btn-ghost, .btn-fire-inner, .lab-preset {
  font-family:'Montserrat', sans-serif !important;
  font-weight:700 !important;
  letter-spacing:0.18em !important;
}
.card-name, .pack-card h3, .how-step h3, .faq-item summary {
  font-family:'Rajdhani', sans-serif !important;
  font-weight:600 !important;
  letter-spacing:0;
}
.lab-info strong { font-family:'Rajdhani', sans-serif !important; font-weight:700 !important; font-size:32px !important; letter-spacing:0.05em }

/* ========== BRAND HEADER ========== */
.brand-mark-svg { width:46px !important; height:54px !important }
.brand-name { font-size:24px !important; font-weight:700 !important; letter-spacing:0.08em !important; color:#fff }
.brand-sub { font-size:9px !important; color:var(--orange) !important; font-weight:600 !important; letter-spacing:0.28em !important }

/* ========== ANIMATIONS LOGO ========== */
.artf-logo { will-change:transform; filter:drop-shadow(0 4px 16px rgba(255,90,0,0.35)) }
.artf-beam {
  transform-origin:50% 38px;
  animation:logo-beam-pulse 2s ease-in-out infinite;
}
@keyframes logo-beam-pulse {
  0%, 100% { opacity:0.85; transform:scaleY(1) }
  50%      { opacity:1;    transform:scaleY(1.05) }
}
.artf-speaker-l, .artf-speaker-r {
  transform-origin:center;
  animation:logo-speaker-vibe 0.6s ease-in-out infinite;
}
.artf-speaker-r { animation-delay:0.3s }
@keyframes logo-speaker-vibe {
  0%, 100% { transform:translate(0, 0) }
  50%      { transform:translate(0, 0.6px) }
}
.brand:hover .artf-beam { animation-duration:0.8s }
.brand:hover .artf-speaker-l, .brand:hover .artf-speaker-r {
  animation-duration:0.2s;
}

/* ========== HERO TAGLINE (services) ========== */
.hero-tagline {
  font-family:'Rajdhani', sans-serif;
  font-size:14px;
  font-weight:600;
  letter-spacing:0.35em;
  color:var(--orange);
  margin:18px 0 24px;
  text-transform:uppercase;
}
.hero-tagline::before {
  content:'';
  display:inline-block;
  width:30px; height:1px; vertical-align:middle;
  background:var(--orange);
  margin-right:14px;
}
.hero-tagline::after {
  content:'';
  display:inline-block;
  width:30px; height:1px; vertical-align:middle;
  background:var(--orange);
  margin-left:14px;
}
.hero-sub { font-family:'Montserrat',sans-serif; font-weight:400; color:#aaa !important }

/* ========== UI COMPONENTS — TYPO TWEAKS ========== */
.section-title { font-size:48px !important; letter-spacing:-0.01em !important; line-height:1.05 }
.section-sub { font-family:'Montserrat',sans-serif; font-weight:400 }
.btn { font-size:12px !important; padding:18px 36px !important }
.btn-primary { font-size:12px !important }

/* Hero counters style number */
.hero-stats strong {
  font-family:'Rajdhani',sans-serif !important;
  font-weight:700 !important;
  font-size:48px !important;
  letter-spacing:0;
  color:#fff;
}
.hero-stats span { font-family:'Montserrat',sans-serif; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; font-size:10px; color:var(--orange) }

/* Card price metallic */
.card-price strong { font-family:'Rajdhani', sans-serif !important; font-weight:700 !important; font-size:18px !important; color:var(--orange) }

/* Lab BPM number */
.lab-bpm strong { font-family:'Rajdhani', sans-serif !important; font-size:16px !important }

/* Marquee brutalist en Rajdhani Black */
.marquee-brutalist { font-family:'Rajdhani', sans-serif !important; font-weight:700 !important; letter-spacing:0.1em }

/* ============================================
   ARTF V4.1 — MINIMALISATION (anti-fête foraine)
   ============================================ */

/* Hero : titre 100% lisible, blanc franc */
.hero-title {
  color:#fff !important;
  background:none !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  -webkit-text-fill-color:#fff !important;
  filter:none !important;
  text-shadow:0 2px 24px rgba(0,0,0,0.4);
  font-weight:600 !important;
}
.hero-title em, .hero-title .hero-accent {
  color:var(--orange) !important;
  background:none !important;
  -webkit-text-fill-color:var(--orange) !important;
  font-style:normal !important;
  font-weight:700 !important;
}
.hero-sub { color:rgba(237,237,239,0.7) !important; font-weight:400 }
.hero-tagline {
  color:var(--orange) !important;
  font-size:11px !important;
  letter-spacing:0.4em !important;
  font-weight:500 !important;
  margin:16px 0 28px !important;
}
.hero-tagline::before, .hero-tagline::after {
  width:18px !important;
  height:1px !important;
  background:rgba(255,90,0,0.5) !important;
}
.eyebrow {
  color:rgba(237,237,239,0.45) !important;
  font-weight:500 !important;
  letter-spacing:0.4em !important;
  background:none !important;
  border:none !important;
  padding:0 !important;
}

/* Hero stats : reset au propre Rajdhani */
.hero-stats strong {
  font-family:'Rajdhani',sans-serif !important;
  font-size:42px !important;
  font-weight:600 !important;
  color:#fff !important;
  letter-spacing:0 !important;
}
.hero-stats span { color:rgba(237,237,239,0.4) !important; letter-spacing:0.25em }

/* Sol grille et bokeh : éliminés */
.hero::after { display:none !important }
.hero-glow, .hero-accent-glow, .hero-bg, .hero-overlay { display:none !important }
.hero-particles, .hero-stage-lights { opacity:0.6 !important }

/* Status line "SYSTEM ONLINE" : enlevée */
.hero-inner::before { display:none !important }
.hero-inner { padding-top:0 !important }

/* Marquee : sober — fond noir mat, texte gris, repères orange uniquement */
.marquee-brutalist {
  background:#0e0e10 !important;
  color:rgba(237,237,239,0.6) !important;
  border-top:1px solid rgba(255,255,255,0.06) !important;
  border-bottom:1px solid rgba(255,255,255,0.06) !important;
  font-weight:500 !important;
  font-size:13px !important;
  letter-spacing:0.3em !important;
}
.marquee-brutalist.marquee-dark {
  background:#0a0a0a !important;
  color:rgba(255,90,0,0.7) !important;
  border-top:none !important;
}
.marquee-track-brutalist { padding:18px 0 !important }
.mb-item { font-weight:500 !important }
/* Colorize la signalétique en orange */
.marquee-brutalist .mb-item {
  background:linear-gradient(90deg, currentColor, currentColor) !important;
  color:rgba(237,237,239,0.55) !important;
}

/* CTA principal — moins extrudé, plus tech minimal */
.btn-primary, .btn.btn-primary {
  background:var(--orange) !important;
  box-shadow:0 8px 24px rgba(255,90,0,0.25), inset 0 1px 0 rgba(255,255,255,0.15) !important;
  border-radius:6px !important;
  font-size:11px !important;
  padding:18px 36px !important;
  letter-spacing:0.25em !important;
}
.btn-primary:hover {
  transform:translateY(-2px) !important;
  box-shadow:0 12px 32px rgba(255,90,0,0.4), inset 0 1px 0 rgba(255,255,255,0.2) !important;
}
.btn-ghost {
  border:1px solid rgba(255,255,255,0.2) !important;
  border-radius:6px !important;
  color:rgba(237,237,239,0.85) !important;
  font-size:11px !important;
  padding:18px 36px !important;
  letter-spacing:0.25em !important;
}
.btn-ghost:hover { border-color:var(--orange) !important; color:var(--orange) !important; background:transparent !important }
/* Pas de flammes additionnelles - trop fête foraine */
.hero-cta .btn-primary::after,
.contact-form .btn-primary::after,
.lab-cta .btn-primary::after { display:none !important }

/* Curseur liquid : couper sur desktop large pour rester pro */
@media (max-width:1200px) {
  html.lc-on, html.lc-on * { cursor:auto !important }
  .lc-cursor, .lc-dot, .lc-trail { display:none !important }
}

/* Cards : enlever scan lines + ring agressifs, garder juste tilt + glow subtil */
.holo-scan { display:none !important }
.holo-ring { opacity:0 !important }
.card:hover .holo-ring { opacity:0.5 !important }
.holo-glow { filter:blur(40px) !important }
.card .card-img::before { display:none !important }

/* Force fonts globalement */
* { font-family:'Montserrat',-apple-system,BlinkMacSystemFont,sans-serif }
h1, h2, h3, h4, .hero-title, .section-title, .brand-name, .brand-sub, .card-name, .pack-card h3, .how-step h3, .hero-stats strong, .lab-info strong, .card-price strong { font-family:'Rajdhani',sans-serif !important }

/* ============================================
   ARTF V5 — Stats odometer / Scroll pin / Bento
   ============================================ */

/* ============ STATS ODOMETER ============ */
.stats-odo {
  display:grid !important;
  grid-template-columns:repeat(4, 1fr) !important;
  gap:0 !important;
  border-top:1px solid rgba(255,255,255,0.1);
  border-bottom:1px solid rgba(255,255,255,0.1);
  margin:60px -10px 0 !important;
  text-align:left;
}
.stats-odo .stat {
  padding:30px 24px !important;
  border-right:1px solid rgba(255,255,255,0.08) !important;
  position:relative;
  overflow:hidden;
  flex-direction:column !important;
  align-items:flex-start !important;
}
.stats-odo .stat:last-child { border-right:none !important }
.stats-odo .stat::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:var(--orange); transform:scaleY(0); transform-origin:top;
  transition:transform 0.6s cubic-bezier(0.22,1,0.36,1);
}
.stats-odo .stat.in-view::before { transform:scaleY(1) }
.stats-odo .stat-label {
  font-family:'Montserrat', sans-serif;
  font-size:10px !important; letter-spacing:0.35em !important;
  color:rgba(255,255,255,0.5);
  text-transform:uppercase; font-weight:600; margin:0 0 16px !important;
}
.stats-odo .stat-num {
  font-family:'Rajdhani', sans-serif !important;
  font-weight:600 !important;
  font-size:54px !important;
  line-height:1 !important;
  letter-spacing:-0.02em !important;
  color:#fff !important;
  display:inline-flex !important;
  align-items:baseline;
}
.stats-odo .stat-suffix {
  font-family:'Rajdhani', sans-serif;
  font-size:24px; font-weight:500;
  color:rgba(255,255,255,0.4);
  margin-left:6px;
}
.stats-odo .stat-bar {
  margin-top:20px; height:2px;
  background:rgba(255,255,255,0.08);
  overflow:hidden; width:100%;
}
.stats-odo .stat-bar-fill {
  height:100%; width:0;
  background:var(--orange);
  transition:width 1.6s cubic-bezier(0.22,1,0.36,1) 0.3s;
}
.stats-odo .stat.in-view .stat-bar-fill { width:var(--w, 80%) }
@media (max-width:768px) {
  .stats-odo { grid-template-columns:repeat(2, 1fr) !important }
  .stats-odo .stat-num { font-size:40px !important }
}

/* ============ HOW IT WORKS — SCROLL HORIZONTAL PIN ============ */
.how-pin-wrap {
  height:300vh;
  position:relative;
  padding:0 !important;
  background:var(--bg);
}
.how-pin-stage {
  position:sticky; top:0; height:100vh;
  overflow:hidden; display:flex; flex-direction:column; justify-content:center;
}
.how-header { text-align:center; padding:0 40px; margin-bottom:50px }
.how-header h2 { margin-bottom:14px }
.how-header h2 em { color:var(--orange); font-style:normal; font-weight:700 }
.how-track {
  display:flex; gap:40px;
  padding:0 calc(50vw - 240px);
  will-change:transform;
  transition:transform 0.05s linear;
}
.how-step-new {
  flex:0 0 480px; min-height:380px;
  background:#111114;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  padding:48px 40px;
  position:relative;
  transition:transform 0.6s cubic-bezier(0.22,1,0.36,1), border-color 0.4s;
}
.how-step-new.active {
  border-color:var(--orange);
  transform:scale(1.02);
}
.how-num-bg {
  font-family:'Rajdhani',sans-serif;
  font-size:96px; font-weight:600; line-height:1;
  color:rgba(255,255,255,0.06);
  position:absolute; top:30px; right:30px;
  transition:color 0.4s;
}
.how-step-new.active .how-num-bg { color:rgba(255,90,0,0.2) }
.how-tag {
  display:inline-block; padding:4px 10px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:4px;
  font-size:10px; letter-spacing:0.25em; color:rgba(255,255,255,0.6);
  text-transform:uppercase; font-weight:600; margin-bottom:24px;
  transition:all 0.4s;
}
.how-step-new.active .how-tag { background:rgba(255,90,0,0.12); border-color:var(--orange); color:var(--orange) }
.how-step-new h3 {
  font-family:'Rajdhani',sans-serif; font-weight:600;
  font-size:30px; line-height:1.1; margin-bottom:18px;
}
.how-step-new p { color:rgba(255,255,255,0.6); line-height:1.65; font-size:14px }
.how-list { margin-top:24px; list-style:none; padding:0 }
.how-list li {
  padding:10px 0; border-top:1px solid rgba(255,255,255,0.06);
  font-size:12px; color:rgba(255,255,255,0.55);
  display:flex; justify-content:space-between;
}
.how-list li span:last-child { color:#fff; font-weight:500 }
.how-dots {
  position:absolute; bottom:50px; left:50%; transform:translateX(-50%);
  display:flex; gap:10px; z-index:5;
}
.how-dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,0.2);
  transition:all 0.3s;
}
.how-dot.active { background:var(--orange); width:32px; border-radius:4px }

/* Mobile : fallback stack vertical, pas de pin */
@media (max-width:768px) {
  .how-pin-wrap { height:auto !important; padding:60px 20px !important }
  .how-pin-stage { position:static !important; height:auto !important }
  .how-track {
    flex-direction:column; padding:0 !important;
    transform:none !important; gap:20px;
  }
  .how-step-new { flex:1 1 auto; min-height:auto }
  .how-dots { display:none }
}

/* ============ BENTO RÉALISATIONS ============ */
.bento-section { padding:100px 0; background:var(--bg) }
.bento-section .section-title em { color:var(--orange); font-style:normal; font-weight:700 }
.bento-grid {
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  grid-auto-rows:160px;
  gap:14px;
  margin-top:50px;
}
.bento-grid .b {
  background:#121215;
  border:1px solid rgba(255,255,255,0.06);
  border-radius:14px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  transition:border-color 0.4s, transform 0.5s cubic-bezier(0.22,1,0.36,1);
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:24px;
}
.bento-grid .b:hover {
  border-color:rgba(255,90,0,0.3);
  transform:translateY(-3px);
}
.bento-grid .b::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.85) 100%);
  z-index:1; pointer-events:none;
}
.bento-grid .b > * { position:relative; z-index:2 }
.b-cat {
  font-size:10px; letter-spacing:0.3em; color:var(--orange);
  text-transform:uppercase; font-weight:600; margin-bottom:8px;
  font-family:'Montserrat',sans-serif;
}
.bento-grid .b h3 {
  font-family:'Rajdhani',sans-serif; font-weight:600; font-size:20px;
  line-height:1.15; color:#fff;
}
.bento-grid .b p { font-size:12px; color:rgba(255,255,255,0.6); margin-top:6px }
.b-meta { display:flex; gap:14px; margin-top:14px; font-size:10px; color:rgba(255,255,255,0.45); letter-spacing:0.1em; flex-wrap:wrap }
.b-meta strong { color:#fff; font-weight:600 }
.bento-grid .b.x2 { grid-column:span 2 }
.bento-grid .b.x3 { grid-column:span 3 }
.bento-grid .b.x4 { grid-column:span 4 }
.bento-grid .b.y2 { grid-row:span 2 }
.bento-grid .b.y3 { grid-row:span 3 }
/* Bento — photos réelles événements (avec fallback dégradés) */
.bento-grid .b {
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  isolation: isolate;
}
.bento-grid .b::before {
  background:linear-gradient(180deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,0.4) 55%, rgba(0,0,0,0.92) 100%) !important;
}
.bento-grid .b { transition: border-color 0.4s, transform 0.5s cubic-bezier(0.22,1,0.36,1), background-position 1.2s ease-out; }
.bento-grid .b:hover { background-position: center 40% !important; }
.v1 { background-image: image-set(url('../images/site/real-gala-chateau.webp') type('image/webp'), url('../images/site/real-gala-chateau.jpg') type('image/jpeg')), radial-gradient(circle at 30% 30%, #2a1d12, #0a0a0a 70%) }
.v2 { background-image: image-set(url('../images/site/real-auditorium.webp') type('image/webp'), url('../images/site/real-auditorium.jpg') type('image/jpeg')), radial-gradient(circle at 70% 20%, #1a2a32, #0a0a0a 70%) }
.v3 { background-image: image-set(url('../images/site/real-bibliotheque.webp') type('image/webp'), url('../images/site/real-bibliotheque.jpg') type('image/jpeg')), radial-gradient(circle at 50% 70%, #3a1a1a, #0a0a0a 70%) }
.v4 { background-image: image-set(url('../images/site/real-festival-strasbourg.webp') type('image/webp'), url('../images/site/real-festival-strasbourg.jpg') type('image/jpeg')), radial-gradient(circle at 20% 60%, #2a2a1a, #0a0a0a 70%) }
.v5 { background-image: image-set(url('../images/site/real-mariage-cathedrale.webp') type('image/webp'), url('../images/site/real-mariage-cathedrale.jpg') type('image/jpeg')), radial-gradient(circle at 80% 80%, #1a1a2a, #0a0a0a 70%) }
.v6 { background-image: image-set(url('../images/site/detail-faders.webp') type('image/webp'), url('../images/site/detail-faders.jpg') type('image/jpeg')), radial-gradient(circle at 50% 50%, #2a1a2a, #0a0a0a 70%) }
.v7 { background-image: image-set(url('../images/site/real-cocktail-opera.webp') type('image/webp'), url('../images/site/real-cocktail-opera.jpg') type('image/jpeg')), radial-gradient(circle at 30% 80%, #1a2a1a, #0a0a0a 70%) }
.b-icon {
  position:absolute; top:20px; right:20px; z-index:2;
  width:32px; height:32px; border-radius:50%;
  background:rgba(255,255,255,0.06);
  display:flex; align-items:center; justify-content:center;
  color:var(--orange); font-size:16px;
  transition:transform 0.5s cubic-bezier(0.22,1,0.36,1), background 0.3s, color 0.3s;
}
.bento-grid .b:hover .b-icon { transform:rotate(45deg) scale(1.1); background:var(--orange); color:#fff }
.b-feat::after {
  content:'SÉLECTION';
  position:absolute; top:16px; left:16px; z-index:3;
  padding:4px 10px; background:rgba(255,90,0,0.15); border:1px solid var(--orange);
  color:var(--orange); border-radius:3px;
  font-size:9px; letter-spacing:0.25em; font-weight:700;
  font-family:'Montserrat',sans-serif;
}
@media (max-width:900px) {
  .bento-grid { grid-template-columns:repeat(2, 1fr) }
  .bento-grid .b.x2, .bento-grid .b.x3, .bento-grid .b.x4 { grid-column:span 2 }
  .bento-grid .b.y3 { grid-row:span 2 }
}

/* ============================================
   ARTF V6 — Hover-reveal + Équipe + Footer cinétique
   ============================================ */

/* ============ CARD HOVER-REVEAL PANEL ============ */
.card { position:relative; overflow:hidden !important }
.card-reveal {
  position:absolute; left:0; right:0; bottom:-100%;
  background:var(--orange);
  color:#0a0a0a;
  padding:18px 22px;
  transition:bottom 0.5s cubic-bezier(0.22,1,0.36,1);
  z-index:5;
}
.card:hover .card-reveal { bottom:0 }
.card-reveal h4 {
  font-family:'Rajdhani', sans-serif !important;
  font-weight:700 !important;
  font-size:11px !important; letter-spacing:0.25em !important;
  text-transform:uppercase; margin-bottom:10px !important;
  color:#0a0a0a !important;
}
.card-specs {
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:1fr 1fr; gap:4px 14px;
  font-size:10px; letter-spacing:0.04em;
}
.card-specs li {
  display:flex; justify-content:space-between;
  border-bottom:1px solid rgba(0,0,0,0.15);
  padding:4px 0;
}
.card-specs li span:first-child { font-weight:500; opacity:0.65 }
.card-specs li span:last-child { font-weight:700 }
.card-reveal-cta {
  margin-top:12px; padding:9px;
  background:#0a0a0a; color:#fff;
  text-align:center; border-radius:3px;
  font-family:'Montserrat',sans-serif;
  font-size:10px; letter-spacing:0.2em; font-weight:700;
  text-transform:uppercase;
}
/* Désactiver l'ancien CTA + holo scan */
.card .card-cta { display:none !important }
.holo-scan, .holo-ring { display:none !important }

/* ============ SECTION ÉQUIPE & GARAGE ============ */
.team-section { padding:100px 0; background:var(--bg) }
.team-section .section-title em { color:var(--orange); font-style:normal; font-weight:700 }
.garage {
  position:relative; height:380px;
  background-color: #0a0a0a;
  background-image:
    linear-gradient(180deg, rgba(0,0,0,0.15) 30%, rgba(0,0,0,0.78)),
    image-set(url('../images/site/garage-cases.webp') type('image/webp'), url('../images/site/garage-cases.jpg') type('image/jpeg'));
  background-size: cover, cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius:14px; overflow:hidden;
  margin:50px 0 50px;
  border:1px solid rgba(255,255,255,0.06);
}
.garage::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,90,0,0.10) 0%, transparent 35%),
    radial-gradient(circle at 70% 60%, rgba(255,90,0,0.06) 0%, transparent 40%);
  pointer-events:none;
}
.garage-text {
  position:absolute; left:40px; bottom:40px; right:40px; z-index:2;
}
.garage-text h3 {
  font-family:'Rajdhani',sans-serif !important; font-weight:600;
  font-size:30px; line-height:1.1; max-width:480px; margin-bottom:12px; color:#fff;
}
.garage-text p { font-size:14px; color:rgba(255,255,255,0.6); max-width:440px; line-height:1.6 }
.garage-meta {
  position:absolute; right:40px; top:40px; z-index:2;
  text-align:right;
}
.garage-label {
  font-size:10px; letter-spacing:0.3em; color:rgba(255,255,255,0.5);
  text-transform:uppercase; font-weight:600; margin-bottom:6px;
}
.garage-val {
  font-family:'Rajdhani',sans-serif !important; font-weight:600;
  font-size:32px; color:#fff;
}
.team-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:20px;
}
.person {
  background:#121215;
  border:1px solid rgba(255,255,255,0.06);
  border-radius:12px;
  overflow:hidden;
  cursor:pointer;
  transition:border-color 0.4s, transform 0.5s cubic-bezier(0.22,1,0.36,1);
}
.person:hover {
  border-color:rgba(255,90,0,0.3);
  transform:translateY(-4px);
}
.person-img {
  aspect-ratio:4/5;
  background:linear-gradient(135deg, #2a1d0d, #0a0a0a);
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.person-img-photo { background:#0a0a0a; }
.person-img-photo img, .person-img-photo picture {
  width:100%; height:100%; object-fit:cover; object-position:center 22%;
  display:block;
  transition:transform 0.7s cubic-bezier(0.22,1,0.36,1), filter 0.5s ease;
  filter:saturate(0.95) contrast(1.04);
}
.person:hover .person-img-photo img { transform:scale(1.06); filter:saturate(1.05) contrast(1.08) brightness(1.05); }
.person-avatar {
  width:110px; height:110px; border-radius:50%;
  background:linear-gradient(135deg, var(--orange), #cc4400);
  display:flex; align-items:center; justify-content:center;
  font-family:'Rajdhani',sans-serif; font-weight:700;
  color:#fff; font-size:40px;
  transition:transform 0.5s cubic-bezier(0.22,1,0.36,1);
}
.person:hover .person-avatar { transform:scale(1.08) }
.person-badge {
  position:absolute; top:12px; right:12px;
  padding:4px 10px; background:rgba(255,90,0,0.15);
  border:1px solid var(--orange); color:var(--orange);
  border-radius:3px; font-size:9px; letter-spacing:0.25em; font-weight:700;
  text-transform:uppercase; font-family:'Montserrat',sans-serif;
}
.person-body { padding:18px 20px }
.person-name {
  font-family:'Rajdhani',sans-serif !important; font-weight:600 !important;
  font-size:20px !important; line-height:1.2; margin-bottom:4px;
}
.person-role {
  font-size:10px; letter-spacing:0.25em; color:var(--orange);
  text-transform:uppercase; font-weight:600; margin-bottom:12px;
}
.person-bio {
  font-size:12px; color:rgba(255,255,255,0.55); line-height:1.55;
  max-height:0; overflow:hidden;
  transition:max-height 0.5s cubic-bezier(0.22,1,0.36,1);
}
.person:hover .person-bio { max-height:200px }
.person-skills {
  display:flex; flex-wrap:wrap; gap:6px; margin-top:14px;
}
.skill {
  padding:3px 8px; background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:3px; font-size:9px; letter-spacing:0.15em;
  color:rgba(255,255,255,0.6); text-transform:uppercase; font-weight:600;
  font-family:'Montserrat',sans-serif;
}

/* ============ FOOTER CINÉTIQUE ============ */
.site-footer { display:none !important } /* hide ancien */
.footer-cinetic {
  background:var(--bg);
  padding:80px 40px 0;
  position:relative;
  overflow:hidden;
}
.footer-grid {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:60px; padding-bottom:60px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.f-brand .f-picto { display:inline-block; margin-bottom:18px; opacity:0.95 }
.f-tagline {
  font-family:'Rajdhani',sans-serif !important;
  font-size:22px; font-weight:500;
  color:#fff; line-height:1.3; max-width:360px;
}
.f-tagline em { font-style:normal; color:var(--orange); font-weight:700 }
.f-desc { font-size:14px; color:rgba(255,255,255,0.6); line-height:1.6; max-width:320px; margin-top:14px }
.f-col h4 {
  font-family:'Montserrat',sans-serif !important; font-size:10px;
  letter-spacing:0.3em; text-transform:uppercase; color:var(--orange);
  font-weight:600 !important; margin-bottom:20px;
}
.f-col a {
  display:block; color:rgba(255,255,255,0.65);
  text-decoration:none; padding:7px 0;
  font-size:13px;
  transition:color 0.3s, padding 0.3s;
}
.f-col a:hover { color:var(--orange); padding-left:6px }
.services-strip {
  max-width:1200px; margin:0 auto;
  display:flex; justify-content:space-between; align-items:center;
  padding:36px 0;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.service-pill {
  font-family:'Rajdhani',sans-serif; font-weight:600;
  font-size:13px; letter-spacing:0.3em;
  color:rgba(255,255,255,0.5); text-transform:uppercase;
  position:relative;
  transition:color 0.3s;
}
.service-pill:hover { color:var(--orange) }
.service-pill + .service-pill::before {
  content:'';
  position:absolute; left:-30px; top:50%; transform:translateY(-50%);
  width:4px; height:4px; border-radius:50%;
  background:rgba(255,255,255,0.2);
}
.artf-giant {
  font-family:'Rajdhani',sans-serif !important;
  font-weight:700 !important;
  font-size:clamp(140px, 24vw, 380px) !important;
  text-align:center;
  line-height:0.85;
  color:transparent !important;
  -webkit-text-stroke:1px rgba(255,255,255,0.08);
  letter-spacing:-0.04em !important;
  margin:60px 0 -10px;
  position:relative;
  transform:translateY(40px);
  opacity:0;
  transition:transform 1.2s cubic-bezier(0.22,1,0.36,1), opacity 1.2s;
}
.footer-cinetic.in-view .artf-giant {
  transform:translateY(0); opacity:1;
}
.artf-giant::after {
  content:'ARTF';
  position:absolute; inset:0;
  background:linear-gradient(180deg, var(--orange) 0%, transparent 100%);
  -webkit-background-clip:text; background-clip:text;
  color:transparent !important;
  -webkit-text-fill-color:transparent;
  opacity:0;
  transition:opacity 1s 0.3s;
}
.footer-cinetic.in-view .artf-giant::after { opacity:0.35 }
.footer-bottom-new {
  max-width:1200px; margin:0 auto; padding:30px 0;
  display:flex; justify-content:space-between; align-items:center;
  font-size:11px; color:rgba(255,255,255,0.4);
  letter-spacing:0.1em;
}
.social { display:flex; gap:14px }
.social a {
  width:32px; height:32px; border-radius:50%;
  border:1px solid rgba(255,255,255,0.15);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,0.6);
  text-decoration:none; transition:all 0.3s;
  font-size:11px; font-weight:600;
}
.social a:hover { border-color:var(--orange); color:var(--orange) }
@media (max-width:900px) {
  .footer-grid { grid-template-columns:1fr 1fr; gap:40px }
  .services-strip { flex-wrap:wrap; gap:20px 40px; justify-content:flex-start }
  .service-pill + .service-pill::before { display:none }
  .footer-bottom-new { flex-direction:column; gap:20px }
}

/* ============================================
   ARTF V7 — Configurateur / Calendrier / FAQ / Panier
   ============================================ */

/* ============ CONFIGURATEUR DEVIS ============ */
.config-section { padding:100px 0; background:#0c0c0e }
.config-section .section-title em { color:var(--orange); font-style:normal; font-weight:700 }
.config-wrap {
  display:grid; grid-template-columns:1.4fr 1fr;
  gap:50px; align-items:start; margin-top:60px;
}
.config-step {
  margin-bottom:32px; padding-bottom:32px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.config-step:last-child { border-bottom:none }
.step-num {
  display:inline-block;
  font-family:'Rajdhani',sans-serif; font-weight:700;
  font-size:11px; letter-spacing:0.3em; color:var(--orange);
  text-transform:uppercase; margin-bottom:14px;
}
.step-num::before { content:'◆ '; margin-right:6px }
.step-label {
  display:block; font-family:'Rajdhani',sans-serif; font-weight:600;
  font-size:22px; color:#fff; margin-bottom:8px;
}
.step-current { color:var(--orange); font-weight:700 }
.type-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:8px; margin-top:16px }
.type-card {
  padding:12px 10px;
  background:transparent;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:6px;
  color:rgba(255,255,255,0.7);
  cursor:pointer;
  font-family:'Montserrat',sans-serif;
  font-size:10px; letter-spacing:0.18em; font-weight:600;
  text-transform:uppercase;
  transition:all 0.3s;
}
.type-card:hover { color:#fff; border-color:rgba(255,255,255,0.3) }
.type-card.active { background:rgba(255,90,0,0.12); border-color:var(--orange); color:var(--orange) }
.slider-wrap { margin-top:14px }
.config-section input[type=range] {
  -webkit-appearance:none; appearance:none;
  width:100%; height:4px;
  background:rgba(255,255,255,0.1);
  outline:none; border-radius:2px;
  margin:14px 0;
}
.config-section input[type=range]::-webkit-slider-thumb {
  -webkit-appearance:none; appearance:none;
  width:22px; height:22px; border-radius:50%;
  background:var(--orange); cursor:pointer;
  border:3px solid #0c0c0e;
  box-shadow:0 0 0 1px var(--orange), 0 0 12px rgba(255,90,0,0.4);
}
.config-section input[type=range]::-moz-range-thumb {
  width:18px; height:18px; border-radius:50%;
  background:var(--orange); cursor:pointer; border:3px solid #0c0c0e;
}
.slider-marks {
  display:flex; justify-content:space-between;
  font-size:10px; letter-spacing:0.2em; color:rgba(255,255,255,0.4);
  text-transform:uppercase; font-weight:600; margin-top:4px;
}
.options-row { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px }
.opt-toggle {
  padding:9px 13px;
  background:transparent;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:6px;
  color:rgba(255,255,255,0.6);
  cursor:pointer;
  font-family:'Montserrat',sans-serif;
  font-size:10px; letter-spacing:0.15em; font-weight:600;
  text-transform:uppercase;
  transition:all 0.3s;
  display:inline-flex; align-items:center; gap:6px;
}
.opt-toggle::before { content:'+'; font-size:13px; color:rgba(255,255,255,0.4); transition:color 0.3s }
.opt-toggle:hover { border-color:rgba(255,255,255,0.3); color:#fff }
.opt-toggle.active { background:rgba(255,90,0,0.12); border-color:var(--orange); color:var(--orange) }
.opt-toggle.active::before { content:'✓'; color:var(--orange) }
.estimate-panel {
  position:sticky; top:80px;
  background:#16161a;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  padding:28px;
}
.estimate-label {
  font-family:'Montserrat',sans-serif;
  font-size:10px; letter-spacing:0.4em; color:rgba(255,255,255,0.5);
  text-transform:uppercase; font-weight:600;
}
.estimate-total {
  font-family:'Rajdhani',sans-serif !important; font-weight:700 !important;
  font-size:60px !important; line-height:1 !important; color:#fff;
  margin:12px 0 4px; letter-spacing:-0.02em;
  transition:transform 0.2s;
}
.estimate-total.bump { transform:scale(1.05) }
.estimate-total .currency { color:var(--orange) }
.estimate-range { font-size:11px; color:rgba(255,255,255,0.5); margin-bottom:26px }
.estimate-bk { list-style:none; padding:0; margin:0 0 24px }
.estimate-bk li {
  display:flex; justify-content:space-between;
  padding:9px 0; border-top:1px solid rgba(255,255,255,0.06);
  font-size:12px;
}
.estimate-bk li:first-child { border-top:none }
.estimate-bk li span:first-child { color:rgba(255,255,255,0.5) }
.estimate-bk li span:last-child { color:#fff; font-weight:600 }
.estimate-bk li.total { padding-top:12px; border-top:1px solid rgba(255,90,0,0.4); margin-top:8px }
.estimate-bk li.total span:first-child { color:var(--orange); font-weight:700; letter-spacing:0.15em; text-transform:uppercase; font-size:10px }
.estimate-bk li.total span:last-child { font-family:'Rajdhani',sans-serif; font-size:20px; font-weight:700 }
.estimate-bk li.min-floor span:first-child { color:rgba(255,90,0,0.7); font-style:italic; font-size:11px }
.estimate-bk li.min-floor span:last-child { color:var(--orange) }
.cfg-cta { width:100% !important; padding:14px !important; margin-bottom:8px !important }
.estimate-note { text-align:center; margin-top:8px; font-size:10px; color:rgba(255,255,255,0.4); letter-spacing:0.05em }
.config-hint { margin-top:10px; font-size:11px; color:rgba(255,255,255,0.5); font-style:italic; letter-spacing:0.02em }
.config-hint strong { color:var(--orange); font-weight:600; font-style:normal }
/* Type grid passe à 5 colonnes max → wrap propre */
.type-grid { grid-template-columns:repeat(5, 1fr) !important }
@media (max-width:1100px) { .type-grid { grid-template-columns:repeat(3, 1fr) !important } }
@media (max-width:900px) {
  .config-wrap { grid-template-columns:1fr; gap:30px }
  .type-grid { grid-template-columns:repeat(2, 1fr) !important }
}

/* ============ CALENDRIER DISPOS ============ */
.cal-section { padding:100px 0; background:var(--bg) }
.cal-section .section-title em { color:var(--orange); font-style:normal; font-weight:700 }
.cal-wrap {
  background:#16161a;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  padding:32px;
  margin-top:50px;
}
.cal-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:24px;
}
.cal-title {
  font-family:'Rajdhani',sans-serif !important; font-weight:600 !important;
  font-size:22px !important; letter-spacing:-0.005em;
  color:#fff;
}
.cal-nav button {
  width:36px; height:36px; border-radius:6px;
  background:transparent;
  border:1px solid rgba(255,255,255,0.12);
  color:#fff; cursor:pointer; font-size:14px;
  transition:all 0.3s;
}
.cal-nav button:hover { border-color:var(--orange); color:var(--orange) }
.cal-legend {
  display:flex; gap:24px; flex-wrap:wrap; margin-bottom:20px;
  font-size:10px; color:rgba(255,255,255,0.6); letter-spacing:0.15em;
  text-transform:uppercase; font-weight:600;
}
.legend-dot { display:inline-block; width:10px; height:10px; border-radius:50%; vertical-align:middle; margin-right:6px }
.legend-dot.avail { background:var(--orange) }
.legend-dot.busy { background:rgba(255,255,255,0.15) }
.legend-dot.selected { background:#fff }
.cal-grid { display:grid; grid-template-columns:repeat(7, 1fr); gap:5px }
.day-name {
  text-align:center; padding:8px 0;
  font-size:10px; letter-spacing:0.25em; color:rgba(255,255,255,0.4);
  text-transform:uppercase; font-weight:600;
}
.day {
  aspect-ratio:1; border-radius:6px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  cursor:pointer; position:relative;
  font-family:'Rajdhani',sans-serif; font-weight:600;
  font-size:16px;
  transition:all 0.3s;
}
.day.empty { cursor:default; opacity:0; pointer-events:none }
.day.avail {
  background:rgba(255,90,0,0.08);
  border:1px solid rgba(255,90,0,0.25);
  color:#fff;
}
.day.avail::after {
  content:''; position:absolute; bottom:5px;
  width:3px; height:3px; border-radius:50%; background:var(--orange);
}
.day.avail:hover { background:rgba(255,90,0,0.18); border-color:var(--orange); transform:translateY(-2px) }
.day.busy {
  background:rgba(255,255,255,0.03);
  color:rgba(255,255,255,0.3);
  border:1px solid rgba(255,255,255,0.06);
  text-decoration:line-through;
  cursor:not-allowed;
}
.day.selected {
  background:var(--orange); border:1px solid var(--orange); color:#fff;
  transform:scale(1.05);
  box-shadow:0 4px 16px rgba(255,90,0,0.4);
}
.day.selected::after { background:#fff }
.day-mini { font-size:8px; letter-spacing:0.15em; color:rgba(255,255,255,0.4); margin-top:1px; text-transform:uppercase; font-weight:600 }
.day.avail .day-mini { color:rgba(255,90,0,0.8) }
.cal-selected {
  margin-top:24px; padding:20px;
  background:rgba(255,90,0,0.06);
  border:1px solid rgba(255,90,0,0.25);
  border-radius:10px;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
}
.cal-selected.empty { background:rgba(255,255,255,0.03); border-color:rgba(255,255,255,0.08) }
.cal-selected-text { font-size:13px; color:rgba(255,255,255,0.7) }
.cal-selected-text strong { color:#fff; font-family:'Rajdhani',sans-serif; font-weight:600; font-size:16px; display:block }
.cal-selected-text span { font-size:12px }
.cal-selected .btn { padding:12px 22px !important; font-size:10px !important }
.cal-selected .btn:disabled { background:rgba(255,255,255,0.08) !important; color:rgba(255,255,255,0.3) !important; cursor:not-allowed; box-shadow:none !important; transform:none !important }

/* ============ FAQ RECHERCHE + TAGS ============ */
.faq-search {
  display:flex; align-items:center; gap:14px;
  background:#16161a;
  border:1px solid rgba(255,255,255,0.1);
  border-radius:10px;
  padding:16px 20px;
  margin:30px 0 18px;
  transition:border-color 0.3s;
}
.faq-search:focus-within { border-color:var(--orange) }
.faq-search svg { width:18px; height:18px; color:rgba(255,255,255,0.4); flex-shrink:0 }
.faq-search input {
  flex:1; background:transparent; border:none; outline:none;
  color:#fff; font-family:'Montserrat',sans-serif; font-size:13px;
}
.faq-search input::placeholder { color:rgba(255,255,255,0.4) }
.faq-count { font-size:10px; letter-spacing:0.2em; color:rgba(255,255,255,0.4); text-transform:uppercase; font-weight:600 }
.faq-tags { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:28px }
.faq-tag {
  padding:8px 14px;
  background:transparent;
  border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.6);
  border-radius:6px;
  font-family:'Montserrat',sans-serif;
  font-size:10px; letter-spacing:0.2em; font-weight:600;
  text-transform:uppercase; cursor:pointer;
  transition:all 0.3s;
}
.faq-tag:hover { color:#fff; border-color:rgba(255,255,255,0.3) }
.faq-tag.active { background:rgba(255,90,0,0.12); border-color:var(--orange); color:var(--orange) }
.faq-tag .count { opacity:0.6; margin-left:4px }
.faq-list { display:flex; flex-direction:column; gap:8px }
.faq-list .faq-item {
  background:#16161a;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:10px;
  overflow:hidden;
  transition:border-color 0.3s;
}
.faq-list .faq-item[open] { border-color:rgba(255,90,0,0.4) }
.faq-list .faq-item summary {
  padding:16px 22px;
  cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
  gap:14px; list-style:none;
  font-family:'Rajdhani',sans-serif !important; font-weight:600 !important;
  font-size:16px !important; color:#fff;
}
.faq-list .faq-item summary::-webkit-details-marker { display:none }
.faq-list .faq-item summary::after {
  content:'+'; font-size:22px; font-weight:300; color:rgba(255,255,255,0.5);
  transition:transform 0.3s, color 0.3s;
}
.faq-list .faq-item[open] summary::after { transform:rotate(45deg); color:var(--orange) }
.faq-meta { display:flex; gap:8px; align-items:center; margin-left:auto; margin-right:14px }
.faq-tag-mini {
  padding:3px 8px; background:rgba(255,90,0,0.1);
  color:var(--orange); border-radius:3px;
  font-size:9px; letter-spacing:0.2em; font-weight:700;
  text-transform:uppercase; font-family:'Montserrat',sans-serif;
}
.faq-list .faq-answer {
  padding:0 22px 18px;
  color:rgba(255,255,255,0.65);
  line-height:1.65; font-size:13px;
}
.faq-list .faq-answer mark {
  background:rgba(255,90,0,0.2); color:#fff; padding:1px 4px; border-radius:2px;
}
.faq-empty {
  text-align:center; padding:40px 20px;
  color:rgba(255,255,255,0.4); font-size:12px; letter-spacing:0.1em;
}

/* ============ CARD ACTIONS (panier + direct) ============ */
.card-actions {
  display:flex; gap:8px; margin-top:10px;
}
.card-add, .card-direct {
  flex:1;
  padding:9px 12px;
  font-family:'Montserrat',sans-serif;
  font-size:10px; letter-spacing:0.18em; font-weight:700;
  text-transform:uppercase;
  border-radius:4px;
  cursor:pointer;
  text-align:center;
  text-decoration:none;
  transition:all 0.3s;
}
.card-add { background:#0a0a0a; color:#fff; border:1px solid #0a0a0a }
.card-add:hover { background:#1a1a1e }
.card-direct {
  background:transparent; color:#0a0a0a;
  border:1px solid #0a0a0a; flex:0 0 70px;
}
.card-direct:hover { background:#0a0a0a; color:#fff }
/* Hide old reveal-cta */
.card-reveal-cta { display:none !important }

/* ============ PANIER FLOTTANT + DRAWER ============ */
.cart-btn {
  position:fixed; bottom:30px; right:30px; z-index:60;
  background:var(--orange); color:#fff;
  padding:16px 22px; border-radius:50px;
  border:none; cursor:pointer;
  box-shadow:0 10px 30px rgba(255,90,0,0.4);
  display:flex; align-items:center; gap:12px;
  font-family:'Montserrat',sans-serif;
  font-size:11px; letter-spacing:0.25em; font-weight:700;
  text-transform:uppercase;
  transition:transform 0.3s, box-shadow 0.3s;
}
.cart-btn:hover { transform:translateY(-3px); box-shadow:0 14px 40px rgba(255,90,0,0.55) }
.cart-btn-count {
  background:#0a0a0a; color:var(--orange);
  width:24px; height:24px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:'Rajdhani',sans-serif; font-size:13px; font-weight:700;
  transition:transform 0.3s;
}
.cart-btn-count.bump { transform:scale(1.3) }
.cart-btn-total {
  font-family:'Rajdhani',sans-serif;
  font-size:14px; padding-left:8px;
  border-left:1px solid rgba(255,255,255,0.3); margin-left:4px;
  font-weight:700;
}
.cart-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:99;
  opacity:0; pointer-events:none;
  transition:opacity 0.4s;
}
.cart-overlay.open { opacity:1; pointer-events:auto }
.cart-drawer {
  position:fixed; top:0; right:0; bottom:0; width:420px; max-width:90vw;
  background:#0e0e10;
  border-left:1px solid rgba(255,90,0,0.3);
  z-index:100;
  transform:translateX(100%);
  transition:transform 0.5s cubic-bezier(0.22,1,0.36,1);
  display:flex; flex-direction:column;
}
.cart-drawer.open { transform:translateX(0) }
.cart-head {
  padding:22px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  display:flex; justify-content:space-between; align-items:center;
}
.cart-title {
  font-family:'Rajdhani',sans-serif !important; font-weight:600 !important;
  font-size:20px !important;
}
.cart-title small { color:var(--orange); font-size:13px; margin-left:6px }
.cart-close {
  background:transparent; border:none; color:#fff;
  width:36px; height:36px; border-radius:50%;
  cursor:pointer; font-size:18px;
  display:flex; align-items:center; justify-content:center;
  transition:background 0.3s;
}
.cart-close:hover { background:rgba(255,255,255,0.06) }
.cart-body { flex:1; overflow-y:auto; padding:14px 22px }
.cart-empty { padding:40px 20px; text-align:center; color:rgba(255,255,255,0.4); font-size:13px }
.cart-empty span { display:block; margin-top:8px; font-size:11px; color:rgba(255,255,255,0.3) }
.cart-item {
  display:grid; grid-template-columns:50px 1fr auto;
  gap:14px; padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,0.06);
  align-items:center;
}
.cart-item-img {
  width:50px; height:50px; border-radius:6px;
  background-size:cover; background-position:center;
  background-color:#1c1c22;
}
.cart-item-info { min-width:0 }
.cart-item-name { font-family:'Rajdhani',sans-serif; font-weight:600; font-size:14px; color:#fff; line-height:1.2 }
.cart-item-meta { font-size:11px; color:rgba(255,255,255,0.4); margin-top:2px; letter-spacing:0.05em }
.cart-item-price { font-family:'Rajdhani',sans-serif; font-weight:700; font-size:14px; color:var(--orange); text-align:right; align-self:flex-start }
.cart-item-qty { display:flex; align-items:center; gap:6px; margin-top:6px }
.cart-qty-btn {
  width:22px; height:22px; border-radius:4px;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1);
  color:#fff; cursor:pointer; font-size:11px;
  display:flex; align-items:center; justify-content:center;
  transition:background 0.2s;
}
.cart-qty-btn:hover { background:rgba(255,255,255,0.1) }
.cart-qty-btn.rm { margin-left:6px; color:rgba(255,90,0,0.7) }
.cart-qty-val { font-family:'Rajdhani',sans-serif; font-weight:700; font-size:13px; min-width:18px; text-align:center }
.cart-foot {
  padding:22px; border-top:1px solid rgba(255,255,255,0.08);
  background:#0a0a0a;
}
.cart-foot-row {
  display:flex; justify-content:space-between; margin-bottom:8px;
  font-size:12px; color:rgba(255,255,255,0.6);
}
.cart-foot-row.total {
  font-family:'Rajdhani',sans-serif; font-weight:700;
  font-size:18px; color:#fff;
  border-top:1px solid rgba(255,255,255,0.08);
  padding-top:12px; margin-top:12px;
}
.cart-foot-row.total span:last-child { color:var(--orange) }
.cart-submit {
  margin-top:14px; width:100% !important; padding:14px !important;
  font-size:11px !important;
}
.cart-note { text-align:center; margin-top:8px; font-size:10px; color:rgba(255,255,255,0.4) }

/* ============================================
   ARTF V8 — Hero Cinematic Scroll
   ============================================ */

.hero-cinema {
  position:relative !important;
  height:100vh; min-height:100vh;
  overflow:hidden !important;
  padding:0 !important;
  background:#08080a !important;
  display:block !important;
}
/* Coupe les anciens effets stage lights / particles */
.hero-cinema .hero-bg, .hero-cinema .hero-overlay,
.hero-cinema .hero-glow, .hero-cinema .hero-accent-glow,
.hero-cinema .hero-stage-lights, .hero-cinema .hero-particles,
.hero-cinema::after, .hero-cinema::before { display:none !important }

/* BG photo cinema — hero spots orange (Archive 2) */
.hero-cinema .bg-photo {
  position:absolute; inset:0; z-index:1;
  background-color: #08080a;
  background-image:
    radial-gradient(ellipse 70% 80% at 25% 60%, rgba(120,80,40,0.18) 0%, transparent 50%),
    radial-gradient(ellipse 60% 70% at 80% 40%, rgba(255,90,0,0.10) 0%, transparent 55%),
    image-set(url('../images/site/hero-spots-orange.webp') type('image/webp'), url('../images/site/hero-spots-orange.jpg') type('image/jpeg'));
  background-size: cover, cover, cover;
  background-position: center, center, center;
  background-repeat: no-repeat;
  filter:saturate(0.95) contrast(1.05) brightness(0.78);
  transform:scale(1.06);
  animation:cinemaZoom 28s ease-in-out infinite alternate;
}
@keyframes cinemaZoom {
  0%   { transform:scale(1.06) translate(0, 0) }
  100% { transform:scale(1.14) translate(-12px, -8px) }
}
.hero-cinema .bg-photo::before {
  content:''; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode:overlay; opacity:0.15;
}
.hero-cinema .bg-photo::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 90% at center, transparent 40%, rgba(0,0,0,0.6) 100%);
}

/* Frame corners */
.hero-cinema .frame-tl, .hero-cinema .frame-tr,
.hero-cinema .frame-bl, .hero-cinema .frame-br {
  position:absolute; width:42px; height:42px; z-index:30;
  border:1px solid rgba(255,255,255,0.25);
  pointer-events:none;
}
.hero-cinema .frame-tl { top:90px; left:40px; border-right:none; border-bottom:none }
.hero-cinema .frame-tr { top:90px; right:40px; border-left:none; border-bottom:none }
.hero-cinema .frame-bl { bottom:140px; left:40px; border-right:none; border-top:none }
.hero-cinema .frame-br { bottom:140px; right:40px; border-left:none; border-top:none }

/* Meta top */
.hero-cinema .meta-top {
  position:absolute; left:100px; right:100px; top:96px; z-index:40;
  display:flex; justify-content:space-between; align-items:flex-start;
  font-family:'Montserrat',sans-serif;
  font-size:10px; letter-spacing:0.4em; color:rgba(255,255,255,0.55);
  text-transform:uppercase; font-weight:500;
}
.hero-cinema .meta-top-l, .hero-cinema .meta-top-r { display:flex; flex-direction:column; gap:6px }
.hero-cinema .meta-top-r { text-align:right; align-items:flex-end }
.hero-cinema .meta-top .stamp {
  font-family:'Cormorant Garamond', serif !important;
  font-style:italic; font-weight:400;
  font-size:20px !important; color:var(--orange); letter-spacing:0;
  text-transform:none;
}

/* KINETIC TRACK */
.hero-cinema .kinetic-track {
  position:absolute; left:0; top:50%; transform:translateY(-50%);
  height:60vh; z-index:5;
  display:flex; align-items:center;
  white-space:nowrap;
  will-change:transform;
  transition:transform 0.05s linear;
}
.hero-cinema .kinetic-row {
  display:flex; align-items:center;
  padding:0 6vw;
  flex-shrink:0;
}
.hero-cinema .big-word {
  font-family:'Cormorant Garamond', serif !important;
  font-weight:300 !important;
  font-size:32vw !important;
  line-height:0.85 !important; letter-spacing:-0.04em !important;
  color:#fff !important;
  margin-right:6vw;
  user-select:none;
}
.hero-cinema .big-word.italic { font-style:italic !important; color:var(--orange) !important; font-weight:400 !important }
.hero-cinema .big-word.outline {
  color:transparent !important;
  -webkit-text-stroke:1px rgba(255,255,255,0.4);
}
.hero-cinema .big-word.small { font-size:16vw !important; align-self:flex-end; padding-bottom:6vw }
.hero-cinema .big-word .sup {
  font-size:0.18em; font-style:italic;
  vertical-align:top; color:rgba(255,255,255,0.4);
  margin-right:0.3em;
}
.hero-cinema .vbar {
  width:1px; height:50vh; align-self:center;
  background:linear-gradient(180deg, transparent, rgba(255,90,0,0.4), transparent);
  margin:0 4vw;
  flex-shrink:0;
}
.hero-cinema .vbar.thin { background:linear-gradient(180deg, transparent, rgba(255,255,255,0.15), transparent) }

/* Center card */
.hero-cinema .center-card {
  position:absolute; left:50%; top:50%;
  transform:translate(-50%, -50%);
  z-index:25;
  max-width:560px; padding:36px 40px;
  text-align:center;
  background:rgba(8,8,10,0.55);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:2px;
  opacity:0;
  animation:cardIn 1.2s cubic-bezier(0.22,1,0.36,1) 0.4s forwards;
}
@keyframes cardIn { to { opacity:1 } }
.hero-cinema .center-kicker {
  font-family:'Montserrat',sans-serif !important;
  font-size:10px !important; letter-spacing:0.45em !important; color:rgba(255,255,255,0.55);
  text-transform:uppercase; font-weight:500;
  margin-bottom:24px;
  display:flex; align-items:center; justify-content:center; gap:14px;
}
.hero-cinema .center-kicker::before, .hero-cinema .center-kicker::after {
  content:''; width:24px; height:1px; background:var(--orange);
}
.hero-cinema .center-title {
  font-family:'Cormorant Garamond', serif !important;
  font-weight:400 !important; font-style:italic !important;
  font-size:42px !important; line-height:1.12 !important;
  color:#fff !important;
  margin-bottom:18px !important;
  letter-spacing:-0.005em !important;
  text-shadow:none !important;
  background:none !important;
  -webkit-text-fill-color:#fff !important;
}
.hero-cinema .center-title em {
  font-style:normal !important; color:var(--orange) !important;
  font-weight:500 !important;
  -webkit-text-fill-color:var(--orange) !important;
}
.hero-cinema .center-sub {
  font-size:13px; color:rgba(255,255,255,0.7) !important; line-height:1.7;
  margin-bottom:26px;
  font-family:'Montserrat',sans-serif !important;
}
.hero-cinema .center-cta {
  display:flex; gap:8px; justify-content:center;
}
.hero-cinema .btn-mini {
  padding:13px 24px;
  font-family:'Montserrat',sans-serif !important;
  font-size:10px; letter-spacing:0.28em; font-weight:700;
  text-transform:uppercase; text-decoration:none;
  border-radius:2px; cursor:pointer;
  transition:transform 0.2s;
}
.hero-cinema .btn-mini.fill {
  background:var(--orange); color:#fff;
  border:1px solid var(--orange);
}
.hero-cinema .btn-mini.fill:hover { transform:translateY(-2px) }
.hero-cinema .btn-mini.outline {
  background:transparent; color:#fff;
  border:1px solid rgba(255,255,255,0.25);
}
.hero-cinema .btn-mini.outline:hover { border-color:var(--orange) }

/* Scroll line indicator (au-dessus du stats) */
.hero-cinema .scroll-line {
  position:absolute; left:50%; bottom:170px; transform:translateX(-50%);
  z-index:40;
  display:flex; flex-direction:column; align-items:center; gap:14px;
}
.hero-cinema .scroll-line-text {
  font-family:'Montserrat',sans-serif;
  font-size:9px; letter-spacing:0.45em; color:rgba(255,255,255,0.5);
  text-transform:uppercase; font-weight:600;
}
.hero-cinema .scroll-line-bar {
  width:1px; height:42px; background:rgba(255,255,255,0.15);
  position:relative; overflow:hidden;
}
.hero-cinema .scroll-line-bar::after {
  content:''; position:absolute; left:0; top:0; right:0; height:35%;
  background:var(--orange);
  animation:scrollPulseV8 2.2s ease-in-out infinite;
}
@keyframes scrollPulseV8 {
  0%   { transform:translateY(-100%) }
  100% { transform:translateY(280%) }
}

/* Live clock */
.hero-cinema .live-clock {
  position:absolute; left:100px; bottom:155px; z-index:40;
  font-family:'Cormorant Garamond', serif;
  font-style:italic; font-weight:400;
  font-size:14px; color:rgba(255,255,255,0.45);
}
.hero-cinema .live-clock::before {
  content:''; display:inline-block;
  width:6px; height:6px; border-radius:50%;
  background:var(--orange); margin-right:10px; vertical-align:middle;
  box-shadow:0 0 6px var(--orange);
  animation:pulseLiveV8 1.5s ease-in-out infinite;
}
@keyframes pulseLiveV8 { 0%,100% { opacity:1 } 50% { opacity:0.3 } }

/* Stats odometer en bas du hero (par dessus tout, en bandeau full width) */
.hero-cinema .stats-odo {
  position:absolute !important;
  left:0 !important; right:0 !important; bottom:0 !important;
  margin:0 !important;
  z-index:40;
  padding:0 60px !important;
  background:rgba(8,8,10,0.7);
  backdrop-filter:blur(20px);
  border-top:1px solid rgba(255,255,255,0.06);
}
.hero-cinema .stats-odo .stat {
  padding:20px 24px !important;
}
.hero-cinema .stats-odo .stat-num {
  font-size:40px !important;
}

/* RESPONSIVE */
@media (max-width:900px) {
  .hero-cinema .meta-top, .hero-cinema .live-clock,
  .hero-cinema .frame-tl, .hero-cinema .frame-tr,
  .hero-cinema .frame-bl, .hero-cinema .frame-br { display:none }
  .hero-cinema .center-card { max-width:90vw; padding:24px }
  .hero-cinema .center-title { font-size:30px !important }
  .hero-cinema .big-word { font-size:52vw !important }
  .hero-cinema .stats-odo { padding:0 20px !important }
  .hero-cinema .stats-odo .stat { padding:14px !important }
  .hero-cinema .stats-odo .stat-num { font-size:28px !important }
  .hero-cinema .scroll-line { display:none }
}

/* ============ TRANSITIONS SECTIONS — line draw orange ============ */
section.reveal { position:relative }
section.reveal:not(.hero-cinema)::before {
  content:''; position:absolute; left:50%; top:0;
  transform:translateX(-50%) scaleX(0);
  width:80px; height:1px;
  background:var(--orange);
  transform-origin:center;
  transition:transform 0.9s cubic-bezier(0.22,1,0.36,1) 0.2s;
}
section.reveal.is-visible:not(.hero-cinema)::before {
  transform:translateX(-50%) scaleX(1);
}

/* ============================================
   ARTF PRO PASS — mobile, a11y, conversion
   ============================================ */

:root { color-scheme: dark; }

.skip-link {
  position:fixed;
  left:16px;
  top:12px;
  z-index:10000;
  transform:translateY(-140%);
  background:var(--orange);
  color:#fff;
  padding:10px 14px;
  border-radius:6px;
  font-family:'Montserrat', sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  text-decoration:none;
  transition:transform 0.2s ease;
}
.skip-link:focus { transform:translateY(0); outline:2px solid #fff; outline-offset:3px; }

.cart-btn[hidden] { display:none !important; }

.form-status {
  min-height:18px;
  margin:2px 0 0;
  color:rgba(255,255,255,0.55);
  font-size:12px;
  line-height:1.5;
}

.float-mail,
.float-phone {
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
}
.float-mail.visible,
.float-phone.visible {
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.float-mail.visible:hover,
.float-phone.visible:hover {
  transform:scale(1.08) translateY(-2px);
}

.hero-cinema {
  min-height:100dvh;
  height:100dvh;
}

@media (hover:none), (max-width:900px) {
  .card-reveal {
    position:static;
    background:rgba(255,90,0,0.12);
    color:#fff;
    padding:12px 14px 14px;
    border-top:1px solid rgba(255,90,0,0.25);
  }
  .card-reveal h4,
  .card-specs { display:none; }
  .card-actions { margin-top:0; }
  .card-add,
  .card-direct {
    min-height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    letter-spacing:0.12em;
  }
  .card-add {
    background:var(--orange);
    border-color:var(--orange);
    color:#fff;
  }
  .card-direct {
    color:#fff;
    border-color:rgba(255,255,255,0.24);
  }
}

@media (max-width:900px) {
  .header-inner {
    min-height:74px;
    padding:12px 4vw;
    gap:14px;
  }
  .brand { min-width:0; }
  .brand-mark-svg {
    width:42px !important;
    height:48px !important;
    flex:0 0 auto;
  }
  .brand-name { font-size:22px !important; }
  .brand-sub {
    max-width:190px;
    letter-spacing:0.24em !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .nav-toggle {
    margin-left:auto;
    flex:0 0 auto;
    min-width:42px;
    min-height:42px;
  }
  .nav-toggle span {
    display:block !important;
    width:20px !important;
    height:2px !important;
    margin:0 !important;
    background:#fff !important;
    opacity:1 !important;
  }

  .hero-cinema {
    min-height:100svh;
    height:100svh;
  }
  .hero-cinema .bg-photo {
    background-position:center top, center top, center top;
    filter:saturate(0.95) contrast(1.04) brightness(0.7);
  }
  .hero-cinema .kinetic-track { display:none; }
  .hero-cinema .center-card {
    width:calc(100vw - 32px);
    max-width:none;
    padding:28px 20px 24px;
    top:47%;
    background:rgba(8,8,10,0.74);
    border-color:rgba(255,255,255,0.12);
  }
  .hero-cinema .center-kicker {
    gap:9px;
    letter-spacing:0.28em !important;
    margin-bottom:18px;
  }
  .hero-cinema .center-kicker::before,
  .hero-cinema .center-kicker::after { width:18px; }
  .hero-cinema .center-title {
    font-size:34px !important;
    line-height:1.04 !important;
    margin-bottom:16px !important;
  }
  .hero-cinema .center-sub {
    max-width:28rem;
    margin:0 auto 22px;
    font-size:12px;
    line-height:1.65;
  }
  .hero-cinema .center-cta {
    flex-direction:column;
    gap:10px;
  }
  .hero-cinema .btn-mini {
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    min-height:48px;
    padding:13px 16px;
    letter-spacing:0.2em;
  }
  .hero-cinema .stats-odo {
    padding:0 !important;
    background:rgba(8,8,10,0.82);
  }
  .hero-cinema .stats-odo .stat {
    min-height:104px;
    padding:14px 16px !important;
  }
  .hero-cinema .stats-odo .stat-label {
    letter-spacing:0.24em !important;
    margin-bottom:10px !important;
  }
}

@media (max-width:540px) {
  body { padding-bottom:0; }
  .container { padding:0 20px; }
  .brand-sub { max-width:150px; font-size:8px !important; }
  .cat-nav { padding:72px 0 32px; }
  .section-title { font-size:42px !important; }
  .section-sub {
    max-width:30rem;
    margin-left:auto;
    margin-right:auto;
    line-height:1.6;
  }
  .search-wrap input {
    min-height:52px;
    padding-right:42px;
    font-size:14px;
  }
  .cat-pills {
    justify-content:flex-start;
    overflow-x:auto;
    flex-wrap:nowrap;
    width:100%;
    padding:0 20px 8px;
    margin:0 -20px;
    scrollbar-width:none;
  }
  .cat-pills::-webkit-scrollbar { display:none; }
  .pill {
    flex:0 0 auto;
    min-height:40px;
    padding:10px 14px;
    letter-spacing:0.16em !important;
  }
  .grid {
    grid-template-columns:1fr;
    gap:18px;
  }
  .card-body { padding:18px 18px 20px; }
  .card-name {
    font-size:22px !important;
    line-height:1.16;
  }
  .sticky-cta-bar { display:none; }
  .float-mail,
  .float-phone,
  .scroll-top { display:none !important; }
  .scroll-top {
    display:grid !important;
    right:18px;
    bottom:88px;
    width:44px;
    height:44px;
    z-index:101;
  }
  .cart-btn {
    left:16px;
    right:16px;
    bottom:16px;
    justify-content:center;
    width:auto;
    min-height:54px;
    padding:14px 18px;
  }
}

/* ============================================
   ARTF V9.3 — Catalogue packshot premium
   ============================================ */
.catalogue-section {
  background:
    linear-gradient(180deg, rgba(255,90,0,0.045) 0%, rgba(255,90,0,0) 420px),
    linear-gradient(180deg, #0e0f11 0%, var(--bg) 100%) !important;
}

.grid {
  grid-template-columns: repeat(auto-fill, minmax(285px, 1fr));
  gap: clamp(18px, 2.1vw, 30px);
  align-items: start;
}

.card {
  border-radius: 8px !important;
  background:
    linear-gradient(180deg, rgba(28,30,33,0.98) 0%, rgba(15,16,18,0.98) 100%) !important;
  border-color: rgba(245,245,240,0.105) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,0.26), inset 0 1px 0 rgba(255,255,255,0.045) !important;
  transform-style: preserve-3d;
  transition: transform 0.36s cubic-bezier(0.22,1,0.36,1), border-color 0.28s ease, box-shadow 0.36s ease !important;
  content-visibility: auto;
  contain-intrinsic-size: 520px;
}

.card:hover {
  border-color: rgba(255,90,0,0.38) !important;
  box-shadow: 0 26px 72px rgba(0,0,0,0.36), 0 0 0 1px rgba(255,90,0,0.08), inset 0 1px 0 rgba(255,255,255,0.06) !important;
}

.card-img {
  background-color: #101114 !important;
  background-position: center !important;
  background-size: cover !important;
  filter: saturate(0.96) contrast(1.05) brightness(0.9) !important;
  transition: filter 0.36s ease, transform 0.36s ease !important;
  box-shadow: inset 0 -1px 0 rgba(255,255,255,0.055), inset 0 -90px 80px rgba(0,0,0,0.18);
}

.card--pro .card-img {
  filter: saturate(0.98) contrast(1.08) brightness(0.9) !important;
}

.card:hover .card-img {
  filter: saturate(1.04) contrast(1.12) brightness(0.98) !important;
}

.card-img::after {
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 32%, rgba(0,0,0,0.12) 68%, rgba(0,0,0,0.62) 100%),
    linear-gradient(90deg, rgba(255,90,0,0.10), rgba(255,255,255,0) 34%, rgba(255,255,255,0) 66%, rgba(255,90,0,0.06)) !important;
}

.card-ref {
  top: 12px !important;
  left: 12px !important;
  background: rgba(9,10,12,0.78) !important;
  border-color: rgba(245,245,240,0.16) !important;
  color: rgba(245,245,240,0.82) !important;
  border-radius: 4px !important;
  padding: 6px 10px !important;
  backdrop-filter: blur(10px);
}

.card-price {
  top: 12px !important;
  right: 12px !important;
  border-radius: 4px !important;
  background: rgba(9,10,12,0.82) !important;
  border-color: rgba(255,90,0,0.55) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,0.24), inset 0 1px 0 rgba(255,255,255,0.08) !important;
  backdrop-filter: blur(10px);
}

.card-body {
  padding: 20px 20px 22px !important;
  gap: 9px !important;
}

.card-cat {
  color: rgba(255,90,0,0.92) !important;
  letter-spacing: 0.22em !important;
}

.card-name {
  font-size: clamp(19px, 1.35vw, 22px) !important;
  line-height: 1.13 !important;
  text-wrap: balance;
}

.card-desc {
  margin: 2px 0 0;
  color: rgba(245,245,240,0.58);
  font-size: 13px;
  line-height: 1.45;
  max-width: 34em;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card-reveal {
  bottom: 0 !important;
  transform: translateY(calc(100% - 2px));
  background: rgba(13,14,16,0.94) !important;
  color: var(--fg) !important;
  border-top: 1px solid rgba(255,90,0,0.54);
  padding: 16px 18px 18px !important;
  backdrop-filter: blur(16px);
  transition: transform 0.42s cubic-bezier(0.22,1,0.36,1) !important;
}

.card:hover .card-reveal {
  transform: translateY(0);
}

.card-reveal h4 {
  color: rgba(255,90,0,0.92) !important;
}

.card-specs li {
  color: rgba(245,245,240,0.88);
  border-bottom-color: rgba(245,245,240,0.12) !important;
  gap: 12px;
  min-width: 0;
}

.card-specs li span {
  min-width: 0;
}

.card-specs li span:last-child {
  text-align: right;
  overflow-wrap: anywhere;
}

.card-add {
  background: var(--orange) !important;
  border-color: var(--orange) !important;
  color: #fff !important;
}

.card-add:hover {
  background: #ff6b1a !important;
  border-color: #ff6b1a !important;
}

.card-direct {
  color: rgba(245,245,240,0.88) !important;
  border-color: rgba(245,245,240,0.22) !important;
}

.card-direct:hover {
  background: rgba(245,245,240,0.92) !important;
  color: #101114 !important;
}

.card-actions {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 88px;
  gap: 10px !important;
  align-items: stretch;
}

.card-add,
.card-direct {
  min-height: 42px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: 0.15em !important;
}

.card-direct {
  flex: none !important;
}

.lc-cursor,
.lc-dot,
.lc-trail {
  display: none !important;
}

html.lc-on,
html.lc-on * {
  cursor: auto !important;
}

@media (hover:none), (max-width:900px) {
  .card {
    content-visibility: visible;
    contain-intrinsic-size: auto;
  }
  .card-reveal {
    position: static !important;
    transform: none !important;
    background: rgba(255,90,0,0.10) !important;
    border-top-color: rgba(255,90,0,0.28) !important;
  }
}

@media (max-width:540px) {
  .grid { gap: 20px; }
  .card-img { aspect-ratio: 16 / 11; }
  .card-name { font-size: 21px !important; }
}

@media (prefers-reduced-motion: reduce) {
  .card,
  .card-img,
  .card-reveal {
    transition: none !important;
    animation: none !important;
  }
}

/* ============================================
   ARTF V9.4 — Marquee orange typographique
   ============================================ */
.marquee-brutalist,
.marquee-brutalist.marquee-dark {
  background:
    linear-gradient(180deg, rgba(255,90,0,0.035), transparent 54%),
    #070809 !important;
  color: var(--orange) !important;
  border-top: 1px solid rgba(255,90,0,0.28) !important;
  border-bottom: 1px solid rgba(255,90,0,0.20) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.035), inset 0 -1px 0 rgba(0,0,0,0.7);
}

.marquee-brutalist::before,
.marquee-brutalist::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: min(18vw, 220px);
  z-index: 2;
  pointer-events: none;
}

.marquee-brutalist {
  position: relative;
}

.marquee-brutalist::before {
  left: 0;
  background: linear-gradient(90deg, #070809 0%, rgba(7,8,9,0) 100%);
}

.marquee-brutalist::after {
  right: 0;
  background: linear-gradient(270deg, #070809 0%, rgba(7,8,9,0) 100%);
}

.marquee-track-brutalist {
  padding: 16px 0 !important;
  gap: 64px !important;
}

.marquee-track-brutalist.reverse {
  animation-duration: 44s !important;
}

.marquee-brutalist:not(.marquee-dark) .marquee-track-brutalist {
  animation-duration: 42s !important;
}

.marquee-brutalist .mb-item {
  background: none !important;
  color: var(--orange) !important;
  padding-left: 64px !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: clamp(17px, 1.45vw, 23px) !important;
  font-weight: 700 !important;
  letter-spacing: 0.22em !important;
  line-height: 1;
  text-transform: uppercase;
  text-shadow:
    0 0 12px rgba(255,90,0,0.25),
    0 0 28px rgba(255,90,0,0.10);
  opacity: 0.95;
}

.marquee-brutalist.marquee-dark .mb-item {
  color: #ff7a2b !important;
  opacity: 0.88;
}

@media (max-width: 700px) {
  .marquee-track-brutalist { padding: 13px 0 !important; }
  .marquee-brutalist .mb-item {
    font-size: 15px !important;
    letter-spacing: 0.18em !important;
    padding-left: 38px !important;
  }
}

/* ============================================
   ARTF V9.5 — Badge logo header premium
   ============================================ */
.brand {
  gap: 14px !important;
}

.brand-mark.brand-mark-svg {
  position: relative !important;
  display: inline-grid !important;
  place-items: center !important;
  width: 54px !important;
  height: 54px !important;
  flex: 0 0 54px !important;
  aspect-ratio: 1 / 1 !important;
  overflow: hidden !important;
  border-radius: 50% !important;
  color: #f5f5f0 !important;
  background:
    radial-gradient(circle at 38% 28%, rgba(255, 90, 0, 0.22), transparent 38%),
    linear-gradient(145deg, #17181d 0%, #090a0c 52%, #030304 100%) !important;
  border: 1px solid rgba(255, 90, 0, 0.46) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.10),
    inset 0 -10px 22px rgba(0, 0, 0, 0.42),
    0 10px 28px rgba(0, 0, 0, 0.44),
    0 0 30px rgba(255, 90, 0, 0.20) !important;
}

.brand-mark.brand-mark-svg::before {
  content: '';
  position: absolute;
  inset: 6px;
  border-radius: inherit;
  border: 1px solid rgba(255, 90, 0, 0.18);
  box-shadow: inset 0 0 18px rgba(255, 90, 0, 0.08);
  pointer-events: none;
}

.brand-mark.brand-mark-svg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.14), transparent 36%);
  opacity: 0.7;
  pointer-events: none;
}

.brand-mark.brand-mark-svg svg.artf-picto-official {
  position: relative;
  z-index: 1;
  display: block !important;
  width: 38px !important;
  height: 38px !important;
  transform: none !important;
  transform-origin: center;
  filter:
    drop-shadow(0 2px 7px rgba(0, 0, 0, 0.55))
    drop-shadow(0 0 10px rgba(255, 90, 0, 0.18)) !important;
}

.brand .artf-picto-official {
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.45s cubic-bezier(0.22, 1, 0.36, 1) !important;
}

.brand:hover .brand-mark.brand-mark-svg {
  border-color: rgba(255, 90, 0, 0.72) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -10px 22px rgba(0, 0, 0, 0.44),
    0 12px 34px rgba(0, 0, 0, 0.50),
    0 0 36px rgba(255, 90, 0, 0.30) !important;
}

.brand:hover .brand-mark.brand-mark-svg svg.artf-picto-official {
  transform: scale(1.06) rotate(-2deg) !important;
}

@media (max-width: 900px) {
  .brand {
    gap: 12px !important;
  }

  .brand-mark.brand-mark-svg {
    width: 50px !important;
    height: 50px !important;
    flex-basis: 50px !important;
  }

  .brand-mark.brand-mark-svg svg.artf-picto-official {
    width: 35px !important;
    height: 35px !important;
  }
}

/* ============================================
   ARTF V9.6 — Images visibles, CTA pro, staff
   ============================================ */
.bento-grid .b {
  --mx: 50%;
  --my: 50%;
  background-color: #090a0c !important;
}

.bento-grid .b .b-media {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  display: block !important;
  overflow: hidden !important;
  background: #070809;
}

.bento-grid .b .b-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at var(--mx) var(--my), rgba(255, 90, 0, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.02) 0%, rgba(0, 0, 0, 0.22) 50%, rgba(0, 0, 0, 0.76) 100%);
  opacity: 0.62;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.bento-grid .b .b-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  opacity: 0.96 !important;
  filter: saturate(1.10) contrast(1.05) brightness(1.03);
  transform: scale(1.01);
  transition:
    transform 1s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.55s ease,
    opacity 0.35s ease;
}

.bento-grid .b:hover .b-media img,
.bento-grid .b.is-lit .b-media img {
  transform: scale(1.06);
  filter: saturate(1.18) contrast(1.08) brightness(1.10);
}

.bento-grid .b:hover .b-media::after,
.bento-grid .b.is-lit .b-media::after {
  opacity: 0.58;
}

.bento-grid .b > *:not(.b-media) {
  position: relative;
  z-index: 2;
}

.bento-grid .b::before {
  z-index: 1 !important;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.00) 0%, rgba(0, 0, 0, 0.22) 46%, rgba(0, 0, 0, 0.82) 100%) !important;
}

.bento-grid .b.v2 .b-media img,
.bento-grid .b.v3 .b-media img,
.bento-grid .b.v5 .b-media img {
  object-position: center 42% !important;
}

.bento-grid .b.v6 .b-media img {
  object-position: center 58% !important;
}

.lab-cta {
  margin-top: 30px !important;
}

.lab-cta .btn-fire,
.lab-cta .btn.btn-fire,
.lab-cta .btn-primary.btn-fire {
  display: inline-flex !important;
  width: auto !important;
  padding: 0 !important;
  margin: 0 auto !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  transform: none !important;
}

.lab-cta .btn-fire-inner {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 14px !important;
  min-height: 52px !important;
  padding: 0 28px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(255, 90, 0, 0.55) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.015)),
    #0c0d10 !important;
  color: #f5f5f0 !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 12px 28px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(255, 90, 0, 0.06) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.20em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  transition:
    border-color 0.25s ease,
    color 0.25s ease,
    transform 0.25s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.25s ease !important;
}

.lab-cta .btn-fire-inner span[aria-hidden="true"] {
  color: var(--orange);
  font-size: 15px;
  letter-spacing: 0;
  transform: translateY(-1px);
}

.lab-cta .btn-fire:hover .btn-fire-inner {
  transform: translateY(-2px) !important;
  border-color: rgba(255, 90, 0, 0.86) !important;
  color: #fff !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.10),
    0 16px 34px rgba(0, 0, 0, 0.48),
    0 0 28px rgba(255, 90, 0, 0.18) !important;
}

.btn-fire-flames,
.flame {
  display: none !important;
}

.person {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(255, 255, 255, 0)),
    #121215 !important;
}

.person-img-photo--dimitri img {
  object-position: center 34% !important;
}

.person-img-photo--alex img {
  object-position: center 50% !important;
}

.person-img-photo--generated img {
  object-position: center 22% !important;
}

.person-avatar {
  background:
    radial-gradient(circle at 30% 24%, rgba(255, 255, 255, 0.18), transparent 30%),
    linear-gradient(145deg, #1a1b20, #090a0c) !important;
  border: 1px solid rgba(255, 90, 0, 0.55);
  color: var(--orange) !important;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.42), 0 0 26px rgba(255, 90, 0, 0.16);
}

.artf-giant {
  display: none !important;
}

.footer-logo-stage {
  max-width: 1200px;
  margin: 22px auto 0;
  padding: clamp(40px, 7vw, 82px) 0 clamp(34px, 5vw, 62px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  display: grid;
  place-items: center;
}

.footer-kinetic-logo {
  --mx: 50%;
  --my: 50%;
  --phase: 0;
  position: relative;
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: clamp(22px, 4vw, 46px);
  min-height: clamp(150px, 18vw, 250px);
  padding: clamp(18px, 3vw, 36px);
  isolation: isolate;
}

.footer-kinetic-logo::before {
  content: '';
  position: absolute;
  inset: -18px -28px;
  z-index: -2;
  background:
    radial-gradient(circle at var(--mx) var(--my), rgba(255, 90, 0, 0.20), transparent 32%),
    linear-gradient(90deg, transparent, rgba(255, 90, 0, 0.08), transparent);
  opacity: 0.9;
  filter: blur(2px);
  border-radius: 24px;
}

.footer-kinetic-logo::after {
  content: '';
  position: absolute;
  left: 4%;
  right: 4%;
  top: 50%;
  height: 1px;
  z-index: -1;
  background: linear-gradient(90deg, transparent, rgba(255, 90, 0, 0.72), transparent);
  transform: translateY(-50%) scaleX(0.2);
  transform-origin: center;
  opacity: 0;
  transition: transform 1.1s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.6s ease;
}

.footer-cinetic.in-view .footer-kinetic-logo::after {
  transform: translateY(-50%) scaleX(1);
  opacity: 1;
}

.kinetic-ring {
  position: absolute;
  width: clamp(128px, 15vw, 198px);
  height: clamp(128px, 15vw, 198px);
  left: clamp(8px, 2vw, 24px);
  top: 50%;
  border-radius: 50%;
  border: 1px solid rgba(255, 90, 0, 0.24);
  transform: translateY(-50%) rotate(calc(var(--phase) * 18deg));
  box-shadow: inset 0 0 28px rgba(255, 90, 0, 0.05), 0 0 40px rgba(255, 90, 0, 0.10);
}

.kinetic-ring::before,
.kinetic-ring::after {
  content: '';
  position: absolute;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--orange);
  box-shadow: 0 0 18px rgba(255, 90, 0, 0.75);
}

.kinetic-ring::before { top: 9%; left: 50%; }
.kinetic-ring::after { bottom: 15%; right: 14%; opacity: 0.65; }

.kinetic-mark {
  width: clamp(92px, 11vw, 154px);
  height: clamp(92px, 11vw, 154px);
  color: #f5f5f0;
  filter: drop-shadow(0 16px 40px rgba(0, 0, 0, 0.55)) drop-shadow(0 0 18px rgba(255, 90, 0, 0.22));
  transform: translate3d(calc((var(--mx) - 50%) * 0.018), calc((var(--my) - 50%) * 0.012), 0);
}

.kinetic-word {
  display: flex;
  align-items: baseline;
  gap: clamp(4px, 0.8vw, 10px);
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(78px, 13vw, 190px);
  line-height: 0.76;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: #f5f5f0;
}

.kinetic-word span {
  display: inline-block;
  opacity: 0;
  transform: translateY(34px);
  text-shadow: 0 0 30px rgba(255, 90, 0, 0.12);
  transition:
    transform 0.9s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.7s ease,
    color 0.35s ease;
  transition-delay: calc(var(--i, 0) * 70ms);
}

.footer-cinetic.in-view .kinetic-word span {
  opacity: 1;
  transform: translateY(0);
}

.footer-kinetic-logo.is-running .kinetic-word span {
  animation: kinetic-letter-breathe 4.8s ease-in-out infinite;
  animation-delay: calc(var(--i, 0) * 0.18s);
}

@keyframes kinetic-letter-breathe {
  0%, 100% { color: #f5f5f0; text-shadow: 0 0 24px rgba(255, 90, 0, 0.08); }
  48% { color: #ff7a2b; text-shadow: 0 0 34px rgba(255, 90, 0, 0.20); }
}

.kinetic-caption {
  grid-column: 2;
  margin-top: 18px;
  font-family: 'Montserrat', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(245, 245, 240, 0.56);
}

@media (max-width: 800px) {
  .footer-kinetic-logo {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    gap: 18px;
  }

  .kinetic-ring {
    left: 50%;
    transform: translate(-50%, -50%) rotate(calc(var(--phase) * 18deg));
  }

  .kinetic-caption {
    grid-column: 1;
    font-size: 9px;
    line-height: 1.5;
    max-width: 280px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .footer-kinetic-logo.is-running .kinetic-word span,
  .kinetic-ring {
    animation: none !important;
    transform: none !important;
  }
}

/* ============================================
   ARTF V9.7 — Catalogue trié par usage
   ============================================ */
.catalogue-group {
  grid-column: 1 / -1;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  min-height: 44px;
  margin: clamp(12px, 2vw, 22px) 0 -4px;
  padding: 0 2px 12px;
  border-bottom: 1px solid rgba(255, 90, 0, 0.26);
  position: relative;
}

.catalogue-group:first-child {
  margin-top: 0;
}

.catalogue-group::before {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  width: clamp(70px, 12vw, 150px);
  height: 1px;
  background: var(--orange);
  box-shadow: 0 0 18px rgba(255, 90, 0, 0.42);
}

.catalogue-group span {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(22px, 2.2vw, 34px);
  line-height: 0.95;
  font-weight: 700;
  color: #f5f5f0;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.catalogue-group small {
  max-width: 430px;
  font-family: 'Montserrat', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  line-height: 1.45;
  text-transform: uppercase;
  text-align: right;
  color: rgba(245, 245, 240, 0.48);
}

.catalogue-group span::first-letter {
  color: var(--orange);
}

@media (max-width: 720px) {
  .catalogue-group {
    display: grid;
    align-items: start;
    gap: 8px;
    margin-top: 22px;
    padding-bottom: 14px;
  }

  .catalogue-group small {
    text-align: left;
    font-size: 9px;
    letter-spacing: 0.14em;
  }
}

/* ============================================
   ARTF V9.8 — Catalogue controls, sober pro finish
   ============================================ */
.card-reveal {
  background:
    linear-gradient(180deg, rgba(14, 15, 17, 0.98), rgba(8, 9, 10, 0.98)) !important;
  border-top-color: rgba(255, 90, 0, 0.34) !important;
  box-shadow: 0 -22px 48px rgba(0, 0, 0, 0.32) !important;
}

.card-reveal h4 {
  color: rgba(245, 245, 240, 0.86) !important;
  letter-spacing: 0.24em !important;
}

.card-add,
.card-direct {
  border-radius: 4px !important;
  min-height: 40px !important;
  transition: transform 0.22s ease, background 0.22s ease, border-color 0.22s ease, color 0.22s ease !important;
}

.card-add {
  background: rgba(245, 245, 240, 0.94) !important;
  border-color: rgba(245, 245, 240, 0.94) !important;
  color: #090a0b !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28) !important;
}

.card-add:hover {
  background: #fffaf0 !important;
  border-color: #fffaf0 !important;
  color: #090a0b !important;
  transform: translateY(-1px);
}

.card-direct {
  background: transparent !important;
  border-color: rgba(255, 90, 0, 0.44) !important;
  color: rgba(255, 122, 43, 0.95) !important;
}

.card-direct:hover {
  background: rgba(255, 90, 0, 0.10) !important;
  border-color: rgba(255, 122, 43, 0.72) !important;
  color: #ff8a3d !important;
  transform: translateY(-1px);
}

.card-actions {
  grid-template-columns: minmax(0, 1fr) 82px !important;
}

/* ============================================
   ARTF V10 — Evening launch polish
   ============================================ */
.brand-mark.brand-mark-svg {
  width: 58px !important;
  height: 50px !important;
  flex: 0 0 58px !important;
  border-radius: 10px !important;
  background:
    radial-gradient(circle at 34% 24%, rgba(255, 90, 0, 0.24), transparent 40%),
    linear-gradient(145deg, rgba(27, 29, 33, 0.98), rgba(7, 8, 10, 0.98)) !important;
}

.brand-mark.brand-mark-svg::before {
  inset: 5px !important;
  border-radius: 7px !important;
}

.brand-mark.brand-mark-svg svg.artf-picto-official {
  width: 42px !important;
  height: 40px !important;
}

.hero-cinema .center-card {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  padding: 24px 28px !important;
  max-width: 660px !important;
}

.hero-cinema .center-title {
  text-shadow: 0 18px 52px rgba(0, 0, 0, 0.72) !important;
}

.hero-cinema .center-sub {
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
  color: rgba(245, 245, 240, 0.78) !important;
  text-shadow: 0 10px 26px rgba(0, 0, 0, 0.70);
}

.hero-cinema .center-cta {
  gap: 10px !important;
}

.hero-cinema .btn-mini,
.btn-primary,
.btn.btn-primary,
.pack-cta {
  border-radius: 5px !important;
}

.hero-cinema .btn-mini.fill,
.btn-primary,
.btn.btn-primary {
  background:
    linear-gradient(180deg, rgba(245, 245, 240, 0.96), rgba(214, 211, 201, 0.96)) !important;
  border: 1px solid rgba(245, 245, 240, 0.74) !important;
  color: #08090b !important;
  box-shadow:
    0 12px 30px rgba(0, 0, 0, 0.30),
    inset 0 1px 0 rgba(255, 255, 255, 0.72) !important;
}

.hero-cinema .btn-mini.fill:hover,
.btn-primary:hover,
.btn.btn-primary:hover {
  transform: translateY(-2px) !important;
  border-color: #fffaf0 !important;
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(255, 90, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.84) !important;
}

.hero-cinema .btn-mini.outline,
.btn-ghost,
.btn.btn-ghost {
  background: rgba(8, 9, 11, 0.44) !important;
  border: 1px solid rgba(255, 90, 0, 0.38) !important;
  color: rgba(245, 245, 240, 0.88) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.055) !important;
}

.hero-cinema .btn-mini.outline:hover,
.btn-ghost:hover,
.btn.btn-ghost:hover {
  border-color: rgba(255, 122, 43, 0.78) !important;
  color: #ff8a3d !important;
  background: rgba(255, 90, 0, 0.08) !important;
}

.pack-card {
  border-radius: 8px !important;
  background:
    linear-gradient(180deg, rgba(29, 31, 35, 0.92), rgba(13, 14, 16, 0.98)) !important;
  border-color: rgba(245, 245, 240, 0.10) !important;
}

.pack-card:hover {
  border-color: rgba(255, 90, 0, 0.40) !important;
  box-shadow:
    0 22px 60px rgba(0, 0, 0, 0.34),
    0 0 0 1px rgba(255, 90, 0, 0.06) !important;
}

.pack-cta {
  width: fit-content;
  padding: 10px 12px !important;
  border: 1px solid rgba(255, 90, 0, 0.34);
  color: rgba(255, 122, 43, 0.95) !important;
  background: rgba(255, 90, 0, 0.055);
  letter-spacing: 0.18em !important;
}

.pack-card:hover .pack-cta {
  color: #ff8a3d !important;
  border-color: rgba(255, 122, 43, 0.70);
  background: rgba(255, 90, 0, 0.09);
}

.packs-grid {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
}

.pack-card {
  min-height: 100% !important;
}

.pack-card--media {
  padding: 14px 18px 20px !important;
  gap: 12px !important;
}

.pack-media {
  position: relative;
  margin: -14px -18px 4px;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 8px 8px 4px 4px;
  background:
    radial-gradient(circle at 50% 52%, rgba(255, 90, 0, 0.18), transparent 54%),
    #0a0b0d;
  border-bottom: 1px solid rgba(255, 90, 0, 0.22);
  isolation: isolate;
}

.pack-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(6, 7, 9, 0.04) 0%, rgba(6, 7, 9, 0.08) 46%, rgba(6, 7, 9, 0.54) 100%),
    radial-gradient(circle at 50% 92%, rgba(255, 90, 0, 0.16), transparent 52%);
  pointer-events: none;
  z-index: 1;
}

.pack-media picture,
.pack-media img {
  display: block;
  width: 100%;
  height: 100%;
}

.pack-media img {
  object-fit: cover;
  transform: scale(1.01);
  filter: saturate(0.98) contrast(1.04) brightness(0.92);
  transition:
    transform 700ms cubic-bezier(0.19, 1, 0.22, 1),
    filter 700ms cubic-bezier(0.19, 1, 0.22, 1);
}

.pack-card--media:hover .pack-media img {
  transform: scale(1.055);
  filter: saturate(1.06) contrast(1.08) brightness(1);
}

.pack-card--media .pack-icon {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  margin: -30px 0 2px 8px;
  border-radius: 8px;
  color: #ff7a2b;
  background:
    linear-gradient(180deg, rgba(58, 34, 24, 0.88), rgba(20, 14, 12, 0.88));
  border: 1px solid rgba(255, 90, 0, 0.42);
  box-shadow:
    0 14px 32px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(255, 255, 255, 0.035) inset;
  backdrop-filter: blur(10px);
}

.pack-card--media .pack-icon svg {
  width: 24px;
  height: 24px;
}

.pack-card--media h3 {
  margin-top: 2px;
}

.pack-card--media > p {
  min-height: 66px;
}

.pack-card--media .pack-cta {
  margin-top: auto;
}

@media (prefers-reduced-motion: reduce) {
  .pack-media img {
    transition: none;
  }
}

@media (max-width: 720px) {
  .pack-card--media {
    padding: 12px 14px 18px !important;
  }

  .pack-media {
    margin: -12px -14px 2px;
    aspect-ratio: 1.18 / 1;
  }

  .pack-card--media .pack-icon {
    margin-top: -28px;
  }

  .pack-card--media > p {
    min-height: 0;
  }
}

.type-card.active,
.opt-toggle.active {
  background: rgba(255, 90, 0, 0.075) !important;
  border-color: rgba(255, 90, 0, 0.55) !important;
}

.form-status {
  min-height: 20px;
  color: rgba(255, 122, 43, 0.92);
  font-size: 12px;
}

.f-col .f-text {
  color: rgba(245, 245, 240, 0.52);
  font-size: 14px;
}

.social a {
  min-width: 46px;
  padding-inline: 10px;
  font-size: 11px;
}

.footer-bottom-new > div:first-child {
  display: grid;
  gap: 8px;
}

.footer-bottom-new p {
  margin: 0;
}

.footer-credit {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 16px;
  max-width: 760px;
  color: rgba(245, 245, 240, 0.48);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.13em;
  line-height: 1.55;
  text-transform: uppercase;
}

.footer-credit span {
  position: relative;
}

.footer-credit span + span::before {
  content: "";
  position: absolute;
  left: -9px;
  top: 50%;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: rgba(255, 90, 0, 0.72);
  transform: translateY(-50%);
}

.footer-credit a {
  color: rgba(255, 122, 43, 0.94);
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 90, 0, 0.32);
  transition: color 0.22s ease, border-color 0.22s ease;
}

.footer-credit a:hover {
  color: #ff9b52;
  border-bottom-color: rgba(255, 122, 43, 0.82);
}

@media (max-width: 760px) {
  .brand-mark.brand-mark-svg {
    width: 52px !important;
    height: 46px !important;
    flex-basis: 52px !important;
  }

  .hero-cinema .center-card {
    padding: 18px 16px !important;
  }

  .hero-cinema .center-cta {
    display: grid !important;
    grid-template-columns: 1fr;
  }

  .footer-bottom-new {
    text-align: center;
  }

  .footer-credit {
    justify-content: center;
  }

.footer-credit span + span::before {
    display: none;
  }
}

/* ============================================
   ARTF V10.1 — Visual catalogue correction
   ============================================ */
.marquee-brutalist .mb-item,
.marquee-brutalist.marquee-dark .mb-item {
  color: rgba(245, 245, 240, 0.92) !important;
  opacity: 0.94 !important;
  text-shadow:
    0 0 12px rgba(245, 245, 240, 0.10),
    0 0 24px rgba(255, 90, 0, 0.12) !important;
}

.marquee-brutalist {
  border-color: rgba(245, 245, 240, 0.08) !important;
}

.card-img {
  background-size: cover !important;
  background-repeat: no-repeat !important;
}

.card-img[style*="produits-vector"] {
  filter: saturate(1.02) contrast(1.08) brightness(0.96) !important;
}

.card:hover .card-img[style*="produits-vector"] {
  filter: saturate(1.08) contrast(1.12) brightness(1.02) !important;
}

/* ARTF V10.4 — Marquee technique, sans étoiles */
.marquee-brutalist .mb-item {
  display: inline-flex !important;
  align-items: center !important;
  gap: clamp(14px, 1.8vw, 28px) !important;
  padding-left: clamp(28px, 4vw, 64px) !important;
}

.marquee-brutalist .mb-item > span {
  color: rgba(245, 245, 240, 0.92) !important;
}

.marquee-brutalist .mb-item > i {
  display: inline-block !important;
  position: relative !important;
  width: clamp(18px, 2.6vw, 42px) !important;
  height: 1px !important;
  flex: 0 0 auto !important;
  background: linear-gradient(90deg, transparent, rgba(255, 90, 0, 0.86), transparent) !important;
  opacity: 0.86 !important;
}

.marquee-brutalist .mb-item > i::after {
  content: '' !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 4px !important;
  height: 4px !important;
  border-radius: 50% !important;
  background: #ff5a00 !important;
  transform: translate(-50%, -50%) !important;
  box-shadow: 0 0 12px rgba(255, 90, 0, 0.42) !important;
}

/* ============================================
   ARTF V10.2 — Footer logo centering
   ============================================ */
.footer-kinetic-logo {
  --logo-stage: clamp(132px, 15vw, 202px);
  grid-template-columns: var(--logo-stage) auto !important;
  grid-template-areas:
    "mark word"
    "mark caption" !important;
}

.kinetic-ring {
  width: var(--logo-stage) !important;
  height: var(--logo-stage) !important;
  left: clamp(18px, 3vw, 36px) !important;
  top: 50% !important;
  transform: translateY(-50%) rotate(calc(var(--phase) * 18deg)) !important;
}

.kinetic-mark {
  grid-area: mark !important;
  grid-column: 1 !important;
  grid-row: 1 / 3 !important;
  justify-self: center !important;
  align-self: center !important;
  width: calc(var(--logo-stage) * 0.72) !important;
  height: calc(var(--logo-stage) * 0.72) !important;
  transform: translate3d(0, 0, 0) !important;
}

.kinetic-word {
  grid-area: word !important;
}

.kinetic-caption {
  grid-area: caption !important;
}

@media (max-width: 700px) {
  .footer-kinetic-logo {
    --logo-stage: 138px;
    grid-template-areas:
      "mark"
      "word"
      "caption" !important;
  }
}

/* ============================================
   ARTF V10.3 — HD catalogue + stats lisibles
   ============================================ */
.hero-cinema .stats-odo .stat-num,
.stats-odo .stat-num {
  display: flex !important;
  align-items: baseline !important;
  gap: 10px !important;
  font-size: clamp(54px, 5.8vw, 94px) !important;
  line-height: 0.86 !important;
  font-weight: 800 !important;
  color: rgba(245, 245, 240, 0.96) !important;
  letter-spacing: 0.01em !important;
  font-variant-numeric: tabular-nums !important;
}

.stats-odo .odo {
  font-size: 1em !important;
  line-height: inherit !important;
}

.stats-odo .stat-suffix {
  font-size: clamp(22px, 2.1vw, 36px) !important;
  line-height: 1 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  color: rgba(245, 245, 240, 0.62) !important;
}

.stats-odo .stat-label {
  font-size: 12px !important;
  color: rgba(245, 245, 240, 0.68) !important;
}

.card-img[style*="produits-hd"] {
  background-size: cover !important;
  background-position: center center !important;
  filter: saturate(1.04) contrast(1.06) brightness(0.99) !important;
}

.card:hover .card-img[style*="produits-hd"] {
  filter: saturate(1.10) contrast(1.10) brightness(1.03) !important;
}

@media (max-width: 900px) {
  .hero-cinema .stats-odo .stat-num,
  .stats-odo .stat-num {
    font-size: clamp(38px, 12vw, 62px) !important;
  }
}
