/* Frame 36 Film Lab — analog zine */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=Archivo:ital,wght@0,400;0,600;0,800;1,500&family=Space+Mono:ital,wght@0,400;0,700;1,400&display=swap');

:root {
  --paper:   #f1ece0;
  --paper-2: #e8e1d2;
  --ink:     #16140f;
  --ink-2:   #3a352c;
  --red:     #e0381f;
  --yellow:  #f4be1b;
  --cyan:    #1fa6b8;
  --line:    rgba(22,20,15,.16);
  --maxw: 1120px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: 'Archivo', system-ui, sans-serif;
  font-size: 18px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* grain overlay */
body::after {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: .055;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

a { color: inherit; }
img { max-width: 100%; display: block; }

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

/* ---- type ---- */
.mono { font-family: 'Space Mono', monospace; }
.eyebrow {
  font-family: 'Space Mono', monospace;
  font-size: 12px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--ink-2);
}
h1, h2, h3 { font-family: 'Anton', 'Archivo', sans-serif; font-weight: 400; line-height: .96; letter-spacing: .005em; text-transform: uppercase; margin: 0; }
h1 { font-size: clamp(54px, 11vw, 150px); }
h2 { font-size: clamp(34px, 6vw, 68px); }
h3 { font-size: clamp(20px, 3vw, 30px); }
p { margin: 0 0 1.1em; max-width: 62ch; }
.lead { font-size: clamp(19px, 2.4vw, 24px); line-height: 1.5; }

/* ---- film strip / sprocket motif ---- */
/* one clean continuous film edge: black bar, evenly spaced rounded
   sprocket holes aligned top + bottom. single tiling SVG, no jitter. */
.filmstrip {
  height: 30px;
  background-color: var(--ink);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='30'%3E%3Crect width='34' height='30' fill='%2316140f'/%3E%3Crect x='9' y='5' width='16' height='7' rx='2.5' fill='%23f1ece0'/%3E%3Crect x='9' y='18' width='16' height='7' rx='2.5' fill='%23f1ece0'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-position: center;
  background-size: 34px 30px;
}

/* ---- nav ---- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: var(--paper);
  border-bottom: 2px solid var(--ink);
}
.nav .wrap { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; padding-bottom: 14px; }
.brand { display: flex; align-items: baseline; gap: 8px; text-decoration: none; }
.brand b { font-family: 'Anton', sans-serif; font-size: 26px; letter-spacing: .03em; text-transform: uppercase; }
.brand .tick {
  font-family: 'Space Mono', monospace; font-weight: 700; font-size: 13px;
  background: var(--red); color: var(--paper); padding: 2px 7px; border-radius: 2px;
  transform: rotate(-3deg);
}
.nav .cta { font-family: 'Space Mono', monospace; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; text-decoration: none; border: 2px solid var(--ink); padding: 8px 14px; background: var(--yellow); border-radius: 2px; }
.nav .cta:hover { background: var(--ink); color: var(--paper); }

/* ---- hero ---- */
.hero { padding: 70px 0 50px; position: relative; }
.hero .badge {
  display: inline-block; font-family: 'Space Mono', monospace; font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em;
  background: var(--ink); color: var(--paper); padding: 7px 13px; transform: rotate(-1.5deg); margin-bottom: 26px;
}
.hero h1 { margin-bottom: 8px; }
.hero h1 .out { -webkit-text-stroke: 2px var(--ink); color: transparent; }
.hero .counter { font-family: 'Space Mono', monospace; color: var(--red); font-size: clamp(54px,11vw,150px); }
.hero .sub { margin-top: 26px; max-width: 54ch; }
.hero .place { font-family:'Space Mono',monospace; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-2); margin-bottom:26px; }

/* ---- waitlist form ---- */
.waitlist {
  background: var(--ink); color: var(--paper);
  border-radius: 4px; padding: 30px; margin-top: 38px;
  position: relative; box-shadow: 10px 10px 0 var(--red);
  max-width: 620px;
}
.waitlist h3 { color: var(--paper); margin-bottom: 6px; }
.waitlist p { color: rgba(241,236,224,.7); font-size: 15px; margin-bottom: 18px; }
.wl-row { display: flex; gap: 10px; flex-wrap: wrap; }
.wl-row input[type=email], .wl-row input[type=text] {
  flex: 1 1 240px; min-width: 0;
  font-family: 'Space Mono', monospace; font-size: 15px;
  padding: 14px 16px; border: 2px solid var(--paper); background: transparent; color: var(--paper);
  border-radius: 2px;
}
.wl-row input::placeholder { color: rgba(241,236,224,.5); }
.wl-row button {
  font-family: 'Space Mono', monospace; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  font-size: 14px; padding: 14px 22px; border: 2px solid var(--yellow); background: var(--yellow); color: var(--ink);
  border-radius: 2px; cursor: pointer;
}
.wl-row button:hover { background: var(--red); border-color: var(--red); color: var(--paper); }
.wl-note { font-family:'Space Mono',monospace; font-size: 12px; color: rgba(241,236,224,.55); margin: 14px 0 0; }
.wl-ok { display:none; font-family:'Space Mono',monospace; color: var(--yellow); margin-top:14px; }

/* ---- sections ---- */
section { padding: 72px 0; }
.section-tag { display:flex; align-items:center; gap:14px; margin-bottom: 30px; }
.section-tag .num { font-family:'Space Mono',monospace; font-size:13px; font-weight:700; background:var(--red); color:var(--paper); padding:3px 8px; }
.section-tag .ln { flex:1; height:2px; background:var(--ink); }

/* problem callout */
.problem { background: var(--ink); color: var(--paper); }
.problem h2 { color: var(--paper); max-width: 16ch; }
.problem .lead { color: rgba(241,236,224,.78); }
.stat-row { display:grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 44px; }
.stat { border-top: 2px solid var(--red); padding-top: 14px; }
.stat b { font-family:'Anton',sans-serif; font-size: clamp(34px,5vw,56px); display:block; line-height:1; }
.stat span { font-family:'Space Mono',monospace; font-size:13px; color: rgba(241,236,224,.7); text-transform:uppercase; letter-spacing:.06em; }

/* services grid */
.svc-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.svc {
  background: var(--paper-2); border: 2px solid var(--ink); border-radius: 4px; padding: 22px;
  position: relative;
}
.svc:nth-child(3n+1){ transform: rotate(-.6deg); }
.svc:nth-child(3n+2){ transform: rotate(.5deg); }
.svc .tape {
  position:absolute; top:-12px; left:18px; font-family:'Space Mono',monospace; font-size:11px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; background:var(--yellow); color:var(--ink); padding:3px 9px; transform:rotate(-3deg);
}
.svc h3 { font-size: 22px; margin: 8px 0 6px; }
.svc p { font-size: 15px; margin: 0; color: var(--ink-2); }

/* steps */
.steps { display:grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.step .n { font-family:'Anton',sans-serif; font-size: 64px; color: var(--red); line-height:1; }
.step h3 { font-size: 22px; margin: 6px 0 8px; }
.step p { font-size: 15px; color: var(--ink-2); }

/* about */
.about { background: var(--yellow); }
.about .wrap { display:grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items:center; }
.about h2 { max-width: 12ch; }
.about p { color: var(--ink); }
.about .sig { font-family:'Space Mono',monospace; font-size:13px; letter-spacing:.04em; }

/* cities footer */
.cities { background: var(--ink); color: var(--paper); }
.cities h2 { color: var(--paper); }
.city-links { display:grid; grid-template-columns: repeat(3,1fr); gap: 10px 24px; margin-top: 30px; }
.city-links a {
  font-family:'Space Mono',monospace; font-size:14px; text-decoration:none; color: var(--paper);
  border-bottom: 1px solid rgba(241,236,224,.25); padding: 9px 0; display:flex; justify-content:space-between;
}
.city-links a:hover { color: var(--yellow); }
.city-links a span { color: rgba(241,236,224,.4); }

/* footer */
.foot { background: var(--paper); border-top: 2px solid var(--ink); padding: 34px 0; }
.foot .wrap { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; }
.foot .mono { font-size: 12px; color: var(--ink-2); }

/* city page hero variant */
.cityhero { padding: 64px 0 40px; }
.cityhero .crumb { font-family:'Space Mono',monospace; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); margin-bottom:22px; }
.cityhero h1 { font-size: clamp(40px,8vw,104px); }
.cityhero h1 em { font-style:normal; color: var(--red); }
.prose { max-width: 64ch; }
.prose p { color: var(--ink-2); }

/* responsive */
@media (max-width: 820px) {
  .svc-grid, .steps, .stat-row, .city-links { grid-template-columns: 1fr 1fr; }
  .about .wrap { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 540px) {
  body { font-size: 17px; }
  .svc-grid, .steps, .stat-row, .city-links { grid-template-columns: 1fr; }
  .nav .cta { display:none; }
  section { padding: 54px 0; }
}
