:root{--bg:#0b0f16;--panel:#0f1320;--border:#2b3144;--muted:#9aa3af;--text:#e9eef5;--accent:#36d17c;--accent2:#2ac06f}
.container{max-width:980px;margin:0 auto;padding:18px}
.header h1{margin:0 0 6px}.header .sub{margin:0 0 16px;color:#b0b8c4}

.is-hidden{display:none!important}
/* sorgt dafür, dass die Form-Card denselben Schatten/Spacing-Feel hat */
.card.final { padding: 16px 14px; }
.status { color: var(--muted); min-height: 1.2em; }

/* Steps */
.step{margin:18px 0 22px}
.step h2{margin:0 0 12px}
.step.is-disabled{opacity:.35;pointer-events:none;user-select:none}

/* Hero */
.hero{margin:10px 0 16px;text-align:center}
.hero img{max-width:100%;border-radius:14px;border:1px solid var(--border)}
.hero-sub{color:var(--muted);margin:8px 0 0}

/* Orientation buttons */
.orient-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:760px){.orient-row{grid-template-columns:1fr}}
.orient-btn{border:2px solid var(--border);border-radius:16px;background:#101721;cursor:pointer;display:block}
.orient-btn .btn-visual{display:flex;align-items:center;gap:14px;padding:16px;min-height:84px}
.orient-btn .mini{border-radius:8px;box-shadow:inset 0 0 0 2px rgba(255,255,255,.08)}
.orient-btn .mini.landscape{width:68px;height:40px;background:linear-gradient(180deg,#1a5b35,#13432a)}
.orient-btn .mini.portrait{width:40px;height:68px;background:linear-gradient(180deg,#1a5b35,#13432a)}
.orient-btn .txt{display:flex;flex-direction:column;justify-content:center}
.orient-btn .txt .title{font-weight:800}
.orient-btn .txt .sub{color:var(--muted)}
.orient-btn:has(input:checked){border-color:var(--accent);box-shadow:0 0 0 3px rgba(54,209,124,.24)}

/* Upload */
.upload-drop{display:block;border:2px dashed var(--border);border-radius:16px;padding:28px;text-align:center;background:#121728;cursor:pointer}
.upload-icon{font-size:36px;margin-bottom:8px}.upload-title{font-size:1.25rem;margin-bottom:6px}.upload-subtitle{color:var(--muted)}

/* Stage + tools */
.stage{width:100%;min-height:260px;display:grid;place-items:center;background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.stage img{max-width:100%;display:block}
.toolbar{display:flex;gap:8px;margin:10px 0}
.toolbar button{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:#1c2030;color:#e9eef5}
.toolbar button:hover{background:#2b3144}

/* Buttons */
.btn-primary{background:linear-gradient(90deg,var(--accent),var(--accent2));color:#081a10;border:none}
.btn-xl{font-size:1.15rem;padding:12px 18px;border-radius:12px}
.primary-row{display:flex;justify-content:center;margin:14px 0 6px}
.btn-primary.center{display:inline-block;margin-inline:auto}

/* Saved preview */
.saved-wrap{text-align:center;margin-top:16px}
.saved-wrap.is-hidden{display:none}
.export-preview img{max-width:460px;border:1px solid var(--border);border-radius:10px}
.export-info{color:var(--muted);margin-top:6px}

/* Form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid label{display:grid;gap:6px}
.form-grid input,.form-grid select{background:#1c2030;border:1px solid var(--border);color:#e9eef5;border-radius:10px;padding:10px 12px}
.form-grid .primary-row{grid-column:1 / -1;display:flex;justify-content:center}

/* Fehler */
.field-error{color:#e86b6b;font-size:.9rem;min-height:1.1em}
[aria-invalid="true"]{outline:2px solid #e86b6b;outline-offset:2px}

/* Abschlussbereich */
.final-info{grid-column:1 / -1;display:grid;gap:10px;margin-top:8px}
.money-hint{background:#152616;border:1px solid #25562c;color:#cdebd2;padding:10px 12px;border-radius:12px}
.checkbox{display:flex;gap:10px;align-items:flex-start;background:#10151f;border:1px solid var(--border);border-radius:12px;padding:10px 12px}
@media (max-width:760px){.form-grid{grid-template-columns:1fr}}

/* ================= Kalkulator (voll) ================= */
.calc{margin:0 0 12px;padding:18px;border-radius:16px;position:relative;background:radial-gradient(1200px 1200px at 90% -20%, #35d17c22, transparent 60%), linear-gradient(180deg,#101735,#0f1424);border:1px solid var(--border);box-shadow:0 12px 40px #0004,inset 0 0 0 1px #ffffff07}
.calc-head{text-align:center;margin-bottom:8px;color:var(--text)}
.calc-title{font-weight:800;letter-spacing:.2px;font-size:1.4rem;margin:0 0 6px}
.calc-sub{margin:0;color:#8fa0c2;font-size:1rem}
.qty-wrap{display:grid;grid-template-columns:44px 1fr 44px;gap:10px;align-items:center;margin:14px 0 6px}
.qty-btn{display:flex;align-items:center;justify-content:center;background:#141a2b;border:1px solid var(--border);border-radius:12px;height:34px;width:44px;font-size:1rem;color:#e9eef5}
.qty-btn:active{transform:translateY(1px)}
.qty-input{appearance:none;width:100%;height:8px;border-radius:999px;background:#1b2236;border:1px solid #2b3656;outline:none}
.qty-input::-webkit-slider-thumb{appearance:none;width:22px;height:22px;border-radius:50%;background:linear-gradient(180deg,#36d17c,#22c55e);box-shadow:0 6px 18px rgba(54,209,124,.3);border:none;cursor:pointer}
.qty-line{display:flex;justify-content:center;align-items:center;margin-top:8px}
.qty-count{font-weight:900;font-size:1rem;background:#11253f;border:1px solid #234768;color:#cfe8ff;padding:6px 12px;border-radius:999px}
.price-card{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pill{background:#0b1222;border:1px solid #26314d;border-radius:14px;padding:14px 12px;text-align:center}
.pill .big{display:block;font-size:1.8rem;font-weight:900;color:#e9eef5}
.pill .sub{display:block;margin-top:4px;color:#8fa0c2;font-size:.9rem}
.save-pill{background:#0d1a15;border-color:#1e3a2f}
.save-pill .big{color:#7ce2b9}
.note-line{margin-top:6px;text-align:center;color:#8fa0c2;font-size:.9rem}
.badge-float{position:absolute;right:12px;bottom:12px;font-size:.78rem;font-weight:800;background:linear-gradient(90deg,#f59e0b,#f97316);color:#1b1003;border-radius:999px;padding:6px 10px;white-space:nowrap}

.calc-sep{text-align:center;margin-top:16px}
.sep-wrap{display:inline-flex;flex-direction:column;align-items:center;gap:10px;padding:12px 16px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(180deg,#0f1526,#0b101a);color:#cfe1ff;font-weight:800;letter-spacing:.2px;box-shadow:0 6px 24px rgba(0,0,0,.25),inset 0 0 0 1px rgba(255,255,255,.04)}
.sep-text{white-space:nowrap}
.arrow-tray{width:100%;height:40px;margin-top:6px;display:flex;justify-content:center;align-items:center;overflow:hidden;pointer-events:none}
