:root {
  --primary: #06B6D4;
  --primary-dark: #0891B2;
  --navy: #0F172A;
  --navy-border: #1e2d44;
  --text: #101828;
  --text-soft: #475467;
  --line: #eef2f8;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif; color: var(--text); background: #f4f7fb; line-height: 1.55; }
sub { font-size: 0.72em; }

/* Schlanke dunkle Yostro-Kopfleiste */
.hdr { position: relative; display: flex; align-items: center; padding: 13px 24px; background: var(--navy); }
.hdr-back { color: var(--primary); text-decoration: none; font-size: 15px; font-weight: 700; letter-spacing: -0.2px; }
.hdr-back:hover { color: #22D3EE; }
.hdr-title { position: absolute; left: 50%; transform: translateX(-50%); font-weight: 600; font-size: 16px; color: #fff; }

/* Breiter als v1: das Cockpit braucht Platz für zwei Spalten. */
.wrap { max-width: 1240px; margin: 0 auto; padding: 32px 24px 64px; }

/* Eingabeformular */
.form { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px 24px; background: #fff; border-radius: 16px; padding: 24px; box-shadow: 0 4px 16px rgba(16,24,40,0.06); }
.form label { display: flex; flex-direction: column; gap: 6px; }
.form label span { font-size: 13px; font-weight: 600; color: var(--text-soft); white-space: nowrap; }
.form input { border: 1px solid #d0d5dd; border-radius: 8px; padding: 10px 12px; font-size: 15px; color: var(--text); }
.form input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(6,182,212,0.15); }
.form button { grid-column: 1 / -1; position: relative; background: var(--primary); color: #fff; border: 0; border-radius: 10px; padding: 13px; font-size: 15px; font-weight: 700; cursor: pointer; transition: background 0.15s ease; }
.form button:hover { background: var(--primary-dark); }
.form button:disabled { cursor: default; }

/* Ladezustand: Label ausblenden, Spinner einblenden */
.form button.laedt .btn-label { visibility: hidden; }
.form button.laedt::after { content: ""; position: absolute; inset: 0; margin: auto; width: 18px; height: 18px; border: 2px solid rgba(255,255,255,0.4); border-top-color: #fff; border-radius: 50%; animation: ysd-spin 0.8s linear infinite; }
@keyframes ysd-spin { to { transform: rotate(360deg); } }

/* Fehlerbox (Validierung + Netz-/Serverfehler). [hidden] explizit aufheben,
   weil display:flex das hidden-Attribut sonst überstimmt. */
.fehler { display: flex; gap: 14px; align-items: center; justify-content: space-between; flex-wrap: wrap; background: #fdeaea; border: 1px solid #e0a0a0; border-radius: 10px; padding: 12px 14px; color: #7a1f1f; font-size: 14px; margin-top: 16px; }
.fehler[hidden] { display: none; }
.fehler button { background: #b42318; color: #fff; border: 0; border-radius: 8px; padding: 8px 14px; font-size: 13px; font-weight: 600; cursor: pointer; }
.fehler button:hover { background: #912018; }

.hint { color: var(--text-soft); font-size: 14px; margin-top: 14px; }

/* Größen-Tabs */
.tabnav { display: flex; gap: 8px; margin: 24px 0 0; flex-wrap: wrap; }
.tabbtn { background: #eef2f8; border: 1px solid #e4e9f0; border-radius: 10px; padding: 9px 16px; color: var(--text-soft); cursor: pointer; font-size: 14px; white-space: nowrap; transition: background 0.15s ease; }
.tabbtn:hover { background: #e2e9f2; }
.tabbtn.active { background: var(--primary); border-color: var(--primary); color: #fff; font-weight: 600; }

/* PDF-Export: Sekundär-Aktion, dunkel statt Primärfarbe, rechts in der Tab-Leiste */
.pdf-btn { margin-left: auto; background: var(--navy); border: 1px solid var(--navy-border); border-radius: 10px; padding: 9px 16px; color: #fff; cursor: pointer; font-size: 14px; font-weight: 600; white-space: nowrap; transition: background 0.15s ease; }
.pdf-btn:hover { background: #1b2a44; }
.pdf-btn:disabled { cursor: default; opacity: 0.7; }

/* Vergleichsansicht: Tabelle über die volle Breite (Spalten = Größen) */
.vergleich-card { margin-top: 16px; }
.vergleich-tabelle { width: 100%; border-collapse: collapse; }
.vergleich-tabelle th,
.vergleich-tabelle td { padding: 12px 10px; border-bottom: 1px solid #f0f3f8; font-size: 15px; }
.vergleich-tabelle thead th { color: var(--text); font-weight: 700; text-align: right; border-bottom: 1px solid var(--line); }
.vergleich-tabelle th[scope=row] { text-align: left; color: #344054; font-weight: 600; white-space: nowrap; }
.vergleich-tabelle td { text-align: right; font-variant-numeric: tabular-nums; color: #06283d; font-weight: 700; }
.vergleich-tabelle .anordnung { font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-weight: 700; letter-spacing: 0.5px; }
.vergleich-tabelle tbody tr:last-child th,
.vergleich-tabelle tbody tr:last-child td { border-bottom: 0; }
.vergleich-tabelle tfoot td { border-bottom: 0; padding-top: 16px; text-align: center; }
.select-btn { width: 100%; background: var(--primary); border: 1px solid var(--primary); border-radius: 8px; padding: 8px 12px; color: #fff; font-size: 13px; font-weight: 600; cursor: pointer; transition: background 0.15s ease; }
.select-btn:hover { background: var(--primary-dark); }

/* Cockpit: Werte links, Zeichnungen rechts (sticky) */
.cockpit { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr); gap: 16px 20px; align-items: start; margin-top: 16px; }
.cockpit-zeichnungen { position: sticky; top: 16px; display: flex; flex-direction: column; gap: 16px; }

/* Karten */
.card { background: #fff; border-radius: 16px; padding: 24px; box-shadow: 0 4px 16px rgba(16,24,40,0.06); }
.cockpit-werte .card + .card { margin-top: 16px; }
.card-title { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
/* Transparenz-Zeile der Grundauslegung: rückt unter den Titel-Trennstrich */
.card-subtitle { font-size: 12px; color: #98a2b3; margin: -8px 0 10px; }
.card-adjust { border-top: 3px solid var(--primary); }

/* Blueprint-Zeichnungskarten: dunkel wie eine Konstruktions-Software */
.card-zeichnung { background: var(--navy); border: 1px solid var(--navy-border); box-shadow: 0 4px 16px rgba(16,24,40,0.18); }
.card-zeichnung .card-title { color: #e6eef7; border-bottom-color: var(--navy-border); }

/* Diagramm-Wrapper + Maß-Labels (HTML-Overlay, Pixel-Schrift skaliert nicht mit) */
.diagramm-wrapper { position: relative; width: 100%; }
.diagramm-svg-slot { display: block; width: 100%; }
.diagramm-wrapper svg { display: block; width: 100%; height: auto; }
.diagramm-label { position: absolute; font-size: 12px; color: #cfe3f5; pointer-events: none; background: rgba(15, 23, 42, 0.8); padding: 1px 6px; border-radius: 3px; }
.diagramm-label-oben-links { top: 8px; left: 8px; }
.diagramm-label-oben-rechts { top: 8px; right: 8px; }
.diagramm-label-unten-links { bottom: 8px; left: 8px; }
.diagramm-label-unten-rechts { bottom: 8px; right: 8px; }
/* unten-mitte sitzt UNTER der SVG, nicht überlagernd — so wächst der Container
   automatisch um die Label-Höhe mit (wie im Visualizer). */
.diagramm-label-unten-mitte { position: relative; text-align: center; margin-top: 4px; background: none; display: block; }

/* Zweispaltige Ergebniszeilen */
.rows > div { display: flex; justify-content: space-between; align-items: baseline; gap: 20px; padding: 12px 2px; border-bottom: 1px solid #f0f3f8; font-size: 15px; }
.rows > div:last-child { border-bottom: 0; }
.rows > div span { color: #344054; white-space: nowrap; }
.rows > div b { font-variant-numeric: tabular-nums; color: #06283d; font-weight: 700; text-align: right; }
.rows .anordnung { font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace; font-weight: 700; letter-spacing: 0.5px; }

/* n_w-Steuerung */
.cp-block { margin-bottom: 6px; }
.cp-block > label.head { display: block; font-weight: 600; font-size: 15px; color: var(--text); margin-bottom: 12px; }
.cp-block input[type=range] { width: 100%; accent-color: var(--primary); }
.cp-scale { display: flex; justify-content: space-between; font-size: 12px; color: #667085; margin-top: 6px; }
.cp-inputs { display: flex; flex-wrap: wrap; gap: 16px 28px; margin: 18px 0 4px; }
.cp-inputs label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; font-weight: 600; color: var(--text-soft); }
.cp-inputs .cap { white-space: nowrap; }
.cp-inputs .unit { display: flex; align-items: center; gap: 8px; }
.cp-inputs input { width: 120px; border: 1px solid #d0d5dd; border-radius: 8px; padding: 9px 11px; font-size: 15px; color: var(--text); }
.cp-inputs input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(6,182,212,0.15); }
.divider { border: 0; border-top: 1px solid var(--line); margin: 18px 0; }

/* Warnung + „nicht machbar" */
.warn { background: #fff4e0; border: 1px solid #f0c069; border-radius: 8px; padding: 10px 12px; font-size: 13px; color: #663c00; margin-bottom: 14px; }
.nogo { background: #fdeaea; border: 1px solid #e0a0a0; border-radius: 8px; padding: 10px 12px; font-size: 14px; color: #7a1f1f; }
/* Fehlerbox liegt im .rows-Container: dessen Flex-Layout aufheben, sonst werden die
   Textteile (Text | n_w | Rest) per space-between auseinandergerissen. */
.rows > .nogo { display: block; }
.nw { white-space: nowrap; } /* Formelzeichen n_w nie im Tiefstellungs-Token umbrechen */

/* Haftungs-Disclaimer: volle Seitenbreite ganz unten (analog Förderband-Rechner/Visualizer) */
.disclaimer { display: flex; gap: 14px; align-items: flex-start; padding: 14px 24px; background: rgba(255,193,7,0.06); border-top: 1px solid rgba(255,193,7,0.3); font-size: 13px; line-height: 1.55; color: #495057; }
.disclaimer-icon { flex-shrink: 0; width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: rgba(255,193,7,0.15); font-size: 14px; font-weight: 700; color: #b45309; }
.disclaimer strong { color: #212529; font-weight: 600; }

/* Tablet hochkant / schmale Fenster: Cockpit einspaltig, Zeichnungen ZUERST
   (das Bild ist die Rückmeldung beim Sliden) und nicht mehr sticky. */
@media (max-width: 960px) {
  .cockpit { grid-template-columns: 1fr; }
  .cockpit-zeichnungen { position: static; order: -1; }
  .vergleich-tab { display: none; } /* nur Desktop: einspaltig kein Mehrwert ggü. Tabs */
}

/* Smartphone */
@media (max-width: 680px) {
  .wrap { padding: 22px 16px 56px; }
  .hdr { padding: 12px 16px; gap: 10px; }
  .hdr-title { position: static; transform: none; flex: 1; text-align: center; font-size: 14px; }
  .form { grid-template-columns: 1fr; gap: 14px; padding: 18px; }
  .card { padding: 18px; }
  .rows > div { align-items: flex-start; gap: 12px; }
  .rows > div span { white-space: normal; }
  /* Anordnung mobil gestapelt: Label-Zeile, Wert linksbündig darunter über volle Breite
     — die Kette ist zu breit, um neben dem Label einzeilig zu passen. */
  .rows > div.row-anordnung { flex-direction: column; gap: 4px; }
  .rows > div.row-anordnung b { text-align: left; }
  .cp-inputs { flex-direction: column; gap: 14px; }
  .cp-scale { font-size: 11px; }
  .disclaimer { padding: 14px 16px; }
}
