/* ============================================================
   CUL DE SAC INDUSTRIE — landing styles
   palette: bone, off-black, dirty white, blood red as accent
   ============================================================ */

:root{
  --bg:        #0a0a0a;
  --bg-2:      #111111;
  --bg-3:      #161616;
  --ink:       #ebe6dd;     /* off-white / bone */
  --ink-soft:  #9c948a;
  --ink-faint: #4a4540;
  --rule:      #1c1c1c;
  --blood:     #c1302b;
  --max:       1440px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);}
body{
  font-family: "Inter", "Helvetica Neue", Arial, sans-serif;
  font-weight:300;
  font-size:15px;
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

/* ------- texture overlays ------- */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:80;opacity:.22;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.9 0 0 0 0 0.85 0 0 0 0 0.78 0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size:220px 220px;
}
.vignette{
  position:fixed;inset:0;pointer-events:none;z-index:79;
  background:radial-gradient(120% 90% at 50% 30%, transparent 55%, rgba(0,0,0,.65) 100%);
}
.scanlines{
  position:fixed;inset:0;pointer-events:none;z-index:78;opacity:.08;
  background-image:repeating-linear-gradient(
    to bottom, rgba(255,255,255,.4) 0 1px, transparent 1px 3px
  );
  mix-blend-mode:overlay;
}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar{
  position:sticky;top:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;
  border-bottom:1px solid var(--rule);
  background:rgba(10,10,10,.78);
  backdrop-filter:blur(6px);
  font-family:"Special Elite", "Courier New", monospace;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
}
.brand-mark{display:flex;align-items:center;gap:10px;}
.mark-circle{color:var(--blood);font-size:10px;line-height:1;animation:pulse 2.2s infinite;}
.topbar-meta{display:flex;gap:14px;color:var(--ink-soft);}
.topbar-meta .dot{opacity:.4;}
.topbar-cta{
  padding:7px 14px;border:1px solid var(--ink);border-radius:999px;
  transition:.25s ease;
}
.topbar-cta:hover{background:var(--ink);color:var(--bg);}
@keyframes pulse{0%,100%{opacity:.35;}50%{opacity:1;}}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding:60px 28px 0;
  border-bottom:1px solid var(--rule);
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:40px;
  max-width:var(--max);
  margin:0 auto;
  align-items:end;
  padding-bottom:60px;
}
.eyebrow{
  font-family:"Special Elite", monospace;
  font-size:11px;letter-spacing:.22em;
  color:var(--ink-soft);
  text-transform:uppercase;
  margin-bottom:24px;
}
.eyebrow.center{text-align:center;}

.hero-title{
  font-family:"Archivo Black", "Helvetica Neue", sans-serif;
  font-weight:900;
  font-size:clamp(58px, 11.5vw, 178px);
  line-height:.86;
  letter-spacing:-0.035em;
  text-transform:uppercase;
}
.hero-title .line{display:block;}
.hero-title .italic{
  font-family:"Caveat", cursive;
  font-weight:700;
  font-style:normal;
  font-size:.55em;
  letter-spacing:0;
  text-transform:lowercase;
  color:var(--ink-soft);
  padding-left:.4em;
  transform:translateY(-.05em);
}
.hero-title .strike{
  position:relative;
  display:inline-block;
}
.hero-title .strike::after{
  content:"";
  position:absolute;left:-2%;right:-2%;top:54%;
  height:.08em;background:var(--blood);
  transform:rotate(-3deg);
  box-shadow:0 0 14px rgba(193,48,43,.6);
}

.hero-sub{
  max-width:38ch;
  font-size:15px;
  color:var(--ink-soft);
  margin-top:30px;
  letter-spacing:.01em;
}

.hero-meta{
  display:flex;align-items:center;gap:14px;
  margin-top:28px;
  font-family:"Special Elite", monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);
}
.hero-meta .bar{flex:0 0 32px;height:1px;background:var(--ink-faint);}

.hero-art{
  position:relative;
  aspect-ratio: 4 / 5;
  overflow:hidden;
  border:1px solid var(--rule);
  filter:contrast(1.05) saturate(.85);
}
.hero-art img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.35) contrast(1.1);
  transition:transform 1.6s ease;
}
.hero-art:hover img{transform:scale(1.04);}
.art-tag{
  position:absolute;left:14px;bottom:12px;
  font-family:"Special Elite", monospace;font-size:10px;
  letter-spacing:.18em;color:var(--ink);
  background:rgba(10,10,10,.65);padding:4px 8px;
}

/* marquee */
.marquee{
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  overflow:hidden;
  background:var(--bg-2);
}
.marquee-track{
  display:flex;white-space:nowrap;
  font-family:"Archivo Black", sans-serif;
  text-transform:uppercase;
  font-size:clamp(28px, 4.2vw, 64px);
  letter-spacing:-0.02em;
  color:var(--ink);
  padding:10px 0;
  animation:scroll 38s linear infinite;
  opacity:.92;
}
.marquee-track span{padding:0 .35em;}
.marquee-track span:nth-child(odd){
  color:transparent;
  -webkit-text-stroke:1px var(--ink);
}
@keyframes scroll{
  from{transform:translateX(0);}
  to  {transform:translateX(-50%);}
}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap:60px;
  align-items:end;
  padding:120px 28px;
  max-width:var(--max);margin:0 auto;
  border-bottom:1px solid var(--rule);
}
.manifesto-grid .m-line{
  font-family:"Archivo Black", sans-serif;
  font-size:clamp(50px, 9vw, 140px);
  line-height:.9;
  text-transform:uppercase;
  letter-spacing:-0.03em;
}
.manifesto-grid .m-line.italic{
  font-family:"Caveat", cursive;
  font-weight:700;
  color:var(--ink-soft);
  text-transform:lowercase;
  font-size:clamp(60px, 8vw, 130px);
  padding-left:.7em;
}
.manifesto-side p{
  max-width:36ch;
  color:var(--ink-soft);
  font-size:15px;
}
.manifesto-side .caveat{
  font-family:"Caveat", cursive;
  color:var(--ink);
  font-size:24px;
  margin-top:16px;
}

/* ============================================================
   DROP TEASER
   ============================================================ */
.drop{
  padding:140px 28px;
  border-bottom:1px solid var(--rule);
  text-align:center;
  position:relative;
  background:
    radial-gradient(80% 60% at 50% 50%, rgba(193,48,43,.06), transparent 70%),
    var(--bg);
}
.drop-head{margin-bottom:40px;}
.drop-block{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;
}
.drop-label{
  font-family:"Special Elite",monospace;
  font-size:13px;letter-spacing:.32em;color:var(--ink-soft);
  text-transform:uppercase;
}
.drop-num{
  font-family:"Archivo Black",sans-serif;
  font-size:clamp(140px, 22vw, 320px);
  line-height:.85;
  letter-spacing:-0.04em;
  color:var(--ink);
  text-shadow:0 0 60px rgba(193,48,43,.15);
}
.drop-status{
  font-family:"Caveat",cursive;
  font-size:clamp(40px, 5vw, 64px);
  color:var(--ink-soft);
  margin-top:8px;
}
.drop-meta{
  display:flex;align-items:center;justify-content:center;gap:18px;
  margin-top:50px;
  font-family:"Special Elite",monospace;
  font-size:12px;letter-spacing:.22em;color:var(--ink-soft);
  text-transform:uppercase;
  flex-wrap:wrap;
}
.drop-meta em{font-style:normal;color:var(--blood);font-family:"Archivo Black",sans-serif;}
.drop-meta .bar{flex:0 0 28px;height:1px;background:var(--ink-faint);}

/* ============================================================
   INTERLUDE (full-bleed editorial)
   ============================================================ */
.interlude{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:0;
  border-bottom:1px solid var(--rule);
  background:#070707;
}
.interlude.alt{grid-template-columns: .95fr 1.05fr;}
.interlude-img{
  width:100%;
  height:min(82vh, 760px);
  object-fit:cover;
  filter:grayscale(.4) contrast(1.1) brightness(.92);
}
.interlude-text{
  display:flex;flex-direction:column;justify-content:center;
  padding:60px 56px;
  border-left:1px solid var(--rule);
}
.interlude.alt .interlude-text{
  border-left:none;border-right:1px solid var(--rule);
  align-items:flex-end;text-align:right;
}
.big-quote{
  font-family:"Archivo Black",sans-serif;
  font-size:clamp(54px, 8vw, 124px);
  line-height:.92;
  text-transform:uppercase;
  letter-spacing:-0.025em;
}
.big-quote em{
  font-family:"Caveat",cursive;
  font-style:normal;
  font-weight:700;
  color:var(--ink-soft);
  text-transform:lowercase;
  display:inline-block;
  transform:translateY(-.08em);
}
.byline{
  margin-top:24px;
  font-family:"Special Elite",monospace;
  font-size:11px;letter-spacing:.2em;color:var(--ink-soft);
  text-transform:uppercase;
}

/* ============================================================
   DOSSIER — single statement
   ============================================================ */
.dossier{
  padding:140px 28px;
  text-align:center;
  border-bottom:1px solid var(--rule);
}
.dossier-statement{
  font-family:"Archivo Black",sans-serif;
  font-size:clamp(32px, 4.6vw, 64px);
  line-height:1.05;
  text-transform:uppercase;
  letter-spacing:-0.025em;
  max-width:18ch;
  margin:24px auto 0;
}
.caveat-mid{
  display:inline-block;
  font-family:"Caveat",cursive;
  font-weight:700;
  text-transform:lowercase;
  font-size:1.1em;
  color:var(--ink-soft);
  letter-spacing:0;
  transform:translateY(-.05em);
}

/* ============================================================
   ACCESS / EMAIL
   ============================================================ */
.access{
  padding:140px 28px;
  background:
    radial-gradient(60% 60% at 50% 30%, rgba(193,48,43,.10), transparent 70%),
    var(--bg);
  border-bottom:1px solid var(--rule);
}
.access-frame{
  position:relative;
  max-width:780px;margin:0 auto;
  padding:60px 48px 70px;
  border:1px solid var(--ink-faint);
  background:rgba(8,8,8,.6);
  text-align:center;
}
.access-frame::before,
.access-frame::after{
  content:"";position:absolute;
  width:24px;height:24px;
  border:1px solid var(--ink);
}
.access-frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none;}
.access-frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none;}

.access-title{
  font-family:"Archivo Black",sans-serif;
  font-size:clamp(50px, 7vw, 96px);
  line-height:.92;
  text-transform:uppercase;
  letter-spacing:-0.025em;
  margin-top:8px;
}
.caveat-big{
  display:block;
  font-family:"Caveat",cursive;
  font-weight:700;
  font-size:1.05em;
  color:var(--ink-soft);
  text-transform:lowercase;
  letter-spacing:0;
}
.access-sub{
  max-width:44ch;margin:24px auto 36px;
  color:var(--ink-soft);
}

.access-form{display:block;}
.access-form[hidden]{display:none;}
.access-success[hidden]{display:none;}
.form-row{
  display:flex;border:1px solid var(--ink);
  background:#000;
}
.form-row input[type="email"]{
  flex:1;background:transparent;color:var(--ink);
  border:none;outline:none;
  padding:18px 18px;
  font-family:"Special Elite",monospace;
  font-size:13px;letter-spacing:.12em;
}
.form-row input::placeholder{color:var(--ink-faint);}
.form-row button{
  background:var(--ink);color:var(--bg);
  border:none;cursor:pointer;
  padding:0 26px;
  font-family:"Archivo Black",sans-serif;
  font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;
  transition:.25s ease;
}
.form-row button:hover{background:var(--blood);color:var(--ink);}
.check{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:16px;
  font-family:"Special Elite",monospace;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);
}
.check input{accent-color:var(--blood);}
.form-note{
  margin-top:18px;
  font-family:"Special Elite",monospace;
  font-size:10.5px;letter-spacing:.18em;color:var(--ink-faint);
  text-transform:uppercase;
}
.form-counter{
  margin-top:10px;
  font-family:"Special Elite",monospace;
  font-size:11px;letter-spacing:.22em;
  color:var(--ink);
  text-transform:uppercase;
}
.form-counter .dim{color:var(--ink-faint);}
.form-error{
  margin-top:14px;
  font-family:"Special Elite",monospace;
  font-size:11px;letter-spacing:.18em;
  color:var(--blood);text-transform:uppercase;min-height:14px;
}
.form-row button:disabled{opacity:.7;cursor:wait;}

.access-success{
  text-align:center;padding:12px 0;
  animation:fade-in .6s ease both;
}
.access-success .ok-1{
  font-family:"Archivo Black",sans-serif;
  font-size:36px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--blood);
}
.access-success .ok-2{
  font-family:"Special Elite",monospace;
  font-size:13px;letter-spacing:.2em;color:var(--ink-soft);
  text-transform:uppercase;margin-top:8px;
}
.access-success .ok-3{
  font-family:"Caveat",cursive;
  font-size:30px;color:var(--ink);margin-top:18px;
}

.medallion{
  margin-top:46px;
  display:flex;justify-content:center;
}
.medallion img{
  width:140px;height:140px;border-radius:50%;
  object-fit:cover;
  filter:grayscale(.3) contrast(1.1);
  opacity:.85;
  border:1px solid var(--ink-faint);
}
@keyframes fade-in{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  padding:48px 28px 24px;
  background:#060606;
  font-family:"Special Elite",monospace;
  font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft);
}
.footer-row{
  display:flex;justify-content:space-between;align-items:end;
  gap:30px;flex-wrap:wrap;
  max-width:var(--max);margin:0 auto;
}
.drop-date{
  font-family:"Archivo Black",sans-serif;
  font-size:46px;letter-spacing:-0.02em;color:var(--ink);
  text-transform:uppercase;
}
.footer-mid p{color:var(--ink);}
.footer-mid .small{color:var(--ink-soft);font-size:10.5px;}
.footer-right{display:flex;gap:18px;}
.footer-right a{color:var(--ink);}
.footer-right a:hover{color:var(--blood);}
.legal{
  max-width:var(--max);margin:30px auto 0;
  padding-top:18px;border-top:1px solid var(--rule);
  font-size:10px;color:var(--ink-faint);
  text-align:center;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px){
  .hero-grid{grid-template-columns:1fr;gap:30px;}
  .hero-art{aspect-ratio:3/4;}
  .manifesto{grid-template-columns:1fr;gap:40px;}
  .interlude, .interlude.alt{grid-template-columns:1fr;}
  .interlude-text{border-left:none;border-top:1px solid var(--rule);}
  .interlude.alt .interlude-text{border-right:none;align-items:flex-start;text-align:left;}
}
@media (max-width: 640px){
  .topbar-meta{display:none;}
  .topbar{padding:12px 16px;font-size:10px;}
  .hero{padding:36px 16px 0;}
  .hero-grid{padding-bottom:36px;gap:24px;}
  .marquee-track{font-size:30px;}
  .manifesto, .drop, .dossier, .access{padding:64px 16px;}
  .interlude-text{padding:36px 20px;}
  .access-frame{padding:36px 20px 44px;}
  .form-row{flex-direction:column;}
  .form-row button{padding:16px 0;}
  .drop-date{font-size:34px;}
  .footer-row{flex-direction:column;align-items:flex-start;gap:20px;}
}
