:root{
  --navy-900:#060d24;
  --navy-800:#0a1433;
  --navy-700:#111c44;
  --navy-600:#1a2755;
  --navy-500:#2a3a70;
  --line:rgba(255,255,255,0.08);
  --line-strong:rgba(255,255,255,0.16);
  --text:#f4f5f7;
  --muted:rgba(244,245,247,0.58);
  --muted-2:rgba(244,245,247,0.38);
  --orange:#e8793a;
  --orange-hover:#f0884d;
  --orange-dim:#c6632a;
  --success:#6fd99a;
  --danger:#ff7a6b;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--navy-800);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  overflow-x:hidden;
}

/* soft vignette */
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(800px 600px at 85% -10%, rgba(232,121,58,0.08), transparent 60%),
    radial-gradient(900px 700px at -10% 110%, rgba(42,58,112,0.35), transparent 60%);
  pointer-events:none;
  z-index:0;
}

/* ------------ LAYOUT ------------ */
.shell{
  position:relative;
  z-index:1;
  max-width:1240px;
  margin:0 auto;
  padding:28px 28px 120px;
}

/* Top bar */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 0 36px;
}
.logo-pmt{
  display:inline-flex;
  align-items:center;
  gap:12px;
  color:#fff;
  text-decoration:none;
}
.logo-mark{
  font-family:'Archivo',sans-serif;
  font-weight:900;
  letter-spacing:-0.04em;
  font-size:22px;
  line-height:1;
  background:#000;
  color:#fff;
  padding:10px 12px 9px;
  border-radius:6px;
  border:1px solid var(--line-strong);
}
.logo-meta{
  display:flex;flex-direction:column;gap:2px;
  font-size:12px;
  line-height:1.2;
}
.logo-meta .name{font-weight:600;letter-spacing:0.02em}
.logo-meta .role{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:0.18em}

.topbar-right{
  display:flex;align-items:center;gap:18px;
  font-size:12px;color:var(--muted);
}
.save-indicator{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,0.02);
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  letter-spacing:0.04em;
}
.save-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--success);
  box-shadow:0 0 0 3px rgba(111,217,154,0.12);
}
.save-dot.saving{background:var(--orange);box-shadow:0 0 0 3px rgba(232,121,58,0.16);animation:pulse 1.2s infinite}
@keyframes pulse{
  0%,100%{opacity:1}
  50%{opacity:0.4}
}

/* Grid: sidebar + form */
.layout{
  display:grid;
  grid-template-columns:320px 1fr;
  gap:48px;
  align-items:start;
}
@media (max-width: 960px){
  .layout{grid-template-columns:1fr; gap:24px}
  .sidebar{position:static !important}
}

/* Sidebar */
.sidebar{
  position:sticky;
  top:28px;
}
.sidebar h1{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  font-size:44px;
  line-height:0.98;
  letter-spacing:-0.03em;
  margin:0 0 16px;
  text-wrap:balance;
}
.sidebar h1 .pill{
  display:inline-block;
  background:var(--orange);
  color:#0a1433;
  padding:2px 12px 4px;
  border-radius:6px;
  font-weight:900;
  margin-left:2px;
  transform:translateY(-4px);
}
.sidebar p.lead{
  color:var(--muted);
  font-size:14px;
  line-height:1.55;
  margin:0 0 28px;
  max-width:34ch;
}

/* Stepper */
.stepper{
  display:flex;flex-direction:column;
  gap:2px;
  border-left:1px solid var(--line);
  padding-left:0;
  margin-top:20px;
}
.step{
  position:relative;
  display:flex;
  align-items:center;
  gap:14px;
  padding:12px 0 12px 22px;
  cursor:pointer;
  border:0;background:transparent;
  text-align:left;
  color:var(--muted);
  font-family:inherit;
  font-size:13px;
  transition:color .2s;
}
.step::before{
  content:"";
  position:absolute;
  left:-1px;top:50%;
  width:2px;height:0;
  background:var(--orange);
  transform:translateY(-50%);
  transition:height .25s;
}
.step .step-num{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  letter-spacing:0.08em;
  color:var(--muted-2);
  width:24px;
}
.step .step-label{
  font-weight:500;
  letter-spacing:-0.005em;
}
.step .step-check{
  margin-left:auto;
  width:16px;height:16px;
  border-radius:50%;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;
  flex-shrink:0;
}
.step.active{color:#fff}
.step.active::before{height:70%}
.step.active .step-num{color:var(--orange)}
.step.done{color:rgba(244,245,247,0.85)}
.step.done .step-check{
  background:var(--success);
  border-color:var(--success);
  color:#0a1433;
}

/* Form card */
.form-card{
  background:linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
  border:1px solid var(--line);
  border-radius:20px;
  padding:44px 48px 40px;
  backdrop-filter:blur(10px);
  min-height:560px;
  display:flex;flex-direction:column;
}
@media (max-width:720px){
  .form-card{padding:28px 22px 28px; border-radius:16px}
  .shell{padding:20px 16px 80px}
}

/* Section header */
.section-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  margin-bottom:8px;
  padding-bottom:20px;
  border-bottom:1px solid var(--line);
}
.section-head .eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  color:var(--orange);
  letter-spacing:0.12em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.section-head h2{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  font-size:30px;
  line-height:1.05;
  letter-spacing:-0.02em;
  margin:0;
  text-wrap:balance;
}
.section-head .count{
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  color:var(--muted);
  white-space:nowrap;
  padding-left:16px;
}

/* Fields */
.fields{
  display:flex;flex-direction:column;
  gap:28px;
  margin-top:32px;
  flex:1;
}
.field{
  display:flex;flex-direction:column;
  gap:10px;
}
.field-grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:end;
}
.field-grid-2 > .field{
  height:100%;
  justify-content:flex-end;
}
.field-grid-2 > .field label.q{
  min-height:1.4em;
}
@media (max-width:560px){
  .field-grid-2{grid-template-columns:1fr; align-items:stretch}
}
label.q{
  font-size:14.5px;
  font-weight:500;
  line-height:1.4;
  color:#fff;
  display:flex;
  align-items:baseline;
  gap:8px;
  text-wrap:balance;
}
label.q .req{color:var(--orange);font-size:12px}
label.q .hint{color:var(--muted-2);font-size:12px;font-weight:400;margin-left:auto}
.help{
  font-size:12.5px;
  color:var(--muted);
  line-height:1.5;
  margin-top:-4px;
}

/* Inputs */
.input,.textarea,.select{
  width:100%;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--line-strong);
  border-radius:10px;
  color:#fff;
  font-family:inherit;
  font-size:15px;
  padding:13px 14px;
  transition:border-color .15s, background .15s, box-shadow .15s;
  outline:none;
}
.input::placeholder,.textarea::placeholder{color:var(--muted-2)}
.input:hover,.textarea:hover,.select:hover{border-color:rgba(255,255,255,0.24)}
.input:focus,.textarea:focus,.select:focus{
  border-color:var(--orange);
  background:rgba(232,121,58,0.06);
  box-shadow:0 0 0 3px rgba(232,121,58,0.15);
}
.textarea{resize:vertical;min-height:92px;line-height:1.5}
.input.error,.textarea.error{border-color:var(--danger);box-shadow:0 0 0 3px rgba(255,122,107,0.12)}
.err-msg{
  font-size:12px;
  color:var(--danger);
  font-family:'JetBrains Mono',monospace;
}

/* Radio / choice */
.choices{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.choice{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:11px 16px;
  border:1px solid var(--line-strong);
  border-radius:10px;
  background:rgba(255,255,255,0.02);
  cursor:pointer;
  font-size:14px;
  transition:all .15s;
  user-select:none;
}
.choice:hover{border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.05)}
.choice input{position:absolute;opacity:0;pointer-events:none}
.choice .dot{
  width:14px;height:14px;
  border-radius:50%;
  border:1.5px solid var(--line-strong);
  flex-shrink:0;
  transition:all .15s;
}
.choice.selected{
  border-color:var(--orange);
  background:rgba(232,121,58,0.12);
  color:#fff;
}
.choice.selected .dot{
  border-color:var(--orange);
  background:var(--orange);
  box-shadow:inset 0 0 0 3px var(--navy-800);
}

/* scale 1-10 */
.scale{
  display:grid;
  grid-template-columns:repeat(10,1fr);
  gap:6px;
}
.scale-btn{
  border:1px solid var(--line-strong);
  background:rgba(255,255,255,0.02);
  color:var(--muted);
  border-radius:8px;
  padding:10px 0;
  font-family:'JetBrains Mono',monospace;
  font-size:13px;
  font-weight:500;
  cursor:pointer;
  transition:all .15s;
}
.scale-btn:hover{border-color:rgba(255,255,255,0.3);color:#fff}
.scale-btn.selected{
  background:var(--orange);
  border-color:var(--orange);
  color:#0a1433;
  font-weight:700;
}
.scale-legend{
  display:flex;justify-content:space-between;
  font-size:11px;
  color:var(--muted-2);
  font-family:'JetBrains Mono',monospace;
  letter-spacing:0.04em;
  margin-top:4px;
}

/* Footer nav */
.form-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:40px;
  padding-top:24px;
  border-top:1px solid var(--line);
  gap:16px;
}
.progress-wrap{
  flex:1;
  max-width:320px;
}
.progress-label{
  display:flex;justify-content:space-between;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  color:var(--muted);
  margin-bottom:8px;
  letter-spacing:0.04em;
}
.progress-label b{color:#fff;font-weight:600}
.progress-track{
  height:4px;
  background:rgba(255,255,255,0.06);
  border-radius:99px;
  overflow:hidden;
}
.progress-bar{
  height:100%;
  background:var(--orange);
  border-radius:99px;
  transition:width .4s cubic-bezier(.4,0,.2,1);
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:13px 22px;
  border-radius:10px;
  font-family:inherit;
  font-size:14px;
  font-weight:600;
  cursor:pointer;
  border:1px solid transparent;
  transition:all .15s;
  letter-spacing:-0.005em;
}
.btn-primary{
  background:var(--orange);
  color:#0a1433;
}
.btn-primary:hover{background:var(--orange-hover);transform:translateY(-1px)}
.btn-primary:disabled{opacity:0.5;cursor:not-allowed;transform:none;background:var(--orange-dim)}
.btn-ghost{
  background:transparent;
  color:var(--muted);
  border-color:var(--line-strong);
}
.btn-ghost:hover{color:#fff;border-color:rgba(255,255,255,0.3)}
.btn-ghost:disabled{opacity:0.3;cursor:not-allowed}
.btn .arrow{transition:transform .2s}
.btn-primary:hover .arrow{transform:translateX(3px)}

/* Transition */
.page-enter{
  animation:slideIn .35s cubic-bezier(.4,0,.2,1);
}
@keyframes slideIn{
  from{opacity:0;transform:translateX(16px)}
  to{opacity:1;transform:translateX(0)}
}

/* Success */
.success-wrap{
  display:flex;flex-direction:column;
  align-items:center;
  text-align:center;
  padding:40px 20px;
  gap:16px;
}
.success-mark{
  width:72px;height:72px;
  border-radius:50%;
  background:var(--orange);
  color:#0a1433;
  display:flex;align-items:center;justify-content:center;
  font-size:34px;font-weight:900;
  font-family:'Archivo',sans-serif;
}
.success-wrap h2{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  font-size:36px;
  line-height:1;
  letter-spacing:-0.02em;
  margin:8px 0 4px;
}
.success-wrap p{color:var(--muted);max-width:42ch;line-height:1.55;margin:0}
.summary{
  margin-top:28px;
  padding:20px 24px;
  border:1px solid var(--line);
  border-radius:12px;
  background:rgba(255,255,255,0.02);
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
  color:var(--muted);
  text-align:left;
  max-width:440px;
  width:100%;
  line-height:1.7;
}
.summary b{color:#fff;font-weight:500}

/* Intro */
.intro-wrap{
  display:flex;flex-direction:column;
  gap:20px;
  padding:20px 0 0;
}
.intro-wrap .kicker{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  color:var(--orange);
  letter-spacing:0.14em;
  text-transform:uppercase;
}
.intro-wrap h2{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  font-size:44px;
  line-height:0.98;
  letter-spacing:-0.025em;
  margin:0;
  text-wrap:balance;
}
.intro-wrap h2 em{
  font-style:normal;
  background:var(--orange);
  color:#0a1433;
  padding:2px 12px 4px;
  border-radius:6px;
  display:inline-block;
  transform:translateY(-4px);
}
.intro-wrap .lead{
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
  max-width:52ch;
}
.intro-meta{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:16px;
  padding-top:20px;
  border-top:1px solid var(--line);
}
@media (max-width:560px){.intro-meta{grid-template-columns:1fr}}
.meta-cell .k{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  color:var(--muted-2);
  letter-spacing:0.12em;
  text-transform:uppercase;
  margin-bottom:4px;
}
.meta-cell .v{
  font-size:14px;
  color:#fff;
  font-weight:500;
}

.hp{
  position:absolute;
  left:-9999px;
  top:-9999px;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
