/* =========================
   CAT LAP '26 POSTER THEME
   ========================== */

/* Core palette pulled from poster */
:root {
  --catlap-yellow: #fef100;
  --catlap-blue:   #00a3e6;
  --catlap-pink:   #f4519d;
  --catlap-green:  #66c343;
  --catlap-orange: #ff7b25;
  --catlap-brown:  #9c4d18;
  --catlap-black:  #000000;

  --page-bg: var(--catlap-yellow);
  --ink: var(--catlap-black);
  --ink-soft: #222222;

  --max-width: 1100px;
}

/* =========================
   Custom Font
   ========================== */

@font-face {
  font-family: "MyUploadedFont";
  src: url("../fonts/phosphate.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* =========================
   Global Resets
   ========================== */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  min-height: 100%;
}

body {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    Arial, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at 5% 25%,  rgba(0,163,230,0.95) 0 20%,  transparent 24%),
    radial-gradient(circle at 95% 40%, rgba(244,81,157,0.95) 0 22%, transparent 26%),
    radial-gradient(circle at 15% 95%, rgba(102,195,67,0.95) 0 18%, transparent 22%),
    var(--page-bg);
  background-repeat: no-repeat;
  background-attachment: fixed;
}

main {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 1.5rem 1.25rem 3rem;
}

/* =========================
   Typography
   ========================== */

h1,
h2,
h3 {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    Roboto, Arial, sans-serif;
  font-weight: 900;              /* “Black” weight */
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 0.75rem;
  text-shadow: 3px 3px 0 var(--catlap-black);
}

h1 {
  font-size: clamp(2.6rem, 4.8vw, 3.6rem);
  color: var(--catlap-yellow);
}

h2 {
  font-size: clamp(1.9rem, 3.4vw, 2.4rem);
  color: #fffad2;
}

h3 {
  font-size: clamp(1.2rem, 2.4vw, 1.7rem);
  color: var(--catlap-black);
}

p {
  margin: 0 0 0.8rem;
  line-height: 1.5;
  color: var(--ink-soft);
  font-size: 0.96rem;
}

a {
  color: inherit;
  text-decoration: none;
}

/* =========================
   Skip link (keyboard users)
   ========================== */

.skip-link {
  position: absolute;
  left: -999px;
  top: 0;
  padding: 0.5rem 1rem;
  background: var(--catlap-black);
  color: var(--catlap-yellow);
  font-weight: 700;
  z-index: 1000;
}

.skip-link:focus-visible {
  left: 0.75rem;
  top: 0.75rem;
}


/* =========================
   Header / Nav (CD stays!)
   ========================== */

header {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0.75rem 1.25rem 0.25rem;
}

.nav-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.logo-text {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

/* CD badge with smooth gradient */
.logo-badge {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 28% 28%,
      #ffffff 0%,
      #ffffff 14%,
      var(--catlap-yellow) 15%,
      var(--catlap-pink) 55%,
      var(--catlap-black) 100%
    );
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "MyUploadedFont", system-ui, sans-serif;
  font-size: 1.1rem;
  color: #ffffff;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.5);
  transform: rotate(-10deg);
}

.logo-wordmark {
  font-family: "MyUploadedFont", system-ui, sans-serif;
  font-size: 1.5rem;
  color: var(--catlap-black);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-shadow: 2px 2px 0 var(--catlap-yellow);
}

.nav-links {
  display: flex;
  gap: 1.1rem;
  font-size: 0.9rem;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.nav-links a {
  position: relative;
  padding: 0.15rem 0.25rem;
}

.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px;
  width: 0;
  height: 3px;
  background: var(--catlap-black);
  transition: width 0.18s ease;
}

.nav-links a:hover::after {
  width: 100%;
}

@media (max-width: 720px) {
  .nav-bar {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* =========================
   Hero Section
   ========================== */

.hero {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.5fr);
  gap: 1.6rem;
  align-items: center;
}

.hero-image-wrap {
  position: relative;
}

/* Use catlap26.webp or CD art as hero image in HTML */
.hero-image {
  display: block;
  width: 100%;
  max-width: 520px;
  height: auto;
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.55);
  transform: rotate(-4deg);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.hero-image:hover {
  transform: rotate(0deg) translateY(-4px) scale(1.02);
  box-shadow: 0 24px 40px rgba(0, 0, 0, 0.7);
}

/* Bubble tag: like stamped type over the poster */
.hero-bubble {
  position: absolute;
  right: -16px;
  bottom: -20px;
  background: var(--catlap-pink);
  color: var(--catlap-yellow);
  border-radius: 999px;
  border: 4px solid var(--catlap-black);
  padding: 0.6rem 1.4rem;
  font-family: "MyUploadedFont", system-ui, sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.5);
  text-shadow: 2px 2px 0 var(--catlap-black);
  animation: heroFloat 3.5s ease-in-out infinite alternate;
}

@keyframes heroFloat {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-6px);
  }
}

.hero-content {
  background: var(--catlap-blue);
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  padding: 1.5rem 1.5rem 1.7rem;
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.55);
  position: relative;
  overflow: hidden;
}

.hero-content::before {
  content: "";
  position: absolute;
  inset: -40px;
  background:
    radial-gradient(circle at 10% 90%, rgba(244,81,157,0.8) 0 32%, transparent 40%),
    radial-gradient(circle at 110% 0%, rgba(102,195,67,0.8) 0 30%, transparent 40%);
  mix-blend-mode: multiply;
  opacity: 0.7;
  pointer-events: none;
}

.hero-inner {
  position: relative;
  z-index: 1;
}

.hero-tagline {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.25rem 0.9rem;
  border-radius: 999px;
  border: 3px solid var(--catlap-black);
  background: var(--catlap-yellow);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 0.8rem;
}

.hero-tagline .paw {
  display: inline-block;
  transform: rotate(-12deg);
}

.hero-content h1 {
  color: var(--catlap-yellow);
}

.hero-description,
.hero-note,
.hero-content p {
  color: var(--catlap-yellow);
}

.hero-description {
  font-size: 0.96rem;
  max-width: 32rem;
}

.hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0.9rem 0 1.1rem;
}

.meta-pill {
  padding: 0.45rem 0.85rem;
  border-radius: 999px;
  border: 3px solid var(--catlap-black);
  background: var(--catlap-green);
  color: var(--catlap-black);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}

.meta-pill.secondary {
  background: var(--catlap-pink);
}

/* Buttons – bold poster blocks */
.btn-primary,
.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  border-radius: 999px;
  padding: 0.6rem 1.5rem;
  font-family: "MyUploadedFont", system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.95rem;
  border-width: 3px;
  border-style: solid;
  cursor: pointer;
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease,
    background-color 0.15s ease,
    color 0.15s ease;
}

.btn-primary {
  background: var(--catlap-pink);
  color: var(--catlap-yellow);
  border-color: var(--catlap-black);
  box-shadow: 0 7px 18px rgba(0, 0, 0, 0.55);
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 11px 26px rgba(0, 0, 0, 0.7);
  background: var(--catlap-black);
}

.btn-outline {
  background: var(--catlap-yellow);
  color: var(--catlap-black);
  border-color: var(--catlap-black);
}

.btn-outline:hover {
  background: var(--catlap-blue);
  color: #ffffff;
}

.hero-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  align-items: center;
}

.hero-note {
  font-size: 0.8rem;
  margin-top: 0.7rem;
}

@media (max-width: 880px) {
  .hero {
    grid-template-columns: 1fr;
  }

  .hero-image-wrap {
    order: -1;
    justify-self: center;
  }

  .hero-image {
    max-width: 360px;
  }

  .hero-bubble {
    right: -4px;
    bottom: -10px;
    font-size: 1rem;
  }
}

/* =========================
   Countdown Strip
   ========================== */

.countdown {
  margin-top: 2.4rem;
  display: flex;
  justify-content: center;
}

.countdown-inner {
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  background:
    linear-gradient(
      135deg,
      rgba(244, 81, 157, 0.3),
      rgba(0, 163, 230, 0.3)
    ),
    var(--catlap-black);
  color: var(--catlap-yellow);
  padding: 1.1rem 1.4rem 1.3rem;
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.7);
  text-align: center;
}

.countdown-inner h2 {
  margin-bottom: 0.6rem;
}

/* Timer row */
.timer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.7rem;
  margin-top: 0.25rem;
}

/* Individual time blocks */
.time-box {
  flex: 1 1 90px;
  max-width: 140px;
  min-width: 90px;
  background: var(--catlap-blue);
  border-radius: 0;
  border: 3px solid var(--catlap-yellow);
  padding: 0.55rem 0.7rem 0.6rem;
  text-align: center;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.75);
}

/* Number */
.time-box span:first-child {
  display: block;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: clamp(1.6rem, 3.2vw, 2.2rem);
  letter-spacing: 0.06em;
  margin-bottom: 0.1rem;
}

/* Label (days/hours/etc) */
.time-box .label {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    Roboto, Arial, sans-serif;
  font-weight: 800;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
}

/* Sub text under the timer */
.countdown-sub {
  margin-top: 0.75rem;
  font-size: 0.82rem;
  color: #fffad2;
}

/* Small screens */
@media (max-width: 520px) {
  .time-box {
    flex: 1 1 100%;
    max-width: 100%;
  }
}

/* =========================
   Section Header
   ========================== */

.section-header {
  margin-top: 2.4rem;
  margin-bottom: 1.1rem;
}

.section-header p {
  max-width: 34rem;
}

/* =========================
   Formats
   ========================== */

.formats {
  margin-top: 1.5rem;
}

.format-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.2rem;
  align-items: stretch;
}

/* Equal-height cards with stronger poster feel */
.format-card {
  background: var(--catlap-yellow);
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  padding: 1rem 1rem 1.1rem;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.6);
  position: relative;
  overflow: hidden;

  /* Make content stack and fill height */
  display: flex;
  flex-direction: column;
}

/* subtle internal noise / color blend */
.format-card::before {
  content: "";
  position: absolute;
  inset: -30px;
  background:
    radial-gradient(circle at 0% 0%, rgba(244, 81, 157, 0.6) 0 30%, transparent 40%),
    radial-gradient(circle at 120% 120%, rgba(0, 163, 230, 0.6) 0 30%, transparent 40%);
  opacity: 0.45;
  pointer-events: none;
  mix-blend-mode: multiply;
}

.format-card h3,
.format-card p,
.format-card ul,
.format-card .card-link {
  position: relative;
  z-index: 1;
}

/* Heading with cat badge icon */
.format-card h3 {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.4rem;
  color: #ffffff;
  text-shadow: 2px 2px 0 var(--catlap-black);
}

/* Circular icon pulled from the color cat webps */
.format-card h3::before {
  content: "";
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 3px solid var(--catlap-black);
  background-size: cover;
  background-position: center;
  background-color: var(--catlap-yellow);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.6);
}

/* Map card 1/2/3 to each cat color photo
   Adjust the paths if your images live somewhere else. */
.format-card:nth-child(1) h3::before {
  /* card 1 – clacky green */
  background-image: url("../photos/clackygreen.webp");
}

.format-card:nth-child(2) h3::before {
  /* card 2 – tony pink */
  background-image: url("../photos/tonypink.webp");
}

.format-card:nth-child(3) h3::before {
  /* card 3 – klicky blue */
  background-image: url("../photos/klickyblue.webp");
}

/* Alt card still uses pink background but keeps white headings */
.format-card.alt {
  background: var(--catlap-pink);
  color: var(--catlap-black);
}

.format-card.alt p,
.format-card.alt li {
  color: var(--catlap-black);
}

/* Body text / list */
.format-card ul {
  padding-left: 1.1rem;
  margin: 0 0 0.6rem;
  font-size: 0.9rem;
}

.format-card li {
  margin-bottom: 0.2rem;
}

/* Push CTA link to the bottom so cards line up cleanly */
.card-link {
  display: inline-flex;
  padding: 0.25rem 0.7rem;
  border-radius: 999px;
  border: 3px solid var(--catlap-black);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: var(--catlap-blue);
  color: #ffffff;
  margin-top: auto;   /* equal-height magic */
}

.card-link:hover {
  background: #ffffff;
  color: var(--catlap-black);
}

/* Responsive */
@media (max-width: 960px) {
  .format-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .format-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================
   Feline Race Committee
   ========================== */

.committee {
  margin-top: 2.4rem;
}

/* 3-column grid on desktop, collapses down responsively */
.committee-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.2rem;
  align-items: stretch;
}

/* Equal-height poster-style cards */
.committee-card {
  background: var(--catlap-yellow);
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  padding: 1rem 1rem 1.1rem;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.7);

  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

/* noisy poster wash */
.committee-card::before {
  content: "";
  position: absolute;
  inset: -30px;
  background:
    radial-gradient(circle at 0% 0%, rgba(244, 81, 157, 0.6) 0 30%, transparent 40%),
    radial-gradient(circle at 120% 120%, rgba(0, 163, 230, 0.6) 0 30%, transparent 40%);
  opacity: 0.45;
  pointer-events: none;
  mix-blend-mode: multiply;
}

.committee-card > * {
  position: relative;
  z-index: 1;
}

/* header row: avatar + name/role */
.committee-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

/* circular avatar using the tinted cat webps */
.committee-avatar {
  flex: 0 0 52px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 3px solid var(--catlap-black);
  overflow: hidden;
  box-shadow: 0 5px 12px rgba(0, 0, 0, 0.7);
  background: var(--catlap-yellow);
}

.committee-avatar img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Name + role text */
.committee-heading h3 {
  margin: 0;
  color: #ffffff;
  text-shadow: 2px 2px 0 var(--catlap-black);
}

.committee-role {
  margin: 0.15rem 0 0;
  font-size: 0.8rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--catlap-black);
}

/* Cats’ bullet lists */
.committee-list {
  padding-left: 1.1rem;
  margin: 0.2rem 0 0.6rem;
  font-size: 0.9rem;
}

.committee-list li {
  margin-bottom: 0.25rem;
}

/* tagline sits at the bottom so cards line up */
.committee-tagline {
  margin-top: auto;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ink-soft);
}

/* per-cat tints */
.committee-card--clack {
  background: var(--catlap-green);
}
.committee-card--klick {
  background: var(--catlap-blue);
}
.committee-card--wash {
  background: var(--catlap-pink);
}

.committee-card--clack h3,
.committee-card--klick h3,
.committee-card--wash h3 {
  color: #ffffff;
}

/* Responsive behavior */
@media (max-width: 960px) {
  .committee-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .committee-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================
   FAQ
   ========================== */

.faq {
  margin-top: 2.4rem;
}

.faq-list {
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.6);
  overflow: hidden;
}

.faq-item + .faq-item {
  border-top: 3px solid var(--catlap-black);
}

/* Tweak FAQ question typography for readability */
.faq-question {
  width: 100%;
  padding: 0.8rem 0.9rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  background: transparent;
  border: none;
  cursor: pointer;

  /* more legible type */
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    Roboto, Arial, sans-serif;
  font-size: 0.98rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

/* specifically target the text part of the question */
.faq-question span:first-child {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    Roboto, Arial, sans-serif;
  font-weight: 800;
}

/* keep the + icon in the funky display font if you like */
.faq-icon {
  font-family: "MyUploadedFont", system-ui, sans-serif;
  font-size: 1.2rem;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  padding: 0 0.9rem;
  transition:
    max-height 0.2s ease,
    padding-top 0.2s ease,
    padding-bottom 0.2s ease;
}

.faq-answer p {
  font-size: 0.88rem;
}

/* open state */
.faq-item--open .faq-answer {
  max-height: 220px;
  padding-top: 0.25rem;
  padding-bottom: 0.7rem;
}

.faq-item--open .faq-icon {
  transform: rotate(45deg);
}

/* =========================
   Cat Squish Gallery
   ========================== */

.squish {
  margin-top: 2.4rem;
}

.squish-controls {
  margin-bottom: 0.75rem;
  display: flex;
  justify-content: flex-start;
}

.squish .squish-shuffle {
  font-size: 0.8rem;
  padding: 0.45rem 1.1rem;
}

.squish-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1rem;
  justify-items: center;
}

/* Polaroid-style but in poster colors */
.squish-card {
  width: 180px !important;
  max-width: 70vw !important;
  background: var(--catlap-yellow);
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  padding: 0.5rem 0.5rem 0.7rem;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.7);
  position: relative;
  transform-origin: center center;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

/* fake tape at the top */
.squish-card::before {
  content: "";
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%) rotate(-4deg);
  width: 72px;
  height: 18px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px dashed rgba(0, 0, 0, 0.35);
}

/* slight random tilt per card */
.squish-card:nth-child(1) { transform: rotate(-4deg); }
.squish-card:nth-child(2) { transform: rotate(3deg); }
.squish-card:nth-child(3) { transform: rotate(-7deg); }
.squish-card:nth-child(4) { transform: rotate(5deg); }
.squish-card:nth-child(5) { transform: rotate(-2deg); }

/* HARD CAP: image size */
.squish-card img {
  display: block;
  width: 100% !important;
  max-width: 160px !important;
  height: auto !important;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  margin: 0 auto;
  border-radius: 0;
  border: 3px solid var(--catlap-black);
  background: var(--page-bg);
}

/* Tonal tints per cat */
.squish-card.squish-tony {
  background: var(--catlap-pink);
}
.squish-card.squish-klick {
  background: var(--catlap-blue);
}
.squish-card.squish-clack {
  background: var(--catlap-green);
}

.squish-card figcaption {
  margin-top: 0.4rem;
  font-size: 0.8rem;
  text-align: center;
  font-weight: 700;
}

/* hover straightens them out a bit */
.squish-card:hover {
  transform: rotate(0deg) translateY(-4px) scale(1.03);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.8);
}

/* =========================
   Audio Banner
   ========================== */

.audio-banner {
  position: fixed;
  left: 1rem;
  bottom: 1rem;
  z-index: 50;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.audio-banner--hidden {
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
}

.audio-banner--visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.audio-toggle {
  border: 3px solid var(--catlap-black);
  background: var(--catlap-yellow);
  color: var(--catlap-black);
  font-family: "MyUploadedFont", system-ui, sans-serif;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border-radius: 999px;
  padding: 0.45rem 1.1rem;
  cursor: pointer;
  box-shadow: 0 7px 16px rgba(0, 0, 0, 0.6);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.audio-toggle[aria-pressed="true"] {
  background: var(--catlap-blue);
  color: #ffffff;
}

/* =========================
   Format Carousel
   ========================== */

.format-carousel {
  margin-top: 2.8rem;
}

.format-carousel-shell {
  position: relative;
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.7);
  overflow: hidden;
  padding: 1.1rem 2.4rem;
}

.format-carousel-track {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  width: 100%;
  transform: translateX(0);
  transition: transform 0.3s ease;
  position: relative;
  z-index: 1;
}

.format-carousel-slide {
  flex: 0 0 100%;
  padding: 0.25rem 0;
  position: relative;
  z-index: 1;
}

.format-carousel-card {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.4fr);
  gap: 1.25rem;
  align-items: center;
}

.format-carousel-media {
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Use tonypink/klickyblue/clackygreen.webp in HTML; this just styles the frame */
.format-carousel-media img {
  display: block;
  width: 100%;
  max-width: 220px;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  background: var(--page-bg);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.7);
  transform: rotate(-4deg);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.format-carousel-slide:nth-child(2) .format-carousel-media img {
  transform: rotate(3deg);
}
.format-carousel-slide:nth-child(3) .format-carousel-media img {
  transform: rotate(-6deg);
}

.format-carousel-slide:hover .format-carousel-media img {
  transform: rotate(0deg) translateY(-4px) scale(1.03);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.8);
}

.format-carousel-content h3 {
  margin-bottom: 0.3rem;
}

.format-carousel-content p {
  font-size: 0.9rem;
}

.format-carousel-meta {
  margin-top: 0.5rem;
  font-size: 0.82rem;
  color: #555555;
}

/* Arrows */
.format-carousel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 3px solid var(--catlap-black);
  background: var(--catlap-yellow);
  color: var(--catlap-black);
  font-family: "MyUploadedFont", system-ui, sans-serif;
  font-size: 1.4rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 7px 18px rgba(0, 0, 0, 0.7);
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
  z-index: 5;
}

.format-carousel-arrow--prev {
  left: 0.7rem;
}

.format-carousel-arrow--next {
  right: 0.7rem;
}

.format-carousel-arrow:hover {
  transform: translateY(-50%) translateY(-2px);
  box-shadow: 0 11px 24px rgba(0, 0, 0, 0.85);
  background: var(--catlap-blue);
  color: #ffffff;
}

/* Dots / progress pills */
.format-carousel-dots {
  display: flex;
  justify-content: center;
  gap: 0.4rem;
  margin-top: 0.7rem;
}

.format-carousel-dot {
  width: 18px;
  height: 6px;
  border-radius: 999px;
  border: 2px solid var(--catlap-black);
  background: #ffffff;
  cursor: pointer;
  padding: 0;
}

.format-carousel-dot.is-active {
  background: var(--catlap-pink);
}

/* Responsive tweaks */
@media (max-width: 880px) {
  .format-carousel-shell {
    padding: 1rem 1.2rem;
  }

  .format-carousel-card {
    grid-template-columns: minmax(0, 1fr);
  }

  .format-carousel-media img {
    max-width: 180px;
  }

  .format-carousel-arrow--prev {
    left: 0.4rem;
  }

  .format-carousel-arrow--next {
    right: 0.4rem;
  }
}

@media (max-width: 600px) {
  .format-carousel-shell {
    padding: 0.9rem 1rem 1rem;
  }

  .format-carousel-arrow {
    width: 30px;
    height: 30px;
    font-size: 1.2rem;
  }
}

/* =========================
   Global "Register Now" Button
   ========================== */

.catlap-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6rem 1.4rem;
  border-radius: 999px;
  border: 3px solid var(--catlap-black);
  font-size: 0.92rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  cursor: pointer;
  box-shadow: 3px 3px 0 var(--catlap-black);
  text-decoration: none;
  transition:
    transform 0.12s ease,
    box-shadow 0.12s ease,
    background-color 0.12s ease,
    color 0.12s ease;
}

/* Primary register button */
.catlap-btn--register {
  background: var(--catlap-yellow);
  color: var(--catlap-black);
}

/* Secondary / ghost version (if you want it on white cards) */
.catlap-btn--ghost {
  background: #ffffff;
  color: var(--catlap-black);
}

/* Hover / active states */
.catlap-btn:hover {
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 var(--catlap-black);
}

.catlap-btn:active {
  transform: translate(0, 0);
  box-shadow: 2px 2px 0 var(--catlap-black);
}

/* CTA row layout */
.catlap-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
  justify-content: center; /* center everywhere by default */
  margin-top: 1rem;
}

/* Hero keeps its CTAs left-aligned */
.hero .catlap-cta-row {
  justify-content: flex-start;
}


@media (max-width: 640px) {
  .catlap-cta-row {
    flex-direction: column;
    align-items: center; /* keep non-hero CTAs centered */
  }

  .hero .catlap-cta-row {
    align-items: flex-start; /* hero stays left-aligned */
  }
}

/* Pre-footer CTA stripe */

.catlap-prefooter-cta {
  margin-top: 3rem;
}

.catlap-prefooter-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 1.4rem 1.25rem 1.6rem;
  background: #ffffff;
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.6);
  display: flex;
  gap: 1.2rem;
  align-items: center;
  justify-content: space-between;
}

.catlap-prefooter-copy h2 {
  margin: 0 0 0.35rem;
  font-size: 1.4rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #000000;
  text-shadow: 2px 2px 0 #fef100;
}

.catlap-prefooter-copy p {
  margin: 0;
  font-size: 0.95rem;
  color: var(--ink-soft);
}

.catlap-prefooter-action {
  flex-shrink: 0;
}

@media (max-width: 720px) {
  .catlap-prefooter-inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ============ Global Header & Nav ============ */

.site-header {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0.75rem 1.25rem 0.25rem;
}

.nav-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

/* Logo */

.logo-text {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
  color: var(--catlap-black);
}

.logo-badge {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 28% 28%,
      #ffffff 0%,
      #ffffff 14%,
      #fef100 15%,
      var(--catlap-pink) 55%,
      var(--catlap-black) 100%
    );
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "MyUploadedFont", system-ui, sans-serif;
  font-size: 1.1rem;
  color: #ffffff;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.5);
  transform: rotate(-10deg);
}

.logo-wordmark {
  font-family: "MyUploadedFont", system-ui, sans-serif;
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  text-shadow: 2px 2px 0 #fef100;
}

/* Desktop nav links */

.nav-links {
  display: flex;
  gap: 1.1rem;
  flex-wrap: wrap;
  font-size: 0.9rem;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.nav-link {
  position: relative;
  padding: 0.15rem 0.25rem;
  text-decoration: none;
  color: var(--catlap-black);
}

.nav-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -3px;
  width: 0;
  height: 3px;
  background: var(--catlap-black);
  transition: width 0.18s ease;
}

.nav-link:hover::after,
.nav-link--active::after {
  width: 100%;
}

/* Hamburger button */

.nav-toggle {
  display: none; /* hidden on desktop */
  background: transparent;
  border: none;
  padding: 0.25rem;
  cursor: pointer;
}

.nav-toggle span {
  display: block;
  width: 22px;
  height: 3px;
  background: var(--catlap-black);
  margin: 4px 0;
  transition:
    transform 0.2s ease,
    opacity 0.2s ease;
}

/* ============ Mobile behavior ============ */

@media (max-width: 720px) {
  .nav-bar {
    align-items: center;
  }

  .nav-toggle {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
  }

  .nav-links {
    position: absolute;
    top: 60px;
    left: 0;
    right: 0;
    padding: 0.75rem 1.25rem 1rem;
    background: rgba(255, 255, 255, 0.96);
    border-top: 3px solid var(--catlap-black);
    border-bottom: 3px solid var(--catlap-black);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.35);
    flex-direction: column;
    gap: 0.6rem;
    transform: translateY(-120%);
    opacity: 0;
    pointer-events: none;
    transition:
      transform 0.2s ease,
      opacity 0.2s ease;
    z-index: 50;
  }

  /* When nav is open (body.nav-open), show menu */
  body.nav-open .nav-links {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  .nav-link {
    padding: 0.25rem 0;
  }

  /* Animate hamburger into X when open */
  body.nav-open .nav-toggle span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  body.nav-open .nav-toggle span:nth-child(2) {
    opacity: 0;
  }

  body.nav-open .nav-toggle span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }
}

/* =========================
   Formats Section
   ========================== */

.formats {
  margin-top: 2.4rem;
  padding-bottom: 3rem;
}

.formats .section-header {
  margin: 0 0 1.4rem;
}

/* outer grid: three cards on desktop, stack down as screen shrinks */
.format-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.6rem;
  align-items: stretch;
}

/* poster-style cards, same language as countdown/committee */
.format-card {
  background: var(--catlap-yellow);
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  padding: 1.25rem 1.5rem 1.4rem;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.7);
  position: relative;
  overflow: hidden;
}

/* noisy overlay */
.format-card::before {
  content: "";
  position: absolute;
  inset: -30px;
  background:
    radial-gradient(circle at 0% 0%, rgba(244, 81, 157, 0.6) 0 30%, transparent 40%),
    radial-gradient(circle at 120% 120%, rgba(0, 163, 230, 0.6) 0 30%, transparent 40%);
  opacity: 0.45;
  pointer-events: none;
  mix-blend-mode: multiply;
}

.format-card-inner,
.format-card > * {
  position: relative;
  z-index: 1;
}

/* per-format tint, like committee cards */
.format-card--clacky {
  background: var(--catlap-green);
}
.format-card--tony {
  background: var(--catlap-pink);
}
.format-card--klicky {
  background: var(--catlap-blue);
}

/* inner layout: copy + photo in a grid so it feels less cramped */
.format-card-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(120px, 0.9fr);
  align-items: center;
  column-gap: 1.5rem;
  row-gap: 0.75rem;
}

/* text column */
.format-copy {
  max-width: 26rem;
}

.format-copy h3 {
  margin: 0 0 0.5rem;
  color: #ffffff;
  text-shadow: 2px 2px 0 var(--catlap-black);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 1.1rem; /* a hair smaller than global h3 so it doesn’t shout */
  line-height: 1.2;
}

/* remove the circular badge in this section – the polaroid is enough */
.formats .format-card h3::before {
  content: none;
  display: none;
}

.format-copy p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.6;
  color: #111111;
}

/* photo column – big enough to feel like album art, not so big it crowds */
.cat-photo {
  margin: 0;
  justify-self: end;
  width: 100%;
  max-width: 210px;
  position: relative;
  background: #ffffff;
  border-radius: 0;
  border: 4px solid var(--catlap-black);
  padding: 0.35rem;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.7);
}

.cat-photo img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 0;
  border: 3px solid var(--catlap-black);
}

/* tape strip on top of the photo */
.cat-photo::before {
  content: "";
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%) rotate(-4deg);
  width: 72%;
  height: 16px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px dashed rgba(0, 0, 0, 0.35);
}

/* subtle tilt per cat */
.cat-photo--clacky { transform: rotate(-6deg); }
.cat-photo--tony   { transform: rotate(4deg); }
.cat-photo--klicky { transform: rotate(-3deg); }

/* shared CTA under grid */
.formats-cta-row {
  max-width: var(--max-width);
  margin: 2rem auto 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.catlap-btn.catlap-btn--register-all {
  font-size: 1.05rem;
  padding: 0.9rem 2.8rem;
  text-transform: lowercase;
  box-shadow: 5px 5px 0 var(--catlap-black);
}

/* responsive breakpoints */

@media (max-width: 960px) {
  .format-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .format-grid {
    grid-template-columns: 1fr;
  }

  .format-card-inner {
    grid-template-columns: 1fr;
  }

  .cat-photo {
    justify-self: flex-start;
    max-width: 220px;
  }
}
