/* ============================================================
   TECHCAR — Accueil (styles spécifiques)
   ============================================================ */

/* ---------------- HERO ---------------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-top: 84px;
  overflow: hidden;
}
.hero-bg {
  position: absolute; inset: -12% 0 -12% 0;
  z-index: 0;
  background:
    radial-gradient(70% 90% at 70% 18%, oklch(0.30 0.04 70 / 0.5), transparent 60%),
    repeating-linear-gradient(125deg, oklch(0.185 0.008 72) 0 2px, transparent 2px 14px),
    linear-gradient(160deg, var(--bg-2), var(--bg));
}
.hero-bg image-slot, .hero-bg .well, .hero-bg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-veil {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, oklch(0.145 0.006 70 / 0.55) 0%, transparent 22%, transparent 45%, oklch(0.145 0.006 70 / 0.86) 86%, var(--bg) 100%),
    linear-gradient(95deg, oklch(0.145 0.006 70 / 0.78) 0%, transparent 62%);
}
.hero-inner { position: relative; z-index: 3; width: 100%; padding-bottom: clamp(48px, 8vh, 96px); }
.hero-eyebrow { margin-bottom: 26px; }
.hero h1 { max-width: 15ch; margin-bottom: 26px; }
.hero .lead { margin-bottom: 38px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }

.hero-side {
  position: absolute; right: var(--gut); top: 50%; z-index: 3;
  transform: rotate(90deg) translateX(50%);
  transform-origin: right center;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--muted);
  display: flex; align-items: center; gap: 14px;
}
.hero-side::before { content: ""; width: 46px; height: 1px; background: var(--gold-line); }

.hero-scroll {
  position: absolute; left: var(--gut); bottom: clamp(48px, 8vh, 96px); z-index: 3;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--muted);
  display: flex; align-items: center; gap: 12px;
}
.hero-scroll i { width: 1px; height: 40px; background: var(--gold-line); display: block; position: relative; overflow: hidden; }
.hero-scroll i::after { content:""; position:absolute; inset:0; background: var(--gold); transform: translateY(-100%); animation: scrolldrop 2.4s var(--ease) infinite; }
@keyframes scrolldrop { 0% { transform: translateY(-100%);} 55%{ transform: translateY(100%);} 100%{ transform: translateY(100%);} }

/* hero entrance */
.hero .anim { opacity: 0; transform: translateY(40px); animation: heroUp 1.2s var(--ease-out) forwards; }
.hero .anim.d1 { animation-delay: 0.15s; }
.hero .anim.d2 { animation-delay: 0.3s; }
.hero .anim.d3 { animation-delay: 0.45s; }
.hero .anim.d4 { animation-delay: 0.6s; }
@keyframes heroUp { to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .hero .anim { opacity: 1; transform: none; animation: none; } }

/* ---------------- MARQUEE ---------------- */
.marquee-sec { border-block: 1px solid var(--line); padding: 30px 0; background: var(--bg-1); overflow: hidden; }
.marquee-head { font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--muted); text-align: center; margin-bottom: 22px; }
.marquee { display: flex; overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent); }
.marquee-track { display: flex; gap: 64px; padding-right: 64px; flex: none; animation: scrollx 38s linear infinite; }
.marquee-track span { font-family: var(--display); font-size: clamp(20px, 2.6vw, 34px); color: var(--ink-2); white-space: nowrap; font-weight: 700; text-transform: uppercase; letter-spacing: 0.01em; }
.marquee-track span em { color: var(--gold); font-style: normal; }
@keyframes scrollx { to { transform: translateX(-100%); } }
@media (prefers-reduced-motion: reduce) { .marquee-track { animation: none; } }

/* ---------------- MANIFESTO + STATS ---------------- */
.manifesto { padding: clamp(90px, 14vh, 170px) 0; }
.manifesto-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(40px, 7vw, 110px); align-items: end; }
.manifesto-statement { font-family: var(--display); font-weight: 700; line-height: 1.04; font-size: clamp(28px, 3.7vw, 50px); letter-spacing: -0.015em; }
.manifesto-statement em { font-style: italic; color: var(--gold); }
.manifesto .lead { margin-bottom: 38px; }

.stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: clamp(60px, 9vh, 120px); }
.stat { background: var(--bg); padding: 38px 34px; }
.stat-num { font-family: var(--display); font-size: clamp(42px, 5.2vw, 72px); font-weight: 800; line-height: 0.92; color: var(--ink); font-style: italic; letter-spacing: -0.02em; }
.stat-num .u { color: var(--gold); }
.stat-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); margin-top: 14px; }
@media (min-width: 760px) { .stats { grid-template-columns: repeat(4, 1fr); } }

/* ---------------- SERVICES (editorial rows) ---------------- */
.services { padding: clamp(50px, 8vh, 90px) 0 clamp(90px, 14vh, 160px); }
.services-head { text-align: center; max-width: 760px; margin: 0 auto clamp(56px, 9vh, 110px); display: flex; flex-direction: column; align-items: center; gap: 30px; }

.srow { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 6vw, 90px); align-items: center; padding: clamp(40px, 7vh, 88px) 0; border-top: 1px solid var(--line); }
.srow:last-child { border-bottom: 1px solid var(--line); }
.srow-media { position: relative; }
.srow-media .frame {
  position: relative; overflow: hidden; aspect-ratio: 4 / 3.1;
  background:
    radial-gradient(80% 90% at 32% 18%, oklch(0.27 0.03 72 / 0.55), transparent 62%),
    repeating-linear-gradient(125deg, oklch(0.205 0.008 72) 0 2px, transparent 2px 13px),
    linear-gradient(155deg, var(--bg-2), var(--bg-1));
  border: 1px solid var(--line);
}
.srow-media image-slot, .srow-media .well, .srow-media .frame img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 1.2s var(--ease); }
.srow:hover .srow-media image-slot, .srow:hover .srow-media .well, .srow:hover .srow-media .frame img { transform: scale(1.04); }
.srow-num { position: absolute; top: -10px; left: -8px; font-family: var(--display); font-size: clamp(70px, 9vw, 130px); line-height: 1; color: transparent; -webkit-text-stroke: 1px var(--gold-line); z-index: 4; pointer-events: none; }
.srow:nth-child(even) .srow-media { order: 2; }
.srow-body { max-width: 46ch; }
.srow-body .h2 { margin: 16px 0 18px; }
.srow-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 24px 0 28px; }
.tag { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-2); border: 1px solid var(--line-2); padding: 7px 13px; border-radius: 2px; white-space: nowrap; }
.srow-foot { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }
.price { font-family: var(--display); font-weight: 700; font-style: italic; font-size: 27px; color: var(--ink); white-space: nowrap; letter-spacing: -0.01em; }
.price small { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); display: block; }

/* ---------------- GALLERY ---------------- */
.gallery { padding: clamp(40px, 7vh, 80px) 0 clamp(90px, 14vh, 160px); }
.gallery-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; margin-bottom: 48px; flex-wrap: wrap; }
.gallery-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px; }
.gcell { position: relative; overflow: hidden;
  background:
    radial-gradient(80% 90% at 32% 18%, oklch(0.27 0.03 72 / 0.5), transparent 62%),
    repeating-linear-gradient(125deg, oklch(0.205 0.008 72) 0 2px, transparent 2px 13px),
    linear-gradient(155deg, var(--bg-2), var(--bg-1));
  border: 1px solid var(--line);
}
.gcell image-slot, .gcell .well, .gcell img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 1.4s var(--ease); }
.gcell:hover image-slot, .gcell:hover .well, .gcell:hover img { transform: scale(1.05); }
.gcap { position: absolute; left: 16px; bottom: 14px; z-index: 3; font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink); background: oklch(0.145 0.006 70 / 0.6); backdrop-filter: blur(6px); padding: 6px 11px; }
.g-a { grid-column: span 7; aspect-ratio: 16/10; }
.g-b { grid-column: span 5; aspect-ratio: 16/10; }
.g-c { grid-column: span 4; aspect-ratio: 4/3; }
.g-d { grid-column: span 4; aspect-ratio: 4/3; }
.g-e { grid-column: span 4; aspect-ratio: 4/3; }
.g-f { grid-column: span 6; aspect-ratio: 16/10; }
.g-g { grid-column: span 6; aspect-ratio: 16/10; }
@media (max-width: 760px) {
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .g-a, .g-b, .g-c, .g-d, .g-e, .g-f, .g-g { grid-column: span 1; aspect-ratio: 1; }
  .g-a { grid-column: span 2; aspect-ratio: 16/11; }
}

/* ---------------- REELS / INSTAGRAM ---------------- */
.reels { padding: clamp(80px, 12vh, 150px) 0; }
.reels-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; margin-bottom: 48px; flex-wrap: wrap; }
.reels-head .h1 { max-width: 16ch; }

/* Reel cards grid — first card (video) features larger */
.reel-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.reel-card {
  position: relative; display: block; border: 1px solid var(--line); border-radius: 3px;
  overflow: hidden; aspect-ratio: 9 / 16; background: var(--bg-2);
  transition: border-color .5s var(--ease), transform .5s var(--ease);
  padding: 0; margin: 0; font: inherit; color: inherit; text-align: left; cursor: pointer; width: 100%;
}
.reel-card.feature { grid-row: span 2; grid-column: span 2; aspect-ratio: auto; }
.reel-poster { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.reel-card.feature video { position: relative; z-index: 1; }
.reel-card img, .reel-card video { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 1.2s var(--ease); }
.reel-card:hover { border-color: var(--gold-line); }
.reel-card:hover img, .reel-card:hover video { transform: scale(1.06); }
.reel-card::after { content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background: linear-gradient(to top, oklch(0.07 0.004 70 / 0.85) 2%, transparent 38%),
              radial-gradient(60% 50% at 50% 42%, oklch(0.07 0.004 70 / 0.22), transparent 70%); }
.reel-play { position: absolute; top: 50%; left: 50%; z-index: 4; transform: translate(-50%, -50%);
  width: 54px; height: 54px; border-radius: 50%; display: grid; place-items: center;
  background: oklch(0.1 0.004 70 / 0.5); border: 1.5px solid oklch(1 0 0 / 0.85); backdrop-filter: blur(4px);
  transition: .4s var(--ease); }
.reel-card:hover .reel-play { background: var(--gold); border-color: var(--gold); transform: translate(-50%, -50%) scale(1.08); }
.reel-play svg { width: 18px; height: 18px; margin-left: 3px; color: var(--ink); }
.reel-card:hover .reel-play svg { color: #1a1206; }
.reel-tag { position: absolute; top: 14px; left: 14px; z-index: 4; display: flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink);
  background: oklch(0.1 0.004 70 / 0.6); backdrop-filter: blur(6px); padding: 6px 11px; border-radius: 2px; }
.reel-tag svg { width: 13px; height: 13px; }
.reel-tag i { width: 7px; height: 7px; border-radius: 50%; background: #ff4d4d; }
.reel-tag.live i { animation: livepulse 2s infinite; }
@keyframes livepulse { 0% { box-shadow: 0 0 0 0 oklch(0.65 0.22 25 / 0.7);} 70%{ box-shadow: 0 0 0 7px transparent;} 100%{ box-shadow:0 0 0 0 transparent;} }
.reel-cap { position: absolute; left: 0; right: 0; bottom: 0; z-index: 4; padding: 40px 16px 15px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; color: var(--ink-2); line-height: 1.4; }
@media (max-width: 900px) {
  .reel-cards { grid-template-columns: repeat(2, 1fr); }
  .reel-card.feature { grid-column: span 2; grid-row: auto; aspect-ratio: 9/16; }
}
@media (max-width: 540px) { .reel-cards { grid-template-columns: 1fr 1fr; } .reel-card.feature { grid-column: span 2; } }

/* ---------------- LIGHTBOX (lecteur intégré) ---------------- */
.lightbox { position: fixed; inset: 0; z-index: 200; display: grid; place-items: center; padding: 4vh 4vw;
  background: oklch(0.06 0.004 70 / 0.92); backdrop-filter: blur(10px); animation: lbfade .3s var(--ease); }
.lightbox[hidden] { display: none; }
@keyframes lbfade { from { opacity: 0; } to { opacity: 1; } }
.lb-stage { position: relative; max-width: min(560px, 92vw); width: 100%; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.lb-video, .lb-image { width: 100%; max-height: 82vh; border-radius: 4px; border: 1px solid var(--line-2); background: #000; display: block; object-fit: contain; box-shadow: 0 40px 120px oklch(0 0 0 / 0.6); }
.lb-cap { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; color: var(--ink-2); text-align: center; }
.lb-close { position: absolute; top: -46px; right: 0; width: 38px; height: 38px; display: grid; place-items: center;
  background: oklch(0.16 0.006 70 / 0.8); border: 1px solid var(--line-2); border-radius: 50%; color: var(--ink); cursor: pointer; transition: .3s var(--ease); }
.lb-close:hover { border-color: var(--gold); color: var(--gold); }
.lb-close svg { width: 18px; height: 18px; }
@media (max-width: 560px) { .lb-close { top: -44px; } }

/* ---------------- PROCESS ---------------- */
.process { padding: clamp(80px, 12vh, 150px) 0; background-color: oklch(0.135 0.006 70);
  background-image:
    linear-gradient(27deg, oklch(0.17 0.007 70) 3.5px, transparent 3.5px),
    linear-gradient(207deg, oklch(0.17 0.007 70) 3.5px, transparent 3.5px),
    linear-gradient(27deg, oklch(0.12 0.005 70) 3.5px, transparent 3.5px),
    linear-gradient(207deg, oklch(0.12 0.005 70) 3.5px, transparent 3.5px);
  background-size: 14px 14px; background-position: 0 0, 7px 7px, 7px 0, 0 7px;
  border-block: 1px solid var(--line); }
.process-head { max-width: 640px; margin-bottom: clamp(50px, 8vh, 90px); display: flex; flex-direction: column; gap: 22px; }
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.step { background: oklch(0.16 0.006 70 / 0.86); padding: 40px 30px 46px; position: relative; transition: background 0.5s var(--ease); }
.step:hover { background: oklch(0.21 0.008 72 / 0.92); }
.step::before { content: ""; position: absolute; left: 0; top: 0; width: 0; height: 2px; background: var(--gold); transition: width 0.6s var(--ease); }
.step:hover::before { width: 100%; }
.step-num { font-family: var(--mono); font-size: 12px; letter-spacing: 0.2em; color: var(--gold); margin-bottom: 30px; }
.step h4 { font-family: var(--display); font-weight: 700; text-transform: uppercase; letter-spacing: -0.005em; line-height: 1.12; font-size: 21px; margin-bottom: 18px; min-height: 2.24em; }
.step p { color: var(--muted); font-size: 14.5px; line-height: 1.6; }
@media (max-width: 860px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 500px) { .steps { grid-template-columns: 1fr; } }

/* ---------------- TESTIMONIALS ---------------- */
.testi { padding: clamp(90px, 14vh, 160px) 0; }
.testi-head { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 20px; margin-bottom: clamp(50px, 8vh, 90px); }
.stars { color: var(--gold); letter-spacing: 3px; font-size: 17px; }
.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.quote { border: 1px solid var(--line); background: var(--bg-1); padding: 38px 34px 32px; display: flex; flex-direction: column; gap: 22px; transition: border-color 0.5s var(--ease), transform 0.6s var(--ease); }
.quote:hover { border-color: var(--gold-line); transform: translateY(-4px); }
.quote-mark { font-family: Georgia, serif; font-size: 60px; line-height: 0.5; color: var(--gold-line); height: 26px; }
.quote p { font-family: var(--sans); font-size: 17px; line-height: 1.55; color: var(--ink); font-weight: 500; }
.quote-by { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 14px; padding-top: 22px; border-top: 1px solid var(--line); }
.quote-by .nm { font-size: 14px; font-weight: 600; }
.quote-by .veh { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin-top: 4px; }
.g-badge { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; color: var(--muted); display: flex; align-items: center; gap: 7px; white-space: nowrap; }
@media (max-width: 860px) { .testi-grid { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; } }

/* ---------------- HOME RESPONSIVE ---------------- */
@media (max-width: 900px) {
  .manifesto-grid { grid-template-columns: 1fr; gap: 44px; }
  .srow { grid-template-columns: 1fr; gap: 28px; }
  .srow:nth-child(even) .srow-media { order: 0; }
}
