
/* ---------- Theme ---------- */
:root{
  --bg: #07070B;               /* deep space */
  --fg: #EDECF2;               /* light text */
  --muted: #B9B7C6;
  --accent: #e63946;           /* red */
  --accent2: #6b2cff;          /* deep purple glow core */
  --card-bg: rgba(18,18,24,0.6);
  --blur: blur(8px);
  --header-h: 110px;           /* fallback if JS not present */
}

/* Reset */
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font-family: ui-sans-serif, system-ui, Segoe UI, Roboto, Helvetica, Arial, Apple Color Emoji, Segoe UI Emoji;
  background: var(--bg);
  color: var(--fg);
  line-height: 1.6;
  overflow-x: hidden;
}

/* Background */
#starfield{
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  z-index: -2;
  background: radial-gradient(1200px 600px at 20% -10%, rgba(107,44,255,0.25), transparent 60%),
              radial-gradient(900px 500px at 90% 20%, rgba(230,57,70,0.18), transparent 60%),
              radial-gradient(1000px 800px at 50% 120%, rgba(107,44,255,0.12), transparent 70%),
              #05050A;
}
.space-glow{
  position: fixed;
  inset: -40% -20% auto -20%;
  height: 70vh;
  background: radial-gradient(60% 60% at 50% 0%,
    rgba(107,44,255,0.35), rgba(230,57,70,0.22) 45%, transparent 70%);
  filter: blur(40px);
  z-index: -1;
  pointer-events: none;
}

/* Scroll/anchor spacing relative to fixed header */
html, body { scroll-padding-top: calc(var(--header-h) + 12px); }
main { padding-top: calc(var(--header-h) + 12px); }
section { scroll-margin-top: calc(var(--header-h) + 12px); }

/* Navbar */
header{
  position: fixed;
  top: 0; left: 0; width: 100%;
  backdrop-filter: saturate(120%) blur(6px);
  -webkit-backdrop-filter: saturate(120%) blur(6px);
  background: linear-gradient(to bottom, rgba(10,10,16,0.8), rgba(10,10,16,0.3));
  border-bottom: 1px solid rgba(255,255,255,0.06);
  z-index: 10;
}
.navbar{
  max-width: 1100px;
  margin: 0 auto;
  padding: 1rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.logo { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; }
.logo img {
  height: 90px;
  width: auto;
  display: block;
  filter: drop-shadow(0 0 8px rgba(107,44,255,0.25));
}
@media (max-width: 480px) { .logo img { height: 56px; } }

.nav-links{list-style:none;display:flex;gap:1.25rem}
.nav-links a{
  color: var(--fg);
  text-decoration: none;
  opacity: 0.9;
  transition: 180ms ease;
}
.nav-links a:hover,
.nav-links a.active{
  color: var(--accent);
  text-shadow: 0 0 10px rgba(230,57,70,0.7), 0 0 22px rgba(107,44,255,0.5);
}

/* Sections & Cards */
section{padding: 110px 1.25rem}
.card{
  max-width: 1024px; margin: 0 auto;
  background: var(--card-bg);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 2rem;
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  box-shadow: 0 10px 40px rgba(0,0,0,0.45);
}
h1.page-title{ font-size: clamp(2rem, 4.5vw, 3rem); margin-bottom:.25rem; }
.page-lede{ color: var(--muted); }

/* Hero */
.hero{
  min-height: 100vh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 0 1rem;
  position: relative;
  isolation: isolate;
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(15deg, transparent 20%, rgba(255,255,255,0.03) 25%, transparent 35%) repeat;
  background-size: 120px 120px;
  mask-image: radial-gradient(90% 60% at 50% 45%, #000 60%, transparent 100%);
  z-index:-1;
}
.hero-content h1{
  font-size: clamp(2.8rem, 7vw, 5rem);
  font-weight: 900;
  letter-spacing: 1px;
  transform: skewX(-6deg);
  background: linear-gradient(90deg, #b18cff 0%, #e63946 60%, #ff5e84 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  text-shadow: 0 0 18px rgba(107,44,255,0.35);
  margin-bottom: .75rem;
}
.hero-content p{
  color: var(--muted);
  max-width: 720px;
  margin: 0 auto 1.75rem;
}
.hero-skull{
  position: absolute;
  inset: auto auto 8% 50%;
  transform: translateX(-50%) rotate(-6deg);
  width: min(60vw, 520px);
  opacity: 0.08;
  pointer-events: none;
  filter: drop-shadow(0 0 20px rgba(107,44,255,0.35));
  z-index: -1;
}

/* Buttons */
.btn{
  padding: .85rem 1.5rem;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.1);
  background: linear-gradient(180deg, rgba(230,57,70,0.9), rgba(107,44,255,0.85));
  color: white;
  text-decoration: none;
  font-weight: 700;
  letter-spacing:.5px;
  transition: transform .15s ease, box-shadow .25s ease, filter .25s ease;
}
.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 0 18px rgba(230,57,70,0.45), 0 0 36px rgba(107,44,255,0.35);
}

/* Footer */
.footer{
  text-align: center;
  padding: 2rem 1rem 2.5rem;
  color: var(--muted);
  font-size: .9rem;
}
.footer img{
  height: 90px;
  width: auto;
  margin-bottom: .6rem;
  opacity: .9;
  filter: drop-shadow(0 0 10px rgba(230,57,70,0.25));
}

/* ---------- Profession Tiles (collapsible, image-driven) ---------- */
.tiles-collapsible{ width: 100%; max-width:1100px; margin: 0 auto 2rem; counter-reset: ns; }
.tile-c{ counter-increment: ns; }

/* Base tile */
.tile-c{
  position: relative;
  z-index: 0;
  display: block;
  width: 100%;
  overflow: hidden;
  text-decoration: none;
  color: var(--fg);

  /* sizes */
  --collapsed-h: 150px;
  --expanded-h: 480px;
  --img: none;                  /* set per tile: style="--img:url(...)" */

  height: var(--collapsed-h);

  /* glass + border */
  background: linear-gradient(180deg, rgba(18,18,24,.55), rgba(18,18,24,.7));
  border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  box-shadow: 0 12px 28px rgba(0,0,0,.4);

  /* travel */
  transition:
    height .6s cubic-bezier(.20, .90, .25, 1.1),
    box-shadow .35s ease,
    border-color .35s ease;
}

/* Image layer (brighter) */
.tile-c::before{
  content:"";
  position:absolute; inset:0;
  background-image: var(--img);
  background-size: cover;
  background-position: center;
  transform: scale(1.08);
  opacity: 0.9;
  clip-path: inset(0 0 calc(100% - var(--collapsed-h)) 0);
  filter: brightness(1.15) contrast(1.08);
  transition:
    transform .7s cubic-bezier(.20, .90, .25, 1.1),
    filter .7s ease,
    opacity .6s ease,
    clip-path .7s cubic-bezier(.20, .90, .25, 1.1);
  z-index: 0;
}
/* Readability overlay */
.tile-c::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(5,5,10,.15), rgba(5,5,10,.45) 55%, rgba(5,5,10,.7));
  z-index: 1;
}

.tile-title,
.tile-reveal{ position: relative; z-index: 2; }

.tile-title{
  font-size: clamp(1.1rem, 3vw, 1.4rem);
  font-weight: 900;
  letter-spacing: .4px;
  padding: 1.1rem 1.25rem;
  transform: skewX(-6deg);
  text-shadow: 0 0 10px rgba(107,44,255,.3);
}

.tile-reveal{
  padding: 0 1.25rem 1.25rem;
  max-width: 1100px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .42s ease, transform .42s ease;
}
.tile-reveal p{
  color: var(--fg);
  max-width: 800px;
  margin: .25rem 0 1rem;
}
.tile-cta{
  display: inline-block;
  opacity: 0;
  transition: opacity .40s ease .05s, transform .25s ease;
}

/* Desktop hover */
@media (hover:hover){
  .tile-c:hover{
    height: var(--expanded-h);
    border-color: rgba(255,255,255,.14);
    box-shadow: 0 24px 52px rgba(107,44,255,.28), 0 0 28px rgba(230,57,70,.18);
  }
  .tile-c:hover::before{
    transform: scale(1.02);
    clip-path: inset(0 0 0 0);
    opacity: 1;
    filter: brightness(1.2) contrast(1.12) saturate(1.08);
  }
  .tile-c:hover .tile-reveal{ opacity: 1; transform: translateY(0); }
  .tile-c:hover .tile-cta{ opacity: 1; transform: translateY(0); }
}

/* Touch open (script toggles .open) */
.tile-c.open{
  height: var(--expanded-h);
}
.tile-c.open::before{
  transform: scale(1.02);
  clip-path: inset(0 0 0 0);
  opacity: 1;
  filter: brightness(1.2) contrast(1.12) saturate(1.08);
}
.tile-c.open .tile-reveal{ opacity: 1; transform: translateY(0); }
.tile-c.open .tile-cta{ opacity: 1; transform: translateY(0); }

/* Sequencing badge NS 01, NS 02 ... */
.tile-seq{
  position: absolute;
  right: 14px;
  bottom: 12px;
  pointer-events: none;
  opacity: .75;
  transition: opacity .25s ease, transform .25s ease;
}
.tiles-collapsible{ counter-reset: ns; }
.tile-seq::before {
  content: "NS " counter(ns, decimal-leading-zero);
  font-family: 'moonhouse', sans-serif;
  font-weight: 400;
  letter-spacing: .15em;
  font-size: clamp(0.85rem, 2vw, 1.1rem);
  color: rgba(237,236,242,0.32);
  text-shadow: 0 0 6px rgba(0,0,0,0.45), 0 0 14px rgba(107,44,255,0.2);
}
@media (hover:hover){
  .tile-c:hover .tile-seq{ opacity: .95; transform: translateY(-1px); }
}

/* ---------- Lore & Cause helpers ---------- */
.muted { color: var(--muted); }
.lc-split{
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  gap: 1rem;
  padding: 0 1.25rem;
}
@media (min-width: 980px){
  .lc-split{ grid-template-columns: 1fr 1fr; }
}
.lc-accordion{ margin-top:.75rem; display:grid; gap:.5rem; }
.lc-acc-btn{
  width: 100%; display:flex; justify-content:space-between; align-items:center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--fg); padding:.8rem 1rem; border-radius:12px; cursor:pointer;
  transition: transform .12s ease, box-shadow .2s ease, border-color .2s ease;
}
.lc-acc-btn:hover{ transform: translateY(-1px); box-shadow: 0 10px 24px rgba(107,44,255,.25), 0 0 18px rgba(230,57,70,.18); border-color: rgba(255,255,255,.2); }
.lc-acc-panel{ overflow:hidden; background: rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.1); border-radius:12px; padding: 0 1rem; }
.lc-acc-panel p{ padding:.9rem 0 1rem; color: var(--muted); }

/* ---------- Crew & Fleet basic grid ---------- */
.roster{ max-width:1100px; margin:0 auto; display:grid; gap:1rem; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); }
.roster .card{ padding:1rem; }
.roster img{ width:100%; border-radius:12px; display:block; }

/* ---------- Signal Archive (Media) ---------- */
.sa-controls .sa-bar{ display:grid; gap:.6rem; }
.sa-controls input[type="search"]{
  width: 100%;
  padding: .8rem 1rem;
  border-radius: 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--fg);
  outline: none;
}
.sa-chips{ display:flex; flex-wrap:wrap; gap:.5rem; }
.sa-grid-wrap{ padding-top: 1rem; }
.sa-grid{ display:grid; gap:1rem; }
@media (min-width: 720px){ .sa-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1080px){ .sa-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); } }
.sa-item{
  background: rgba(17,17,24,0.66);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,0.35);
  transition: transform .15s ease, box-shadow .25s ease;
}
.sa-item:hover{
  transform: translateY(-3px);
  box-shadow: 0 14px 34px rgba(107,44,255,0.25), 0 0 22px rgba(230,57,70,0.18);
}
.sa-thumb img{ width:100%; height:220px; object-fit:cover; display:block; filter: brightness(1.1) contrast(1.05); }
.sa-caption{ padding: .8rem 1rem; }
.sa-caption h3{ font-weight:900; margin-bottom:.15rem; }

/* ---------- Communications (two-column form) ---------- */
.page-comms .form-grid{
  display: grid;
  gap: .9rem;
  margin-top: .6rem;
}
@media (min-width: 860px){
  .page-comms .form-grid{ grid-template-columns: 1fr 1fr; }
  .page-comms .field-span{ grid-column: 1 / -1; }
}
.page-comms .field label{ display:block; font-weight: 800; margin-bottom: .25rem; }
.page-comms .field input[type="text"],
.page-comms .field input[type="email"],
.page-comms .field select,
.page-comms .field textarea{
  width: 100%; padding: .8rem 1rem; border-radius: 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--fg); outline: none;
}
.page-comms .field textarea{ resize: vertical; }
.page-comms .comms-actions{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top: .4rem; }
.page-comms .tiny{ font-size: .85rem; }
.page-comms .notice{ margin-top: .8rem; color: var(--muted); }
.hp{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }

/* ---------- 3D Social Logos (logo-only, diagonal gradient) ---------- */
.social-3d{
  margin-top: 1.25rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(64px, 1fr));
  gap: .9rem;
  justify-items: center;
}
@media (min-width: 560px){
  .social-3d{ grid-template-columns: repeat(6, minmax(64px, 1fr)); }
}
.social-3d a.logo3d{
  display: grid;
  place-items: center;
  width: clamp(56px, 8vw, 80px);
  height: clamp(56px, 8vw, 80px);
  border-radius: 18px;
  text-decoration: none;
  background: linear-gradient(45deg, #0b0b12 0%, #7b3fff 100%);
  box-shadow:
    0 10px 18px rgba(0,0,0,0.50),
    inset 0 2px 6px rgba(255,255,255,0.08),
    inset 0 -4px 10px rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.12);
  transition: transform .18s ease, box-shadow .22s ease, border-color .22s ease, filter .22s ease;
  position: relative;
  overflow: hidden;
}
.social-3d a.logo3d::before{
  content:"";
  position:absolute; inset: 0;
  background: linear-gradient(45deg, rgba(255,255,255,0.15), transparent 45%);
  mix-blend-mode: overlay;
  pointer-events: none;
}
.social-3d a.logo3d:hover{
  transform: translateY(-3px);
  box-shadow:
    0 14px 26px rgba(0,0,0,0.55),
    inset 0 2px 8px rgba(255,255,255,0.10),
    inset 0 -5px 12px rgba(0,0,0,0.35);
  border-color: rgba(255,255,255,0.18);
  filter: saturate(1.05);
}
.logo3d svg{ width: 58%; height: 58%; filter: drop-shadow(0 2px 2px rgba(0,0,0,0.5)); }

/* Smaller icons specifically in the footer to avoid "huge" look */
.footer .social-3d { margin-top: 1rem; gap: .6rem; }
.footer .social-3d .logo3d{
  width: clamp(46px, 6.5vw, 64px);
  height: clamp(46px, 6.5vw, 64px);
}

/* Utilities */
.reveal{opacity:0;transform: translateY(40px);transition: all .8s ease}
.reveal.active{opacity:1;transform: translateY(0)}
.fade-in{opacity:0;animation:fadeIn 1.5s forwards}
.fade-in.delay{animation-delay:.8s}
@keyframes fadeIn{to{opacity:1}}


/* Center footer social logos and keep compact size */
.footer .social-3d { 
  display: flex; 
  justify-content: center; 
  align-items: center; 
  gap: .8rem; 
  margin-top: 1rem;
}
.footer .social-3d .logo3d{
  width: clamp(46px, 6.5vw, 64px);
  height: clamp(46px, 6.5vw, 64px);
}

/* Media page socials row */
.media-socials {
  display: flex;
  justify-content: center;   /* center horizontally */
  gap: 2.5rem;               /* more space than footer (adjust to taste) */
  margin: 2rem 0;            /* push away from content above/below */
}

.media-socials .logo3d {
  width: clamp(60px, 8vw, 80px);   /* make them a bit larger than footer */
  height: clamp(60px, 8vw, 80px);
}

/* Media page socials: centered with more spacing and slightly larger */
.social-3d.social-top{
  display: flex;              /* override the grid layout for this row */
  justify-content: center;
  align-items: center;
  gap: 2.5rem;                /* more spacing than footer */
  margin: 1.75rem 0 2.25rem;  /* breathing room around the row */
}

.social-3d.social-top .logo3d{
  width: clamp(64px, 8vw, 88px);   /* larger than footer */
  height: clamp(64px, 8vw, 88px);
}
