/* =========================================================
   WAVO RAUMGESTALTUNG — Premium Corporate
   Ruhige, hochwertige Optik · viel Weißraum · klare Typo
   Inspiration: zurückhaltende Industrie-/Premium-Auftritte
   Eine Markenfarbe (Petrol), Anthrazit, Weiß. Kein Deko-Raster.
   ========================================================= */

:root {
  --white:    #ffffff;
  --paper:    #f5f7f7;   /* sehr helles Grau für Wechselsektionen */
  --paper-2:  #e9eded;   /* Bild-Platzhalter */
  --paper-3:  #dde3e3;
  --ink:      #15201f;   /* Anthrazit, leicht grünstichig */
  --ink-2:    #2c3a39;
  --muted:    #5f6d6c;
  --line:     #e2e7e7;   /* Haarlinie */
  --line-2:   #cdd5d5;
  --petrol:   #0E6E6C;
  --petrol-d: #0a5453;
  --petrol-tint: #e7f1f0;

  --maxw: 1280px;
  --pad: clamp(1.15rem, 4vw, 3rem);
  --radius: 4px;
  --sans: "Helvetica Neue", Helvetica, Arial, "Segoe UI", system-ui, sans-serif;
  --t: .28s cubic-bezier(.4, 0, .2, 1);
  --shadow: 0 18px 50px -20px rgba(21, 32, 31, .22);
  --shadow-sm: 0 10px 30px -16px rgba(21, 32, 31, .18);
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--white);
  font-size: 17px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img, svg, video, iframe { display: block; max-width: 100%; }
a { color: var(--petrol); text-decoration: none; transition: color var(--t); }
ul { list-style: none; padding: 0; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }

h1, h2, h3, h4 { font-weight: 700; line-height: 1.12; letter-spacing: -.018em; color: var(--ink); }
h1 { font-size: clamp(2.5rem, 5.6vw, 4.6rem); }
h2 { font-size: clamp(1.9rem, 3.8vw, 3rem); }
h3 { font-size: 1.3rem; letter-spacing: -.01em; }
p { color: var(--muted); }

::selection { background: var(--petrol); color: #fff; }
:focus-visible { outline: 2.5px solid var(--petrol); outline-offset: 3px; border-radius: 2px; }

.skip-link { position: absolute; left: 14px; top: -70px; z-index: 2000; background: var(--ink); color: #fff; padding: .7rem 1.1rem; border-radius: var(--radius); transition: top .2s; }
.skip-link:focus { top: 14px; color: #fff; }
.vh { position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0; }

.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--pad); }

/* ---------- Typo-Bausteine ---------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: .7rem;
  font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: var(--petrol);
  margin-bottom: 1.3rem;
}
.eyebrow::before { content: ""; width: 26px; height: 2px; background: var(--petrol); }
.lead { font-size: clamp(1.08rem, 1.6vw, 1.28rem); color: var(--ink-2); line-height: 1.6; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .6rem; justify-content: center;
  padding: 1rem 1.9rem; border-radius: var(--radius); font-weight: 600; font-size: 1rem;
  border: 1.5px solid transparent; transition: background var(--t), color var(--t), border-color var(--t), transform var(--t);
}
.btn .ico { transition: transform var(--t); }
.btn:hover .ico { transform: translateX(4px); }
.btn--primary { background: var(--petrol); color: #fff; }
.btn--primary:hover { background: var(--petrol-d); color: #fff; }
.btn--outline { border-color: var(--line-2); color: var(--ink); }
.btn--outline:hover { border-color: var(--ink); background: var(--ink); color: #fff; }
.btn--light { background: #fff; color: var(--ink); }
.btn--light:hover { background: var(--petrol); color: #fff; }
.btn--ghost-light { border-color: rgba(255,255,255,.4); color: #fff; }
.btn--ghost-light:hover { background: rgba(255,255,255,.12); color: #fff; }
.btn--sm { padding: .7rem 1.3rem; font-size: .92rem; }

.link-arrow { display: inline-flex; align-items: center; gap: .5rem; font-weight: 600; color: var(--petrol); }
.link-arrow .ico { transition: transform var(--t); }
.link-arrow:hover { color: var(--petrol-d); }
.link-arrow:hover .ico { transform: translateX(4px); }

/* ---------- Header ---------- */
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 1000; background: rgba(255,255,255,.86); backdrop-filter: blur(10px); border-bottom: 1px solid transparent; transition: border-color var(--t), box-shadow var(--t), background var(--t); }
.site-header.scrolled { border-color: var(--line); box-shadow: 0 2px 20px -12px rgba(21,32,31,.25); background: rgba(255,255,255,.95); }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; height: 80px; }
.brand { display: flex; align-items: center; }
.brand img { height: 38px; width: auto; max-width: none; }

.main-nav { display: flex; align-items: center; gap: 2.4rem; }
.nav-links { display: flex; gap: 2rem; }
.nav-links a { color: var(--ink); font-weight: 500; font-size: .98rem; position: relative; padding: .4rem 0; }
.nav-links a::after { content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 2px; background: var(--petrol); transition: width var(--t); }
.nav-links a:hover { color: var(--petrol); }
.nav-links a:hover::after { width: 100%; }

.nav-toggle { display: none; width: 46px; height: 46px; position: relative; z-index: 1100; }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after { content: ""; position: absolute; left: 50%; top: 50%; width: 24px; height: 2px; background: var(--ink); transform: translate(-50%,-50%); transition: transform var(--t), opacity var(--t), background var(--t); }
.nav-toggle span::before { transform: translate(-50%, -8px); }
.nav-toggle span::after { transform: translate(-50%, 8px); }
body.nav-open .nav-toggle span { background: transparent; }
body.nav-open .nav-toggle span::before { transform: translate(-50%,0) rotate(45deg); background: #fff; }
body.nav-open .nav-toggle span::after { transform: translate(-50%,0) rotate(-45deg); background: #fff; }

/* ---------- Sections ---------- */
.section { padding-block: clamp(4rem, 8vw, 7.5rem); }
.section--alt { background: var(--paper); }
.section--ink { background: var(--ink); color: #fff; }
.section--ink h2, .section--ink h3 { color: #fff; }
.section--ink p { color: rgba(255,255,255,.74); }
.section-header { max-width: 760px; margin-bottom: clamp(2.4rem, 5vw, 3.6rem); }
.section-header.center { margin-inline: auto; text-align: center; }
.section-header.center .eyebrow::before { display: none; }
.section-header.center .eyebrow { padding: 0; }
.section-header p { margin-top: 1.1rem; font-size: 1.08rem; }

/* ---------- Hero ---------- */
.hero { padding-top: 80px; }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; padding-block: clamp(3rem, 7vw, 6rem); }
.hero h1 { margin-bottom: 1.5rem; }
.hero h1 .accent { color: var(--petrol); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 1.1rem 1.6rem; align-items: center; margin-top: 2.2rem; }
.hero-stats { display: flex; flex-wrap: wrap; gap: 2.4rem; margin-top: 3rem; padding-top: 2.2rem; border-top: 1px solid var(--line); }
.hero-stats div b { display: block; font-size: clamp(1.7rem, 3vw, 2.4rem); font-weight: 700; color: var(--ink); line-height: 1; letter-spacing: -.02em; }
.hero-stats div span { font-size: .9rem; color: var(--muted); }

.hero-visual { position: relative; aspect-ratio: 4/5; border-radius: 8px; overflow: hidden; background: var(--ink); display: flex; align-items: center; justify-content: center; }
.hero-visual img { width: 100%; height: 100%; object-fit: cover; }
.visual-mark { color: rgba(255,255,255,.16); width: 42%; }
.visual-cap { position: absolute; left: 1.2rem; bottom: 1.2rem; right: 1.2rem; color: rgba(255,255,255,.6); font-size: .8rem; }
.hero-visual .tag { position: absolute; top: 1.2rem; left: 1.2rem; background: var(--petrol); color: #fff; font-size: .76rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; padding: .45rem .9rem; border-radius: 3px; }

/* ---------- Leistungen ---------- */
.services { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.service-card { background: #fff; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; transition: border-color var(--t), box-shadow var(--t), transform var(--t); display: flex; flex-direction: column; }
.service-card:hover { border-color: transparent; box-shadow: var(--shadow); transform: translateY(-4px); }
.service-card__img { aspect-ratio: 16/10; background: var(--paper-2); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.service-card__img .ic { width: 46px; height: 46px; color: var(--petrol); transition: transform var(--t); }
.service-card:hover .service-card__img .ic { transform: scale(1.08); }
.service-card__img .no { position: absolute; top: .9rem; left: 1rem; font-size: .82rem; font-weight: 700; color: var(--line-2); letter-spacing: .04em; }
.service-card__body { padding: 1.6rem 1.5rem 1.7rem; flex: 1; display: flex; flex-direction: column; }
.service-card__body h3 { margin-bottom: .6rem; }
.service-card__body > p { font-size: .96rem; margin-bottom: 1.1rem; }
.service-card__body ul { display: grid; gap: .45rem; margin-bottom: 1.3rem; }
.service-card__body li { display: flex; gap: .55rem; font-size: .9rem; color: var(--muted); }
.service-card__body li svg { width: 16px; height: 16px; color: var(--petrol); flex: none; margin-top: 5px; }
.service-card__body .link-arrow { margin-top: auto; font-size: .92rem; }

/* ---------- Über uns ---------- */
.about-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.about-visual { aspect-ratio: 5/6; border-radius: 8px; overflow: hidden; background: var(--paper-2); display: flex; align-items: center; justify-content: center; position: relative; }
.about-visual img { width: 100%; height: 100%; object-fit: cover; }
.about-visual .ic { width: 60px; height: 60px; color: var(--line-2); }
.about-visual .cap { position: absolute; bottom: 1rem; left: 1rem; right: 1rem; font-size: .8rem; color: var(--muted); }
.about-badge { position: absolute; right: -1rem; bottom: 2rem; background: var(--petrol); color: #fff; padding: 1.2rem 1.5rem; border-radius: 6px; box-shadow: var(--shadow-sm); }
.about-badge b { display: block; font-size: 1.8rem; font-weight: 700; line-height: 1; }
.about-badge span { font-size: .82rem; opacity: .85; }
.about-text p { margin-bottom: 1.1rem; }
.checks { display: grid; gap: .75rem; margin-top: 1.7rem; }
.checks li { display: flex; gap: .8rem; align-items: flex-start; font-weight: 500; color: var(--ink); }
.checks li svg { width: 22px; height: 22px; color: var(--petrol); flex: none; margin-top: 3px; }

/* ---------- Vorher / Nachher ---------- */
.ba-wrap { max-width: 960px; margin-inline: auto; }
.ba-slider { position: relative; aspect-ratio: 16/9; border-radius: 8px; overflow: hidden; user-select: none; touch-action: pan-y; cursor: ew-resize; border: 1px solid var(--line); }
.ba-img { position: absolute; inset: 0; display: flex; align-items: flex-end; padding: 1.3rem; }
.ba-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ba-img .ba-tag { position: relative; z-index: 2; }
.ba-after { background: var(--petrol); color: #fff; }
.ba-before { background: var(--ink-2); color: #fff; clip-path: inset(0 50% 0 0); }
.ba-tag { background: rgba(0,0,0,.32); color: #fff; font-size: .76rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; padding: .4rem .8rem; border-radius: 3px; }
.ba-mark { position: absolute; inset: 0; margin: auto; width: 56px; height: 56px; color: rgba(255,255,255,.25); }
.ba-handle { position: absolute; top: 0; bottom: 0; left: 50%; width: 2px; background: #fff; transform: translateX(-50%); }
.ba-handle::after { content: ""; position: absolute; top: 50%; left: 50%; width: 46px; height: 46px; border-radius: 50%; background: #fff; transform: translate(-50%,-50%); box-shadow: var(--shadow-sm); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%230E6E6C' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 5 L3 11 L9 17 M15 5 L21 11 L15 17'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: center; }
.ba-range { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: ew-resize; margin: 0; }
.ba-caption { display: flex; justify-content: space-between; flex-wrap: wrap; gap: .8rem; margin-top: 1.3rem; font-size: .92rem; color: var(--muted); }

/* ---------- Galerie ---------- */
.filter { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; margin-bottom: 2.4rem; }
.filter button { padding: .6rem 1.3rem; border-radius: 50px; border: 1px solid var(--line-2); font-weight: 500; font-size: .92rem; color: var(--muted); transition: all var(--t); }
.filter button:hover { border-color: var(--petrol); color: var(--petrol); }
.filter button.active { background: var(--ink); border-color: var(--ink); color: #fff; }
.gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.gallery-item { position: relative; aspect-ratio: 1; border-radius: 6px; overflow: hidden; cursor: pointer; background: var(--paper-2); display: flex; align-items: flex-end; padding: 1rem; text-align: left; border: 1px solid var(--line); transition: box-shadow var(--t), transform var(--t); }
.gallery-item img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--t); }
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item .ic { position: absolute; inset: 0; margin: auto; width: 40px; height: 40px; color: var(--line-2); transition: transform var(--t), color var(--t); }
.gallery-item .cat { position: absolute; top: .8rem; left: .9rem; font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; color: var(--petrol); }
.gallery-item .ttl { position: relative; z-index: 2; font-weight: 600; font-size: .92rem; color: var(--ink); }
.gallery-item::after { content: ""; position: absolute; inset: 0; background: var(--ink); opacity: 0; transition: opacity var(--t); }
.gallery-item:hover { transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.gallery-item:hover::after { opacity: .04; }
.gallery-item:hover .ic { transform: scale(1.1); color: var(--petrol); }
.gallery-item.hide { display: none; }

.lightbox { position: fixed; inset: 0; z-index: 1500; background: rgba(21,32,31,.92); display: none; align-items: center; justify-content: center; padding: 2rem; backdrop-filter: blur(3px); }
.lightbox.open { display: flex; }
.lightbox__inner { position: relative; display: flex; flex-direction: column; align-items: center; gap: .9rem; max-width: min(90vw, 780px); }
.lightbox__img { max-width: 100%; max-height: 78vh; width: auto; height: auto; border-radius: 8px; background: var(--ink-2); object-fit: contain; }
.lightbox__inner .ic { width: 76px; height: 76px; color: rgba(255,255,255,.3); }
.lightbox__cap { text-align: center; color: #fff; font-weight: 500; }
.lightbox__close { position: absolute; top: -3.4rem; right: 0; width: 44px; height: 44px; border: 1.5px solid rgba(255,255,255,.4); border-radius: 50%; color: #fff; display: flex; align-items: center; justify-content: center; }
.lightbox__close:hover { background: rgba(255,255,255,.12); }
.lightbox__close svg { width: 22px; height: 22px; }

/* ---------- Warum ---------- */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.4rem 2rem; }
.feature .ic { width: 40px; height: 40px; color: var(--petrol); margin-bottom: 1.1rem; }
.feature h3 { font-size: 1.18rem; margin-bottom: .55rem; }
.feature p { font-size: .96rem; }

/* ---------- Ablauf ---------- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.step { position: relative; }
.step__no { font-size: .85rem; font-weight: 700; color: var(--petrol); letter-spacing: .08em; }
.step__line { height: 2px; background: var(--line-2); margin: 1.1rem 0; position: relative; }
.step__line::before { content: ""; position: absolute; left: 0; top: 50%; width: 9px; height: 9px; border-radius: 50%; background: var(--petrol); transform: translateY(-50%); }
.step h3 { font-size: 1.12rem; margin-bottom: .5rem; }
.step p { font-size: .94rem; }

/* ---------- Kontakt (ink) ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.contact-info h2 { margin-bottom: 1.3rem; }
.contact-info > p { color: rgba(255,255,255,.74); margin-bottom: 2rem; }
.contact-list { display: grid; gap: 1.3rem; margin-bottom: 2rem; }
.contact-list li { display: flex; gap: 1rem; align-items: flex-start; }
.contact-list .ci-ic { width: 44px; height: 44px; border-radius: 6px; flex: none; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.07); color: #fff; }
.contact-list .ci-ic svg { width: 21px; height: 21px; }
.contact-list .lab { display: block; font-size: .76rem; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.5); margin-bottom: .2rem; }
.contact-list a, .contact-list span.val { color: #fff; font-weight: 500; font-size: 1.05rem; }
.contact-list a:hover { color: var(--petrol); }

.map { border-radius: 8px; overflow: hidden; border: 1px solid rgba(255,255,255,.12); }
.map-consent { background: rgba(255,255,255,.05); padding: 2rem 1.5rem; text-align: center; display: flex; flex-direction: column; gap: 1rem; align-items: center; aspect-ratio: 16/9; justify-content: center; }
.map-consent .ic { width: 36px; height: 36px; color: var(--petrol); }
.map-consent p { color: rgba(255,255,255,.7); font-size: .9rem; max-width: 40ch; }
.map iframe { width: 100%; height: 100%; min-height: 280px; border: 0; }
.map.loaded { aspect-ratio: 16/9; }

/* Formular (weiße Karte auf dunkel) */
.contact-form { background: #fff; border-radius: 8px; padding: clamp(1.7rem, 4vw, 2.6rem); box-shadow: var(--shadow); }
.contact-form h3 { margin-bottom: .4rem; font-size: 1.5rem; }
.contact-form > p { font-size: .95rem; margin-bottom: 1.7rem; }
.field { margin-bottom: 1.35rem; }
.field label { display: block; font-weight: 600; font-size: .9rem; color: var(--ink); margin-bottom: .5rem; }
.field label .req { color: var(--petrol); }
.field input, .field select, .field textarea { width: 100%; padding: .85rem 1rem; border: 1.5px solid var(--line-2); border-radius: var(--radius); font: inherit; font-size: 1rem; color: var(--ink); background: #fff; transition: border-color var(--t), box-shadow var(--t); }
.field textarea { resize: vertical; min-height: 130px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--petrol); box-shadow: 0 0 0 3px var(--petrol-tint); }
.field.invalid input, .field.invalid select, .field.invalid textarea { border-color: #c0392b; }
.field .err { display: none; color: #c0392b; font-size: .84rem; margin-top: .4rem; }
.field.invalid .err { display: block; }
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.charc { font-size: .8rem; color: var(--muted); text-align: right; margin-top: .35rem; }
.consent { display: flex; gap: .7rem; align-items: flex-start; font-size: .88rem; color: var(--muted); margin-bottom: 1.5rem; }
.consent input { width: 18px; height: 18px; margin-top: 3px; flex: none; accent-color: var(--petrol); }
.consent a { color: var(--petrol); text-decoration: underline; font-weight: 600; }
.form-status { display: none; padding: 1rem 1.2rem; border-radius: var(--radius); margin-bottom: 1.4rem; font-size: .94rem; }
.form-status.show { display: block; }
.form-status.success { background: var(--petrol-tint); color: var(--petrol-d); border: 1px solid #bcdedb; }
.form-status.error { background: #fdecea; color: #b23227; border: 1px solid #f3c4bd; }

/* ---------- Footer ---------- */
.site-footer { background: #0f1817; color: rgba(255,255,255,.66); padding-block: clamp(3rem, 5vw, 4.5rem) 1.6rem; }
.footer-grid { display: grid; grid-template-columns: 1.7fr 1fr 1fr; gap: 2.5rem; padding-bottom: 2.8rem; border-bottom: 1px solid rgba(255,255,255,.1); }
.footer-brand img { height: 42px; width: auto; max-width: none; margin-bottom: 1.2rem; }
.footer-brand p { color: rgba(255,255,255,.6); font-size: .94rem; max-width: 36ch; }
.footer-col h4 { color: #fff; font-size: .95rem; margin-bottom: 1.1rem; }
.footer-col ul { display: grid; gap: .65rem; }
.footer-col a { color: rgba(255,255,255,.7); font-size: .93rem; }
.footer-col a:hover { color: var(--petrol); }
.footer-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: .6rem; padding-top: 1.6rem; font-size: .85rem; color: rgba(255,255,255,.45); }
.footer-bottom a { color: rgba(255,255,255,.55); }
.footer-bottom a:hover { color: var(--petrol); }

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta { display: none; }

/* ---------- Cookie banner ---------- */
.cookie { position: fixed; left: 1rem; right: 1rem; bottom: 1rem; z-index: 1600; max-width: 540px; margin-inline: auto; background: #fff; border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); padding: 1.6rem; transform: translateY(160%); transition: transform .4s cubic-bezier(.4,0,.2,1); }
.cookie.show { transform: translateY(0); }
.cookie h3 { font-size: 1.12rem; margin-bottom: .5rem; }
.cookie p { font-size: .9rem; margin-bottom: 1.2rem; }
.cookie p a { color: var(--petrol); font-weight: 600; }
.cookie-actions { display: flex; flex-wrap: wrap; gap: .7rem; }
.cookie-actions .btn { flex: 1 1 auto; padding: .75rem 1.2rem; font-size: .92rem; }

/* ---------- Legal ---------- */
.legal { padding-top: 80px; }
.legal-hero { background: var(--paper); border-bottom: 1px solid var(--line); padding-block: clamp(3rem, 6vw, 5rem); }
.legal-body { padding-block: clamp(2.6rem, 5vw, 4rem); max-width: 820px; }
.legal-body h2 { font-size: 1.5rem; margin: 2.4rem 0 .8rem; }
.legal-body h3 { font-size: 1.12rem; margin: 1.6rem 0 .5rem; }
.legal-body p, .legal-body li { color: var(--muted); margin-bottom: .8rem; }
.legal-body ul { list-style: disc; padding-left: 1.4rem; margin-bottom: 1rem; }
.legal-body a { text-decoration: underline; }
.back-link { display: inline-flex; align-items: center; gap: .5rem; font-weight: 600; margin-bottom: 2rem; }
.note { background: var(--petrol-tint); border-left: 3px solid var(--petrol); padding: 1rem 1.2rem; font-size: .9rem; color: var(--ink-2); margin-top: 1.2rem; border-radius: 0 var(--radius) var(--radius) 0; }

/* ---------- 404 ---------- */
.error-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; text-align: center; padding: 2rem; background: var(--paper); }
.error-page h1 { font-size: clamp(5rem, 18vw, 12rem); color: var(--petrol); line-height: 1; }
.error-page p { font-size: 1.1rem; margin: .6rem 0 2rem; }

/* ---------- Reveal ---------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s cubic-bezier(.4,0,.2,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-d="1"] { transition-delay: .08s; }
.reveal[data-d="2"] { transition-delay: .16s; }
.reveal[data-d="3"] { transition-delay: .24s; }

/* ============ RESPONSIVE ============ */
@media (max-width: 1024px) {
  .services, .features { grid-template-columns: repeat(2, 1fr); }
  .hero-grid, .about-grid, .contact-grid { grid-template-columns: 1fr; }
  .hero-visual { max-width: 460px; }
  .about-visual { max-width: 420px; margin-inline: auto; }
  .gallery { grid-template-columns: repeat(3, 1fr); }
  .steps { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 760px) {
  body { font-size: 16px; }
  .nav-toggle { display: flex; }
  .main-nav { position: fixed; inset: 0 0 0 auto; width: min(84vw, 360px); background: var(--ink); flex-direction: column; align-items: stretch; justify-content: center; gap: 0; padding: 5rem 2rem 2rem; transform: translateX(100%); transition: transform var(--t); box-shadow: var(--shadow); z-index: 1050; }
  body.nav-open .main-nav { transform: translateX(0); }
  .nav-links { flex-direction: column; gap: 0; }
  .nav-links a { color: #fff; padding: 1.1rem 0; border-bottom: 1px solid rgba(255,255,255,.12); font-size: 1.15rem; }
  .nav-links a::after { display: none; }
  .main-nav .btn { margin-top: 1.5rem; }
  .nav-overlay { position: fixed; inset: 0; background: rgba(21,32,31,.5); opacity: 0; visibility: hidden; transition: opacity var(--t); z-index: 1040; }
  body.nav-open .nav-overlay { opacity: 1; visibility: visible; }

  .services, .features, .steps, .gallery { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr; gap: 1.8rem; }
  .hero-stats { gap: 1.4rem 2rem; }

  .sticky-cta { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; position: fixed; left: 0; right: 0; bottom: 0; z-index: 900; background: #fff; padding: .6rem; border-top: 1px solid var(--line); box-shadow: 0 -4px 20px -10px rgba(21,32,31,.2); }
  .sticky-cta .btn { padding: .85rem; font-size: .95rem; }
  body { padding-bottom: 72px; }
  .cookie { bottom: 82px; }
}

@media (max-width: 440px) {
  .gallery { grid-template-columns: 1fr; }
  .hero-actions .btn { width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
  .reveal { opacity: 1; transform: none; }
}

@media print {
  .site-header, .sticky-cta, .cookie { display: none !important; }
}
