/* Umzugsrechner Pro - Frontend CSS */
:root {
  --mi-blau: #1a4d8f;
  --mi-blau-dark: #123668;
  --mi-blau-light: #e8f0fb;
  --mi-orange: #ff5a00;
  --mi-orange-light: #fff4ec;
  --mi-gruen: #16a34a;
  --mi-grau: #f8fafc;
  --mi-border: #e2e8f0;
  --mi-text: #1e293b;
  --mi-muted: #64748b;
  --mi-r: 14px;
  --mi-rs: 8px;
}

.mi-hp-field {
  position: absolute !important;
  left: -10000px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

/* Trust elements */
.mi-trust-bar { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-bottom: 16px; }
.mi-trust-pill { display: inline-flex; align-items: center; gap: 7px; background: linear-gradient(135deg, #fff, #fff7ed); border: 1.5px solid rgba(255,106,26,.28); border-radius: 999px; padding: 7px 15px; font-size: 13px; font-weight: 900; color: var(--mi-blau); box-shadow: 0 10px 24px rgba(26,77,143,.1); }
.mi-trust-pill > span { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 999px; background: var(--mi-orange); color: #fff; font-size: 12px; line-height: 1; }

/* Main wrapper */
#mi-pro { max-width: 920px; margin: 0 auto; background: #fff; border-radius: 20px; box-shadow: 0 12px 48px rgba(26,77,143,.16); overflow: hidden; font-family: "DM Sans Local", -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; }

/* HEADER */
.mi-header { background: linear-gradient(135deg, var(--mi-blau) 0%, var(--mi-blau-dark) 100%); padding: 24px 36px 20px; position: relative; overflow: hidden; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 14px; }
.mi-header::before { content: ''; position: absolute; right: -40px; top: -40px; width: 200px; height: 200px; background: rgba(255,255,255,.04); border-radius: 50%; pointer-events: none; }
.mi-h1 { margin: 0; font-size: 20px; font-weight: 800; color: #fff; line-height: 1.2; }
.mi-sub { margin: 4px 0 0; font-size: 13px; color: rgba(255,255,255,.72); }
.mi-tool-proof { display: flex; flex-wrap: wrap; gap: 6px 8px; margin-top: 8px; }
.mi-tool-proof > span { display: inline-flex; align-items: center; gap: 5px; padding: 4px 8px; border-radius: 999px; background: rgba(255,255,255,.12); color: rgba(255,255,255,.9); font-size: 11px; font-weight: 800; line-height: 1.1; }
.mi-tool-proof > span > span { color: var(--mi-orange); font-size: 12px; line-height: 1; }
.mi-h1,
.mi-section-title,
.mi-sub-title,
.mi-quote-header h3,
.mi-contact-card h4,
.mi-size-btns button,
.mi-step,
.mi-cost-box strong {
  font-family: "Montserrat Local", -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  letter-spacing: -.02em;
}
.mi-live-price { text-align: right; position: relative; z-index: 1; }
.lp-label { font-size: 10px; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .8px; font-weight: 600; }
.lp-amount { font-size: 30px; font-weight: 800; color: var(--mi-orange); line-height: 1.1; transition: transform .3s cubic-bezier(.34,1.56,.64,1); }
.lp-amount.bump { transform: scale(1.1); }
.lp-sub { font-size: 10px; color: rgba(255,255,255,.45); }

/* STEPS NAV */
.mi-steps-nav { display: flex; background: var(--mi-grau); border-bottom: 1.5px solid var(--mi-border); }
.mi-step { flex: 1; padding: 13px 6px; text-align: center; font-size: 12px; font-weight: 600; color: var(--mi-muted); display: flex; align-items: center; justify-content: center; gap: 6px; position: relative; transition: color .2s; }
.mi-step::after { content: ''; position: absolute; bottom: -1.5px; left: 0; right: 0; height: 3px; background: transparent; transition: background .3s; }
.mi-step.active { color: var(--mi-blau); }
.mi-step.active::after { background: var(--mi-orange); }
.mi-step.done { color: var(--mi-gruen); }
.mi-step.done::after { background: var(--mi-gruen); }
.mi-step-num { width: 26px; height: 26px; border-radius: 50%; background: #e2e8f0; color: var(--mi-muted); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; transition: all .3s; flex-shrink: 0; }
.mi-step.active .mi-step-num { background: var(--mi-orange); color: #fff; box-shadow: 0 3px 10px rgba(244,121,32,.35); }
.mi-step.done .mi-step-num { background: var(--mi-gruen); color: #fff; }
.mi-step-lbl { display: inline; }

/* PROGRESS */
.mi-progress-wrap { padding: 0 36px; background: var(--mi-grau); border-bottom: 1px solid var(--mi-border); }
.mi-progress-info { display: flex; justify-content: space-between; padding: 7px 0 8px; font-size: 11px; color: var(--mi-muted); font-weight: 500; }
.mi-progress-bar { height: 4px; background: #e2e8f0; border-radius: 99px; overflow: hidden; }
.mi-progress-fill { height: 100%; background: linear-gradient(90deg, var(--mi-blau), var(--mi-orange)); border-radius: 99px; transition: width .5s cubic-bezier(.34,1.2,.64,1); }
.mi-rechner-note { padding: 9px 36px 0; background: #fff; color: var(--mi-muted); font-size: 11px; line-height: 1.45; text-align: center; }
.mi-noscript { max-width: 920px; margin: 0 auto 12px; padding: 14px 18px; border: 1.5px solid #fed7aa; border-radius: var(--mi-rs); background: #fff7ed; color: #9a3412; font-weight: 700; }

/* PANES */
.mi-pane { display: none; padding: 28px 36px; animation: miFadeIn .3s ease; }
.mi-pane.active { display: block; }
@keyframes miFadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* TYPOGRAPHY */
.mi-section-title { font-size: 18px; font-weight: 700; color: var(--mi-blau); margin: 0 0 18px; display: flex; align-items: center; gap: 8px; }
.mi-sub-title { font-size: 14px; font-weight: 700; color: var(--mi-text); margin: 22px 0 12px; display: flex; align-items: center; gap: 6px; }
.mi-tool-intro { margin: -6px 0 16px; color: var(--mi-muted); font-size: 13px; line-height: 1.5; }

/* LEAD BOX */
.mi-lead-box { background: linear-gradient(135deg, var(--mi-blau-light), #e0ecff); border: 1.5px solid rgba(26,77,143,.15); border-radius: var(--mi-r); padding: 14px 18px; margin-bottom: 22px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.mi-lead-icon { font-size: 26px; flex-shrink: 0; }
.mi-lead-text { flex: 1; font-size: 13px; font-weight: 600; color: var(--mi-blau); min-width: 160px; }
.mi-lead-text small { display: block; font-size: 11px; font-weight: 400; color: var(--mi-muted); margin-top: 2px; }
.mi-lead-input { padding: 9px 12px; border: 2px solid var(--mi-border); border-radius: var(--mi-rs); font-size: 13px; font-family: inherit; width: 200px; }
.mi-lead-input:focus { border-color: var(--mi-blau); outline: none; }
.mi-lead-box--info { background: linear-gradient(135deg, #fff7ed, #eef4ff); }
.mi-inline-alert { margin: 12px 0 0; padding: 12px 14px; border-radius: var(--mi-rs); background: #fff7ed; border: 1px solid rgba(244,121,32,.28); color: #9a3412; font-size: 13px; font-weight: 700; }

/* FORM */
.mi-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.mi-field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 13px; }
.mi-field label { font-size: 12px; font-weight: 600; color: var(--mi-text); }
.mi-field label .req { color: var(--mi-orange); }
#mi-pro input[type=text], #mi-pro input[type=number], #mi-pro input[type=email],
#mi-pro input[type=tel], #mi-pro input[type=date], #mi-pro select, #mi-pro textarea {
  width: 100%; padding: 11px 13px; border: 2px solid var(--mi-border); border-radius: var(--mi-rs);
  min-height: 48px; line-height: 1.25;
  font-size: 14px; font-family: inherit; color: var(--mi-text); background: #fff;
  transition: border-color .2s, box-shadow .2s; outline: none; box-sizing: border-box;
}
#mi-pro input:focus, #mi-pro select:focus, #mi-pro textarea:focus { border-color: var(--mi-blau); box-shadow: 0 0 0 3px rgba(26,77,143,.09); }
#mi-pro select {
  height: auto;
  min-height: 50px;
  padding: 0 40px 0 13px;
  line-height: normal;
  appearance: auto;
}
#mi-pro textarea { min-height: 96px; line-height: 1.5; }
#mi-pro input.mi-invalid, #mi-pro select.mi-invalid, #mi-pro textarea.mi-invalid { border-color: #ef4444; }
.mi-hint { font-size: 11px; color: var(--mi-muted); }
.mi-err { font-size: 11px; color: #ef4444; display: none; }
.mi-err.show { display: block; }

/* PLZ INFO */
.mi-plz-info { background: var(--mi-grau); border: 1.5px dashed var(--mi-border); border-radius: var(--mi-rs); padding: 9px 13px; font-size: 12px; color: var(--mi-muted); text-align: center; margin-top: 6px; transition: all .3s; }
.mi-plz-info.loaded { background: #f0fdf4; border-color: #86efac; color: var(--mi-gruen); font-weight: 600; }
.mi-plz-info.warn { background: #fff7ed; border-color: #fdba74; color: #9a3412; font-weight: 700; }

/* DATE HINT */
.mi-date-hint { font-size: 12px; padding: 7px 11px; border-radius: 6px; margin-top: 5px; display: none; }
.mi-date-hint.warn { background: #fff7ed; color: #c2410c; border: 1px solid #fed7aa; display: block; }
.mi-date-hint.ok { background: #f0fdf4; color: var(--mi-gruen); border: 1px solid #86efac; display: block; }

/* SIZE BUTTONS */
.mi-size-btns { display: flex; gap: 7px; margin-bottom: 6px; }
.mi-size-btns button { flex: 1; display: grid; gap: 2px; align-content: center; padding: 9px 4px; border: 2px solid var(--mi-border); background: #fff; border-radius: var(--mi-rs); cursor: pointer; font-weight: 700; font-size: 12px; color: var(--mi-muted); transition: border-color .2s, color .2s, background .2s, box-shadow .2s, transform .2s; line-height: 1.2; font-family: inherit; }
.mi-size-btns button small { display: block; color: inherit; font-size: 10px; font-weight: 800; opacity: .74; }
.mi-size-btns button:hover { border-color: var(--mi-blau); color: var(--mi-blau); }
.mi-size-btns button.active { border-color: var(--mi-orange); background: var(--mi-orange-light); color: var(--mi-orange); box-shadow: 0 3px 12px rgba(244,121,32,.2); }
.mi-size-impact { margin: 0 0 10px; padding: 8px 11px; border-radius: 10px; background: #fff7ed; color: #9a3412; font-size: 11px; font-weight: 800; line-height: 1.35; }

/* CATEGORY TABS */
.mi-cat-tabs { display: flex; gap: 6px; margin-bottom: 16px; flex-wrap: wrap; }
.mi-cat-tab { padding: 8px 14px; border: 2px solid var(--mi-border); background: #fff; border-radius: 999px; font-size: 13px; font-weight: 600; color: var(--mi-muted); cursor: pointer; transition: all .2s; font-family: inherit; white-space: nowrap; }
.mi-cat-tab:hover { border-color: var(--mi-blau); color: var(--mi-blau); }
.mi-cat-tab.active { border-color: var(--mi-blau); background: var(--mi-blau); color: #fff; }

/* INVENTORY GRID */
.mi-inventory { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 9px; margin-bottom: 14px; }
.mi-inv-item { display: none; border: 2px solid var(--mi-border); border-radius: var(--mi-r); padding: 12px 9px 10px; text-align: center; background: #fff; transition: border-color .2s, transform .2s, box-shadow .2s; }
.mi-inv-item.show { display: block; }
.mi-inv-item:hover { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(15, 23, 42, .08); }
.mi-inv-item.has-items { border-color: var(--mi-blau); background: var(--mi-blau-light); box-shadow: 0 12px 28px rgba(14, 58, 93, .12); }
.mi-inv-emoji { width: 44px; height: 44px; border-radius: 16px; background: linear-gradient(135deg, #eef6ff, #fff7ed); display: inline-flex; align-items: center; justify-content: center; font-size: 25px; line-height: 1; margin-bottom: 8px; }
.mi-inv-name { font-size: 11px; font-weight: 700; color: var(--mi-text); display: block; margin-bottom: 2px; line-height: 1.3; }
.mi-inv-price { font-size: 12px; color: var(--mi-orange); display: block; font-weight: 900; margin-bottom: 2px; }
.mi-inv-volume { font-size: 10px; color: var(--mi-muted); display: block; margin-bottom: 8px; }

/* QTY CONTROLS */
.mi-qty { display: flex; justify-content: center; align-items: center; gap: 5px; }
.mi-qty-btn { width: 28px; height: 28px; border: none; background: var(--mi-blau); color: #fff; border-radius: 6px; font-size: 16px; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .15s, transform .1s; flex-shrink: 0; font-family: inherit; }
.mi-qty-btn:hover { background: var(--mi-blau-dark); }
.mi-qty-btn:active { transform: scale(.88); }
.mi-qty-val { width: 38px; min-height: 30px !important; text-align: center; border: 1px solid rgba(26,77,143,.18) !important; border-radius: 7px !important; padding: 0 3px !important; font-weight: 800; font-size: 15px; background: #fff !important; box-shadow: none !important; pointer-events: auto; }
.mi-qty-val:focus { border-color: var(--mi-orange) !important; box-shadow: 0 0 0 3px rgba(255,106,26,.12) !important; }

/* WARNINGS */
.mi-warn { border-radius: var(--mi-rs); padding: 10px 14px; font-size: 12px; margin-bottom: 10px; }
.mi-warn { background: #fff7ed; border: 1.5px solid #fed7aa; color: #c2410c; }
.mi-warn-purple { background: #faf5ff; border-color: #c084fc; color: #7e22ce; }

/* CUSTOM BLOCK */
.mi-custom-block { border: 2px dashed var(--mi-border); border-radius: var(--mi-r); padding: 16px; margin-bottom: 14px; }
.mi-custom-block h5 { font-size: 12px; font-weight: 700; color: var(--mi-muted); margin: 0 0 10px; }
.mi-dim-labels { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 7px; margin-bottom: 4px; }
.mi-dim-labels span { font-size: 10px; color: var(--mi-muted); text-align: center; font-weight: 600; }
.mi-dim-row { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 7px; margin-bottom: 10px; }
.mi-dim-row input { padding: 8px !important; text-align: center; font-size: 13px !important; }
.mi-dim-calc { font-size: 12px; color: var(--mi-blau); font-weight: 600; margin-bottom: 8px; min-height: 18px; }
.mi-custom-list { margin-top: 8px; }
.mi-custom-list-item { display: flex; justify-content: space-between; align-items: center; background: var(--mi-blau-light); border-radius: 6px; padding: 6px 10px; margin-bottom: 5px; font-size: 12px; }
.mi-del-custom { background: none; border: none; color: #ef4444; cursor: pointer; font-size: 16px; padding: 0 3px; }
.mi-btn-secondary { background: var(--mi-blau); color: #fff; border: none; padding: 9px 16px; border-radius: var(--mi-rs); font-size: 12px; font-weight: 700; cursor: pointer; width: 100%; font-family: inherit; transition: background .2s; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; }
.mi-btn-secondary:hover { background: var(--mi-blau-dark); }

/* COST BOX */
.mi-cost-box { background: var(--mi-grau); border: 1.5px solid var(--mi-border); border-radius: var(--mi-r); padding: 13px 18px; display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.mi-cost-box span { font-size: 13px; font-weight: 600; color: var(--mi-muted); }
.mi-cost-box strong { font-size: 20px; font-weight: 800; color: var(--mi-blau); }
.mi-volume-hint { margin: 6px 0 12px; font-size: 12px; font-weight: 700; color: var(--mi-blau); text-align: right; }
.mi-price-breakdown { display: flex; flex-wrap: wrap; gap: 6px; margin: 9px 0 12px; }
.mi-price-breakdown span { display: inline-flex; align-items: center; padding: 6px 9px; border-radius: 999px; background: #eef6ff; color: var(--mi-blau); font-size: 11px; font-weight: 800; line-height: 1.2; }

/* LOCATION BLOCK */
.mi-location-block { background: var(--mi-grau); border: 1.5px solid var(--mi-border); border-radius: var(--mi-r); padding: 18px; margin-bottom: 14px; }
.mi-location-block .mi-sub-title { margin-top: 0; }

/* SERVICES */
.mi-services { display: grid; gap: 9px; }
.mi-svc-label { display: flex; align-items: flex-start; gap: 12px; padding: 13px 16px; border: 2px solid var(--mi-border); border-radius: var(--mi-r); cursor: pointer; transition: all .2s; background: #fff; }
.mi-svc-label:hover { border-color: var(--mi-blau); background: var(--mi-blau-light); }
.mi-svc-label:has(input:checked) { border-color: var(--mi-orange); background: var(--mi-orange-light); }
.mi-svc-label input[type=checkbox] { width: 18px; height: 18px; accent-color: var(--mi-orange); flex-shrink: 0; margin-top: 2px; cursor: pointer; border: none !important; padding: 0 !important; box-shadow: none !important; }
.mi-svc-text strong { font-size: 13px; font-weight: 700; display: block; }
.mi-svc-text span { font-size: 12px; color: var(--mi-muted); display: block; margin-top: 2px; }
.mi-badge { background: var(--mi-orange); color: #fff; font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 999px; flex-shrink: 0; align-self: center; white-space: nowrap; margin-left: auto; }
.mi-service-detail { display: none; margin: -3px 0 7px 30px; padding: 12px 14px; border-radius: 13px; background: #fff7ed; border: 1px solid rgba(255,106,26,.22); }
.mi-service-detail.show { display: block; }
.mi-service-detail label { display: block; margin-bottom: 6px; color: var(--mi-text); font-size: 12px; font-weight: 800; }
.mi-service-detail__row { display: grid; grid-template-columns: minmax(90px, 150px) auto; align-items: center; gap: 8px; }
.mi-service-detail__row input { min-height: 40px !important; padding: 8px 10px !important; }
.mi-service-detail__row span { color: var(--mi-orange); font-weight: 900; font-size: 12px; }
.mi-service-detail p { margin: 6px 0 0; color: #9a3412; font-size: 11px; line-height: 1.4; font-weight: 700; }

/* DSGVO */
.mi-dsgvo { display: flex; align-items: flex-start; gap: 11px; padding: 14px; background: #fff7ed; border: 1.5px solid rgba(255,106,26,.26); border-radius: var(--mi-rs); font-size: 13px; color: var(--mi-text); line-height: 1.5; font-weight: 600; }
.mi-dsgvo input { width: 21px; height: 21px; flex-shrink: 0; margin-top: 1px; accent-color: var(--mi-orange); }
.mi-dsgvo:focus-within { box-shadow: 0 0 0 3px rgba(255,106,26,.13); }
.mi-dsgvo a { color: var(--mi-blau); }

/* STEP 4 QUOTE */
.mi-quote-header { display: flex; align-items: center; gap: 14px; background: linear-gradient(135deg, var(--mi-blau-light), #e0ecff); border: 1.5px solid rgba(26,77,143,.15); border-radius: var(--mi-r); padding: 16px 20px; margin-bottom: 16px; }
.mi-qh-check { width: 44px; height: 44px; background: var(--mi-gruen); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; color: #fff; flex-shrink: 0; box-shadow: 0 4px 12px rgba(22,163,74,.3); }
.mi-quote-header h3 { font-size: 16px; margin: 0; font-weight: 700; color: var(--mi-blau); }
.mi-quote-header p { font-size: 12px; color: var(--mi-muted); margin: 3px 0 0; }
.mi-quote-table { width: 100%; border-collapse: collapse; margin-bottom: 14px; font-size: 13px; }
.mi-quote-table tr { border-bottom: 1px solid var(--mi-border); }
.mi-quote-table td { padding: 8px 11px; }
.mi-quote-table td:last-child { text-align: right; font-weight: 600; }
.mi-qt-sh td { background: var(--mi-grau); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--mi-muted); padding: 6px 11px; }
.mi-qt-total td { font-size: 15px; font-weight: 800; color: var(--mi-blau); background: var(--mi-blau-light); border-bottom: none; padding: 13px 11px; }
.mi-qt-total td:last-child { font-size: 19px; color: var(--mi-orange); }
.mi-market-compare { background: #f0fdf4; border: 1.5px solid #86efac; border-radius: var(--mi-rs); padding: 10px 14px; font-size: 12px; color: var(--mi-gruen); font-weight: 600; display: flex; align-items: center; gap: 7px; margin-bottom: 18px; }
.mi-contact-card { background: var(--mi-grau); border: 1.5px solid var(--mi-border); border-radius: var(--mi-r); padding: 22px; }
.mi-contact-card h4 { font-size: 16px; font-weight: 700; color: var(--mi-blau); margin: 0 0 14px; }
.mi-contact-promise { margin: -5px 0 14px; color: var(--mi-muted); font-size: 12px; line-height: 1.5; font-weight: 700; }
.mi-disclaimer { font-size: 11px; color: var(--mi-muted); text-align: center; margin-top: 9px; line-height: 1.5; }

/* BUTTONS */
.mi-btn-primary { background: linear-gradient(135deg, var(--mi-orange), #e06010); color: #fff; border: none; padding: 14px 28px; border-radius: var(--mi-rs); font-size: 14px; font-weight: 700; cursor: pointer; width: 100%; margin-top: 10px; transition: all .2s; box-shadow: 0 4px 16px rgba(244,121,32,.3); display: flex; align-items: center; justify-content: center; gap: 7px; font-family: inherit; }
.mi-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(244,121,32,.4); }
.mi-btn-primary:active { transform: none; }
.mi-btn-primary.loading { opacity: .78; pointer-events: none; }
.mi-btn-primary.loading::after { content: ""; width: 15px; height: 15px; border: 2px solid rgba(255,255,255,.55); border-top-color: #fff; border-radius: 50%; animation: miSpin .7s linear infinite; }
@keyframes miSpin { to { transform: rotate(360deg); } }
.mi-btn-back { background: var(--mi-grau); color: var(--mi-text); border: 2px solid var(--mi-border); padding: 12px 20px; border-radius: var(--mi-rs); font-size: 13px; font-weight: 600; cursor: pointer; flex: 0 0 auto; transition: all .2s; font-family: inherit; }
.mi-btn-back:hover { border-color: var(--mi-blau); color: var(--mi-blau); }
.mi-nav { display: flex; gap: 10px; align-items: center; margin-top: 14px; }
.mi-nav .mi-btn-primary { flex: 1; margin-top: 0; }
.mi-wa-btn { display: flex; align-items: center; justify-content: center; gap: 9px; background: #25d366; color: #fff; border: none; padding: 12px 28px; border-radius: var(--mi-rs); font-size: 14px; font-weight: 700; cursor: pointer; width: 100%; margin-top: 9px; text-decoration: none; transition: all .2s; box-shadow: 0 4px 16px rgba(37,211,102,.3); font-family: inherit; }
.mi-wa-btn:hover { background: #1da851; transform: translateY(-1px); }
.mi-wa-hint { margin: 8px 0 0; font-size: 11px; line-height: 1.45; color: var(--mi-muted); text-align: center; }
.mi-phone-btn { display: inline-flex; justify-content: center; width: 100%; margin-top: 10px; color: var(--mi-blau); font-size: 12px; font-weight: 900; text-decoration: none; }
.mi-phone-btn:hover { color: var(--mi-orange); }

/* FOOTER TRUST */
.mi-footer-trust { display: flex; justify-content: center; gap: 18px; padding: 14px 36px; border-top: 1px solid var(--mi-border); background: var(--mi-grau); flex-wrap: wrap; font-size: 11px; font-weight: 600; color: var(--mi-muted); }

/* Compact home mode */
#mi-pro.mi-pro--home { max-width: none; width: 100%; border-radius: 24px; box-shadow: 0 28px 70px rgba(7, 22, 44, .28); display: flex; flex-direction: column; min-height: 0; overflow: visible; }
.mi-pro--home .mi-header { display: grid; grid-template-columns: minmax(0, 1fr) minmax(112px, auto); align-items: start; padding: 12px 18px 11px; gap: 8px 12px; overflow: visible; }
.mi-pro--home .mi-header-text { min-width: 0; }
.mi-pro--home .mi-h1 { font-size: 17px; line-height: 1.16; overflow-wrap: anywhere; }
.mi-pro--home .mi-sub { font-size: 11px; line-height: 1.32; max-width: none; }
.mi-pro--home .mi-tool-proof { margin-top: 7px; gap: 5px 7px; }
.mi-pro--home .mi-tool-proof > span { padding: 4px 7px; font-size: 10.5px; line-height: 1.15; }
.mi-pro--home .mi-live-price { min-width: 112px; align-self: start; }
.mi-pro--home .lp-label { font-size: 9px; line-height: 1.1; }
.mi-pro--home .lp-amount { font-size: 21px; line-height: 1; }
.mi-pro--home .lp-sub { font-size: 9.5px; line-height: 1.2; }
.mi-pro--home .mi-steps-nav { min-height: 38px; }
.mi-pro--home .mi-step { padding: 7px 4px; font-size: 10.5px; }
.mi-pro--home .mi-step-num { width: 22px; height: 22px; }
.mi-pro--home .mi-progress-wrap { padding: 5px 18px 6px; }
.mi-pro--home .mi-progress-info { display: flex; padding: 0 0 5px; font-size: 10.5px; }
.mi-pro--home .mi-pane { padding: 12px 18px 14px; }
.mi-pro--home .mi-pane.active { flex: 1 1 auto; min-height: 0; overflow: visible; padding-bottom: 18px; }
.mi-pro--home .mi-pane.active::-webkit-scrollbar { width: 9px; }
.mi-pro--home .mi-pane.active::-webkit-scrollbar-track { background: rgba(226, 232, 240, .7); border-radius: 999px; }
.mi-pro--home .mi-pane.active::-webkit-scrollbar-thumb { background: rgba(26, 77, 143, .34); border-radius: 999px; }
.mi-pro--home .mi-nav { position: static; margin: 14px 0 0; padding: 0; background: transparent; border-top: 0; box-shadow: none; }
.mi-pro--home .mi-section-title { font-size: 14px; margin-bottom: 8px; }
.mi-pro--home .mi-lead-box { padding: 10px 12px; margin-bottom: 12px; }
.mi-pro--home .mi-row { gap: 10px; }
.mi-pro--home .mi-field { margin-bottom: 6px; gap: 3px; }
.mi-pro--home .mi-field label { font-size: 10.5px; }
.mi-pro--home input[type=text],
.mi-pro--home input[type=number],
.mi-pro--home input[type=email],
.mi-pro--home input[type=tel],
.mi-pro--home input[type=date],
.mi-pro--home select,
.mi-pro--home textarea { min-height: 38px !important; padding: 8px 10px !important; font-size: 12.5px !important; }
.mi-pro--home input.mi-qty-val[type=number] { width: 38px !important; min-height: 30px !important; padding: 0 2px !important; font-size: 14px !important; line-height: 30px !important; color: var(--mi-text) !important; }
.mi-pro--home .mi-plz-info { padding: 6px 10px; font-size: 10.5px; margin-top: 3px; }
.mi-pro--home .mi-hint,
.mi-pro--home .mi-err,
.mi-pro--home .mi-date-hint { font-size: 10.5px; }
.mi-pro--home .mi-sub-title { margin: 9px 0 7px; font-size: 12.5px; }
.mi-pro--home .mi-size-btns button { padding: 7px 3px; }
.mi-pro--home .mi-size-impact { margin-bottom: 8px; padding: 6px 9px; font-size: 10.5px; }
.mi-pro--home .mi-price-breakdown { gap: 5px; margin: 7px 0 10px; }
.mi-pro--home .mi-price-breakdown span { padding: 5px 7px; font-size: 10px; }
.mi-pro--home .mi-inventory { grid-template-columns: repeat(auto-fill, minmax(112px, 1fr)); gap: 8px; }
.mi-pro--home .mi-custom-block,
.mi-pro--home .mi-location-block,
.mi-pro--home .mi-contact-card { padding: 14px; }
.mi-pro--home .mi-svc-label { padding: 11px 13px; }
.mi-pro--home .mi-btn-primary { padding: 10px 18px; margin-top: 6px; }
.mi-pro--home .mi-footer-trust { display: none; }

/* SUCCESS */
.mi-success { text-align: center; padding: 52px 36px; }
.mi-success-icon { width: 72px; height: 72px; background: linear-gradient(135deg,#22c55e,#16a34a); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; color: #fff; margin: 0 auto 22px; box-shadow: 0 8px 24px rgba(22,163,74,.3); animation: miPopIn .5s cubic-bezier(.34,1.56,.64,1); }
@keyframes miPopIn { from { transform: scale(0); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.mi-success h3 { font-size: 22px; font-weight: 800; color: var(--mi-blau); margin-bottom: 10px; }
.mi-success p { font-size: 15px; color: var(--mi-muted); max-width: 380px; margin: 0 auto 7px; }
.mi-success .mi-success-link { max-width: 260px; margin: 0 auto; }
.mi-success-steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; max-width: 520px; margin: 20px auto 0; }
.mi-success-steps span { display: grid; gap: 6px; padding: 12px 10px; border-radius: 14px; background: #f0fdf4; color: var(--mi-gruen); font-size: 12px; font-weight: 900; }
.mi-success-steps strong { width: 24px; height: 24px; margin: 0 auto; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; background: var(--mi-gruen); color: #fff; }

/* RESPONSIVE */
@media (max-width: 680px) {
  #mi-pro,
  #mi-pro.mi-pro--home {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    height: auto;
    max-height: none;
    overflow: visible;
  }
  .mi-header,
  .mi-pro--home .mi-header { padding: 14px 16px; display: grid; grid-template-columns: 1fr; }
  .mi-live-price { text-align: left; }
  .lp-amount { font-size: 24px; }
  .mi-tool-proof { gap: 5px; }
  .mi-tool-proof > span { font-size: 10px; padding: 4px 7px; }
  .mi-pane { padding: 18px 16px; }
  .mi-pro--home .mi-pane.active { overflow: visible; padding-bottom: 18px; }
  .mi-pro--home .mi-nav { position: static; margin: 14px 0 0; padding: 0; border-top: 0; background: transparent; }
  .mi-row { grid-template-columns: 1fr; }
  .mi-steps-nav { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); font-size: 10px; }
  .mi-step { min-width: 0; padding: 11px 0; }
  .mi-step-lbl { display: none; }
  .mi-size-btns { gap: 4px; }
  .mi-size-btns button { font-size: 11px; padding: 9px 3px; }
  .mi-inventory { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .mi-dim-labels, .mi-dim-row { grid-template-columns: 1fr 1fr; }
  .mi-lead-box { flex-direction: column; }
  .mi-lead-input { width: 100%; }
  .mi-progress-wrap { padding: 0 16px; }
  .mi-rechner-note { padding: 9px 16px 0; font-size: 10.5px; }
  .mi-service-detail { margin-left: 0; }
  .mi-footer-trust { gap: 10px; padding: 12px 16px; }
  .mi-trust-bar { gap: 5px; }
  .mi-trust-pill { font-size: 11px; padding: 5px 10px; }
  .mi-success-steps { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .mi-pro--home .mi-header { grid-template-columns: 1fr; }
  .mi-pro--home .mi-live-price { text-align: left; min-width: 0; }
}

