/* S-Change UI – Sparkassen CD (Basis)
   Quellen: vom Auftraggeber bereitgestellte Farbwerte/Buttons/Fonds.
*/
:root {
  --sparkasse-red: #EE0000;
  --darkgray: #666666;
  --silvergray: #D9D9D9;
  --black: #000000;
  --white: #FFFFFF;
  --gray-0: #F0F0F0;
  --gray-1: #E9E9E9;
  --gray-2: #E3E3E3;
  --gray-3: #D6D6D6;
  --gray-4: #CCCCCC;
  --gray-5: #BBBBBB;
  --gray-6: #999999;
  --darkgray-2: #444444;

  --radius: 18px;
  --shadow: 0 6px 18px rgba(0,0,0,.08);
}

<style id='cf-frontend-style-inline-css' type='text/css'>
@font-face {
	font-family: 'SparkasseSymbol_Rg';
	font-weight: 400;
	src: url('https://immosummit.info/wp-content/uploads/2019/07/SparkasseSymbol_Rg.ttf') format('truetype');
}
@font-face {
	font-family: 'SparkasseHeadRegular';
	font-weight: 400;
	src: url('https://immosummit.info/wp-content/uploads/2019/07/SparkasseHead_web_Rg.woff') format('woff');
}
@font-face {
	font-family: 'SparkasseHeadRegular';
	font-weight: 400;
	src: url('https://immosummit.info/wp-content/uploads/2019/07/SparkasseHead_web_Rg.woff') format('woff');
}
@font-face {
	font-family: 'SparkasseMedium';
	font-weight: 400;
	src: url('https://immosummit.info/wp-content/uploads/2019/07/Sparkasse_web_Md.woff') format('woff');
}
@font-face {
	font-family: 'SparkasseRegular';
	font-weight: 400;
	src: url('https://immosummit.info/wp-content/uploads/2019/07/Sparkasse_web_Rg.woff') format('woff');
}
@font-face {
	font-family: 'SparkasseLight';
	font-weight: 400;
	src: url('https://immosummit.info/wp-content/uploads/2019/07/Sparkasse_web_Lt.woff') format('woff');
}

.btn-mini{padding:6px 10px;font-size:12px;border-radius:999px}
.btn-icon{display:inline-flex;align-items:center;gap:6px}
.btn-icon .ico{font-size:14px;line-height:1}
.notice{border:1px solid #e5e5e5;border-left:4px solid var(--sparkasse-red, #e2001a);padding:10px 12px;border-radius:12px;background:#fff}
.textlink{color:var(--sparkasse-red, #e2001a);text-decoration:none}
.textlink:hover{text-decoration:underline}

.export-link{display:inline-flex;align-items:center;gap:6px;padding:2px 0;border:0;background:transparent;color:inherit;text-decoration:none;font-size:13px}
.export-link:hover{text-decoration:underline}
.export-link .ico{font-size:14px;line-height:1}

</style>

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: #fff;
  color: var(--black);
  font-family: SparkasseRegular, SparkasseHeadRegular, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

a { color: var(--sparkasse-red); text-decoration: none; }
a:hover { text-decoration: underline; }

.container {
  width: min(1100px, calc(100% - 32px));
  margin: 0 auto;
  padding: 22px 0 44px;
}

.topbar {
  background: var(--white);
  box-shadow: var(--shadow);
  border-bottom: 1px solid var(--gray-2);
}

.topbar-inner {
  width: min(1100px, calc(100% - 32px));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: SparkasseHeadRegular, SparkasseRegular, Arial, sans-serif;
  font-size: 20px;
}
.badge {
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--gray-1);
  color: var(--darkgray-2);
  font-size: 12px;
}

.card {
  background: var(--white);
  border: 1px solid var(--gray-2);
  border-radius: 22px;
  box-shadow: var(--shadow);
  padding: 22px;
}

.h1 {
  font-family: SparkasseHeadRegular, SparkasseRegular, Arial, sans-serif;
  font-size: 26px;
  margin: 0 0 10px;
}

.muted { color: var(--darkgray); }

/* Form helper text (smaller than body copy, similar to labels). */
.help-text{margin-top:6px;font-size:13px;color:var(--darkgray);}

.grid {
  display: grid;
  gap: 16px;
}

.grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 860px) {
  .grid-2 { grid-template-columns: 1fr; }
}

label {
  display: block;
  font-size: 13px;
  color: var(--darkgray-2);
  margin: 0 0 6px;
}

.label-strong{font-weight:700;}

input[type="email"], input[type="password"], input[type="text"] {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--gray-4);
  outline: none;
  background: var(--white);
}
input:focus {
  border-color: var(--sparkasse-red);
  box-shadow: 0 0 0 3px rgba(238,0,0,.12);
}

.btn {
  font-size: 14px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 18px;
  border-radius: var(--radius);
  font-weight: 600;
  border: 2px solid var(--sparkasse-red);
  background: var(--white);
  color: var(--sparkasse-red);
  cursor: pointer;
  transition: all .12s ease;
  user-select: none;
}

.btn:hover {
  background: var(--sparkasse-red);
  color: var(--white);
}

.btn-secondary {
  border-color: var(--darkgray);
  color: var(--darkgray);
}
.btn-secondary:hover {
  background: var(--darkgray);
  color: var(--white);
}

.flash {
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--gray-2);
  background: var(--gray-1);
  margin-bottom: 14px;
}

.flash.error {
  border-color: rgba(238,0,0,.35);
  background: rgba(238,0,0,.08);
}

.flash.success {
  border-color: rgba(0,130,0,.35);
  background: rgba(0,130,0,.08);
}

.table {
  width: 100%;
  border-collapse: collapse;
}
.table th, .table td {
  border-bottom: 1px solid var(--gray-2);
  padding: 10px 8px;
  text-align: left;
  vertical-align: top;
  font-size: 14px;
}
.table th {
  color: var(--darkgray);
  font-weight: 700;
}

/* v0.3 Ampel */
.ampel{display:inline-block;width:12px;height:12px;border-radius:50%;border:1px solid #666;vertical-align:middle;}
.ampel-green{background:#2ecc71;}
.ampel-yellow{background:#f1c40f;}
.ampel-red{background:#e74c3c;}
.ampel-grey{background:#bdc3c7;}
.ampel-none{background:#fff;}

.btn-danger{background:#b00020;color:#fff;border:2px solid #b00020;}
.btn-danger:hover{filter:brightness(0.95);}

/* Small utility: keep action button groups perfectly aligned (e.g. Admin lists). */
.actions-inline{display:inline-flex;gap:10px;align-items:center;}
.actions-inline__form{display:inline-flex;margin:0;}

/* v2.70.0 – Super-Admin Bearbeiten: Edit-Zeile über volle Tabellenbreite */
.table tr.sa-edit-row{ display:none; }
.table tr.sa-edit-row:target{ display:table-row; }
.table tr.sa-edit-row td{ padding: 0; border-bottom: 0; }
.sa-edit-inner{ padding: 12px; background: var(--gray-1); border: 1px solid var(--gray-2); border-radius: 14px; }

.flash.warning{background:#fff3cd;border:1px solid #ffecb5;color:#664d03;}


/* v2.1 – kleine UI-Ergänzungen (Login / Navigation) */
.topnav { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.brand-logo { display:block; max-width:200px; max-height:60px; object-fit:contain; }
.btn-icon { padding: 12px 12px; width: 44px; justify-content:center; }
.input-with-icon { position: relative; }
.input-with-icon input { padding-right: 44px; }
.icon-btn {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  cursor: pointer;
  color: var(--darkgray);
  padding: 6px;
  border-radius: 10px;
}
.icon-btn:hover { background: var(--gray-1); }


/* v2.2 form ux */
*, *::before, *::after { box-sizing: border-box; }

/* Inputs */
input[type="email"], input[type="password"], input[type="text"], input[type="number"], input[type="tel"], input[type="url"], textarea, select {
  width: 100%;
  max-width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--gray-4);
  outline: none;
  background: var(--white);
  font: inherit;
  line-height: 1.2;
}
textarea { min-height: 120px; resize: vertical; }
select {
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, var(--darkgray) 50%),
                    linear-gradient(135deg, var(--darkgray) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% - 3px),
                       calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 34px;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--sparkasse-red);
  box-shadow: 0 0 0 3px rgba(238,0,0,.12);
}

input[type="file"]{
  width: 100%;
  max-width: 100%;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid var(--gray-3);
  background: #fff;
}

/* Form sections */
.form-section{
  border: 1px solid var(--gray-2);
  background: #fff;
  border-radius: var(--radius);
  padding: 14px;
  margin-top: 14px;
}
.section-title{
  font-size: 18px;
  margin: 0 0 10px;
  font-family: SparkasseHeadRegular, Arial, sans-serif;
}
.hint{
  font-size: 12px;
  color: var(--darkgray);
  margin-top: 6px;
}
.checkline{
  display:flex;
  gap:10px;
  align-items:center;
  margin: 10px 0 2px;
}
.checkline input{ width:auto; }


/* Dashboard v2.3 */
.kpi-row{ display:flex; gap:14px; }
.kpi{ flex:1; padding:14px; border:1px solid var(--gray-2); border-radius:16px; background:#fff; }
.kpi-label{ font-size:13px; color: var(--darkgray-2); margin-bottom:6px; }
.kpi-value{ font-size:28px; font-weight:700; letter-spacing:-.3px; margin:4px 0 2px; }
.dash-metrics{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.dash-metric{ padding:12px; border:1px solid var(--gray-2); border-radius:16px; }
.dash-metric-label{ font-size:13px; color: var(--darkgray-2); }
.dash-metric-value{ font-size:26px; font-weight:700; margin-top:6px; }
.dash-metric-value a{ color: inherit; text-decoration:none; }
.dash-metric-value a:hover{ text-decoration:underline; }
.link{ color: var(--sparkasse-red); text-decoration:none; font-weight:600; }
.link:hover{ text-decoration:underline; }
@media (max-width: 860px){
  .kpi-row{ flex-direction:column; }
  .dash-metrics{ grid-template-columns: 1fr; }
}


/* Dashboard v2.3.1 */
.kpi-label{
  font-size:16px;
  font-weight:700;
}
.kpi .muted{
  font-size:12px;
}
.kpi-value.kpi-green{
  color:#009864;
}
.stat-red{
  color: var(--sparkasse-red);
}


/* Dashboard v2.3.2 */
.link-black{
  color:#000;
  text-decoration:none;
  font-weight:600;
}
.link-black:hover{ text-decoration:underline; }

.stat-red{
  color: var(--sparkasse-red);
  text-decoration: underline !important;
}


/* Dashboard v2.3.3 */
.has-footer-link{
  position: relative;
  padding-bottom: 44px; /* Platz für Footer-Link */
}
.box-footer-left{
  position: absolute;
  left: 16px;
  bottom: 16px;
}


/* v2.3.4: Statistik-Zahlen rot erzwingen (überschreibt .dash-metric-value a { color: inherit; }) */
.dash-metric-value a.stat-red{
  color: var(--sparkasse-red) !important;
  text-decoration: underline !important;
}


/* v2.5 – Footer */
.site-footer{margin-top:18px;border-top:1px solid var(--gray-2);padding:10px 0;color:#666;font-size:13px;}
.site-footer a{color:inherit;text-decoration:none;}
.site-footer a:hover{text-decoration:underline;}
.footer-inner{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:center;}
.footer-sep{opacity:0.6;}


/* v2.5 – Ampel: Rot blinkt (neu/unbeantwortet) */
@keyframes ampel-blink{0%,55%{opacity:1}60%,100%{opacity:.25}}
.ampel-red{animation:ampel-blink 1s infinite;}

/* v2.9.1: Ampel-Filter Icons */
.traffic-icon{
  display:inline-flex;
  width:34px;
  height:34px;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  text-decoration:none;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  font-size:18px;
  line-height:1;
}
.traffic-icon .ampel{width:14px;height:14px;animation:none !important;}
.traffic-icon:hover{ text-decoration:underline; }
.traffic-icon.active{
  border-color:#d4002a;
  box-shadow: 0 0 0 2px rgba(212,0,42,.12);
}

/* v2.80.0: Custom status dropdown (leads filter) */
.status-select{position:relative;}
.status-select__btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding: 10px 12px;
  border: 1px solid var(--gray-3);
  border-radius: 12px;
  background: #fff;
  font-size: 14px;
}
.status-select__btn:focus{outline:2px solid rgba(212,0,42,.25); outline-offset:2px;}
.status-select__left{display:inline-flex; align-items:center; gap:8px; min-width:0;}
.status-select__label{white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.status-select__chev{opacity:.7;}
.status-select__menu{
  position:absolute;
  left:0;
  right:0;
  top: calc(100% + 6px);
  z-index: 50;
  background:#fff;
  border:1px solid var(--gray-3);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.12);
  padding: 6px;
}
.status-select__opt{
  width:100%;
  display:flex;
  align-items:center;
  gap:8px;
  padding: 9px 10px;
  border-radius: 10px;
  border:0;
  background:transparent;
  text-align:left;
  cursor:pointer;
  font-size: 14px;
}
.status-select__opt:hover{background: rgba(0,0,0,.04);}
.status-select .ampel{animation:none !important;}

/* v2.80.0: Leads tables – make "öffnen" consistently align to the right */
.table-leads th:last-child,
.table-leads td:last-child{ text-align:right; }

/* Tooltip boxes */
.tooltip-link{
  color: var(--red);
  text-decoration: underline;
  font-weight: 700;
}
.tooltip-box{
  background: #fff;
  border: 1px solid var(--gray-3);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.35;
  box-shadow: 0 8px 24px rgba(0,0,0,.10);
}

/* v2.9.5: File upload field wrapper to keep hint inside frame */
.file-field{
  border: 1px solid var(--gray-3);
  background: #fff;
  border-radius: 12px;
  padding: 10px 12px;
}
.file-field input[type="file"]{
  border: 0;
  padding: 0;
  background: transparent;
  width: 100%;
}
.file-field .hint{
  margin-top: 6px;
}

/* v2.10: file input button corners / consistent look */
.file-field input[type="file"]{
  font: inherit;
  width: 100%;
}
.file-field input[type="file"]::file-selector-button{
  border: 1px solid var(--gray-3);
  background: #f6f6f6;
  color: var(--darkgray);
  border-radius: 10px;
  padding: 10px 12px;
  margin-right: 10px;
  cursor: pointer;
}
.file-field input[type="file"]::file-selector-button:hover{
  text-decoration: underline;
}
.file-field input[type="file"]::-webkit-file-upload-button{
  border: 1px solid var(--gray-3);
  background: #f6f6f6;
  color: var(--darkgray);
  border-radius: 10px;
  padding: 10px 12px;
  margin-right: 10px;
  cursor: pointer;
}
.file-field input[type="file"]::-webkit-file-upload-button:hover{
  text-decoration: underline;
}

/* v2.10: spacing in lead detail file upload */
.file-upload-row{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}
.file-upload-row input[type="file"]{
  max-width: 520px;
}

/* KPI-Links (Statistik): rot + unterstrichen */
a.stat-link{color:var(--sparkasse-red, #e2001a);text-decoration:underline}
a.stat-link:hover{text-decoration:underline}

/* Button-Loading-Spinner */
.btn.is-loading{cursor:wait;opacity:.85}
.btn .btn-spinner{display:inline-block;width:14px;height:14px;margin-left:8px;border:2px solid currentColor;border-top-color:transparent;border-radius:999px;animation:spin .8s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}


/* v2.19.0 – OTP resend link disabled state */
.link.is-disabled{ color:#888; cursor:default; pointer-events:none; text-decoration:none; }


/* v2.20.0 – password rules UI */
.pw-rule-list{ list-style: none; margin:0; padding:0; }
.pw-rule{ display:flex; align-items:flex-start; gap:8px; margin: 4px 0; }
.pw-icon{ display:inline-block; width: 18px; line-height: 18px; text-align:center; font-weight: bold; color:#b00020; }
.pw-rule.ok .pw-icon{ color:#1a7f37; }
.pw-rule.ok{ color:#1a7f37; }
.pw-rule.bad{ color:#666; }
.btn[disabled], .btn:disabled{ opacity: .6; cursor: not-allowed; }


/* Contact form readonly fields */
.readonly-field{background:#f4f4f4;color:#666;border-color:#e0e0e0;}

/* Inline validation icons (leads/new) */
.vwrap{position:relative;}
.vwrap > input,
.vwrap > select{padding-right:48px;}
.vmark{
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  font-size:28px;
  line-height:1;
  font-weight:800;
  pointer-events:none;
  opacity:0;
}
.vmark.is-valid{color:#1a8f3a; opacity:1;}
.vmark.is-invalid{color:#b00020; opacity:1;}




/* v2.29.1 – Lead Detail UX (restored) */
.lead-meta-box{
  background:#f3f3f3;
  border:1px solid #e2e2e2;
  border-radius:16px;
  padding:14px 16px;
}
.lead-meta-box .meta-row{
  display:grid;
  grid-template-columns: 180px 1fr;
  gap:10px;
  padding:4px 0;
}
.lead-meta-box .meta-label{ color:#666; }
.lead-meta-box .meta-val{ color:#111; }
.export-pills{ display:flex; gap:10px; flex-wrap:wrap; }
.export-pill{
  display:inline-block;
  padding:8px 10px;
  border:1px solid #dcdcdc;
  border-radius:10px;
  text-decoration:none;
  color:#111;
  background:#fff;
  font-weight:600;
  font-size:13px;
}
.export-pill:hover{ border-color:#bfbfbf; }
@media (max-width: 720px){
  .lead-meta-box .meta-row{ grid-template-columns: 1fr; gap:2px; }
}

/* v2.28.0 – Responsive (Mobile/Tablet) – ohne Desktop zu verändern */
.nav-toggle{
  display:none;
  border:1px solid var(--gray-3);
  background:#fff;
  color: var(--darkgray-2);
  border-radius: 14px;
  padding: 10px 12px;
  cursor: pointer;
  align-items:center;
  justify-content:center;
  box-shadow: 0 2px 10px rgba(0,0,0,.05);
}
.nav-toggle:hover{ background: var(--gray-1); }

.nav-backdrop{ display:none; }

.table-scroll{ overflow: visible; }

@media (max-width: 900px){
  /* Layout spacing */
  .container{ width: calc(100% - 20px); padding: 16px 0 32px; }
  .card{ padding: 16px; border-radius: 18px; }

  /* Header / Navigation */
  .topbar-inner{ flex-wrap: wrap; gap: 10px; padding: 12px 0; }
  .brand{ gap: 8px; }
  .brand-logo{ max-width: 160px; max-height: 48px; }
  .badge{ font-size: 11px; padding: 4px 9px; }

  .nav-toggle{ display:inline-flex; margin-left:auto; }
  .topnav{
    width: 100%;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding-top: 8px;
  }
  body.nav-open .topnav{ display:flex; }

  .topnav .btn,
  .topnav a.btn,
  .topnav button.btn{ width: 100%; justify-content: center; }
  .topnav .btn-icon{ width: 100%; }
  .topnav form{ width: 100%; }

  /* Backdrop for open mobile menu */
  .nav-backdrop{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.28);
    display:none;
    z-index: 10;
  }
  body.nav-open .nav-backdrop{ display:block; }
  .topbar{ position: relative; z-index: 11; }

  /* Tables: horizontal scroll instead of broken layout */
  .table-scroll{ overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .table-scroll .table{ width: max-content; min-width: 100%; }
  .table-scroll .table th, .table-scroll .table td{ white-space: nowrap; }

  /* Footer link in dashboard boxes should not overlap content */
  .has-footer-link{ padding-bottom: 18px; }
  .box-footer-left{ position: static; margin-top: 12px; }

  /* Forms with inline flex styles: stack nicely */
  form[style*="display:flex"]{ align-items: stretch !important; }
  form[style*="display:flex"] > div{ min-width: 100% !important; }
}

/* v2.30.0 – Lead-Detail: CTA-Ausrichtung (Annahme/Ablehnung) */
.lead-decision-grid > .card{
  display:flex;
  flex-direction:column;
}
.lead-decision-grid .lead-decision-form{
  display:flex;
  flex-direction:column;
  flex:1;
}
.lead-decision-grid .decision-actions{
  margin-top:auto;
  padding-top:10px;
}


/* v2.70.2 – Generic accordion panel rows inside tables (Admin lists, Nutzer-Übersicht). */
.table tr.accordion-panel-row td{ padding: 0; border-bottom: 0; }
.accordion-inner{ padding: 12px; background: var(--gray-1); border: 1px solid var(--gray-2); border-radius: 14px; }
