/* =========================================================
   realKomm GmbH — Bauherrenmodelle & Vorsorgewohnungen
   Seriöses, modernes Redesign · Serifen-Typografie
   Markenakzent #ca2556 (aus Logo übernommen)
   ========================================================= */

:root{
  --ink:#15171a;          /* fast schwarz — Header, Hero, Footer */
  --ink-2:#1f2226;        /* abgesetzte dunkle Flächen */
  --ink-soft:#3a3f46;     /* dunkler Fließtext */
  --cream:#f7f4ef;        /* warmes Off-White — Grundfläche */
  --cream-2:#efe9e0;      /* abgesetzte helle Fläche */
  --paper:#ffffff;
  --line:#e3ddd2;         /* Trennlinien auf hell */
  --line-dark:#2c3037;    /* Trennlinien auf dunkel */
  --accent:#ca2556;       /* Markenmagenta */
  --accent-deep:#a81d47;
  --muted:#7d7468;        /* gedämpfter Text auf hell */
  --muted-dark:#9aa0a8;   /* gedämpfter Text auf dunkel */
  --gold:#b79b6e;         /* dezenter zweiter Akzent */
  --maxw:1180px;
  --ff-display:"Fraunces", Georgia, "Times New Roman", serif;
  --ff-body:"Source Serif 4", Georgia, serif;
  --shadow:0 24px 60px -28px rgba(21,23,26,.35);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--ff-body);font-size:18px;line-height:1.7;
  font-weight:380;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--ff-display);font-weight:560;line-height:1.08;letter-spacing:-.01em;margin:0}
h1{font-size:clamp(2.6rem,6vw,4.7rem);font-weight:500}
h2{font-size:clamp(2rem,4vw,3rem)}
h3{font-size:clamp(1.3rem,2.2vw,1.7rem)}
p{margin:0 0 1.1em}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.lead{font-size:clamp(1.15rem,1.7vw,1.4rem);line-height:1.6;color:var(--ink-soft)}
.eyebrow{
  font-family:var(--ff-body);font-size:.74rem;font-weight:600;letter-spacing:.28em;
  text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:.7em;margin:0 0 1.2rem;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--accent);display:inline-block}
.eyebrow.on-dark{color:#e7889f}
.eyebrow.on-dark::before{background:#e7889f}
.center{text-align:center}
.center .eyebrow::before{display:none}
.center .eyebrow{display:block;margin-bottom:.7rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;font-family:var(--ff-body);
  font-size:.95rem;font-weight:600;letter-spacing:.02em;padding:.95em 1.7em;border-radius:2px;
  border:1px solid transparent;cursor:pointer;transition:.25s ease;line-height:1;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-deep)}
.btn-ghost{background:transparent;border-color:currentColor;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn-ghost.on-dark{color:var(--cream)}
.btn-ghost.on-dark:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn .arr{transition:transform .25s ease}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- Header ---------- */
.site-head{
  position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(21,23,26,.0);
  transition:background .3s ease,box-shadow .3s ease,padding .3s ease;padding:22px 0;
}
.site-head.solid{background:rgba(21,23,26,.97);box-shadow:0 1px 0 var(--line-dark);padding:14px 0;backdrop-filter:saturate(140%) blur(6px)}
.head-in{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand img{height:34px;width:auto;display:block}
.nav{display:flex;align-items:center;gap:34px}
.nav a{font-family:var(--ff-body);font-size:.98rem;color:#e9e3da;letter-spacing:.01em;opacity:.85;transition:.2s}
.nav a:hover{opacity:1;color:#fff}
.nav .btn{padding:.7em 1.3em}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-toggle span{width:26px;height:2px;background:#fff;display:block;transition:.3s}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden;background:var(--ink)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.55}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(21,23,26,.55) 0%,rgba(21,23,26,.35) 35%,rgba(21,23,26,.85) 100%)}
.hero-in{position:relative;z-index:2;padding-bottom:clamp(50px,9vh,110px);padding-top:160px;max-width:980px}
.hero h1{color:#fff}
.hero h1 .accent{color:var(--accent);font-style:italic;font-weight:400}
.hero .lead{color:#e4ddd2;max-width:620px;margin-top:1.6rem}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:2.3rem}
.hero-meta{position:absolute;right:28px;bottom:clamp(50px,9vh,110px);z-index:2;text-align:right;display:none}
.scroll-hint{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:#cfc7ba;opacity:.8;
  writing-mode:vertical-rl;}

/* ---------- Trust strip ---------- */
.trust{background:var(--ink-2);color:var(--cream);border-top:1px solid var(--line-dark)}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding-top:54px;padding-bottom:54px}
.stat .n{font-family:var(--ff-display);font-size:clamp(2.1rem,3.4vw,2.9rem);font-weight:500;color:#fff;line-height:1}
.stat .n .u{color:var(--accent);font-size:.6em;margin-left:.1em}
.stat .l{margin-top:.55rem;font-size:.92rem;color:var(--muted-dark);letter-spacing:.02em}

/* ---------- Section base ---------- */
section{position:relative}
.sec{padding:clamp(76px,11vh,140px) 0}
.sec-head{max-width:720px;margin-bottom:clamp(40px,6vh,68px)}
.sec-head.center{margin-left:auto;margin-right:auto}

/* ---------- Über uns ---------- */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,80px);align-items:center}
.about-copy h2{margin-bottom:1.1rem}
.about-figure{position:relative}
.about-figure img{border-radius:3px;box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover}
.about-figure .tag{position:absolute;left:-22px;bottom:34px;background:var(--ink);color:var(--cream);
  padding:20px 26px;border-radius:3px;max-width:230px;box-shadow:var(--shadow)}
.about-figure .tag .q{font-family:var(--ff-display);font-style:italic;font-size:1.15rem;line-height:1.35;color:#fff}
.about-figure .tag .a{margin-top:.6rem;font-size:.82rem;letter-spacing:.04em;color:var(--muted-dark)}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:clamp(48px,6vh,72px)}
.pillar{padding-top:22px;border-top:2px solid var(--ink)}
.pillar h3{font-size:1.18rem;margin-bottom:.5rem}
.pillar p{font-size:.98rem;color:var(--ink-soft);margin:0}

/* ---------- Leistungen (Modelle) ---------- */
.models{background:var(--ink);color:var(--cream)}
.models .eyebrow{color:#e7889f}.models .eyebrow::before{background:#e7889f}
.models h2{color:#fff}
.models .sec-head .lead{color:var(--muted-dark)}
.model-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:10px}
.model{background:var(--ink-2);border:1px solid var(--line-dark);border-radius:4px;overflow:hidden;
  display:flex;flex-direction:column;transition:.3s ease}
.model:hover{transform:translateY(-4px);border-color:#41464e}
.model-img{aspect-ratio:16/10;overflow:hidden}
.model-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.model:hover .model-img img{transform:scale(1.05)}
.model-body{padding:32px 34px 36px}
.model .k{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600}
.model h3{color:#fff;margin:.7rem 0 .8rem;font-size:1.55rem}
.model p{color:var(--muted-dark);font-size:1rem;margin-bottom:1.3rem}
.model ul{list-style:none;padding:0;margin:0 0 1.6rem}
.model li{position:relative;padding-left:26px;margin-bottom:.6rem;font-size:.97rem;color:#d8d2c8}
.model li::before{content:"";position:absolute;left:0;top:.62em;width:11px;height:1px;background:var(--accent)}
.model .more{margin-top:auto;font-family:var(--ff-body);font-weight:600;color:#fff;
  display:inline-flex;gap:.5em;align-items:center;font-size:.95rem}
.model .more .arr{color:var(--accent);transition:transform .25s}
.model:hover .more .arr{transform:translateX(4px)}

/* ---------- Leistungen (Service-Reihe) ---------- */
.serve{background:var(--cream-2)}
.serve-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.serve-item{background:var(--cream);padding:40px 40px 44px}
.serve-item .num{font-family:var(--ff-display);font-size:1.05rem;color:var(--accent);font-weight:600}
.serve-item h3{margin:.6rem 0 .7rem;font-size:1.45rem}
.serve-item p{margin:0;color:var(--ink-soft);font-size:1rem}

/* ---------- Projekte ---------- */
.projects{background:var(--cream)}
.proj-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:22px;margin-top:8px}
.proj{position:relative;overflow:hidden;border-radius:4px;background:var(--ink);min-height:300px}
.proj img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .7s ease;opacity:.95}
.proj:hover img{transform:scale(1.06)}
.proj::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,23,26,0) 35%,rgba(21,23,26,.82) 100%)}
.proj .cap{position:absolute;left:0;bottom:0;z-index:2;padding:26px 28px;color:#fff}
.proj .cap .loc{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#e7c9d3}
.proj .cap h3{color:#fff;margin-top:.4rem;font-size:1.45rem}
.proj .cap .meta{font-size:.9rem;color:#d9d3c9;margin-top:.3rem}
.proj.big{grid-column:span 7;min-height:440px}
.proj.tall{grid-column:span 5;min-height:440px}
.proj.third{grid-column:span 4;min-height:330px}
.proj-note{margin-top:30px;text-align:center;color:var(--muted);font-size:.95rem}

/* ---------- Team ---------- */
.team{background:var(--ink);color:var(--cream)}
.team .eyebrow{color:#e7889f}.team .eyebrow::before{background:#e7889f}
.team h2{color:#fff}
.team .sec-head .lead{color:var(--muted-dark)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:8px}
.member{}
.member-ph{position:relative;aspect-ratio:3/4;border-radius:4px;overflow:hidden;background:var(--ink-2);
  filter:grayscale(1) contrast(1.02);transition:filter .5s ease}
.member:hover .member-ph{filter:grayscale(0)}
.member-ph img{width:100%;height:100%;object-fit:cover;object-position:center top}
.member-ph::after{content:"";position:absolute;inset:0;box-shadow:inset 0 -60px 60px -40px rgba(21,23,26,.9)}
.member h3{font-size:1.22rem;color:#fff;margin-top:1.1rem}
.member .role{color:var(--accent);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-top:.35rem;font-weight:600}
.member .role{color:#e7889f}
.member .ct{margin-top:.9rem;font-size:.92rem;color:var(--muted-dark);line-height:1.6}
.member .ct a{color:#d8d2c8;border-bottom:1px solid var(--line-dark);transition:.2s}
.member .ct a:hover{color:#fff;border-color:var(--accent)}

/* ---------- Kontakt ---------- */
.contact{background:var(--cream-2)}
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(40px,6vw,90px);align-items:start}
.contact-info h2{margin-bottom:1.1rem}
.contact-info .lead{margin-bottom:2rem}
.info-row{display:flex;gap:16px;padding:18px 0;border-top:1px solid var(--line)}
.info-row:last-child{border-bottom:1px solid var(--line)}
.info-row .ic{color:var(--accent);flex:0 0 auto;margin-top:3px}
.info-row .k{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:.2rem}
.info-row .v{font-size:1.05rem;color:var(--ink)}
.info-row a:hover{color:var(--accent)}
form .field{margin-bottom:18px}
form label{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;font-weight:600}
form input,form textarea{
  width:100%;font-family:var(--ff-body);font-size:1.02rem;color:var(--ink);background:var(--paper);
  border:1px solid var(--line);border-radius:3px;padding:.85em 1em;transition:.2s;resize:vertical;
}
form input:focus,form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(202,37,86,.1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.consent{display:flex;gap:12px;align-items:flex-start;margin:6px 0 22px;font-size:.9rem;color:var(--ink-soft)}
.consent input{width:18px;height:18px;margin-top:3px;flex:0 0 auto;accent-color:var(--accent)}
.consent a{color:var(--accent);border-bottom:1px solid currentColor}
form .btn-primary{width:100%;justify-content:center;padding:1.05em}
.form-note{margin-top:14px;font-size:.84rem;color:var(--muted);text-align:center}
.form-msg{display:none;padding:14px 16px;border-radius:3px;margin-bottom:16px;font-size:.95rem}
.form-msg.ok{display:block;background:#edf5ee;color:#256b39;border:1px solid #bfe0c6}
.form-msg.err{display:block;background:#fbecef;color:#a81d47;border:1px solid #f0c7d2}

/* ---------- Footer ---------- */
.site-foot{background:var(--ink);color:var(--muted-dark);padding-top:72px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:54px;border-bottom:1px solid var(--line-dark)}
.foot-brand img{height:30px;margin-bottom:22px}
.foot-brand p{font-size:.96rem;color:var(--muted-dark);max-width:330px;margin:0}
.foot-col h4{font-family:var(--ff-body);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#cfc7ba;margin-bottom:18px;font-weight:600}
.foot-col a,.foot-col p{display:block;font-size:.96rem;color:var(--muted-dark);margin-bottom:.7rem;transition:.2s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:26px 0 34px;font-size:.86rem;color:#6c727b}
.foot-bottom a{color:#8a909a}.foot-bottom a:hover{color:#fff}
.foot-legal{display:flex;gap:22px;flex-wrap:wrap}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);background:var(--ink);flex-direction:column;
    align-items:flex-start;justify-content:center;gap:26px;padding:40px;transform:translateX(100%);
    transition:transform .35s ease;box-shadow:-30px 0 60px rgba(0,0,0,.4)}
  .nav.open{transform:none}
  .nav a{font-size:1.3rem}
  .nav-toggle{display:flex}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .about-figure{max-width:440px;margin:0 auto}
  .about-figure .tag{left:0}
  .model-grid,.serve-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .trust .wrap{grid-template-columns:repeat(2,1fr);gap:34px}
  .proj.big,.proj.tall,.proj.third{grid-column:span 12;min-height:300px}
  .foot-top{grid-template-columns:1fr 1fr}
  .pillars{grid-template-columns:1fr}
}
@media(max-width:560px){
  body{font-size:17px}
  .wrap{padding:0 20px}
  .hero-in{padding-top:130px}
  .hero-cta{flex-direction:column}.hero-cta .btn{width:100%;justify-content:center}
  .team-grid{grid-template-columns:1fr 1fr;gap:16px}
  .form-row{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .about-figure .tag{position:static;max-width:none;margin-top:14px}
}

/* ---------- Legal pages ---------- */
.legal{background:var(--cream);padding-top:140px;padding-bottom:90px}
.legal .wrap{max-width:820px}
.legal h1{font-size:clamp(2.1rem,4vw,3rem);margin-bottom:1.4rem}
.legal h2{font-size:1.4rem;margin:2.2rem 0 .8rem}
.legal h3{font-size:1.12rem;margin:1.6rem 0 .5rem}
.legal p,.legal li{font-size:1rem;color:var(--ink-soft);line-height:1.75}
.legal ul{padding-left:1.2em}
.legal a{color:var(--accent);border-bottom:1px solid currentColor}
.back-link{display:inline-flex;gap:.5em;align-items:center;color:var(--accent);font-weight:600;margin-bottom:2rem;font-size:.95rem}
