/* =================================================================
   WILICOLOR — Entwurf / Design-System
   Fonts:  Bricolage Grotesque (Display) + IBM Plex Sans (Body)
   Marke:  Logo-Grün + Logo-Rot auf warmweisser Putz-/Kalk-Basis
   Signature: grün→rot Pinselschwung (aus dem Logo-Bogen abgeleitet)
   ================================================================= */

:root {
  /* Basis – warme Putz-/Kalk-Töne, kein Reinweiss */
  --ink:        #1b1714;
  --ink-soft:   #46403a;
  --paper:      #f5f1e8;
  --paper-2:    #ebe4d6;
  --paper-3:    #e0d7c5;
  --white:      #ffffff;

  /* Markenfarben – direkt aus dem Logo */
  --red:        #d8281c;
  --red-deep:   #ad1810;
  --green:      #6aa92b;
  --green-deep: #4f8a1b;

  --line:       rgba(27,23,20,.13);
  --line-soft:  rgba(27,23,20,.07);
  --shadow:     0 1px 2px rgba(27,23,20,.05), 0 10px 30px -12px rgba(27,23,20,.18);

  --ff-display: "Bricolage Grotesque", "Arial Narrow", system-ui, sans-serif;
  --ff-body:    "IBM Plex Sans", system-ui, -apple-system, Segoe UI, sans-serif;

  --wrap: 1180px;
  --gut:  clamp(1.1rem, 4vw, 2.5rem);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--ff-body);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  font-size: 1.0625rem;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }

/* ---------- Typografie ---------- */
h1, h2, h3, h4 {
  font-family: var(--ff-display);
  font-weight: 800;
  line-height: 1.04;
  letter-spacing: -.015em;
  color: var(--ink);
}
h1 { font-size: clamp(2.4rem, 6vw, 4.4rem); }
h2 { font-size: clamp(1.9rem, 4vw, 3rem); }
h3 { font-size: clamp(1.25rem, 2.4vw, 1.6rem); font-weight: 700; }
p  { max-width: 64ch; }
.lead { font-size: clamp(1.15rem, 2.1vw, 1.45rem); line-height: 1.55; color: var(--ink-soft); }

.wrap { width: min(100% - 2.2rem, var(--wrap)); margin-inline: auto; }
.section { padding-block: clamp(3.5rem, 8vw, 7rem); }
.eyebrow {
  font-family: var(--ff-body);
  font-weight: 600; font-size: .8rem;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--red-deep);
  display: inline-flex; align-items: center; gap: .6rem;
}
.eyebrow::before { content:""; width: 26px; height: 2px; background: var(--green); display:inline-block; }

/* ---------- Pinselschwung-Signature ---------- */
/* der grün→rot Bogen aus dem Logo, als wiederkehrendes Detail */
.brush { display:block; height:.5rem; width:170px; margin-top:.7rem; }
.brush--center { margin-inline:auto; }
.heading-mark { margin-bottom: 1.6rem; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .55rem;
  font-family: var(--ff-body); font-weight: 600; font-size: 1rem;
  padding: .85rem 1.5rem; border-radius: 2px; border: 2px solid transparent;
  cursor: pointer; transition: transform .12s ease, background .15s ease, color .15s ease;
  line-height: 1;
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--red); color: #fff; }
.btn--primary:hover { background: var(--red-deep); }
.btn--ghost { border-color: var(--ink); color: var(--ink); background: transparent; }
.btn--ghost:hover { background: var(--ink); color: var(--paper); }
.btn--ghost-light { border-color: rgba(255,255,255,.7); color:#fff; }
.btn--ghost-light:hover { background:#fff; color: var(--ink); border-color:#fff; }
.btn svg { width: 1.05em; height: 1.05em; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-block: .7rem; }
.brand { display: flex; align-items: center; gap: .7rem; }
.brand img { height: 38px; width: auto; }
.brand .place { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft); border-left: 1px solid var(--line); padding-left: .7rem; }
.nav { display: flex; align-items: center; gap: clamp(.7rem, 1.6vw, 1.7rem); }
.nav a { font-weight: 500; font-size: .98rem; padding: .35rem 0; position: relative; color: var(--ink-soft); }
.nav a:hover, .nav a[aria-current="page"] { color: var(--ink); }
.nav a[aria-current="page"]::after {
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px;
  background: linear-gradient(90deg, var(--green), var(--red));
}
.header-cta { display: inline-flex; align-items: center; gap: .5rem; font-weight: 700; color: var(--red-deep); }
.header-cta svg { width: 1.05em; height: 1.05em; }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: .4rem; }
.nav-toggle span { display:block; width: 26px; height: 2.5px; background: var(--ink); margin: 5px 0; transition: .2s; }

/* ---------- Hero ---------- */
.hero { position: relative; color: #fff; isolation: isolate; }
.hero-media { position: absolute; inset: 0; z-index: -2; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; object-position: 30% center; }
.hero::after {
  content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(100deg, rgba(15,12,10,.86) 0%, rgba(15,12,10,.6) 42%, rgba(15,12,10,.15) 100%);
}
.hero-inner { padding-block: clamp(5rem, 16vw, 11rem); max-width: 40rem; }
.hero h1 { color: #fff; }
.hero h1 .accent { color: #fff; }
.hero .lead { color: rgba(255,255,255,.9); margin-top: 1.2rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }
.hero-meta { margin-top: 2.4rem; display:flex; flex-wrap:wrap; gap: 1.6rem; font-size: .92rem; color: rgba(255,255,255,.82); }
.hero-meta b { color:#fff; font-weight:600; }

/* ---------- Intro ---------- */
.intro-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem, 5vw, 4rem); align-items: start; }
.values { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.values li { background: var(--paper); padding: 1.1rem 1.2rem; display:flex; gap:.8rem; align-items:flex-start; }
.values .v-ico { color: var(--green-deep); flex: 0 0 auto; margin-top: .15rem; }
.values b { font-family: var(--ff-display); font-weight: 700; }

/* ---------- Leistungen (echte Fotos, kein Icon-Grid) ---------- */
.services { display: grid; gap: clamp(1.1rem, 2.5vw, 1.8rem); }
.service {
  display: grid; grid-template-columns: 320px 1fr; gap: clamp(1.2rem, 3vw, 2.6rem);
  align-items: center; background: var(--white); border: 1px solid var(--line);
  box-shadow: var(--shadow); overflow: hidden;
}
.service:nth-child(even) { grid-template-columns: 1fr 320px; }
.service:nth-child(even) .service-media { order: 2; }
.service-media { align-self: stretch; }
.service-media img { width: 100%; height: 100%; min-height: 240px; object-fit: cover; }
.service-body { padding: clamp(1.4rem, 3vw, 2.4rem) clamp(1.4rem, 3vw, 2.4rem) clamp(1.4rem,3vw,2.4rem) 0; }
.service:nth-child(even) .service-body { padding-left: clamp(1.4rem, 3vw, 2.4rem); padding-right: 0; }
.service-num { font-family: var(--ff-display); font-weight: 800; color: var(--paper-3); font-size: 2.2rem; line-height:1; }
.service h3 { margin: .3rem 0 .6rem; }
.service .more { display:inline-flex; align-items:center; gap:.45rem; font-weight:600; color: var(--red-deep); margin-top: 1.1rem; }
.service .more svg { width:1em; height:1em; transition: transform .15s ease; }
.service .more:hover svg { transform: translateX(3px); }

/* ---------- Galerie / Referenzen ---------- */
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: .8rem; }
.shot { position: relative; overflow: hidden; background: var(--paper-2); border: 1px solid var(--line); cursor: zoom-in; }
.shot img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; transition: transform .4s ease; }
.shot:hover img { transform: scale(1.04); }
.shot figcaption {
  position:absolute; left:0; right:0; bottom:0; padding: .7rem .8rem .6rem;
  font-size:.85rem; color:#fff;
  background: linear-gradient(to top, rgba(15,12,10,.78), transparent);
}
.shot--placeholder {
  cursor: default; aspect-ratio: 4/3; display: grid; place-content: center; text-align: center;
  background: repeating-linear-gradient(45deg, var(--paper-2), var(--paper-2) 12px, var(--paper-3) 12px, var(--paper-3) 24px);
  color: var(--ink-soft); padding: 1rem;
}
.shot--placeholder span { font-family: var(--ff-display); font-weight:700; }

/* ---------- Platzhalter-Notiz (ehrliche Lücke) ---------- */
.placeholder {
  border: 1px dashed var(--red); background: rgba(216,40,28,.05);
  padding: 1rem 1.2rem; border-radius: 2px; font-size: .92rem; color: var(--ink-soft);
  display:flex; gap:.7rem; align-items:flex-start;
}
.placeholder b { color: var(--red-deep); font-weight:700; }
.placeholder .p-ico { flex:0 0 auto; color: var(--red); }

/* ---------- Bänder / dunkle Sektion ---------- */
.band-dark { background: var(--ink); color: var(--paper); }
.band-dark h2, .band-dark h3 { color: #fff; }
.band-dark .lead { color: rgba(245,241,232,.78); }
.band-dark a.under { color:#fff; border-bottom:1px solid var(--green); }

/* ---------- Kontakt ---------- */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem,4vw,3.5rem); align-items:start; }
.contact-list { display:grid; gap: 1.1rem; margin-top: 1.6rem; }
.contact-list a, .contact-list div { display:flex; gap:.9rem; align-items:flex-start; font-size:1.05rem; }
.contact-list .c-ico { color: var(--red); flex:0 0 auto; margin-top:.15rem; }
.contact-list b { display:block; font-family:var(--ff-display); font-weight:700; font-size:.85rem; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:.1rem; }

.form { display:grid; gap: 1rem; }
.field { display:grid; gap:.35rem; }
.field label { font-weight:600; font-size:.9rem; }
.field input, .field textarea {
  font: inherit; padding: .75rem .85rem; border:1px solid var(--line); background: var(--white);
  border-radius:2px; color: var(--ink);
}
.field input:focus, .field textarea:focus { outline: 2px solid var(--green); border-color: var(--green); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.privacy-hint { font-size:.85rem; color: var(--ink-soft); display:flex; gap:.6rem; align-items:flex-start; }
.privacy-hint a { color: var(--red-deep); border-bottom:1px solid var(--line); }

/* Karte / Consent */
.map-consent {
  aspect-ratio: 16/9; border:1px solid var(--line); background: var(--paper-2);
  display:grid; place-content:center; text-align:center; gap:.8rem; padding:1.5rem;
}
.map-consent p { margin-inline:auto; max-width: 36ch; font-size:.92rem; color: var(--ink-soft); }
.map-frame { width:100%; aspect-ratio:16/9; border:1px solid var(--line); }

/* ---------- Page-Header (Unterseiten) ---------- */
.page-head { background: var(--paper-2); border-bottom:1px solid var(--line); }
.page-head .wrap { padding-block: clamp(2.6rem, 6vw, 4.5rem); }
.crumbs { font-size:.85rem; color: var(--ink-soft); margin-bottom: .7rem; }
.crumbs a:hover { color: var(--ink); }

/* dünner Markenstreifen oben (grün→rot) */
.brandbar { height: 4px; background: linear-gradient(90deg, var(--green) 0%, var(--green) 38%, var(--red) 62%, var(--red) 100%); }

/* ---------- Footer ---------- */
.site-footer { background: var(--ink); color: rgba(245,241,232,.72); padding-block: clamp(2.6rem,6vw,4rem) 1.5rem; }
.footer-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; }
.site-footer h4 { color:#fff; font-size:1rem; margin-bottom:1rem; font-family:var(--ff-display); letter-spacing:.02em; }
.site-footer a:hover { color:#fff; }
.site-footer .f-brand img { height: 40px; background:#fff; padding:6px 8px; border-radius:2px; }
.footer-links li { margin-bottom:.5rem; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top: 2.4rem; padding-top:1.4rem; display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; justify-content:space-between; font-size:.85rem; }
.footer-bottom a { border-bottom:1px solid rgba(255,255,255,.25); }

/* ---------- Lightbox ---------- */
.lightbox { position: fixed; inset:0; background: rgba(15,12,10,.92); z-index:100; display:none; place-content:center; padding: 2rem; }
.lightbox.open { display:grid; }
.lightbox img { max-width: min(92vw, 1100px); max-height: 86vh; object-fit: contain; box-shadow: 0 20px 60px rgba(0,0,0,.5); }
.lightbox .lb-close { position:absolute; top:1.1rem; right:1.3rem; background:none; border:0; color:#fff; font-size:2.4rem; line-height:1; cursor:pointer; }
.lightbox figcaption { color: rgba(255,255,255,.85); text-align:center; margin-top:.9rem; font-size:.92rem; }

/* ---------- Responsive ---------- */
@media (max-width: 860px) {
  .nav { position: fixed; inset: 0 0 0 auto; width: min(78vw, 320px); background: var(--white);
    flex-direction: column; align-items: flex-start; justify-content: flex-start; gap: .2rem;
    padding: 5rem 1.6rem 2rem; transform: translateX(100%); transition: transform .25s ease;
    box-shadow: -10px 0 40px rgba(0,0,0,.15); }
  .nav.open { transform: translateX(0); }
  .nav a { font-size: 1.15rem; padding: .6rem 0; width:100%; border-bottom:1px solid var(--line-soft); }
  .nav .header-cta { margin-top: 1rem; font-size:1.1rem; }
  .nav-toggle { display:block; z-index: 60; }
  .nav-toggle.open span:nth-child(1){ transform: translateY(7.5px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform: translateY(-7.5px) rotate(-45deg); }
  .intro-grid, .contact-grid, .footer-grid { grid-template-columns: 1fr; }
  .service, .service:nth-child(even) { grid-template-columns: 1fr; }
  .service:nth-child(even) .service-media { order: 0; }
  .service-media img { min-height: 220px; max-height: 280px; }
  .service-body, .service:nth-child(even) .service-body { padding: 0 1.4rem 1.6rem; }
  .form-row { grid-template-columns: 1fr; }
  .brand .place { display:none; }
}
@media (max-width: 520px) {
  .hero-meta { gap: .9rem 1.4rem; }
}
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
