@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css');

:root {
  --bg: #0c111c;
  --bg-alt: #121828;
  --text: #c7d6fa;
  --muted: #8a9cbc;
  --accent: #3f7caf;
  --accent-2: #5f4ca5;
  --border: #2f3e5e;
  --radius: 7px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--text);
  background: radial-gradient(1200px 700px at 15% -10%, #1d2a48 0%, transparent 70%), radial-gradient(1050px 620px at 90% -20%, #2a2146 0%, transparent 68%), var(--bg);
}
.bg-grid { position: fixed; inset: 0; background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 1px, transparent 1px 22px); background-size: 220px 220px; opacity: .35; pointer-events: none; animation: drift 38s linear infinite; }
@keyframes drift { from { background-position: 0 0; } to { background-position: 220px 220px; } }
@keyframes heroGlow {
  0% { transform: translate3d(-2%, 0, 0) scale(1); opacity: .85; }
  50% { transform: translate3d(1%, 2%, 0) scale(1.04); opacity: 1; }
  100% { transform: translate3d(3%, -1%, 0) scale(1.02); opacity: .88; }
}
.site-header { position: sticky; top: 0; z-index: 10; display: flex; justify-content: space-between; align-items: center; padding: .9rem 1.5rem; backdrop-filter: blur(12px); background: linear-gradient(180deg, rgba(33, 43, 63, .97), rgba(25, 34, 52, .95)); border-bottom: 1px solid #465778; box-shadow: 0 10px 28px rgba(0,0,0,.4); }
.logo { text-decoration: none; display:flex; align-items:center; }
.logo img { height: 66px; width:auto; }
nav { display:flex; gap:.55rem; }
nav a { color: #d6def6; text-decoration: none; padding: .5rem .75rem; border-radius: var(--radius); border: 1px solid #313d5b; background: rgba(255,255,255,.03); font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 700; }
nav a:hover { color: var(--text); border-color: #4f6192; background: rgba(255,255,255,.08); }

/* Mobile header layout: keep all nav buttons visible */
@media (max-width: 760px) {
  .site-header {
    flex-wrap: wrap;
    gap: .55rem;
    padding: .7rem .85rem;
  }
  .logo img { height: 50px; }
  nav {
    flex: 1 1 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: .45rem;
  }
  nav a {
    padding: .42rem .55rem;
    font-size: .72rem;
    letter-spacing: .06em;
  }
}

@media (max-width: 420px) {
  .logo img { height: 44px; }
  nav a { font-size: .68rem; padding: .38rem .5rem; }
}

/* Current page highlight */
body[data-page="home"] nav a[href$="index.html"],
body[data-page="games"] nav a[href$="games.html"],
body[data-page="about"] nav a[href$="about.html"],
body[data-page="contact"] nav a[href$="contact.html"],
nav a.active {
  color: #8fd0ff;
  border-color: rgba(143,208,255,.55);
  background: rgba(143,208,255,.08);
}
main { max-width: 1140px; margin: 0 auto; padding: 2rem 1.25rem 4rem; position: relative; }

.full-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* Home hero collage (full width, sits at the top of the hero) */
.hero-collage {
  position: absolute;
  inset: 0 0 auto 0;
  /* Keep all 4 panels in one line; scale height with viewport (start scaling earlier) */
  height: clamp(90px, 18vw, 165px);
  z-index: -1;
  overflow: hidden;
  border-radius: var(--radius);
}
.hero-collage::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8,12,20,.25), rgba(8,12,20,.78));
}
.hero-collage-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  height: 100%;
}
.hero-collage-panel {
  background-size: cover;
  background-position: center;
  position: relative;
}
/* smooth seams */
.hero-collage-panel:not(:first-child)::before {
  content: "";
  position: absolute;
  left: -30px;
  top: 0;
  width: 60px;
  height: 100%;
  background: linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.55), rgba(0,0,0,.0));
  pointer-events: none;
}
.hero-collage-panel.p1 { background-image: url('assets/images/headers/sky-gamblers-storm-raiders.jpg'); }
.hero-collage-panel.p2 { background-image: url('assets/images/headers/radiation-island.jpg'); }
.hero-collage-panel.p3 { background-image: url('assets/images/headers/sky-gamblers-air-supremacy.jpg'); }
.hero-collage-panel.p4 { background-image: url('assets/images/headers/infinite-tanks.jpg'); }

/* Generic full-bleed collage strip (Games / Contact pages) */
.page-collage {
  background: #0a1020;
  border-top: 1px solid rgba(56, 71, 101, .25);
  border-bottom: 1px solid rgba(56, 71, 101, .25);
  margin-top: .6rem;
  margin-bottom: 1.25rem;
}
.page-collage-grid {
  display: grid;
  /* Keep all panels in one line; scale height with viewport (start scaling earlier) */
  height: clamp(100px, 20vw, 180px);
}
.page-collage-grid.collage-4 { grid-template-columns: repeat(4, 1fr); }
.page-collage-grid.collage-3 { grid-template-columns: repeat(3, 1fr); }
.page-collage-panel {
  background-size: cover;
  background-position: center;
  position: relative;
}
.page-collage-panel:not(:first-child)::before {
  content: "";
  position: absolute;
  left: -26px;
  top: 0;
  width: 52px;
  height: 100%;
  background: linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.55), rgba(0,0,0,.0));
  pointer-events: none;
}

/* Use games we haven't used in the home hero collage */
.page-collage-panel.g1 { background-image: url('assets/images/headers/cubic-odyssey.jpg'); }
.page-collage-panel.g2 { background-image: url('assets/images/headers/infinite-jets.jpg'); }
.page-collage-panel.g3 { background-image: url('assets/images/headers/battle-supremacy-evolution.jpg'); }
.page-collage-panel.g4 { background-image: url('assets/images/headers/titan-glory.jpg'); }

/* Contact collage (try different games again) */
.page-collage-panel.c1 { background-image: url('assets/images/headers/sky-gamblers-storm-raiders.jpg'); }
.page-collage-panel.c2 { background-image: url('assets/images/headers/radiation-city.jpg'); }
.page-collage-panel.c3 { background-image: url('assets/images/headers/sky-gamblers-cold-war.jpg'); }
.page-collage-panel.c4 { background-image: url('assets/images/headers/infinite-tanks.jpg'); }

/* News collage */
.page-collage-panel.n1 { background-image: url('assets/images/headers/cubic-odyssey.jpg'); }
.page-collage-panel.n2 { background-image: url('assets/images/headers/air-supremacy-2.jpg'); }
.page-collage-panel.n3 { background-image: url('assets/images/headers/radiation-island.jpg'); }
.page-collage-panel.n4 { background-image: url('assets/images/headers/battle-supremacy-evolution.jpg'); }

/* About collage (make it punchier, closer to the game collages) */
.page-collage-grid.about-collage {
  /* Match the responsive scaling behavior of other collage strips */
  height: clamp(100px, 20vw, 180px);
}
.page-collage-grid.about-collage .page-collage-panel { filter: saturate(1.25) contrast(1.12) brightness(1.05); }
.page-collage-panel.a1 { background-image: url('assets/images/headers/sky-gamblers-storm-raiders.jpg'); }
.page-collage-panel.a2 { background-image: url('assets/images/headers/sky-gamblers-air-supremacy.jpg'); }
.page-collage-panel.a3 { background-image: url('assets/images/headers/radiation-island.jpg'); }
.page-collage-panel.a4 { background-image: url('assets/images/headers/cubic-odyssey.jpg'); }

@media (max-width: 760px) {
  /* Reduce seam blend width on small screens (avoid over-dark overlap) */
  .hero-collage-panel:not(:first-child)::before { left: -16px; width: 32px; }
  .page-collage-panel:not(:first-child)::before { left: -14px; width: 28px; }
}

.about-hero {
  border: 1px solid rgba(56, 71, 101, .48);
  border-radius: var(--radius);
  overflow: hidden;
  background: #0a1020;
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
  margin-bottom: 1.25rem;
}
.about-hero-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  height: 260px;
}
.about-hero-panel {
  background-size: cover;
  background-position: center;
  position: relative;
}
/* smooth seams */
.about-hero-panel:not(:first-child)::before {
  content: "";
  position: absolute;
  left: -28px;
  top: 0;
  width: 56px;
  height: 100%;
  background: linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.55), rgba(0,0,0,.0));
  pointer-events: none;
}
.about-hero-panel.p1 { background-image: url('assets/images/about/about-panel-1.jpg'); }
.about-hero-panel.p2 { background-image: url('assets/images/about/about-panel-2.jpg'); }
.about-hero-panel.p3 { background-image: url('assets/images/about/about-panel-3.jpg'); }

@media (max-width: 760px) {
  .about-hero-grid { grid-template-columns: 1fr; height: 240px; }
  .about-hero-panel.p2, .about-hero-panel.p3 { display: none; }
}
.hero { padding: 4.5rem 0 2.5rem; padding-left: 1rem; position: relative; overflow: hidden; isolation: isolate; border-radius: var(--radius); background: linear-gradient(165deg, rgba(10,15,25,.82), rgba(6,10,18,.68)); border: 1px solid rgba(56, 71, 101, .48); }
.hero-video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.32; z-index:-2; filter:saturate(1.1) contrast(1.05); }
.hero-inner { position:relative; z-index:1; }
.hero::after { content:""; position:absolute; inset:0; z-index:-1; background: linear-gradient(180deg, rgba(8,12,20,.42), rgba(8,12,20,.58)); }
.hero::before {
  content: "";
  position: absolute;
  inset: -24% -12% auto -12%;
  height: 150%;
  z-index: -1;
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 20% 30%, rgba(72,126,172,.22), transparent 44%),
    radial-gradient(circle at 78% 24%, rgba(104,83,161,.19), transparent 48%),
    linear-gradient(120deg, rgba(255,255,255,.03), rgba(255,255,255,0));
  mix-blend-mode: screen;
  filter: blur(0.8px);
  animation: heroGlow 13s ease-in-out infinite alternate;
}
.eyebrow { color: var(--accent); text-transform: uppercase; letter-spacing: .1em; font-size: .8rem; }
h1 { font-size: clamp(2rem, 5.2vw, 4rem); line-height: 1.08; margin: .6rem 0 1rem; max-width: 32ch; }
.lead { color: var(--muted); font-size: 1.1rem; max-width: 64ch; }
.hero-actions { margin-top: 1.4rem; display: flex; gap: .8rem; flex-wrap: wrap; }
.btn { display: inline-block; padding: .8rem 1rem; border-radius: var(--radius); text-decoration: none; font-weight: 700; border: 1px solid transparent; transition: transform .2s ease, filter .2s ease, box-shadow .2s ease, border-color .2s ease; }
.btn-primary { color: white; background: linear-gradient(120deg, var(--accent), var(--accent-2)); box-shadow: 0 8px 20px rgba(87, 182, 255, .25); }
.btn-ghost { color: var(--text); border-color: var(--border); background: rgba(255,255,255,.02); }
.btn:hover { transform: translateY(-1px) scale(1.01); filter: brightness(1.06) saturate(1.05); }
.btn-primary:hover { box-shadow: 0 10px 24px rgba(87, 182, 255, .34); }
.btn-ghost:hover { border-color: #7ea5e8; box-shadow: 0 8px 20px rgba(80,120,200,.2); }
.btn:active { transform: translateY(0) scale(0.995); }
.section { padding: 2.2rem 0; }
.section + .section { margin-top: .8rem; }
.section-alt { border: 1px solid var(--border); background: linear-gradient(180deg, rgba(255,255,255,.01), rgba(255,255,255,.02)); border-radius: var(--radius); padding: 2rem; }
.section-head h2 { margin: 0; font-size: 1.8rem; }
.section-head p { margin: .5rem 0 1.2rem; color: var(--muted); }

/* When section heads don't have helper text (<p>...), keep a little breathing room before content */
.section-head { margin-bottom: .85rem; }
.section-head + .section-alt,
.section-head + .media-videos,
.section-head + .media-grid {
  margin-top: .55rem;
}
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1rem; }
.card { border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem; background: rgba(255,255,255,.02); }
.card h3 { margin: .6rem 0 .35rem; font-size: 1.1rem; }
.card p { margin: 0; color: var(--muted); font-size: .95rem; }

/* News (compact cards) */
.news-feed {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
}

.news-card { text-decoration: none; color: inherit; display: block; height: 100%; }
.news-post {
  padding: 0;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform .18s ease, filter .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.news-card:hover .news-post {
  transform: translateY(-1px);
  filter: brightness(1.06) saturate(1.03);
  border-color: #7ea5e8;
  box-shadow: 0 10px 24px rgba(80,120,200,.20);
}

/* Special styling for the website entry */
.news-post.is-featured {
  background: linear-gradient(160deg, rgba(87,182,255,.10), rgba(143,107,255,.07));
  border-color: rgba(126,165,232,.62);
}

.news-post img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-bottom: 1px solid var(--border);
  background: #0a1020;
}
.news-body { padding: 1rem; flex: 1; display: flex; flex-direction: column; }
.news-meta { color: var(--muted); font-size: .85rem; margin-bottom: .35rem; }
.news-post h3 { margin: 0 0 .55rem; font-size: 1.1rem; }
.news-excerpt {
  margin: 0;
  color: var(--muted);
  font-size: .95rem;
  line-height: 1.35;
  flex: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

/* Make platform badges align to the bottom across cards (even when text lengths differ) */
.card-game { display: flex; flex-direction: column; height: 100%; }
.card-game p { flex: 1; }
.card-game .badges { margin-top: auto; padding-top: .6rem; }
.card a { color: var(--text); text-decoration: none; }
.card a:hover { color: var(--accent); }
.card-game img {
  width: 100%;
  /* Slightly taller than 16/9, but not poster-tall */
  aspect-ratio: 2.93 / 3;
  /* Fill the card (no black bars); keep proportions */
  object-fit: cover;
  /* Bias toward showing top area (often where the title text is) */
  object-position: center 20%;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: #0d1020;
  transition: transform .22s ease, filter .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card-media-link:hover img { transform: translateY(-1px) scale(1.01); filter: brightness(1.08) saturate(1.06); border-color: #7ea5e8; box-shadow: 0 8px 20px rgba(80,120,200,.28); }
.badges { display:flex; flex-wrap:wrap; gap:.45rem; margin-top:.75rem; align-items:center; }
.badge { font-size:.75rem; padding:.26rem .5rem; border:1px solid var(--border); border-radius: var(--radius); color:#d2dcf7; background: rgba(255,255,255,.03); }

/* Store/platform icon badges (like the live site icons) */
.store-badge {
  width: 34px;
  height: 30px;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: rgba(255,255,255,.03);
  color: #d2dcf7;
  text-decoration: none;
  transition: transform .18s ease, filter .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.store-badge i { font-size: 1.05rem; line-height: 1; }
.store-badge:hover {
  transform: translateY(-1px);
  filter: brightness(1.12) saturate(1.08);
  border-color: #7ea5e8;
  box-shadow: 0 8px 18px rgba(80,120,200,.22);
}
.store-badge:active { transform: translateY(0); }
.chips { display: flex; flex-wrap: wrap; gap: .6rem; }
.chip { border: 1px solid var(--border); background: rgba(255,255,255,.02); color: var(--muted); padding: .5rem .75rem; border-radius: var(--radius); font-size: .9rem; text-decoration:none; }
.container { max-width: 1140px; margin: 0 auto; padding: 0 1.25rem; }

/* About: full-width collage background + centered content card */
/* Connect the top collage strip with the background collage (no vertical gap) */
body[data-page="about"] .page-collage { margin-bottom: 0; border-bottom: 0; }
body[data-page="about"] .about-bg { margin-top: 0; padding-top: 0; }
body[data-page="about"] .about-bg .container { padding-top: 5px; }

.about-bg {
  position: relative;
  overflow: hidden;
}
.about-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  /* (Collage moved to a real element below; keep ::before as a no-op layer for compatibility) */
  background: none;
  opacity: 0;
  z-index: 0;
}
.about-bg-collage{
  position: absolute;
  /* Nudge up by 1px to eliminate any seam between the two collage strips */
  inset: -1px 0 auto 0;
  height: clamp(100px, 20vw, 180px);
  overflow: hidden;
  z-index: 0;
  /* Match previous look (+20% brightness vs old .9) */
  filter: saturate(1.15) contrast(1.05) brightness(1.08);
  opacity: .35;
}
.page-collage-grid.about-bg-collage-grid{ height: 100%; }

/* About secondary collage: match the top collage behavior (edge-to-edge, no internal gaps) */
.page-collage-panel.ab1{ background-image: url('assets/images/about/design-award-slide-1600.jpg'); background-size: cover; background-repeat:no-repeat; background-position:center; }
.page-collage-panel.ab2{ background-image: url('assets/images/about/keynote-ipad-1600.jpg'); background-size: cover; background-repeat:no-repeat; background-position:center; }
.page-collage-panel.ab3{ background-image: url('assets/images/about/wwdc-stage-1600.jpg'); background-size: cover; background-repeat:no-repeat; background-position:center; }
.page-collage-panel.ab4{ background-image: url('assets/images/about/darth-vader-programming.jpg'); background-size: cover; background-repeat:no-repeat; background-position:center; }

.about-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(80% 120% at 50% 0%, rgba(0,0,0,.25), rgba(0,0,0,.78));
  z-index: 0;
}
.about-bg > * { position: relative; z-index: 1; }

.about-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.2rem;
  align-items: start;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
  background: rgba(10, 16, 32, .55);
  backdrop-filter: blur(6px);
}

.about-title{
  font-size: clamp(2rem, 5vw, 3rem);
  margin: .15rem 0 .55rem;
  letter-spacing: -0.01em;
}

.about-card p { color: var(--muted); margin: 0 0 .85rem; }
.about-card p.lead { color: #b9c8ea; font-size: 1.05rem; line-height: 1.55; }
.about-card strong { color: #8fd0ff; }
.about-points p { margin: 0 0 .6rem; }

/* About: highlight facts (form-like tiles) */
.about-facts{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .9rem;
  margin: .35rem 0 .2rem;
}
.fact-form{
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(56, 71, 101, .62);
  border-radius: var(--radius);
  padding: .95rem 1rem;
  background: linear-gradient(160deg, rgba(87,182,255,.08), rgba(143,107,255,.06));
  box-shadow: 0 12px 30px rgba(0,0,0,.32);
}
.fact-form::after{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(600px 220px at 15% 0%, rgba(143,208,255,.20), transparent 55%),
              radial-gradient(600px 220px at 100% 80%, rgba(167,120,255,.18), transparent 55%);
  opacity: .55;
  pointer-events:none;
}
.fact-form > *{ position: relative; z-index: 1; }
.fact-kicker{ font-size: .72rem; text-transform: uppercase; letter-spacing: .14em; color: rgba(199,214,250,.72); }
.fact-value{ display:flex; align-items: baseline; gap: .45rem; margin: .25rem 0 .55rem; }
.fact-number{ font-size: 2.15rem; font-weight: 820; color: #eef5ff; line-height: 1; }
.fact-unit{ font-size: 1rem; font-weight: 720; color: #8fd0ff; letter-spacing: .01em; }
.fact-lines{ display:grid; gap: .35rem; color: rgba(199,214,250,.78); font-size: .92rem; }
.fact-lines span{ padding-top: .35rem; border-top: 1px solid rgba(47,62,94,.75); }
.fact-lines span:first-child{ border-top: 1px solid rgba(47,62,94,.55); }

@media (max-width: 900px){
  .about-facts{ grid-template-columns: 1fr; }
  .fact-number{ font-size: 2rem; }
}
.cta { text-align: center; border: 1px solid var(--border); border-radius: var(--radius); padding: 2.2rem 1rem; background: linear-gradient(160deg, rgba(87,182,255,.08), rgba(143,107,255,.08)); }
.cta p { color: var(--muted); }
footer { border-top: 1px solid #465778; color: var(--muted); text-align: center; padding: 1.25rem; background: linear-gradient(180deg, rgba(33, 43, 63, .97), rgba(25, 34, 52, .95)); }
.reveal { opacity: 0; transform: translateY(12px); transition: opacity .5s ease, transform .5s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }
.game-header {
  border: 1px solid rgba(56, 71, 101, .48);
  border-radius: var(--radius);
  overflow: hidden;
  background: #0a1020;
  margin: 0 0 1.25rem;
}
.game-header img {
  width: 100%;
  height: auto;
  display: block;
  /* Center the crop on the content below */
  object-position: center;
  aspect-ratio: 21 / 9;
  object-fit: cover;
}

/* Per-game header crop tweaks */
body[data-page="game:air-supremacy-2"] .game-header img {
  /* Show more of the left side so the title on the art stays visible */
  object-position: left center;
}

.game-hero { display:grid; grid-template-columns: 1.2fr 1fr; gap:1rem; border:1px solid var(--border); border-radius: var(--radius); padding:1rem; background:rgba(255,255,255,.02); }
.game-hero img {
  width: 100%;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  /* Match the game cards aspect/behavior from the Games page */
  aspect-ratio: 2.93 / 3;
  object-fit: cover;
  object-position: center 20%;
}
.contact-form { display:grid; gap:.65rem; }
.contact-form-title { margin: .1rem 0 .25rem; font-size: 1.68rem; font-weight: 500; }

/* Contact form submit button: smaller + action color */
#contact-submit.btn-action {
  padding: .6rem .9rem;
  font-size: .95rem;
  border-color: rgba(87, 182, 255, .45);
  background: linear-gradient(120deg, rgba(87,182,255,.22), rgba(143,107,255,.18));
  color: #eaf3ff;
}
#contact-submit.btn-action:hover {
  border-color: rgba(87, 182, 255, .75);
  box-shadow: 0 10px 24px rgba(87, 182, 255, .18);
}
body[data-page="contact"] .contact-form { margin-top: 1.1rem; }
body[data-page="contact"] #contact-submit { margin: .4rem 0 .8rem; }

/* Contact form: inline math anti-spam */
body[data-page="contact"] .contact-math-row{
  display:flex;
  align-items:center;
  gap:.5rem;
  flex-wrap:nowrap;
  font-size: 1.05rem;
}
body[data-page="contact"] .contact-math-row .contact-math-text{
  flex: 0 1 auto;
}
body[data-page="contact"] .contact-math-row .math-strong{ font-weight: 750; }
body[data-page="contact"] #contact-math{
  width: 7rem;
  flex: 0 0 auto;
}
/* Basic anti-spam honeypot (hidden from humans) */
.hp-field {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.contact-form label { display:grid; gap:.35rem; color:var(--muted); font-size:.9rem; }
.contact-form input, .contact-form textarea { background: rgba(255,255,255,.03); border:1px solid var(--border); color:var(--text); padding:.65rem .75rem; border-radius: var(--radius); font: inherit; }
.contact-status { min-height: 1.2em; margin: .1rem 0 0; color: #ffd4d4; font-size: .9rem; }
.contact-success { border:1px solid var(--border); background: rgba(255,255,255,.03); border-radius: var(--radius); padding: 1rem; }
.contact-success h3 { margin: 0 0 .4rem; color: #9fe39f; }
.contact-success p { margin: 0; color: var(--muted); }
.contact-locations { display: grid; grid-template-columns: 1fr 1fr; gap: .9rem; margin: .35rem 0 .2rem; }
.contact-location-title { margin: 0 0 .45rem; color: var(--muted); font-size: .9rem; font-weight: 700; }
/* Contact page layout helpers */

@media (max-width: 760px) {
  .contact-locations { grid-template-columns: 1fr; }
}

.map-wrap iframe { width:100%; height:220px; border:1px solid var(--border); border-radius: var(--radius); }
.media-videos { display:grid; grid-template-columns: 1fr; gap: .9rem; margin-bottom: .9rem; }
.media-videos iframe, .media-videos video {
  width: 100%;
  /* Make the trailer feel like a real embedded video (big, responsive, no distortion) */
  aspect-ratio: 16 / 9;
  height: auto;
  min-height: 360px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: #0a1020;
}

@media (max-width: 760px) {
  .media-videos iframe, .media-videos video { min-height: 220px; }
}
.media-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: .75rem; }
.media-grid a { display:block; }
.media-grid img { width:100%; aspect-ratio:16/9; object-fit:cover; border:1px solid var(--border); border-radius: var(--radius); }

@media (max-width: 760px) { .about, .game-hero { grid-template-columns: 1fr; } }

/* Lightbox (Media gallery) */
body.lightbox-open { overflow: hidden; }

.lightbox-backdrop {
  position: fixed;
  left: 0;
  right: 0;
  top: var(--lb-top, 0px);
  bottom: var(--lb-bottom, 0px);
  z-index: 9; /* keep header (z=10) above */
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(3px);
  display: grid;
  place-items: center;
  padding: 1rem;
}

.lightbox-panel {
  position: relative;
  max-width: min(1100px, 96vw);
  max-height: min(78vh, 900px);
  width: 100%;
  display: grid;
  place-items: center;
}

.lightbox-img {
  max-width: 100%;
  max-height: 100%;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 16px 50px rgba(0,0,0,.55);
  background: #0a1020;
}

.lightbox-close {
  position: absolute;
  top: -0.25rem;
  right: -0.25rem;
  transform: translate(20%, -20%);
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(20, 28, 44, .85);
  color: #eaf1ff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}

.lightbox-close:hover {
  background: rgba(35, 48, 74, .92);
  border-color: rgba(143,208,255,.55);
}
