*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;color:#0f172a;background:#0b1220}
.app-container{max-width:1100px;margin:0 auto;padding:24px}
.app-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
h1{margin:0;color:#e2e8f0;font-size:28px} .subtitle{color:#94a3b8;margin:0}
.wizard{background:#0f172a;border:1px solid #1e293b;border-radius:16px;overflow:hidden}
.wizard-progress{height:6px;background:#0b1220} .wizard-progress-bar{height:100%;background:#22c55e;transition:width .25s}
.wizard-body{display:grid;grid-template-columns:1fr 340px;gap:0}
.wizard-step{padding:24px 24px 12px}
.summary{border-left:1px solid #1e293b;background:#0b1220;padding:16px 16px;height:100%}
.summary h2{margin:4px 0 12px 0;color:#e2e8f0}
#summaryContent{font-size:14px;color:#cbd5e1;display:grid;gap:8px}
.cost-line{display:flex;align-items:center;justify-content:space-between;margin:6px 0;color:#e2e8f0}
.cost-line.total{font-size:18px;border-top:1px dashed #334155;margin-top:10px;padding-top:10px}
.cta-col{display:flex;gap:8px;margin-top:12px}
.app-legal{color:#64748b;margin-top:12px}

label{display:block;color:#cbd5e1;margin:10px 0 6px}
input[type="text"],input[type="number"],select{width:100%;padding:10px;border-radius:10px;border:1px solid #334155;background:#0b1220;color:#e2e8f0}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.helper{font-size:12px;color:#8b9bb1;margin-top:4px}
.tooltip{border-bottom:1px dotted #94a3b8;cursor:help}
.badge{display:inline-block;background:#1e293b;color:#e2e8f0;border:1px solid #334155;border-radius:999px;padding:2px 8px;font-size:12px}
hr{border:0;border-top:1px solid #1e293b;margin:10px 0}

.btn{appearance:none;border:1px solid #334155;background:#111827;color:#e5e7eb;padding:10px 14px;border-radius:12px;cursor:pointer}
.btn:hover{filter:brightness(1.1)}
.btn[disabled]{opacity:.5;cursor:not-allowed}
.btn.primary{background:#22c55e;border-color:#16a34a;color:#07260c;font-weight:600}
.btn.ghost{background:transparent}

.choice{display:flex;gap:8px;flex-wrap:wrap}
.choice .opt{border:1px solid #334155;padding:8px 10px;border-radius:10px;cursor:pointer;color:#e2e8f0}
.choice .opt.active{border-color:#22c55e;background:#08230f}

.step-title{color:#e2e8f0;margin:0 0 8px}
.step-desc{color:#94a3b8;margin:0 0 16px;font-size:14px}
.grid{display:grid;gap:12px}
@media (max-width: 920px){
  .wizard-body{grid-template-columns:1fr}
  .summary{border-left:0;border-top:1px solid #1e293b}
}
