/* V2 — Cinematic, with Dark + Light themes */

/* Default = DARK */
:root,
:root[data-theme="dark"]{
  --bg:#0a0a0c;
  --bg-2:#111114;
  --ink:#f4f1ea;
  --muted:#8a8a90;
  --accent:#d4ff3a;          /* signature lime — used on CTA backgrounds */
  --accent-text:#d4ff3a;     /* tints for text/borders/icons */
  --line:rgba(255,255,255,.1);
  --header-bg:rgba(10,10,12,.6);
  --hover-bg:rgba(255,255,255,.06);
  --grad-end:#fff;
  --logo-filter:brightness(0) invert(1);
  --shadow-color:#fff;
  --hero-radial-a:rgba(212,255,58,.12);
  --hero-radial-b:rgba(60,80,200,.15);
  --contact-radial:rgba(212,255,58,.08);
  --sans:"Space Grotesk","Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

/* LIGHT theme (V1 editorial palette) */
:root[data-theme="light"]{
  --bg:#f7f5f1;
  --bg-2:#efece6;
  --ink:#111;
  --muted:#6b6b6b;
  --accent:#d4ff3a;          /* keep lime CTA for brand recognition */
  --accent-text:#1a1a1a;     /* dark ink for accent text/lines (lime unreadable on cream) */
  --line:rgba(0,0,0,.12);
  --header-bg:rgba(247,245,241,.75);
  --hover-bg:rgba(0,0,0,.05);
  --grad-end:#111;
  --logo-filter:grayscale(1) brightness(.2);
  --shadow-color:#111;
  --hero-radial-a:rgba(212,255,58,.18);
  --hero-radial-b:rgba(60,80,200,.08);
  --contact-radial:rgba(0,0,0,.04);
}

/* System preference when no explicit setting */
@media (prefers-color-scheme: light){
  :root:not([data-theme="dark"]):not([data-theme="light"]){
    --bg:#f7f5f1;--bg-2:#efece6;--ink:#111;--muted:#6b6b6b;
    --accent:#d4ff3a;--accent-text:#1a1a1a;--line:rgba(0,0,0,.12);
    --header-bg:rgba(247,245,241,.75);--hover-bg:rgba(0,0,0,.05);
    --grad-end:#111;--logo-filter:grayscale(1) brightness(.2);
    --shadow-color:#111;--hero-radial-a:rgba(212,255,58,.18);
    --hero-radial-b:rgba(60,80,200,.08);--contact-radial:rgba(0,0,0,.04);
  }
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .35s ease,color .35s ease}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--accent);color:#000}

/* Nav */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(14px);background:var(--header-bg);border-bottom:1px solid var(--line);transition:background .35s ease,border-color .35s ease}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 40px;max-width:1800px;margin:0 auto;gap:16px}
.brand{font-family:var(--mono);font-size:14px;letter-spacing:.04em;text-transform:uppercase;font-weight:500}
.brand .dot{display:inline-block;width:8px;height:8px;background:var(--accent);border-radius:50%;margin-right:10px;vertical-align:middle;animation:pulse 2s infinite}
@keyframes pulse{50%{opacity:.4}}
.nav-links{display:flex;gap:6px;list-style:none;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em}
.nav-links a{padding:8px 16px;border-radius:99px;transition:.2s}
.nav-links a:hover{background:var(--hover-bg)}
.nav-links a.active{background:var(--accent);color:#000}
.nav-toggle{display:none;background:none;border:none;color:var(--ink);font-size:22px;cursor:pointer}

/* Language toggle */
.lang-toggle{display:inline-flex;align-items:center;gap:2px;padding:3px;border:1px solid var(--line);border-radius:99px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;flex-shrink:0}
.lang-toggle button{appearance:none;border:0;background:transparent;color:var(--muted);cursor:pointer;padding:6px 12px;border-radius:99px;font:inherit;letter-spacing:inherit;text-transform:inherit;transition:.2s}
.lang-toggle button:hover{color:var(--ink)}
.lang-toggle button.active{background:var(--accent);color:#000}

/* Theme toggle button */
.theme-toggle{
  width:38px;height:38px;border-radius:99px;border:1px solid var(--line);background:transparent;color:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;
  flex-shrink:0;
}
.theme-toggle:hover{background:var(--hover-bg);border-color:var(--ink)}
.theme-toggle svg{width:18px;height:18px;display:block}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
:root[data-theme="light"] .theme-toggle .icon-sun{display:block}
:root[data-theme="light"] .theme-toggle .icon-moon{display:none}
@media (prefers-color-scheme: light){
  :root:not([data-theme="dark"]):not([data-theme="light"]) .theme-toggle .icon-sun{display:block}
  :root:not([data-theme="dark"]):not([data-theme="light"]) .theme-toggle .icon-moon{display:none}
}

/* Hero */
.hero{
  min-height:100vh;display:flex;align-items:center;padding:120px 40px 80px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 30%,var(--hero-radial-a),transparent 50%),
             radial-gradient(circle at 20% 80%,var(--hero-radial-b),transparent 55%);
  z-index:0;
}
.hero-inner{max-width:1800px;margin:0 auto;width:100%;display:grid;grid-template-columns:1.3fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:var(--accent-text);margin-bottom:24px;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--accent-text)}
.hero h1{font-size:clamp(56px,9vw,140px);line-height:.95;letter-spacing:-.03em;font-weight:500;margin-bottom:32px}
.hero h1 span{background:linear-gradient(135deg,var(--accent-text),var(--grad-end));-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
.hero .lead{color:var(--muted);font-size:18px;max-width:560px;line-height:1.6}
.hero .cta-row{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:99px;font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;transition:.25s}
.btn-primary{background:var(--accent);color:#000}
.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--shadow-color)}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{background:var(--hover-bg);border-color:var(--ink)}
.hero-visual{position:relative;aspect-ratio:3/4;border-radius:6px;overflow:hidden;background:#000}
.hero-visual img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(.9)}
.hero-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.5))}
.hero-meta{position:absolute;bottom:24px;left:24px;right:24px;z-index:2;display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#fff}

/* Marquee — text variant (kept for reuse) */
.marquee{padding:30px 0;border-block:1px solid var(--line);overflow:hidden;white-space:nowrap;background:var(--bg-2)}
.marquee.marquee-logos{padding:48px 0}
.marquee-track{display:inline-flex;gap:60px;animation:scroll 40s linear infinite;font-family:var(--mono);font-size:13px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted)}
.marquee-track span{display:inline-flex;align-items:center;gap:60px}
.marquee-track span::after{content:"✦";color:var(--accent-text)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* Sections */
.section{padding:120px 40px;max-width:1800px;margin:0 auto}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:40px;margin-bottom:64px}
.section-head h2{font-size:clamp(38px,5vw,72px);line-height:1;letter-spacing:-.02em;font-weight:500;max-width:800px}
.section-head h2 em{font-style:italic;color:var(--muted)}
.section-head .meta{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);text-align:right;flex-shrink:0}

/* Feature cards — keep dark overlay regardless of theme (image readability) */
.features{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.feature{position:relative;aspect-ratio:5/4;overflow:hidden;border-radius:8px;background:#000;cursor:pointer}
.feature img,.feature video{width:100%;height:100%;object-fit:cover;transition:1s ease;display:block}
.feature:hover img,.feature:hover video{transform:scale(1.06)}
.feature::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85));pointer-events:none}
.mute-btn{position:absolute;top:20px;right:20px;z-index:3;width:56px;height:56px;border-radius:50%;border:none;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,transform .2s ease}
.mute-btn:hover{background:rgba(0,0,0,.8);transform:scale(1.06)}
.mute-btn svg{width:24px;height:24px;display:none}
.mute-btn[aria-pressed="true"] .icon-muted{display:block}
.mute-btn[aria-pressed="false"] .icon-sound{display:block}
.feature-meta{position:absolute;bottom:0;left:0;right:0;padding:32px;z-index:2;color:#fff}
.feature-meta .tag{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.feature-meta h3{font-size:28px;font-weight:500;letter-spacing:-.01em}

/* Clients — marquee */
.clients-section{padding:120px 0;background:var(--bg-2);border-block:1px solid var(--line)}
.clients-section .section-head{padding:0 40px;max-width:1800px;margin:0 auto 48px}
.logo-marquee{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.logo-track{display:flex;gap:80px;width:max-content;animation:logo-scroll 50s linear infinite;align-items:center}
.logo-track img{height:40px;width:auto;opacity:.5;filter:var(--logo-filter);transition:.3s;flex-shrink:0}
.logo-track img:hover{opacity:1;transform:scale(1.1)}
.logo-marquee:hover .logo-track{animation-play-state:paused}
.logo-marquee.lg .logo-track{gap:110px;animation-duration:60s}
.logo-marquee.lg .logo-track img{height:72px;opacity:.65}
.logo-marquee.lg .logo-track img:hover{opacity:1}
@keyframes logo-scroll{to{transform:translateX(-50%)}}

/* Videos */
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.video{position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:10px;background:#000;border:1px solid var(--line)}
.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-meta{margin-top:18px}
.video-meta .tag{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-text);margin-bottom:6px}
.video-meta h3{font-size:18px;font-weight:500;letter-spacing:-.01em}

/* Spotify */
.spotify-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.spotify-wrap h2{font-size:clamp(38px,5vw,72px);line-height:1;letter-spacing:-.02em;font-weight:500;margin-bottom:20px}
.spotify-wrap h2 em{font-style:italic;color:var(--muted)}
.spotify-wrap p{color:var(--muted);margin-bottom:28px;max-width:440px}
.spotify-embed{border-radius:14px;overflow:hidden;background:#000;border:1px solid var(--line)}
.spotify-embed iframe{width:100%;height:420px;border:0;display:block}

/* Album grid */
.album-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.album{display:block;position:relative}
.album .cover{aspect-ratio:1;overflow:hidden;border-radius:6px;background:#000;position:relative}
.album .cover img{width:100%;height:100%;object-fit:cover;transition:.5s}
.album:hover .cover img{transform:scale(1.05)}
.album .cover::after{content:"▶";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);color:var(--accent);font-size:36px;opacity:0;transition:.3s}
.album:hover .cover::after{opacity:1}
.album .title{font-size:18px;margin-top:16px;font-weight:500}
.album .label-name{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* Work list */
.work-list{list-style:none;border-top:1px solid var(--line)}
.work-list li{display:grid;grid-template-columns:80px 1fr auto auto;column-gap:16px;align-items:center;padding:32px 0;border-bottom:1px solid var(--line);font-size:clamp(24px,3vw,42px);font-weight:500;letter-spacing:-.01em;transition:.3s;cursor:pointer}
.work-list li:hover{padding-left:20px;color:var(--accent-text)}
.work-list .num{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.2em}
.work-list .tag{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.work-list .play-pill{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);font-size:11px;color:var(--muted);transition:.3s;opacity:.7}
.work-list li[data-video]:hover .play-pill{background:var(--accent-text,#fff);color:var(--bg,#000);border-color:transparent;opacity:1;transform:scale(1.08)}

/* Vertical video modal */
.vid-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .25s ease;pointer-events:none}
.vid-modal[data-open="true"]{opacity:1;pointer-events:auto}
.vid-modal-phone{position:relative;width:min(360px,90vw);aspect-ratio:9/16;max-height:90vh;border-radius:28px;overflow:hidden;background:#000;box-shadow:0 30px 80px rgba(0,0,0,.5);transform:scale(.94);transition:transform .25s ease}
.vid-modal[data-open="true"] .vid-modal-phone{transform:scale(1)}
.vid-modal-video{width:100%;height:100%;object-fit:cover;display:block}
.vid-modal-close{position:absolute;top:24px;right:24px;width:48px;height:48px;border-radius:50%;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.vid-modal-close:hover{background:rgba(255,255,255,.25)}

/* About */
.about-hero{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center;padding-top:60px}
.about-hero img{aspect-ratio:3/4;object-fit:cover;width:100%;border-radius:8px}
.about-hero .quote{font-size:clamp(28px,3.5vw,48px);line-height:1.15;letter-spacing:-.01em;font-weight:500;margin-bottom:40px}
.about-hero .quote::before{content:"";display:block;width:60px;height:2px;background:var(--accent-text);margin-bottom:32px}
.about-hero p{color:var(--muted);font-size:17px;line-height:1.7;margin-bottom:18px}
.about-hero p strong{color:var(--ink);font-weight:400}

/* Contact */
.contact-hero{min-height:90vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:120px 24px 60px;text-align:center;position:relative}
.contact-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,var(--contact-radial),transparent 60%);z-index:0}
.contact-hero > *{position:relative;z-index:1}
.contact-hero h1{font-size:clamp(56px,10vw,160px);line-height:.92;letter-spacing:-.03em;font-weight:500;margin-bottom:32px}
.contact-hero h1 em{font-style:italic;background:linear-gradient(135deg,var(--accent-text),var(--grad-end));-webkit-background-clip:text;background-clip:text;color:transparent}
.contact-hero .lead{color:var(--muted);max-width:520px;font-size:18px}
.contact-hero .email{display:inline-block;margin-top:40px;font-size:clamp(22px,3vw,36px);font-weight:500;border-bottom:2px solid var(--accent);padding-bottom:6px}
.socials{display:flex;justify-content:center;gap:14px;margin-top:48px}
.socials a{padding:12px 24px;border:1px solid var(--line);border-radius:99px;font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;transition:.2s}
.socials a:hover{background:var(--accent);color:#000;border-color:var(--accent)}

/* Legal */
.legal{max-width:820px;margin:0 auto;padding:140px 24px 80px}
.legal h1{font-size:clamp(40px,6vw,72px);letter-spacing:-.02em;margin-bottom:48px;font-weight:500}
.legal h2{font-size:18px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.18em;color:var(--accent-text);margin:48px 0 16px}
.legal p{color:var(--muted);line-height:1.7;margin-bottom:14px}
.legal a{color:var(--ink);border-bottom:1px solid var(--line)}

/* Footer */
.site-footer{border-top:1px solid var(--line);margin-top:120px;padding:48px 40px;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);max-width:1800px;margin-left:auto;margin-right:auto;flex-wrap:wrap;gap:20px}
.site-footer .socials-mini{display:flex;gap:24px}
.site-footer .socials-mini a:hover{color:var(--accent-text)}

@media(max-width:900px){
  .nav{padding:16px 20px;gap:8px}
  .nav-links{display:none}
  .nav-toggle{display:block}
  .lang-toggle{font-size:10px}
  .lang-toggle button{padding:5px 9px}
  .hero{padding:120px 20px 60px;min-height:auto}
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .section,.clients-section{padding:80px 20px}
  .features,.about-hero{grid-template-columns:1fr;gap:32px}
  /* Mobile: video à l'échelle (pas de crop) + bouton mute toujours visible */
  .feature{aspect-ratio:16/9}
  .feature video{object-fit:contain;background:#000}
  .feature:hover video{transform:none}
  .mute-btn{top:12px;right:12px;width:48px;height:48px;background:rgba(0,0,0,.7);opacity:1}
  .album-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .video-grid{grid-template-columns:1fr;gap:24px}
  .spotify-wrap{grid-template-columns:1fr;gap:32px}
  .section-head{flex-direction:column;align-items:flex-start;gap:16px}
  .site-footer{padding:32px 20px;flex-direction:column}
}
