/* =======================================================
   IAN GREENBERG vs. 70 HOT DOGS
   Aesthetic: competitive-eating poster — Coney Island
   boardwalk meets ESPN broadcast. Mustard & ketchup.
   ======================================================= */

:root {
  --cream:        #FCEFCF;
  --paper:        #FFF8E7;
  --bun:          #F4D89E;
  --mustard:      #F2A900;
  --mustard-deep: #C9870A;
  --ketchup:      #CE1126;
  --ketchup-deep: #97091B;
  --ink:          #241403;
  --char:         #2B1C09;
  --relish:       #5E7E1E;

  --shadow:  6px 6px 0 var(--ink);
  --shadow-sm: 4px 4px 0 var(--ink);

  --display: 'Anton', 'Arial Narrow', sans-serif;
  --serif:   'Fraunces', Georgia, serif;
  --body:    'Libre Franklin', system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--body);
  color: var(--ink);
  background-color: var(--cream);
  background-image:
    repeating-linear-gradient(45deg,
      transparent 0 26px,
      rgba(36,20,3,.035) 26px 28px);
  line-height: 1.55;
  overflow-x: hidden;
}

/* film grain overlay */
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='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
}

::selection { background: var(--ketchup); color: var(--paper); }

/* ===== BREAKING-NEWS TICKER ===== */
.ticker {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: stretch;
  background: var(--ketchup);
  border-bottom: 3px solid var(--ink);
  overflow: hidden;
}
.ticker__flag {
  position: relative;
  z-index: 2;
  flex: none;
  display: flex;
  align-items: center;
  padding: 0 18px;
  background: var(--ink);
  color: var(--mustard);
  font-family: var(--display);
  font-size: 15px;
  letter-spacing: .12em;
  text-transform: uppercase;
  box-shadow: 5px 0 9px rgba(0,0,0,.5);
}
.ticker__track {
  position: relative;
  z-index: 1;
  display: flex;
  white-space: nowrap;
  animation: marquee 42s linear infinite;
}
.ticker__track span {
  padding: 9px 0;
  color: var(--paper);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.ticker__track span::before {
  content: "🌭";
  margin: 0 26px;
  filter: grayscale(.2);
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ===== LAYOUT ===== */
.wrap {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 22px 60px;
}

.section-h {
  font-family: var(--display);
  font-size: clamp(30px, 6vw, 54px);
  line-height: .98;
  text-transform: uppercase;
  letter-spacing: .005em;
  margin-bottom: 18px;
}
.section-h--center { text-align: center; }
.section-h::after {
  content: "";
  display: block;
  width: 90px;
  height: 7px;
  margin-top: 12px;
  background: var(--ketchup);
  border: 2px solid var(--ink);
}
.section-h--center::after { margin-left: auto; margin-right: auto; }

/* ===== HERO ===== */
.hero {
  text-align: center;
  padding: 38px 0 30px;
}
.hero__main {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  gap: clamp(26px, 4vw, 46px);
  align-items: start;
  margin-top: 34px;
  text-align: left;
}
.hero__right { display: flex; flex-direction: column; }
.hero__right .lede  { max-width: none; margin: 0 0 22px; }
.hero__right .clock { max-width: none; margin: 0; }
.hero__right .taunt { max-width: none; margin: 22px 0 0; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: var(--ink);
  color: var(--bun);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 8px 16px;
  border: 2px solid var(--ink);
  transform: rotate(-1.5deg);
}
.eyebrow .dot {
  width: 9px; height: 9px;
  background: var(--ketchup);
  border-radius: 50%;
  animation: blink 1.4s steps(1) infinite;
}
@keyframes blink { 50% { opacity: .15; } }

.title {
  margin: 26px 0 18px;
  font-family: var(--display);
  text-transform: uppercase;
  line-height: .86;
}
.title__name {
  display: block;
  font-size: clamp(46px, 11vw, 116px);
  color: var(--ink);
  -webkit-text-stroke: 1px var(--ink);
}
.title__vs {
  display: block;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(22px, 4vw, 38px);
  color: var(--ketchup);
  text-transform: lowercase;
  margin: 4px 0;
}
.title__dogs {
  display: block;
  font-size: clamp(46px, 11vw, 116px);
  color: var(--ketchup);
  text-shadow:
    4px 4px 0 var(--mustard),
    5px 5px 0 var(--ink);
}
.big70 {
  display: inline-block;
  font-size: 1.32em;
  color: var(--mustard);
  text-shadow:
    4px 4px 0 var(--ketchup-deep),
    5px 5px 0 var(--ink);
  transform: rotate(-4deg);
}

.lede {
  max-width: 600px;
  margin: 0 auto 38px;
  font-family: var(--serif);
  font-size: clamp(17px, 2.4vw, 22px);
  font-weight: 500;
}
.lede strong { color: var(--ketchup-deep); }

/* ===== SCOREBOARD CLOCK ===== */
.clock {
  background: var(--char);
  border: 3px solid var(--ink);
  box-shadow: var(--shadow);
  padding: 22px 18px 26px;
  max-width: 640px;
  margin: 0 auto;
}
.clock__label {
  color: var(--bun);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.clock__label span { color: var(--mustard); }
.clock__row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.unit {
  background:
    repeating-linear-gradient(0deg,
      rgba(0,0,0,.28) 0 2px, transparent 2px 4px),
    var(--ink);
  border: 2px solid #000;
  padding: 12px 4px 8px;
}
.unit__num {
  display: block;
  font-family: var(--display);
  font-size: clamp(34px, 9vw, 62px);
  line-height: 1;
  color: var(--mustard);
  text-shadow: 0 0 14px rgba(242,169,0,.55);
  font-variant-numeric: tabular-nums;
}
.unit__lbl {
  display: block;
  margin-top: 4px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--bun);
}

.taunt {
  min-height: 2.6em;
  max-width: 560px;
  margin: 30px auto 0;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(18px, 2.8vw, 25px);
  color: var(--ketchup-deep);
  transition: opacity .4s ease;
}
.taunt::before { content: "“"; }
.taunt::after  { content: "”"; }

/* ===== MUGSHOT (hero feature photo) ===== */
.mugshot {
  position: relative;
  margin: 6px 0 0;
  background: var(--paper);
  border: 4px solid var(--ink);
  box-shadow: var(--shadow);
  padding: 13px 13px 0;
  transform: rotate(-3deg);
}
.mugshot img {
  display: block;
  width: 100%;
  height: auto;
  border: 2px solid var(--ink);
  filter: saturate(1.05) contrast(1.03);
}
.mugshot figcaption {
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  text-align: center;
  padding: 11px 6px 13px;
}
.tape__tape {
  position: absolute;
  width: 96px; height: 28px;
  background: rgba(242,169,0,.62);
  border: 1px dashed rgba(36,20,3,.4);
  z-index: 3;
}
.tape__tape--tl { top: -13px; left: -24px; transform: rotate(-38deg); }
.tape__tape--br { bottom: 54px; right: -26px; transform: rotate(-40deg); }
.stamp {
  position: absolute;
  bottom: 76px;
  right: -20px;
  z-index: 4;
  display: grid;
  place-items: center;
  width: 116px; height: 116px;
  border-radius: 50%;
  border: 4px double var(--ketchup);
  color: var(--ketchup);
  font-family: var(--display);
  font-size: 26px;
  line-height: .8;
  text-transform: uppercase;
  text-align: center;
  transform: rotate(-15deg);
  opacity: .85;
}
.stamp small {
  display: block;
  font-family: var(--body);
  font-weight: 800;
  font-size: 9px;
  letter-spacing: .14em;
  margin-top: 4px;
}

/* ===== TALE OF THE TAPE (rap sheet) ===== */
.rapsheet {
  background: var(--paper);
  border: 3px solid var(--ink);
  box-shadow: var(--shadow);
  padding: 36px clamp(20px, 4vw, 48px) 42px;
  margin: 70px 0;
  text-align: center;
}
.stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 clamp(24px, 4vw, 48px);
  margin-top: 24px;
  text-align: left;
}
.stats > div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 16px;
  padding: 13px 4px;
  border-bottom: 2px dotted rgba(36,20,3,.35);
}
.stats dt {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mustard-deep);
  flex: none;
}
.stats dd {
  font-family: var(--serif);
  font-size: clamp(16px, 2.2vw, 20px);
  font-weight: 600;
  text-align: right;
}

/* ===== THE DOG COUNT ===== */
.count {
  background: var(--paper);
  border: 3px solid var(--ink);
  box-shadow: var(--shadow);
  padding: 38px clamp(18px, 4vw, 46px) 42px;
  margin: 70px 0;
  text-align: center;
}
.count__score {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: center;
  gap: 10px;
  margin: 8px 0 22px;
}
.count__eaten {
  font-family: var(--display);
  font-size: clamp(70px, 17vw, 150px);
  line-height: .8;
  color: var(--ketchup);
  text-shadow: 4px 4px 0 var(--mustard), 5px 5px 0 var(--ink);
}
.count__of {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(20px, 3vw, 30px);
}
.count__total {
  font-family: var(--display);
  font-size: clamp(40px, 9vw, 76px);
  color: var(--ink);
}
.count__word {
  flex-basis: 100%;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mustard-deep);
}

.bar {
  position: relative;
  height: 38px;
  background: var(--bun);
  border: 3px solid var(--ink);
  margin: 6px 0 16px;
  overflow: hidden;
}
.bar__fill {
  height: 100%;
  width: 0;
  background:
    repeating-linear-gradient(45deg,
      var(--ketchup) 0 16px,
      var(--ketchup-deep) 16px 32px);
  border-right: 3px solid var(--ink);
  transition: width 1.4s cubic-bezier(.22,1,.36,1);
}
.bar__pct {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-family: var(--display);
  font-size: 19px;
  color: var(--ink);
  mix-blend-mode: hard-light;
}
.count__remain {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(16px, 2.4vw, 21px);
  margin-bottom: 26px;
}

.grid {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: clamp(4px, 1.3vw, 10px);
  max-width: 560px;
  margin: 0 auto 14px;
}
.dog {
  font-size: clamp(18px, 4.4vw, 30px);
  line-height: 1;
  filter: grayscale(1) opacity(.32);
  transition: transform .2s ease;
}
.dog--done {
  filter: drop-shadow(1.5px 1.5px 0 var(--ink));
}
.dog--next {
  filter: grayscale(.3) opacity(.9);
  animation: nextpulse 1.3s ease-in-out infinite;
}
@keyframes nextpulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.32); }
}
.grid__key {
  font-size: 13px;
  font-style: italic;
  font-family: var(--serif);
  color: var(--char);
}
.grid__key span { font-style: normal; }

/* ===== THE TERMS ===== */
.terms { margin: 70px 0; }
.terms__intro {
  max-width: 620px;
  font-family: var(--serif);
  font-size: clamp(16px, 2.3vw, 20px);
  margin-bottom: 26px;
}
.terms__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.term {
  background: var(--mustard);
  border: 3px solid var(--ink);
  box-shadow: var(--shadow-sm);
  padding: 20px 12px;
  text-align: center;
}
.term:nth-child(2) { background: var(--ketchup); color: var(--paper); }
.term:nth-child(3) { background: var(--relish);  color: var(--paper); }
.term:nth-child(4) { background: var(--ink);     color: var(--bun); }
.term__num {
  display: block;
  font-family: var(--display);
  font-size: clamp(44px, 9vw, 76px);
  line-height: .9;
}
.term__txt {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.terms__foot {
  margin-top: 24px;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(15px, 2.2vw, 19px);
}

/* ===== FOOTER ===== */
.foot {
  text-align: center;
  border-top: 3px solid var(--ink);
  padding-top: 40px;
  margin-top: 70px;
}
.foot__big {
  font-family: var(--display);
  font-size: clamp(34px, 8vw, 66px);
  text-transform: uppercase;
  color: var(--ketchup);
  text-shadow: 3px 3px 0 var(--mustard), 4px 4px 0 var(--ink);
}
.foot__small {
  max-width: 460px;
  margin: 14px auto 18px;
  font-size: 14px;
  font-style: italic;
  font-family: var(--serif);
}
.foot__url {
  display: inline-block;
  background: var(--ink);
  color: var(--mustard);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .08em;
  padding: 8px 18px;
  transform: rotate(-1.5deg);
}

/* ===== ENTRANCE ANIMATIONS ===== */
.eyebrow, .title, .lede, .clock, .taunt {
  animation: rise .7s cubic-bezier(.22,1,.36,1) both;
}
.title  { animation-delay: .08s; }
.lede   { animation-delay: .22s; }
.clock  { animation-delay: .32s; }
.taunt  { animation-delay: .44s; }
.mugshot {
  animation: rise-tilt .75s cubic-bezier(.22,1,.36,1) both;
  animation-delay: .16s;
}
@keyframes rise {
  from { opacity: 0; transform: translateY(26px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes rise-tilt {
  from { opacity: 0; transform: translateY(30px) rotate(-3deg); }
  to   { opacity: 1; transform: translateY(0) rotate(-3deg); }
}

.reveal { opacity: 0; transform: translateY(34px); }
.reveal.in {
  opacity: 1;
  transform: translateY(0);
  transition: opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}

/* ===== RESPONSIVE ===== */
@media (max-width: 760px) {
  .hero { padding-top: 30px; }
  .hero__main {
    grid-template-columns: 1fr;
    gap: 30px;
    text-align: center;
  }
  .mugshot { max-width: 330px; margin: 0 auto; }
  .hero__right .lede,
  .hero__right .taunt { text-align: center; }
  .clock__row { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .stats { grid-template-columns: 1fr; }
  .terms__grid { grid-template-columns: repeat(2, 1fr); }
  .count { padding: 30px 16px 34px; }
  .rapsheet { padding: 30px 18px 34px; }
}
