/* =====================================================================
   Autotechnik Hoppe – Public Stylesheet
   Design: Werkstatt-Präzision. Slate (Marke) + Signal-Amber als einziger
   Akzent. Archivo (Headlines), IBM Plex Sans (Text), IBM Plex Mono (Daten),
   Racer (Wortmarke).
   ===================================================================== */

/* ---------- Fonts ---------- */
@font-face{font-family:"Racer";src:url("/assets/fonts/racer.woff2") format("woff2"),url("/assets/fonts/racer.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("/assets/fonts/archivo-latin-wght-normal.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"Plex";src:url("/assets/fonts/ibm-plex-sans-latin-400-normal.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Plex";src:url("/assets/fonts/ibm-plex-sans-latin-500-normal.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Plex";src:url("/assets/fonts/ibm-plex-sans-latin-600-normal.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Plex";src:url("/assets/fonts/ibm-plex-sans-latin-700-normal.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"PlexMono";src:url("/assets/fonts/ibm-plex-mono-latin-400-normal.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"PlexMono";src:url("/assets/fonts/ibm-plex-mono-latin-500-normal.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"PlexMono";src:url("/assets/fonts/ibm-plex-mono-latin-600-normal.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --slate-950:#10171F; --slate-900:#17202A; --slate-800:#283746; --slate-700:#33465A;
  --slate-600:#445566; --slate-500:#5C7085; --slate-400:#8598A8;
  --mist-300:#C6D1DC; --mist-200:#D8E0E8; --mist-100:#E7ECF1;
  --paper:#FCFBFB; --white:#fff;
  --signal:#F5A623; --signal-600:#D98A12; --signal-700:#B0700C; --signal-100:#FBE7C4;
  --open:#34C56B; --closed:#E5544A;

  --ink:var(--slate-900); --body:var(--slate-600);
  --font-brand:"Racer",sans-serif;
  --font-display:"Archivo","Plex",system-ui,sans-serif;
  --font-body:"Plex",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-mono:"PlexMono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --wrap:1200px; --gut:clamp(1.1rem,4vw,2.5rem);
  --header-h:72px;
  --r:14px; --r-sm:9px;
  --shadow:0 18px 50px -22px rgba(16,23,31,.45);
  --shadow-sm:0 6px 20px -12px rgba(16,23,31,.4);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--paper);color:var(--body);
  font-family:var(--font-body);font-size:clamp(1rem,.97rem + .2vw,1.075rem);line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img,picture,svg{display:block;max-width:100%}
img{height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3{margin:0;color:var(--ink);font-family:var(--font-display);line-height:1.05;font-weight:800;letter-spacing:-.01em}
p{margin:0}
:focus-visible{outline:3px solid var(--signal);outline-offset:3px;border-radius:3px}
::selection{background:var(--signal);color:var(--slate-950)}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
[hidden]{display:none!important}
.skip-link{position:fixed;top:10px;left:10px;z-index:200;transform:translateY(-160%);background:var(--slate-900);color:var(--white);padding:.7rem 1.1rem;border-radius:var(--r-sm);font-weight:600}
.skip-link:focus{transform:none}

/* ---------- Layout ---------- */
.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gut)}
.wrap--narrow{max-width:860px}
.section{padding-block:clamp(3.5rem,7vw,6.5rem);position:relative}
.section--paper{background:var(--paper);color:var(--body)}
.section--mist{background:var(--mist-100);color:var(--body)}
.section--slate{background:var(--slate-900);color:var(--mist-200)}
[id]{scroll-margin-top:calc(var(--header-h) + 14px)}

/* ---------- Eyebrow / Section head ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;margin:0 0 1rem;
  font-family:var(--font-mono);font-size:.78rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--slate-500)}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--signal);border-radius:2px}
.eyebrow--light{color:var(--signal)}
.eyebrow--light::before{background:var(--signal)}
.eyebrow__svg{width:1.05em;height:1.05em}
.section__head{max-width:62ch;margin-bottom:clamp(2.2rem,4vw,3.4rem)}
.section__title{font-size:clamp(1.9rem,1.3rem + 2.6vw,3.05rem)}
.section__intro{margin-top:1.1rem;font-size:1.08rem;color:var(--slate-600);max-width:60ch}
.section__intro--light{color:var(--mist-300)}
.section--slate .section__title{color:var(--white)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.8rem 1.25rem;border-radius:var(--r-sm);
  font-family:var(--font-display);font-weight:700;font-size:.98rem;letter-spacing:.01em;
  transition:transform .18s var(--ease),background-color .2s,box-shadow .2s,color .2s;white-space:nowrap}
.btn__icon{width:1.15em;height:1.15em;flex:none}
.btn--call{background:var(--signal);color:var(--slate-950);box-shadow:0 10px 24px -12px rgba(245,166,35,.9)}
.btn--call:hover{background:#ffb739;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--white);box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.5)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px #fff;background:rgba(255,255,255,.08);transform:translateY(-2px)}
.btn--lg{padding:1rem 1.5rem;font-size:1.05rem}

/* ---------- Header ---------- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;height:var(--header-h);
  background:var(--slate-900);box-shadow:var(--shadow-sm);
  transition:background-color .3s,box-shadow .3s,transform .3s}
.site-header[data-transparent]:not(.is-stuck){background:transparent;box-shadow:none}
.header__inner{display:flex;align-items:center;gap:1.5rem;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:.7rem;margin-right:auto}
.brand__mark{font-family:var(--font-brand);color:var(--white);font-size:1.5rem;line-height:1;letter-spacing:.02em}
.brand__seal{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--signal);border:1px solid rgba(245,166,35,.5);padding:.2rem .45rem;border-radius:4px}
@media (max-width:560px){.brand__seal{display:none}}
.nav{display:flex;gap:.35rem}
.nav__link{position:relative;padding:.5rem .85rem;color:var(--mist-200);font-weight:500;font-size:.98rem;border-radius:6px;transition:color .2s}
.nav__link::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.28rem;height:2px;background:var(--signal);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.nav__link:hover,.nav__link.is-active{color:var(--white)}
.nav__link:hover::after,.nav__link.is-active::after{transform:scaleX(1)}
.header__call{padding:.6rem 1rem;font-size:.92rem}
.nav-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;color:var(--white)}
.nav-toggle svg{width:26px;height:26px}
.nav-toggle__close{display:none}

/* ---------- Mobile nav ---------- */
.mobile-nav{position:fixed;inset:var(--header-h) 0 0 0;z-index:90;background:var(--slate-950);
  display:flex;flex-direction:column;justify-content:center;gap:.4rem;padding:2rem var(--gut);
  transform:translateY(-8px);opacity:0;transition:opacity .25s,transform .25s;pointer-events:none}
.mobile-nav[data-open]{opacity:1;transform:none;pointer-events:auto}
.mobile-nav nav{display:flex;flex-direction:column}
.mobile-nav a{color:var(--white);font-family:var(--font-display);font-weight:700;font-size:1.6rem;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-nav__call{margin-top:1.6rem;justify-content:center}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;isolation:isolate;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 60%}
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(90deg,rgba(16,23,31,.92) 0%,rgba(16,23,31,.68) 40%,rgba(16,23,31,.28) 100%),
    linear-gradient(0deg,rgba(16,23,31,.95) 2%,rgba(16,23,31,.35) 42%,rgba(16,23,31,.15) 100%)}
.hero__inner{padding-block:calc(var(--header-h) + 2rem) clamp(3rem,7vh,5.5rem);max-width:760px}
.hero__title{color:var(--white);font-size:clamp(3rem,2rem + 8vw,6.4rem);font-weight:800;letter-spacing:-.02em;
  text-transform:uppercase;margin:.4rem 0 0}
.hero__lead{color:var(--mist-200);font-size:clamp(1.05rem,1rem + .5vw,1.3rem);max-width:46ch;margin-top:1.3rem;line-height:1.55}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.hero__scroll{position:absolute;left:50%;bottom:1.1rem;translate:-50% 0;z-index:1;color:rgba(255,255,255,.7);
  width:44px;height:44px;display:grid;place-items:center;animation:bob 2.4s var(--ease) infinite}
.hero__scroll svg{width:28px;height:28px}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}
.eyebrow__tick{width:9px;height:9px;border-radius:50%;background:var(--signal);box-shadow:0 0 0 4px rgba(245,166,35,.22)}

/* ---------- Status (Betriebsanzeige) ---------- */
.status{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.9rem;font-weight:500}
.status__led{width:11px;height:11px;border-radius:50%;flex:none;background:var(--slate-400)}
.status.is-closed .status__led{background:var(--closed);box-shadow:0 0 0 4px rgba(229,84,74,.18)}
.status.is-open .status__led{background:var(--open);box-shadow:0 0 0 4px rgba(52,197,107,.22),0 0 14px 2px rgba(52,197,107,.65);animation:pulse 2s ease-in-out infinite}
.status__label{font-weight:600;letter-spacing:.02em}
.status.is-open .status__label{color:var(--open)}
.status.is-closed .status__label{color:var(--closed)}
.status__detail{color:var(--slate-400)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(52,197,107,.28),0 0 10px 1px rgba(52,197,107,.5)}50%{box-shadow:0 0 0 6px rgba(52,197,107,.1),0 0 18px 4px rgba(52,197,107,.8)}}
.status--hero{margin-top:1.8rem;background:rgba(16,23,31,.55);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.14);padding:.7rem 1.1rem;border-radius:100px}
.status--hero .status__detail{color:var(--mist-300)}

/* ---------- Leistungen ---------- */
.service-grid{display:grid;gap:1.15rem;grid-template-columns:repeat(3,1fr)}
.service-card{background:var(--white);border:1px solid var(--mist-200);border-radius:var(--r);padding:1.7rem 1.6rem;
  transition:transform .25s var(--ease),box-shadow .25s,border-color .25s}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--mist-300)}
.service-card__icon{display:inline-grid;place-items:center;width:52px;height:52px;border-radius:12px;
  background:var(--slate-900);color:var(--signal);margin-bottom:1.1rem}
.service-card__icon svg{width:27px;height:27px}
.service-card__title{font-size:1.28rem;font-weight:700;color:var(--ink);margin-bottom:.9rem;letter-spacing:-.005em}
.service-card__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.service-card__list li{display:flex;gap:.6rem;align-items:flex-start;font-size:.985rem;color:var(--slate-600)}
.tick{width:18px;height:18px;flex:none;margin-top:.22rem;color:var(--signal-600)}

/* Callout */
.callout{margin-top:1.15rem;background:var(--slate-900);color:var(--mist-200);border-radius:var(--r);
  padding:clamp(1.6rem,3vw,2.4rem);display:flex;flex-wrap:wrap;gap:1.6rem;align-items:center;justify-content:space-between;
  background-image:radial-gradient(120% 140% at 100% 0,rgba(245,166,35,.16),transparent 55%)}
.callout__kicker{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--signal)}
.callout__head{font-family:var(--font-display);font-weight:700;font-size:clamp(1.3rem,1rem + 1.5vw,1.75rem);color:var(--white);margin-top:.4rem}
.callout__sub{margin-top:.5rem;color:var(--mist-300);max-width:46ch}
.callout__actions{display:flex;flex-wrap:wrap;gap:.8rem}

/* ---------- Contact line (shared) ---------- */
.contact-line{display:inline-flex;align-items:center;gap:.85rem;padding:.7rem .95rem;border-radius:var(--r-sm);
  background:rgba(255,255,255,.06);transition:background-color .2s,transform .18s}
.callout .contact-line{background:rgba(255,255,255,.08)}
.contact-line:hover{background:rgba(255,255,255,.14);transform:translateY(-1px)}
.contact-line__icon{width:22px;height:22px;flex:none;color:var(--signal)}
.contact-line__body{display:flex;flex-direction:column;line-height:1.25}
.contact-line__label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slate-400)}
.contact-line__value{font-weight:600;color:var(--white)}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem}
.gallery__item{position:relative;aspect-ratio:3/2;border-radius:var(--r-sm);overflow:hidden;background:var(--slate-800)}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease),filter .3s}
.gallery__item::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(16,23,31,.5),transparent 55%);opacity:0;transition:opacity .3s}
.gallery__zoom{position:absolute;right:.6rem;bottom:.6rem;width:34px;height:34px;display:grid;place-items:center;
  border-radius:50%;background:var(--signal);color:var(--slate-950);opacity:0;transform:scale(.7);transition:opacity .25s,transform .25s}
.gallery__zoom svg{width:19px;height:19px;stroke-width:2.4}
.gallery__item:hover img,.gallery__item:focus-visible img{transform:scale(1.07)}
.gallery__item:hover::after{opacity:1}
.gallery__item:hover .gallery__zoom,.gallery__item:focus-visible .gallery__zoom{opacity:1;transform:none}

/* ---------- Meister ---------- */
.meister{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.8rem,4vw,3.5rem);align-items:center}
.meister--nomedia{grid-template-columns:1fr;max-width:60ch}
.meister__media{position:relative;width:min(300px,70vw)}
.meister__media img{width:100%;border-radius:var(--r);box-shadow:var(--shadow);aspect-ratio:2/3;object-fit:cover}
.meister__badge{position:absolute;left:-.7rem;bottom:1.2rem;display:inline-flex;align-items:center;gap:.45rem;
  background:var(--signal);color:var(--slate-950);font-family:var(--font-mono);font-size:.72rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;padding:.5rem .8rem;border-radius:6px;box-shadow:var(--shadow-sm)}
.meister__badge-icon{width:16px;height:16px}
.meister__role{font-family:var(--font-mono);color:var(--signal-700);font-size:.95rem;letter-spacing:.04em;margin-top:.7rem}
.meister__text{margin:1.2rem 0 1.8rem;font-size:1.08rem;max-width:52ch}

/* ---------- Kontakt ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1.4rem,3vw,2.6rem);align-items:start}
.contact-col{display:flex;flex-direction:column;gap:1.4rem}
.info-block{background:var(--white);border:1px solid var(--mist-200);border-radius:var(--r);padding:1.6rem}
.info-block__title{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--ink);margin-bottom:1rem}
.info-block__icon{width:22px;height:22px;color:var(--signal-600)}
.info-block__addr{font-style:normal;line-height:1.7;color:var(--slate-700)}
.info-block__addr strong{color:var(--ink)}
.link-arrow{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;font-weight:600;color:var(--slate-800);
  border-bottom:2px solid var(--signal);padding-bottom:2px;transition:gap .2s,color .2s}
.link-arrow:hover{gap:.8rem;color:var(--signal-700)}
.link-arrow__icon{width:19px;height:19px;color:var(--signal-600)}
.contact-lines{display:flex;flex-direction:column;gap:.55rem}
/* Kontaktzeilen auf hellem Grund */
.info-block .contact-line{background:var(--mist-100)}
.info-block .contact-line:hover{background:var(--mist-200)}
.info-block .contact-line__value{color:var(--ink)}
.info-block .contact-line__label{color:var(--slate-500)}
.info-block .contact-line__icon{color:var(--signal-600)}

/* Öffnungszeiten-Board */
.hours-board{background:var(--slate-900);color:var(--mist-200);border-radius:var(--r);padding:clamp(1.5rem,3vw,2.1rem);
  box-shadow:var(--shadow);background-image:radial-gradient(120% 120% at 100% 0,rgba(245,166,35,.14),transparent 50%)}
.hours-board__top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  padding-bottom:1.1rem;margin-bottom:.4rem;border-bottom:1px solid rgba(255,255,255,.12)}
.status--board{font-size:1rem}
.status--board .status__label{color:var(--white)}
.hours-board__detail{font-family:var(--font-mono);font-size:.85rem;color:var(--mist-300)}
.hours-table{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:.92rem}
.hours-table th{text-align:left;font-weight:400;color:var(--mist-200);padding:.5rem 0}
.hours-table td{text-align:right;color:var(--mist-300);padding:.5rem 0;font-variant-numeric:tabular-nums}
.hours-table tr+tr th,.hours-table tr+tr td{border-top:1px solid rgba(255,255,255,.07)}
.hours-table .is-today th{color:var(--white);font-weight:600}
.hours-table .is-today td{color:var(--signal);font-weight:500}
.today-tag{margin-left:.55rem;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;background:var(--signal);color:var(--slate-950);padding:.12rem .4rem;border-radius:4px;vertical-align:middle}
.hours-board__note{display:flex;align-items:center;gap:.5rem;margin-top:1.2rem;font-size:.85rem;color:var(--mist-300)}
.hours-board__note-icon{width:17px;height:17px;flex:none;color:var(--signal)}

/* ---------- Impressum ---------- */
.section--impressum{border-top:1px solid var(--mist-200)}
.impressum{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem 2.5rem;font-size:.95rem}
.impressum__block--wide{grid-column:1/-1}
.impressum h3{font-family:var(--font-display);font-size:1rem;color:var(--ink);margin-bottom:.5rem;font-weight:700}
.impressum p{color:var(--slate-600);line-height:1.7}
.impressum a{color:var(--slate-800);border-bottom:1px solid var(--mist-300)}
.impressum a:hover{color:var(--signal-700)}

/* ---------- Footer ---------- */
.site-footer{background:var(--slate-950);color:var(--mist-300);padding-block:2.6rem}
.footer__inner{display:flex;flex-wrap:wrap;gap:1.4rem 2.5rem;align-items:center;justify-content:space-between}
.footer__brand .brand__mark{font-family:var(--font-brand);color:var(--white);font-size:1.4rem}
.footer__tag{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;color:var(--slate-400);margin-top:.35rem}
.footer__nav{display:flex;flex-wrap:wrap;gap:.4rem 1.3rem}
.footer__nav a{color:var(--mist-300);font-size:.92rem;transition:color .2s}
.footer__nav a:hover{color:var(--signal)}
.footer__copy{width:100%;font-family:var(--font-mono);font-size:.76rem;color:var(--slate-500);border-top:1px solid rgba(255,255,255,.08);padding-top:1.3rem;margin-top:.3rem}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;
  background:rgba(10,15,20,.94);padding:clamp(1rem,4vw,3rem);opacity:0;transition:opacity .25s}
.lightbox[data-open]{opacity:1}
.lightbox__figure{margin:0;max-width:min(1100px,92vw);max-height:88vh;display:flex;flex-direction:column;gap:.8rem}
.lightbox__figure img{max-width:100%;max-height:82vh;object-fit:contain;border-radius:var(--r-sm);
  transform:scale(.96);transition:transform .3s var(--ease)}
.lightbox[data-open] .lightbox__figure img{transform:none}
.lightbox__close{position:absolute;top:1rem;right:1rem;width:48px;height:48px;color:#fff;border-radius:50%;background:rgba(255,255,255,.08)}
.lightbox__close svg{width:26px;height:26px;margin:auto}
.lightbox__close:hover{background:rgba(255,255,255,.18)}
.lightbox__nav{position:absolute;top:50%;translate:0 -50%;width:52px;height:52px;display:grid;place-items:center;
  color:#fff;background:rgba(255,255,255,.08);border-radius:50%;transition:background-color .2s}
.lightbox__nav:hover{background:rgba(255,255,255,.2)}
.lightbox__nav svg{width:28px;height:28px}
.lightbox__nav--prev{left:clamp(.5rem,2vw,1.5rem);rotate:90deg}
.lightbox__nav--next{right:clamp(.5rem,2vw,1.5rem);rotate:-90deg}

/* ---------- Scroll-Reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}
.service-card[data-reveal],.gallery__item[data-reveal]{transition-delay:calc(var(--i,0)*60ms)}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:760px){
  .nav,.header__call{display:none}
  .nav-toggle{display:flex}
  .site-header.is-open .nav-toggle__open{display:none}
  .site-header.is-open .nav-toggle__close{display:block}
  .meister{grid-template-columns:1fr;justify-items:start}
  .impressum{grid-template-columns:1fr}
  .callout{flex-direction:column;align-items:flex-start}
}
@media (max-width:520px){
  .service-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr);gap:.6rem}
  .hero__actions .btn{flex:1 1 100%;justify-content:center}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  [data-reveal]{opacity:1;transform:none}
  .hero__scroll{animation:none}
}
