/*
Theme Name: Eberth
Theme URI: https://eberth.codlab.de
Author: CodLab — codlab.de
Description: Editorial premium theme for Malermeisterbetrieb Eberth, Regensburg. Terracotta + cream + ink editorial palette, Castle of Avenue display serif + Helvena Grotesk body + Intermezo signature.
Version: 1.0.1
Text Domain: eberth
*/

/* ============================================================
   01 · FONTS
   ============================================================ */
@font-face{
  font-family:'CastleOfAvenue';
  src:url('assets/fonts/CastleOfAvenue-Regular.woff2') format('woff2');
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'CastleOfAvenue';
  src:url('assets/fonts/CastleOfAvenue-Italic.woff2') format('woff2');
  font-weight:400;font-style:italic;font-display:swap;
}
@font-face{
  font-family:'CastleOfAvenue';
  src:url('assets/fonts/CastleOfAvenue-Bold.woff2') format('woff2');
  font-weight:700;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Intermezo';
  src:url('assets/fonts/Intermezo.woff2') format('woff2');
  font-weight:400;font-style:normal;font-display:swap;
}

/* ============================================================
   02 · DESIGN TOKENS
   ============================================================ */
:root{
  /* Palette */
  --clay-deep:#8E3B23;
  --clay:#B85A3E;
  --clay-soft:#D88A6E;
  --cream:#EFE5D3;
  --cream-2:#F6EFE0;
  --cream-page:#FAF6EC;
  --ink:#1C1916;
  --ink-soft:#3A332E;
  --stone:#8A8278;
  --stone-line:#D8D0C2;
  --brass:#B89968;
  --paper:#FDFBF5;
  --white:#FFFFFF;

  /* Type */
  --serif:'CastleOfAvenue', 'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --script:'Intermezo', cursive;
  --mono:ui-monospace, 'SF Mono', Menlo, monospace;

  /* Spacing scale */
  --s1:.5rem;--s2:1rem;--s3:1.5rem;--s4:2rem;--s5:3rem;--s6:4rem;--s7:6rem;--s8:8rem;

  /* Other */
  --maxw:1320px;
  --maxw-narrow:920px;
  --maxw-prose:680px;
  --r-sm:6px;--r-md:14px;--r-lg:24px;--r-pill:9999px;
  --tx-fast:.18s cubic-bezier(.4,0,.2,1);
  --tx:.32s cubic-bezier(.4,0,.2,1);
  --tx-slow:.7s cubic-bezier(.16,1,.3,1);
}

/* ============================================================
   03 · BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream-page);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video{max-width:100%;display:block}
a{color:var(--ink);text-decoration:none;transition:color var(--tx-fast)}
a:hover{color:var(--clay)}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
ul,ol{padding-left:1.2em}
hr{border:0;border-top:1px solid var(--stone-line);margin:var(--s5) 0}
::selection{background:var(--clay);color:var(--cream-2)}

/* Subtle film grain (anti-AI feel) */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 .1 0 0 0 0 .1 0 0 0 0 .1 0 0 0 .9 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
}
@media (prefers-reduced-motion: reduce){
  body::after{display:none}
  html{scroll-behavior:auto}
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
}

/* ============================================================
   04 · TYPOGRAPHY
   ============================================================ */
.eyebrow{
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--clay);
  font-weight:600;
}
h1,h2,h3,h4,.h1,.h2,.h3{
  font-family:var(--serif);
  font-weight:400;
  color:var(--ink);
  letter-spacing:-.01em;
  margin:0 0 .6em;
  line-height:1.08;
}
h1,.h1{font-size:clamp(2.6rem,6.5vw,5.4rem);line-height:1.02;font-weight:400}
h2,.h2{font-size:clamp(2rem,4.5vw,3.6rem);line-height:1.06}
h3,.h3{font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.18}
h4{font-size:1.18rem;font-family:var(--sans);font-weight:600;letter-spacing:.02em;text-transform:uppercase}
.script{font-family:var(--script);font-style:normal;color:var(--clay-deep);font-weight:400}
.italic{font-style:italic}
p{margin:0 0 1.1em}
.lead{font-size:1.18rem;line-height:1.55;color:var(--ink-soft)}
.measure{max-width:var(--maxw-prose)}
.eberth-hr{
  width:64px;height:1px;background:var(--clay);margin:var(--s3) 0;
}

/* ============================================================
   05 · LAYOUT
   ============================================================ */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem)}
.wrap-narrow{max-width:var(--maxw-narrow)}
.section{padding:clamp(4rem,9vw,7rem) 0;position:relative;z-index:2}
.section-tight{padding:clamp(2.5rem,5vw,4rem) 0}
.on-cream{background:var(--cream)}
.on-paper{background:var(--paper)}
.on-ink{background:var(--ink);color:var(--cream-2)}
.on-ink h1,.on-ink h2,.on-ink h3{color:var(--cream-2)}
.on-ink .eyebrow{color:var(--clay-soft)}
.on-ink .eberth-hr{background:var(--clay-soft)}

/* ============================================================
   06 · BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  padding:.85em 1.6em;
  font-family:var(--sans);font-size:.92rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  border-radius:var(--r-pill);
  transition:all var(--tx);cursor:pointer;text-decoration:none;
  border:1px solid transparent;
}
.btn--clay{background:var(--clay-deep);color:var(--cream-2)}
.btn--clay:hover{background:var(--ink);color:var(--cream-2);transform:translateY(-1px);box-shadow:0 8px 24px -8px rgba(28,25,22,.4)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--cream-2)}
.btn--ghost-light{background:transparent;color:var(--cream-2);border-color:var(--cream-2)}
.btn--ghost-light:hover{background:var(--cream-2);color:var(--ink)}
.btn .arr{display:inline-block;transition:transform var(--tx)}
.btn:hover .arr{transform:translateX(4px)}

/* ============================================================
   07 · HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:1.2rem clamp(1.2rem,4vw,2.4rem);
  background:rgba(250,246,236,.78);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:all var(--tx);
}
.site-header.is-scrolled{
  background:rgba(250,246,236,.94);
  border-bottom-color:var(--stone-line);
  padding-top:.85rem;padding-bottom:.85rem;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  max-width:var(--maxw);margin:0 auto;
}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--ink)}
.brand-logo{width:36px;height:36px;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--serif);font-size:1.45rem;letter-spacing:.04em;font-weight:700}
.brand-tag{font-family:var(--sans);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--stone);margin-top:3px}
.primary-nav{display:flex;gap:2rem;align-items:center}
.primary-nav a{
  font-family:var(--sans);font-size:.92rem;font-weight:500;
  letter-spacing:.02em;color:var(--ink);position:relative;padding:.3em 0;
}
.primary-nav a::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:1px;
  background:var(--clay);transform:scaleX(0);transform-origin:left;
  transition:transform var(--tx);
}
.primary-nav a:hover::after,.primary-nav a.is-active::after{transform:scaleX(1)}
.header-cta{display:flex;align-items:center;gap:.8rem}
.phone-link{
  display:inline-flex;align-items:center;gap:.4rem;color:var(--ink);font-weight:500;
  font-size:.92rem;
}
.phone-link svg{width:14px;height:14px;color:var(--clay)}

.burger{display:none;width:44px;height:44px;align-items:center;justify-content:center;color:var(--ink)}
.burger span{display:block;width:22px;height:2px;background:currentColor;position:relative;transition:transform var(--tx)}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:100%;height:2px;background:currentColor;transition:transform var(--tx)}
.burger span::before{top:-7px}
.burger span::after{top:7px}
.is-mobile-open .burger span{background:transparent}
.is-mobile-open .burger span::before{top:0;transform:rotate(45deg)}
.is-mobile-open .burger span::after{top:0;transform:rotate(-45deg)}

@media (max-width:980px){
  .primary-nav,.header-cta .phone-link{display:none}
  .burger{display:inline-flex}
}
@media (max-width:720px){
  .header-cta > .btn{display:none}
}

.mobile-drawer{
  position:fixed;inset:0;background:var(--ink);color:var(--cream-2);z-index:49;
  padding:6rem 2rem 2rem;display:flex;flex-direction:column;gap:1rem;
  transform:translateX(100%);transition:transform var(--tx);overflow-y:auto;
}
.is-mobile-open .mobile-drawer{transform:translateX(0)}
.mobile-drawer a{
  font-family:var(--serif);font-size:2rem;color:var(--cream-2);
  padding:.4em 0;border-bottom:1px solid rgba(255,255,255,.08);
}
.mobile-drawer .phone-link{color:var(--clay-soft);margin-top:1.5rem;font-size:1.1rem}

/* spacing under fixed header */
.site-main{padding-top:84px}

/* ============================================================
   08 · HERO
   ============================================================ */
.hero{
  min-height:min(92vh, 880px);
  display:flex;align-items:flex-end;
  position:relative;overflow:hidden;
  background:var(--ink);color:var(--cream-2);
  padding:clamp(5rem,12vw,8rem) 0 clamp(3rem,6vw,5rem);
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(28,25,22,.35) 0%, rgba(28,25,22,.6) 60%, rgba(28,25,22,.85) 100%);
}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-eyebrow{color:var(--clay-soft);margin-bottom:1.2rem}
.hero h1{
  color:var(--cream-2);max-width:18ch;
  font-size:clamp(2.8rem,7vw,6rem);font-weight:400;line-height:1;
}
.hero h1 .accent{color:var(--clay-soft);font-style:italic}
.hero-sub{
  font-size:clamp(1.05rem,1.6vw,1.3rem);
  color:rgba(239,229,211,.78);
  max-width:48ch;margin:1.5rem 0 2rem;line-height:1.45;
}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.hero-meta{
  position:absolute;top:clamp(5rem,10vw,7rem);right:clamp(1.2rem,4vw,2.4rem);z-index:3;
  font-family:var(--mono);font-size:.78rem;color:var(--cream-2);opacity:.62;
  letter-spacing:.05em;
  display:flex;align-items:center;gap:.6em;
}
.hero-meta::before{content:"";display:block;width:8px;height:8px;border-radius:50%;background:var(--clay-soft);box-shadow:0 0 0 4px rgba(216,138,110,.18)}

/* ============================================================
   09 · STAT STRIP
   ============================================================ */
.stat-strip{
  background:var(--ink);color:var(--cream-2);padding:clamp(2rem,4vw,3rem) 0;
  position:relative;z-index:3;border-top:1px solid rgba(216,138,110,.12);
}
.stat-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem);
}
.stat{display:flex;flex-direction:column;gap:.3rem}
.stat-num{
  font-family:var(--serif);font-size:clamp(2.4rem,4.5vw,3.6rem);
  line-height:1;color:var(--cream-2);font-weight:400;
}
.stat-num.accent{color:var(--clay-soft);font-style:italic}
.stat-label{
  font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:rgba(239,229,211,.55);
}
@media (max-width:780px){
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:1.4rem}
  .stat-num{font-size:2.2rem}
}

/* ============================================================
   10 · MANIFESTO
   ============================================================ */
.manifesto{
  background:var(--cream-page);padding:clamp(5rem,10vw,8rem) 0;
}
.manifesto-grid{
  display:grid;grid-template-columns:1fr 1.6fr;gap:clamp(2rem,6vw,5rem);
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem);
  align-items:start;
}
.manifesto-eyebrow-col{position:sticky;top:120px}
.manifesto-text{font-size:clamp(1.3rem,2vw,1.6rem);line-height:1.45;color:var(--ink);font-family:var(--serif);font-weight:400}
.manifesto-text strong{color:var(--clay-deep);font-weight:400;font-style:italic}
.manifesto-sign{
  font-family:var(--script);font-size:2rem;color:var(--clay-deep);
  margin-top:1.5rem;line-height:1;
}
.manifesto-sign-sub{font-family:var(--sans);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--stone);margin-top:.5rem}
@media (max-width:840px){
  .manifesto-grid{grid-template-columns:1fr;gap:2rem}
  .manifesto-eyebrow-col{position:static}
}

/* ============================================================
   11 · LEISTUNGEN BENTO
   ============================================================ */
.leistungen{background:var(--cream);padding:clamp(5rem,9vw,7rem) 0}
.section-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:2rem;margin-bottom:clamp(2.5rem,5vw,4rem);flex-wrap:wrap;
}
.section-head h2{margin:0;max-width:18ch}
.section-head .head-right{max-width:42ch;color:var(--ink-soft)}

.bento{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:1.2rem;
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem);
}
.bento-card{
  position:relative;overflow:hidden;border-radius:var(--r-md);
  background:var(--paper);
  transition:transform var(--tx-slow);
  min-height:280px;
  display:flex;flex-direction:column;justify-content:flex-end;
}
.bento-card:hover{transform:translateY(-4px)}
.bento-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform var(--tx-slow);
}
.bento-card:hover img{transform:scale(1.04)}
.bento-card-overlay{
  position:relative;z-index:2;padding:1.5rem 1.8rem;
  background:linear-gradient(180deg, transparent 0%, rgba(28,25,22,.85) 80%);
  color:var(--cream-2);min-height:50%;display:flex;flex-direction:column;justify-content:flex-end;
}
.bento-card h3{color:var(--cream-2);margin:0 0 .3em}
.bento-card p{color:rgba(239,229,211,.82);margin:0;font-size:.94rem}
.bento-card .arr-link{
  margin-top:.8rem;font-family:var(--sans);font-size:.82rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--clay-soft);
}

.bento-card--feature{grid-column:span 1;grid-row:span 2;min-height:580px}
.bento-card--tall{grid-row:span 2;min-height:580px}
.bento-card--wide{grid-column:span 2}

@media (max-width:880px){
  .bento{grid-template-columns:1fr 1fr}
  .bento-card--feature{grid-column:1/-1;grid-row:auto;min-height:380px}
  .bento-card--tall{grid-row:auto;min-height:380px}
  .bento-card--wide{grid-column:1/-1}
}
@media (max-width:540px){
  .bento{grid-template-columns:1fr}
  .bento-card{min-height:320px}
}

/* ============================================================
   12 · PROCESS TIMELINE
   ============================================================ */
.process{background:var(--cream-page);padding:clamp(5rem,9vw,7rem) 0;position:relative}
.process-list{
  max-width:var(--maxw-narrow);margin:3rem auto 0;padding:0 clamp(1.2rem,4vw,2.4rem);
  position:relative;
}
.process-list::before{
  content:"";position:absolute;left:30px;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg, var(--clay) 0%, var(--clay) 80%, transparent 100%);
}
.process-step{
  display:grid;grid-template-columns:60px 1fr;gap:1.5rem;
  padding:1.5rem 0 2rem;position:relative;
}
.process-step::before{
  content:"";position:absolute;left:26px;top:1.5rem;width:9px;height:9px;border-radius:50%;
  background:var(--clay);box-shadow:0 0 0 5px var(--cream-page),0 0 0 6px var(--clay);
}
.process-num{
  font-family:var(--serif);font-size:1.6rem;color:var(--clay-deep);font-weight:400;
  padding-left:50px;font-style:italic;
}
.process-step h3{margin:0 0 .4em;font-size:1.4rem}
.process-step p{margin:0;color:var(--ink-soft)}
.process-meta{
  font-family:var(--mono);font-size:.78rem;color:var(--stone);
  margin-top:.6rem;letter-spacing:.04em;
}

/* ============================================================
   13 · OWNER SECTION
   ============================================================ */
.owner{background:var(--ink);color:var(--cream-2);padding:clamp(5rem,9vw,7rem) 0;overflow:hidden}
.owner-grid{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,6vw,5rem);
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem);
  align-items:center;
}
.owner-image{position:relative;aspect-ratio:3/4;background:var(--ink-soft);border-radius:var(--r-md);overflow:hidden}
.owner-image img{width:100%;height:100%;object-fit:cover}
.owner-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(28,25,22,.45) 100%);
}
.owner-content h2{color:var(--cream-2);margin-bottom:.6em}
.owner-content h2 .script{color:var(--clay-soft);display:block;font-size:.66em;margin-top:.2em}
.owner-content p{color:rgba(239,229,211,.82);font-size:1.1rem;line-height:1.55}
.owner-quote{
  font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,2vw,1.4rem);
  color:var(--cream-2);padding:1.5rem 0;border-top:1px solid rgba(216,138,110,.22);
  margin-top:2rem;
}
.owner-sig{font-family:var(--script);font-size:2.2rem;color:var(--clay-soft);margin-top:1rem;line-height:1}
.owner-sig-sub{font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(239,229,211,.5);margin-top:.4em}
@media (max-width:840px){
  .owner-grid{grid-template-columns:1fr;gap:2rem}
  .owner-image{max-width:340px}
}

/* ============================================================
   14 · GALERIE
   ============================================================ */
.galerie{padding:clamp(5rem,9vw,7rem) 0;background:var(--cream)}
.galerie-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:1rem;
  max-width:var(--maxw);margin:3rem auto 0;padding:0 clamp(1.2rem,4vw,2.4rem);
}
.galerie-item{position:relative;overflow:hidden;border-radius:var(--r-sm);background:var(--paper)}
.galerie-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--tx-slow);aspect-ratio:4/3}
.galerie-item:hover img{transform:scale(1.05)}
.galerie-item--lg{grid-column:span 7}
.galerie-item--md{grid-column:span 5}
.galerie-item--sm{grid-column:span 4}
.galerie-cap{
  position:absolute;left:1rem;bottom:1rem;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--cream-2);background:rgba(28,25,22,.65);padding:.4rem .8rem;border-radius:var(--r-pill);
  backdrop-filter:blur(8px);
}
@media (max-width:780px){
  .galerie-item--lg,.galerie-item--md,.galerie-item--sm{grid-column:span 12}
}

/* ============================================================
   15 · KONTAKT
   ============================================================ */
.kontakt{background:var(--cream-page);padding:clamp(5rem,9vw,7rem) 0}
.kontakt-grid{
  display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(2rem,6vw,5rem);
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem);
}
.kontakt-info dl{margin:0}
.kontakt-info dt{
  font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--stone);margin-top:1.4rem;
}
.kontakt-info dt:first-child{margin-top:0}
.kontakt-info dd{
  margin:.3rem 0 0;font-family:var(--serif);font-size:1.3rem;color:var(--ink);
}
.kontakt-info dd a{color:var(--ink)}
.kontakt-info dd a:hover{color:var(--clay-deep)}

.kontakt-form{
  background:var(--paper);padding:clamp(1.8rem,4vw,3rem);
  border-radius:var(--r-md);border:1px solid var(--stone-line);
}
.field{margin-bottom:1.2rem}
.field label{
  display:block;font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--stone);margin-bottom:.5rem;
}
.field input,.field textarea{
  width:100%;padding:.85rem 1rem;border:1px solid var(--stone-line);
  border-radius:var(--r-sm);background:var(--white);font:inherit;color:var(--ink);
  transition:border-color var(--tx-fast);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--clay)}
.field textarea{min-height:140px;resize:vertical;font-family:var(--sans)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:540px){.field-row{grid-template-columns:1fr}}
.consent{
  display:flex;align-items:flex-start;gap:.6rem;font-size:.84rem;color:var(--ink-soft);
  line-height:1.4;margin:1rem 0;
}
.consent input{margin-top:.25em}
.kontakt-feedback{
  padding:.9rem 1rem;border-radius:var(--r-sm);font-size:.92rem;margin-bottom:1rem;
}
.kontakt-feedback.ok{background:#e8f3e9;color:#1c5a26}
.kontakt-feedback.err{background:#fae7e7;color:#8e1c1c}

@media (max-width:840px){
  .kontakt-grid{grid-template-columns:1fr;gap:2.5rem}
}

/* ============================================================
   16 · FOOTER
   ============================================================ */
.site-footer{
  background:var(--ink);color:var(--cream-2);padding:clamp(4rem,7vw,5rem) 0 0;
  border-top:1px solid rgba(216,138,110,.12);
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem) 3rem;
}
.footer-brand .brand-name{color:var(--cream-2)}
.footer-brand p{color:rgba(239,229,211,.62);margin-top:1rem;max-width:32ch}
.footer-col h4{
  color:var(--cream-2);font-family:var(--sans);font-size:.74rem;
  letter-spacing:.18em;text-transform:uppercase;margin:0 0 1rem;
}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:.55rem}
.footer-col a{color:rgba(239,229,211,.74);font-size:.94rem}
.footer-col a:hover{color:var(--clay-soft)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:1.5rem 0;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  max-width:var(--maxw);margin:0 auto;padding-left:clamp(1.2rem,4vw,2.4rem);padding-right:clamp(1.2rem,4vw,2.4rem);
  font-size:.82rem;color:rgba(239,229,211,.52);
}
.codlab-glass-badge{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.5rem 1rem;
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:9999px;
  text-decoration:none;
  transition:all var(--tx);
}
.codlab-glass-badge:hover{
  background:rgba(255,255,255,.08);
  border-color:rgba(184,90,62,.3);
  transform:translateY(-1px);
}
.codlab-logo{width:88px;height:auto}
@media (max-width:780px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){
  .footer-grid{grid-template-columns:1fr}
}

/* ============================================================
   17 · REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity var(--tx-slow), transform var(--tx-slow)}
.reveal.is-in{opacity:1;transform:translateY(0)}
.reveal-2{transition-delay:.1s}
.reveal-3{transition-delay:.2s}
.reveal-4{transition-delay:.3s}

/* ============================================================
   18 · PAGE HERO (sub-pages)
   ============================================================ */
.page-hero{
  padding:clamp(7rem,12vw,10rem) 0 clamp(3rem,5vw,4rem);
  background:var(--cream);
  border-bottom:1px solid var(--stone-line);
  text-align:center;
}
.page-hero .eyebrow{margin-bottom:1.2rem}
.page-hero h1{font-size:clamp(2.4rem,5vw,4.4rem);margin-bottom:.5rem;max-width:24ch;margin-left:auto;margin-right:auto}
.page-hero .lead{margin:1.2rem auto 0;max-width:48ch}

/* ============================================================
   19 · LEISTUNGEN LIST PAGE
   ============================================================ */
.lst-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;
  max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.4rem);
}
.lst-card{
  background:var(--paper);padding:2.5rem;border-radius:var(--r-md);
  display:flex;flex-direction:column;gap:1rem;
  border:1px solid var(--stone-line);
  transition:all var(--tx);
}
.lst-card:hover{border-color:var(--clay);transform:translateY(-2px)}
.lst-card .num{
  font-family:var(--serif);font-size:1.6rem;color:var(--clay-deep);font-style:italic;
}
.lst-card h3{margin:0;font-size:1.6rem}
.lst-card p{margin:0;color:var(--ink-soft)}
.lst-card ul{margin:.5rem 0 0;padding:0;list-style:none}
.lst-card li{padding:.4rem 0;border-top:1px solid var(--stone-line);color:var(--ink-soft);font-size:.94rem;display:flex;align-items:center;gap:.5em}
.lst-card li::before{content:"·";color:var(--clay);font-weight:700;font-size:1.4em}
@media (max-width:780px){.lst-grid{grid-template-columns:1fr}}

/* ============================================================
   20 · UTILITIES
   ============================================================ */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mt-2{margin-top:var(--s2)}
.mt-4{margin-top:var(--s4)}
.mb-0{margin-bottom:0}
.flex{display:flex}
.gap-2{gap:var(--s2)}
.gap-4{gap:var(--s4)}

/* hidden but accessible */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
