: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}

/* 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: mobil 1 Spalte */
.orient-row{display:grid; grid-template-columns:1fr 1fr; gap:14px}
@media (max-width:760px){
  .orient-row{grid-template-columns:1fr}
}

/* deutlicher Fokus, vertikal zentriert */
.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)}

/* Nur EIN grüner Rahmen, kein Doppelschatten */
.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:var(--text)}
.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}

/* Neue Fehlerdarstellung */
.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}}
