/* Vertragsleistung Online — MAIN-Look (Navy + Teal, Palette wie Aufgabenplaner). Vanilla, kein Build. */
:root {
  --navy: #1E1F5B;
  --navy2: #2E3192;
  --primary-hover: #3A3FB0;   /* Aufgabenplaner --primary-hover */
  --accent: #008BA3;          /* Aufgabenplaner --accent (Teal) */
  --gold: #008BA3;            /* Markenakzent = Teal (wie Aufgabenplaner), nicht mehr Gold */
  --gold-d: #036b80;
  --bg: #EEF1F7;
  --card: #ffffff;
  --text: #1f2233;
  --muted: #6b7088;
  --line: #e2e6f0;
  --danger: #D10000;
  /* Status-Farben */
  --s-risiko: #6b7a99;
  --s-nummer: #2E7CD6;
  --s-kalk: #E69500;
  --s-konzept: #7A52C8;
  --s-abgegeben: #00897B;
  --s-auftrag: #1F8A30;
  --s-abgelehnt: #D10000;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: "Segoe UI", system-ui, -apple-system, sans-serif;
  background: var(--bg); color: var(--text); font-size: 15px;
  -webkit-text-size-adjust: 100%;
}
button { font-family: inherit; }

/* ---------- Topbar ---------- */
.topbar {
  display: flex; align-items: center; gap: 12px;
  background: linear-gradient(90deg, #15163f, var(--navy) 55%, var(--navy2));
  color: #fff; padding: 0 18px;
  height: calc(56px + env(safe-area-inset-top));
  padding-top: env(safe-area-inset-top);
  position: sticky; top: 0; z-index: 40;
  box-shadow: 0 2px 12px rgba(8, 12, 40, .25);
}
.brand { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: 17px; letter-spacing: .2px; }
.brand-v {
  display: inline-grid; place-items: center; width: 30px; height: 30px;
  background: var(--accent); color: #fff; border-radius: 8px; font-weight: 800;
}
.spacer { flex: 1; }
.userbox { display: flex; align-items: center; gap: 10px; }
.uname { opacity: .9; font-size: 14px; max-width: 40vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ---------- Buttons ---------- */
.btn {
  border: 1px solid var(--line); background: #fff; color: var(--text);
  padding: 9px 16px; border-radius: 10px; cursor: pointer; font-size: 14px; font-weight: 500;
  transition: filter .12s, background .12s, border-color .12s;
}
.btn:hover { filter: brightness(.97); }
.btn:disabled { opacity: .55; cursor: not-allowed; }
.btn.primary { background: var(--navy2); border-color: var(--navy2); color: #fff; font-weight: 600; }
.btn.primary:hover { background: var(--primary-hover); filter: none; }
.btn.ghost { background: transparent; border-color: rgba(255, 255, 255, .35); color: #fff; }
.btn.ghost:hover { background: rgba(255, 255, 255, .12); filter: none; }
.btn.sm { padding: 6px 11px; font-size: 13px; }
.btn.danger { color: var(--danger); border-color: #f0c0c0; }

/* ---------- Content ---------- */
.content { max-width: 980px; margin: 0 auto; padding: 20px 16px 60px; }
.toolbar { display: flex; gap: 10px; align-items: center; margin-bottom: 16px; }
.search {
  flex: 1; padding: 10px 14px; border: 1px solid var(--line); border-radius: 10px;
  font-size: 15px; background: #fff;
}
.leer { text-align: center; color: var(--muted); padding: 48px 12px; }

/* ---------- Objektliste ---------- */
.liste { display: flex; flex-direction: column; gap: 10px; }
.okarte {
  display: flex; align-items: center; gap: 14px; background: var(--card);
  border: 1px solid var(--line); border-radius: 14px; padding: 14px 16px; cursor: pointer;
  box-shadow: 0 1px 3px rgba(20, 24, 60, .05); transition: box-shadow .12s, transform .06s;
}
.okarte:hover { box-shadow: 0 6px 18px rgba(20, 24, 60, .12); }
.ok-haupt { flex: 1; min-width: 0; }
.ok-adr { font-weight: 600; font-size: 15.5px; }
.ok-sub { color: var(--muted); font-size: 13px; margin-top: 3px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ---------- Status-Badge ---------- */
.badge { display: inline-block; padding: 4px 11px; border-radius: 999px; font-size: 12.5px; font-weight: 600; color: #fff; white-space: nowrap; }
.badge.s-risiko_beantragt { background: var(--s-risiko); }
.badge.s-angebotsnummer_erhalten { background: var(--s-nummer); }
.badge.s-kalkulation { background: var(--s-kalk); }
.badge.s-konzept { background: var(--s-konzept); }
.badge.s-angebot_abgegeben { background: var(--s-abgegeben); }
.badge.s-auftrag { background: var(--s-auftrag); }
.badge.s-abgelehnt { background: var(--s-abgelehnt); }

/* ---------- Detail ---------- */
.back { background: none; border: none; color: var(--navy2); cursor: pointer; font-size: 14px; padding: 0; margin-bottom: 12px; }
.dhead { display: flex; align-items: center; gap: 12px; margin-bottom: 6px; }
.dhead h1 { font-size: 22px; margin: 0; }
.dsub { color: var(--muted); margin-bottom: 18px; }
.card {
  background: var(--card); border: 1px solid var(--line); border-radius: 14px;
  padding: 18px; margin-bottom: 18px; box-shadow: 0 1px 3px rgba(20, 24, 60, .05);
}
.card h3 { margin: 0 0 14px; font-size: 15px; color: var(--navy); text-transform: uppercase; letter-spacing: .4px; }

/* ---------- Stepper ---------- */
.stepper { display: flex; flex-wrap: wrap; gap: 6px 4px; }
.step { display: flex; align-items: center; gap: 7px; padding: 6px 10px 6px 6px; border-radius: 999px; background: #f1f3f9; color: var(--muted); font-size: 12.5px; }
.step .dot { display: inline-grid; place-items: center; width: 20px; height: 20px; border-radius: 50%; background: #cdd3e2; color: #fff; font-size: 11px; font-weight: 700; }
.step.done { background: #e8f3ea; color: #2b6b38; }
.step.done .dot { background: var(--s-auftrag); }
.step.cur { background: var(--navy); color: #fff; }
.step.cur .dot { background: var(--accent); color: #fff; }

/* ---------- Formfelder ---------- */
.feld { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; }
.flabel { font-size: 12.5px; color: var(--muted); font-weight: 600; }
.feld input, .feld select, .feld textarea {
  padding: 9px 12px; border: 1px solid var(--line); border-radius: 9px; font-size: 14.5px;
  font-family: inherit; background: #fff; width: 100%;
}
.feld textarea { resize: vertical; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 14px; }
.error { color: var(--danger); font-size: 13.5px; min-height: 18px; }

/* ---------- Module ---------- */
.module { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.modkarte { border: 1px solid var(--line); border-radius: 12px; padding: 15px; background: #fbfcfe; display: flex; flex-direction: column; gap: 9px; }
.modkopf { display: flex; align-items: center; justify-content: space-between; font-weight: 700; color: var(--navy); }
.modbadge { font-size: 11px; font-weight: 600; color: #036b80; background: #e6f4f7; border: 1px solid #b8e0e6; padding: 2px 8px; border-radius: 999px; }
.modtext { font-size: 13px; color: var(--muted); flex: 1; line-height: 1.45; }

/* ---------- Risikobewertung-Panel ---------- */
.risiko { display: flex; flex-direction: column; gap: 16px; }
.rb-step { border: 1px solid var(--line); border-radius: 12px; padding: 15px; background: #fbfcfe; }
.rb-h { font-weight: 700; color: var(--navy); margin-bottom: 3px; }
.rb-sub { font-size: 13px; color: var(--muted); margin-bottom: 12px; line-height: 1.45; }
.rb-mail { display: flex; gap: 10px; align-items: center; margin-bottom: 12px; flex-wrap: wrap; }
.rb-mail input[type=file] { font-size: 13px; }
.dok-name { flex: 1; }
.dok-dl { color: var(--navy2); font-weight: 700; }

/* ---------- Dokumente ---------- */
.doks { display: flex; flex-direction: column; gap: 8px; }
.dok { display: flex; align-items: center; gap: 10px; font-size: 14px; padding: 8px 10px; border: 1px solid var(--line); border-radius: 9px; }
.dok .typ { font-size: 11px; font-weight: 700; color: var(--navy2); background: #eef0fb; padding: 2px 7px; border-radius: 6px; }

/* ---------- Modal / Auth ---------- */
.overlay { position: fixed; inset: 0; background: rgba(15, 18, 45, .45); display: grid; place-items: center; padding: 16px; z-index: 60; overflow: auto; }
.modal { background: #fff; border-radius: 16px; padding: 22px; width: min(560px, 96vw); box-shadow: 0 18px 50px rgba(8, 12, 40, .35); }
.modal h2 { margin: 0 0 16px; font-size: 19px; color: var(--navy); }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 8px; }

.auth-bg { min-height: 100vh; display: grid; place-items: center; background: linear-gradient(135deg, #15163f, var(--navy) 60%, var(--navy2)); padding: 16px; }
.auth-wrap { background: #fff; border-radius: 18px; padding: 30px 28px; width: min(400px, 94vw); box-shadow: 0 20px 60px rgba(0, 0, 0, .35); }
.auth-wrap .logo { display: grid; place-items: center; width: 54px; height: 54px; background: linear-gradient(135deg, var(--accent), var(--navy2)); color: #fff; border-radius: 14px; font-size: 28px; font-weight: 800; margin: 0 auto 14px; }
.auth-wrap h2 { text-align: center; margin: 0 0 4px; color: var(--navy); }
.auth-wrap .sub { text-align: center; color: var(--muted); font-size: 13.5px; margin-bottom: 20px; }
.auth-wrap .switch { text-align: center; margin-top: 14px; font-size: 13.5px; color: var(--muted); }
.auth-wrap .switch a { color: var(--navy2); cursor: pointer; font-weight: 600; }

/* ---------- Adress-Autocomplete ---------- */
.ac { position: relative; }
.ac-drop { position: absolute; left: 0; right: 0; top: 100%; background: #fff; border: 1px solid var(--line); border-top: none; border-radius: 0 0 10px 10px; box-shadow: 0 10px 24px rgba(8, 12, 40, .18); z-index: 5; display: none; max-height: 260px; overflow: auto; }
.ac-item { padding: 9px 12px; cursor: pointer; font-size: 14px; border-bottom: 1px solid #f1f3f9; }
.ac-item:hover { background: #f4f6fc; }

/* ---------- Toast ---------- */
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); background: var(--navy); color: #fff; padding: 11px 20px; border-radius: 10px; box-shadow: 0 8px 24px rgba(8, 12, 40, .35); z-index: 80; font-size: 14px; }

/* ---------- Kalkulation (4 Phasen) ---------- */
.kbar { max-width: 1180px; margin: 0 auto; padding: 14px 16px 0; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.kstepper { display: flex; gap: 6px; flex-wrap: wrap; }
.kstep { display: flex; align-items: center; gap: 8px; border: 1px solid var(--line); background: #fff; color: var(--muted); padding: 7px 14px; border-radius: 999px; cursor: pointer; font-size: 13.5px; font-weight: 600; }
.kstep .kdot { display: inline-grid; place-items: center; width: 20px; height: 20px; border-radius: 50%; background: #cdd3e2; color: #fff; font-size: 11px; }
.kstep.cur { background: var(--accent); border-color: var(--accent); color: #fff; }
.kstep.cur .kdot { background: #fff; color: var(--accent); }
.kalk-content { max-width: 1180px; }
.kh { font-size: 18px; color: var(--navy); margin: 6px 0 16px; }
.kinfo { margin-top: 14px; background: #e6f4f7; border: 1px solid #b8e0e6; border-left: 4px solid var(--accent); border-radius: 8px; padding: 10px 14px; font-size: 13px; color: #06596b; }
.kactions { display: flex; justify-content: space-between; gap: 10px; margin-top: 18px; }
.kactions .btn.primary { margin-left: auto; }
.btn.sm { padding: 6px 11px; font-size: 12.5px; }

.btiles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.btile { border: 1px solid var(--line); border-radius: 10px; background: #fff; padding: 13px; cursor: pointer; transition: border-color .12s; }
.btile:hover { border-color: var(--accent); }
.btile.on { border-left: 5px solid var(--accent); box-shadow: 0 2px 10px rgba(0, 139, 163, .12); }
.btile.addon { background: #fbfcfe; }
.bt-h { font-weight: 700; color: var(--navy); display: flex; justify-content: space-between; gap: 6px; }
.bt-n { color: var(--accent); font-size: 12.5px; font-weight: 600; margin: 4px 0 6px; }
.bt-list { font-size: 12px; color: var(--muted); line-height: 1.5; }
.pflicht { font-size: 10px; font-weight: 700; color: #fff; background: var(--danger); padding: 2px 7px; border-radius: 999px; align-self: center; }

.k3 { display: grid; grid-template-columns: 220px 1fr 300px; gap: 14px; align-items: start; }
.k3-l, .k3-m, .k3-r { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 12px; }
.klabel { font-size: 11.5px; font-weight: 700; color: var(--navy); text-transform: uppercase; letter-spacing: .4px; margin: 6px 0; }
.klist { display: flex; flex-direction: column; gap: 2px; margin-bottom: 8px; }
.klist-item { padding: 7px 10px; border-radius: 7px; cursor: pointer; font-size: 13.5px; }
.klist-item:hover { background: #f1f3f9; }
.klist-item.sel { background: var(--accent); color: #fff; font-weight: 600; }
.akacheln { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 10px; }
.akachel { border: 1px solid var(--line); border-left: 5px solid #cdd3e2; border-radius: 10px; padding: 11px; background: #fff; }
.akachel.m-pflicht { border-left-color: #D32F2F; }
.akachel.m-ueblich { border-left-color: #2E7D32; }
.akachel.m-optional { border-left-color: #E65100; }
.ak-h { display: flex; justify-content: space-between; gap: 6px; font-weight: 600; font-size: 12.5px; }
.ak-pz { color: var(--muted); font-size: 11px; white-space: nowrap; }
.ak-stk { font-size: 11.5px; color: var(--muted); margin: 5px 0 8px; }
.kpos { display: flex; flex-direction: column; gap: 7px; max-height: 62vh; overflow: auto; }
.kpos-z { border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; }
.kpos-t { display: flex; justify-content: space-between; gap: 8px; font-weight: 600; font-size: 13px; }
.kpos-x { color: var(--danger); cursor: pointer; font-weight: 700; }
.kpos-m { font-size: 11.5px; color: var(--muted); margin-top: 3px; }

.kdialog { width: min(760px, 96vw); }
.kemp { background: #e6f4f7; border: 1px solid #b8e0e6; border-radius: 8px; padding: 10px 12px; font-size: 13px; color: #06596b; margin-bottom: 14px; }
.kemp-t { font-weight: 700; margin-bottom: 3px; }
.kaufbau { background: #1b2030; color: #e8ecf5; border-radius: 8px; padding: 12px 14px; font-size: 13px; line-height: 1.7; margin-top: 10px; }
.kgesamt { font-weight: 800; color: #7fe0c4; font-size: 16px; margin-top: 6px; }

.kbaum { display: flex; flex-direction: column; gap: 2px; }
.kb-ber { display: flex; justify-content: space-between; font-weight: 700; color: var(--navy); padding: 8px 4px 4px; border-bottom: 1px solid var(--line); }
.kb-gew { display: flex; justify-content: space-between; font-weight: 600; padding: 5px 4px 5px 16px; }
.kb-pos { display: flex; justify-content: space-between; gap: 10px; font-size: 12.5px; color: var(--muted); padding: 3px 4px 3px 30px; }
.kplausi { font-size: 13.5px; }
.ksumme { text-align: right; font-size: 20px; font-weight: 800; color: var(--navy); margin: 14px 2px; }

@media (max-width: 1024px) {
  .btiles { grid-template-columns: 1fr 1fr; }
  .k3 { grid-template-columns: 1fr; }
  .akacheln { grid-template-columns: 1fr; }
}

/* ---------- Mobil ---------- */
@media (max-width: 1024px) {
  .module { grid-template-columns: 1fr; }
  .grid2 { grid-template-columns: 1fr; }
  .uname { display: none; }
}
