/* ============================================================
   A&S Bau Hamburg GmbH — "Editorial Ingenieur"
   Warm paper · deep ink · Fraunces serif · hairlines ·
   restrained brand blue · terracotta accent · annual-report figures.
   ============================================================ */

/* ---------- 1. Tokens ---------- */
:root {
  --bg:#F4F1EA; --surface:#FBFAF6; --surface-alt:#EFEAE1;
  --ink:#16212E; --ink-soft:#3A4654; --muted:#555E6A;
  --line:#D8D2C4; --line-soft:#E6E1D5;
  --brand:#0F4C8C; --brand-strong:#0B3A6B; --brand-soft:#E4ECF4;
  --accent:#B06A38; --accent-on-dark:#C8814A;
  --dark:#102330; --on-dark:#EDEAE1; --on-dark-soft:#9AA6B2; --on-dark-line:rgba(237,234,225,.14);

  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Inter Tight',system-ui,-apple-system,sans-serif;

  --r-sm:4px; --r-md:8px;
  --hair:1px solid var(--line);
  --shadow-card:0 1px 0 var(--line);

  --section-y:clamp(5rem,9vw,9rem);
  --container:1120px; --container-wide:1280px; --measure:64ch;
  --gutter:clamp(1.2rem,5vw,2.5rem);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- 2. Reset & base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

body{
  background:var(--bg); color:var(--ink-soft);
  font-family:var(--font-body); font-size:1.0625rem; line-height:1.7;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:400; color:var(--ink); letter-spacing:-.015em; line-height:1.06; font-optical-sizing:auto; }
h1{ font-size:clamp(2.7rem,6vw,5rem); line-height:1.02; }
h2{ font-size:clamp(2.1rem,4.2vw,3.4rem); line-height:1.08; }
h3{ font-size:clamp(1.3rem,1.9vw,1.7rem); font-weight:500; line-height:1.15; letter-spacing:-.01em; }
p{ color:var(--ink-soft); }
a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
ul{ list-style:none; padding:0; }
button{ font:inherit; cursor:pointer; color:inherit; }
strong{ color:var(--ink); font-weight:600; }
:focus-visible{ outline:2px solid var(--brand); outline-offset:3px; border-radius:2px; }
::selection{ background:var(--brand); color:#fff; }

/* annual-report figures */
.num,.pc-num,.hero-stats .n,.ring,.service-num,.machine-list b,
.topbar a,.c-value,.footer-contact a,.j-meta,.pc-figure{ font-variant-numeric:tabular-nums; }

/* ---------- 3. Layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.container--wide{ max-width:var(--container-wide); }
.section{ padding-block:var(--section-y); position:relative; border-top:var(--hair); }
.section:first-of-type{ border-top:0; }
.section--tint{ background:var(--surface-alt); }
.section--anchor{ background:var(--dark); color:var(--on-dark); border-top-color:transparent; }

/* eyebrow as a survey tick */
.eyebrow{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--font-body); font-weight:600; font-size:.72rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--muted);
}
.eyebrow::before{ content:""; width:26px; height:2px; border-radius:1px; background:var(--accent); }
.eyebrow--center{ justify-content:center; }

.section-head{ max-width:760px; }
.section-head--center{ margin-inline:auto; text-align:center; }
.section-head h2{ margin-top:1.1rem; }
.section-head .lead{ margin-top:1.3rem; }

.lead{ font-size:clamp(1.18rem,1.6vw,1.5rem); font-weight:400; line-height:1.5; color:var(--ink-soft); max-width:62ch; }

/* ---------- 4. Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  padding:.95rem 1.6rem; border-radius:var(--r-sm);
  font-family:var(--font-body); font-weight:600; font-size:.97rem; letter-spacing:.005em;
  border:1px solid transparent; white-space:nowrap;
  transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.btn svg{ width:1.05em; height:1.05em; }
.btn--primary,.btn--light{ background:var(--brand); color:#fff; }
.btn--primary:hover,.btn--light:hover{ background:var(--brand-strong); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--bg); }
.btn--ondark{ background:transparent; color:var(--on-dark); border-color:var(--on-dark-soft); }
.btn--ondark:hover{ background:var(--on-dark); color:var(--dark); border-color:var(--on-dark); }
.btn--lg{ padding:1.08rem 2rem; font-size:1.02rem; }
.btn .arrow{ transition:transform .3s var(--ease); }
.btn:hover .arrow{ transform:translateX(3px); }

.textlink{ display:inline-flex; align-items:center; gap:.5rem; font-weight:600; color:var(--brand); border-bottom:1px solid transparent; transition:border-color .2s; }
.textlink:hover{ border-bottom-color:var(--brand); }
.textlink .arrow{ transition:transform .3s var(--ease); }
.textlink:hover .arrow{ transform:translateX(3px); }

/* ---------- 5. Top bar ---------- */
.topbar{ background:var(--dark); color:var(--on-dark-soft); font-size:.8rem; }
.topbar .container{ display:flex; align-items:center; justify-content:space-between; min-height:42px; gap:1rem; }
.topbar a{ color:var(--on-dark-soft); transition:color .2s; }
.topbar a:hover{ color:var(--on-dark); }
.topbar-left{ display:flex; gap:1.8rem; align-items:center; flex-wrap:wrap; }
.topbar-left span{ display:inline-flex; align-items:center; gap:.5rem; font-variant:small-caps; letter-spacing:.04em; }
.topbar-left svg{ width:14px; height:14px; opacity:.7; }
.topbar-right{ display:inline-flex; align-items:center; gap:.5rem; font-weight:600; color:var(--on-dark); font-variant:small-caps; letter-spacing:.05em; }
@media (max-width:760px){ .topbar-left span:nth-child(n+2){ display:none; } }

/* ---------- 6. Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:transparent; backdrop-filter:none;
  border-bottom:1px solid transparent;
  transition:background .3s var(--ease), border-color .3s;
}
.site-header.scrolled{ background:var(--surface); border-bottom:var(--hair); }
.nav{ display:flex; align-items:center; justify-content:space-between; min-height:80px; gap:1.5rem; }

.brand{ display:inline-flex; align-items:center; gap:.7rem; }
.brand-mark{ height:46px; width:auto; flex:none; display:block; }
.brand-wordmark{ height:29px; width:auto; flex:none; display:block; }

.nav-links{ display:flex; align-items:center; gap:.2rem; }
.nav-links a{
  position:relative; padding:.55rem .72rem; white-space:nowrap;
  font-weight:500; font-size:.95rem; color:var(--ink-soft);
  transition:color .2s;
}
.nav-links a::after{ content:""; position:absolute; left:.8rem; right:.8rem; bottom:.42rem; height:1px; background:var(--brand); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease); }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after,.nav-links a.active::after{ transform:scaleX(1); }
.nav-cta{ display:flex; align-items:center; gap:.6rem; }

.nav-toggle{ display:none; width:46px; height:46px; border-radius:var(--r-sm); border:var(--hair); background:var(--surface); align-items:center; justify-content:center; }
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{ content:""; display:block; width:20px; height:1.5px; background:var(--ink); border-radius:2px; transition:transform .3s var(--ease), opacity .2s; }
.nav-toggle span::before{ transform:translateY(-6px); } .nav-toggle span::after{ transform:translateY(4.5px); }
body.menu-open .nav-toggle span{ background:transparent; }
body.menu-open .nav-toggle span::before{ transform:translateY(0) rotate(45deg); }
body.menu-open .nav-toggle span::after{ transform:translateY(-1.5px) rotate(-45deg); }

@media (max-width:1140px){
  .nav-toggle{ display:inline-flex; }
  .nav-links{
    position:fixed; inset:0 0 0 auto; width:min(86vw,360px);
    flex-direction:column; align-items:stretch; gap:.1rem;
    background:var(--surface); padding:6.5rem 1.5rem 2rem; border-left:var(--hair);
    transform:translateX(100%); transition:transform .4s var(--ease-out); z-index:55;
  }
  body.menu-open .nav-links{ transform:translateX(0); }
  .nav-links a{ padding:.95rem 1rem; font-size:1.15rem; border-bottom:var(--hair); }
  .nav-links a::after{ display:none; }
  .nav-cta .btn--ghost{ display:none; }
  .nav-scrim{ position:fixed; inset:0; background:rgba(16,33,46,.4); opacity:0; visibility:hidden; transition:opacity .35s, visibility .35s; z-index:50; }
  body.menu-open .nav-scrim{ opacity:1; visibility:visible; }
}

/* ---------- 7. Hero ---------- */
.hero{ background:var(--bg); color:var(--ink); position:relative; overflow:visible; border-top:0; }
.hero .container{ position:relative; z-index:2; }
.hero-inner{ display:grid; grid-template-columns:1.12fr .88fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; padding-block:clamp(3.5rem,7vw,6.5rem); }

.hero-eyebrow{ display:inline-flex; align-items:center; gap:.7rem; font-size:.72rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); }
.hero-eyebrow::before{ content:""; width:26px; height:2px; border-radius:1px; background:var(--accent); }
.hero h1{ color:var(--ink); margin-top:1.6rem; }
.hero h1 .hl{ color:var(--brand); }
.hero-sub{ margin-top:1.6rem; font-size:clamp(1.12rem,1.5vw,1.4rem); line-height:1.55; color:var(--ink-soft); max-width:40ch; }
.hero-cta{ margin-top:2.2rem; display:flex; flex-wrap:wrap; gap:.9rem; }
.hero-badges{ margin-top:2.6rem; padding-top:1.6rem; border-top:var(--hair); display:flex; flex-wrap:wrap; gap:1rem 2rem; }
.hero-badge{ display:inline-flex; align-items:center; gap:.55rem; font-size:.86rem; color:var(--ink-soft); font-variant:small-caps; letter-spacing:.05em; }
.hero-badge svg{ width:17px; height:17px; color:var(--accent); flex:none; }

/* hero index table (right column) */
.hero-panel{ position:relative; }
.hero-card{ background:var(--surface); border:var(--hair); border-radius:var(--r-md); padding:1.9rem; box-shadow:none; }
.hero-card-title{ font-family:var(--font-body); font-weight:600; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); display:flex; align-items:center; gap:.6rem; }
.hero-card-title::before{ content:""; width:26px; height:2px; border-radius:1px; background:var(--accent); }
.hero-layers{ margin-top:.4rem; }
.hero-layer{ display:flex; align-items:baseline; gap:1rem; padding:1.05rem 0; border-top:var(--hair); }
.hero-layer:first-child{ border-top:0; }
.hero-layer .ix{ font-family:var(--font-display); font-weight:500; font-size:1.05rem; color:var(--accent); flex:none; width:1.8rem; }
.hero-layer b{ font-family:var(--font-display); font-weight:500; font-size:1.18rem; color:var(--ink); display:block; letter-spacing:-.01em; }
.hero-layer span{ font-size:.85rem; color:var(--muted); }
.hero-layer .ic{ display:none; }

@media (max-width:980px){ .hero-inner{ grid-template-columns:1fr; gap:2.5rem; } .hero-panel{ max-width:480px; } }
@media (max-width:480px){ .hero-cta{ flex-direction:column; align-items:stretch; } .hero-cta .btn{ width:100%; } }

/* ---------- 8. Trust ---------- */
.trust{ background:var(--bg); }
.trust .container{ padding-block:2.6rem; }
.trust-intro{ text-align:center; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.trust-row{ margin-top:1.4rem; display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:.7rem .8rem; }
.trust-chip{ display:inline-flex; align-items:center; gap:.55rem; padding:.6rem 1rem; border:var(--hair); border-radius:var(--r-sm); color:var(--ink-soft); font-weight:500; font-size:.9rem; background:transparent; transition:border-color .25s, color .25s; }
.trust-chip:hover{ border-color:var(--ink); color:var(--ink); }
.trust-chip svg{ width:17px; height:17px; color:var(--brand); }

/* ---------- 9. Services ---------- */
.services-grid{ margin-top:clamp(2.4rem,4vw,3.6rem); display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(1rem,2vw,1.5rem); }
.service-card{ position:relative; background:var(--surface); border:var(--hair); border-radius:var(--r-md); padding:2rem; transition:border-color .25s var(--ease); }
.service-card:hover{ border-color:var(--ink); }
.service-num{ font-family:var(--font-display); font-weight:400; font-size:1.4rem; color:var(--accent); letter-spacing:.02em; }
.service-ic{ width:34px; height:34px; display:grid; place-items:center; color:var(--ink); margin:1.1rem 0 1rem; background:none; box-shadow:none; }
.service-ic svg{ width:30px; height:30px; stroke-width:1.4; }
.service-card h3{ font-size:1.4rem; }
.service-card .summary{ margin-top:.7rem; color:var(--ink-soft); font-size:1rem; }
.service-list{ margin-top:1.3rem; display:grid; gap:.6rem; border-top:var(--hair); padding-top:1.3rem; }
.service-list li{ display:flex; gap:.7rem; align-items:flex-start; font-size:.92rem; color:var(--ink-soft); }
.service-list svg{ width:16px; height:16px; color:var(--accent); flex:none; margin-top:.28rem; stroke-width:2; }
@media (max-width:720px){ .services-grid{ grid-template-columns:1fr; } }

/* ---------- 10. Why / features ---------- */
.why-wrap{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.why-aside{ position:sticky; top:110px; }
.why-aside .lead{ margin-top:1.2rem; }
.badge-stack{ margin-top:2rem; display:grid; gap:0; border-top:var(--hair); }
.why-badge{ display:flex; gap:1rem; align-items:baseline; padding:1.1rem 0; border-bottom:var(--hair); }
.why-badge .ic{ width:1.8rem; flex:none; font-family:var(--font-display); color:var(--accent); }
.why-badge .ic svg{ display:none; }
.why-badge b{ display:block; color:var(--ink); font-weight:600; font-size:1rem; }
.why-badge span{ font-size:.88rem; color:var(--muted); }

.features{ display:grid; grid-template-columns:repeat(2,1fr); gap:2.2rem 2.4rem; }
.feature{ border-top:var(--hair); padding-top:1.3rem; }
.feature .f-ic{ width:30px; height:30px; display:grid; place-items:center; color:var(--ink); margin-bottom:1rem; background:none; transition:color .25s; }
.feature:hover .f-ic{ color:var(--brand); }
.feature .f-ic svg{ width:28px; height:28px; stroke-width:1.4; }
.feature h3{ font-size:1.18rem; }
.feature p{ margin-top:.55rem; font-size:.95rem; color:var(--ink-soft); }
@media (max-width:900px){ .why-wrap{ grid-template-columns:1fr; } .why-aside{ position:static; } }
@media (max-width:560px){ .features{ grid-template-columns:1fr; } }

/* ---------- 11. Stat band (light, framed) ---------- */
.statband{ background:var(--bg); }
.statband .container{ border-block:var(--hair); padding-block:clamp(2.4rem,4vw,3.4rem); }
.statband-grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.statband .stat{ padding:.5rem clamp(1rem,2.5vw,2rem); }
.statband .stat + .stat{ border-left:var(--hair); }
.statband .num{ font-family:var(--font-display); font-weight:400; font-size:clamp(2.6rem,5vw,3.8rem); line-height:1; letter-spacing:-.02em; color:var(--ink); }
.statband .num .u{ font-size:.42em; color:var(--accent); margin-left:.15em; font-weight:500; }
.statband .lab{ margin-top:.7rem; color:var(--muted); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; font-weight:600; }
@media (max-width:760px){ .statband-grid{ grid-template-columns:1fr 1fr; gap:2rem 0; } .statband .stat:nth-child(odd){ border-left:0; } .statband .stat:nth-child(n+3){ border-top:var(--hair); padding-top:2rem; } }

/* ---------- 12. Process ---------- */
.process-grid{ margin-top:clamp(2.6rem,4vw,3.8rem); display:grid; grid-template-columns:repeat(5,1fr); gap:1.4rem; counter-reset:step; }
.pstep{ position:relative; padding-top:1.4rem; border-top:1px solid var(--ink); }
.pstep .ring{ font-family:var(--font-display); font-weight:400; font-size:1.5rem; color:var(--accent); }
.pstep h3{ font-size:1.12rem; margin-top:.5rem; }
.pstep p{ margin-top:.5rem; font-size:.9rem; color:var(--ink-soft); }
@media (max-width:900px){ .process-grid{ grid-template-columns:repeat(2,1fr); gap:2rem 1.4rem; } }
@media (max-width:480px){ .process-grid{ grid-template-columns:1fr; } }

/* ---------- 13. Projects ---------- */
.projects-grid{ margin-top:clamp(2.2rem,4vw,3.2rem); display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.project-card{ position:relative; background:var(--surface); border:var(--hair); border-radius:var(--r-md); padding:1.7rem 1.5rem 1.5rem; transition:border-color .25s var(--ease); }
.project-card:hover{ border-color:var(--ink); }
.pc-top{ display:flex; align-items:center; gap:.5rem; }
.pc-top .pc-pin{ width:16px; height:16px; color:var(--accent); flex:none; stroke-width:1.6; }
.pc-top h3{ font-size:1.18rem; }
.pc-figure{ display:flex; align-items:baseline; gap:.3rem; margin-top:1rem; border-top:var(--hair); padding-top:1rem; }
.pc-num{ font-family:var(--font-display); font-weight:400; font-size:2.6rem; line-height:1; color:var(--ink); letter-spacing:-.02em; }
.pc-unit{ font-weight:600; color:var(--accent); font-size:1rem; }
.pc-foot{ margin-top:1rem; display:flex; flex-wrap:wrap; gap:.5rem; }
.pc-chip{ font-size:.76rem; font-weight:600; padding:.32rem .7rem; border-radius:var(--r-sm); border:var(--hair); color:var(--ink-soft); font-variant:small-caps; letter-spacing:.04em; }
.pc-chip--ha{ border-color:var(--accent); color:var(--accent); }
@media (max-width:900px){ .projects-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .projects-grid{ grid-template-columns:1fr; } }

/* ---------- 14. Region ---------- */
.region-wrap{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.region-content .lead{ margin-top:1.2rem; }
.region-areas{ margin-top:1.8rem; display:flex; flex-wrap:wrap; gap:.5rem; }
.region-areas span{ padding:.45rem .85rem; border:var(--hair); border-radius:var(--r-sm); font-size:.86rem; color:var(--ink-soft); background:transparent; font-weight:500; transition:border-color .2s, color .2s; }
.region-areas span:hover{ border-color:var(--ink); color:var(--ink); }
.region-pin{ display:inline-flex; align-items:center; gap:.5rem; margin-top:1.8rem; font-weight:600; color:var(--ink); font-variant:small-caps; letter-spacing:.04em; }
.region-pin svg{ width:18px; height:18px; color:var(--accent); stroke-width:1.6; }
.region-map{ position:relative; border-radius:var(--r-md); overflow:hidden; }
.region-map--de{ background:var(--surface); border:var(--hair); padding:clamp(1rem,2.4vw,1.8rem); }
.region-map--de svg{ width:100%; height:auto; }
@media (max-width:860px){ .region-wrap{ grid-template-columns:1fr; } .region-map{ order:-1; } }

/* ---------- 15. Maschinenpark (the one dark anchor) ---------- */
.section--anchor .eyebrow{ color:var(--on-dark-soft); }
.section--anchor .eyebrow::before{ background:var(--accent-on-dark); }
.section--anchor h2{ color:var(--on-dark); }
.section--anchor .lead{ color:var(--on-dark-soft); }
.machine-grid{ margin-top:clamp(2.4rem,4vw,3.6rem); display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:var(--on-dark-line); }
.machine-card{ padding:1.8rem clamp(1rem,2vw,1.6rem); border-bottom:var(--on-dark-line); border-right:var(--on-dark-line); }
.machine-grid > .machine-card:nth-child(4n){ border-right:0; }
.machine-card .m-ic{ width:28px; height:28px; color:var(--accent-on-dark); margin-bottom:1.1rem; background:none; box-shadow:none; }
.machine-card .m-ic svg{ width:26px; height:26px; stroke-width:1.4; }
.machine-card h3{ color:var(--on-dark); font-size:1.1rem; }
.machine-list{ margin-top:1.1rem; display:grid; gap:0; }
.machine-list li{ display:flex; gap:.7rem; align-items:baseline; font-size:.9rem; color:var(--on-dark-soft); padding:.55rem 0; border-top:var(--on-dark-line); }
.machine-list li:first-child{ border-top:0; }
.machine-list li b{ color:var(--accent-on-dark); font-weight:600; min-width:26px; flex:none; }
@media (max-width:920px){ .machine-grid{ grid-template-columns:1fr 1fr; } .machine-grid > .machine-card:nth-child(2n){ border-right:0; } }
@media (max-width:520px){ .machine-grid{ grid-template-columns:1fr; } .machine-card{ border-right:0; } }

/* ---------- 16. Career ---------- */
.career-wrap{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.career-intro .lead{ margin-top:1.2rem; }
.career-intro p{ margin-top:1rem; }
.job-list{ display:grid; gap:0; border-top:var(--hair); }
.job{ display:flex; align-items:center; gap:1.1rem; padding:1.5rem .3rem; border-bottom:var(--hair); transition:padding-left .25s var(--ease); }
.job:hover{ padding-left:.9rem; }
.job .j-ic{ width:26px; height:26px; color:var(--ink); flex:none; }
.job .j-ic svg{ width:24px; height:24px; stroke-width:1.4; }
.job .j-body{ flex:1; }
.job h3{ font-size:1.12rem; }
.job .j-meta{ display:flex; gap:1rem; flex-wrap:wrap; margin-top:.3rem; font-size:.8rem; color:var(--muted); font-variant:small-caps; letter-spacing:.05em; }
.job .j-type{ color:var(--accent); }
.job .j-arrow{ width:34px; height:34px; border-radius:50%; border:var(--hair); display:grid; place-items:center; color:var(--ink); flex:none; transition:background .25s, color .25s, border-color .25s; }
.job:hover .j-arrow{ background:var(--brand); color:#fff; border-color:var(--brand); }
.job .j-arrow svg{ stroke-width:1.6; }
@media (max-width:860px){ .career-wrap{ grid-template-columns:1fr; } }

/* ---------- 17. FAQ ---------- */
.faq-wrap{ max-width:820px; margin-inline:auto; margin-top:clamp(2rem,4vw,3rem); border-top:var(--hair); }
.faq-item{ border-bottom:var(--hair); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1.5rem .1rem; background:none; border:none; text-align:left; font-family:var(--font-display); font-weight:500; font-size:1.18rem; color:var(--ink); }
.faq-q .pm{ width:26px; height:26px; flex:none; position:relative; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; top:50%; left:50%; width:13px; height:1.5px; background:var(--ink); transform:translate(-50%,-50%); transition:transform .3s var(--ease), background .3s; }
.faq-q .pm::after{ transform:translate(-50%,-50%) rotate(90deg); }
.faq-item.open .faq-q .pm::before,.faq-item.open .faq-q .pm::after{ background:var(--brand); }
.faq-item.open .faq-q .pm::after{ transform:translate(-50%,-50%) rotate(0); }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .4s var(--ease); }
.faq-a-inner{ padding:0 .1rem 1.5rem; color:var(--ink-soft); max-width:64ch; }

/* ---------- 18. Contact ---------- */
.contact-wrap{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.contact-info .lead{ margin-top:1.2rem; }
.contact-cards{ margin-top:2rem; display:grid; gap:0; border-top:var(--hair); }
.contact-card{ display:flex; gap:1rem; align-items:baseline; padding:1.2rem 0; border-bottom:var(--hair); }
.contact-card .c-ic{ width:22px; height:22px; color:var(--accent); flex:none; }
.contact-card .c-ic svg{ width:20px; height:20px; stroke-width:1.5; }
.contact-card .c-label{ font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; color:var(--muted); font-weight:600; }
.contact-card .c-value{ font-weight:500; color:var(--ink); margin-top:.2rem; }
.contact-card .c-value a:hover{ color:var(--brand); }

.form-card{ background:var(--surface); border:var(--hair); border-radius:var(--r-md); padding:clamp(1.6rem,3vw,2.4rem); }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
.field{ margin-top:1.5rem; display:flex; flex-direction:column; }
.field:first-child{ margin-top:0; }
.field label{ font-size:.74rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:.5rem; }
.field label .req{ color:var(--accent); }
.field input,.field select,.field textarea{
  font:inherit; font-size:1rem; padding:.6rem 0; border:0; border-bottom:var(--hair); border-radius:0;
  background:transparent; color:var(--ink); transition:border-color .25s; width:100%;
}
.field textarea{ resize:vertical; min-height:120px; }
.field input::placeholder,.field textarea::placeholder{ color:var(--muted); opacity:.6; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-bottom-color:var(--brand); border-bottom-width:1.5px; }
.field select{ padding-left:0; }
.form-check{ display:flex; gap:.65rem; align-items:flex-start; margin-top:1.6rem; font-size:.85rem; color:var(--muted); }
.form-check input{ margin-top:.15rem; width:17px; height:17px; accent-color:var(--brand); flex:none; }
.form-check a{ color:var(--brand); border-bottom:1px solid var(--line); }
.form-card .btn{ margin-top:1.6rem; width:100%; }
.form-note{ margin-top:1rem; font-size:.8rem; color:var(--muted); text-align:center; }
.form-success{ display:none; padding:.9rem 1.1rem; border-radius:var(--r-sm); border:1px solid var(--brand); color:var(--brand-strong); font-weight:600; font-size:.92rem; margin-top:1rem; }
.form-success.show{ display:block; }
@media (max-width:560px){ .form-row{ grid-template-columns:1fr; gap:0; } }
@media (max-width:860px){ .contact-wrap{ grid-template-columns:1fr; } }

/* ---------- 19. Footer (anchor) ---------- */
.site-footer{ background:var(--dark); color:var(--on-dark-soft); padding-top:clamp(3.5rem,6vw,5rem); }
.footer-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:2.5rem; padding-bottom:3rem; }
.footer-brand .brand-mark{ background:var(--surface); border-radius:var(--r-sm); padding:5px; }
.footer-brand .brand-wordmark{ filter:brightness(0) invert(1); }
.footer-brand p{ margin-top:1.2rem; font-size:.92rem; color:var(--on-dark-soft); max-width:32ch; }
.footer-social{ margin-top:1.5rem; display:flex; gap:.6rem; }
.footer-social a{ width:40px; height:40px; border-radius:50%; border:1px solid var(--on-dark-line); display:grid; place-items:center; color:var(--on-dark-soft); transition:background .25s, color .25s, border-color .25s; }
.footer-social a:hover{ background:var(--on-dark); color:var(--dark); border-color:var(--on-dark); }
.footer-social svg{ width:17px; height:17px; }
.footer-col h4{ font-family:var(--font-body); color:var(--on-dark); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; font-weight:600; margin-bottom:1.2rem; }
.footer-col ul{ display:grid; gap:.7rem; }
.footer-col a{ font-size:.92rem; color:var(--on-dark-soft); transition:color .2s, padding .2s; }
.footer-col a:hover{ color:var(--on-dark); padding-left:3px; }
.footer-contact li{ display:flex; gap:.6rem; font-size:.92rem; color:var(--on-dark-soft); margin-bottom:.8rem; }
.footer-contact svg{ width:16px; height:16px; color:var(--accent-on-dark); flex:none; margin-top:.2rem; stroke-width:1.6; }
.footer-bottom{ border-top:1px solid var(--on-dark-line); padding-block:1.7rem; display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap; font-size:.83rem; color:var(--on-dark-soft); }
.footer-bottom a:hover{ color:var(--on-dark); }
.footer-legal{ display:flex; gap:1.4rem; flex-wrap:wrap; }
@media (max-width:900px){ .footer-top{ grid-template-columns:1fr 1fr; gap:2.5rem; } }
@media (max-width:520px){ .footer-top{ grid-template-columns:1fr; } }

/* ---------- 20. Reveal & motion ---------- */
[data-reveal]{ opacity:0; transform:translateY(12px); transition:opacity .6s var(--ease-out), transform .6s var(--ease-out); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal][data-delay="1"]{ transition-delay:.06s; }
[data-reveal][data-delay="2"]{ transition-delay:.12s; }
[data-reveal][data-delay="3"]{ transition-delay:.18s; }
[data-reveal][data-delay="4"]{ transition-delay:.24s; }
@media (prefers-reduced-motion:reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; transition:none; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

/* ---------- 21. Legal pages ---------- */
.legal-hero{ background:var(--bg); padding-block:clamp(3.5rem,7vw,6rem) clamp(2.5rem,5vw,4rem); border-bottom:var(--hair); }
.legal-hero .eyebrow{ color:var(--muted); }
.legal-hero h1{ color:var(--ink); }
.legal-hero p{ color:var(--ink-soft); margin-top:1rem; }
.legal-body{ max-width:760px; padding-block:clamp(3rem,6vw,5rem); }
.legal-body h2{ font-size:clamp(1.5rem,2.4vw,1.9rem); margin-top:2.8rem; padding-top:2.8rem; border-top:var(--hair); }
.legal-body h2:first-child{ margin-top:0; padding-top:0; border-top:0; }
.legal-body h3{ font-size:1.2rem; margin-top:1.9rem; }
.legal-body p,.legal-body li{ color:var(--ink-soft); margin-top:.9rem; font-size:1rem; }
.legal-body ul{ margin-top:.6rem; padding-left:1.2rem; list-style:disc; }
.legal-body li{ margin-top:.4rem; }
.legal-body a{ color:var(--brand); text-decoration:underline; text-underline-offset:3px; }
.legal-back{ display:inline-flex; align-items:center; gap:.5rem; margin-top:2.6rem; font-weight:600; color:var(--brand); }

/* ---------- 22. Utility ---------- */
.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; }
.skip-link{ position:fixed; top:-100px; left:12px; z-index:200; padding:.8rem 1.3rem; background:var(--ink); color:var(--bg); font-weight:600; border-radius:var(--r-sm); transition:top .2s var(--ease); }
.skip-link:focus{ top:10px; }
.scroll-top{ position:fixed; right:22px; bottom:22px; width:46px; height:46px; border-radius:var(--r-sm); background:var(--ink); color:var(--bg); border:none; display:grid; place-items:center; opacity:0; visibility:hidden; transform:translateY(10px); transition:opacity .3s, visibility .3s, transform .3s, background .25s; z-index:40; }
.scroll-top.show{ opacity:1; visibility:visible; transform:none; }
.scroll-top:hover{ background:var(--brand); }
.scroll-top svg{ width:18px; height:18px; stroke-width:1.8; }

/* ============================================================
   23. Refinements from visual critique (Edel-Pass 2)
   ============================================================ */
/* Headline: blue out, elegant Fraunces italic emphasis instead */
.hero h1 .hl{ color:var(--ink); font-style:italic; }

/* Remove generic template icons — typography & numbers carry it */
.service-ic, .feature .f-ic, .machine-card .m-ic, .job .j-ic, .hero-badge svg{ display:none; }
.service-num{ display:block; margin-bottom:1rem; }
.service-card h3{ margin-top:0; }
.hero-badge{ gap:0; }

/* Hero index = open list (no boxed card) */
.hero-card{ background:transparent; border:0; padding:0; box-shadow:none; }
.hero-card-title{ margin-bottom:.4rem; }
.hero-layer:first-child{ border-top:var(--hair); }

/* Process: reserve two title lines so all 5 columns share a baseline */
.pstep h3{ min-height:2.5em; }

/* Maschinenpark: keep terracotta rare — quantities in warm off-white */
.machine-list li b{ color:var(--on-dark); }

/* Address line: sentence case, not small-caps */
.region-pin{ font-variant:normal; text-transform:none; letter-spacing:0; }

/* Consent link stays navy (blue reserved for the send button) */
.form-check a{ color:var(--ink); border-bottom-color:var(--line); }

/* FAQ heading shares the left edge of the accordion */
#faq .section-head--center{ text-align:left; max-width:820px; }
#faq .eyebrow--center{ justify-content:flex-start; }

/* One geometry: footer contact circles -> same small radius */
.footer-social a{ border-radius:var(--r-sm); }

/* Edel-Pass 3 (final confirmation) */
.hero-inner{ align-items:start; }
.hero-panel{ margin-top:clamp(1rem,3.5vw,3.4rem); }
.hero-secondary{ display:inline-flex; align-items:center; gap:.5rem; font-weight:600; font-size:1.02rem; color:var(--ink); border-bottom:1px solid transparent; transition:border-color .25s; align-self:center; }
.hero-secondary:hover{ border-bottom-color:var(--ink); }
.hero-secondary .arrow{ width:1.05em; height:1.05em; transition:transform .3s var(--ease); }
.hero-secondary:hover .arrow{ transform:translateX(3px); }
.machine-list li b{ color:#F2EEE4; }
@media (max-width:480px){ .hero-cta{ align-items:stretch; } .hero-secondary{ align-self:flex-start; padding:.4rem 0; } }

/* ---------- 24. Qualifikationen & Zertifikate ---------- */
.qual-grid{ margin-top:clamp(2.4rem,4vw,3.6rem); display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.qual-card{ background:var(--surface); border:var(--hair); border-radius:var(--r-md); padding:1.7rem 1.5rem; transition:border-color .25s var(--ease); }
.qual-card:hover{ border-color:var(--ink); }
.qual-std{ display:inline-block; font-family:var(--font-body); font-weight:600; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); padding-bottom:.9rem; border-bottom:var(--hair); margin-bottom:.9rem; }
.qual-card h3{ font-size:1.14rem; }
.qual-card p{ margin-top:.6rem; font-size:.92rem; color:var(--ink-soft); }
.qual-note{ margin-top:1.6rem; font-size:.9rem; color:var(--muted); }
@media (max-width:900px){ .qual-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .qual-grid{ grid-template-columns:1fr; } }
