

body[data-product="keyboard-warrior"] {
  --bg: #06080e;
  --bg-2: #0b0f1a;
  --bg-3: #11172a;
  --ink: #f4f6fb;
  --ink-dim: rgba(244, 246, 251, .62);
  --ink-faint: rgba(244, 246, 251, .4);
  --line: rgba(255, 255, 255, .08);
  --kw-accent: #ff5a3c;
  --kw-gold: #ffc14d;
  --kw-glow: rgba(255, 90, 60, .55);
  --ease: cubic-bezier(.16, 1, .3, 1);

  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
}

body[data-product="keyboard-warrior"] #main-content {
  background: var(--bg);
}

body[data-product="keyboard-warrior"] .kw-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
body[data-product="keyboard-warrior"] .kw-cap {
  width: min(1200px, 92vw);
  margin-inline: auto;
}

body[data-product="keyboard-warrior"] .kw-section {
  padding-block: clamp(6rem, 12vh, 11rem);
  position: relative;
}

body[data-product="keyboard-warrior"] .kw-display {
  font-family: "Oswald", "Archivo", system-ui, sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -.01em;
  line-height: .98;
  text-wrap: balance;
  font-size: clamp(2.2rem, 6vw, 5rem);
  margin: 0;
}
body[data-product="keyboard-warrior"] .kw-display--xl {
  font-size: clamp(2.6rem, 7.5vw, 6.5rem);
  font-weight: 800;
}
body[data-product="keyboard-warrior"] .kw-eyebrow {
  font-family: "Oswald", system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .34em;
  font-size: .72rem;
  font-weight: 600;
  color: var(--ink-faint);
  margin: 0 0 1.1rem;
  display: block;
}
body[data-product="keyboard-warrior"] .kw-eyebrow--accent {
  color: var(--kw-gold);
}
body[data-product="keyboard-warrior"] .kw-body {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  font-weight: 400;
  font-size: clamp(1rem, 1.05vw, 1.125rem);
  line-height: 1.6;
  color: var(--ink-dim);
  max-width: 58ch;
  margin: 1.4rem 0 0;
}

body[data-product="keyboard-warrior"] .kw-ghost {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-family: "Oswald", system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  padding: .95rem 1.9rem;
  border: 1px solid rgba(255, 255, 255, .4);
  border-radius: 999px;
  background: rgba(255, 255, 255, .02);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor: pointer;
  transition: border-color .5s var(--ease), background .5s var(--ease),
    box-shadow .5s var(--ease), transform .5s var(--ease);
}
body[data-product="keyboard-warrior"] .kw-ghost:hover {
  border-color: var(--kw-accent);
  background: rgba(255, 90, 60, .1);
  box-shadow: 0 0 32px -6px var(--kw-glow);
  transform: translateY(-2px);
}

body[data-product="keyboard-warrior"] .kw-hero {
  position: relative;
  min-height: 100svh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
body[data-product="keyboard-warrior"] .kw-hero__art {
  position: absolute;
  inset: 0;
  background-image: url("/assets/images/apps/keyboard-warrior/hero-bg.webp");
  background-size: cover;
  background-position: center 42%;
  transform: scale(1.05);
  animation: kw-kenburns 28s ease-in-out infinite alternate;
  z-index: 0;
}
@keyframes kw-kenburns {
  from { transform: scale(1.05); }
  to   { transform: scale(1.12); }
}
body[data-product="keyboard-warrior"] .kw-hero__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(6, 8, 14, .55), transparent 28%, transparent 55%, rgba(6, 8, 14, .92)),
    radial-gradient(120% 80% at 50% 38%, transparent 40%, rgba(6, 8, 14, .6));
}

body[data-product="keyboard-warrior"] .kw-hero__cutout {
  position: absolute;
  z-index: 1;
  right: clamp(-4rem, -2vw, 0rem);
  bottom: 0;
  width: clamp(320px, 42vw, 720px);
  height: auto;
  pointer-events: none;
  filter: drop-shadow(0 22px 60px rgba(0, 0, 0, .6));
  animation: kw-cutout-float 9s ease-in-out infinite alternate;
}
@keyframes kw-cutout-float {
  from { transform: translateY(0); }
  to   { transform: translateY(-12px); }
}
body[data-product="keyboard-warrior"] .kw-hero__content {
  position: relative;
  z-index: 2;
  padding: 0 6vw 14vh;
  width: 100%;
  text-align: center;
}
body[data-product="keyboard-warrior"] .kw-hero__logo {
  width: min(640px, 82vw);
  height: auto;
  margin: 0 auto;
  display: block;
  filter: drop-shadow(0 0 38px rgba(255, 90, 60, .35)) drop-shadow(0 8px 24px rgba(0, 0, 0, .7));
}
body[data-product="keyboard-warrior"] .kw-hero__eyebrow {
  margin: 1.8rem 0 0;
  letter-spacing: .34em;
  font-family: "Oswald", system-ui, sans-serif;
  text-transform: uppercase;
  font-size: .8rem;
  font-weight: 600;
  color: var(--ink-faint);
}
body[data-product="keyboard-warrior"] .kw-hero__tag {
  font-family: "Inter", system-ui, sans-serif;
  color: var(--ink-dim);
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  max-width: 46ch;
  margin: 1.1rem auto 0;
  line-height: 1.5;
}
body[data-product="keyboard-warrior"] .kw-hero__actions {
  margin-top: 2.2rem;
}

body[data-product="keyboard-warrior"] .kw-scrollcue {
  position: absolute;
  left: 50%;
  bottom: 2.2rem;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  color: var(--ink-faint);
  text-decoration: none;
  font-family: "Oswald", system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .28em;
  font-size: .62rem;
}
body[data-product="keyboard-warrior"] .kw-scrollcue svg {
  animation: kw-bob 2.2s ease-in-out infinite;
}
@keyframes kw-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(6px); }
}

body[data-product="keyboard-warrior"] .kw-breather {
  background: var(--bg);
  text-align: center;
  padding-block: clamp(7rem, 16vh, 13rem);
}
body[data-product="keyboard-warrior"] .kw-breather .kw-display {
  max-width: 16ch;
  margin-inline: auto;
}
body[data-product="keyboard-warrior"] .kw-breather .kw-accent-word {
  color: var(--kw-accent);
}
body[data-product="keyboard-warrior"] .kw-breather .kw-body {
  margin-inline: auto;
  text-align: center;
  max-width: 52ch;
}

body[data-product="keyboard-warrior"] .kw-story {
  position: relative;
  min-height: 86vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
body[data-product="keyboard-warrior"] .kw-story__art {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
}
body[data-product="keyboard-warrior"] .kw-story__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(6, 8, 14, .35), transparent 30%, transparent 50%, rgba(6, 8, 14, .96)),
    radial-gradient(120% 70% at 30% 80%, rgba(6, 8, 14, .7), transparent 60%);
}
body[data-product="keyboard-warrior"] .kw-story__copy {
  position: relative;
  z-index: 2;
  max-width: 560px;
  padding: 0 6vw clamp(4rem, 9vh, 8rem);
}

body[data-product="keyboard-warrior"] .kw-roster {
  background: linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
}
body[data-product="keyboard-warrior"] .kw-roster__head {
  width: min(1200px, 92vw);
  margin: 0 auto clamp(2.5rem, 5vh, 4rem);
  text-align: center;
}
body[data-product="keyboard-warrior"] .kw-rail {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: clamp(220px, 26vw, 300px);
  gap: 1.1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding: .5rem clamp(1rem, 6vw, 6vw) 1.5rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 90, 60, .4) transparent;
}
body[data-product="keyboard-warrior"] .kw-rail::-webkit-scrollbar { height: 6px; }
body[data-product="keyboard-warrior"] .kw-rail::-webkit-scrollbar-thumb {
  background: rgba(255, 90, 60, .4);
  border-radius: 999px;
}
body[data-product="keyboard-warrior"] .kw-card {
  scroll-snap-align: center;
  position: relative;
  aspect-ratio: 3 / 4;
  border-radius: 18px;
  overflow: hidden;
  background: var(--bg-3);
  border: 1px solid var(--line);
  transition: transform .55s var(--ease), box-shadow .55s var(--ease), border-color .55s var(--ease);
}
body[data-product="keyboard-warrior"] .kw-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transition: transform .65s var(--ease), filter .65s var(--ease);
  filter: saturate(.92) brightness(.92);
}
body[data-product="keyboard-warrior"] .kw-card__foot {
  position: absolute;
  inset: auto 0 0 0;
  z-index: 2;
  padding: 2.4rem 1.1rem 1rem;
  background: linear-gradient(180deg, transparent, rgba(6, 8, 14, .92));
}
body[data-product="keyboard-warrior"] .kw-card__name {
  font-family: "Oswald", system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-weight: 700;
  font-size: 1.15rem;
  margin: 0;
}
body[data-product="keyboard-warrior"] .kw-card__trait {
  font-family: "Inter", system-ui, sans-serif;
  font-size: .82rem;
  color: var(--ink-dim);
  margin: .2rem 0 0;
}
body[data-product="keyboard-warrior"] .kw-card:hover {
  transform: translateY(-6px);
  border-color: rgba(255, 90, 60, .45);
  box-shadow: 0 24px 50px -22px rgba(0, 0, 0, .9), 0 0 40px -16px var(--kw-glow);
}
body[data-product="keyboard-warrior"] .kw-card:hover img {
  transform: scale(1.06);
  filter: saturate(1.05) brightness(1.05);
}
body[data-product="keyboard-warrior"] .kw-card--bonus {
  border-color: rgba(255, 193, 77, .35);
}
body[data-product="keyboard-warrior"] .kw-card--bonus .kw-card__name { color: var(--kw-gold); }

body[data-product="keyboard-warrior"] .kw-module {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: clamp(2rem, 5vw, 5rem);
  width: min(1200px, 92vw);
  margin-inline: auto;
  padding-block: clamp(3rem, 7vh, 6rem);
}
body[data-product="keyboard-warrior"] .kw-module--flip .kw-module__art { order: -1; }
body[data-product="keyboard-warrior"] .kw-module__art {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--line);
  aspect-ratio: 3 / 2;
  background: var(--bg-3);
}
body[data-product="keyboard-warrior"] .kw-module__art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .8s var(--ease);
}
body[data-product="keyboard-warrior"] .kw-module__art::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(110% 110% at 70% 20%, transparent 50%, rgba(6, 8, 14, .55));
  pointer-events: none;
}
body[data-product="keyboard-warrior"] .kw-module__art:hover img { transform: scale(1.04); }
body[data-product="keyboard-warrior"] .kw-module__copy .kw-body { margin-bottom: 0; }

body[data-product="keyboard-warrior"] .kw-stats {
  list-style: none;
  margin: 1.8rem 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
body[data-product="keyboard-warrior"] .kw-stats li {
  font-family: "Oswald", system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .68rem;
  font-weight: 600;
  color: var(--ink-dim);
  padding: .42rem .85rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, .02);
}

body[data-product="keyboard-warrior"] .kw-enemies {
  background: var(--bg-2);
}
body[data-product="keyboard-warrior"] .kw-enemies__head {
  width: min(1200px, 92vw);
  margin: 0 auto clamp(2.2rem, 4vh, 3.4rem);
  text-align: center;
}
body[data-product="keyboard-warrior"] .kw-enemy-grid {
  width: min(1200px, 92vw);
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
}
body[data-product="keyboard-warrior"] .kw-enemy {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--bg-3);
  transition: transform .5s var(--ease), border-color .5s var(--ease), box-shadow .5s var(--ease);
}
body[data-product="keyboard-warrior"] .kw-enemy img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(.9) brightness(.9);
  transition: transform .6s var(--ease), filter .6s var(--ease);
}
body[data-product="keyboard-warrior"] .kw-enemy__name {
  position: absolute;
  inset: auto 0 0 0;
  z-index: 2;
  padding: 1.6rem .7rem .55rem;
  background: linear-gradient(180deg, transparent, rgba(6, 8, 14, .9));
  font-family: "Oswald", system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .03em;
  font-size: .72rem;
  font-weight: 600;
  color: var(--ink);
}
body[data-product="keyboard-warrior"] .kw-enemy:hover {
  transform: translateY(-4px);
  border-color: rgba(255, 90, 60, .45);
  box-shadow: 0 0 32px -12px var(--kw-glow);
}
body[data-product="keyboard-warrior"] .kw-enemy:hover img {
  transform: scale(1.08);
  filter: saturate(1.05) brightness(1.05);
}

body[data-product="keyboard-warrior"] .kw-bosses {
  background: var(--bg);
}
body[data-product="keyboard-warrior"] .kw-bosses__head {
  width: min(1200px, 92vw);
  margin: 0 auto clamp(2.4rem, 5vh, 3.8rem);
  text-align: center;
}
body[data-product="keyboard-warrior"] .kw-boss-list {
  width: min(900px, 92vw);
  margin-inline: auto;
  display: grid;
  gap: .9rem;
}
body[data-product="keyboard-warrior"] .kw-boss {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.4rem;
  align-items: baseline;
  padding: 1.3rem 1.6rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .02), transparent);
  transition: border-color .5s var(--ease), background .5s var(--ease);
}
body[data-product="keyboard-warrior"] .kw-boss:hover {
  border-color: rgba(255, 90, 60, .4);
  background: linear-gradient(180deg, rgba(255, 90, 60, .06), transparent);
}
body[data-product="keyboard-warrior"] .kw-boss__stage {
  font-family: "Oswald", system-ui, sans-serif;
  font-weight: 700;
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--kw-gold);
  white-space: nowrap;
}
body[data-product="keyboard-warrior"] .kw-boss__name {
  font-family: "Oswald", system-ui, sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 1.15rem;
  margin: 0;
  letter-spacing: .02em;
}
body[data-product="keyboard-warrior"] .kw-boss__line {
  font-family: "Inter", system-ui, sans-serif;
  color: var(--ink-dim);
  font-size: .92rem;
  margin: .25rem 0 0;
}
body[data-product="keyboard-warrior"] .kw-boss--final {
  border-color: rgba(255, 90, 60, .5);
  background: linear-gradient(180deg, rgba(255, 90, 60, .1), transparent);
}

body[data-product="keyboard-warrior"] .kw-closer {
  position: relative;
  text-align: center;
  background:
    radial-gradient(80% 60% at 50% 0%, rgba(255, 90, 60, .14), transparent 70%),
    #04050a;
  overflow: hidden;
}
body[data-product="keyboard-warrior"] .kw-closer__inner {
  position: relative;
  z-index: 2;
  width: min(720px, 92vw);
  margin-inline: auto;
}
body[data-product="keyboard-warrior"] .kw-closer .kw-body {
  margin-inline: auto;
  text-align: center;
}
body[data-product="keyboard-warrior"] .kw-closer__mark {
  width: 88px;
  height: 88px;
  border-radius: 22px;
  margin: 0 auto 1.8rem;
  display: block;
  box-shadow: 0 0 50px -10px var(--kw-glow);
}
body[data-product="keyboard-warrior"] .kw-closer__actions { margin-top: 2.2rem; }
body[data-product="keyboard-warrior"] .kw-closer__note {
  margin-top: 1.6rem;
  font-family: "Inter", system-ui, sans-serif;
  font-size: .8rem;
  color: var(--ink-faint);
}

body[data-product="keyboard-warrior"] #main-content::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 9;
  pointer-events: none;
  opacity: .04;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='120' height='120' filter='url(%23n)'/></svg>");
}

body[data-product="keyboard-warrior"] .rk-reveal,
body[data-product="keyboard-warrior"] .rk-reveal-left,
body[data-product="keyboard-warrior"] .rk-reveal-right,
body[data-product="keyboard-warrior"] .rk-reveal-scale {
  opacity: 0;
  transition: opacity .9s var(--ease), transform .9s var(--ease);
  will-change: opacity, transform;
}
body[data-product="keyboard-warrior"] .rk-reveal { transform: translateY(34px); }
body[data-product="keyboard-warrior"] .rk-reveal-left { transform: translateX(-44px); }
body[data-product="keyboard-warrior"] .rk-reveal-right { transform: translateX(44px); }
body[data-product="keyboard-warrior"] .rk-reveal-scale { transform: scale(.94); }
body[data-product="keyboard-warrior"] .rk-reveal.is-visible,
body[data-product="keyboard-warrior"] .rk-reveal-left.is-visible,
body[data-product="keyboard-warrior"] .rk-reveal-right.is-visible,
body[data-product="keyboard-warrior"] .rk-reveal-scale.is-visible {
  opacity: 1;
  transform: none;
}

body[data-product="keyboard-warrior"] .kw-stagger > * {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
}
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > * {
  opacity: 1;
  transform: none;
}
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(1) { transition-delay: .04s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(2) { transition-delay: .10s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(3) { transition-delay: .16s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(4) { transition-delay: .22s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(5) { transition-delay: .28s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(6) { transition-delay: .34s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(7) { transition-delay: .40s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(8) { transition-delay: .46s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(9) { transition-delay: .52s; }
body[data-product="keyboard-warrior"] .kw-stagger.is-visible > *:nth-child(10) { transition-delay: .58s; }

@media (max-width: 860px) {
  body[data-product="keyboard-warrior"] .kw-module {
    grid-template-columns: 1fr;
    gap: 1.6rem;
  }
  body[data-product="keyboard-warrior"] .kw-module--flip .kw-module__art { order: 0; }
  body[data-product="keyboard-warrior"] .kw-enemy-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  body[data-product="keyboard-warrior"] .kw-hero__cutout {
    width: clamp(220px, 60vw, 360px);
    opacity: .85;
  }
  body[data-product="keyboard-warrior"] .kw-boss {
    grid-template-columns: 1fr;
    gap: .4rem;
  }
}
@media (max-width: 520px) {
  body[data-product="keyboard-warrior"] .kw-enemy-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (prefers-reduced-motion: reduce) {
  body[data-product="keyboard-warrior"] * {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
  body[data-product="keyboard-warrior"] .rk-reveal,
  body[data-product="keyboard-warrior"] .rk-reveal-left,
  body[data-product="keyboard-warrior"] .rk-reveal-right,
  body[data-product="keyboard-warrior"] .rk-reveal-scale,
  body[data-product="keyboard-warrior"] .kw-stagger > * {
    opacity: 1 !important;
  }
}
