/* ====== Local Helvetica fonts ====== */
@font-face{
  font-family:"Helvetica Custom";
  src:url("../fonts/helvetica-bold.ttf") format("truetype");
  font-weight:700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Helvetica Custom";
  src:url("../fonts/helvetica-neue-lt-blk.otf") format("opentype");
  font-weight:900;font-style:normal;font-display:swap;
}

/* ====== Reset & tokens ====== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#050505;
  --bg-2:#0a0a0c;
  --fg:#fff;
  --fg-dim:rgba(255,255,255,.72);
  --fg-mute:rgba(255,255,255,.5);
  --line:rgba(255,255,255,.1);
  --accent:#FFFDBE;
  --pad-x:clamp(20px,4.2vw,72px);
  --ease:cubic-bezier(.65,.05,.15,1);
  --ease-soft:cubic-bezier(.2,.7,.2,1);
}
html{
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  scroll-behavior:smooth;
}
html.has-snap{scroll-snap-type:y mandatory}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:"Helvetica Neue","Helvetica","Arial",sans-serif;
  font-weight:400;font-size:16px;line-height:1.55;
  overflow-x:clip;
}
/* Display = bold/black headings use the local Helvetica files */
.h2,.btn,.tile__title,.album__edition,.nav__links a,.nav__lang,.eyebrow,.footer__legal a,.footer__copy,
.page-hero h1,.prose h1,.prose h2,.album__retailers a,.mt-hero__edition,.mt-retailers__head h2,
input::placeholder{
  font-family:"Helvetica Custom","Helvetica Neue","Helvetica","Arial",sans-serif;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}

/* ====== Filmic grain ====== */
body::after{
  content:"";position:fixed;inset:0;z-index:90;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.5'/></svg>");
  opacity:.06;mix-blend-mode:overlay;
}

/* ====== Typography ====== */
.eyebrow{
  font-size:11px;font-weight:400;
  text-transform:uppercase;letter-spacing:normal;
  color:var(--fg-mute);
}
.h2{
  font-weight:700;
  font-size:clamp(40px,7vw,118px);
  line-height:.95;letter-spacing:normal;
  text-transform:uppercase;
}
.body-lg{font-size:clamp(15px,1.18vw,17px);line-height:1.65;color:var(--fg-dim);max-width:min(54ch,100%);font-weight:400}

/* ====== Buttons : borderless, no fill, just text ====== */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 0;
  font-size:13px;font-weight:700;
  text-transform:uppercase;letter-spacing:normal;
  color:var(--fg);background:none;border:none;
  cursor:pointer;
  transition:opacity .35s var(--ease),transform .5s var(--ease);
}
.btn:hover{opacity:.7}
.btn--primary{color:var(--accent)}
.btn--primary:hover{opacity:.85}
.btn .arrow{display:inline-block;transition:transform .5s var(--ease)}
.btn:hover .arrow{transform:translateX(10px)}

/* ====== Intro curtain ====== */
.curtain{
  position:fixed;inset:0;z-index:100;background:var(--bg);
  display:grid;place-items:center;
  animation:curtainSlide 1.2s var(--ease) 1.4s forwards;
}
.curtain__logo{
  width:min(180px,38vw);opacity:0;
  animation:fadeIn .8s ease-out .2s forwards,fadeOut .4s ease-in 1.3s forwards;
}
@keyframes fadeIn{to{opacity:.85}}
@keyframes fadeOut{to{opacity:0;transform:scale(.97)}}
@keyframes curtainSlide{to{transform:translateY(-100%)}}
body.loaded .curtain{display:none}

/* ====== Nav ====== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--pad-x);
  transition:background .5s var(--ease),padding .5s var(--ease);
}
.nav.scrolled{background:rgba(5,5,5,.72);backdrop-filter:blur(12px);padding:14px var(--pad-x)}
.nav__brand img{height:36px;width:auto;opacity:.95;transition:opacity .3s ease}
.nav__brand:hover img{opacity:1}
.nav__links{display:flex;gap:36px}
.nav__links a{
  position:relative;
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:normal;
  color:var(--fg-dim);transition:color .35s ease;padding:6px 0;
}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--fg);transform:scaleX(0);transform-origin:right;
  transition:transform .55s var(--ease);
}
.nav__links a:hover{color:var(--fg)}
.nav__links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav__links a.is-current{color:var(--fg)}
.nav__lang{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:normal;color:var(--fg-dim);transition:color .3s ease}
.nav__lang:hover{color:var(--fg)}
@media (max-width:760px){.nav__links{display:none}}

/* ====== Snap section base : full-screen on PC ====== */
.snap{
  scroll-snap-align:start;scroll-snap-stop:always;
  min-height:100vh;
  padding:96px var(--pad-x);
  display:flex;flex-direction:column;justify-content:center;
  position:relative;
  overflow:hidden;
}

/* ====== Hero ====== */
.hero{
  height:100vh;min-height:100vh;width:100%;
  padding:0 var(--pad-x) clamp(70px,9vw,120px);
  display:flex;flex-direction:column;justify-content:flex-end;
  position:relative;overflow:hidden;isolation:isolate;
  scroll-snap-align:start;scroll-snap-stop:always;
}
.hero__bg{
  position:absolute;inset:0;z-index:-2;
  background-position:center right;background-size:cover;background-repeat:no-repeat;
  transform:scale(1.06);
  animation:slowZoom 24s ease-out forwards;
}
@keyframes slowZoom{from{transform:scale(1.14)}to{transform:scale(1)}}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(110deg,rgba(5,5,5,.78) 0%,rgba(5,5,5,.3) 50%,rgba(5,5,5,0) 80%);
}
.hero__eyebrow{margin-bottom:24px}
.hero__logo-wrap{margin-bottom:30px;overflow:hidden;max-width:100%}
.hero__logo{
  width:min(680px,86vw);height:auto;
  filter:drop-shadow(0 8px 30px rgba(0,0,0,.5));
  transform:translateY(110%);
  animation:rise 1.6s var(--ease) 1.8s forwards;
}
@keyframes rise{to{transform:translateY(0)}}
.hero__sub{
  margin-bottom:38px;
  font-size:clamp(15px,1.2vw,17px);
  color:var(--fg-dim);max-width:min(42ch,100%);font-weight:400;line-height:1.65;
  opacity:0;animation:softIn 1s ease-out 2.4s forwards;
}
.hero__ctas{display:flex;gap:32px;flex-wrap:wrap;opacity:0;animation:softIn 1s ease-out 2.7s forwards}
@keyframes softIn{to{opacity:1}}

/* ====== Album ====== */
.album{background:var(--bg-2)}
.album__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,90px);align-items:center;
  max-width:1400px;margin:0 auto;width:100%;
}
.album__visual{
  position:relative;aspect-ratio:1/1;display:grid;place-items:center;
  padding:18%;max-width:560px;justify-self:center;width:100%;
}
.album__visual::before{
  content:"";position:absolute;inset:18%;border-radius:50%;
  background:radial-gradient(circle,rgba(77,141,255,.22),transparent 65%);
  filter:blur(40px);pointer-events:none;
}
.album__cd{
  position:relative;width:100%;
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.65));
  animation:slowSpin 80s linear infinite;transform-origin:center;
}
@keyframes slowSpin{to{transform:rotate(360deg)}}
.album__copy{max-width:100%}
.album__copy .eyebrow{margin-bottom:22px}
.album__logo{width:min(380px,80%);margin-bottom:14px;filter:drop-shadow(0 4px 14px rgba(0,0,0,.4))}
.album__edition{
  font-size:clamp(24px,2.8vw,42px);font-weight:700;letter-spacing:normal;text-transform:uppercase;
  color:var(--accent);margin-bottom:26px;line-height:1;
}
.album__copy p{margin-bottom:32px;font-size:clamp(14px,1.05vw,16px);line-height:1.65;color:var(--fg-dim);font-weight:400;max-width:min(52ch,100%)}
.album__ctas{display:flex;gap:36px;flex-wrap:wrap;margin-bottom:32px}
.album__retailers{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.album__retailers span{font-size:11px;text-transform:uppercase;color:var(--fg-mute);margin-right:6px;font-weight:400}
.album__retailers a{
  font-size:12px;color:var(--fg-dim);font-weight:700;
  border-bottom:1px solid var(--line);padding-bottom:3px;transition:color .35s ease,border-color .35s ease;
}
.album__retailers a:hover{color:var(--fg);border-color:var(--fg)}
@media (max-width:900px){
  .album__grid{grid-template-columns:1fr;gap:36px}
  .album__visual{order:-1;max-width:300px;width:100%}
}

/* ====== Bio (home) ====== */
.bio__grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,5vw,100px);align-items:center;
  max-width:1400px;margin:0 auto;width:100%;
}
.bio__copy{max-width:100%}
.bio__copy p{margin-bottom:16px;font-size:clamp(14px,1.05vw,16px);line-height:1.65;color:var(--fg-dim);font-weight:400;max-width:min(56ch,100%)}
.bio__copy .btn{margin-top:18px}
.bio__photo-wrap{
  aspect-ratio:3/4;overflow:hidden;position:relative;
  max-height:70vh;width:100%;justify-self:end;
}
.bio__photo{
  width:100%;height:100%;
  background:url('../img/kyler-photo-3.jpg') center/cover;
  transform:scale(1.06);transition:transform 14s linear;
}
.bio__photo-wrap.in .bio__photo{transform:scale(1)}
.bio__photo-wrap::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(5,5,5,.4),transparent 45%);
}
@media (max-width:900px){
  .bio__grid{grid-template-columns:1fr}
  .bio__photo-wrap{order:-1;max-height:50vh}
}

/* ====== Explore ====== */
.explore__inner{max-width:1400px;margin:0 auto;width:100%}
.explore__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:24px;flex-wrap:wrap}
.explore__head h2{max-width:14ch}
.explore__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:900px){.explore__grid{grid-template-columns:1fr}}
.tile{
  position:relative;display:block;aspect-ratio:16/10;overflow:hidden;background:#0a0a0a;
  min-height:260px;
}
.tile__bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.04);transition:transform 1.4s var(--ease-soft);
}
.tile:hover .tile__bg{transform:scale(1.12)}
.tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(5,5,5,.92) 0%,rgba(5,5,5,.15) 60%,rgba(5,5,5,.05) 100%);
}
.tile__caption{
  position:absolute;left:24px;right:24px;bottom:24px;z-index:2;
  display:flex;justify-content:space-between;align-items:flex-end;gap:16px;
}
.tile__title{font-weight:700;font-size:clamp(24px,2.6vw,40px);line-height:.95;letter-spacing:normal;text-transform:uppercase}
.tile__arrow{
  width:44px;height:44px;border:1px solid rgba(255,255,255,.55);border-radius:50%;
  display:grid;place-items:center;font-size:14px;
  transition:background .45s var(--ease),color .45s var(--ease),transform .55s var(--ease);
}
.tile:hover .tile__arrow{background:var(--fg);color:var(--bg);transform:rotate(-45deg)}

/* ====== Newsletter ====== */
.newsletter{background:var(--bg-2);text-align:center}
.newsletter__inner{max-width:680px;margin:0 auto;width:100%}
.newsletter h2{margin-bottom:20px;font-size:clamp(36px,5.5vw,84px);max-width:1100px;margin-left:auto;margin-right:auto}
.newsletter > .newsletter__inner > p{color:var(--fg-mute);margin-bottom:44px;font-size:13px;letter-spacing:normal;text-transform:uppercase;font-weight:400}
.newsletter form{display:flex;flex-direction:column;gap:18px}
.newsletter input[type=text],
.newsletter input[type=email]{
  width:100%;background:transparent;
  border:none;border-bottom:1px solid var(--line);
  padding:16px 0;font:inherit;color:var(--fg);font-size:16px;font-weight:400;
  transition:border-color .4s ease;
}
.newsletter input::placeholder{color:var(--fg-mute);text-transform:uppercase;letter-spacing:normal;font-size:12px;font-weight:400}
.newsletter input:focus{outline:none;border-color:var(--fg)}
.newsletter .row{display:grid;grid-template-columns:1fr 1fr;gap:32px}
@media (max-width:600px){.newsletter .row{grid-template-columns:1fr}}
.newsletter button{margin-top:30px;align-self:center}
.newsletter .w-form-done,.newsletter .w-form-fail{display:none;margin-top:24px;font-size:13px;text-transform:uppercase;font-weight:700}
.newsletter .w-form-done{color:var(--accent)}
.newsletter .w-form-fail{color:#ff7676}

/* ====== Footer ====== */
footer.snap{
  min-height:auto;padding:64px var(--pad-x) 36px;
  border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:32px;align-items:center;text-align:center;
  justify-content:flex-start;
}
.socials{display:flex;gap:18px}
.socials a{
  width:48px;height:48px;background:var(--fg);border-radius:50%;
  display:grid;place-items:center;
  transition:transform .4s var(--ease),background .4s ease;
}
.socials a:hover{transform:translateY(-3px);background:var(--accent)}
.socials img{width:22px;height:22px;object-fit:contain;filter:invert(1)}
.footer__legal{display:flex;gap:24px;font-size:12px;text-transform:uppercase;color:var(--fg-mute);font-weight:700}
.footer__legal a{transition:color .3s ease}
.footer__legal a:hover{color:var(--fg)}
.footer__copy{font-size:11px;text-transform:uppercase;color:var(--fg-mute);font-weight:400}

/* ====== Reveals ====== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.wipe-img{clip-path:inset(0 100% 0 0);transition:clip-path 1.6s var(--ease)}
.wipe-img.in{clip-path:inset(0)}
.stagger > *{transform:translateY(28px);opacity:0;transition:transform 1s var(--ease),opacity 1s ease}
.stagger.in > *:nth-child(1){transition-delay:.05s}
.stagger.in > *:nth-child(2){transition-delay:.15s}
.stagger.in > *:nth-child(3){transition-delay:.25s}
.stagger.in > *:nth-child(4){transition-delay:.35s}
.stagger.in > *:nth-child(5){transition-delay:.45s}
.stagger.in > *:nth-child(6){transition-delay:.55s}
.stagger.in > *:nth-child(7){transition-delay:.65s}
.stagger.in > *{transform:none;opacity:1}

::selection{background:var(--accent);color:#000}

/* ====== Mobile : pas de snap, sections en flow naturel ====== */
@media (max-width:760px){
  html.has-snap{scroll-snap-type:none}
  .snap{min-height:auto;padding-top:96px;padding-bottom:96px}
  .hero{height:100vh;min-height:100vh}
  footer.snap{min-height:auto}
  .nav{padding:18px var(--pad-x)}
}

/* ====== Page-specific helpers ====== */
.page-hero{
  min-height:100vh;
  padding:120px var(--pad-x) 80px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;isolation:isolate;
}
.page-hero__bg{
  position:absolute;inset:0;z-index:-2;
  background-position:center;background-size:cover;background-repeat:no-repeat;
  transform:scale(1.06);animation:slowZoom 24s ease-out forwards;
}
.page-hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to top,rgba(5,5,5,.75) 0%,rgba(5,5,5,.25) 60%,rgba(5,5,5,.55) 100%);
}
.page-hero h1{
  font-weight:700;text-transform:uppercase;letter-spacing:normal;
  font-size:clamp(48px,8vw,140px);line-height:.95;
  margin-bottom:24px;
}
.page-hero__sub{font-size:clamp(15px,1.2vw,18px);color:var(--fg-dim);max-width:min(54ch,100%);font-weight:400;line-height:1.65}

/* Long-form content with side photo */
.bio-page{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,120px);align-items:start;
  max-width:1400px;margin:0 auto;padding:120px var(--pad-x);width:100%;
}
.bio-page__prose{font-size:clamp(15px,1.1vw,17px);line-height:1.75;color:var(--fg-dim);font-weight:400;max-width:100%}
.bio-page__prose p{margin-bottom:24px}
.bio-page__prose .btn{margin-top:16px}
.bio-page__photo{
  aspect-ratio:3/4;overflow:hidden;
  background-size:cover;background-position:center;
  position:relative;width:100%;max-height:80vh;
}
.bio-page__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(5,5,5,.3),transparent 40%)}
@media (max-width:900px){
  .bio-page{grid-template-columns:1fr;gap:40px;padding:80px var(--pad-x)}
  .bio-page__photo{position:relative;top:auto;max-height:60vh;order:-1}
}

/* Legal text */
.prose{
  max-width:720px;margin:0 auto;
  font-size:clamp(15px,1.1vw,17px);line-height:1.75;color:var(--fg-dim);font-weight:400;
}
.prose p{margin-bottom:24px;max-width:100%}
.prose h1,.prose h2{color:var(--fg);font-weight:700;text-transform:uppercase}
.prose h2{font-size:clamp(20px,1.8vw,28px);margin:48px 0 18px}
.prose a{color:var(--accent);border-bottom:1px solid var(--line);transition:border-color .3s ease}
.prose a:hover{border-color:var(--accent)}
