/* =========================================================
   PRIOR Immobilien – Landing Page (Lead-Capture)
   Reduziert auf das Wesentliche: Name, Telefon, E-Mail
   Farben & Typografie an den Flyer angelehnt
   ========================================================= */

/* ---- Schriften (alle lokal gehostet -> keine Drittanbieter-Requests, DSGVO-konform) ---- */
/* DM Sans (Fließtext) – Variable Font, deckt 400–700 ab */
@font-face {
  font-family:"DM Sans"; font-style:normal; font-weight:400 700; font-display:swap;
  src:url("../assets/fonts/DMSans-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face {
  font-family:"DM Sans"; font-style:normal; font-weight:400 700; font-display:swap;
  src:url("../assets/fonts/DMSans-latinext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face { font-family:"Montserrat"; src:url("../assets/fonts/Montserrat-Regular.ttf") format("truetype");  font-weight:400; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("../assets/fonts/Montserrat-Medium.ttf") format("truetype");   font-weight:500; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("../assets/fonts/Montserrat-SemiBold.ttf") format("truetype"); font-weight:600; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("../assets/fonts/Montserrat-Bold.ttf") format("truetype");     font-weight:700; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("../assets/fonts/Montserrat-ExtraBold.ttf") format("truetype");font-weight:800; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("../assets/fonts/Montserrat-Black.ttf") format("truetype");    font-weight:900; font-display:swap; }

/* --- Marken-Schriften (Flyer) ---
   Lovelo (Headlines, Button, Trust-Titel) = solide „Lovelo Black"-Variante.
   Buffalo (Script-Slogan). Beide als WOFF eingebunden, voll offline-tauglich.
   Hinweis: Freie Versionen – vor dem Livegang Web-Lizenz prüfen. */
@font-face {
  font-family:"Lovelo";
  src:url("../assets/fonts/Lovelo.woff") format("woff");
  font-weight:400 900; font-style:normal; font-display:swap;
}
@font-face {
  font-family:"Buffalo";
  src:url("../assets/fonts/Buffalo.woff") format("woff");
  font-weight:400; font-style:normal; font-display:swap;
}

:root {
  --taupe:       #8c857a;
  --gold:        #b89a5b;
  --gold-dark:   #a2854a;
  --charcoal:    #2b2b2b;
  --white:       #ffffff;
  --line:        #e3ddd3;
  --muted:       #6f6a62;
  --shadow:      0 20px 55px rgba(35,32,28,.22);
  /* Headlines: Lovelo (Flyer) -> Fallback Montserrat */
  --font-display:"Lovelo","Montserrat","Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  /* Fließtext: DM Sans (Flyer) -> Fallback Inter/System */
  --font-body:   "DM Sans","Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  /* Script-Slogan: Buffalo (Flyer, lokal) -> System-Fallback */
  --font-script: "Buffalo","Segoe Script","Brush Script MT",cursive;
}

*,*::before,*::after { box-sizing:border-box; }
[hidden] { display:none !important; }
html { -webkit-text-size-adjust:100%; }
body {
  margin:0; font-family:var(--font-body); color:var(--charcoal); line-height:1.55;
  background:var(--taupe); background-image:linear-gradient(150deg,#979084 0%,#7e776b 100%);
  -webkit-font-smoothing:antialiased;
}
a { color:var(--gold-dark); }

/* ---- Layout ---- */
.page {
  min-height:100vh; min-height:100dvh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:
    calc(24px + env(safe-area-inset-top))
    calc(16px + env(safe-area-inset-right))
    calc(24px + env(safe-area-inset-bottom))
    calc(16px + env(safe-area-inset-left));
}
.card {
  width:100%; max-width:440px; background:var(--white);
  border-radius:18px; border-top:6px solid var(--gold);
  box-shadow:var(--shadow); padding:0 28px 26px; text-align:center;
  overflow:hidden;
}

/* ---- Foto-Header ---- */
.card-photo {
  margin:0 -28px 0;            /* randlos bis zu den Kartenkanten */
  background:#8c857a; overflow:hidden; line-height:0;
}
.card-photo img { width:100%; height:auto; display:block; }

/* ---- Kopf ---- */
.logo { height:88px; width:auto; margin:18px auto 6px; display:block; }
.tagline {
  font-family:var(--font-script); color:var(--gold-dark);
  font-size:1.35rem; line-height:1; margin:0 0 16px;
}
.kicker {
  font-family:var(--font-display);
  text-transform:uppercase; letter-spacing:.14em; font-weight:700;
  font-size:.8rem; color:var(--charcoal); margin:0 0 4px;
}
.headline {
  margin:0 0 12px; line-height:1.06; font-family:var(--font-display);
  overflow-wrap:break-word; hyphens:auto;   /* Sicherheitsnetz gegen Abschneiden */
}
.headline-gold {
  display:block; text-transform:uppercase; font-weight:900; color:var(--gold);
  font-size:clamp(1.3rem,5.9vw,1.85rem); letter-spacing:-.01em;
}
.headline-sub {
  display:block; text-transform:uppercase; font-weight:700; color:var(--charcoal);
  font-size:clamp(.95rem,4.2vw,1.3rem); letter-spacing:.01em; margin-top:3px;
}
.subline { font-size:.98rem; color:var(--muted); margin:0 0 16px; }
.subline strong { color:var(--charcoal); }

/* ---- Trust-Chips ---- */
.chips {
  list-style:none; padding:0; margin:0 0 22px;
  display:flex; flex-wrap:wrap; justify-content:center; gap:8px 16px;
  font-weight:600; font-size:.85rem; color:var(--charcoal);
}
.chips li { display:inline-flex; align-items:center; gap:6px; }
.check {
  display:inline-grid; place-items:center; width:18px; height:18px;
  border-radius:50%; background:var(--gold); color:#fff; font-size:.6rem; font-weight:900;
}

/* ---- Formular ---- */
form { display:flex; flex-direction:column; gap:12px; text-align:left; }
.field { display:flex; flex-direction:column; }
input[type="text"], input[type="tel"], input[type="email"], select, textarea {
  font-family:var(--font-body); font-size:1rem; color:var(--charcoal);
  padding:15px 16px; border:1.5px solid var(--line); border-radius:11px;
  background:#fdfcfa; width:100%; transition:border-color .15s,box-shadow .15s;
}
textarea { resize:vertical; min-height:48px; line-height:1.5; }
input::placeholder, textarea::placeholder { color:#9a948a; }
input:focus, select:focus, textarea:focus { outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(184,154,91,.18); }
.field.invalid input, .field.invalid select, .field.invalid textarea { border-color:#c0392b; box-shadow:0 0 0 3px rgba(192,57,43,.12); }

/* Honeypot – komplett unsichtbar, aber im DOM (für Bots) */
.hp { position:absolute !important; left:-9999px !important; top:auto; width:1px; height:1px; overflow:hidden; }

/* Select mit eigenem Pfeil */
select {
  -webkit-appearance:none; appearance:none; cursor:pointer;
  padding-right:44px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath fill='none' stroke='%23a2854a' stroke-width='2' d='M1 1l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center;
}
select:required:invalid { color:#9a948a; }   /* Platzhalter-Option wirkt wie placeholder */
select option { color:var(--charcoal); }
.field-error { color:#c0392b; font-size:.76rem; margin-top:5px; font-weight:600; }

.checkbox {
  display:flex; gap:9px; align-items:flex-start; cursor:pointer;
  font-size:.78rem; color:var(--muted); font-weight:500; margin-top:2px;
}
.checkbox input { width:auto; margin-top:2px; flex:0 0 auto; accent-color:var(--gold); transform:scale(1.15); }
.checkbox a { font-weight:700; }
.checkbox.invalid span { color:#c0392b; }

.btn {
  margin-top:6px; width:100%; border:none; cursor:pointer;
  font-family:var(--font-display); font-weight:800; text-transform:uppercase; letter-spacing:.03em;
  font-size:.98rem; color:#fff; background:var(--gold);
  padding:16px 20px; border-radius:11px; line-height:1.15;
  box-shadow:0 8px 20px rgba(184,154,91,.35); transition:background .2s,transform .12s,box-shadow .2s;
}
.btn:hover { background:var(--gold-dark); transform:translateY(-2px); }
.btn:active { transform:translateY(0); }
.btn[disabled] { opacity:.65; cursor:not-allowed; transform:none; }

.reassure { text-align:center; font-size:.78rem; color:var(--muted); margin:12px 0 0; }
.form-status { text-align:center; font-size:.84rem; font-weight:600; margin-top:8px; min-height:1px; }
.form-status.error { color:#c0392b; }

/* ---- Erfolg ---- */
.form-success { padding:14px 4px 4px; }
.success-ico {
  width:62px; height:62px; margin:0 auto 14px; border-radius:50%;
  background:var(--gold); color:#fff; display:grid; place-items:center; font-size:1.8rem; font-weight:900;
}
.form-success h2 { font-family:var(--font-display); font-weight:900; text-transform:uppercase; font-size:1.4rem; margin:0 0 8px; }
.form-success p { color:var(--muted); margin:0; }

/* ---- Anruf-Zeile ---- */
.call {
  margin:20px 0 0; padding-top:16px; border-top:1px solid var(--line);
  font-size:.92rem; color:var(--muted);
}
.call a { font-weight:800; color:var(--charcoal); text-decoration:none; }
.call a:hover { color:var(--gold-dark); }

/* ---- Trust-Strip ---- */
.trust { width:100%; max-width:440px; margin-top:26px; text-align:center; }
.trust-title {
  font-family:var(--font-display);
  color:#fff; text-transform:uppercase; font-weight:900; letter-spacing:.02em;
  font-size:1.05rem; margin:0 0 16px;
}
.trust-list { list-style:none; padding:0; margin:0; display:grid; gap:12px; }
.trust-list li {
  display:grid; grid-template-columns:auto 1fr; grid-template-rows:auto auto;
  column-gap:14px; align-items:center; text-align:left;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2);
  border-radius:12px; padding:14px 16px;
}
.trust-ico {
  grid-row:1 / 3; width:42px; height:42px; border-radius:50%;
  display:grid; place-items:center;
  background:var(--gold); color:#fff;
}
.trust-ico svg { width:22px; height:22px; display:block; }
.trust-list strong { color:#fff; font-size:.95rem; }
.trust-list li > span:last-child { color:#ece7df; font-size:.82rem; line-height:1.4; }

/* ---- Mini-Footer ---- */
.mini-footer { margin-top:22px; text-align:center; color:#ece7df; font-size:.76rem; }
.mini-footer p { margin:2px 0; }
.mini-footer a { color:#fff; text-decoration:none; font-weight:600; }
.mini-footer a:hover { text-decoration:underline; }

/* ---- Sehr kleine Geräte ---- */
@media (max-width:380px) {
  .card { padding:24px 20px 22px; }
  .chips { gap:6px 12px; }
}
