:root {
  --bg: #0e0e14;
  --card-bg: #1b152c46;

  --primary: #805ad5;
  --primary-opacity: rgba(129, 90, 213, 0.653); 
  --primary-hover: #6b46c1;
  --primary-dark-shadow: #412d92;
  --primary-shadow: #5a3aa9;

  --text: #e1cefe;
  --muted: #a79bbd;

  --success: #4caf50;
  --error: #ef4444;

  --input-bg: #100a1c;
  --input-border: #372d67;
  --feedback-border: rgba(128, 90, 213, 0.2);
  --suggestion-bg: rgba(128, 90, 213, 0.08);

  --btn-disabled-text: #555;
  --shadow: rgba(0, 0, 0, 0.25);
  --grid-line: rgba(129, 90, 213, 0.049);
}

#backgroundCanvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: -1;
  pointer-events: none;
  display: block;
  opacity: 0.2;
  filter: blur(0px);
}

.plus-jakarta-sans> {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 800;
  font-style: normal;
}

body {
  margin: 0;
  background: 
    linear-gradient(to right, var(--grid-line) 1.5px, transparent 1.5px),
    linear-gradient(to bottom, var(--grid-line) 1.5px, transparent 1.5px),
    linear-gradient(to bottom, var(--bg), var(--bg));
  background-size: 40px 40px;
  color: var(--text);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 100vh;
  padding: 20px;
  overscroll-behavior: none;
}

.mission-panel{
  width: min(780px, 92vw);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-radius: 12px;
  padding: 18px;
  margin-top: 18px;
  box-shadow: 0 10px 30px -12px rgba(7,6,15,0.6);
  border: 1px solid rgba(255,255,255,0.03);
}
.mission-desc{
  font-size:15px;
  color:var(--muted);
  margin-bottom:12px;
}
.mission-form{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start}
.mission-form .field{flex:1 1 200px;display:flex;flex-direction:column;gap:6px}
.mission-form label{font-size:13px;color:var(--muted)}
.mission-form input{background:var(--input-bg);border:1px solid var(--input-border);color:var(--text);padding:8px;border-radius:8px}
.mission-form input::placeholder{color:#757083}
.preview-req{flex-basis:100%;margin-top:6px}
.preview-req h4{margin:0 0 6px 0}
.preview-req ul{margin:0;padding-left:18px;color:var(--text);column-count:2;column-gap:24px;list-style-position:inside}
@media (max-width:720px){
  .preview-req ul{column-count:1}
}
.launch-row{flex-basis:100%;display:flex;justify-content:flex-end;margin-top:12px}
.launch-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(180deg,var(--primary),var(--primary-hover));border:0;padding:8px 12px;border-radius:8px;color:#061026;cursor:pointer}
.launch-btn img{width:18px;height:18px}

.preview-card {
  width: min(720px, 90vw);
  height: auto;
  margin: 28px 0 12px;
  perspective: 1200px;
  -webkit-perspective: 1200px;
}

.preview-card img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 14px;
  transform-origin: center center;
  transition: transform 420ms cubic-bezier(.2,.9,.2,1), box-shadow 420ms cubic-bezier(.2,.9,.2,1);
  box-shadow: 0 18px 40px -12px rgba(7,6,15,0.6), inset 0 1px 0 rgba(255,255,255,0.02);
  will-change: transform;
  backface-visibility: hidden;
}

.preview-card::before {
  content: "";
  position: absolute;
  pointer-events: none;
}

.preview-card:hover img,
.preview-card:focus-within img {
  transform: matrix3d(
    1.01, 0.02, 0.00, 0.0003,
    -0.02, 1.04, 0.00, -0.0008,
    0.00, 0.00, 1.00, 0.00005,
    0.00, -18, 0.00, 1.00
  ) translateZ(28px) rotateX(8deg) rotateY(-6deg);
  box-shadow: 0 34px 60px -18px rgba(7,6,15,0.75), 0 8px 30px -10px rgba(90,58,169,0.12);
}

.preview-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.35) 0%, rgba(255,255,255,0.06) 18%, rgba(255,255,255,0.02) 35%, transparent 60%);
  mix-blend-mode: overlay;
  pointer-events: none;
}

.preview-card {
  position: relative;
  display: block;
}

.preview-shadow {
  position: absolute;
  left: 6%;
  right: 6%;
  bottom: -6%;
  height: 40px;
  border-radius: 50%;
  background: radial-gradient(closest-side, rgba(7,6,15,0.55), rgba(7,6,15,0.16) 45%, transparent 70%);
  filter: blur(18px);
  transform-origin: 50% 50% 0;
  transition: transform 420ms cubic-bezier(.2,.9,.2,1), opacity 320ms ease;
  z-index: 0;
  pointer-events: none;
}

.preview-card img { position: relative; z-index: 1; }

@media (prefers-reduced-motion: reduce) {
  .preview-card img { transition: none; transform: none !important; }
}