:root{
  /* Brand palette (Rot/Grau/Weiß/Schwarz) */
  --bg: #ffffff;          /* page background */
  --bg-2: #f6f7f9;        /* subtle section tint */
  --surface: #ffffff;
  --surface-2: #fbfbfc;
  --text: #0b0d10;        /* near-black */
  --muted: rgba(11,13,16,.72);
  --stroke: rgba(11,13,16,.12);

  --primary: #991723;     /* Logo-Rot */
  --primary-2: #b01e2c;   /* hellerer Ton für Verläufe */

  --shadow: 0 14px 40px rgba(0,0,0,.12);
  --radius: 18px;
  --radius-sm: 14px;
  --container: 1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color: var(--text);
  background: #ffffff;
  line-height:1.6;
}

/* Dezentes Hintergrundfoto (nur bis inkl. Hero-Bereich, weich in Weiß auslaufend) */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    linear-gradient(to bottom,
      rgba(255,255,255,.78) 0%,
      rgba(255,255,255,.78) 55%,
      rgba(255,255,255,1) 88%,
      rgba(255,255,255,1) 100%
    ),
    url("../images/hero-bg.jpg");
  background-size: cover;
  background-position: center top;
  background-repeat:no-repeat;
}

/* Ab "Wer wir sind": Hintergrundbild vollständig ausblenden */
#wer{
  position:relative;
}
#wer::before{
  content:"";
  position:absolute;
  inset:-2px 0 0 0;
  z-index:-1;
  background: #ffffff;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; height:auto}

.container{
  width:min(var(--container), calc(100% - 2rem));
  margin-inline:auto;
}

.skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip-link:focus{
  left:1rem; top:1rem;
  width:auto; height:auto;
  padding:.75rem 1rem;
  background:#fff;
  color:#000;
  border-radius:12px;
  z-index:9999;
}

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

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  background: rgba(255,255,255,.92);
  border-bottom: 1px solid var(--stroke);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0; /* minimal möglich */
  gap: 1rem;
}

.brand{
  display:flex;
  align-items:center;
  gap:.65rem;
  font-weight:700;
  letter-spacing:.2px;
}
/* Icon entfernt  wir zeigen nur das Logo */
.brand-mark{display:none}

.brand-logo{
  display:block;
  height:64px;
  width:auto;
  object-fit:contain;
  background:transparent;
}
.brand-logo--header{
  height:92px; /* so groß wie möglich ohne den Header zu sprengen */
  width:auto;
  max-width: 420px;
}
.brand-text{font-size:1.05rem}

.brand{gap:0}

.nav{position:relative}
.nav-toggle{
  display:none;
  background: transparent;
  border: 1px solid var(--stroke);
  color: var(--text);
  border-radius: 12px;
  padding: .55rem .7rem;
}
.nav-menu{
  display:flex;
  align-items:center;
  gap:.9rem;
  list-style:none;
  margin:0;
  padding:0;
}
.nav-menu a{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.55rem .75rem;
  border-radius: 12px;
  color: rgba(11,13,16,.72);
  border: 1px solid transparent;
}
.nav-menu a:hover{
  color: var(--text);
  border-color: var(--stroke);
  background: rgba(0,0,0,.03);
}
.nav-menu .nav-cta{
  color: #ffffff;
  background: linear-gradient(135deg, var(--primary-2), var(--primary));
  border: none;
  font-weight: 700;
}
.nav-menu .nav-cta:hover{filter: brightness(1.03)}

/* Hero */
.hero{
  position:relative;
  padding: 5.25rem 0 2.5rem;
  overflow:hidden;
}
.hero-inner{
  display:grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: start;
}

.hero-content{
  max-width: 860px;
  margin: 0 auto;
}
.hero-bg{
  position:absolute;
  inset:-30% -10% auto -10%;
  height: 520px;
  background:
    radial-gradient(420px 280px at 30% 20%, rgba(153,23,35,.12), transparent 62%),
    radial-gradient(540px 340px at 70% 30%, rgba(153,23,35,.16), transparent 62%);
  pointer-events:none;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.35rem .65rem;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  margin:0 0 1rem;
}

h1{
  margin:0 0 .8rem;
  font-size: clamp(2rem, 3.6vw, 3.2rem);
  line-height:1.08;
  letter-spacing:-.03em;
}

/* Subtle red accent for headings */
.section-head h2,
.cta h2{
  position:relative;
}
.section-head h2::after,
.cta h2::after{
  content:"";
  display:block;
  width:56px;
  height:3px;
  margin-top:.6rem;
  border-radius:999px;
  background: linear-gradient(90deg, var(--primary), rgba(255,255,255,0));
}
.lead{
  margin:0 0 1.25rem;
  color: var(--muted);
  font-size: 1.08rem;
}

.hero-actions{display:flex; gap:.8rem; flex-wrap:wrap}
.hero-actions-center{justify-content:center}

.btn{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.85rem 1rem;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-weight: 700;
  box-shadow: 0 10px 25px rgba(0,0,0,.16);
  transition: transform .15s ease, filter .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{transform: translateY(-1px); filter: brightness(1.05)}
.btn:active{transform: translateY(0)}
.btn-primary{
  border:none;
  color:#ffffff;
  background: linear-gradient(135deg, var(--primary-2), var(--primary));
}
.btn-sm{
  padding: .55rem .8rem;
  border-radius: 12px;
  font-weight: 800;
  box-shadow: 0 10px 22px rgba(153,23,35,.18);
}
.btn-ghost{background: rgba(0,0,0,.03)}

.hero-badges{
  display:flex;
  gap: .9rem;
  justify-content: space-between;
  width: 100%;
  flex-wrap: nowrap;
  margin-top: 1.35rem;
  margin-bottom: 1.25rem; /* mehr Abstand zur Karte */
}
.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.7rem .85rem;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(0,0,0,.02);
  color: rgba(11,13,16,.70);
  flex: 1 1 0;
  min-width: 0;
}

/* Icon-Farben im neuen Logo-Rot (Transparenzen bleiben über rgba/Opacity erhalten) */
.badge i,
.mini i{
  color: rgba(153,23,35,.95);
}
.card-icon i,
.hero-card-icon i{
  color: rgba(153,23,35,.95);
}
.badge span{white-space:nowrap}

.hero-card{
  position:relative;
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  background: linear-gradient(180deg, rgba(255,255,255,1), rgba(255,255,255,.98));
  box-shadow: var(--shadow);
  padding: 1.2rem;
}

/* Inline-Variante im Hero (unter den Badges, zentriert & volle Breite) */
.hero-card-inline{
  width: 100%;
  max-width: 860px;
  margin: 0 auto;
}
.hero-card:before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(153,23,35,.28), rgba(255,255,255,0));
  opacity:.35;
  pointer-events:none;
}
.hero-card > *{position:relative}
.hero-card-top{display:flex; gap:.9rem; align-items:center; margin-bottom: 1rem}
.hero-card-icon{
  width:46px; height:46px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(153,23,35,.14);
  border: 1px solid rgba(153,23,35,.26);
}
.hero-card-title{margin:0; font-weight:700}
.hero-card-sub{margin:.15rem 0 0; color: rgba(11,13,16,.65); font-size:.95rem}
.hero-card-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:.65rem;
}
.mini{
  display:flex;
  align-items:center;
  gap:.55rem;
  padding:.7rem .75rem;
  border-radius: 14px;
  border: 1px solid var(--stroke);
  background: rgba(0,0,0,.02);
  color: rgba(11,13,16,.72);
}

/* Sections */
.section{padding: 3.25rem 0}
.section-alt{
  background: var(--bg-2);
  border-top: 1px solid rgba(0,0,0,.06);
  border-bottom: 1px solid rgba(0,0,0,.06)
}
.section-head{max-width: 860px; margin-bottom: 1.5rem}
.section-head h2{
  margin:0 0 .55rem;
  font-size: clamp(1.5rem, 2.2vw, 2.1rem);
  letter-spacing:-.02em;
}
.section-head p{margin:0; color: var(--muted)}

.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.cards-2{grid-template-columns: repeat(2, 1fr)}

.card{
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  background: #ffffff;
  padding: 1.2rem;
  box-shadow: 0 12px 34px rgba(0,0,0,.10);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.card:hover{
  transform: translateY(-2px);
  border-color: rgba(153,23,35,.28);
  box-shadow: 0 16px 45px rgba(0,0,0,.12);
}
.card-icon{
  width:44px; height:44px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(153,23,35,.10);
  border: 1px solid rgba(153,23,35,.20);
  margin-bottom: .85rem; /* default (mobile/stack) */
}

/* Karten: Icon links neben Text (Desktop), mobil wieder oben */
.card--iconleft{
  display:flex;
  gap: .85rem;
  align-items:flex-start;
}
.card--iconleft .card-icon{
  margin-bottom: 0;
  flex: 0 0 44px;
}
.card--iconleft .card-body{min-width: 0}

.card h3{margin:.1rem 0 .35rem; font-size: 1.1rem}
.card p{margin:0; color: rgba(11,13,16,.70)}

@media (max-width: 640px){
  /* Leistungen (mobil): alle Boxen gleich aufgebaut */
  .cards-2{gap: 1rem}

  .card--iconleft{
    display:flex;
    gap: .85rem;
    align-items:flex-start;
  }
  .card--iconleft .card-icon{
    margin-bottom: 0;
    flex: 0 0 44px;
  }
  .card--iconleft .card-body{min-width: 0}

  .service-tags{
    grid-template-columns: 1fr;
    row-gap: 1rem;   /* exakt wie .cards/.cards-2 */
    margin-bottom: 1rem;
  }
  .service-tag{
    border-radius: var(--radius);
    border: 1px solid var(--stroke);
    background: #ffffff;
    padding: 1.2rem;
    box-shadow: 0 12px 34px rgba(0,0,0,.10);
    display:flex;
    gap: .85rem;
    align-items:flex-start;
  }
}

/* Embeds (MyHammer etc.) */
.embed-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  flex-wrap:wrap;
  margin-bottom: .85rem;
}
.embed-title{margin:0; font-weight:800}
.embed-wrap{
  width:100%;
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
}
.embed-fallback{
  padding: 1.2rem;
}
.embed-actions{
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
  margin-top: .9rem;
}

/* Review cards */
.reviews{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  padding: 0 1.2rem 1.2rem;
}
.review{
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 16px;
  padding: 1rem;
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}
.review-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.75rem;
}
.review-name{margin:0; font-weight:800}
.review-loc{font-weight:600; color: rgba(11,13,16,.60)}
.review-meta{margin:.2rem 0 0; color: rgba(11,13,16,.60); font-size:.95rem}
.review-job{margin:.8rem 0 .35rem; font-weight:700}
.review-text{margin:0; color: rgba(11,13,16,.78)}
.stars{color: #f59e0b; white-space:nowrap}
.stars i{margin-left:2px}

@media (max-width: 840px){
  .reviews{grid-template-columns: 1fr; padding: 0 1.2rem 1.2rem}
}

/* Google Rezensionen Block */
.gblock{
  display:grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  align-items: start;
}
.ginfo h3{margin:.1rem 0 .35rem}
.glist{
  list-style:none;
  padding:0;
  margin: .85rem 0 0;
  display:grid;
  gap: .55rem;
}
.glist li{
  display:flex;
  gap:.6rem;
  align-items:flex-start;
  color: rgba(11,13,16,.78);
}
.glist-row--maps{
  align-items:center;
  flex-wrap: wrap;
}
.glist-row--maps .btn{
  margin-left: .2rem;
}
.glist-row--maps i{margin-top:0}
.glist i{color: rgba(153,23,35,.95); margin-top:.18rem}

.ginfo{
  padding: 1.2rem;
}

.ginfo-grid{
  display:grid;
  grid-template-columns: 1fr 360px;
  gap: 1.1rem;
  align-items:start;
}

.ginfo-text h3{margin:.1rem 0 .35rem}

.ginfo-map{
  align-self:start;
}
.gframe-wrap{
  width:100%;
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.10);
  background: var(--bg-2);
}
.gframe-wrap iframe{
  display:block;
  width:100%;
  height: 240px; /* kleiner wie gewünscht */
}
.gplaceholder{
  padding: 1.2rem;
}

/* Leistungen Zusatz-Tags */
.service-tags{
  margin-top: 1rem;
  margin-bottom: 1rem; /* Abstand zur nächsten Grid-Reihe = exakt wie Box-Abstand */
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 1rem; /* exakt wie .cards */
  row-gap: 1rem; /* exakt wie .cards */
}
.service-tag{
  border-radius: var(--radius);
  border: 1px solid var(--stroke);
  background: #ffffff;
  padding: 1.2rem; /* exakt wie .card */
  box-shadow: 0 12px 34px rgba(0,0,0,.10);
  display:flex;
  gap: .85rem;
  align-items:flex-start;
}
.service-tag{
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.service-tag:hover{
  transform: translateY(-2px);
  border-color: rgba(153,23,35,.28);
  box-shadow: 0 16px 45px rgba(0,0,0,.12);
}
.service-tag-icon{
  width:44px;
  height:44px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(153,23,35,.10);
  border: 1px solid rgba(153,23,35,.20);
  flex: 0 0 44px;
}
.service-tag-icon i{color: rgba(153,23,35,.95)}
.service-tag strong{
  display:block;
  font-weight: 850;
  letter-spacing: .1px;
  margin: .1rem 0 .35rem; /* exakt wie .card h3 spacing */
  font-size: 1.1rem;      /* exakt wie .card h3 */
}
.service-tag .muted{
  display:block;
  margin:0;
  color: rgba(11,13,16,.70);
  font-size: 1rem;        /* an .card p angeglichen */
  line-height: 1.6;       /* an globale Lesbarkeit angeglichen */
}

/* Gleiche Höhen/Abstände pro Reihe */
.cards-2,
.service-tags{
  align-items: stretch;
}
.card,
.service-tag{height: 100%}

/* überall gleiche Spalt-/Zeilenabstände bei Leistungen */
.cards-2{gap: 1rem}

/* Kein zusätzlicher Abstand zwischen Zusatzleistungen und Hauptkarten */
.service-tags + .cards{margin-top: 0}
@media (max-width: 840px){
  .service-tags{grid-template-columns: 1fr}
}

/* Slider / Referenzen */
.slider{
  position:relative;
  border-radius: calc(var(--radius) + 6px);
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: var(--surface);
  box-shadow: var(--shadow);
}
.slider-viewport{
  overflow:hidden;
  outline:none;
}
.slider-track{
  display:flex;
  transition: transform 420ms ease;
  will-change: transform;
}
.slide{
  min-width:100%;
  margin:0;
  position:relative;
  background: #fff;
}
.slide img{
  width:100%;
  /* weniger "in die Länge gezogen": Höhe reduziert + Portrait-Bilder werden nicht abgeschnitten */
  height: min(60vh, 560px);
  object-fit: contain;
  object-position: center;
  display:block;
  background: var(--bg-2);
}
.slide figcaption{
  position:absolute;
  left: 14px;
  bottom: 14px;
  padding: .55rem .8rem;
  border-radius: 999px;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(0,0,0,.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-weight: 650;
}

.slider-btn{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  display:grid;
  place-items:center;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 26px rgba(0,0,0,.14);
  cursor:pointer;
}
.slider-btn i{color: rgba(11,13,16,.78)}
.slider-btn:hover{border-color: rgba(153,23,35,.35)}
.slider-btn:active{transform: translateY(-50%) scale(.98)}
.slider-btn--prev{left: 12px}
.slider-btn--next{right: 12px}

.slider-dots{
  position:absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 12px;
  display:flex;
  gap: .45rem;
  padding: .4rem .55rem;
  border-radius: 999px;
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(0,0,0,.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.20);
  background: rgba(0,0,0,.12);
  padding:0;
  cursor:pointer;
}
.dot.is-active{
  background: rgba(153,23,35,.85);
  border-color: rgba(153,23,35,.45);
}

@media (max-width: 960px){
  .slide img{height: min(52vh, 440px)}
}
@media (max-width: 640px){
  .slide img{height: min(46vh, 360px)}
  .slider-btn{width: 40px; height: 40px}
}

/* CTA */
.cta{padding: 3rem 0 4rem}
.cta-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1.25rem;
  border-radius: calc(var(--radius) + 4px);
  border: 1px solid rgba(0,0,0,.08);
  background: linear-gradient(135deg, rgba(153,23,35,.08), rgba(0,0,0,.02));
  box-shadow: var(--shadow);
  padding: 1.6rem;
}

/* CTA Layout: Text etwas weiter links, Buttons in 2 Reihen */
.cta-inner > div:first-child{
  flex: 1 1 auto;
  max-width: 640px;
}
.cta-actions{
  display:flex;
  flex-direction:column;
  gap:.75rem;
  flex: 0 0 360px;
  align-items:stretch;
}
.cta-actions-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:.75rem;
}
.btn-wide{
  width:100%;
  justify-content:center;
}
.cta h2{margin:0 0 .3rem}
.cta p{margin:0; color: rgba(11,13,16,.70)}
/* CTA actions: override old inline rule */
.cta-actions{display:flex; flex-direction:column; gap:.75rem; align-items:stretch; flex: 0 0 360px}

/* Cookie Banner */
.cookie-banner{
  position: fixed;
  inset: 0;
  z-index: 2147483647; /* garantiert über allem */
  display:none;
  align-items:center;
  justify-content:center;
  padding: 1.25rem;
  background: rgba(11,13,16,.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.cookie-banner.is-open{display:flex}
.cookie-banner__inner{
  width: min(760px, 100%);
  margin: 0;
  border-radius: calc(var(--radius) + 10px);
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.98);
  box-shadow: 0 28px 90px rgba(0,0,0,.32);
  padding: 1.35rem 1.4rem;
  display:flex;
  gap: 1.1rem;
  align-items:flex-start;
  justify-content:space-between;
}
.cookie-banner__inner::before{
  content:"";
  position:absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events:none;
}
.cookie-banner__inner{position:relative}
.cookie-banner__title{font-size:1.15rem}
.cookie-banner__actions .btn{min-width: 160px}

.cookie-banner__title{margin:0 0 .25rem; font-weight:900}
.cookie-banner__text{max-width: 760px}
.cookie-banner__actions{display:flex; gap:.6rem; flex-wrap:wrap; flex: 0 0 auto}

/* Consent block (Maps Platzhalter) */
.consent-block{
  padding: 1rem;
}
.consent-title{margin:0 0 .35rem; font-weight:850}
[data-consent-block] iframe{display:none}
[data-consent-block].is-active .consent-block{display:none}
[data-consent-block].is-active iframe{display:block}

@media (max-width: 640px){
  .cookie-banner__inner{flex-direction:column; align-items:stretch}
  .cookie-banner__actions{justify-content:flex-start}
  .cookie-banner__actions .btn{width:100%; justify-content:center}
}

/* Footer */
.site-footer{border-top: 1px solid rgba(0,0,0,.08); padding: 1.25rem 0; background: #ffffff}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap: 1rem; flex-wrap:wrap}
.footer-links{display:flex; align-items:center; gap: 1rem; flex-wrap:wrap}
.footer-links a{color: rgba(11,13,16,.65)}
.footer-links a:hover{color: var(--text)}
.muted{color: rgba(11,13,16,.65); margin:0}
.to-top{color: rgba(11,13,16,.65)}
.to-top:hover{color: var(--text)}

/* Responsive */
@media (max-width: 960px){
  .hero-inner{grid-template-columns: 1fr;}

  /* Hero-Card Icon nur mobil ausblenden */
  .hero-card-icon{display:none}

  /* Badges in Mobile nebeneinander */
  .hero-badges{
    flex-wrap: nowrap;
    justify-content: space-between;
    gap: .6rem;
  }
  .badge{
    flex: 1 1 0;
    justify-content:center;
    padding: .6rem .6rem;
  }
  .badge span{font-size: .95rem}

  .ginfo-grid{grid-template-columns: 1fr}
  .gframe-wrap iframe{height: 260px}
}

@media (max-width: 840px){
  .nav-toggle{display:inline-flex}
  .nav-menu{
    position:absolute;
    right:0;
    top: calc(100% + .6rem);
    width: min(320px, calc(100vw - 2rem));
    flex-direction:column;
    align-items:stretch;
    gap:.25rem;
    padding:.6rem;
    border-radius: 16px;
    border: 1px solid var(--stroke);
    background: rgba(255,255,255,.96);
    box-shadow: var(--shadow);
    display:none;
  }
  .nav-menu.open{display:flex}
  .nav-menu a{justify-content:space-between}
  .cards{grid-template-columns: 1fr}
  .cards-2{grid-template-columns: 1fr}
  .gblock{grid-template-columns: 1fr}
  .cta-inner{flex-direction:column; align-items:flex-start}
  .cta-actions{flex: 1 1 auto; width:100%; max-width: 520px}
  .cta-actions-row{grid-template-columns: 1fr 1fr}
  .btn-wide{justify-content:center}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .btn:hover{transform:none}
}
