/* =============================================================
   Immo Wertermittlung — Herobanner Glas-Karte (E&V-Stil)
   Markendesign Immobilienservice Altan
   Gold #BCA257 · Nunito (weich, abgerundet) · helle Karte
   Alles unter .imwo-wrap gescoped.
   ============================================================= */

.imwo-wrap {
  /* ── Markenpalette (helle Variante) ── */
  --imwo-gold:        #BCA257;
  --imwo-gold-bright: #CBB066;
  --imwo-gold-deep:   #A8842A;
  --imwo-gold-hover:  #A88E47;
  --imwo-gold-pale:   rgba(188,162,87,0.12);
  --imwo-ink:         #14140F;
  --imwo-text:        #1F1D18;
  --imwo-text-mid:    #5C564C;
  --imwo-text-dim:    #978C78;
  --imwo-line:        #E7E1D6;
  --imwo-line-gold:   rgba(188,162,87,0.55);
  --imwo-field:       #F7F4ED;
  --imwo-field-focus: #FFFFFF;
  --imwo-error:       #C0392B;

  box-sizing: border-box;
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
  padding: 48px 54px 38px;
  border-radius: 22px;
  border: 1px solid var(--imwo-line);
  background: #FFFFFF;
  box-shadow: 0 24px 60px -28px rgba(40,34,18,0.30), 0 2px 8px -4px rgba(40,34,18,0.10);
  font-family: 'Nunito', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 16px;
  line-height: 1.5;
  color: var(--imwo-text);
  -webkit-font-smoothing: antialiased;
  text-align: left;
}

.imwo-wrap *,
.imwo-wrap *::before,
.imwo-wrap *::after { box-sizing: border-box; }

/* Gold-Akzentlinie oben */
.imwo-wrap::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--imwo-gold), var(--imwo-gold-bright), var(--imwo-gold), transparent);
}

/* ── Kartenkopf ──────────────────────────────────────────── */
.imwo-card-head { margin-bottom: 30px; }

.imwo-brand-eyebrow {
  display: inline-block;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--imwo-gold);
  margin-bottom: 12px;
}

.imwo-card-title {
  font-family: inherit;
  font-weight: 800;
  font-size: 40px;
  line-height: 1.14;
  letter-spacing: -0.01em;
  color: var(--imwo-text);
  margin: 0 0 11px;
}

.imwo-card-sub {
  font-size: 17.5px;
  color: var(--imwo-text-mid);
  margin: 0;
}

/* ── Schritt-Indikator ───────────────────────────────────── */
.imwo-steps-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  margin-bottom: 12px;
}

.imwo-step-top-item {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 0 1 auto;
  min-width: 0;
  transition: opacity 0.3s ease;
}
.imwo-step-top-item.inactive { opacity: 0.45; }

.imwo-step-top-dot {
  flex: 0 0 auto;
  width: 24px; height: 24px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 500;
  border: 1px solid var(--imwo-line-gold);
  color: var(--imwo-text-mid);
  background: transparent;
  transition: all 0.3s ease;
}
.imwo-step-top-item.active .imwo-step-top-dot {
  background: var(--imwo-gold);
  border-color: var(--imwo-gold);
  color: var(--imwo-ink);
  font-weight: 600;
  box-shadow: 0 0 0 4px var(--imwo-gold-pale);
}
.imwo-step-top-item.done .imwo-step-top-dot {
  background: transparent;
  border-color: var(--imwo-gold);
  color: var(--imwo-gold);
}

.imwo-step-top-label {
  font-size: 12px;
  font-weight: 400;
  color: var(--imwo-text-mid);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.imwo-step-top-item.active .imwo-step-top-label { color: var(--imwo-text); font-weight: 500; }

/* ── Fortschrittsbalken ──────────────────────────────────── */
.imwo-progress-track {
  height: 3px;
  border-radius: 3px;
  background: rgba(20,20,15,0.08);
  overflow: hidden;
  margin-bottom: 22px;
}
.imwo-progress-fill {
  height: 100%;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--imwo-gold), var(--imwo-gold-bright));
  transition: width 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ── Slides ──────────────────────────────────────────────── */
/* Alle Schritte liegen in derselben Rasterzelle übereinander, damit der
   Inhaltsbereich immer die Höhe des größten Schritts hat → gleiche Höhe pro Schritt.
   Kein interner Scrollbalken: die Karte wächst einfach auf die nötige Höhe. */
.imwo-form-content {
  display: grid;
  overflow: hidden;
}

.imwo-form-content > .imwo-slide,
.imwo-form-content > .imwo-success { grid-area: 1 / 1; align-self: start; }

.imwo-slide {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.imwo-slide.active {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

@keyframes imwo-fade {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.imwo-step-header { margin-bottom: 16px; }
.imwo-eyebrow {
  display: block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--imwo-gold);
  margin-bottom: 5px;
}
.imwo-heading {
  font-family: inherit;
  font-weight: 700;
  font-size: 19px;
  line-height: 1.3;
  letter-spacing: -0.005em;
  color: var(--imwo-text);
  margin: 0;
}

/* ── Objektart-Karten ────────────────────────────────────── */
/* Standard: drei quadratische Kacheln nebeneinander. Auf schmalen Screens
   (Smartphone, siehe Media-Query unten) wird daraus wieder eine Liste mit
   horizontalen Karten (Icon links, Text rechts). */
.imwo-prop-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.imwo-prop-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 20px;
  aspect-ratio: 1 / 1;
  padding: 28px 16px;
  border-radius: 18px;
  border: 1px solid var(--imwo-line);
  background: var(--imwo-field);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, transform 0.15s;
}
.imwo-prop-card:hover { border-color: var(--imwo-line-gold); transform: translateY(-2px); }
.imwo-prop-card.selected {
  border-color: var(--imwo-gold);
  background: var(--imwo-gold-pale);
  box-shadow: inset 0 0 0 1px var(--imwo-gold);
}
.imwo-pc-icon {
  flex: 0 0 auto;
  width: 94px;
  height: 94px;
  border-radius: 20px;
  background: var(--imwo-gold-pale);
  color: var(--imwo-gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s;
}
.imwo-pc-icon svg { width: 52px; height: 52px; display: block; }
.imwo-prop-card.selected .imwo-pc-icon {
  background: var(--imwo-gold);
  color: #FFFFFF;
}
.imwo-pc-text { display: flex; flex-direction: column; align-items: center; gap: 2px; min-width: 0; }
.imwo-pc-label { font-size: 20px; font-weight: 600; color: var(--imwo-text); line-height: 1.2; }
/* Untertitel und Pfeil nur in der Mobil-Liste sichtbar, im Quadrat ausgeblendet */
.imwo-pc-sub   { display: none; font-size: 12px; color: var(--imwo-text-dim); line-height: 1.35; }
.imwo-pc-arrow {
  display: none;
  flex: 0 0 auto;
  font-size: 18px;
  color: var(--imwo-gold);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 0.2s, transform 0.2s;
}
.imwo-prop-card:hover .imwo-pc-arrow { opacity: 1; transform: translateX(0); }

/* Hinweiszeile unter den Objektart-Karten */
.imwo-teaser-note {
  margin: 22px 0 2px;
  text-align: center;
  font-size: 14px;
  color: var(--imwo-text-dim);
}

/* ── Felder-Grid ─────────────────────────────────────────── */
.imwo-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.imwo-fgroup { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.imwo-fgroup.col2 { grid-column: 1 / -1; }

.imwo-fgroup label {
  font-size: 12.5px;
  font-weight: 400;
  color: var(--imwo-text-mid);
  letter-spacing: 0.01em;
}
.imwo-req { color: var(--imwo-gold); }

.imwo-wrap input[type="text"],
.imwo-wrap input[type="email"],
.imwo-wrap input[type="tel"],
.imwo-wrap input[type="number"],
.imwo-wrap select,
.imwo-wrap textarea {
  width: 100%;
  font-family: inherit;
  font-size: 14.5px;
  color: var(--imwo-text);
  background: var(--imwo-field);
  border: 1px solid var(--imwo-line);
  border-radius: 9px;
  padding: 11px 13px;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
  -webkit-appearance: none;
  appearance: none;
}
.imwo-wrap input::placeholder,
.imwo-wrap textarea::placeholder { color: var(--imwo-text-dim); }

/* Keine Zahl-Pfeile (Spinner) – stattdessen steht rechts die Einheit */
.imwo-wrap input[type="number"] { -moz-appearance: textfield; }
.imwo-wrap input[type="number"]::-webkit-outer-spin-button,
.imwo-wrap input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.imwo-wrap input:focus,
.imwo-wrap select:focus,
.imwo-wrap textarea:focus {
  outline: none;
  border-color: var(--imwo-gold);
  background: var(--imwo-field-focus);
  box-shadow: 0 0 0 3px var(--imwo-gold-pale);
}
.imwo-wrap input.imwo-err-input,
.imwo-wrap select.imwo-err-input {
  border-color: var(--imwo-error);
  box-shadow: 0 0 0 3px rgba(229,156,143,0.14);
}

/* Select-Pfeil (Gold) */
.imwo-wrap select {
  padding-right: 36px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%23BCA257' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round' d='M1 1.5l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 13px center;
  cursor: pointer;
}
.imwo-wrap select option { background: #FFFFFF; color: var(--imwo-text); }

/* Input mit Einheit (m² / €) */
.imwo-input-unit { position: relative; }
.imwo-input-unit input { padding-right: 42px; }
.imwo-unit {
  position: absolute;
  right: 13px; top: 50%;
  transform: translateY(-50%);
  font-size: 13px;
  color: var(--imwo-text-dim);
  pointer-events: none;
}

.imwo-err {
  display: none;
  font-size: 12px;
  color: var(--imwo-error);
  margin: 2px 0 0;
}

/* ── Freitext / Nachricht ────────────────────────────────── */
.imwo-wrap textarea {
  min-height: 104px;
  line-height: 1.5;
  resize: vertical;
}
.imwo-optional {
  font-size: 11.5px;
  font-weight: 400;
  color: var(--imwo-text-dim);
}
.imwo-charcount {
  margin: 5px 0 0;
  font-size: 11.5px;
  color: var(--imwo-text-dim);
  text-align: right;
}

/* ── Zustands-Karten ─────────────────────────────────────── */
.imwo-sect-label {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--imwo-text-mid);
  letter-spacing: 0.04em;
  margin: 18px 0 10px;
}
.imwo-cond-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
}
.imwo-cond-card {
  padding: 12px 13px;
  border-radius: 9px;
  border: 1px solid var(--imwo-line);
  background: var(--imwo-field);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}
.imwo-cond-card:hover { border-color: var(--imwo-line-gold); }
.imwo-cond-card.selected {
  border-color: var(--imwo-gold);
  background: var(--imwo-gold-pale);
  box-shadow: inset 0 0 0 1px var(--imwo-gold);
}
.imwo-cond-label { font-size: 13.5px; font-weight: 500; color: var(--imwo-text); }

/* ── Anrede-Pills ────────────────────────────────────────── */
.imwo-anrede-row { display: flex; gap: 9px; }
.imwo-anrede-opt {
  flex: 1;
  text-align: center;
  padding: 10px 8px;
  border-radius: 9px;
  border: 1px solid var(--imwo-line);
  background: var(--imwo-field);
  font-size: 14px;
  color: var(--imwo-text-mid);
  cursor: pointer;
  transition: all 0.2s;
}
.imwo-anrede-opt:hover { border-color: var(--imwo-line-gold); }
.imwo-anrede-opt.selected {
  border-color: var(--imwo-gold);
  background: var(--imwo-gold-pale);
  color: var(--imwo-text);
  box-shadow: inset 0 0 0 1px var(--imwo-gold);
}

/* ── Datenschutz-Checkbox ────────────────────────────────── */
.imwo-privacy-block {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  margin-top: 18px;
  padding: 13px 14px;
  border-radius: 10px;
  border: 1px solid var(--imwo-line);
  background: var(--imwo-field);
  cursor: pointer;
  transition: border-color 0.2s;
}
.imwo-privacy-block:hover { border-color: var(--imwo-line-gold); }
.imwo-priv-box {
  flex: 0 0 auto;
  width: 20px; height: 20px;
  border-radius: 6px;
  border: 1.5px solid var(--imwo-line-gold);
  display: flex; align-items: center; justify-content: center;
  margin-top: 1px;
  transition: all 0.2s;
}
.imwo-priv-box svg { width: 11px; height: 9px; opacity: 0; transition: opacity 0.15s; }
.imwo-priv-box svg polyline { fill: none; stroke: var(--imwo-ink); stroke-width: 1.6; }
.imwo-privacy-block.checked .imwo-priv-box {
  background: var(--imwo-gold);
  border-color: var(--imwo-gold);
}
.imwo-privacy-block.checked .imwo-priv-box svg { opacity: 1; }
.imwo-priv-text { font-size: 12px; line-height: 1.5; color: var(--imwo-text-mid); margin: 0; }
.imwo-priv-text a { color: var(--imwo-gold); text-decoration: underline; text-underline-offset: 2px; }

/* ── Navigation ──────────────────────────────────────────── */
.imwo-form-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid var(--imwo-line);
}
.imwo-nav-right { display: flex; align-items: center; gap: 12px; }
.imwo-step-counter { font-size: 12px; color: var(--imwo-text-dim); white-space: nowrap; }

.imwo-btn-back {
  font-family: inherit;
  font-size: 14px;
  color: var(--imwo-text-mid);
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 8px 4px;
  transition: color 0.2s;
}
.imwo-btn-back:hover:not(:disabled) { color: var(--imwo-text); }
.imwo-btn-back:disabled { opacity: 0; pointer-events: none; }

.imwo-btn-next,
.imwo-btn-submit {
  font-family: inherit;
  font-size: 14.5px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--imwo-ink);
  background: linear-gradient(135deg, var(--imwo-gold-bright), var(--imwo-gold));
  border: none;
  border-radius: 9px;
  padding: 12px 24px;
  cursor: pointer;
  transition: filter 0.2s, transform 0.15s, box-shadow 0.2s;
  box-shadow: 0 8px 22px -8px rgba(188,162,87,0.6);
}
.imwo-btn-next:hover,
.imwo-btn-submit:hover { filter: brightness(1.06); transform: translateY(-1px); }
.imwo-btn-next:active,
.imwo-btn-submit:active { transform: translateY(0); }
.imwo-btn-submit:disabled { opacity: 0.6; pointer-events: none; }

/* ── Footer ──────────────────────────────────────────────── */
.imwo-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.imwo-footer-note { font-size: 11.5px; color: var(--imwo-text-dim); }
.imwo-footer-links { display: flex; gap: 14px; }
.imwo-footer-links a {
  font-size: 11.5px;
  color: var(--imwo-text-dim);
  text-decoration: none;
  transition: color 0.2s;
}
.imwo-footer-links a:hover { color: var(--imwo-gold); }

/* ── Erfolg ──────────────────────────────────────────────── */
.imwo-success {
  display: none;
  text-align: center;
  padding: 22px 10px 14px;
}
.imwo-success.show { display: block; animation: imwo-fade 0.5s ease both; }
.imwo-success-ring {
  width: 64px; height: 64px;
  margin: 0 auto 18px;
  border-radius: 50%;
  border: 2px solid var(--imwo-gold);
  display: flex; align-items: center; justify-content: center;
  background: var(--imwo-gold-pale);
}
.imwo-success-ring svg { width: 30px; height: 30px; }
.imwo-success-ring svg polyline { fill: none; stroke: var(--imwo-gold); stroke-width: 2.4; }
.imwo-success-title {
  font-family: inherit;
  font-weight: 800;
  font-size: 23px;
  letter-spacing: -0.01em;
  color: var(--imwo-text);
  margin: 0 0 8px;
}
.imwo-success-body { font-size: 14px; color: var(--imwo-text-mid); margin: 0 auto; max-width: 340px; }
.imwo-success-body strong { color: var(--imwo-text); }

/* ── Honeypot (versteckt) ────────────────────────────────── */
.imwo-hp {
  position: absolute !important;
  left: -9999px !important;
  width: 1px; height: 1px;
  overflow: hidden;
}

/* ── Dialog / Modal ──────────────────────────────────────── */
/* Sperrt das Scrollen der Seite, solange der Dialog offen ist. */
body.imwo-modal-active { overflow: hidden; }

.imwo-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 99999;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.imwo-modal.open { display: flex; }

.imwo-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20,18,10,0.55);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  animation: imwo-modal-bg 0.25s ease both;
}
@keyframes imwo-modal-bg { from { opacity: 0; } to { opacity: 1; } }

.imwo-modal-dialog {
  position: relative;
  width: 100%;
  max-width: 480px;
  max-height: 92vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 30px 30px 22px;
  border-radius: 16px;
  border: 1px solid var(--imwo-line);
  background: #FFFFFF;
  box-shadow: 0 30px 80px -20px rgba(20,16,4,0.55);
  animation: imwo-modal-in 0.32s cubic-bezier(0.16, 1, 0.3, 1) both;
}
@keyframes imwo-modal-in {
  from { opacity: 0; transform: translateY(24px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
/* Gold-Akzentlinie oben (wie die Teaser-Karte) */
.imwo-modal-dialog::before {
  content: '';
  display: block;
  height: 3px;
  margin: -30px -30px 22px;
  border-radius: 16px 16px 0 0;
  background: linear-gradient(90deg, transparent, var(--imwo-gold), var(--imwo-gold-bright), var(--imwo-gold), transparent);
}

.imwo-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid var(--imwo-line);
  background: #FFFFFF;
  color: var(--imwo-text-mid);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2;
  transition: color 0.2s, border-color 0.2s, transform 0.15s;
}
.imwo-modal-close svg { width: 16px; height: 16px; }
.imwo-modal-close:hover { color: var(--imwo-text); border-color: var(--imwo-line-gold); transform: rotate(90deg); }

.imwo-modal-head { margin-bottom: 18px; padding-right: 40px; }
.imwo-modal-chip {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--imwo-gold);
  background: var(--imwo-gold-pale);
  border-radius: 999px;
  padding: 4px 12px;
  margin-bottom: 10px;
}
.imwo-modal-title {
  font-family: inherit;
  font-weight: 800;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--imwo-text);
  margin: 0;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 540px) {
  .imwo-wrap { padding: 24px 20px 18px; border-radius: 14px; }
  .imwo-card-title { font-size: 24px; }
  .imwo-step-top-label { display: none; }
  .imwo-steps-top { justify-content: flex-start; gap: 10px; }

  /* Objektart-Karten: zurück zur Listendarstellung (Icon links, Text rechts) */
  .imwo-prop-cards { display: flex; flex-direction: column; }
  .imwo-prop-card {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    text-align: left;
    gap: 14px;
    aspect-ratio: auto;
    padding: 14px 16px;
  }
  .imwo-prop-card:hover { transform: translateX(2px); }
  .imwo-pc-icon  { width: 42px; height: 42px; border-radius: 10px; }
  .imwo-pc-icon svg { width: 23px; height: 23px; }
  .imwo-pc-text  { align-items: flex-start; flex: 1 1 auto; }
  .imwo-pc-label { font-size: 15px; }
  .imwo-pc-sub   { display: block; }
  .imwo-pc-arrow { display: block; }

  .imwo-modal { padding: 0; align-items: flex-end; }
  .imwo-modal-dialog {
    max-width: none;
    max-height: 94vh;
    padding: 26px 20px 18px;
    border-radius: 18px 18px 0 0;
  }
  .imwo-modal-dialog::before { margin: -26px -20px 20px; border-radius: 18px 18px 0 0; }
  .imwo-modal-title { font-size: 20px; }
}

@media (max-width: 380px) {
  .imwo-grid { grid-template-columns: 1fr; }
  .imwo-cond-grid { grid-template-columns: 1fr; }
}
