/*
Theme Name: Kauter Immo
Theme URI: https://kauter.immo
Author: Kauter Immo
Description: Individuelles WordPress-Theme fuer Kauter Immo mit direkter Propstack-API-Anbindung (ohne Plugin). Blau-Tuerkis, Du-Ansprache, OpenImmo/Propstack-Felder.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: kauter-immo
*/

  :root{
    --ink:#0E1E24;
    --ink-soft:#45565C;
    --teal:#0A6F84;
    --teal-deep:#0C5662;
    --teal-300:#6FC9D8;
    --coral:#FF5E3A;
    --coral-deep:#E8431F;
    --coral-soft:#FFE4DB;
    --cream:#F6F1E8;
    --card:#FFFFFF;
    --sand:#EADFC8;
    --line:rgba(14,30,36,.12);
    --shadow:0 1px 2px rgba(14,30,36,.06), 0 12px 30px -12px rgba(14,30,36,.18);
    --shadow-lg:0 30px 60px -24px rgba(12,86,98,.42);
    --r:18px;
    --maxw:1180px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  @media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
  body{
    margin:0;background:var(--cream);color:var(--ink);
    font-family:"Figtree",system-ui,sans-serif;font-size:17px;line-height:1.6;
    -webkit-font-smoothing:antialiased;overflow-x:hidden;
  }
  h1,h2,h3{font-family:"Bricolage Grotesque",system-ui,sans-serif;font-weight:800;line-height:1.04;letter-spacing:-.02em;margin:0}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .eyebrow{font-family:"Space Mono",monospace;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);font-weight:700}
  .btn{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:16px;padding:14px 24px;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .18s ease, background .18s ease, box-shadow .18s ease;will-change:transform}
  .btn:focus-visible{outline:3px solid var(--coral);outline-offset:3px}
  .btn-primary{background:var(--coral);color:#fff}
  .btn-primary:hover{background:var(--coral-deep);transform:translateY(-2px)}
  .btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
  .btn-ghost:hover{background:var(--ink);color:var(--cream);transform:translateY(-2px)}
  .btn-light{background:#fff;color:var(--teal-deep)}
  .btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}

  /* ---------- Header ---------- */
  header{position:sticky;top:0;z-index:50;background:rgba(246,241,232,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:72px}
  .brand{display:flex;align-items:center;gap:10px;font-family:"Bricolage Grotesque";font-weight:800;font-size:22px;letter-spacing:-.03em}
  .brand .dot{width:30px;height:30px;border-radius:9px;background:var(--teal);display:grid;place-items:center;color:#fff;font-size:16px;transform:rotate(-6deg)}
  .brand b{color:var(--coral)}
  .nav-links{display:flex;align-items:center;gap:28px}
  .nav-links a{font-size:15.5px;font-weight:500;color:var(--ink-soft);transition:color .15s}
  .nav-links a:hover{color:var(--ink)}
  .menu-cta{display:none}
  .nav-cta{display:flex;align-items:center;gap:14px}
  .phone{font-weight:700;font-size:15px;color:var(--teal-deep);white-space:nowrap}
  .burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
  .burger span{display:block;width:24px;height:2.5px;background:var(--ink);margin:5px 0;border-radius:2px;transition:.25s}

  /* ---------- Hero ---------- */
  .hero{position:relative;padding:72px 0 56px}
  .hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
  .hero h1{font-size:clamp(40px,6.2vw,76px)}
  .hero h1 .mark{color:var(--coral);position:relative;white-space:nowrap}
  .hero p.lead{font-size:clamp(18px,2vw,21px);color:var(--ink-soft);margin:24px 0 32px;max-width:32ch}
  .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
  .hero-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:22px}
  .pulse{width:9px;height:9px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 0 rgba(255,94,58,.5);animation:pulse 2.2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,94,58,.5)}70%{box-shadow:0 0 0 12px rgba(255,94,58,0)}100%{box-shadow:0 0 0 0 rgba(255,94,58,0)}}
  @media (prefers-reduced-motion:reduce){.pulse{animation:none}}

  .hero-photo{position:relative}
  .photo-frame{position:relative;border-radius:26px;overflow:hidden;background:linear-gradient(160deg,var(--teal),var(--teal-deep));aspect-ratio:4/4.6;box-shadow:var(--shadow-lg);display:grid;place-items:end center}
  .photo-frame svg{width:100%;height:100%;position:absolute;inset:0;opacity:.16}
  .photo-frame .figure{position:relative;width:88%;align-self:end}
  .badge-stamp{position:absolute;left:-26px;bottom:34px;width:118px;height:118px;background:var(--coral);color:#fff;border-radius:50%;display:grid;place-items:center;text-align:center;font-family:"Bricolage Grotesque";font-weight:800;font-size:13px;line-height:1.15;padding:14px;transform:rotate(-12deg);box-shadow:var(--shadow);z-index:2}
  .badge-stamp small{display:block;font-family:"Space Mono";font-size:9px;letter-spacing:.1em;font-weight:400;margin-top:3px;opacity:.85}
  .float-card{position:absolute;right:10px;top:24px;background:#fff;border-radius:16px;padding:13px 15px;box-shadow:var(--shadow);display:flex;align-items:center;gap:11px;z-index:3}
  .float-card .ic{width:38px;height:38px;border-radius:10px;background:var(--coral-soft);display:grid;place-items:center;font-size:19px}
  .float-card b{display:block;font-family:"Bricolage Grotesque";font-size:16px}
  .float-card span{font-size:12.5px;color:var(--ink-soft)}

  /* ---------- Trust bar ---------- */
  .trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--card)}
  .trust-row{display:flex;flex-wrap:wrap;gap:14px 40px;align-items:center;justify-content:space-between;padding:20px 24px}
  .trust-item{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px}
  .trust-item .n{font-family:"Bricolage Grotesque";font-size:24px;color:var(--teal)}
  .trust-item svg{flex:none}

  /* ---------- Section base ---------- */
  section{padding:84px 0;scroll-margin-top:80px}
  .sec-head{max-width:640px;margin-bottom:40px}
  .sec-head h2{font-size:clamp(30px,4.4vw,46px);margin-top:14px}
  .sec-head p{color:var(--ink-soft);margin:16px 0 0;font-size:18px}

  /* ---------- Objekte ---------- */
  .obj-top{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:30px}
  .filters{display:flex;gap:8px;flex-wrap:wrap}
  .chip{font-family:"Figtree";font-weight:600;font-size:14.5px;padding:9px 18px;border-radius:999px;border:1.5px solid var(--line);background:transparent;color:var(--ink-soft);cursor:pointer;transition:.18s}
  .chip:hover{border-color:var(--ink)}
  .chip[aria-pressed="true"]{background:var(--teal);border-color:var(--teal);color:#fff}
  .chip:focus-visible{outline:3px solid var(--coral);outline-offset:2px}
  .obj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .obj{background:var(--card);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .22s ease, box-shadow .22s ease}
  .obj:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
  .obj-img{position:relative;aspect-ratio:3/2;overflow:hidden}
  .obj-img .ph{position:absolute;inset:0}
  .obj-img .hmark{position:absolute;inset:0;opacity:.22}
  .obj-tags{position:absolute;top:12px;left:12px;display:flex;gap:7px;z-index:2}
  .tag{font-family:"Space Mono";font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:6px 10px;border-radius:8px;background:rgba(255,255,255,.94);color:var(--teal-deep)}
  .tag.top{background:var(--coral);color:#fff}
  .obj-body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1}
  .obj-loc{font-family:"Space Mono";font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px}
  .obj h3{font-size:20px;line-height:1.15}
  .obj-meta{display:flex;gap:16px;flex-wrap:wrap;margin:14px 0 18px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .obj-meta div{font-size:13.5px;color:var(--ink-soft)}
  .obj-meta b{display:block;font-family:"Bricolage Grotesque";font-size:17px;color:var(--ink);font-weight:700}
  .obj-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
  .price{font-family:"Bricolage Grotesque";font-weight:800;font-size:23px}
  .price small{display:block;font-family:"Space Mono";font-size:11px;font-weight:400;letter-spacing:.04em;color:var(--ink-soft);text-transform:uppercase}
  .obj-link{font-weight:600;font-size:14.5px;color:var(--coral);display:inline-flex;align-items:center;gap:5px}
  .obj-link:hover{gap:9px}
  .obj-note{margin-top:30px;font-size:14px;color:var(--ink-soft);display:flex;align-items:center;gap:10px;justify-content:center}
  .obj-note span{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--teal);color:#fff;font-size:13px}

  /* ---------- Leistungen ---------- */
  #leistungen{background:var(--ink);color:var(--cream)}
  #leistungen .eyebrow{color:var(--teal-300)}
  #leistungen .sec-head h2{color:#fff}
  #leistungen .sec-head p{color:rgba(246,241,232,.66)}
  .serv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  .serv{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:26px 22px;transition:.2s}
  .serv:hover{background:rgba(255,255,255,.08);transform:translateY(-4px)}
  .serv .si{width:46px;height:46px;border-radius:12px;background:var(--coral);display:grid;place-items:center;margin-bottom:18px}
  .serv h3{font-size:20px;color:#fff;margin-bottom:8px}
  .serv p{font-size:14.5px;color:rgba(246,241,232,.66);margin:0}
  .serv .more{margin-top:14px;font-size:13.5px;font-weight:600;color:var(--teal-300)}

  /* ---------- Über ---------- */
  .about-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center}
  .about-photo{border-radius:24px;background:linear-gradient(160deg,var(--sand),#d9c9a4);aspect-ratio:1/1.1;position:relative;overflow:hidden;box-shadow:var(--shadow)}
  .about-photo svg{position:absolute;inset:0;width:100%;height:100%;opacity:.25}
  .about-photo .nm{position:absolute;left:22px;bottom:20px;background:#fff;border-radius:12px;padding:10px 16px;box-shadow:var(--shadow)}
  .about-photo .nm b{font-family:"Bricolage Grotesque";display:block;font-size:18px}
  .about-photo .nm span{font-size:13px;color:var(--ink-soft)}
  .about h2{font-size:clamp(30px,4.4vw,46px);margin:14px 0 0}
  .about .quote{font-family:"Bricolage Grotesque";font-weight:700;font-size:clamp(20px,2.4vw,26px);line-height:1.3;margin:22px 0;letter-spacing:-.01em}
  .about p{color:var(--ink-soft);margin:0 0 16px}
  .sign{font-family:"Bricolage Grotesque";font-size:22px;color:var(--teal);margin-top:6px}

  /* ---------- Gebiete ---------- */
  #gebiete{background:var(--teal);color:#fff}
  #gebiete .eyebrow{color:var(--teal-300)}
  #gebiete h2{color:#fff;font-size:clamp(28px,4vw,42px)}
  #gebiete p.intro{color:rgba(255,255,255,.78);max-width:560px;margin:16px 0 30px}
  .geo{display:flex;flex-wrap:wrap;gap:10px}
  .geo a{border:1.5px solid rgba(255,255,255,.28);border-radius:999px;padding:9px 18px;font-weight:600;font-size:15px;transition:.18s}
  .geo a:hover{background:#fff;color:var(--teal-deep);border-color:#fff}

  /* ---------- Testimonials ---------- */
  .tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .tst{background:var(--card);border-radius:var(--r);padding:28px;box-shadow:var(--shadow);position:relative}
  .tst .stars{color:var(--coral);font-size:16px;letter-spacing:2px;margin-bottom:12px}
  .tst p{font-size:15.5px;margin:0 0 18px}
  .tst .who{display:flex;align-items:center;gap:12px}
  .tst .av{width:42px;height:42px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:"Bricolage Grotesque";font-weight:700}
  .tst .who b{display:block;font-size:15px}
  .tst .who span{font-size:13px;color:var(--ink-soft)}

  /* ---------- Bewertung CTA ---------- */
  .val{background:linear-gradient(135deg,var(--coral),var(--coral-deep));border-radius:28px;padding:54px 48px;color:#fff;display:grid;grid-template-columns:1.3fr .7fr;gap:32px;align-items:center;box-shadow:var(--shadow-lg)}
  .val h2{font-size:clamp(28px,3.6vw,42px);color:#fff}
  .val p{margin:14px 0 0;color:rgba(255,255,255,.9);font-size:18px}
  .val .act{display:flex;justify-content:flex-end}
  @media (max-width:760px){.val{grid-template-columns:1fr;text-align:left}.val .act{justify-content:flex-start}}

  /* ---------- Kontakt ---------- */
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
  .ct-card{background:var(--card);border-radius:var(--r);padding:30px;box-shadow:var(--shadow)}
  .ct-line{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
  .ct-line:last-child{border-bottom:0}
  .ct-line .ic{width:42px;height:42px;border-radius:11px;background:var(--coral-soft);display:grid;place-items:center;flex:none}
  .ct-line b{display:block;font-family:"Bricolage Grotesque";font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
  .ct-line a,.ct-line span{font-size:18px;font-weight:600}
  .ct-hours{background:var(--teal);color:#fff;border-radius:var(--r);padding:30px;display:flex;flex-direction:column;justify-content:center}
  .ct-hours h3{color:#fff;font-size:24px;margin-bottom:8px}
  .ct-hours p{color:rgba(255,255,255,.82);margin:0 0 22px}
  .socials{display:flex;gap:12px;margin-top:8px}
  .socials a{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.14);display:grid;place-items:center;transition:.18s}
  .socials a:hover{background:#fff;color:var(--teal-deep)}

  /* ---------- Footer ---------- */
  footer{background:var(--ink);color:rgba(246,241,232,.6);padding:44px 0}
  .foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
  .foot .brand{color:#fff}
  .foot-links{display:flex;gap:22px;font-size:14.5px}
  .foot-links a:hover{color:#fff}

  /* ---------- reveal ---------- */
  .rev{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .6s ease}
  .rev.in{opacity:1;transform:none}
  html:not(.js) .rev{opacity:1;transform:none}
  @media (prefers-reduced-motion:reduce){.rev{opacity:1;transform:none;transition:none}}

  /* ---------- responsive ---------- */
  @media (max-width:960px){
    .hero-grid{grid-template-columns:1fr;gap:36px}
    .hero-photo{max-width:420px;margin:0 auto}
    .obj-grid{grid-template-columns:repeat(2,1fr)}
    .serv-grid{grid-template-columns:repeat(2,1fr)}
    .about-grid{grid-template-columns:1fr;gap:32px}
    .about-photo{max-width:360px}
    .contact-grid{grid-template-columns:1fr}
  }
  @media (max-width:680px){
    .nav-links,.phone{display:none}
    .nav-cta .btn-primary{display:none}
    .burger{display:block}
    .nav-links.open{display:flex;position:absolute;top:72px;left:0;right:0;background:var(--cream);flex-direction:column;align-items:flex-start;padding:20px 24px;gap:16px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
    .nav-links.open a{font-size:18px}
    .menu-cta{display:inline-flex;align-items:center;background:var(--coral);color:#fff;padding:12px 22px;border-radius:999px;font-weight:600;margin-top:4px}
    section{padding:60px 0}
    .obj-grid{grid-template-columns:1fr}
    .serv-grid{grid-template-columns:1fr}
    .tst-grid{grid-template-columns:1fr}
    .val{padding:36px 26px}
    .float-card{display:none}
  }
