:root{
  --bg:#ffffff;
  --bg-alt:#e3ecfb;
  --text:#101114;
  --muted:#4a4f57;
  --border:#d9dde3;
  --accent:#0f4aa5;
  --accent-soft: rgba(15,74,165,.18);
  --accent-2:#b42828;
  --accent-2-soft: rgba(180,40,40,.10);
  --shadow: 0 10px 30px rgba(16,17,20,.06);
  --radius: 18px;
}

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

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

a{color:inherit;text-decoration:none}
a.link{display:inline-block;margin-top:10px;text-decoration:underline;color:var(--text)}
a.link:hover{opacity:.75}

.container{max-width:1120px;margin:0 auto;padding:0 20px}
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:12px;top:12px;width:auto;height:auto;background:#fff;border:1px solid var(--border);padding:10px;border-radius:12px;z-index:1000}

.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:64px}
.brand{font-weight:750;letter-spacing:.2px}
.nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.nav a{padding:9px 10px;border-radius:12px}
.nav a:hover{background:var(--bg-alt)}
.nav .nav .cta:hover{background: rgba(22,74,159,.12)}
.nav-toggle{display:none;border:1px solid var(--border);background:#fff;border-radius:12px;padding:8px 10px;cursor:pointer}
.mobile-nav{border-top:1px solid var(--border);background:rgba(255,255,255,.97)}
.mobile-nav-inner{display:grid;gap:6px;padding:14px 20px}
.mobile-nav a{padding:10px;border-radius:12px}
.mobile-nav a:hover{background:var(--bg-alt)}
.mobile-nav .hero{padding:72px 0 34px 0; background: linear-gradient(180deg, var(--accent-soft), rgba(255,255,255,0) 45%)}
.eyebrow{color:var(--muted);font-size:13px;margin:0 0 10px 0;letter-spacing:.15px}
.hero h1{font-size:40px;line-height:1.14;margin:0 0 14px 0;max-width:860px}
.lead{font-size:18px;color:var(--muted);max-width:900px;margin:0 0 8px 0}
.micro{color:var(--muted);margin:0 0 18px 0}
.cta-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.cta-sub{color:var(--muted);font-size:13px}

.section{padding:46px 0;border-top:1px solid var(--border)}
.section.alt{background:var(--bg-alt)}
h2{font-size:24px;margin:0 0 14px 0}
h3{font-size:16px;margin:0 0 8px 0}
.note{color:var(--muted);max-width:980px}

.cards{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:12px;
}
.cards li{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  box-shadow: var(--shadow);
}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.grid.two{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.grid.three{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.tile{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow: var(--shadow);
}
.tile p{margin:0;color:var(--muted)}
.tile.emph{border-color:#c8ccd3}
.section-footer{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:18px}

.callout{
  margin-top:16px;
  background: rgba(22,74,159,.08);border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow: var(--shadow);
}
.callout ul{margin:10px 0 0 18px;color:var(--muted)}

.steps{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.steps li{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  display:grid;gap:6px;
  box-shadow: var(--shadow);
}
.steps strong{display:block}
.steps span{color:var(--muted)}

.accordion details{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);
  padding:0;
  box-shadow: var(--shadow);
  overflow:hidden;
  margin-bottom:10px;
}
.accordion summary{
  cursor:pointer;
  padding:14px 16px;
  list-style:none;
  font-weight:650;
}
.accordion summary::-webkit-details-marker{display:none}
.details-body{padding:0 16px 14px 16px;color:var(--muted)}

.two-col{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;align-items:start}
.form{display:grid;gap:12px;max-width:720px}
label{display:grid;gap:6px;font-size:13px;color:var(--muted)}
input,textarea{
  border:1px solid var(--border);
  border-radius:14px;
  padding:10px 12px;
  font:inherit;
  background:#fff;
  color:var(--text);
}
.button{display:inline-block;padding:10px 14px;border-radius:14px;border:1px solid rgba(15,74,165,.45);background: rgba(15,74,165,.14);cursor:pointer}
.button:hover{background: rgba(15,74,165,.16);border-color: rgba(15,74,165,.60)}
.micro-note{color:var(--muted);font-size:13px;margin:0}
.contact-box{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow: var(--shadow);
}
.muted{color:var(--muted)}
.small{font-size:13px}

.site-footer{border-top:1px solid var(--border);padding:22px 0}
.footer-inner{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:13px}
.footer-links{display:flex;gap:14px}
.footer-links a{text-decoration:underline}
.footer-links a:hover{opacity:.75}

/* Responsive */
@media (max-width: 980px){
  .hero h1{font-size:34px}
  

/* Desktop vs Mobile navigation safety:
   - On devices with mouse/trackpad (pointer:fine + hover), always use desktop nav (old behavior),
     even if the browser window is narrow.
   - On touch devices (pointer:coarse), use the mobile toggle/accordion.
*/
@media (hover:hover) and (pointer:fine){
  .nav{display:flex !important;}
  .nav-toggle{display:none !important;}
  #mobile-nav{display:none !important;}
}

.two-col{grid-template-columns:1fr}
  .nav{display:none}
  .nav-toggle{display:inline-block}
}

/* Process flow (Grafik 1: Vorgehensmodell) */
.process-flow{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:12px;
  align-items:stretch;
  margin-top:14px;
}
.process-step{
  position:relative;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  box-shadow: var(--shadow);
  min-height: 210px;
}
.process-step::after{
  content:"→";
  position:absolute;
  right:-14px;
  top:18px;
  color:var(--muted);
  font-size:16px;
}
.process-step:last-child::after{content:"";}
.process-title{
  font-weight:750;
  letter-spacing:.2px;
  margin-bottom:6px;
}
.process-sub{
  color:var(--muted);
  font-size:13px;
  margin-bottom:10px;
}
.process-bullets{
  margin:0;
  padding-left:16px;
  color:var(--muted);
  font-size:13px;
}
.process-bullets li{margin:6px 0;}
.process-footnote{
  margin-top:12px;
  color:var(--muted);
  font-size:13px;
}

/* Process flow responsive */
@media (max-width: 1020px){
  .process-flow{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .process-step::after{content:"";}
}
@media (max-width: 520px){
  .process-flow{grid-template-columns:1fr;}
}

/* Leistungslandkarte (Grafik 2) */
.service-map{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
  margin-top:14px;
  margin-bottom:12px;
}
.service-group{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  box-shadow: var(--shadow);
}
.service-group-title{
  font-weight:750;
  letter-spacing:.2px;
  margin-bottom:10px;
}
.service-list{
  margin:0;
  padding-left:16px;
  color:var(--muted);
  font-size:13px;
}
.service-list li{margin:7px 0}
.service-map-footnote{
  color:var(--muted);
  font-size:13px;
  margin:0 0 6px 0;
}

/* Service map responsive */
@media (max-width: 1020px){
  .service-map{grid-template-columns:repeat(2, minmax(0, 1fr));}
}
@media (max-width: 520px){
  .service-map{grid-template-columns:1fr;}
}

/* Subtle accents (V1.3) */
.section.alt{
  background: var(--bg-alt);
}
h2{
  position:relative;
  padding-bottom:10px;
}

.tile.emph{border-color: rgba(22,74,159,.55); box-shadow: 0 14px 38px rgba(22,74,159,.14);}
.tile.emph h3{
  position:relative;
}
.tile.emph h3::before{content:"";display:inline-block;width:9px;height:9px;border-radius:99px;background: var(--accent);opacity:.75;margin-right:8px;transform: translateY(-1px);}
/* Labels */
.service-group-title,
.process-title{
  color: var(--text);
}
.service-group-title{border-left: 4px solid rgba(22,74,159,.60);padding-left:10px;}
.process-step{background: linear-gradient(180deg, rgba(22,74,159,.10), rgba(255,255,255,0) 58%), #fff;}
.process-step::after{
  color: rgba(31,75,153,.45);
}
.button{
  border-color: rgba(31,75,153,.25);
}
.button:hover{
  border-color: rgba(31,75,153,.45);
}
.nav /* Entscheidungslogik (Grafik 3) */
.decision-flow{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:12px;
  margin-top:16px;
}
.decision-step{
  background: linear-gradient(180deg, rgba(22,74,159,.12), rgba(255,255,255,0) 55%), #fff;
  border:1px solid rgba(22,74,159,.35);
  border-radius:var(--radius);
  padding:14px;
  box-shadow: var(--shadow);
}
.decision-title{
  font-weight:750;
  margin-bottom:6px;
}
.decision-branch{
  grid-column:2 / span 2;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  align-items:stretch;
}
.branch{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:12px;
  box-shadow: var(--shadow);
}
.branch h3{margin:0 0 6px 0;font-size:14px}
.branch.emph{
  border-color: rgba(22,74,159,.55);
  background: rgba(22,74,159,.10);
}
.branch.mandatory{
  border-color: rgba(180,40,40,.55);
  background: rgba(180,40,40,.08);
}
.decision-footnote{
  margin-top:12px;
  color:var(--muted);
  font-size:13px;
}
@media (max-width: 1020px){
  .decision-flow{grid-template-columns:1fr}
  .decision-branch{grid-column:auto;grid-template-columns:1fr}
}

/* Systemblick (Grafik 5) */
.system-map{
  position:relative;
  display:grid;
  grid-template-columns:repeat(5, minmax(0,1fr));
  gap:12px;
  margin-top:16px;
}
.system-center{grid-column:1 / -1;text-align:center;margin-bottom:6px}
.system-core{display:inline-block;padding:10px 18px;border-radius:999px;border:1px solid rgba(22,74,159,.55);background: rgba(22,74,159,.14);font-weight:750}
.system-sub{color:var(--muted);font-size:13px;margin-top:6px}
.system-node{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow: var(--shadow)}
.system-node h3{margin:0 0 8px 0;font-size:15px}
.system-node ul{margin:0;padding-left:16px;color:var(--muted);font-size:13px}
.system-node ul li{margin:6px 0}
.system-node.tech{border-color: rgba(22,74,159,.45)}
.system-node.orga{border-color: rgba(22,74,159,.35)}
.system-node.recht{border-color: rgba(22,74,159,.35)}
.system-node.wirtschaft{border-color: rgba(22,74,159,.45)}
.system-node.mensch{border-color: rgba(22,74,159,.55);background: rgba(22,74,159,.08)}
@media (max-width: 1020px){.system-map{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 520px){.system-map{grid-template-columns:1fr}}

/* Dezentralstruktur (Grafik 4) */
.decentral-wrap{margin-top:18px}
.decentral-diagram{
  position:relative;
  display:grid;
  grid-template-columns:1.05fr 1.1fr 1.05fr;
  gap:12px;
  margin-top:12px;
  align-items:stretch;
}
.node{position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow: var(--shadow)}
.node.central{border-color: rgba(22,74,159,.45);background: rgba(22,74,159,.06)}
.node.audit{border-color: rgba(22,74,159,.35);background: linear-gradient(180deg, rgba(22,74,159,.10), rgba(255,255,255,0) 60%), #fff}
.node-title{font-weight:750;margin-bottom:8px}
.node ul{margin:0;padding-left:16px;color:var(--muted);font-size:13px}
.node ul li{margin:6px 0}
.badge{display:inline-block;margin-top:10px;padding:6px 10px;border-radius:999px;border:1px solid rgba(22,74,159,.35);background: rgba(22,74,159,.10);font-size:12px;color: var(--text)}
.badge.warn{border-color: rgba(180,40,40,.45);background: rgba(180,40,40,.10)}
.pill-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.pill{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid rgba(22,74,159,.25);background: rgba(22,74,159,.08);font-size:12px}
.hint{margin-top:10px;color:var(--muted);font-size:13px}
.connector{position:absolute;top:50%;height:2px;background: rgba(22,74,159,.35)}
.connector.left{left: calc(33.33% - 6px);width: calc(33.33% + 12px)}
.connector.right{left: calc(66.66% - 6px);width: calc(33.33% + 12px)}
.connector::after{content:"";position:absolute;right:-2px;top:-4px;width:0;height:0;border-left:8px solid rgba(22,74,159,.35);border-top:5px solid transparent;border-bottom:5px solid transparent}
@media (max-width: 980px){.decentral-diagram{grid-template-columns:1fr}.connector{display:none}}

/* Related links tiles */
.related-links .tile{text-decoration:none;color:inherit;display:block}
.related-links .tile p{color:var(--muted)}

/* Tags / badges */
.tag{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(15,74,165,.35);
  background: rgba(15,74,165,.10);
  font-size:12px;
  color: var(--text);
  margin-right:8px;
}
.tag.red{
  border-color: rgba(180,40,40,.45);
  background: rgba(180,40,40,.10);
}

.hero-tags{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px}

/* Stronger color on subpages */
.page-banner{
  background: linear-gradient(90deg, rgba(15,74,165,.20), rgba(15,74,165,.06));
  border-bottom: 1px solid rgba(15,74,165,.22);
}
.page-banner .container{ padding: 18px 0 14px 0; }
.page-kicker{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-top:10px; }
.page-title{ margin:0; padding-bottom:10px; position:relative; }
.page-title::after{
  content:""; position:absolute; left:0; bottom:0;
  width:88px; height:4px; border-radius:999px;
  background: rgba(15,74,165,.55);
}
.section.alt{background: var(--bg-alt);}

/* ProLook v2.6 */
:root{
  --shadow-2: 0 18px 45px rgba(0,0,0,.10);
  --shadow-3: 0 24px 65px rgba(0,0,0,.14);
}

/* Typography rhythm */
h1{letter-spacing:-.02em}
.hero h1, .page-title{font-weight:760}
.hero h1{font-size:44px;line-height:1.06}
@media (max-width: 760px){ .hero h1{font-size:34px} }

.section{padding:72px 0}
@media (max-width: 760px){ .section{padding:54px 0} }

/* Hero background + depth */
.hero{
  position:relative;
  overflow:hidden;
  border-bottom: 1px solid rgba(15,74,165,.18);
  background:
    radial-gradient(900px 420px at 15% 20%, rgba(15,74,165,.22), transparent 60%),
    radial-gradient(900px 420px at 85% 10%, rgba(15,74,165,.14), transparent 60%),
    linear-gradient(180deg, rgba(227,236,251,.85), rgba(255,255,255,0) 68%),
    #fff;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.22'/%3E%3C/svg%3E");
  opacity:.08;
  pointer-events:none;
}
.hero .container{position:relative; z-index:1}

/* Proof bar */
.proof-bar{
  margin-top:18px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.proof-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(15,74,165,.22);
  background: rgba(255,255,255,.66);
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 25px rgba(0,0,0,.06);
  font-size:13px;
}
.proof-dot{
  width:8px; height:8px;
  border-radius:999px;
  background: rgba(15,74,165,.70);
}

/* Buttons */
.button, .button:hover, .cta:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow-2);
  background: rgba(15,74,165,.18);
}

/* Tiles depth */
.tile{
  border:1px solid rgba(15,74,165,.14);
  background:
    linear-gradient(180deg, rgba(15,74,165,.06), rgba(255,255,255,0) 45%),
    #fff;
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.tile:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
  border-color: rgba(15,74,165,.28);
}

/* Section headings accent */
.section h2{
  position:relative;
  padding-bottom:12px;
}
.section 

/* Slightly richer alt sections */
.section.alt{
  background:
    radial-gradient(900px 420px at 20% 10%, rgba(15,74,165,.08), transparent 60%),
    var(--bg-alt);
}

/* --- Pricing + References additions (v2.6e) --- */
.pricing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px}
.pricing-grid .card{padding:18px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);backdrop-filter: blur(6px)}
.pricing-grid .price{font-size:20px;font-weight:700;margin:8px 0 10px}
.pricing-grid ul{margin:0;padding-left:18px}
.pricing-grid li{margin:6px 0}
.logo-wall{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-top:16px}
.logo-item{padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;min-height:78px}
.logo-item img{max-width:180px;max-height:48px;opacity:.92}
@media (max-width: 900px){.pricing-grid{grid-template-columns:1fr}.logo-wall{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* v2.6h: Referenzlogos lokal eingebettet */
.logo-wall img{height:42px;width:auto;display:block;filter:none}
.logo-item{display:flex;align-items:center;justify-content:center}

/* --- v2.6i: Transparent logos + placeholder text --- */
.logo-item{background:rgba(255,255,255,.05)}
.logo-item img{opacity:1;filter: none;max-height:44px}
.logo-item.placeholder{justify-content:center;text-align:center}
.logo-item.placeholder span{font-size:14px;opacity:.9;line-height:1.2}

/* --- v2.6j: Referenzen-Fix (sichtbar & robust) --- */
.logo-wall{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-top:16px}
.logo-item{padding:14px;border-radius:16px;border:1px solid rgba(0,0,0,.08);background:rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;min-height:78px}
.logo-item img{max-width:180px;max-height:46px;opacity:1}
.logo-item.placeholder{background:rgba(255,255,255,.55)}
.logo-item.placeholder span{font-size:14px;color:#111;opacity:.9;line-height:1.2}
@media (max-width: 900px){.logo-wall{grid-template-columns:repeat(2,minmax(0,1fr))}}

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

.logo-item{display:flex; align-items:center; justify-content:center;}
.logo-item img{max-width:100%; max-height:48px; object-fit:contain;}
.logo-item .logo-text{display:none; font-size:12px; color:#334155; padding:10px; text-align:center;}

/* --- v2.6n: Impressum Typografie (ruhiger) --- */
.page-impressum h1{font-size:40px;letter-spacing:-0.02em}
.page-impressum h2{font-size:22px}
.page-impressum .card, .page-impressum .content{font-size:16px;line-height:1.6}
.page-impressum p, .page-impressum li{font-size:16px}
.page-impressum strong{font-weight:650}
@media (max-width: 900px){
  .page-impressum h1{font-size:32px}
}

/* --- v2.6o: Feintuning – Hero stabil (kein Springen) + Start-Headline ruhiger --- */
/* Stabilisiert Hero-Medienhöhe seitenübergreifend */
.hero, .hero-section, header.hero, .masthead{
  --hero-media-h: 360px;
}
.hero img, .hero-section img, header.hero img, .masthead img,
.hero .media img, .hero-media img, .hero__media img{
  width: 100%;
  height: var(--hero-media-h);
  object-fit: cover;
  object-position: center;
  display: block;
}
/* Falls Hero als Hintergrund genutzt wird */
.hero, .hero-section, header.hero, .masthead{
  background-size: cover;
  background-position: center;
  min-height: calc(var(--hero-media-h) + 40px);
}

/* Mobile */
@media (max-width: 900px){
  .hero, .hero-section, header.hero, .masthead{ --hero-media-h: 260px; }
}

/* Startseite: Headline etwas kleiner & weniger plump */
.page-home h1{
  font-size: clamp(28px, 3.2vw, 44px);
  font-weight: 650;
  letter-spacing: -0.015em;
  line-height: 1.12;
}

/* --- v2.6p: Fix Sprung beim Seitenwechsel (Branchen/Downloads/Über uns) --- */
/* Einheitliche Hero-Höhe + stabiler Headline-Block */
.hero, .hero-section, header.hero, .masthead{
  --hero-media-h: 360px;
  --hero-title-min: 110px;
}
.hero .content, .hero__content, .hero-content, .masthead .content{
  min-height: var(--hero-title-min);
}
@media (max-width: 900px){
  .hero, .hero-section, header.hero, .masthead{
    --hero-media-h: 260px;
    --hero-title-min: 90px;
  }
}



/* --- v2.6r: Header-Kontaktbutton --- */
.btn-header{
  margin-left: 12px;
  padding: 8px 14px;
  font-size: 14px;
  line-height: 1.2;
}
@media (max-width: 900px){
  .btn-header{padding: 8px 12px;}
}


/* --- v2.6s: Mobile Header – Kontakt-Button gleiche Schriftgröße --- */
/* Desktop bleibt unverändert */
.btn-header{
  font-size: inherit; /* gleiche Schriftgröße wie Nav */
}

/* Mobile: Kontakt-Button in Header-Reihe integrieren */
@media (max-width: 900px){
  header nav, .header nav, .site-header nav{
    display:flex;
    align-items:center;
    gap:10px;
  }
  .btn-header{
    padding: 8px 12px;
    font-weight: 500;
    font-size: inherit; /* explizit gleich */
  }
}


/* --- v2.6u: Fix Seiten-Sprung beim Wechsel (Scrollbar-Konsistenz) --- */
html{overflow-y: scroll;}


/* --- v2.6u: Impressum kleiner (Pflichtangabe) --- */
.page-impressum h1{font-size:30px;font-weight:650}
.page-impressum h2{font-size:18px;font-weight:650}
.page-impressum p,.page-impressum li{font-size:14px;line-height:1.55}
.page-impressum .card,.page-impressum .content{font-size:14px}
@media (max-width: 900px){.page-impressum h1{font-size:24px}}


/* --- v2.6ae: Über uns – Ansprechpartner Panel --- */
.person-panel{
  max-width: 980px;
  margin: 28px auto;
  padding: 22px 22px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(6px);
}
.person-panel h2{margin-top:0}
.person-panel p{margin: 10px 0}



/* --- EnPI page: image group sizing (placeholder Excel screenshots) --- */
.image-group{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 14px 0 6px;
}

.image-group img{
  width: 100%;
  max-width: 920px;
  height: auto;
  display: block;
  margin: 0 auto;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 10px;
  background: #fff;
}

/* Make content blocks not stretch overly wide on large screens */
.content-block{
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}


/* --- Hint blocks (Weiterführend) --- */
.content-block.hint{
  max-width: 980px;
  margin: 14px auto 8px;
  padding: 12px 14px;
  border: 1px solid rgba(0,0,0,.08);
  border-left: 4px solid rgba(0,0,0,.18);
  border-radius: 10px;
  background: rgba(255,255,255,.75);
}
.content-block.hint p{ margin: 0; }
.content-block.hint a{ text-decoration: underline; }


/* --- Card headline wrapping fix --- */
.tile h2,
.card h2 {
  hyphens: auto;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.25;
}




/* --- Weiterführend Optik (einheitlich & dezent) --- */
.content-block.hint.weiterfuehrend{
  max-width: 980px;
  margin: .9rem auto 1.4rem;
  padding: .75rem .95rem;
  border-left: 3px solid rgba(0,0,0,.10);
  background: linear-gradient(0deg, rgba(0,0,0,.02), rgba(0,0,0,.02));
  border-radius: 10px;
}

.content-block.hint.weiterfuehrend p{
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .2rem .55rem;
  font-size: .95rem;
  line-height: 1.35;
}

.content-block.hint.weiterfuehrend strong{
  margin-right: .15rem;
  white-space: nowrap;
}

.content-block.hint.weiterfuehrend a{
  white-space: nowrap;
  text-decoration: none;
  border-bottom: 1px dotted rgba(0,0,0,.35);
}

.content-block.hint.weiterfuehrend a:hover{
  border-bottom-style: solid;
}


/* --- Stabiler Seitenlayout-Shift (immer Scrollbar reservieren) --- */
html {
  overflow-y: scroll;
}


/* --- Scrollbar stabil (file:// & http) --- */
html, body {
  overflow-y: scroll;
}
html {
  scrollbar-gutter: stable;
}


/* --- Modern background + section rhythm + cards (subtle) --- */
:root{
  --page-bg: rgba(0,0,0,0.012);
  --section-alt-bg: rgba(0,0,0,0.018);
  --card-bg: #fff;
  --card-border: rgba(0,0,0,0.08);
  --card-shadow: 0 10px 24px rgba(0,0,0,0.06);
}

body{
  background: var(--page-bg);
}

/* sections */
.section{
  padding: 72px 0;
}
.section.alt{
  background: var(--section-alt-bg);
}

/* containers feel calmer on wide screens */
.container{
  max-width: 1180px;
}

/* cards / tiles */
.tile{
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  box-shadow: var(--card-shadow);
}
.tile p{
  line-height: 1.55;
}

/* headings spacing */
h1, .h1{
  margin-bottom: 14px;
}
h2{
  margin-top: 0;
  margin-bottom: 14px;
}


/* --- Startseite Hero Top: refined, no-image, subtle CTA --- */
#hero-top{
  padding-top: 34px;
  padding-bottom: 14px;
}
#hero-top .kicker{
  display:inline-block;
  font-size: .92rem;
  letter-spacing: .02em;
  opacity: .85;
  margin-bottom: 10px;
}
#hero-top h1{
  font-weight: 600;
  line-height: 1.08;
  margin-top: 8px;
  margin-bottom: 14px;
}
#hero-top .hero-copy{
  max-width: 100%;
}
#hero-top .hero-copy p{
  margin: 0 0 12px 0;
}
#hero-top .hero-ctas{
  display:flex;
  gap: 12px 14px;
  flex-wrap: wrap;
  margin-top: 10px;
}
#hero-top .hero-ctas a{
  display:inline-block;
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(255,255,255,0.70);
  text-decoration:none;
}
#hero-top .hero-ctas a:hover{
  background: rgba(255,255,255,0.90);
}

/* --- Hero top cleanup: consistent left edge, no CTA --- */
#hero-top .hero-copy{max-width: 860px;}
#hero-top .hero-copy p{max-width: 860px;}
#hero-top .hero-ctas{display:none !important;}


/* --- Einheitliche Weiterführend-Logik (visuell) --- */
.weiterfuehrend{
  margin-top: 28px;
  padding-top: 16px;
  border-top: 1px solid rgba(0,0,0,0.12);
  font-size: 0.95rem;
}
.weiterfuehrend span{
  font-weight: 600;
  margin-right: 8px;
}
.weiterfuehrend a{
  text-decoration: none;
  margin-right: 14px;
}
.weiterfuehrend a:after{
  content: "→";
  margin-left: 4px;
}


/* --- Navigation: modern, ruhig, mit Dropdowns --- */
.nav{
  display:flex;
  align-items:center;
  gap: 18px;
  flex-wrap: wrap;
}
.nav a{
  text-decoration:none;
  padding: 8px 10px;
  border-radius: 10px;
}
.nav a:hover{
  background: rgba(255,255,255,0.65);
}
.nav-dd{
  position: relative;
  display: inline-flex;
  align-items: center;
}
.dd-menu{
  position:absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 260px;
  display:none;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.10);
  background: rgba(255,255,255,0.96);
  box-shadow: 0 16px 32px rgba(0,0,0,0.08);
  z-index: 50;
}
.dd-menu a{
  display:block;
  padding: 8px 10px;
  border-radius: 10px;
}
.nav-dd:hover .dd-menu,
.nav-dd:focus-within .dd-menu{
  display:block;
}
.dd-trigger:after{
  content:"▾";
  margin-left: 6px;
  font-size: .85em;
  opacity: .7;
}
@media (max-width: 980px){
  .dd-menu{ position: static; display:none; box-shadow:none; border:none; padding:0; background: transparent; }
  .dd-trigger:after{ content:""; }
  .nav-dd{ display:block; width:100%; }
  .dd-menu a{ padding-left: 18px; }
}

  .nav-dd{ display:block; width:100%; }
  .dd-menu a{ padding-left: 18px; }
}

/* Startseite: dezente Linkpfade in Kacheln */
.tile .small a{
  text-decoration:none;
  border-bottom:1px dotted rgba(0,0,0,.35);
}
.tile .small a:hover{
  border-bottom-style: solid;
}


/* --- Einheitliches Lesetempo für textlastige Seiten --- */
.section{
  padding: clamp(48px, 6vw, 88px) 0;
}
.section .lead{
  max-width: 780px;
  margin-bottom: 28px;
}
.container > h2{
  margin-bottom: 18px;
}
.container > h2 + p,
.container > h2 + .lead{
  margin-top: 8px;
}
.container p{
  max-width: 780px;
}
.card{
  padding: 22px 22px 24px;
}
.card h3{
  margin-bottom: 8px;
}
.card p{
  margin-bottom: 0;
}
.text-block{
  max-width: 780px;
}


/* --- Links (Textpfade) sichtbarer: Weiterführend + "Zum Thema" --- */
.weiterfuehrend a,
.tile .small a,
.card .small a{
  font-weight: 600;
  border-bottom: 2px solid rgba(0,0,0,0.28);
  padding-bottom: 1px;
}
.weiterfuehrend a:hover,
.tile .small a:hover,
.card .small a:hover{
  border-bottom-color: rgba(0,0,0,0.55);
}
.weiterfuehrend{
  background: rgba(255,255,255,0.65);
}


/* --- Startseite: Puzzle-System-Block (sichtbar, ruhig, ohne Interaktivität) --- */
.puzzle-system .container{
  display: grid;
  grid-template-columns: minmax(260px, 420px) 1fr;
  gap: 28px;
  align-items: start;
}
.puzzle-system .puzzle-visual{
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
}
.puzzle-system .puzzle-svg{
  width: 100%;
  max-width: 420px;
  height: auto;
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(0,0,0,0.08);
}
.puzzle-system .puzzle-text p{
  max-width: 780px;
  margin: 0 0 12px 0;
}
@media (max-width: 980px){
  .puzzle-system .container{ grid-template-columns: 1fr; }
  .puzzle-system .puzzle-svg{ max-width: 520px; }
}

/* Puzzle image (transparent PNG) */
.puzzle-system .puzzle-img{
  width: 100%;
  max-width: 420px;
  height: auto;
  display:block;
}

/* Leistungen – Hand01 kleiner & weiter oben */
.hand01-top img{
  max-width: 360px;
  margin-top: -20px;
}
@media (max-width: 980px){
  .hand01-top img{
    max-width: 260px;
    margin-top: 0;
  }
}


/* Leistungen – Intro Layout */
.leistungen-header{
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 32px;
  align-items: start;
}

/* Leistungen – Kacheln direkt unter dem Intro (ohne doppelten Titel/Text) */
.leistungen-intro{padding-bottom:28px}
.leistungen-cards{padding-top:34px;border-top:0}
.leistungen-image img{
  max-width: 300px;
}
.leistungen-text h1{
  margin-top: 0;
}
.leistungen-text .lead{
  max-width: 720px;
}

@media (max-width: 900px){
  .leistungen-header{
    grid-template-columns: 1fr;
  }
  .leistungen-image img{
    max-width: 240px;
    margin-bottom: 12px;
  }
}

/* Language switcher (scaffold) */
.lang-switch{display:inline-flex;align-items:center;gap:8px;margin-right:10px;font-size:12px}
.lang-switch .lang{padding:4px 8px;border-radius:999px;text-decoration:none;color:inherit;border:1px solid rgba(0,0,0,.18)}
.lang-switch .lang.is-active{font-weight:700}
.lang-switch .lang-sep{opacity:.4}


/* === Visual Refinement Option 2 (balanced) === */
:root{
  --accent-strong:#2f6fd6; /* stronger blue */
  --accent-soft:#eaf1ff;
  --card-border:#dbe6ff;
  --cta-bg:#1f57b8;
  --cta-bg-hover:#2f6fd6;
}

/* Headings markers */


/* Cards differentiation */
.card{
  border:1px solid var(--card-border);
}



/* Links */
a{
  color:var(--accent-strong);
}
a:hover{
  text-decoration:underline;
}

/* CTA buttons */
.btn, .cta, .search-fab{
  background:var(--cta-bg);
  color:#fff;
}
.btn:hover, .cta:hover, .search-fab:hover{
  background:var(--cta-bg-hover);
}


/* === Visual Refinement Alternative B: Top Accent, No Left Stripe === */
.card.primary{
  border:1px solid var(--card-border);
  border-top:4px solid var(--accent-strong);
  background:#ffffff;
}

.note{
  background:var(--accent-soft);
  border:1px solid var(--card-border);
  border-top:4px solid var(--accent-strong);
  padding: 12px 14px;
  border-radius: 12px;
  margin-top: 8px;
}


/* === Cleanup: remove short horizontal markers on pages with top accents === */
h2::after{
  content:none !important;
  display:none !important;
}

/* === Remove header accent lines on structure pages === */
.page-header h1::after,
.page-intro::before,
.page-intro::after{
  content:none !important;
  display:none !important;
}

/* Remove blue intro background bars */
.page-intro,
.intro,
.header-intro{
  background:transparent !important;
  border:none !important;
}


/* === Global cleanup: remove all short underline markers under H1/H2 === */
h1::after,
.page-header h1::after,
.header h1::after{
  content:none !important;
  display:none !important;
  height:0 !important;
  border:none !important;
}

/* hero-spacing-adjust */
.home .hero,
.home .hero-section,
.home .page-hero{
  padding-top: clamp(2rem, 4vw, 3.5rem);
  margin-top: 0;
}

/* puzzle-spacing-adjust */
/* Reduce bottom spacing of puzzle block on homepage */
.home .puzzle,
.home .puzzle-block,
.home .puzzle-section{
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  padding-bottom: 0;
}

/* Slightly reduce puzzle image size to hint scroll */
.home .puzzle img,
.home .puzzle-block img,
.home .puzzle-section img{
  max-width: 92%;
  height: auto;
}

/* partner-highlight: safe emphasis without layout impact */
.partner-highlight{
  font-weight: 600;
  color: inherit;
}


/* Mobile nav accordion */
@media (max-width: 980px){
  .mobile-nav-inner{gap:4px}
  .mnav-group{border-top:1px solid var(--border); padding-top:6px; margin-top:6px}
  .mnav-toggle{width:100%; display:flex; justify-content:space-between; align-items:center; padding:10px; border-radius:12px; border:1px solid var(--border); background:#fff; cursor:pointer; font:inherit; color:var(--text)}
  .mnav-toggle:after{content:"▾"; opacity:.75}
  .mnav-group.is-open .mnav-toggle:after{content:"▴"}
  .mnav-sub{display:none; padding:6px 0 0 10px}
  .mnav-group.is-open .mnav-sub{display:block}
  .mnav-sub a{display:block; padding:9px 10px; border-radius:12px}
}

@media (min-width: 1100px){
  .nav{flex-wrap:nowrap;}
}


/* ===== Navigation: device-capability split =====
   Desktop (mouse/trackpad): keep the classic top navigation + hover dropdowns.
   Mobile/Touch: use the mobile toggle/accordion (no hover-only submenus).
*/
@media (hover:hover) and (pointer:fine){
  .nav{display:flex !important;}
  .nav-toggle{display:none !important;}
  #mobile-nav{display:none !important;}
}
@media (hover:none) and (pointer:coarse){
  .nav{display:none !important;}
  .nav-toggle{display:inline-flex !important;}
  #mobile-nav{display:block !important;}
  /* never show desktop hover dropdowns on touch */
  nav ul ul{display:none !important;}
}


/* Contact form */
.contact-form-block{max-width:760px;margin:32px auto;padding:22px;border:1px solid rgba(0,0,0,.08);border-radius:16px;background:#fff;box-shadow:0 6px 18px rgba(0,0,0,.06);}
.contact-form-block .lead{margin-top:6px;margin-bottom:16px;}
.contact-form{display:block;}
.contact-form .form-row{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;}
.contact-form label{font-weight:600;}
.contact-form input,.contact-form textarea{border:1px solid rgba(0,0,0,.2);border-radius:12px;padding:10px 12px;font:inherit;max-width:100%;}
.contact-form textarea{resize:vertical;min-height:120px;}
.contact-form .form-hint{font-size:.92rem;opacity:.85;margin-top:12px;line-height:1.35;}
.hp-field{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}


.seo-anchor{max-width:980px;margin:12px 0 0;opacity:.95;line-height:1.45;font-size:0.98rem;}
.ems-clarify{font-size:.9rem;opacity:.8;margin:12px 0;}


/* SEO anchor: keep aligned with hero text (no centering) */
#hero-top .seo-anchor{max-width:980px;margin:12px 0 0;opacity:.95;line-height:1.45;font-size:0.98rem;}



/* HERO width + line break consistency (Phase 1) */
.hero .container,
.hero .hero-inner,
.hero .hero-content,
.hero .hero-copy,
.hero .hero-text{
  max-width: 1200px;
}
@media (max-width: 1240px){
  .hero .container,
  .hero .hero-inner,
  .hero .hero-content,
  .hero .hero-copy,
  .hero .hero-text{
    max-width: calc(100% - 64px);
  }
}
@media (max-width: 720px){
  .hero .container,
  .hero .hero-inner,
  .hero .hero-content,
  .hero .hero-copy,
  .hero .hero-text{
    max-width: calc(100% - 32px);
  }
}
/* spacing after inserted SEO anchor */
.seo-anchor{margin:12px 0 18px !important; max-width: none !important;}


/* Layout: keep hero headline in exactly 2 lines on desktop */
.nowrap-desktop{white-space:nowrap;}
@media (max-width: 980px){
  .nowrap-desktop{white-space:normal;}
}
/* Ensure hero paragraphs wrap naturally */
.hero .hero-content p{white-space:normal;}


.cta-grid{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 0;}
.cta-grid .mobile-sub{display:block;padding:6px 0 6px 18px;font-size:0.95em;opacity:0.9;}


/* Dropdown usability: keep menu open while moving mouse */
.dd-menu::before{content:"";position:absolute;left:0;right:0;top:-10px;height:10px;}
.nav-dd{padding-bottom:8px;}


/* SEO Brand Kicker (Hero) – refined (subtle, aligned) */
.hero-kicker{
  display:inline-block !important;
  visibility:visible !important;
  opacity:1 !important;
  position:relative;
  z-index:2;
  margin: 0 0 10px 0; /* slightly tighter to H1 */
  padding: 0;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: rgba(60, 90, 130, 0.75); /* calmer blue-grey */
  background: transparent;
  border: none;
  border-radius: 0;
  max-width: none;
  line-height: 1.2;
}

/* keep it from looking like a bar if other styles apply */




/* CTA banner – refined (looks like a card, not a field) */
.cta{
  max-width:1120px;
  margin: 18px auto 0;
  padding: 16px 22px;
  border-radius: 16px;
  border:1px solid rgba(22,74,159,.30);
  background: rgba(22,74,159,.045);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
  transition: transform .15s ease, background-color .15s ease, box-shadow .15s ease;
}
.cta:hover{
  background: rgba(22,74,159,.06);
  box-shadow: 0 14px 32px rgba(0,0,0,.07);
  transform: translateY(-1px);
}
.cta a{
  display:block;
  color: rgba(22,74,159,.95);
  font-weight: 700;
  text-decoration: none;
  letter-spacing: .01em;
}
.cta a:hover{ text-decoration: none; }


/* Footer refinement */
footer{
  max-width:1120px;
  margin: 28px auto 0;
  padding: 16px 20px 26px;
  color: rgba(40,50,60,.78);
}
footer .footer-inner, footer .footer-content{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  flex-wrap: wrap;
}
footer, footer p, footer small{
  font-size: 0.92rem;
  line-height: 1.35;
}
footer a{
  color: rgba(22,74,159,.85);
}
footer a:hover{ text-decoration: underline; }
@media (max-width: 720px){
  footer .footer-inner, footer .footer-content{ justify-content:center; }
  footer{ text-align:center; }
}
/* Center common footer text blocks if present */
.footer-text, .copyright, .footer-left{
  text-align: center;
}
.footer-claim{
  display:block;
  margin-top: 8px;
  color: rgba(40,50,60,.70);
}



/* Subtle CTA arrow */
.cta a::after{
  content: " →";
  font-weight: 700;
}





.iso-situative-visual{
  max-width:1120px;
  margin: 18px auto 18px;
}
.iso-situative-visual img{
  width:100%;
  height:auto;
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(0,0,0,.08);
}




.iso-situative-visual{
  max-width:1120px;
  margin: 16px auto 14px;
}
.iso-situative-visual img{
  width:100%;
  height:auto;
  max-height: 260px;
  object-fit: cover;
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(0,0,0,.08);
}


/* ISO 50001 visuals (v3 – less cropping, better rhythm) */
.iso-hero-visual{
  max-width:1120px;
  margin: 14px auto 18px;
}
.iso-hero-visual img{
  width:100%;
  height:auto;
  border-radius: 18px;
  box-shadow: 0 14px 36px rgba(0,0,0,.10);
}

/* Split layout: image left, text right (desktop), stacked (mobile) */
.iso-split{
  max-width:1120px;
  margin: 14px auto 16px;
  display:flex;
  gap: 26px;
  align-items:flex-start;
}
.iso-split-media{
  flex: 0 0 44%;
}
.iso-split-media img{
  width:100%;
  height:auto;
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(0,0,0,.08);
}
.iso-split-text{
  flex: 1 1 auto;
}
@media (max-width: 920px){
  .iso-split{ flex-direction: column; gap: 14px; }
  .iso-split-media{ flex-basis: auto; }
}

/* Keep legacy class usable elsewhere */
.iso-situative-visual{
  max-width:1120px;
  margin: 16px auto 14px;
}
.iso-situative-visual img{
  width:100%;
  height:auto;
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(0,0,0,.08);
}






/* ISO 50001 left anchor layout (v7 – refined, calmer) */
.iso-left-anchor{
  max-width:1120px;
  margin: 24px auto 32px;
  display:grid;
  grid-template-columns: 35% 1fr; /* narrower image column */
  gap: 36px; /* more breathing room */
  align-items:start;
}
.iso-left-media{
  position: sticky;
  top: 96px; /* below header */
}
.iso-left-media img{
  width:100%;
  height:auto;
  border-radius: 12px; /* calmer radius */
  box-shadow: 0 8px 22px rgba(0,0,0,.08); /* softer shadow */
}
.iso-right-flow h2{
  margin-top: 6px;
}
.iso-right-flow p{
  margin-bottom: 14px;
}

@media (max-width: 980px){
  .iso-left-anchor{
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .iso-left-media{
    position: static;
  }
}



/* ISO 50001: Wide content lane that keeps the same left edge as .container and expands only to the right */
.iso-wide{
  width: 100%;
  max-width: 1320px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
}
@media (max-width: 720px){
  .iso-wide{
    max-width: 100%;
    padding-left: 16px;
    padding-right: 16px;
  }
}



/* ISO 50001: image + text flow */
.iso-flow{ position: relative; }
.iso-float{
  float: left;
  width: clamp(300px, 34%, 420px);
  margin: 8px 28px 18px 0;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
}
.iso-float img{
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width: 900px){
  .iso-float{ width: 360px; }
}
@media (max-width: 720px){
  .iso-float{
    float: none;
    width: 100%;
    margin: 12px 0 18px 0;
  }
}
/* clear floats after the flow block */
.iso-flow::after{ content:""; display:block; clear: both; }



/* --- ISO 50001 (Standard) overrides: keep image size, expand text lane --- */
.iso-wide{
  width: 100%;
  max-width: 1320px; /* uses more page width, without touching global container */
  margin: 0 auto;
  padding-left: 24px;
  padding-right: 24px;
}
@media (max-width: 720px){
  .iso-wide{
    max-width: 100%;
    padding-left: 16px;
    padding-right: 16px;
  }
}
.iso-flow{ position: relative; }
.iso-float{
  float: left;
  width: 420px;           /* image size stays stable */
  max-width: 42vw;        /* responsive cap on very small screens */
  margin: 8px 28px 18px 0;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
  background: #fff;
}
.iso-float img{ display:block; width:100%; height:auto; }
@media (max-width: 900px){
  .iso-float{ width: 360px; }
}
@media (max-width: 720px){
  .iso-float{
    float:none;
    width:100%;
    max-width:100%;
    margin: 12px 0 18px 0;
  }
}
.iso-flow::after{ content:""; display:block; clear:both; }
