:root{
  --bg:#05060a; --ink:#e6f0ff; --muted:#9ab0d0;
  --brand:#72d2ff; --brand-2:#6a9cff; --ring: rgba(114,210,255,.45);
  --gold1:#f8e6a0; --gold2:#e7c76b; --gold3:#b98b28;
}
*{box-sizing:border-box; margin:0; padding:0}
body{height:100%; background: var(--bg); color:var(--ink);
     font-family: Inter, sans-serif; line-height:1.6; overflow-x:hidden; position:relative;}
a{color:inherit; text-decoration:none}
.wrap{max-width:1200px; margin:0 auto; padding:0 20px}

/* Subtle starfield fallback */
@keyframes twinkle{ 0%,100%{opacity:.35} 50%{opacity:.5} }
body::before { content: ""; position: fixed; inset: 0; z-index: -3; background:
  radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,0.8) 50%, transparent 60%),
  radial-gradient(1.5px 1.5px at 70% 60%, rgba(255,255,255,0.6) 50%, transparent 60%),
  radial-gradient(1px 1px at 40% 80%, rgba(255,255,255,0.7) 50%, transparent 60%),
  radial-gradient(2px 2px at 85% 20%, rgba(255,255,255,0.8) 50%, transparent 60%),
  #05060a; background-size: 400px 400px; opacity: .4; animation: twinkle 6s ease-in-out infinite; }

/* Background slideshow */
.bg-img{ position:fixed; inset:0; z-index:-2; pointer-events:none; overflow:hidden; }
.bg-img .slide{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
  opacity:0; transition:opacity 1.2s ease-in-out;
}
.bg-img .slide.active{ opacity:.85; }
.bg-vignette{ position:fixed; inset:0; z-index:-1; pointer-events:none;
  background: radial-gradient(closest-side at 50% 55%, rgba(0,0,0,0) 0%, rgba(0,0,0,.22) 70%); }

/* Top nav */
nav{ position:sticky; top:0; z-index:10; background: rgba(5,6,10,.85);
  backdrop-filter: blur(8px); border-bottom:1px solid rgba(255,255,255,.07) }
nav .bar{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; padding:14px 0 }
.logo{ display:flex; align-items:center; gap:12px; font-family: Orbitron }
.logo .mark{ width:28px; height:28px; border-radius:8px; background: conic-gradient(from 180deg,var(--brand),var(--brand-2),var(--brand)); }
.menu{ display:flex; align-items:center; gap:16px; flex-wrap:wrap }
.menu a{ display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border-radius:999px; color:var(--ink);
  border:1px solid rgba(255,255,255,.12); background: rgba(0,0,0,.25); backdrop-filter: blur(6px); transition: all 0.3s ease; }
.menu a:hover{ background: rgba(114,210,255,.12); border-color: rgba(114,210,255,.6); box-shadow: 0 0 12px rgba(114,210,255,.5); color: var(--brand); }

/* Hero */
.hero{ text-align:center; padding:40px 0 30px; background:transparent; border-radius:0; }
h1{ font-family: Orbitron, sans-serif; font-size: clamp(28px, 5vw, 54px); margin: 6px 0 8px;
  background: linear-gradient(165deg,var(--gold1) 0%, var(--gold2) 25%, var(--gold3) 55%, #7a5a16 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  letter-spacing:.08em; text-transform:uppercase; position:relative; overflow:hidden;
  -webkit-text-stroke: 1px rgba(248,230,160,.8); }
.animated-title span { opacity:0; display:inline-block; will-change: transform, opacity;
  animation: fadeInLetter 0.05s forwards, holoShake 3.2s infinite ease-in-out; }
.animated-title .space{ display:inline-block; width:.5em; opacity:1; animation:none; }
@keyframes fadeInLetter { from { opacity:0; text-shadow:none; } to { opacity:1; text-shadow:0 0 6px var(--gold1), 0 0 12px var(--gold2); } }
@keyframes holoShake { 0%,100% { transform: translate(0,0); } 20% { transform: translate(-0.6px, 0.6px); } 40% { transform: translate(0.6px, -0.6px); } 60% { transform: translate(-0.6px, -0.6px); } 80% { transform: translate(0.6px, 0.6px); } }

.hero-sub{ font-size:clamp(14px,2vw,18px); color:var(--muted); margin-top:10px; font-style:italic; letter-spacing:.05em; }
.actions{ margin-top:16px; display:flex; justify-content:center; gap:12px; flex-wrap:wrap }
.btn{ padding:10px 14px; border-radius:12px; border:1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.06); transition:.25s; font-size:14px }
.btn.primary{ background: linear-gradient(135deg, rgba(248,230,160,.18), rgba(185,139,40,.18)); border-color: rgba(248,230,160,.55); box-shadow: 0 0 14px rgba(248,230,160,.25) }
.btn:hover{ transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,.45) }

section{ padding:68px 0 }
#fleet { margin-top:220px; }

.section-title{ font-family: Orbitron; font-size: clamp(20px,3vw,28px); margin:0 0 20px;
  background: linear-gradient(90deg, var(--gold1), var(--gold3)); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent; }

.panel{ position:relative; background: rgba(255,255,255,.05); border:1px solid rgba(114,210,255,.25);
  border-radius:20px; overflow:hidden; padding:16px; backdrop-filter: blur(2px); transition: all 0.3s ease; }
.panel:hover { border-color: rgba(114,210,255,.6); box-shadow: 0 0 18px rgba(114,210,255,.4); transform: translateY(-2px); }
.panel .headline{ display:flex; justify-content:space-between; font-family: Orbitron; margin-bottom:10px }
.panel .badge{ font-size:11px; padding:4px 8px; border:1px solid rgba(114,210,255,.35); border-radius:999px; }

.grid{ display:grid; grid-template-columns: repeat(12, 1fr); gap:18px }
.col-4{ grid-column: span 4 }
@media (max-width: 900px){ .col-4{ grid-column: span 6 } }
@media (max-width: 640px){ .col-4{ grid-column: span 12 } }

.ship-card{ display:flex; flex-direction:column }
.ship-thumb{ position:relative; border-radius:14px; overflow:hidden; aspect-ratio:16/9; border:1px solid rgba(255,255,255,.12);
  background:#0a0f1a; box-shadow: inset 0 0 0 1px rgba(255,255,255,.04); display:flex; align-items:center; justify-content:center;
  color:var(--gold1); font-family:Orbitron; font-size:20px; text-align:center; padding:12px }
.ship-thumb img{ width:100%; height:100%; object-fit:cover; display:block; transition: all 0.35s ease; }
.ship-thumb img:hover { filter: drop-shadow(0 0 10px rgba(114,210,255,.7)) drop-shadow(0 0 20px rgba(248,230,160,.6)); }
.ship-meta{ padding:10px 4px 0 }
.ship-meta h3{ margin:6px 0 4px; font-family: Orbitron; font-size:18px; display:inline-block; }
.ship-tags{ display:flex; gap:8px; flex-wrap:wrap; margin-top:6px }
.ship-tag{ font-size:12px; padding:4px 8px; border:1px solid rgba(248,230,160,.45); border-radius:999px; color:#f3e7bb; background:rgba(248,230,160,.08) }

.panel.mission{ background-image: url('https://robertsspaceindustries.com/rsi/static/images/RSI-logo.svg');
  background-repeat:no-repeat; background-position:center; background-size:120px; background-blend-mode:overlay; background-color: rgba(255,255,255,.02); }

.sc-logo { margin-top:14px; display:flex; justify-content:center; }
.sc-logo img { max-width:160px; width:100%; height:auto; opacity:0.9; transition: all 0.35s ease; transform-origin: 50% 50%; }
.sc-logo img:hover { opacity:1; filter: drop-shadow(0 0 10px rgba(114,210,255,.7)) drop-shadow(0 0 20px rgba(248,230,160,.6)); }

@media (prefers-reduced-motion: reduce) {
  body::before{ animation: none !important; }
  .animated-title span{ animation: fadeInLetter 0.01s forwards !important; }
}
/* --- Ship modal --- */
.modal-backdrop{ position:fixed; inset:0; z-index:100; background:rgba(0,0,0,.6); display:none; align-items:center; justify-content:center; padding:20px; }
.modal-backdrop.show{ display:flex; }
.modal{ width:min(900px, 96vw); background: rgba(8,12,18,.96); border:1px solid rgba(114,210,255,.35); border-radius:16px; box-shadow: 0 20px 60px rgba(0,0,0,.6); overflow:hidden; }
.modal header{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px; border-bottom:1px solid rgba(255,255,255,.08); font-family: Orbitron; }
.modal header h3{ font-size:20px; }
.modal .close{ appearance:none; border:1px solid rgba(255,255,255,.22); background:rgba(255,255,255,.06); color:var(--ink); border-radius:10px; padding:8px 10px; cursor:pointer; }
.modal .body{ display:grid; grid-template-columns: 1.2fr 1fr; gap:16px; padding:16px; }
.modal .preview{ border-radius:12px; overflow:hidden; border:1px solid rgba(255,255,255,.12); aspect-ratio:16/9; background:#0a0f1a; }
.modal .preview img{ width:100%; height:100%; object-fit:cover; display:block; }
.stats{ border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:12px; }
.stats dl{ display:grid; grid-template-columns: 1fr 1fr; gap:8px 14px; font-size:14px }
.stats dt{ color:var(--muted); }
.stats dd{ text-align:right; }
.modal .desc{ margin-top:10px; color:var(--muted); font-size:14px; }
@media (max-width: 720px){ .modal .body{ grid-template-columns: 1fr; } }

/* Make cards feel clickable + keyboardable */
.ship-card[role="button"]{ cursor:pointer; }
.ship-card[role="button"]:focus{ outline:2px solid var(--brand); outline-offset:4px; }
.modal-backdrop{ position:fixed; inset:0; z-index:100; background:rgba(0,0,0,.6); display:none; align-items:center; justify-content:center; padding:20px; }
.modal-backdrop.show{ display:flex; }
.modal{ width:min(900px, 96vw); background: rgba(8,12,18,.96); border:1px solid rgba(114,210,255,.35); border-radius:16px; box-shadow: 0 20px 60px rgba(0,0,0,.6); overflow:hidden; }
.modal header{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px; border-bottom:1px solid rgba(255,255,255,.08); font-family: Orbitron; }
.modal header h3{ font-size:20px; }
.modal .close{ appearance:none; border:1px solid rgba(255,255,255,.22); background:rgba(255,255,255,.06); color:var(--ink); border-radius:10px; padding:8px 10px; cursor:pointer; }
.modal .body{ display:grid; grid-template-columns: 1.2fr 1fr; gap:16px; padding:16px; }
.modal .preview{ border-radius:12px; overflow:hidden; border:1px solid rgba(255,255,255,.12); aspect-ratio:16/9; background:#0a0f1a; }
.modal .preview img{ width:100%; height:100%; object-fit:cover; display:block; }
.stats{ border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:12px; }
.stats dl{ display:grid; grid-template-columns: 1fr 1fr; gap:8px 14px; font-size:14px }
.stats dt{ color:var(--muted); }
.stats dd{ text-align:right; }
.modal .desc{ margin-top:10px; color:var(--muted); font-size:14px; }
@media (max-width: 720px){ .modal .body{ grid-template-columns: 1fr; } }

.ship-card[role="button"]{ cursor:pointer; }
.ship-card[role="button"]:focus{ outline:2px solid var(--brand); outline-offset:4px; }
