/* ============================================================
   LONDON AI-QUALIFIED AWARDS
   pop-art × criminal-financial neo-noir × black satire
   ============================================================ */

:root{
  --ink:#0a0806;
  --ink-2:#13100c;
  --cream:#f3ead4;
  --cream-dim:#cabd9f;
  --red:#cf1f24;
  --red-bright:#ee2a2f;
  --gold:#e3a92c;
  --teal:#1f9e96;
  --teal-dim:#12706a;
  --panel:#171310;
  --hair:rgba(243,234,212,.14);
  --shadow-hard:6px 6px 0 #000;
  --maxw:1240px;
  --disp:'Anton',sans-serif;
  --black:'Archivo Black',sans-serif;
  --cond:'Oswald',sans-serif;
  --mono:'Space Mono',monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--cream);
  font-family:var(--cond);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--red);color:var(--cream)}

/* ---------- texture overlays ---------- */
.grain,.halftone-fixed,.scanlines{position:fixed;inset:0;pointer-events:none;z-index:90}
.grain{
  opacity:.06;mix-blend-mode:screen;
  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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grainShift .4s steps(2) infinite;
}
@keyframes grainShift{0%{transform:translate(0,0)}50%{transform:translate(-4%,3%)}100%{transform:translate(3%,-2%)}}
.halftone-fixed{
  opacity:.05;
  background-image:radial-gradient(var(--cream) 1px,transparent 1.4px);
  background-size:6px 6px;
}
.scanlines{
  opacity:.35;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0 2px,rgba(0,0,0,.25) 2px 3px);
  mix-blend-mode:multiply;
}

/* ---------- TICKER ---------- */
.ticker{
  position:fixed;top:0;left:0;right:0;z-index:80;
  background:var(--ink-2);
  border-bottom:2px solid var(--red);
  font-family:var(--mono);font-size:13px;letter-spacing:.04em;
  height:34px;display:flex;align-items:center;overflow:hidden;
}
.ticker__track{display:inline-flex;white-space:nowrap;will-change:transform;animation:tick 38s linear infinite}
.ticker:hover .ticker__track{animation-play-state:paused}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tk{padding:0 22px;display:inline-flex;gap:8px;align-items:center}
.tk b{font-weight:700}
.tk--up{color:var(--teal)}
.tk--down{color:var(--red-bright)}
.tk--note{color:var(--gold);text-transform:uppercase}
.tk__sep{color:var(--cream-dim);opacity:.4}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:34px;left:0;right:0;z-index:70;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px clamp(16px,4vw,46px);
  background:linear-gradient(180deg,rgba(10,8,6,.92),rgba(10,8,6,0));
  transition:background .3s;
}
.nav.solid{background:rgba(10,8,6,.96);border-bottom:1px solid var(--hair)}
.nav__brand{font-family:var(--black);font-size:18px;letter-spacing:.06em}
.nav__brand span{color:var(--red);margin:0 2px}
.nav__links{display:flex;gap:clamp(12px,2vw,30px);align-items:center;font-family:var(--cond);text-transform:uppercase;font-size:14px;letter-spacing:.08em}
.nav__links a{opacity:.78;transition:opacity .2s,color .2s}
.nav__links a:hover{opacity:1;color:var(--gold)}
.nav__cta{background:var(--red);color:var(--cream)!important;padding:7px 14px;opacity:1!important;font-weight:600;box-shadow:var(--shadow-hard);transition:transform .12s}
.nav__cta:hover{transform:translate(-2px,-2px);background:var(--red-bright)}
@media(max-width:720px){.nav__links a:not(.nav__cta){display:none}}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px clamp(16px,5vw,70px) 80px;overflow:hidden}
.hero__art{position:absolute;inset:0;z-index:0}
.hero__img{position:absolute;object-fit:cover;filter:contrast(1.08) saturate(1.05)}
.hero__img--wide{inset:0;width:100%;height:100%;opacity:.5}
.hero__img--square{display:none}
.hero__veil{position:absolute;inset:0;background:
  radial-gradient(120% 90% at 70% 30%,rgba(10,8,6,.2),rgba(10,8,6,.86) 70%),
  linear-gradient(180deg,rgba(10,8,6,.7),rgba(10,8,6,.4) 30%,rgba(10,8,6,.95))}
.hero__content{position:relative;z-index:3;max-width:780px}

.kicker{font-family:var(--mono);text-transform:uppercase;letter-spacing:.25em;font-size:13px;color:var(--gold);border:1px solid var(--gold);display:inline-block;padding:6px 12px;margin-bottom:22px}
.kicker--flash{animation:flash 1.4s steps(1) infinite}
@keyframes flash{0%,60%{opacity:1}61%,75%{opacity:.25}76%,100%{opacity:1}}

.hero__title{font-family:var(--disp);line-height:.82;text-transform:uppercase;margin-bottom:26px}
.hero__title .line{display:block;font-size:clamp(64px,16vw,210px);letter-spacing:.01em;color:var(--cream);text-shadow:var(--shadow-hard);position:relative}
.hero__title .o{color:var(--red);display:inline-block;animation:spinO 6s linear infinite;transform-origin:50% 54%}
@keyframes spinO{to{transform:rotate(360deg)}}
.hero__title .sub{display:inline-block;font-family:var(--black);font-size:clamp(18px,3.4vw,40px);letter-spacing:.06em;color:var(--ink);background:var(--gold);padding:4px 16px;transform:skewX(-7deg);box-shadow:var(--shadow-hard);margin:6px 0}
.hero__title .stamp{font-family:var(--black);font-size:clamp(34px,8vw,98px);letter-spacing:.1em;-webkit-text-stroke:2px var(--cream);color:transparent;text-shadow:none}

.hero__meta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:26px}
.meta__chip{background:var(--cream);color:var(--ink);padding:10px 18px;box-shadow:var(--shadow-hard);transform:skewX(-6deg)}
.meta__chip>*{display:block;transform:skewX(6deg)}
.meta__chip b{font-family:var(--black);font-size:20px;line-height:1}
.meta__chip span{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;opacity:.7}
.meta__chip--red{background:var(--red);color:var(--cream)}

.hero__quote{font-family:var(--cond);font-style:italic;font-size:clamp(16px,2.2vw,22px);color:var(--cream-dim);margin-bottom:28px;border-left:3px solid var(--red);padding-left:14px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--black);text-transform:uppercase;letter-spacing:.05em;background:var(--red);color:var(--cream);padding:14px 26px;box-shadow:var(--shadow-hard);transition:transform .12s,background .2s}
.btn span{transition:transform .2s}
.btn:hover{transform:translate(-3px,-3px);background:var(--red-bright)}
.btn:hover span{transform:translate(3px,-3px)}
.btn--big{font-size:clamp(15px,2vw,20px);padding:16px 30px}

/* floating bubbles */
.bubble{position:absolute;z-index:4;background:var(--cream);color:var(--ink);font-family:var(--cond);font-weight:600;text-transform:uppercase;font-size:clamp(11px,1.1vw,15px);line-height:1.15;padding:14px 16px;max-width:210px;box-shadow:var(--shadow-hard);letter-spacing:.02em}
.bubble i{color:var(--red);font-style:normal}
.bubble::after{content:"";position:absolute;width:0;height:0}
.bubble--1{top:16%;right:6%;transform:rotate(3deg)}
.bubble--1::after{bottom:-14px;left:30px;border:8px solid transparent;border-top-color:var(--cream);border-right:0}
.bubble--2{top:54%;right:9%;background:var(--gold);transform:rotate(-2deg)}
.bubble--2 i{color:var(--ink)}
.bubble--2::after{top:-14px;left:30%;border:8px solid transparent;border-bottom-color:var(--gold)}
.bubble--3{bottom:9%;left:5%;background:var(--red);color:var(--cream);transform:rotate(-3deg)}
.bubble--3 i{color:var(--ink)}
.bubble--3::after{top:-14px;right:24px;border:8px solid transparent;border-bottom-color:var(--red)}
@media(max-width:880px){.bubble{display:none}}

/* ---------- MARKET FEED counters ---------- */
.feed{border-top:2px solid var(--red);border-bottom:2px solid var(--red);background:var(--ink-2);padding:26px clamp(16px,5vw,70px)}
.feed__label{font-family:var(--mono);color:var(--teal);text-transform:uppercase;letter-spacing:.22em;font-size:12px;margin-bottom:16px}
.feed__label::before{content:"●";color:var(--red);margin-right:8px;animation:flash 1.2s steps(1) infinite}
.feed__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{display:flex;flex-direction:column}
.stat__num{font-family:var(--disp);font-size:clamp(40px,6vw,76px);line-height:.9;color:var(--gold)}
.stat__cap{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.1em;color:var(--cream-dim)}
@media(max-width:680px){.feed__grid{grid-template-columns:repeat(2,1fr);gap:24px}}

/* ---------- SECTION HEAD ---------- */
.section-head{display:flex;align-items:baseline;gap:18px;padding:0 clamp(16px,5vw,70px);margin:90px auto 38px;max-width:var(--maxw);flex-wrap:wrap}
.section-head__idx{font-family:var(--mono);color:var(--red);font-size:18px;letter-spacing:.1em}
.section-head__title{font-family:var(--disp);text-transform:uppercase;font-size:clamp(30px,6vw,70px);letter-spacing:.02em;line-height:.9}
.section-head__sub{font-family:var(--mono);color:var(--cream-dim);text-transform:uppercase;font-size:12px;letter-spacing:.18em}

/* ---------- MANIFESTO ---------- */
.manifesto{max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,5vw,70px) 40px}
.man__lead{margin:0 0 50px}
.man__lead p{font-family:var(--disp);text-transform:uppercase;font-size:clamp(30px,7vw,80px);line-height:.92;letter-spacing:.01em;color:var(--cream)}
.hl-gold{color:var(--gold)}.hl-teal{color:var(--teal)}.hl-red{color:var(--red-bright)}.hl-cream{color:var(--cream)}

.man__body p{font-size:clamp(18px,2.4vw,28px);line-height:1.45;max-width:900px;margin:0 0 26px;color:var(--cream-dim)}
.man__body p b{color:var(--cream)}
.man__body .big{font-family:var(--black);color:var(--cream);font-size:clamp(22px,3.4vw,40px);line-height:1.2;max-width:1000px}
.man__body .big span{padding:0 4px}
.man__body .punch{font-family:var(--disp);text-transform:uppercase;color:var(--red);font-size:clamp(40px,9vw,120px);line-height:.86;margin:40px 0;max-width:none;text-shadow:var(--shadow-hard)}

.man__split{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;margin:60px 0;align-items:start}
.man__col p{font-size:clamp(16px,2vw,22px);line-height:1.5;color:var(--cream-dim);margin-bottom:18px}
.man__col b{color:var(--cream)}
.ticklist{list-style:none;margin:18px 0}
.ticklist li{font-family:var(--cond);font-size:clamp(18px,2.4vw,26px);padding:8px 0 8px 30px;position:relative;border-bottom:1px dashed var(--hair)}
.ticklist li::before{content:"▲";color:var(--teal);position:absolute;left:0;font-size:14px;top:13px}
.ticklist li b{color:var(--gold)}
.man__col--quotes{display:flex;flex-direction:column;gap:18px;border-left:3px solid var(--gold);padding-left:24px}
.man__col--quotes blockquote{font-family:var(--cond);font-style:italic;font-size:clamp(16px,2vw,22px);color:var(--cream);line-height:1.3}
@media(max-width:760px){.man__split{grid-template-columns:1fr}}

.man__stories{margin:70px 0}
.man__storiesLead{font-family:var(--black);font-size:clamp(20px,3vw,34px);margin-bottom:24px;color:var(--cream)}
.story-cloud{display:flex;flex-wrap:wrap;gap:14px}
.story-cloud span{font-family:var(--cond);font-size:clamp(16px,2vw,24px);background:var(--panel);border:1px solid var(--hair);padding:10px 18px;text-transform:uppercase;letter-spacing:.02em;transition:transform .2s,background .2s}
.story-cloud span:hover{transform:translateY(-3px) rotate(-1deg);background:var(--ink-2)}
.story-cloud__wide{flex-basis:100%}

.man__close{margin-top:40px}
.becomes{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:30px 0}
.becomes__card{background:var(--panel);border:1px solid var(--hair);border-top:3px solid var(--red);padding:22px 18px;font-family:var(--black);text-transform:uppercase;font-size:clamp(15px,1.6vw,20px);line-height:1.15;box-shadow:var(--shadow-hard)}
.becomes__card span{display:block;font-family:var(--cond);font-weight:400;color:var(--gold);font-size:.78em;margin-top:6px;letter-spacing:.04em}
.becomes__card:nth-child(2){border-top-color:var(--gold)}
.becomes__card:nth-child(3){border-top-color:var(--teal)}
.becomes__card:nth-child(4){border-top-color:var(--cream)}
@media(max-width:760px){.becomes{grid-template-columns:1fr 1fr}}

.nobets{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin:40px 0 14px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--cream-dim);font-size:clamp(13px,1.6vw,18px)}
.nobets span{position:relative;padding-right:16px}
.nobets span::after{content:"//";position:absolute;right:0;color:var(--red);opacity:.6}
.nobets b{font-family:var(--disp);color:var(--gold);font-size:clamp(26px,4vw,46px);letter-spacing:.04em}
.man__kicker{font-family:var(--cond);font-style:italic;font-size:clamp(16px,2vw,22px);color:var(--cream-dim)}

/* ---------- CATEGORIES ---------- */
.cats__grid{max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,5vw,70px);display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cat{position:relative;background:var(--panel);border:1px solid var(--hair);padding:26px 22px 22px;box-shadow:var(--shadow-hard);overflow:hidden;transition:transform .18s,background .2s}
.cat::before{content:attr(data-tick);position:absolute;top:10px;right:14px;font-family:var(--mono);font-size:13px;color:var(--teal)}
.cat[data-tick^="-"]::before{color:var(--red-bright)}
.cat::after{content:"";position:absolute;inset:0;background:radial-gradient(var(--cream) .8px,transparent 1.1px);background-size:5px 5px;opacity:.04;pointer-events:none}
.cat__code{font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;font-size:13px;color:var(--gold);display:block;margin-bottom:10px}
.cat h3{font-family:var(--disp);text-transform:uppercase;font-size:clamp(24px,3vw,38px);line-height:.92;letter-spacing:.01em;color:var(--cream)}
.cat:hover{transform:translate(-3px,-3px);background:var(--ink-2)}
.cat--ai{border-color:var(--teal)}
.cat--ai .cat__code{color:var(--teal)}
.cat--grand{grid-column:1/-1;background:linear-gradient(100deg,var(--red),#7a0f12);border:none}
.cat--grand .cat__code{color:var(--cream)}
.cat--grand h3{font-family:var(--black);font-size:clamp(30px,5vw,64px);-webkit-text-stroke:0;color:var(--cream)}
.cat--grand::before{color:var(--gold);font-size:22px}
@media(max-width:860px){.cats__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.cats__grid{grid-template-columns:1fr}}

/* ---------- RULES ---------- */
.rules__wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,5vw,70px)}
.rules__list{list-style:none;counter-reset:none}
.rules__list li{display:flex;gap:18px;align-items:baseline;padding:18px 0;border-bottom:1px solid var(--hair);font-size:clamp(17px,2.2vw,26px);font-family:var(--cond)}
.rules__list li span{font-family:var(--mono);color:var(--red);font-size:14px;flex:0 0 auto}
.rules__list li b{color:var(--gold)}
.rules__creed{display:flex;flex-wrap:wrap;align-items:center;gap:20px;margin:40px 0 0;padding:30px;background:var(--panel);border:1px solid var(--hair);box-shadow:var(--shadow-hard)}
.rules__creed span{font-family:var(--cond);text-transform:uppercase;font-size:clamp(16px,2vw,22px);color:var(--cream-dim);letter-spacing:.04em}
.rules__creed b{font-family:var(--disp);text-transform:uppercase;color:var(--gold);font-size:clamp(26px,4vw,50px);letter-spacing:.02em;flex-basis:100%}

/* ---------- ENTRY ---------- */
.entry{margin:110px auto 0;padding:70px clamp(16px,5vw,70px);background:
  repeating-linear-gradient(135deg,rgba(207,31,36,.06) 0 14px,transparent 14px 28px),var(--ink-2);
  border-top:2px solid var(--red)}
.entry__inner{max-width:760px;margin:0 auto;text-align:center}
.entry__open{font-family:var(--mono);text-transform:uppercase;letter-spacing:.3em;color:var(--gold);font-size:14px;margin-bottom:10px}
.entry__big{font-family:var(--black);text-transform:uppercase;font-size:clamp(90px,24vw,260px);line-height:.8;color:var(--red);letter-spacing:.02em;text-shadow:var(--shadow-hard);margin-bottom:14px}
.entry__line{font-family:var(--cond);font-style:italic;font-size:clamp(16px,2.2vw,24px);color:var(--cream-dim);margin-bottom:30px}

/* FilmFreeway primary button */
.btn--ff{font-size:clamp(16px,2.4vw,24px);padding:18px 34px;background:var(--gold);color:var(--ink);border:none;position:relative}
.btn--ff:hover{background:#f1bf45}
.btn__ff-tag{font-family:var(--mono);font-weight:700;font-size:.6em;letter-spacing:.18em;background:var(--ink);color:var(--gold);padding:4px 8px;transform:skewX(-6deg)}
.btn__arr{transition:transform .2s}
.btn--ff:hover .btn__arr{transform:translate(3px,-3px)}

.entry__or{display:flex;align-items:center;gap:16px;margin:26px auto 22px;max-width:520px;color:var(--cream-dim)}
.entry__or::before,.entry__or::after{content:"";flex:1;height:1px;background:var(--hair)}
.entry__or span{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:11px}

.entry__mail{display:inline-block;margin-top:22px;font-family:var(--black);font-size:clamp(18px,3vw,30px);letter-spacing:.02em;color:var(--cream);border-bottom:3px solid var(--red);padding-bottom:3px;transition:color .2s,transform .15s}
.entry__mail:hover{color:var(--gold);transform:translateY(-2px)}
.entry__note a{color:var(--teal)}
.entry__form{display:grid;grid-template-columns:1fr 1fr;gap:12px;text-align:left}
.entry__form input{font-family:var(--mono);background:var(--ink);border:1px solid var(--hair);color:var(--cream);padding:16px;font-size:14px;letter-spacing:.05em;outline:none;transition:border-color .2s}
.entry__form input::placeholder{color:var(--cream-dim);opacity:.6}
.entry__form input:focus{border-color:var(--gold)}
.entry__form .btn--big{grid-column:1/-1;justify-content:center;cursor:pointer;border:none}
.entry__note{margin-top:18px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--teal)}
@media(max-width:560px){.entry__form{grid-template-columns:1fr}}

/* ---------- FOOTER ---------- */
.foot{padding:70px clamp(16px,5vw,70px);text-align:center;border-top:1px solid var(--hair)}
.foot__mark{font-family:var(--black);font-size:clamp(18px,3vw,30px);letter-spacing:.06em;margin-bottom:14px}
.foot__meta{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:var(--cream-dim);margin-bottom:26px}
.foot__meta a{color:var(--gold);border-bottom:1px solid transparent;transition:border-color .2s}
.foot__meta a:hover{border-color:var(--gold)}
.foot__quote{font-family:var(--cond);font-style:italic;font-size:clamp(18px,3vw,30px);color:var(--gold);margin-bottom:24px}
.foot__fine{font-family:var(--mono);font-size:11px;color:var(--cream-dim);opacity:.6;letter-spacing:.08em}

/* ---------- REVEAL animations ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.cut{transition-duration:.32s}
.cut.in{animation:cutIn .32s cubic-bezier(.2,.9,.2,1)}
@keyframes cutIn{0%{opacity:0;transform:translateY(28px) skewX(-4deg) scale(.98)}60%{transform:translateY(0) skewX(2deg) scale(1.01)}100%{opacity:1;transform:none}}
.punch.in{animation:punchIn .5s cubic-bezier(.2,.9,.2,1)}
@keyframes punchIn{0%{opacity:0;transform:scale(1.6);filter:blur(8px)}55%{opacity:1;transform:scale(.96)}100%{transform:scale(1)}}

/* stamp-in for category cards */
.cat,.becomes__card{opacity:0;transform:translateY(30px) rotate(-1deg)}
.cat.in,.becomes__card.in{animation:stamp .45s cubic-bezier(.2,.9,.2,1) forwards}
@keyframes stamp{0%{opacity:0;transform:translateY(40px) rotate(-3deg) scale(.9)}60%{opacity:1;transform:translateY(0) rotate(1deg) scale(1.02)}100%{opacity:1;transform:none}}

/* glitch */
.glitch{position:relative}
.glitch::before,.glitch::after{content:attr(data-glitch);position:absolute;inset:0;clip-path:inset(0 0 0 0)}
.glitch::before{color:var(--teal);transform:translate(-3px,0);animation:gl1 .25s steps(2) infinite;mix-blend-mode:screen}
.glitch::after{color:var(--red);transform:translate(3px,0);animation:gl2 .3s steps(2) infinite;mix-blend-mode:screen}
@keyframes gl1{0%,100%{clip-path:inset(0 0 80% 0)}50%{clip-path:inset(40% 0 20% 0)}}
@keyframes gl2{0%,100%{clip-path:inset(70% 0 0 0)}50%{clip-path:inset(10% 0 50% 0)}}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal{opacity:1;transform:none}
  .cat,.becomes__card{opacity:1;transform:none}
}
