:root {
  --ink: #1f1d1a;
  --paper: #f7f2e8;
  --cream: #fffaf0;
  --red: #f06449;
  --blue: #477fd5;
  --yellow: #f5ca55;
  --green: #30493b;
  --line: rgba(31, 29, 26, .18);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: "DM Sans", system-ui, sans-serif;
  line-height: 1.55;
}
a { color: inherit; }
.skip-link { position: fixed; top: -80px; left: 20px; z-index: 20; background: var(--ink); color: white; padding: 12px 18px; }
.skip-link:focus { top: 20px; }
.site-header {
  height: 84px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  padding: 0 clamp(24px, 5vw, 76px);
  border-bottom: 1px solid var(--line);
  background: rgba(247, 242, 232, .92);
  backdrop-filter: blur(12px);
  position: sticky;
  top: 0;
  z-index: 10;
}
.brand { display: flex; align-items: center; gap: 10px; font: 700 19px/1 "Fraunces", serif; text-decoration: none; }
.brand-mark { display: grid; place-items: center; width: 35px; height: 35px; border-radius: 50%; background: var(--red); color: white; font: 700 19px/1 serif; letter-spacing: -7px; padding-right: 7px; transform: rotate(-6deg); }
nav { display: flex; gap: 32px; margin-left: auto; }
nav a { font-size: 14px; font-weight: 600; text-decoration: none; }
nav a:hover { color: var(--red); }
.button { display: inline-flex; justify-content: center; align-items: center; min-height: 50px; padding: 0 24px; border: 2px solid var(--ink); border-radius: 100px; background: var(--red); color: #fff; font-weight: 700; text-decoration: none; box-shadow: 4px 4px 0 var(--ink); transition: transform .2s, box-shadow .2s; }
.button:hover { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--ink); }
.button-small { min-height: 40px; padding: 0 18px; font-size: 14px; box-shadow: none; }
.text-link { font-weight: 700; text-underline-offset: 5px; }

.hero { min-height: 690px; display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; }
.hero-copy { padding: clamp(72px, 9vw, 130px) 5vw 80px max(24px, 7vw); align-self: center; }
.eyebrow { display: flex; align-items: center; gap: 10px; margin: 0 0 25px; font-size: 12px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
.eyebrow span { width: 28px; height: 2px; background: currentColor; }
h1, h2, .footer-lead p { margin: 0; font-family: "Fraunces", Georgia, serif; line-height: .95; letter-spacing: -.045em; }
h1 { max-width: 650px; font-size: clamp(72px, 8.3vw, 132px); }
h1 em, h2 em, .footer-lead em { color: var(--red); font-weight: 600; }
.hero-lede { max-width: 590px; margin: 34px 0; font-size: clamp(18px, 1.5vw, 22px); line-height: 1.6; }
.hero-actions { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }
.hero-playground { position: relative; min-height: 690px; background: var(--blue); border-left: 1px solid var(--ink); overflow: hidden; }
.hero-playground::before { content: ""; position: absolute; width: 420px; height: 420px; border: 2px solid rgba(255,255,255,.22); border-radius: 50%; top: -100px; right: -90px; }
.prompt-card { position: absolute; width: min(315px, 60%); min-height: 340px; padding: 28px; border: 2px solid var(--ink); box-shadow: 7px 7px 0 var(--ink); }
.prompt-card p { font: 700 clamp(35px, 4vw, 58px)/1.02 "Fraunces", serif; letter-spacing: -.04em; margin: 36px 0; }
.prompt-label { font-size: 11px; text-transform: uppercase; letter-spacing: .15em; font-weight: 700; }
.prompt-card-one { top: 118px; left: 10%; background: var(--yellow); transform: rotate(-7deg); z-index: 2; }
.prompt-card-two { right: -10px; bottom: 74px; background: var(--cream); transform: rotate(8deg); }
.prompt-card-two p em { color: var(--red); font-weight: 600; }
.prompt-vote { display: flex; gap: 8px; }
.prompt-vote span { padding: 7px 11px; border: 1.5px solid var(--ink); border-radius: 50px; font-size: 11px; font-weight: 700; }
.prompt-vote span:first-child { background: var(--ink); color: white; }
.paw { margin-left: auto; width: 50px; height: 42px; display: grid; place-items: center; border: 3px solid var(--ink); border-radius: 50%; font-size: 10px; }
.speech-bubble { position: absolute; left: 7%; bottom: 55px; z-index: 5; background: var(--red); color: white; padding: 14px 20px; border: 2px solid var(--ink); border-radius: 50%; font: 700 15px "Fraunces", serif; transform: rotate(-5deg); }
.marquee { overflow: hidden; border-block: 1px solid var(--ink); background: var(--yellow); }
.marquee div { width: max-content; display: flex; align-items: center; gap: 34px; padding: 16px 0; animation: scroll 24s linear infinite; }
.marquee span { font: 700 18px "Fraunces", serif; }
.marquee b { color: var(--red); }
@keyframes scroll { to { transform: translateX(-25%); } }

.section { padding: clamp(90px, 11vw, 160px) max(24px, 7vw); }
.program { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; }
h2 { font-size: clamp(52px, 6.3vw, 94px); }
.program-copy { align-self: end; max-width: 570px; }
.program-copy p { font-size: 17px; }
.program-copy .large-copy { font: 600 clamp(24px, 2.3vw, 34px)/1.35 "Fraunces", serif; }
.skills-grid { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 55px; }
.skill-card { min-height: 350px; display: flex; flex-direction: column; padding: 28px; border: 1.5px solid var(--ink); background: rgba(255,255,255,.25); }
.skill-number { font: 700 12px "DM Sans"; }
.skill-icon { margin: 38px 0 auto; font-size: 55px; color: var(--red); }
.skill-card:nth-child(2) .skill-icon { color: var(--blue); }
.skill-card:nth-child(3) .skill-icon { color: var(--green); }
.skill-card h3 { margin: 12px 0 5px; font: 700 30px "Fraunces", serif; }
.skill-card p { max-width: 280px; margin: 0; }

.workshop { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(60px, 9vw, 140px); background: var(--green); color: var(--cream); }
.eyebrow.light { color: var(--yellow); }
.workshop-heading { position: sticky; top: 150px; align-self: start; }
.workshop-heading h2 em { color: var(--yellow); }
.workshop-heading > p:last-child { max-width: 450px; margin-top: 36px; color: rgba(255,255,255,.76); font-size: 18px; }
.session-list { list-style: none; padding: 0; margin: 0; }
.session-list li { display: grid; grid-template-columns: 70px 1fr 55px; gap: 22px; align-items: center; padding: 32px 0; border-top: 1px solid rgba(255,255,255,.3); }
.session-list li:last-child { border-bottom: 1px solid rgba(255,255,255,.3); }
.session-time { color: var(--yellow); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
.session-list h3 { margin: 0 0 7px; font: 700 28px "Fraunces", serif; }
.session-list p { margin: 0; color: rgba(255,255,255,.68); }
.session-mark { width: 48px; height: 48px; display: grid; place-items: center; border: 1.5px solid rgba(255,255,255,.6); border-radius: 50%; font-size: 22px; }

.prompts { display: grid; grid-template-columns: .75fr 1.25fr; gap: 80px; align-items: center; overflow: hidden; }
.prompt-stack { min-height: 570px; position: relative; }
.stack-card { position: absolute; left: 50%; top: 50%; width: min(500px, 80vw); min-height: 300px; padding: 30px; border: 2px solid var(--ink); box-shadow: 8px 8px 0 var(--ink); }
.stack-card span { font: 700 12px "DM Sans"; }
.stack-card p { margin: 70px 0 0; font: 600 clamp(29px, 3vw, 43px)/1.15 "Fraunces", serif; }
.stack-card strong { text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 5px; }
.card-yellow { background: var(--yellow); transform: translate(-58%,-58%) rotate(-7deg); }
.card-blue { background: var(--blue); color: white; transform: translate(-47%,-50%) rotate(4deg); }
.card-red { background: var(--red); transform: translate(-52%,-42%) rotate(-2deg); }

.host { background: var(--blue); }
.host-card { display: grid; grid-template-columns: 1.2fr .8fr; border: 2px solid var(--ink); box-shadow: 10px 10px 0 var(--ink); }
.host-copy { padding: clamp(45px, 7vw, 95px); background: var(--yellow); }
.host-copy h2 { font-size: clamp(48px, 5.5vw, 82px); }
.host-copy h2 em { color: var(--red); }
.host-copy > p:not(.eyebrow) { max-width: 600px; margin: 32px 0; font-size: 18px; }
.button-dark { background: var(--ink); box-shadow: 4px 4px 0 var(--red); }
.host-details { padding: clamp(40px, 5vw, 75px); background: var(--cream); display: flex; flex-direction: column; justify-content: center; }
.host-details h3 { font: 700 30px "Fraunces", serif; }
.host-details ul { list-style: none; padding: 0; margin: 10px 0 30px; }
.host-details li { display: flex; align-items: center; gap: 12px; padding: 16px 0; border-bottom: 1px solid var(--line); }
.host-details li span { display: grid; place-items: center; flex: 0 0 26px; height: 26px; background: var(--red); color: white; border-radius: 50%; font-size: 13px; }
.host-note { font-size: 14px; color: rgba(31,29,26,.65); }

.about { display: grid; grid-template-columns: .65fr 1.35fr; align-items: center; gap: 10vw; }
.about-badge { width: min(320px, 70vw); aspect-ratio: 1; display: grid; place-items: center; position: relative; border: 2px solid var(--ink); border-radius: 50%; background: var(--red); color: white; box-shadow: 10px 10px 0 var(--yellow); transform: rotate(-6deg); }
.about-badge span { position: absolute; top: 30px; font-size: 12px; text-transform: uppercase; letter-spacing: .18em; }
.about-badge strong { font: 700 105px "Fraunces", serif; }
.about-copy { max-width: 720px; }
.about-copy h2 { margin-bottom: 28px; }
.about-copy > p:last-child { font-size: clamp(18px, 1.7vw, 22px); line-height: 1.7; }

footer { background: var(--ink); color: var(--cream); padding: 90px max(24px, 7vw) 30px; }
.footer-lead { display: flex; justify-content: space-between; align-items: end; gap: 50px; padding-bottom: 80px; }
.footer-lead p { font-size: clamp(48px, 6vw, 90px); }
.footer-lead em { color: var(--yellow); }
.footer-email { font-weight: 700; font-size: clamp(16px, 1.6vw, 21px); text-underline-offset: 7px; white-space: nowrap; }
.footer-meta { display: flex; justify-content: space-between; gap: 24px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.25); color: rgba(255,255,255,.6); font-size: 12px; }
.footer-meta a { color: inherit; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } .reveal { opacity: 1; transform: none; transition: none; } .marquee div { animation: none; } }

@media (max-width: 900px) {
  nav { display: none; }
  .hero { grid-template-columns: 1fr; }
  .hero-playground { min-height: 600px; border-left: 0; border-top: 1px solid var(--ink); }
  .program, .workshop, .prompts, .host-card, .about { grid-template-columns: 1fr; }
  .skills-grid { grid-template-columns: 1fr; }
  .skill-card { min-height: 280px; }
  .workshop-heading { position: static; }
  .prompt-stack { min-height: 600px; }
  .host-card { box-shadow: 7px 7px 0 var(--ink); }
  .about-badge { margin: auto; }
  .footer-lead { align-items: start; flex-direction: column; }
}
@media (max-width: 560px) {
  .site-header { height: 70px; padding-inline: 18px; }
  .brand { font-size: 16px; }
  .button-small { padding: 0 13px; min-height: 37px; }
  .hero-copy { padding: 65px 24px; }
  h1 { font-size: 64px; }
  h2 { font-size: 49px; }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .hero-playground { min-height: 510px; }
  .prompt-card { min-height: 285px; padding: 22px; }
  .prompt-card-one { top: 70px; left: 5%; }
  .prompt-card-two { bottom: 45px; }
  .prompt-card p { font-size: 33px; margin: 25px 0; }
  .section { padding: 85px 24px; }
  .program { gap: 42px; }
  .skills-grid { margin-top: 15px; }
  .session-list li { grid-template-columns: 52px 1fr; }
  .session-mark { display: none; }
  .prompt-stack { min-height: 500px; }
  .stack-card { width: 88vw; min-height: 260px; }
  .stack-card p { margin-top: 50px; }
  .host { padding-inline: 16px; }
  .host-copy, .host-details { padding: 38px 28px; }
  .footer-meta { flex-direction: column; }
}
