/* ============================================================
   LOUDHOUSE risograph poster art landing page
   Riso inks, halftone, grain, overprint.
   ============================================================ */

:root{
  /* riso ink palette */
  --paper:   #f3ead3;   /* warm cream stock */
  --ink:     #181410;   /* near-black overprint */
  --pink:    #ff48b0;   /* fluorescent pink */
  --orange:  #ff5722;   /* riso orange */
  --blue:    #2438d8;   /* federal blue */
  --purple:  #7b2ff2;   /* purple */
  --teal:    #00a98f;   /* green/teal */
  --yellow:  #ffd23f;   /* sunshine */

  --shadow: 6px 6px 0 var(--ink);
  --maxw: 1180px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:"Space Grotesk", system-ui, sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  overflow-x:hidden;
  position:relative;
}

/* paper grain overlay: sits over everything, multiplies in */
body::after{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:9999;
  opacity:.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
}

/* ---------- typography ---------- */
h1,h2,h3,.display{
  font-family:"Bricolage Grotesque", sans-serif;
  font-weight:800;
  line-height:.94;
  letter-spacing:-.02em;
  text-transform:uppercase;
}
.eyebrow{
  font-weight:700; text-transform:uppercase; letter-spacing:.18em;
  font-size:.78rem;
}

a{ color:inherit; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }

/* halftone util: dotted ink screen */
.halftone{
  background-image:radial-gradient(var(--ink) 28%, transparent 29%);
  background-size:9px 9px;
}

/* sticker badge */
.sticker{
  display:inline-block;
  font-family:"Bricolage Grotesque",sans-serif;
  font-weight:800; text-transform:uppercase;
  border:3px solid var(--ink);
  padding:.45em .8em;
  background:var(--yellow);
  box-shadow:var(--shadow);
  letter-spacing:-.01em;
  line-height:1;
}

/* buttons */
.btn{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:"Bricolage Grotesque",sans-serif;
  font-weight:800; text-transform:uppercase; letter-spacing:-.01em;
  font-size:1.05rem;
  padding:.8em 1.4em;
  border:3px solid var(--ink);
  background:var(--pink); color:var(--paper);
  box-shadow:var(--shadow);
  cursor:pointer;
  text-decoration:none;
  transition:transform .08s ease, box-shadow .08s ease;
}
.btn:hover{ transform:translate(-2px,-2px); box-shadow:8px 8px 0 var(--ink); }
.btn:active{ transform:translate(4px,4px); box-shadow:2px 2px 0 var(--ink); }
.btn--blue{ background:var(--blue); }
.btn--ghost{ background:var(--paper); color:var(--ink); }

/* ============================================================
   NAV
   ============================================================ */
nav{
  position:sticky; top:0; z-index:100;
  background:var(--paper);
  border-bottom:3px solid var(--ink);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px;
  max-width:1320px; margin:0 auto;
}
.logo{
  font-family:"Bricolage Grotesque",sans-serif;
  font-weight:800; font-size:1.6rem; letter-spacing:-.04em;
  text-transform:uppercase; text-decoration:none;
  display:flex; align-items:center; gap:.4em;
}
.logo .dot{
  width:.7em; height:.7em; border-radius:50%;
  background:var(--orange); border:3px solid var(--ink);
  display:inline-block;
}
.nav-links{ display:flex; align-items:center; gap:28px; }
.nav-links a{ text-decoration:none; font-weight:600; font-size:.95rem; }
.nav-links a:not(.btn):hover{ text-decoration:underline; text-decoration-thickness:3px; text-underline-offset:4px; }
.nav-toggle{ display:none; background:none; border:none; font-size:1.6rem; cursor:pointer; }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  background:var(--ink); color:var(--paper);
  overflow:hidden; white-space:nowrap;
  border-bottom:3px solid var(--ink);
  padding:9px 0;
}
.marquee__track{
  display:inline-block;
  animation:scroll 112s linear infinite;
  font-family:"Bricolage Grotesque",sans-serif;
  font-weight:800; text-transform:uppercase; letter-spacing:.02em;
  font-size:1rem;
}
.marquee__track span{ margin:0 .6em; }
.marquee__track .hl{ color:var(--yellow); }
@keyframes scroll{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding:72px 0 90px;
  overflow:hidden;
}
.hero .wrap{ position:relative; z-index:2; }
.hero h1{
  font-size:clamp(3rem, 11vw, 9rem);
  max-width:14ch;
}
/* overprint misregistration on the headline */
.hero h1 .reg{
  position:relative; display:inline-block; color:var(--ink);
}
.hero h1 .reg::before{
  content:attr(data-t);
  position:absolute; left:-.04em; top:.03em;
  color:var(--pink); z-index:-1;
  mix-blend-mode:multiply;
}
.hero h1 .knock{
  color:var(--orange);
  -webkit-text-stroke:3px var(--ink);
  paint-order:stroke fill;
}
.hero p.lead{
  font-size:clamp(1.1rem,2.2vw,1.5rem);
  max-width:46ch; margin:28px 0 0; font-weight:500;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:16px; margin-top:36px; align-items:center; }
.pay-tag{
  font-family:"Bricolage Grotesque",sans-serif; font-weight:800;
  font-size:1rem; text-transform:uppercase;
}
.pay-tag b{ font-size:1.5rem; color:var(--blue); }

/* decorative riso blobs: multiply so overlaps darken like overprint */
.blob{ position:absolute; border-radius:50%; mix-blend-mode:multiply; z-index:1; filter:blur(.5px); }
.blob--1{ width:340px;height:340px; background:var(--orange); top:-60px; right:4%; }
.blob--2{ width:260px;height:260px; background:var(--purple); top:120px; right:18%; }
.blob--3{ width:180px;height:180px; background:var(--teal);  top:280px; right:2%; }
.hero .halftone-patch{
  position:absolute; width:240px; height:240px; bottom:-40px; left:-40px;
  color:var(--blue); opacity:.5; z-index:1;
  background-image:radial-gradient(var(--blue) 30%, transparent 31%);
  background-size:14px 14px; mix-blend-mode:multiply;
  transform:rotate(-8deg);
}
.float-sticker{
  position:absolute; z-index:3; transform:rotate(8deg);
  top:80px; right:8%;
}
.float-sticker.two{ top:auto; bottom:60px; right:auto; left:6%; transform:rotate(-7deg); background:var(--teal); color:var(--paper); }

/* ============================================================
   GENERIC SECTION
   ============================================================ */
section{ position:relative; }
.band{ border-top:3px solid var(--ink); border-bottom:3px solid var(--ink); }
.pad{ padding:80px 0; }
.section-head{ max-width:30ch; margin-bottom:48px; }
.section-head h2{ font-size:clamp(2rem,6vw,4rem); }
.section-head p{ font-size:1.15rem; margin-top:18px; max-width:52ch; font-weight:500; }

/* ============================================================
   "WHY YOU" cards
   ============================================================ */
.who{ background:var(--blue); color:var(--paper); }
.who .sticker{ background:var(--yellow); color:var(--ink); }
.cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:22px; }
.card{
  background:var(--paper); color:var(--ink);
  border:3px solid var(--ink); box-shadow:var(--shadow);
  padding:26px; position:relative;
}
.card .num{
  font-family:"Bricolage Grotesque",sans-serif; font-weight:800;
  font-size:2.4rem; line-height:1; color:var(--pink);
  -webkit-text-stroke:1.5px var(--ink);
}
.card h3{ font-size:1.4rem; margin:10px 0 8px; }
.card p{ font-size:1rem; }

/* ============================================================
   ISSUES: pick what you believe in
   ============================================================ */
.issues{ background:var(--paper); }
.issue-cloud{ display:flex; flex-wrap:wrap; gap:14px; margin-top:8px; }
.chip{
  font-family:"Bricolage Grotesque",sans-serif; font-weight:800;
  text-transform:uppercase; font-size:clamp(1rem,2vw,1.5rem);
  border:3px solid var(--ink); padding:.4em .8em;
  background:var(--paper); box-shadow:4px 4px 0 var(--ink);
  cursor:default; transition:transform .1s, background .1s, color .1s;
  line-height:1;
}
.chip:hover{ transform:rotate(-2deg) translateY(-3px); }
.chip:nth-child(3n)  { background:var(--pink);   color:var(--paper); }
.chip:nth-child(3n+1){ background:var(--teal);   color:var(--paper); }
.chip:nth-child(4n)  { background:var(--yellow); color:var(--ink);   }
.chip:nth-child(5n)  { background:var(--purple); color:var(--paper); }
.issues .fineprint{ margin-top:28px; font-weight:500; max-width:54ch; font-size:1.05rem; }

/* ============================================================
   PAY
   ============================================================ */
.pay{ background:var(--ink); color:var(--paper); overflow:hidden; }
.pay-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center; }
.pay-stack{ display:flex; flex-direction:column; gap:0; }
.pay-row{
  border:3px solid var(--paper);
  padding:26px 28px;
  background:transparent;
}
.pay-row + .pay-row{ border-top:none; }
.pay-row .big{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:clamp(2.4rem,8vw,4.5rem); line-height:.9; }
.pay-row.base .big{ color:var(--yellow); }
.pay-row.bonus .big{ color:var(--pink); }
.pay-row.total{ background:var(--orange); color:var(--ink); border-color:var(--paper); }
.pay-row.total .big{ color:var(--ink); }
.pay-row small{ display:block; font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:.78rem; opacity:.85; margin-bottom:6px; }
.pay-row p{ margin-top:8px; font-size:.98rem; max-width:34ch; }
.pay-copy h2{ font-size:clamp(2rem,6vw,3.6rem); }
.pay-copy p{ margin-top:18px; font-size:1.1rem; font-weight:500; }
.pay-copy .sticker{ margin-top:24px; }

/* ============================================================
   HOW IT WORKS: stepped
   ============================================================ */
.how{ background:var(--purple); color:var(--paper); }
.steps{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:0; border:3px solid var(--ink); background:var(--ink); }
.step{ background:var(--paper); color:var(--ink); padding:30px; }
.step .num{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:3rem; line-height:1; color:var(--orange); -webkit-text-stroke:1.5px var(--ink); }
.step h3{ font-size:1.35rem; margin:6px 0 8px; }
.step p{ font-size:.98rem; }

/* ============================================================
   THE CREW / structure
   ============================================================ */
.crew{ background:var(--paper); }
.tiers{ display:grid; grid-template-columns:1fr; gap:18px; max-width:780px; margin:0 auto; }
.tier{
  border:3px solid var(--ink); box-shadow:var(--shadow);
  padding:26px 28px; display:flex; gap:22px; align-items:flex-start;
  background:var(--paper);
}
.tier .icon{
  flex:0 0 auto; width:58px; height:58px; border:3px solid var(--ink);
  border-radius:50%; display:grid; place-items:center;
  font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:1.5rem;
}
.tier.t1 .icon{ background:var(--pink); color:var(--paper); }
.tier.t2 .icon{ background:var(--teal); color:var(--paper); }
.tier.t3 .icon{ background:var(--yellow); color:var(--ink); }
.tier h3{ font-size:1.5rem; }
.tier p{ font-size:1rem; margin-top:6px; max-width:52ch; }
.tier .tag{ font-weight:700; text-transform:uppercase; font-size:.72rem; letter-spacing:.14em; display:block; margin-bottom:2px; }
.crew-connector{ display:flex; flex-direction:column; align-items:center; gap:4px; padding:16px 0; font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:1.5rem; color:var(--ink); line-height:1; }
.crew-connector .arr{ font-size:1.6rem; line-height:1; }

/* ============================================================
   CAPTAINS hiring callout
   ============================================================ */
.captains{ background:var(--teal); color:var(--paper); }
.captains .inner{ display:grid; grid-template-columns:1.2fr .8fr; gap:40px; align-items:center; }
.captains h2{ font-size:clamp(2rem,6vw,3.6rem); }
.captains p{ font-size:1.12rem; margin-top:18px; font-weight:500; max-width:50ch; }
.captains .sticker{ background:var(--ink); color:var(--paper); }

/* ============================================================
   APPLY / FORM
   ============================================================ */
.apply{ background:var(--orange); color:var(--ink); }
.apply h2{ font-size:clamp(2.4rem,8vw,5rem); max-width:14ch; }
.apply p.lead{ font-size:1.2rem; font-weight:500; margin-top:18px; max-width:48ch; }
.form-card{
  background:var(--paper); border:3px solid var(--ink); box-shadow:var(--shadow);
  padding:32px; margin-top:8px;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
label{ display:block; font-weight:700; text-transform:uppercase; letter-spacing:.06em; font-size:.78rem; margin:14px 0 6px; }
input,select,textarea{
  width:100%; font-family:inherit; font-size:1rem;
  padding:12px 14px; border:3px solid var(--ink); background:var(--paper);
  color:var(--ink);
}
input:focus,select:focus,textarea:focus{ outline:none; box-shadow:4px 4px 0 var(--ink); }
.form-note{ font-size:.85rem; margin-top:16px; opacity:.85; }
.apply-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; align-items:start; }
.success{ display:none; background:var(--teal); color:var(--paper); border:3px solid var(--ink); padding:24px; margin-top:18px; font-weight:600; box-shadow:var(--shadow); }

/* ============================================================
   FOOTER
   ============================================================ */
footer{ background:var(--ink); color:var(--paper); padding:56px 0 40px; }
.foot-inner{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:30px; align-items:flex-start; }
.foot-logo{ font-family:"Bricolage Grotesque"; font-weight:800; font-size:2rem; text-transform:uppercase; letter-spacing:-.04em; }
.foot-links{ display:flex; gap:40px; flex-wrap:wrap; }
.foot-col h4{ font-size:.8rem; text-transform:uppercase; letter-spacing:.14em; color:var(--yellow); margin-bottom:12px; }
.foot-col a{ display:block; text-decoration:none; font-weight:500; margin-bottom:8px; opacity:.85; }
.foot-col a:hover{ opacity:1; text-decoration:underline; }
.foot-bottom{ margin-top:40px; padding-top:20px; border-top:1px solid rgba(243,234,211,.25); font-size:.82rem; opacity:.7; display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:860px){
  .nav-links{
    position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0;
    background:var(--paper); border-bottom:3px solid var(--ink);
    transform:translateY(-120%); transition:transform .25s ease; padding:8px 0;
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-links a{ padding:14px 24px; width:100%; border-top:1px solid rgba(0,0,0,.1); }
  .nav-links .btn{ margin:14px 24px; }
  .nav-toggle{ display:block; }
  .pay-grid, .captains .inner, .apply-grid{ grid-template-columns:1fr; gap:32px; }
  .form-row{ grid-template-columns:1fr; }
  .float-sticker, .blob--2, .blob--3{ display:none; }
}
@media(prefers-reduced-motion:reduce){
  .marquee__track{ animation:none; }
  *{ scroll-behavior:auto; }
}
