/*
Theme Name: Savings Partners Landing
Theme URI: https://savings-partners.com/
Author: OpenAI
Description: Minimal custom landing page theme for Savings Partners.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: savingspartners
*/

@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url('assets/fonts/inter-latin-var.woff2') format('woff2');
}

@font-face {
  font-family: 'Inter';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url('assets/fonts/inter-latin-italic-var.woff2') format('woff2');
}


/* ══ TOKENS ══ */
:root {
  --dark:   #202C38;
  --dark2:  #283845;
  --gold:   #AD7E15;
  --goldhi: #D4A82A;
  --light:  #F5F5F0;
  --light2: #ECEAE3;
  --white:  #ffffff;
  --muted:  #7a8a99;
  --text:   #202C38;
  --text-primary: var(--text);
  --text-secondary: #45525d;
  --tr:     0.3s ease;
  /* Vertikaler Rhythmus: strikt, keine Abweichung */
  --section-pad: 100px;
  --section-pad-tight: 80px;
  --section-pad-loose: 120px;
  --r24: 24px;
  --r32: 32px;
  --r48: 48px;
  /* Lesespalte (Prosa / Textblöcke): 600–680px, hier 640px */
  --measure: 640px;
  /* Äußerer Rahmen: zentrierte Seite */
  --container-max: 1200px;
  /* Hero: Headline darf breiter als Lesespalte sein */
  --hero-h1-max: 900px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--text);background:var(--light);overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ══ SCROLL REVEAL ══ */
.reveal{opacity:1;transform:translateY(0);transition:opacity 0.75s ease,transform 0.75s ease;pointer-events:auto}
.reveal.visible{opacity:1;transform:none}
.rd1{transition-delay:.12s}.rd2{transition-delay:.24s}.rd3{transition-delay:.36s}
.rd4{transition-delay:.48s}.rd5{transition-delay:.60s}

/* ══ NAV ══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:#ffffff;
  border-bottom:1px solid rgba(0,0,0,0.06);
  padding:0 var(--r24);
}
.nav-inner{
  max-width:var(--container-max);
  margin:0 auto;
  width:100%;
  height:68px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{display:flex;align-items:center;gap:11px}
.nav-logo-mark{
  width:30px;height:30px;border:1.5px solid var(--gold);background:var(--dark);
  display:flex;align-items:center;justify-content:center;
  transition:background var(--tr);
}
.nav-logo-mark:hover{background:rgba(173,126,21,0.15)}
.nav-logo-mark svg{width:14px;height:14px}
.nav-logo-text{font-size:15px;font-weight:700;color:var(--dark);letter-spacing:-.1px}
.nav-logo-text span{color:var(--gold)}
.nav-logo-sub{font-size:9px;color:rgba(32,44,56,0.5);margin-top:2px;letter-spacing:.3px}
.nav-links{display:flex;align-items:center;gap:24px;list-style:none}
.nav-links a{
  font-size:12.5px;font-weight:600;color:rgba(32,44,56,0.65);
  letter-spacing:.3px;transition:color var(--tr);position:relative;padding-bottom:2px;
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:0;width:0;height:1px;
  background:var(--gold);transition:width var(--tr);
}
.nav-links a:hover{color:var(--dark)}
.nav-links a:hover::after{width:100%}
nav .nav-links a.btn-ghost{
  border-color:rgba(32,44,56,0.2);
  color:rgba(32,44,56,0.88);
  padding:11px 22px;
  font-size:14px;
  font-weight:500;
  letter-spacing:0.01em;
  text-transform:none;
  line-height:normal;
  min-height:44px;
  background:transparent;
  transition:border-color var(--tr),color var(--tr);
}
nav .nav-links a.btn-ghost::after{display:none}
nav .nav-links a.btn-ghost:hover{
  border-color:rgba(32,44,56,0.4);
  color:var(--dark);
  background:transparent;
}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.nav-burger span{display:block;width:22px;height:2px;background:var(--dark);transition:var(--tr)}

/* Mobile-Menü: nur ≤640px sichtbar (Panel per JS .is-open) */
.mobile-nav{display:none}

/* ══ BUTTONS ══ */
.btn-primary{
  background:var(--gold);color:var(--white);
  padding:11px 22px;font-size:14px;font-weight:600;
  letter-spacing:0.01em;text-transform:none;border:none;cursor:pointer;
  transition:background var(--tr);display:inline-flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;
}
.btn-primary:hover{background:var(--goldhi)}
.btn-ghost{
  border:1px solid rgba(32,44,56,0.22);color:var(--dark);
  padding:11px 22px;font-size:14px;font-weight:500;cursor:pointer;
  background:transparent;transition:border-color var(--tr),color var(--tr);
  display:inline-flex;align-items:center;justify-content:center;
  text-transform:none;letter-spacing:0.01em;
}
.btn-ghost:hover{border-color:rgba(32,44,56,0.45);color:var(--dark)}
.btn-dark{
  background:var(--dark);color:var(--white);
  padding:16px 36px;font-size:13px;font-weight:700;
  letter-spacing:1.2px;text-transform:uppercase;border:none;cursor:pointer;
  transition:background var(--tr),transform var(--tr);display:inline-block;
  font-family:'Inter',sans-serif;
}
.btn-dark:hover{background:var(--dark2);transform:translateY(-1px)}

/* ══ SHARED ══ */
/* Breiter, zentrierter Rahmen + schmale Lesespalte (.content / .text-col) */
.section{
  padding:var(--section-pad) 0;
}
.section.tight{
  padding:var(--section-pad-tight) 0;
}
.section.loose{
  padding:var(--section-pad-loose) 0;
}
/* Innerhalb von Sections: nur diese drei Abstände */
.section h2{
  margin-bottom:32px;
}
.section h3{
  margin-bottom:24px;
}
.section p{
  margin-bottom:24px;
}
.section .block{
  margin-bottom:48px;
}
.container{
  max-width:var(--container-max);
  margin:0 auto;
  padding:0 var(--r24);
  width:100%;
  box-sizing:border-box;
}
.text-col{max-width:var(--measure);width:100%}
.content{max-width:var(--measure);width:100%;text-align:left}
.content--wide{max-width:none;width:100%}
.inner{max-width:var(--container-max);margin:0 auto;width:100%}
.eyebrow{
  font-size:11px;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:#8a8a8a;margin-bottom:var(--r24);
  display:flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:'';display:block;width:24px;height:1px;background:var(--gold);
}

/* Image placeholder */
.img-ph{
  background:linear-gradient(135deg,var(--light2),#dddbd3);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;border:1px dashed rgba(32,44,56,0.15);
  position:relative;overflow:hidden;
}
.img-ph::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(0,0,0,0.012) 20px,rgba(0,0,0,0.012) 21px);
}
.img-ph svg{width:28px;height:28px;opacity:.25;position:relative;z-index:1;color:var(--dark)}
.img-ph span{font-size:9.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted);opacity:.55;position:relative;z-index:1;padding:0 20px;text-align:left}

.img-ph-dark{
  background:linear-gradient(135deg,var(--dark2),var(--dark));
  border:1px dashed rgba(255,255,255,0.1);
}
.img-ph-dark svg{color:rgba(255,255,255,0.3)}
.img-ph-dark span{color:rgba(255,255,255,0.3)}
.img-ph-dark::before{background:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(255,255,255,0.01) 20px,rgba(255,255,255,0.01) 21px)}

.hero-top{
  display:grid;
  grid-template-columns:minmax(0,var(--measure)) minmax(280px,1fr);
  gap:var(--r32);
  align-items:end;
  margin-bottom:var(--r48);
}
.hero-copy{min-width:0;}
.hero-visual{
  min-width:0;
  align-self:end;
}
.hero-visual-frame{
  position:relative;
  width:100%;
  aspect-ratio:1 / 1;
  border-radius:0 !important;
  overflow:hidden;
  box-shadow:0 24px 60px rgba(32,44,56,0.16);
  background:rgba(32,44,56,0.04);
}
.hero-visual-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
}

/* Giant headline */

.hero-h1 em{color:var(--gold);font-style:normal}

/* ══════════════════════════════════════════
   PROBLEM
══════════════════════════════════════════ */
#problem{background:#ffffff}

.problem-stack{
  display:flex;
  flex-direction:column;
  gap:0;
}

.problem-header{
  margin:0;
}

.problem-header h2{
  font-size:clamp(32px,4vw,52px);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-0.02em;
  color:var(--dark);
  max-width:var(--measure);
}

/* Headline → Frage → Problem 1–3 */
.problem-hook{
  margin:0;
  padding:0;
  background:transparent;
  border:none;
}

.problem-hook p{
  font-size:22px;
  line-height:1.5;
  max-width:var(--measure);
  font-weight:600;
  font-style:italic;
  color:var(--dark);
}

.problem-items{
  display:flex;
  flex-direction:column;
  gap:0;
  margin:0;
  padding:0;
}

.problem-item{
  display:block;
  max-width:var(--measure);
  padding:0;
  border:none;
}

.problem-item h3{
  font-size:22px;
  line-height:1.3;
  font-weight:600;
  color:var(--dark);
  margin:0 0 24px;
}

.problem-item:first-child h3{
  font-size:28px;
  line-height:1.25;
  font-weight:600;
}

.problem-item p{
  font-size:clamp(16px,1.9vw,18px);
  line-height:1.65;
  color:var(--muted);
}

.problem-item:first-child p{
  font-size:18px;
  line-height:1.65;
}

.problem-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:var(--r48);align-items:stretch;
}
.problem-img-wrap{display:flex;flex-direction:column;align-self:stretch}
.problem-img{flex:1;min-height:380px;border-radius:2px}

/* ══════════════════════════════════════════
   POSITIONIERUNG (#quote)
══════════════════════════════════════════ */
#quote{
  background:var(--dark);
}

.quote-inner{
  max-width:100%;margin:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:clamp(24px,4vw,36px);
}

.quote-photo{
  width:280px;height:340px;
  flex-shrink:0;
  overflow:hidden;
  border-radius:2px;
}

.quote-body{}

#quote .quote-position-h2{
  margin:0;
  max-width:640px;
  font-size:clamp(28px,3.2vw,40px);
  font-weight:700;
  line-height:1.2;
  letter-spacing:-0.02em;
  color:#ffffff;
}

#quote .quote-position-sub{
  margin:0;
  max-width:640px;
}

#quote .quote-text{
  font-size:clamp(17px,2vw,20px);
  font-weight:400;
  font-style:normal;
  color:rgba(255,255,255,0.82);
  line-height:1.65;
  letter-spacing:0;
  max-width:640px;
  margin:0;
}

/* ══════════════════════════════════════════
   SOLUTION — split into 2 subsections
══════════════════════════════════════════ */

/* 5a: Value proposition — stacked image → copy, white ground */
#value{background:var(--white)}

.value-header{
  display:block;
  margin-bottom:0;
}
.value-header h2{
  font-size:clamp(32px,4vw,52px);
  font-weight:700;line-height:1.15;letter-spacing:-.5px;
  color:var(--dark);
}
.value-header-right p{
  font-size:16px;color:var(--muted);line-height:1.8;
}
.value-header-right strong{color:var(--dark);font-weight:600}

/* 5b: Process — ruhiger weißer Grund (Linear-Layout s. Dateiende #process .process-core) */
#process{
  background:var(--white);
  background-image:none;
  color:var(--text);
  transition:none;
}

.process-header{margin-bottom:48px}
.process-header h2{
  font-size:clamp(32px,4vw,52px);
  font-weight:700;line-height:1.15;letter-spacing:-.5px;
  color:var(--dark);max-width:640px;
}
.process-header p{
  font-size:16px;color:var(--muted);line-height:1.75;
  max-width:var(--measure);margin-top:var(--r24);
}

.process-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:24px;margin-bottom:24px;
}

.pv-step{
  background:var(--light);
  overflow:hidden;
  transition:box-shadow 0.4s ease;
  display:flex;flex-direction:column;
  box-shadow:0 2px 16px rgba(32,44,56,0.08);
}
.pv-step:hover{box-shadow:0 12px 40px rgba(32,44,56,0.14)}

.pv-step-img{
  height:240px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;position:relative;overflow:hidden;
}
.pv-step-img .ph-icon{width:28px;height:28px;opacity:.25;position:relative;z-index:1;color:var(--dark)}
.pv-step-img-label{
  font-size:9.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--muted);opacity:.5;position:relative;z-index:1;padding:0 20px;text-align:left;
}

.pv-step-body{padding:28px 28px 32px;display:flex;flex-direction:column;gap:10px;background:#ffffff;border-top:1px solid rgba(32,44,56,0.08);}

.pv-step-tag{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--gold);font-size:9px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  align-self:flex-start;
}
.pv-step-tag::before{content:'';width:12px;height:1px;background:var(--gold)}

.pv-step-title{
  font-size:17px;font-weight:700;color:var(--dark);
  display:flex;align-items:center;gap:12px;
}
.pv-step-title-num{
  width:30px;height:30px;border-radius:50%;
  border:1.5px solid rgba(32,44,56,0.25);background:transparent;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;color:var(--dark);flex-shrink:0;
}
.pv-step-desc{font-size:13px;color:var(--muted);line-height:1.7}

.results-bar{
  background:var(--dark);padding:22px 32px;
  display:flex;align-items:center;flex-wrap:wrap;gap:10px;
}
.rb-label{font-size:9px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.4);white-space:nowrap;margin-right:0;padding-right:24px;border-right:1px solid rgba(255,255,255,0.12);}
.rb-div{width:4px;height:4px;border-radius:50%;background:rgba(173,126,21,0.4);margin:0 20px;flex-shrink:0;}
.rb-item{font-size:12px;font-weight:600;color:rgba(255,255,255,0.5);display:flex;align-items:center;gap:6px;letter-spacing:.3px;}
.rb-item::before{content:'✓';color:rgba(255,255,255,0.35);font-size:11px;font-weight:700}

/* ══════════════════════════════════════════
   ABOUT
══════════════════════════════════════════ */
#about{background:#ffffff}

/* Essay layout: Lesespalte + Portrait-Spalte */
#about .container{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,320px);
  gap:80px;
  align-items:start;
}
#about .text-col{
  min-width:0;
}
#about .portrait{
  min-width:0;
}
#about .portrait img{
  display:block;
  width:100%;
  max-width:320px;
  height:auto;
  object-fit:cover;
  object-position:center top;
}

#about .about-intro{
  margin-bottom:clamp(40px,6vw,64px);
  max-width:640px;
}

#about .about-statement{
  font-size:clamp(32px,4vw,52px);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-0.5px;
  color:var(--dark);
  margin:0;
}

#about .about-statement__brand{
  color:var(--gold);
}

#about .about-explain{
  max-width:640px;
  width:100%;
}

#about .about-copy{
  margin:0 0 20px;
  font-size:18px;
  line-height:1.72;
  color:var(--text-secondary);
  max-width:640px;
}

#about .about-explain .about-copy:last-child{
  margin-bottom:0;
}

#about .about-signoff{
  margin-top:0;
  margin-bottom:24px;
  max-width:640px;
}

#about .signature{
  margin-top:32px;
  font-size:clamp(18px,2vw,22px);
  font-weight:600;
  line-height:1.3;
  letter-spacing:-0.02em;
  color:var(--dark);
}

#about .about-contact{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:4px;
  margin-top:12px;
  margin-bottom:0;
}

#about .about-contact .link-muted{
  text-transform:lowercase;
  letter-spacing:0.02em;
}

.about-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:stretch;
}

.about-left{display:flex;flex-direction:column}

.about-founder-row{display:flex;align-items:flex-start;gap:24px;margin-bottom:28px}

.about-name{font-size:22px;font-weight:700;color:var(--dark);margin-bottom:3px;letter-spacing:-.3px}
.about-role{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.about-bio{font-size:13.5px;color:var(--muted);line-height:1.8}

.about-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  margin-top:auto;padding-top:28px;
}
.about-stat{
  background:var(--dark);padding:16px 18px;
  transition:background var(--tr);
}
.about-stat:hover{background:var(--dark2)}
.about-stat-n{font-size:24px;font-weight:800;color:var(--gold);letter-spacing:-.5px;line-height:1}
.about-stat-l{font-size:10px;color:rgba(255,255,255,0.42);margin-top:4px;line-height:1.4}

.about-right{display:flex;flex-direction:column;gap:16px}

.about-team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%}
.team-card{
  background:var(--dark);padding:20px 14px;text-align:left;
  transition:background var(--tr),transform var(--tr);
}
.team-card:hover{background:var(--dark2);transform:translateY(-2px)}
.team-photo{
  width:52px;height:52px;border-radius:50%;
  border:1.5px solid var(--gold);
  background:linear-gradient(135deg,var(--dark2),var(--dark));
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:var(--gold);
  margin:0 auto 12px;
}
.team-name{font-size:11px;font-weight:600;color:var(--white);margin-bottom:3px;line-height:1.3}
.team-role{font-size:10px;color:rgba(255,255,255,0.32)}

/* ══════════════════════════════════════════
   CASE STUDIES
══════════════════════════════════════════ */
.case-card{
  background:#ffffff;
  border:1px solid rgba(32,44,56,0.1);
  display:flex;flex-direction:column;
  transition:box-shadow 0.4s ease;
  pointer-events:auto;
  height:100%;
  box-sizing:border-box;
  box-shadow:0 2px 12px rgba(32,44,56,0.07);
}
.case-card:hover{box-shadow:0 6px 24px rgba(32,44,56,0.12)}
.case-header{
  background:#ffffff;
  padding:28px 28px 20px;
  border-top:none;
  cursor:pointer;user-select:none;position:relative;
  height:168px;
  display:flex;flex-direction:column;
  justify-content:flex-start;
  box-sizing:border-box;
}
.case-header:hover .case-toggle{color:var(--dark)}
.case-number{font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(32,44,56,0.35);margin-bottom:8px}
.case-title{font-size:17px;font-weight:700;color:var(--dark);line-height:1.3;letter-spacing:-.2px;margin-bottom:10px;padding-right:32px}
.case-company{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.3px}
.case-company svg{width:13px;height:13px;flex-shrink:0;opacity:.5}
.case-toggle{
  position:absolute;top:28px;right:24px;
  width:28px;height:28px;border-radius:50%;
  border:1px solid rgba(32,44,56,0.2);
  display:flex;align-items:center;justify-content:center;
  color:rgba(32,44,56,0.4);
  transition:color 0.3s,border-color 0.3s,transform 0.35s ease;
  flex-shrink:0;
}
.case-toggle svg{width:14px;height:14px;transition:transform 0.35s ease}
.case-card.open .case-toggle{border-color:var(--dark);color:var(--dark)}
.case-card.open .case-toggle svg{transform:rotate(45deg)}
.case-kpis{background:var(--dark);padding:20px 28px;display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid rgba(32,44,56,0.08);border-bottom:1px solid rgba(32,44,56,0.08);height:80px;box-sizing:border-box;align-items:center;}
.case-kpi{display:flex;align-items:center;gap:12px;padding:0;height:100%}
.case-kpi:first-child{border-right:1px solid rgba(255,255,255,0.08);padding-right:20px;margin-right:4px}
.case-kpi-icon{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center}
.case-kpi-icon svg{width:15px;height:15px;color:rgba(255,255,255,0.5)}
.case-kpi-val{font-size:18px;font-weight:800;color:var(--white);letter-spacing:-.5px;line-height:1;margin-bottom:3px}
.case-kpi-lbl{font-size:9.5px;color:rgba(255,255,255,0.45);line-height:1.3}
.case-body{
  padding:0 28px;display:flex;flex-direction:column;gap:20px;
  max-height:0;overflow:hidden;
  transition:max-height 0.5s ease, padding-top 0.4s ease, padding-bottom 0.4s ease;
}
.case-card.open .case-body{
  max-height:800px;
  padding-top:24px;
  padding-bottom:24px;
}
.case-field-label{display:flex;align-items:center;gap:7px;font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);opacity:0.6;margin-bottom:8px}
.case-field-label svg{width:13px;height:13px;flex-shrink:0}
.case-field-text{font-size:13px;color:var(--muted);line-height:1.7;padding-left:20px;border-left:1px solid rgba(32,44,56,0.12)}

/* ══════════════════════════════════════════
   PRICING + CALCULATOR
══════════════════════════════════════════ */
#pricing{background:var(--white);color:var(--text)}

.pricing-header{margin-bottom:48px}
.pricing-header h2{
  font-size:clamp(32px,4vw,52px);
  font-weight:700;line-height:1.15;letter-spacing:-.5px;
  color:var(--white);max-width:var(--measure);
}
.pricing-header p{font-size:16px;color:rgba(255,255,255,0.42);line-height:1.75;max-width:var(--measure);margin-top:var(--r24)}

.pricing-model{
  display:grid;grid-template-columns:1fr auto 1fr;
  gap:0;margin-bottom:48px;align-items:stretch;
}
.pricing-plus{
  display:flex;align-items:center;justify-content:center;
  font-size:28px;font-weight:300;color:rgba(255,255,255,0.2);
  padding:0 24px;
}
.pricing-card{
  background:rgba(255,255,255,0.04);
  border-top:1px solid rgba(255,255,255,0.08);
  padding:36px 32px;
  transition:background var(--tr);
  display:flex;flex-direction:column;justify-content:space-between;
}
.pricing-card:hover{background:rgba(255,255,255,0.07)}
.pricing-card h3{font-size:20px;font-weight:700;color:var(--white);margin-bottom:10px;letter-spacing:-.2px}
.pricing-card p{font-size:13.5px;color:rgba(255,255,255,0.42);line-height:1.7;margin-bottom:18px}
.pricing-tag{
  display:inline-block;border:1px solid rgba(255,255,255,0.2);
  color:rgba(255,255,255,0.45);font-size:9px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;padding:5px 12px;
}

/* Calculator */
.calc-wrap{
  background:var(--light);
  padding:48px;
}

.calc-top{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:40px;flex-wrap:wrap;gap:8px;
}
.calc-top h3{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,0.4)}
.calc-top p{font-size:12px;color:var(--muted);font-style:italic}

.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.calc-inputs{display:flex;flex-direction:column;gap:36px}

.calc-field label{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:11px;font-weight:700;color:var(--muted);
  letter-spacing:.8px;text-transform:uppercase;margin-bottom:16px;
}
.calc-field label span{font-size:22px;font-weight:800;color:var(--dark);letter-spacing:-.5px;text-transform:none}

input[type="range"]{
  -webkit-appearance:none;width:100%;height:3px;
  background:rgba(32,44,56,0.15);outline:none;cursor:pointer;border-radius:2px;
}
input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:var(--dark);cursor:pointer;border:2px solid var(--light);
  box-shadow:0 0 0 4px rgba(32,44,56,0.15);transition:box-shadow var(--tr);
}
input[type="range"]::-webkit-slider-thumb:hover{box-shadow:0 0 0 6px rgba(32,44,56,0.2)}
input[type="range"]::-moz-range-thumb{
  width:20px;height:20px;border-radius:50%;
  background:var(--dark);cursor:pointer;border:2px solid var(--light);
}
.range-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);margin-top:8px;opacity:.55}

.calc-results{background:var(--dark);padding:32px;position:relative}
.calc-results::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:rgba(255,255,255,0.08)}
.calc-results h4{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:24px}

.cr-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.05);font-size:13px;
}
.cr-row:last-child{border-bottom:none}
.cr-lbl{color:rgba(255,255,255,0.42)}
.cr-val{color:var(--white);font-weight:600;text-align:right}

.cr-row.hl-savings{background:rgba(255,255,255,0.05);margin:8px -32px 0;padding:14px 32px;border:none}
.cr-row.hl-savings .cr-lbl{color:rgba(255,255,255,0.7);font-weight:600;font-size:13.5px}
.cr-row.hl-savings .cr-val{color:var(--white);font-weight:800;font-size:18px}

.cr-row.hl-net{padding:14px 0 0;border:none}
.cr-row.hl-net .cr-lbl{color:rgba(255,255,255,0.7);font-weight:600;font-size:13.5px}
.cr-row.hl-net .cr-val{color:var(--white);font-weight:800;font-size:18px}

.calc-disclaimer{margin-top:16px;font-size:10.5px;color:rgba(255,255,255,0.2);line-height:1.6;font-style:italic}

.pricing-note{
  font-size:14px;color:rgba(255,255,255,0.38);line-height:1.75;
  text-align:left;margin-top:var(--r32);
}
.pricing-note strong{color:rgba(255,255,255,0.7)}

/* ══════════════════════════════════════════
   CONTACT
══════════════════════════════════════════ */
#contact{background:#ffffff}
#contact .content{text-align:left}
.contact-h2{
  font-size:clamp(32px,3vw,40px);
  font-weight:700;line-height:1.15;letter-spacing:-.5px;
  color:var(--dark);
}
.contact-sub-wrap{max-width:640px;width:100%}
.contact-sub{
  font-size:17px;color:var(--muted);line-height:1.75;max-width:640px;
}
#contact .contact-calendly-trigger{
  display:inline;
  margin:0;padding:0;border:0;background:none;
  font:inherit;font-size:17px;font-weight:600;line-height:1.65;
  color:var(--gold);text-align:left;text-decoration:underline;
  text-underline-offset:0.2em;cursor:pointer;
  transition:color var(--tr);
}
#contact .contact-calendly-trigger:hover{color:var(--goldhi)}

.calendly-wrap{background:var(--white);padding:48px;border:1px solid rgba(32,44,56,0.08)}
.calendly-ph{display:flex;flex-direction:column;align-items:flex-start;gap:var(--r24);padding:var(--r48) 0;color:var(--muted)}
.calendly-ph svg{width:44px;height:44px;opacity:.25}
.calendly-ph p{font-size:14px;line-height:1.65;text-align:left;max-width:var(--measure)}
.calendly-ph code{
  display:block;background:var(--light);border:1px solid var(--light2);
  padding:12px 20px;font-size:11.5px;font-family:monospace;color:var(--dark);
  margin-top:6px;width:100%;text-align:left;
}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
footer{background:var(--dark);padding:var(--r48) var(--r24) var(--r32)}
.footer-inner{max-width:var(--container-max);margin:0 auto;width:100%}
.footer-top{
  display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:var(--r48);
  padding-bottom:var(--r32);border-bottom:1px solid rgba(255,255,255,0.07);margin-bottom:var(--r24);
}
.footer-brand p{font-size:13px;color:rgba(255,255,255,0.32);line-height:1.75;margin-top:14px;max-width:var(--measure)}
.footer-col h4{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,0.4);transition:color var(--tr)}
.footer-col ul li a:hover{color:var(--white)}
.footer-contact p{font-size:13px;color:rgba(255,255,255,0.4);line-height:1.9}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:11.5px;color:rgba(255,255,255,0.2)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:11.5px;color:rgba(255,255,255,0.28);transition:color var(--tr)}
.footer-legal a:hover{color:rgba(255,255,255,0.7)}

/* ══ MODALS ══ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:200;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal-box{background:var(--white);max-width:var(--measure);width:100%;max-height:85vh;overflow-y:auto;padding:var(--r48);position:relative}
.modal-box h2{font-size:24px;font-weight:700;color:var(--dark);margin-bottom:28px;padding-bottom:20px;border-bottom:2px solid var(--gold)}
.modal-box h3{font-size:14px;font-weight:600;color:var(--dark);margin:22px 0 8px}
.modal-box p,.modal-box address{font-size:13px;color:#555;line-height:1.8;font-style:normal}
.modal-close{position:absolute;top:20px;right:24px;background:none;border:none;font-size:24px;cursor:pointer;color:var(--muted);transition:color var(--tr)}
.modal-close:hover{color:var(--dark)}

@media(max-width:960px){
  .hero-top{grid-template-columns:1fr;gap:32px;margin-bottom:48px}
  .hero-visual{max-width:100%}
  .problem-layout{grid-template-columns:1fr}
  .quote-inner{gap:28px}
  .quote-photo{width:100%;height:220px}
  .value-header{grid-template-columns:1fr;gap:24px}
  .process-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .pricing-model{grid-template-columns:1fr}
  .calc-grid{grid-template-columns:1fr;gap:36px}
  .footer-top{grid-template-columns:1fr}
  .rb-div{display:none}
  .results-bar{gap:14px;flex-wrap:wrap}
}

@media (max-width: 640px) {
  /* Fixierte Leiste + Ankerziele nicht unter der Bar (nur Mobile) */
  html{
    scroll-padding-top:68px;
  }
  .section{padding:var(--section-pad) 0}
  .container{padding:0 var(--r24)}
  nav{
    padding:0 20px;
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:10000;
  }
  .nav-burger{display:flex}

  .nav-links{
    display:none;
    list-style:none;
    margin:0;
  }

  /* Vollflächige Mobile-Navigation (editorial, ohne Button-Kästen) */
  .mobile-nav{
    display:block;
    position:fixed;
    inset:0;
    z-index:9990;
    background:var(--dark);
    visibility:hidden;
    opacity:0;
    pointer-events:none;
    transition:opacity 0.32s ease,visibility 0.32s ease;
  }
  .mobile-nav.is-open{
    visibility:visible;
    opacity:1;
    pointer-events:auto;
  }
  .mobile-nav-inner{
    padding:120px 32px 80px;
    min-height:100%;
    box-sizing:border-box;
    text-align:left;
  }
  .mobile-nav-main{
    display:flex;
    flex-direction:column;
    gap:32px;
  }
  .mobile-nav .nav-item{
    display:block;
    margin:0;
    padding:0;
    font-size:clamp(17px,4.2vw,20px);
    font-weight:600;
    line-height:1.25;
    letter-spacing:-0.02em;
    color:rgba(255,255,255,0.94);
    text-decoration:none;
    border:none;
    background:transparent;
    opacity:0;
    transform:translateY(14px);
    transition:opacity 0.42s ease,transform 0.42s ease;
  }
  .mobile-nav .nav-item.primary{
    font-size:clamp(20px,5vw,24px);
    font-weight:700;
    color:#ffffff;
  }
  .mobile-nav .nav-item.secondary{
    font-size:clamp(16px,3.8vw,18px);
    font-weight:500;
    color:rgba(255,255,255,0.78);
  }
  .mobile-nav.is-open .mobile-nav-main .nav-item:nth-child(1){opacity:1;transform:none;transition-delay:0.1s}
  .mobile-nav.is-open .mobile-nav-main .nav-item:nth-child(2){opacity:1;transform:none;transition-delay:0.18s}
  .mobile-nav.is-open .mobile-nav-main .nav-item:nth-child(3){opacity:1;transform:none;transition-delay:0.26s}
  .mobile-nav.is-open .mobile-nav-main .nav-item:nth-child(4){opacity:1;transform:none;transition-delay:0.34s}
  .mobile-nav-cta{
    margin-top:80px;
    padding-top:40px;
    border-top:1px solid rgba(255,255,255,0.07);
    opacity:0;
    transform:translateY(14px);
    transition:opacity 0.45s ease,transform 0.45s ease;
  }
  .mobile-nav.is-open .mobile-nav-cta{
    opacity:1;
    transform:none;
    transition-delay:0.42s;
  }
  .mobile-nav-cta .cta-intro-link{
    display:block;
    margin:0 0 16px;
    font-size:15px;
    line-height:1.55;
    font-weight:400;
    color:rgba(255,255,255,0.52);
    text-decoration:underline;
    text-underline-offset:0.18em;
    max-width:320px;
  }
  .mobile-nav-cta .cta-intro-link:hover{
    color:rgba(255,255,255,0.72);
  }
  .mobile-nav-cta .cta-link{
    display:inline;
    margin:0;
    padding:0;
    font-size:16px;
    font-weight:600;
    color:var(--gold);
    text-decoration:underline;
    text-underline-offset:0.2em;
    border:none;
    background:transparent;
  }
  .mobile-nav-cta .cta-link:hover{
    color:var(--goldhi);
  }

  .nav-burger.is-open span:nth-child(1){
    transform:translateY(7px) rotate(45deg);
  }
  .nav-burger.is-open span:nth-child(2){
    opacity:0;
  }
  .nav-burger.is-open span:nth-child(3){
    transform:translateY(-7px) rotate(-45deg);
  }
  .nav-burger span{
    transition:transform 0.25s ease,opacity 0.2s ease;
  }

  @media (prefers-reduced-motion: reduce) {
    .mobile-nav{
      transition:none;
    }
    .mobile-nav .nav-item,
    .mobile-nav-cta{
      transition:none !important;
      transition-delay:0s !important;
    }
    .mobile-nav.is-open .mobile-nav-main .nav-item,
    .mobile-nav.is-open .mobile-nav-cta{
      opacity:1;
      transform:none;
    }
    .nav-burger span{
      transition:none;
    }
  }

  .about-team-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .modal-box{padding:28px 20px}
  .calendly-wrap{padding:28px 20px}
  .calc-wrap{padding:28px 20px}
}

/* Hover-Klassen statt inline onmouseover */
.btn-gold{background:var(--gold);color:#fff;border:none;cursor:pointer;transition:background 0.2s;}
.btn-gold:hover{background:#9a6e1f;}
.btn-ghost{background:#ffffff;border:1px solid rgba(32,44,56,0.1);color:var(--muted);cursor:pointer;transition:border-color 0.2s,color 0.2s;}
.btn-ghost:hover{border-color:rgba(32,44,56,0.3);color:var(--dark);}
.link-muted{font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color 0.2s;}
.link-muted:hover{color:var(--gold);}
/* Focus states */
a:focus-visible,button:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
/* Case cards – keyboard accessible */
.case-header{cursor:pointer;}
.case-header:focus-visible{outline:2px solid var(--gold);outline-offset:-2px;}



.hero-title .line { display: block; }
.hero-title .line-blue { color: inherit; }
.hero-title .line-gold { color: var(--gold, #AD7E15); }


/* Supplier Savings Program: Titel → Intro → Statements → Bild */
#value .value-layout{
  display:flex;
  flex-direction:column;
  gap:48px;
  max-width:100%;
  margin:0;
  align-items:flex-start;
}
#value .value-visual{
  width:100%;
  max-width:var(--measure);
  min-height:0;
  transform:none;
  padding-right:0;
}
#value .value-visual .program-image{
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  aspect-ratio:16/9;
  object-fit:cover;
  object-position:center 58%;
  border:none;
  border-radius:0;
  box-shadow:none;
  transform:none;
  margin-bottom:0;
  filter:brightness(0.94) contrast(1.04) saturate(0.92);
}
#value .value-visual .program-image:hover{
  transform:none;
}
#value .value-copy{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  max-width:var(--measure);
  padding-left:0;
  padding-right:0;
}
#value .value-copy > h2{
  margin-top:0;
}
#value .value-copy-intro{
  margin-top:0;
}

.value-copy-intro,
#quote .quote-position-sub{
  font-size:16px;
  color:var(--muted);
  line-height:1.7;
}
#value .value-statement-line{
  font-size:26px;
  line-height:1.3;
  font-weight:500;
  letter-spacing:-0.01em;
  color:#202C38;
}

/* ══════════════════════════════════════════
   FIT — Passt das zu uns?
══════════════════════════════════════════ */
#fit.section{
  background:var(--dark);
  color:var(--light);
}
#fit .fit-copy{
  max-width:100%;
}
#fit .fit-h2{
  font-size:clamp(26px,3vw,40px);
  font-weight:700;
  line-height:1.2;
  letter-spacing:-0.02em;
  color:var(--light);
}
#fit .fit-points{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
}
#fit .fit-point{
  font-size:17px;
  font-weight:400;
  line-height:1.5;
  color:rgba(255,255,255,0.9);
  margin:0 0 24px;
  padding:0;
  border:none;
}
#fit .fit-point:first-child{
  font-size:18px;
  font-weight:400;
  color:#ffffff;
}

/* ══════════════════════════════════════════
   PERCEPTION — Unser Verständnis (wie #fit)
══════════════════════════════════════════ */
#perception.section{
  background:var(--dark);
  color:var(--light);
}
#perception .perception-copy{
  max-width:100%;
}
#perception .perception-h2{
  font-size:clamp(26px,3vw,40px);
  font-weight:700;
  line-height:1.2;
  letter-spacing:-0.02em;
  color:var(--light);
}
#perception .perception-points{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
}
#perception .perception-point{
  font-size:17px;
  font-weight:400;
  line-height:1.5;
  color:rgba(255,255,255,0.9);
  margin:0 0 24px;
  padding:0;
  border:none;
}
#perception .perception-point:first-child{
  font-size:18px;
  font-weight:400;
  color:#ffffff;
}

/* hero image sharp corners */
.hero img{
  border-radius: 0 !important;
}

/* definitive hero sharp corners */
.hero-visual-frame{
  border-radius:0 !important;
  overflow:hidden;
}
.hero-visual-frame img,
.hero-visual img,
.hero img{
  border-radius:0 !important;
}



/* ===== Process section redesign ===== */
.process-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-bottom:24px;
}
.pv-step{
  background:var(--dark) !important;
  color:var(--white);
  cursor:pointer;
  box-shadow:none;
}
.pv-step:hover{
  background:var(--dark2) !important;
  box-shadow:none;
}
.pv-step-img{
  display:none !important;
}
.pv-step-body{
  background:transparent !important;
  border-top:none !important;
  padding:28px 28px 32px;
}
.pv-step-tag{
  color:var(--gold) !important;
}
.pv-step-tag::before{
  background:var(--gold) !important;
}
.pv-step-title{
  color:var(--white) !important;
}
.pv-step-title-num{
  border-color:rgba(255,255,255,0.25) !important;
  color:var(--white) !important;
}
.pv-step-desc{
  color:rgba(255,255,255,0.68) !important;
}

/* hidden visuals below cards */
.process-visuals{
  display:none;
  margin-top:8px;
}
.process-visuals.open{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.process-visual{
  background:var(--light);
  overflow:hidden;
  box-shadow:0 2px 16px rgba(32,44,56,0.08);
}
.process-visual img{
  width:100%;
  height:240px;
  object-fit:cover;
  display:block;
}
.process-visual-caption{
  padding:16px 18px;
  font-size:12px;
  color:var(--muted);
  line-height:1.6;
  background:#fff;
  border-top:1px solid rgba(32,44,56,0.08);
}

@media(max-width:960px){
  .process-grid{grid-template-columns:1fr;}
  .process-visuals.open{grid-template-columns:1fr;}
}


/* ===== Process visuals fix ===== */
#process .pv-step-img{
  display:none !important;
}
#process .process-visuals{
  display:none;
  margin-top:8px;
}
#process .process-visuals.open{
  display:grid !important;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
#process .process-visual{
  background:var(--white);
  overflow:hidden;
  box-shadow:0 2px 16px rgba(32,44,56,0.08);
}
#process .process-visual-inner{
  display:block !important;
  height:auto !important;
}
#process .process-visual-inner svg{
  width:100%;
  height:auto;
  display:block;
}
@media(max-width:960px){
  #process .process-visuals.open{
    grid-template-columns:1fr;
  }
}


/* ===== Process 2-column layout ===== */
#process .process-two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  align-items:start;
}

#process .process-left{
  min-width:0;
}

#process .process-right{
  display:flex;
  flex-direction:column;
  gap:24px;
  min-width:0;
}

#process #processVisuals{
  display:block !important;
  margin-top:0;
}

#process #processVisuals.open{
  display:block !important;
}

#process .process-visual{
  display:none;
  background:var(--white);
  overflow:hidden;
  box-shadow:0 2px 16px rgba(32,44,56,0.08);
}

#process .process-visual.active{
  display:block !important;
}

#process .process-visual-inner{
  display:block !important;
}

#process .process-visual-inner svg{
  width:100%;
  height:auto;
  display:block;
}

#process .pv-step{
  background:var(--dark) !important;
  color:var(--white);
  cursor:pointer;
  box-shadow:none;
}

#process .pv-step:hover{
  background:var(--dark2) !important;
}

#process .pv-step-img{
  display:none !important;
}

#process .pv-step-body{
  background:transparent !important;
  border-top:none !important;
}

#process .pv-step-title{
  color:var(--white) !important;
}

#process .pv-step-desc{
  color:rgba(255,255,255,0.68) !important;
}

#process .pv-step-title-num{
  border-color:rgba(255,255,255,0.25) !important;
  color:var(--white) !important;
}

#process .pv-step-tag{
  color:var(--gold) !important;
}

#process .pv-step-tag::before{
  background:var(--gold) !important;
}

@media(max-width:960px){
  #process .process-two-col{
    grid-template-columns:1fr;
  }
}


/* ===== PROCESS TIMELINE REDESIGN ===== */
#process .process-timeline-layout{
  display:grid;
  grid-template-columns:minmax(280px,360px) minmax(0,1fr);
  gap:72px;
  align-items:start;
}
#process .process-timeline-nav{
  position:relative;
  padding-left:28px;
}
#process .process-timeline-line{
  position:absolute;
  left:16px;
  top:8px;
  bottom:8px;
  width:8px;
  border-radius:999px;
  background:transparent;
}
#process .process-step-nav{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:18px;
  width:100%;
  text-align:left;
  background:transparent;
  border:none;
  padding:0 0 30px 0;
  cursor:pointer;
  font-family:'Inter',sans-serif;
  transition:
    background .25s ease,
    transform .25s ease,
    box-shadow .25s ease,
    opacity .25s ease,
    filter .25s ease;
}
#process .process-step-nav:last-child{padding-bottom:0;}
#process .process-step-dot{
  position:relative;
  z-index:2;
  width:18px;
  height:18px;
  min-width:18px;
  border-radius:50%;
  border:1px solid rgba(32,44,56,0.20);
  background:linear-gradient(180deg, #ffffff, rgba(255,255,255,0.70));
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
  margin-left:-18px;
  box-shadow:
    0 10px 22px rgba(10,16,24,0.10),
    0 1px 0 rgba(255,255,255,0.9) inset;
}
#process .process-step-dot::after{
  content:'';
  position:absolute;
  inset:4px;
  border-radius:999px;
  background:rgba(32,44,56,0.18);
  transition:transform .25s ease, background .25s ease, box-shadow .25s ease;
}
#process .process-step-nav.active .process-step-dot{
  border-color:var(--gold);
  background:linear-gradient(180deg, rgba(173,126,21,0.98), rgba(173,126,21,0.72));
  box-shadow:
    0 0 0 6px rgba(173,126,21,0.14),
    0 16px 34px rgba(10,16,24,0.18);
  transform:translateY(-1px);
}
#process .process-step-nav.active .process-step-dot::after{
  background:rgba(255,255,255,0.30);
  box-shadow:0 0 0 1px rgba(255,255,255,0.22) inset;
}
#process .process-step-meta{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding-top:1px;
}
#process .process-step-num{
  font-size:10px;
  font-weight:700;
  letter-spacing:2.5px;
  text-transform:uppercase;
  color:rgba(32,44,56,0.35);
}
#process .process-step-title{
  font-size:18px;
  line-height:1.35;
  font-weight:700;
  color:rgba(32,44,56,0.42);
  letter-spacing:-0.2px;
  transition:color .25s ease;
}
#process .process-step-nav.active .process-step-title{color:var(--dark);}
#process .process-step-nav:hover .process-step-title{color:var(--dark2);}

/* Premium step pill states */
#process .process-step-nav:hover{
  transform:translateY(-1px);
}
#process .process-step-nav.active{
  transform:translateY(-1px);
}
#process .process-detail{display:none;}
#process .process-detail.active{display:block;}
#process .process-detail-eyebrow{
  font-size:10px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:16px;
}
#process .process-detail-headline{
  font-size:clamp(28px,3vw,42px);
  line-height:1.15;
  font-weight:700;
  color:var(--dark);
  letter-spacing:-.5px;
  margin-bottom:18px;
  max-width:var(--measure);
}
#process .process-detail-text{
  font-size:16px;
  line-height:1.8;
  color:var(--muted);
  max-width:var(--measure);
  margin-bottom:var(--r24);
}
#process .process-detail-bullets{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:12px;
  margin:0 0 var(--r32) 0;
  padding:0;
  max-width:var(--measure);
}
#process .process-detail-bullets li{
  position:relative;
  padding-left:18px;
  font-size:14px;
  line-height:1.7;
  color:var(--dark2);
}
#process .process-detail-bullets li::before{
  content:'';
  position:absolute;
  left:0;
  top:10px;
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--gold);
}
#process .process-detail-visual{
  background:var(--white);
  box-shadow:0 2px 16px rgba(32,44,56,0.08);
  overflow:hidden;
}
#process .process-detail-visual .process-visual-caption{display:none !important;}
#process .process-detail-visual-inner{
  display:block !important;
  background:var(--white);
}
#process .process-detail-visual-inner img,
#process .process-detail-visual-inner svg{
  width:100%;
  height:auto;
  display:block;
}
@media(max-width:980px){
  #process .process-timeline-layout{
    grid-template-columns:1fr;
    gap:40px;
  }
  #process .process-timeline-nav{padding-left:18px;}
  #process .process-step-dot{margin-left:-18px;}
  #process .process-step-title{font-size:16px;}
}


/* Adjust ratio: larger left timeline, smaller right details */
#process .process-timeline-layout{
  grid-template-columns: minmax(360px, 1.2fr) minmax(0, 0.8fr);
  gap: 56px;
}
@media(max-width:980px){
  #process .process-timeline-layout{
    grid-template-columns: 1fr;
  }
}


/* Make timeline itself dominant */
#process .process-timeline-layout{
  align-items:stretch;
}
#process .process-timeline-nav{
  padding-left:34px;
  min-height:760px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
#process .process-timeline-line{
  left:17px;
  top:12px;
  bottom:12px;
  width:2px;
  background:linear-gradient(
    to bottom,
    rgba(32,44,56,0.10) 0%,
    rgba(32,44,56,0.18) 18%,
    rgba(32,44,56,0.12) 100%
  );
}
#process .process-step-nav{
  gap:24px;
  padding:0;
  min-height:120px;
  align-items:center;
}
#process .process-step-dot{
  width:34px;
  height:34px;
  min-width:34px;
  margin-left:-34px;
  border-width:2px;
  transition:
    transform .28s ease,
    background-color .28s ease,
    border-color .28s ease,
    box-shadow .28s ease;
}
#process .process-step-nav.active .process-step-dot{
  box-shadow:0 0 0 10px rgba(173,126,21,0.10);
  transform:scale(1.08);
}
#process .process-step-num{
  font-size:11px;
  letter-spacing:3px;
}
#process .process-step-title{
  font-size:24px;
  line-height:1.22;
  font-weight:700;
}
#process .process-step-nav.active .process-step-title{
  color:var(--dark);
}
#process .process-step-nav:hover .process-step-dot{
  transform:scale(1.04);
}
#process .process-step-nav:hover .process-step-title{
  color:var(--dark);
}

/* Subtle active state animation */
#process .process-step-nav.active .process-step-dot::after{
  content:'';
  position:absolute;
  inset:-8px;
  border-radius:50%;
  border:1px solid rgba(173,126,21,0.22);
  animation:processPulse 2.4s ease-out infinite;
}
@keyframes processPulse{
  0%{transform:scale(0.92);opacity:0;}
  25%{opacity:0.55;}
  100%{transform:scale(1.22);opacity:0;}
}

/* Make right side a bit calmer and secondary */
#process .process-detail-panel{
  padding-top:24px;
}
#process .process-detail-headline{
  font-size:clamp(24px,2.4vw,34px);
}
#process .process-detail-text{
  font-size:15px;
  line-height:1.75;
}
#process .process-detail-bullets li{
  font-size:13.5px;
}
#process .process-detail-visual{
  max-width:100%;
}

@media(max-width:980px){
  #process .process-timeline-nav{
    min-height:auto;
    gap:14px;
    justify-content:flex-start;
    padding-left:26px;
  }
  #process .process-step-nav{
    min-height:88px;
  }
  #process .process-step-dot{
    width:26px;
    height:26px;
    min-width:26px;
    margin-left:-26px;
  }
  #process .process-step-title{
    font-size:19px;
  }
  #process .process-timeline-line{
    left:13px;
  }
}


/* ===== PROCESS V2 RIGHT PANEL ===== */
#process .process-v2-visual{
  margin-bottom:28px;
  overflow:hidden;
  box-shadow:0 10px 40px rgba(0,0,0,0.08);
}
#process .process-v2-visual img,
#process .process-v2-visual svg{
  width:100%;
  height:auto;
  display:block;
}

#process .process-v2-eyebrow{
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:14px;
}

#process .process-v2-headline{
  font-size:clamp(24px,2.2vw,32px);
  font-weight:600;
  color:var(--dark);
  margin-bottom:22px;
}

#process .process-v2-micro{
  display:flex;
  flex-direction:column;
  gap:10px;
}

#process .process-v2-line{
  font-size:14px;
  color:var(--dark2);
  letter-spacing:0.2px;
  position:relative;
  padding-left:14px;
}
#process .process-v2-line::before{
  content:'';
  position:absolute;
  left:0;
  top:9px;
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--gold);
}


/* ===== PROCESS V3 MAGAZINE LEVEL ===== */

/* create overlap effect */
#process .process-detail-panel{
  position:relative;
}

#process .process-v2-visual{
  margin-bottom:40px;
  transform:translateX(-40px);
  width:110%;
  position:relative;
  z-index:2;
}

/* subtle gold accent line */
#process .process-v2-visual::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  width:80px;
  height:3px;
  background:var(--gold);
}

/* typography refinement */
#process .process-v2-headline{
  font-size:clamp(22px,2vw,28px);
  font-weight:500;
  letter-spacing:-0.2px;
}

/* micro lines more premium */
#process .process-v2-line{
  font-size:13.5px;
  color:rgba(32,44,56,0.75);
  padding-left:0;
}

#process .process-v2-line::before{
  display:none;
}

/* spacing rhythm */
#process .process-v2-micro{
  gap:14px;
  margin-top:10px;
}

/* add subtle divider */
#process .process-v2-micro::before{
  content:'';
  display:block;
  width:32px;
  height:1px;
  background:rgba(32,44,56,0.15);
  margin-bottom:10px;
}

/* make whole panel feel lighter */
#process .process-detail{
  padding-right:20px;
}

/* mobile reset */
@media(max-width:980px){
  #process .process-v2-visual{
    transform:none;
    width:100%;
  }
}


/* ===== Timeline auto-play progress fill ===== */
#process .process-timeline-line{
  overflow:hidden;
}
#process .process-timeline-line::after{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:var(--timeline-progress, 0%);
  background:linear-gradient(
    to bottom,
    rgba(173,126,21,0.92) 0%,
    rgba(173,126,21,0.72) 100%
  );
  transition:height 0.2s linear;
}


/* ===== Timeline Glow Effect ===== */
#process .process-timeline-line::after {
  box-shadow:
    0 0 6px rgba(173,126,21,0.6),
    0 0 12px rgba(173,126,21,0.4),
    0 0 24px rgba(173,126,21,0.25);
}

#process .process-timeline-line.glow-active::after {
  animation: timelineGlowPulse 2s ease-in-out infinite;
}

@keyframes timelineGlowPulse {
  0% {
    box-shadow:
      0 0 4px rgba(173,126,21,0.4),
      0 0 10px rgba(173,126,21,0.25);
  }
  50% {
    box-shadow:
      0 0 10px rgba(173,126,21,0.7),
      0 0 20px rgba(173,126,21,0.45),
      0 0 32px rgba(173,126,21,0.25);
  }
  100% {
    box-shadow:
      0 0 4px rgba(173,126,21,0.4),
      0 0 10px rgba(173,126,21,0.25);
  }
}


/* ===== Cinematic sync: active step text + detail stage ===== */
#process .process-step-title,
#process .process-step-num{
  transition:
    color .35s ease,
    opacity .35s ease,
    transform .35s ease,
    text-shadow .35s ease,
    letter-spacing .35s ease;
}

#process .process-step-nav{
  transition:
    opacity .35s ease,
    transform .35s ease,
    filter .35s ease;
}

#process .process-step-nav:not(.active){
  opacity:.56;
  filter:saturate(.85);
}

#process .process-step-nav.active{
  transform:translateX(6px);
}

#process .process-step-nav.active .process-step-title{
  color:var(--dark);
  text-shadow:0 0 10px rgba(173,126,21,0.10);
  letter-spacing:-0.28px;
}

#process .process-step-nav.active .process-step-num{
  color:rgba(173,126,21,0.88);
}

#process .process-step-nav.active .process-step-dot{
  box-shadow:
    0 0 0 10px rgba(173,126,21,0.10),
    0 0 18px rgba(173,126,21,0.22);
}

#process .process-detail{
  opacity:0;
  transform:translateY(14px);
  transition:
    opacity .42s ease,
    transform .42s ease,
    filter .42s ease;
  filter:blur(1px);
}

#process .process-detail.active{
  opacity:1;
  transform:translateY(0);
  filter:blur(0);
}

#process .process-v2-visual{
  transition:
    transform .45s ease,
    box-shadow .45s ease,
    filter .45s ease;
}

#process .process-detail.active .process-v2-visual{
  transform:translateX(-40px) scale(1.005);
  box-shadow:
    0 20px 56px rgba(32,44,56,0.12),
    0 0 28px rgba(173,126,21,0.08);
}

#process .process-v2-headline{
  transition:
    color .35s ease,
    transform .35s ease,
    opacity .35s ease;
}

#process .process-detail.active .process-v2-headline{
  transform:translateY(0);
  opacity:1;
}

#process .process-v2-micro{
  transition:
    opacity .35s ease,
    transform .35s ease;
}

#process .process-detail.active .process-v2-micro{
  opacity:1;
  transform:translateY(0);
}

@media(max-width:980px){
  #process .process-step-nav.active{
    transform:none;
  }
  #process .process-detail.active .process-v2-visual{
    transform:none;
  }
}


/* ===== FIXES ===== */

/* 1. Blue line instead of gold */
#process .process-timeline-line::after{
  background: linear-gradient(
    to bottom,
    rgba(32,44,56,0.9) 0%,
    rgba(32,44,56,0.7) 100%
  );
  box-shadow:
    0 0 6px rgba(32,44,56,0.5),
    0 0 14px rgba(32,44,56,0.25);
}

/* 2. Center dots perfectly on line */
#process .process-step-dot{
  position:absolute;
  left:12px;
  transform:translateX(-50%);
}

#process .process-step-nav{
  position:relative;
  padding-left:40px;
}

/* 3. Make line perfectly centered */
#process .process-timeline-line{
  left:12px;
}

/* remove previous margin hack */
#process .process-step-dot{
  margin-left:0 !important;
}

/* ===== TIMELINE ALIGNMENT FIX ===== */
#process .process-timeline-nav{
  position:relative;
  padding-left:56px !important;
}
#process .process-timeline-line{
  position:absolute !important;
  left:28px !important;
  top:12px !important;
  bottom:12px !important;
  width:2px !important;
}
#process .process-step-nav{
  position:relative !important;
  padding-left:0 !important;
}
#process .process-step-dot{
  position:absolute !important;
  left:28px !important;
  top:50% !important;
  transform:translate(-50%,-50%) !important;
  margin-left:0 !important;
}
@media(max-width:980px){
  #process .process-timeline-nav{
    padding-left:44px !important;
  }
  #process .process-timeline-line{
    left:22px !important;
  }
  #process .process-step-dot{
    left:22px !important;
  }
}


/* ===== HARD OVERRIDE: dots exactly on line ===== */
#process .process-timeline-nav{
  position:relative !important;
  padding-left:56px !important;
}
#process .process-timeline-line{
  position:absolute !important;
  left:28px !important;
  top:12px !important;
  bottom:12px !important;
  width:2px !important;
}
#process .process-step-nav{
  position:relative !important;
  padding:0 0 34px 0 !important;
  display:flex !important;
  align-items:flex-start !important;
  gap:18px !important;
}
#process .process-step-dot{
  position:absolute !important;
  z-index:3 !important;
  left:28px !important;
  top:12px !important;
  transform:translate(-50%, 0) !important;
  margin-left:0 !important;
}
#process .process-step-meta{
  margin-left:18px !important;
}
@media(max-width:980px){
  #process .process-timeline-nav{
    padding-left:44px !important;
  }
  #process .process-timeline-line{
    left:22px !important;
  }
  #process .process-step-dot{
    left:22px !important;
  }
}


/* ===== FINAL ALIGNMENT FIX (clean) ===== */
#process .process-timeline-nav{
  position:relative !important;
  padding-left:48px !important;
}

/* LINE POSITION */
#process .process-timeline-line{
  position:absolute !important;
  left:20px !important;
  top:8px !important;
  bottom:8px !important;
  width:2px !important;
}

/* STEP ITEM */
#process .process-step-nav{
  position:relative !important;
  padding-left:0 !important;
  margin-left:0 !important;
}

/* DOT EXACTLY ON LINE */
#process .process-step-dot{
  position:absolute !important;
  left:20px !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  margin:0 !important;
}

/* TEXT OFFSET */
#process .process-step-meta{
  margin-left:28px !important;
}

/* MOBILE */
@media(max-width:980px){
  #process .process-timeline-nav{
    padding-left:36px !important;
  }
  #process .process-timeline-line{
    left:14px !important;
  }
  #process .process-step-dot{
    left:14px !important;
  }
}



/* ===== Robust timeline alignment override ===== */
#process .process-timeline-nav{
  position:relative !important;
  padding-left:0 !important;
}
#process .process-timeline-line{
  position:absolute !important;
  top:8px !important;
  bottom:8px !important;
  width:2px !important;
  left:18px !important;
}
#process .process-step-nav{
  position:relative !important;
  padding:0 0 34px 48px !important;
  margin:0 !important;
}
#process .process-step-dot{
  position:absolute !important;
  left:18px !important;
  top:50% !important;
  transform:translate(-50%,-50%) !important;
  margin:0 !important;
}
#process .process-step-meta{
  margin:0 !important;
}
@media(max-width:980px){
  #process .process-timeline-line{ left:14px !important; }
  #process .process-step-nav{ padding-left:38px !important; }
  #process .process-step-dot{ left:14px !important; }
}

/* ===== FINAL OVERRIDE: thicker line, no base track ===== */
#process .process-timeline-line{
  width:8px !important;
  border-radius:999px !important;
  background:transparent !important;
  box-shadow:none !important;
}

#process .process-timeline-line::after{
  width:100% !important;
  border-radius:999px !important;
}

/* ===== FINAL OVERRIDE: dots centered on 8px timeline ===== */
#process .process-timeline-line{
  left:18px !important;
  width:8px !important;
}

#process .process-step-dot{
  left:22px !important; /* line left + width/2 => 18 + 4 */
  transform:translate(-50%,-50%) !important;
}

@media(max-width:980px){
  #process .process-timeline-line{
    left:14px !important;
    width:8px !important;
  }
  #process .process-step-dot{
    left:18px !important; /* 14 + 4 */
  }
}

/* ===== PROCESS VISUAL UPGRADE (premium showcase) ===== */
#process .process-v2-visual{
  position:relative;
  overflow:visible !important;
  border-radius:22px;
  padding:14px;
  margin-bottom:34px !important;
  border:1px solid rgba(32,44,56,0.10);
  background:
    radial-gradient(900px 260px at 10% 0%, rgba(255,255,255,0.88), rgba(255,255,255,0.58) 48%, rgba(255,255,255,0.30) 100%),
    linear-gradient(180deg, rgba(245,245,240,0.95), rgba(232,236,240,0.82));
  box-shadow:
    0 28px 60px rgba(10,16,24,0.18),
    0 8px 18px rgba(10,16,24,0.10),
    0 1px 0 rgba(255,255,255,0.72) inset;
  transform:translateX(-18px) !important;
  width:105% !important;
}

#process .process-v2-visual::after{
  content:'';
  position:absolute;
  left:22px;
  right:22px;
  bottom:-18px;
  height:22px;
  border-radius:50%;
  background:radial-gradient(ellipse at center, rgba(10,16,24,0.24) 0%, rgba(10,16,24,0.10) 44%, rgba(10,16,24,0) 72%);
  filter:blur(7px);
  pointer-events:none;
}

#process .process-v2-visual .process-detail-visual-inner,
#process .process-v2-visual .process-visual-inner{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(32,44,56,0.12);
  background:#fff;
}

/* Normalize iframe-based visuals so frame hugs content */
#process .process-detail[data-step="3"] .process-v2-visual > div[style*="transform:scale(0.75)"]{
  transform:none !important;
  transform-origin:top left !important;
  width:100% !important;
  height:292px !important;
  border-radius:16px;
  overflow:hidden !important;
}

#process .process-detail[data-step="4"] .process-v2-visual > div[style*="transform:scale(0.72)"]{
  transform:none !important;
  transform-origin:top left !important;
  width:100% !important;
  height:292px !important;
  border-radius:16px;
  overflow:hidden !important;
}

#process .process-detail[data-step="3"] .process-v2-visual > div[style*="transform:scale(0.75)"] iframe,
#process .process-detail[data-step="4"] .process-v2-visual > div[style*="transform:scale(0.72)"] iframe{
  display:block;
  width:100% !important;
  border:0 !important;
}

#process .process-detail[data-step="3"] .process-v2-visual > div[style*="transform:scale(0.75)"] iframe{
  height:560px !important;
}

#process .process-detail[data-step="4"] .process-v2-visual > div[style*="transform:scale(0.72)"] iframe{
  height:580px !important;
}

/* Keep top-right badges above iframe-based visuals */
#process .process-v2-visual{
  isolation:isolate;
}

#process .process-v2-visual::before{
  z-index:8;
}

#process .process-v2-visual > *{
  position:relative;
  z-index:2;
}

/* Step 1: cool executive tint + matrix badge */
#process .process-detail[data-step="1"] .process-v2-visual{
  background:
    radial-gradient(760px 220px at 0% 0%, rgba(32,44,56,0.14), rgba(32,44,56,0) 58%),
    linear-gradient(180deg, rgba(236,241,246,0.96), rgba(225,232,240,0.86));
}

#process .process-detail[data-step="1"] .process-v2-visual::before{
  content:'';
  position:absolute;
  top:-10px;
  right:14px;
  width:36px;
  height:36px;
  border-radius:10px;
  border:1px solid rgba(32,44,56,0.16);
  background:
    linear-gradient(rgba(32,44,56,0.75), rgba(32,44,56,0.75)) 50% 50%/2px 16px no-repeat,
    linear-gradient(rgba(32,44,56,0.75), rgba(32,44,56,0.75)) 50% 50%/16px 2px no-repeat,
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(237,242,247,0.82));
  box-shadow:0 10px 24px rgba(10,16,24,0.16);
}

/* Step 2: warm strategy tint + dossier badge */
#process .process-detail[data-step="2"] .process-v2-visual{
  background:
    radial-gradient(760px 220px at 0% 0%, rgba(173,126,21,0.18), rgba(173,126,21,0) 58%),
    linear-gradient(180deg, rgba(245,242,234,0.96), rgba(236,232,221,0.86));
}

#process .process-detail[data-step="2"] .process-v2-visual::before{
  content:'';
  position:absolute;
  top:-10px;
  right:14px;
  width:36px;
  height:36px;
  border-radius:10px;
  border:1px solid rgba(173,126,21,0.36);
  background:
    linear-gradient(rgba(173,126,21,0.86), rgba(173,126,21,0.86)) 8px 9px/20px 2px no-repeat,
    linear-gradient(rgba(173,126,21,0.66), rgba(173,126,21,0.66)) 8px 16px/16px 2px no-repeat,
    linear-gradient(rgba(173,126,21,0.52), rgba(173,126,21,0.52)) 8px 23px/12px 2px no-repeat,
    linear-gradient(180deg, rgba(255,250,238,0.96), rgba(247,236,207,0.84));
  box-shadow:0 10px 24px rgba(10,16,24,0.16);
}

/* Step 3: negotiation depth tint + handshake-style badge */
#process .process-detail[data-step="3"] .process-v2-visual{
  background:
    radial-gradient(760px 220px at 0% 0%, rgba(28,43,59,0.18), rgba(28,43,59,0) 58%),
    linear-gradient(180deg, rgba(232,238,245,0.96), rgba(220,229,238,0.86));
}

#process .process-detail[data-step="3"] .process-v2-visual::before{
  content:'';
  position:absolute;
  top:-10px;
  right:14px;
  width:36px;
  height:36px;
  border-radius:10px;
  border:1px solid rgba(32,44,56,0.24);
  background:
    linear-gradient(45deg, rgba(32,44,56,0.88), rgba(32,44,56,0.88)) 12px 18px/12px 2px no-repeat,
    radial-gradient(circle at 10px 13px, rgba(32,44,56,0.86) 0 3px, transparent 3.4px),
    radial-gradient(circle at 24px 23px, rgba(32,44,56,0.86) 0 3px, transparent 3.4px),
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(235,242,250,0.84));
  box-shadow:0 10px 24px rgba(10,16,24,0.16);
}

/* Step 4: result/security tint + lock-style badge */
#process .process-detail[data-step="4"] .process-v2-visual{
  background:
    radial-gradient(760px 220px at 0% 0%, rgba(173,126,21,0.18), rgba(173,126,21,0) 58%),
    linear-gradient(180deg, rgba(245,242,234,0.96), rgba(236,232,221,0.86));
}

#process .process-detail[data-step="4"] .process-v2-visual::before{
  content:'';
  position:absolute;
  top:-10px;
  right:14px;
  width:36px;
  height:36px;
  border-radius:10px;
  border:1px solid rgba(173,126,21,0.34);
  background:
    linear-gradient(rgba(173,126,21,0.88), rgba(173,126,21,0.88)) 12px 19px/12px 2px no-repeat,
    linear-gradient(rgba(173,126,21,0.88), rgba(173,126,21,0.88)) 10px 19px/2px 7px no-repeat,
    linear-gradient(rgba(173,126,21,0.88), rgba(173,126,21,0.88)) 22px 19px/2px 7px no-repeat,
    radial-gradient(circle at 17px 14px, transparent 0 4px, rgba(173,126,21,0.84) 4px 5.4px, transparent 5.6px),
    linear-gradient(180deg, rgba(255,252,243,0.96), rgba(247,239,219,0.84));
  box-shadow:0 10px 24px rgba(10,16,24,0.16);
}

/* Slightly scale down SVG-based visuals to fit frame cleanly */
#process .process-v2-visual .process-detail-visual-inner svg{
  width:96% !important;
  height:auto !important;
  margin:10px auto 12px !important;
  display:block !important;
}

@media(max-width:980px){
  #process .process-v2-visual{
    transform:none !important;
    width:100% !important;
    padding:12px;
  }
}

/* ===== PROCESS transition choreography (final) ===== */
#process .process-detail-panel{
  position:relative;
}

#process .process-detail{
  will-change: opacity, transform;
}

#process .process-detail.active{
  animation: processDetailIn 420ms cubic-bezier(0.22, 1, 0.36, 1);
}

#process .process-detail.active .process-v2-eyebrow{
  animation: processTextIn 360ms cubic-bezier(0.22, 1, 0.36, 1) 40ms both;
}

#process .process-detail.active .process-v2-headline{
  animation: processTextIn 420ms cubic-bezier(0.22, 1, 0.36, 1) 70ms both;
}

#process .process-detail.active .process-v2-micro{
  animation: processTextIn 460ms cubic-bezier(0.22, 1, 0.36, 1) 110ms both;
}

#process .process-detail.active .process-v2-visual{
  animation: processVisualIn 520ms cubic-bezier(0.22, 1, 0.36, 1) 120ms both;
}

@keyframes processDetailIn{
  from{
    opacity:0.0;
    transform:translateY(8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes processTextIn{
  from{
    opacity:0.0;
    transform:translateY(6px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes processVisualIn{
  from{
    opacity:0.0;
    transform:translateY(10px) scale(0.985);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

@media (prefers-reduced-motion: reduce){
  #process .process-detail.active,
  #process .process-detail.active .process-v2-eyebrow,
  #process .process-detail.active .process-v2-headline,
  #process .process-detail.active .process-v2-micro,
  #process .process-detail.active .process-v2-visual{
    animation:none !important;
  }
}


/* ===== Center titles vertically to dots ===== */
#process .process-step-nav{
  display:flex !important;
  align-items:center !important;
  min-height:80px;
}
#process .process-step-meta{
  display:flex;
  flex-direction:column;
  justify-content:center;
}

/* ===== Slightly tighter spacing for better alignment ===== */
#process .process-step-title{
  line-height:1.2;
}


/* visuals always below text in process detail */
#process .process-detail{
  display:none;
}
#process .process-detail.active{
  display:block;
}
#process .process-v2-visual{
  margin-top:28px !important;
  margin-bottom:0 !important;
  transform:none !important;
  width:100% !important;
  max-width:100% !important;
}
#process .process-detail.active .process-v2-visual{
  transform:none !important;
}


/* ensure visual spacing below text */
#process .process-v2-visual{
  margin-top:32px !important;
}

/* ===== Final premium case card ===== */
#cases .case-signature-final{
  position:relative;
  grid-row:span 2;
  min-height:100%;
  border:none;
  background:linear-gradient(180deg, rgba(32,44,56,0.98) 0%, rgba(32,44,56,0.94) 100%);
  box-shadow:0 18px 50px rgba(32,44,56,0.16);
  overflow:hidden;
}
#cases .case-signature-final::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at top right, rgba(212,168,42,0.18), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,0.05) 0%, rgba(255,255,255,0.0) 34%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0));
  pointer-events:none;
}
#cases .case-signature-final::after{
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--gold), rgba(212,168,42,0.2));
}
#cases .case-signature-shell{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  min-height:100%;
}
#cases .case-signature-hero{
  padding:34px 34px 28px;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
#cases .case-signature-topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  margin-bottom:22px;
}
#cases .case-signature-number{
  font-size:12px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.42);
}
#cases .case-signature-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid rgba(212,168,42,0.28);
  background:rgba(212,168,42,0.08);
  color:var(--gold);
  font-size:10px;
  font-weight:700;
  letter-spacing:1.8px;
  text-transform:uppercase;
}
#cases .case-signature-tag::before{
  content:'';
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 6px rgba(173,126,21,0.12);
}
#cases .case-signature-title{
  font-size:clamp(28px,2.7vw,40px);
  line-height:1.08;
  letter-spacing:-0.7px;
  color:var(--white);
  font-weight:700;
  max-width:var(--measure);
  margin-bottom:var(--r24);
}
#cases .case-signature-company{
  display:flex;
  align-items:center;
  gap:10px;
  color:rgba(255,255,255,0.58);
  font-size:13px;
  line-height:1.5;
}
#cases .case-signature-company svg{
  width:16px;
  height:16px;
  flex-shrink:0;
  opacity:.7;
}
#cases .case-signature-kpis{
  display:grid;
  grid-template-columns:1.15fr 1fr 1fr;
  gap:0;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
#cases .case-signature-kpi{
  padding:26px 34px;
  border-right:1px solid rgba(255,255,255,0.08);
}
#cases .case-signature-kpi:last-child{
  border-right:none;
}
#cases .case-signature-kpi-label{
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.42);
  margin-bottom:10px;
}
#cases .case-signature-kpi-value{
  font-size:22px;
  line-height:1.05;
  font-weight:800;
  color:var(--white);
  letter-spacing:-0.5px;
}
#cases .case-signature-kpi-value.is-highlight{
  font-size:48px;
  color:var(--gold);
}
#cases .case-signature-kpi-sub{
  margin-top:8px;
  font-size:12px;
  line-height:1.5;
  color:rgba(255,255,255,0.48);
}
#cases .case-signature-story{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:0;
  padding:0;
}
#cases .case-signature-block{
  padding:28px 34px 32px;
  border-right:1px solid rgba(255,255,255,0.08);
}
#cases .case-signature-block:last-child{
  border-right:none;
}
#cases .case-signature-block-label{
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.42);
  margin-bottom:12px;
}
#cases .case-signature-block-label.is-result{
  color:var(--gold);
}
#cases .case-signature-block-text{
  font-size:14px;
  line-height:1.75;
  color:rgba(255,255,255,0.72);
}
#cases .case-signature-block-text strong{
  color:var(--white);
  font-weight:600;
}
#cases .case-card{
  transition:transform .28s ease, box-shadow .28s ease;
}
#cases .case-card:hover{
  transform:translateY(-4px);
}
#cases .case-signature-final:hover{
  box-shadow:0 22px 58px rgba(32,44,56,0.18);
}
@media(max-width:980px){
  #cases .case-signature-kpis,
  #cases .case-signature-story{
    grid-template-columns:1fr;
  }
  #cases .case-signature-kpi,
  #cases .case-signature-block{
    border-right:none;
    border-bottom:1px solid rgba(255,255,255,0.08);
  }
  #cases .case-signature-block:last-child,
  #cases .case-signature-kpi:last-child{
    border-bottom:none;
  }
  #cases .case-signature-hero{
    padding:28px 24px 24px;
  }
  #cases .case-signature-kpi,
  #cases .case-signature-block{
    padding:22px 24px 24px;
  }
  #cases .case-signature-title{
    font-size:30px;
  }
}



/* signature case image clearly visible */
#cases .case-card[style*="grid-row:span 2"] .case-header,
#cases .case-card[style*="grid-row:span 2"] .case-header *{
  box-sizing:border-box;
}
#cases .case-card[style*="grid-row:span 2"] .case-title{
  max-width: 85%;
}


/* ===== Cases section switcher redesign – final ===== */
#cases .cases-switcher{display:flex;gap:12px;margin:-8px 0 28px;}
#cases .case-tab{
  appearance:none;border:1px solid rgba(32,44,56,0.14);background:rgba(255,255,255,0.7);
  color:rgba(32,44,56,0.55);font:700 12px/1 'Inter',sans-serif;letter-spacing:2px;text-transform:uppercase;
  padding:12px 18px;cursor:pointer;transition:all .25s ease;
}
#cases .case-tab:hover{border-color:rgba(32,44,56,0.3);color:var(--dark);}
#cases .case-tab.active{background:var(--dark);border-color:var(--dark);color:var(--white);}
#cases .cases-stage{display:grid;grid-template-columns:1.6fr 1fr;gap:24px;align-items:stretch;}
#cases .active-case-card{height:100%;box-shadow:0 8px 28px rgba(32,44,56,0.10);}
#cases .dynamic-case-header{
  position:relative;min-height:320px;padding:34px 32px 28px;display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;background:#d8ddd9 center/cover no-repeat;
}
#cases .case-header-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top, rgba(32,44,56,0.82) 0%, rgba(32,44,56,0.58) 45%, rgba(32,44,56,0.24) 100%);
}
#cases .case-header-content{position:relative;z-index:2;}
#cases .dynamic-case-number{font-size:13px;letter-spacing:3px;color:rgba(255,255,255,0.72);margin-bottom:10px;font-weight:700;}
#cases .dynamic-case-title{font-size:26px;line-height:1.25;color:#fff;max-width:85%;margin-bottom:12px;font-weight:700;}
#cases .dynamic-case-company{font-size:14px;color:rgba(255,255,255,0.82);}
#cases .dynamic-case-kpis{
  background:var(--dark);padding:20px 28px;display:grid;grid-template-columns:1fr 1fr;gap:0;border-bottom:1px solid rgba(32,44,56,0.08);
}
#cases .dynamic-case-kpis .case-kpi{display:flex;align-items:center;gap:12px;min-height:80px;}
#cases .dynamic-case-kpis .case-kpi:first-child{border-right:1px solid rgba(255,255,255,0.08);padding-right:20px;margin-right:4px;}
#cases .dynamic-case-kpis .case-kpi-icon{
  width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
#cases .dynamic-case-kpis .case-kpi:nth-child(1) .case-kpi-icon{background:rgba(173,126,21,0.15);}
#cases .dynamic-case-kpis .case-kpi-icon::before{content:'';width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,0.45);}
#cases .dynamic-case-kpis .case-kpi:nth-child(1) .case-kpi-icon::before{border-color:rgba(173,126,21,0.85);}
#cases .dynamic-case-kpis .case-kpi-val{font-size:22px;font-weight:800;color:#fff;letter-spacing:-.5px;line-height:1;margin-bottom:4px;}
#cases .dynamic-case-kpis .case-kpi-lbl{font-size:10px;color:rgba(255,255,255,0.45);line-height:1.35;}
#cases .dynamic-case-body{
  display:flex !important;flex-direction:column !important;gap:20px;padding:24px 28px 28px !important;
  max-height:none !important;height:auto !important;overflow:visible !important;opacity:1 !important;visibility:visible !important;
}
#cases .dynamic-case-body .case-field-label{
  display:block !important;font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);opacity:.6;margin-bottom:8px;
}
#cases .dynamic-case-body .case-field-text{
  display:block !important;font-size:13px;color:var(--muted);line-height:1.75;padding-left:20px;border-left:1px solid rgba(32,44,56,0.12);
}
#cases .case-side-visual-card{background:#fff;height:100%;box-shadow:0 8px 28px rgba(32,44,56,0.10);}
#cases .case-side-visual-image-wrap{position:relative;min-height:100%;height:100%;}
#cases .case-side-visual-image{width:100%;height:100%;object-fit:cover;display:block;min-height:640px;}
#cases .case-side-visual-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(32,44,56,0.62) 0%, rgba(32,44,56,0.18) 48%, rgba(32,44,56,0.04) 100%);}
#cases .case-side-visual-meta{position:absolute;left:28px;right:28px;bottom:24px;z-index:2;}
#cases .case-side-visual-kicker{font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.68);margin-bottom:10px;}
#cases .case-side-visual-title{font-size:22px;line-height:1.25;font-weight:700;color:#fff;}
@media(max-width:980px){#cases .cases-stage{grid-template-columns:1fr;}#cases .case-side-visual-image{min-height:380px;}}


/* ===== Alignment adjustments ===== */

/* LEFT SIDE TEXT STRUCTURE */
#cases .dynamic-case-body .case-block:nth-child(1){
  align-self:flex-start;
}

#cases .dynamic-case-body .case-block:nth-child(2){
  align-self:center;
  text-align:left;
}

#cases .dynamic-case-body .case-block:nth-child(3){
  align-self:flex-start;
}

/* ensure vertical spacing looks intentional */
#cases .dynamic-case-body{
  justify-content:space-between;
  min-height:260px;
}

/* RIGHT SIDE: remove text overlay completely */
#cases .case-side-visual-meta{
  display:none !important;
}


/* ===== Header adjustments ===== */
#cases .dynamic-case-header{
  min-height:160px !important; /* half height */
  background:none !important;  /* remove image */
  padding:24px 28px 16px !important;
  justify-content:flex-start !important; /* top align */
}
#cases .case-header-overlay{
  display:none !important; /* remove overlay since no image */
}

/* ===== KPI vertical center ===== */
#cases .dynamic-case-kpis{
  align-items:center !important;
}
#cases .dynamic-case-kpis .case-kpi{
  align-items:center !important;
}


/* ===== Header text dark ===== */
#cases .dynamic-case-title,
#cases .dynamic-case-company,
#cases .dynamic-case-number{
  color: var(--dark) !important;
}

/* ===== KPI perfect vertical centering ===== */
#cases .dynamic-case-kpis{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  height:110px !important;
}

#cases .dynamic-case-kpis .case-kpi{
  display:flex !important;
  align-items:center !important;
  height:100% !important;
}

#cases .dynamic-case-kpis .case-kpi > div{
  display:flex;
  flex-direction:column;
  justify-content:center;
}


/* ===== Highlight primary KPI ===== */
#cases .dynamic-case-kpis .case-kpi:first-child .case-kpi-val{
  font-size:28px !important;
  font-weight:900 !important;
  color:#D4A82A !important; /* gold highlight */
}

#cases .dynamic-case-kpis .case-kpi:first-child .case-kpi-lbl{
  color:rgba(212,168,42,0.8) !important;
}

/* subtle emphasis container */
#cases .dynamic-case-kpis .case-kpi:first-child{
  transform:scale(1.05);
}


/* ===== Case 3 title single line break control ===== */
#cases .dynamic-case-title{
  white-space:normal;
}
#cases .dynamic-case-title br{
  display:none;
}


/* ===== KPI layout refinement ===== */

/* remove bullet visuals */
#cases .case-kpi-icon::before{
  display:none !important;
}

/* distribute KPI content evenly */
#cases .dynamic-case-kpis .case-kpi{
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  width:100%;
}

/* left text (value) */
#cases .case-kpi-val{
  flex:1;
  text-align:left;
}

/* separator line */
#cases .dynamic-case-kpis .case-kpi:first-child{
  border-right:1px solid rgba(255,255,255,0.15) !important;
}

/* right text (label) */
#cases .case-kpi-lbl{
  flex:1;
  text-align:right;
}


/* ===== KPI card final layout ===== */

/* remove circle icons completely */
#cases .case-kpi-icon{
  display:none !important;
}

/* enforce two equal columns */
#cases .dynamic-case-kpis{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  align-items:center !important;
  height:110px;
}

/* each KPI as full column */
#cases .dynamic-case-kpis .case-kpi{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  align-items:flex-start !important;
  height:100%;
  padding:0 20px;
}

/* vertical divider */
#cases .dynamic-case-kpis .case-kpi:first-child{
  border-right:1px solid rgba(255,255,255,0.2) !important;
}

/* text alignment clean */
#cases .case-kpi-val{
  text-align:left !important;
}

#cases .case-kpi-lbl{
  text-align:left !important;
}


/* ===== Optimize Story Layer height ===== */
#cases .dynamic-case-body{
  gap:16px !important;
  padding:20px 28px 20px !important;
  min-height:200px !important;
}

/* tighter spacing inside story */
#cases .dynamic-case-body .case-field-text{
  line-height:1.6 !important;
}

/* ===== Reduce right image height accordingly ===== */
#cases .case-side-visual-image{
  min-height:520px !important;
}

/* keep overall balance */
#cases .cases-stage{
  align-items:start !important;
}


/* ===== Fix right visual alignment ===== */
#cases .cases-stage{
  align-items:stretch !important;
}

#cases .cases-stage-visual{
  display:flex;
  height:100%;
}

#cases .case-side-visual-card{
  display:flex;
  flex-direction:column;
  height:100%;
}

#cases .case-side-visual-image-wrap{
  height:100%;
}

#cases .case-side-visual-image{
  height:100% !important;
  min-height:unset !important;
}


/* ===== Subtle depth between left and right ===== */
#cases .cases-stage-main{
  box-shadow: 0 8px 30px rgba(32,44,56,0.08);
  z-index:2;
}

#cases .cases-stage-visual{
  position:relative;
}

#cases .cases-stage-visual::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:1px;
  background:linear-gradient(
    to bottom,
    rgba(32,44,56,0.12),
    rgba(32,44,56,0.04)
  );
}

/* slight card elevation */
#cases .case-side-visual-card{
  box-shadow: 0 8px 30px rgba(32,44,56,0.06);
}


/* ===== Case transition ===== */
#cases .dynamic-case-header,
#cases .dynamic-case-kpis,
#cases .dynamic-case-body,
#cases .case-side-visual-image-wrap{
  transition:
    opacity .35s ease,
    transform .35s ease,
    filter .35s ease;
}

#cases .case-is-transitioning .dynamic-case-header,
#cases .case-is-transitioning .dynamic-case-kpis,
#cases .case-is-transitioning .dynamic-case-body,
#cases .case-is-transitioning .case-side-visual-image-wrap{
  opacity:0;
  transform:translateY(10px);
  filter:blur(2px);
}


/* ===== Slower + smoother case transition ===== */
#cases .dynamic-case-header,
#cases .dynamic-case-kpis,
#cases .dynamic-case-body,
#cases .case-side-visual-image-wrap{
  transition:
    opacity .85s cubic-bezier(.22,1,.36,1),
    transform .95s cubic-bezier(.22,1,.36,1),
    filter .95s cubic-bezier(.22,1,.36,1) !important;
}

#cases .case-is-transitioning .dynamic-case-header,
#cases .case-is-transitioning .dynamic-case-kpis,
#cases .case-is-transitioning .dynamic-case-body,
#cases .case-is-transitioning .case-side-visual-image-wrap{
  opacity:0;
  transform:translateY(18px);
  filter:blur(4px);
}


/* ensure case 01 visual renders above any placeholder */
#cases .case-side-visual-card,
#cases .case-side-visual-image-wrap{
  background: transparent !important;
}
#cases .case-side-visual-image{
  opacity:1 !important;
}





/* ===== KPI gold aligned with eyebrow gold ===== */
#cases .dynamic-case-kpis .case-kpi:first-child .case-kpi-val{
  color: var(--gold) !important;
}

#cases .dynamic-case-kpis .case-kpi:first-child .case-kpi-lbl{
  color: rgba(173,126,21,0.85) !important;
}


/* ===== Normalize visual size across cases ===== */
#cases .case-side-visual-image-wrap{
  aspect-ratio: 1 / 1; /* same square footprint as case 1 */
}

#cases .case-side-visual-image{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position: top center; /* crop top for better framing */
}


/* ===== Ultra polish: image-only premium transition ===== */
#cases .case-side-visual-image{
  transition:
    opacity .75s cubic-bezier(.22,1,.36,1),
    transform .9s cubic-bezier(.22,1,.36,1),
    filter .9s cubic-bezier(.22,1,.36,1),
    object-position .9s cubic-bezier(.22,1,.36,1);
  will-change: opacity, transform, filter;
}

#cases .case-side-visual-image-wrap{
  overflow:hidden;
}

#cases .case-side-visual-overlay{
  transition:
    opacity .7s cubic-bezier(.22,1,.36,1),
    background .9s cubic-bezier(.22,1,.36,1);
}

#cases .case-side-visual-card.is-polishing .case-side-visual-image{
  opacity:0;
  transform:scale(1.045);
  filter:blur(4px);
}

#cases .case-side-visual-card.is-polishing .case-side-visual-overlay{
  opacity:.88;
}

#cases .case-side-visual-card:not(.is-polishing) .case-side-visual-image{
  opacity:1;
  transform:scale(1);
  filter:blur(0);
}


/* ===== Disable all animations on left side ===== */
#cases .dynamic-case-header,
#cases .dynamic-case-kpis,
#cases .dynamic-case-body{
  transition: none !important;
  animation: none !important;
  transform: none !important;
  filter: none !important;
  opacity: 1 !important;
}

/* —— Hero + Hero-Proof (mobile-first) —— */
#hero{
  background:#ffffff;
  position:relative;
  overflow:hidden;
  padding:var(--section-pad) 0;
}

.hero-content{
  position:relative;
  max-width:var(--container-max);
  margin:0 auto;
  padding:0 var(--r24);
  text-align:left;
}

#hero .hero-h1{
  font-size:clamp(32px,7.5vw,72px);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-0.02em;
  color:var(--dark);
  max-width:var(--hero-h1-max);
  margin:0 0 var(--r24);
}

#hero .hero-sub{
  margin:0 0 var(--r32);
  max-width:var(--measure);
  font-size:clamp(16px,2.6vw,19px);
  font-weight:400;
  line-height:1.5;
  color:#202C38;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden;
}

#hero .hero-actions{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-start;
  gap:10px 12px;
  max-width:var(--measure);
}

#hero .hero-actions a{
  text-align:center;
  justify-content:center;
}

#hero .hero-actions .btn-primary,
#hero .hero-actions .btn-ghost{
  flex:1 1 100%;
  min-height:44px;
}

#hero .hero-cta-fn-marker,
#contact .contact-cta-fn-marker{
  font-weight:700;
  color:var(--gold);
}

@media (min-width:480px){
  #hero .hero-actions .btn-primary,
  #hero .hero-actions .btn-ghost{
    flex:1 1 calc(50% - 6px);
    min-width:0;
  }
}

@media (min-width:720px){
  #hero .hero-actions .btn-primary,
  #hero .hero-actions .btn-ghost{
    flex:0 1 auto;
  }
}

#hero .hero-actions .btn-ghost{
  border-color:rgba(32,44,56,0.2);
  color:rgba(32,44,56,0.88);
}

#hero .hero-actions .btn-ghost:hover{
  border-color:rgba(32,44,56,0.4);
  color:var(--dark);
}

#hero .hero-cta-footnote,
#savingspotential .sp-calc-footnote,
#proof .proof-footnote,
#cases .cases-footnote{
  margin:var(--r24) 0 0;
  max-width:var(--measure);
  text-align:left;
  font-size:12px;
  line-height:1.5;
  color:rgba(32,44,56,0.78);
}
#contact .contact-cta-footnote{
  max-width:var(--measure);
  text-align:left;
  font-size:12px;
  line-height:1.5;
  color:rgba(32,44,56,0.78);
}

#hero .hero-cta-footnote-mark,
#contact .contact-cta-footnote-mark{
  color:var(--gold);
  font-weight:700;
  margin-right:0.25em;
}

/* „Messbare Ergebnisse“ — editorial, eine Lesespalte, vertikale Metrics (#proof) */
.section-proof{
  background:var(--white);
  text-align:left;
}

.section-proof .proof-inner{
  max-width:var(--measure);
  width:100%;
}

.section-proof .proof-header h2{
  margin:0 0 32px;
  font-size:clamp(28px,3.6vw,38px);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-0.02em;
  color:var(--dark);
}

.section-proof .proof-header p{
  margin:0;
  max-width:var(--measure);
  font-size:clamp(16px,2.2vw,18px);
  line-height:1.65;
  color:var(--muted);
}

.section-proof .proof-metrics{
  margin-top:0;
  padding:0;
}

.section-proof .proof-header + .proof-metrics{
  margin-top:48px;
}

.section-proof .proof-metric + .proof-metric{
  margin-top:56px;
}

.section-proof .proof-value{
  font-size:clamp(40px,6.5vw,64px);
  font-weight:700;
  line-height:1.05;
  letter-spacing:-0.03em;
  color:var(--dark);
}

.section-proof .proof-metric:first-child .proof-value{
  font-size:clamp(44px,7vw,70px);
  line-height:1.04;
}

.section-proof .proof-metric--accent .proof-value{
  color:var(--gold);
}

.section-proof .proof-label{
  margin-top:clamp(12px,1.5vw,16px);
  font-size:clamp(15px,1.35vw,17px);
  line-height:1.55;
  font-weight:400;
  color:var(--muted);
  max-width:var(--measure);
}

/* ===== Pricing cards background aligned with 'Aus der Praxis' ===== */
#pricing .pricing-card{
  background: var(--light2) !important;
}


/* ===== Improve text contrast on pricing cards ===== */
#pricing .pricing-card{
  color: var(--dark) !important;
}

#pricing .pricing-card h3{
  color: var(--dark) !important;
}

#pricing .pricing-card p{
  color: #4a5a67 !important;
}

#pricing .pricing-card .tag{
  color: var(--gold) !important;
}


/* ===== Fix tag readability (same gold as eyebrows) ===== */
#pricing .pricing-card .tag{
  color: var(--gold) !important;
  opacity: 1 !important;
  font-weight: 600;
}


/* ===== FORCE tag color fix ===== */
#pricing .pricing-card span,
#pricing .pricing-card .tag,
#pricing .pricing-card .badge{
  color: var(--gold) !important;
  opacity: 1 !important;
  font-weight: 600 !important;
}


/* ===== VERIFIED pricing-tag gold fix ===== */
#pricing .pricing-tag{
  color: var(--gold) !important;
  border-color: rgba(173,126,21,0.28) !important;
  opacity: 1 !important;
  font-weight: 700 !important;
}


/* ===== Pill style for pricing tags ===== */
#pricing .pricing-tag{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  padding:7px 14px !important;
  border-radius:999px !important;
  background:rgba(173,126,21,0.10) !important;
  border:1px solid rgba(173,126,21,0.24) !important;
  color:var(--gold) !important;
  font-size:9px !important;
  font-weight:700 !important;
  letter-spacing:1.8px !important;
  text-transform:uppercase;
  line-height:1;
  box-shadow:0 1px 0 rgba(173,126,21,0.06) inset;
}


/* ===== Calculator as premium widget ===== */
#pricing .calculator-wrap,
#pricing .calculator,
#pricing .calculator-card{
  background:#ffffff !important;
  border-radius:18px !important;
  box-shadow:0 20px 50px rgba(32,44,56,0.12), 0 4px 12px rgba(32,44,56,0.06) !important;
  padding:28px !important;
  border:1px solid rgba(32,44,56,0.06);
}

/* inner spacing refinement */
#pricing .calculator *{
  position:relative;
  z-index:1;
}


/* ===== Calculator widget verified fix ===== */
#pricing .calc-wrap{
  background:#ffffff !important;
  border-radius:18px !important;
  box-shadow:
    0 20px 50px rgba(32,44,56,0.12),
    0 4px 12px rgba(32,44,56,0.06) !important;
  padding:28px !important;
  border:1px solid rgba(32,44,56,0.06) !important;
  overflow:hidden !important;
}

#pricing .calc-top,
#pricing .calc-grid{
  position:relative;
  z-index:1;
}

#pricing .calc-top{
  margin-bottom:18px;
}

#pricing .calc-grid{
  background:transparent !important;
}


/* ===== Calculator header upgrade ===== */
#pricing .calc-top{
  text-align:left;
}

#pricing .calc-top h3{
  color: var(--dark) !important;
  font-size: 26px !important;
  font-weight: 700 !important;
  letter-spacing: -0.3px;
  margin-bottom: 8px;
}

#pricing .calc-top p{
  text-align:left;
  font-size:14px;
  color:#5b6b78;
}


/* ===== Slider redesign inspired by classic calculator widgets ===== */
#pricing .calc-inputs{
  display:flex;
  flex-direction:column;
  gap:18px;
}

#pricing .calc-field{
  background:#f7f8fa;
  border:1px solid rgba(32,44,56,0.08);
  border-radius:16px;
  padding:18px 18px 16px;
}

#pricing .calc-field label{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font-size:13px;
  font-weight:700;
  color:var(--dark);
  margin-bottom:14px;
  line-height:1.2;
}

#pricing .calc-field label span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:88px;
  padding:8px 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(32,44,56,0.08);
  box-shadow:0 1px 2px rgba(32,44,56,0.04);
  color:var(--dark);
  font-size:12px;
  font-weight:700;
}

#pricing .calc-field input[type="range"]{
  -webkit-appearance:none;
  appearance:none;
  width:100%;
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--dark) 0%, rgba(32,44,56,0.68) 100%);
  outline:none;
  margin:0;
}

#pricing .calc-field input[type="range"]::-webkit-slider-runnable-track{
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--dark) 0%, rgba(32,44,56,0.68) 100%);
}

#pricing .calc-field input[type="range"]::-moz-range-track{
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--dark) 0%, rgba(32,44,56,0.68) 100%);
}

#pricing .calc-field input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:22px;
  height:22px;
  border-radius:50%;
  background:#fff;
  border:3px solid var(--gold);
  box-shadow:0 4px 12px rgba(32,44,56,0.16);
  margin-top:-7px;
  cursor:pointer;
}

#pricing .calc-field input[type="range"]::-moz-range-thumb{
  width:22px;
  height:22px;
  border-radius:50%;
  background:#fff;
  border:3px solid var(--gold);
  box-shadow:0 4px 12px rgba(32,44,56,0.16);
  cursor:pointer;
}

#pricing .range-labels{
  display:flex;
  justify-content:space-between;
  margin-top:10px;
  font-size:11px;
  color:#70808d;
  letter-spacing:.01em;
}

#pricing .calc-field:hover{
  border-color:rgba(32,44,56,0.16);
}


/* ===== Results box aligned to classic calculator style ===== */
#pricing .calc-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  align-items:start;
}

#pricing .calc-results{
  background:#f7f8fa !important;
  border:1px solid rgba(32,44,56,0.08);
  border-radius:16px;
  padding:20px 20px 18px;
}

#pricing .calc-results h4{
  color:var(--dark) !important;
  font-size:18px;
  font-weight:700;
  letter-spacing:-0.2px;
  margin-bottom:14px;
}

#pricing .cr-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding:12px 0;
  border-top:1px solid rgba(32,44,56,0.08);
}

#pricing .cr-row:first-of-type{
  border-top:none;
  padding-top:0;
}

#pricing .cr-lbl{
  font-size:13px;
  color:#5b6b78;
  line-height:1.45;
}

#pricing .cr-val{
  text-align:right;
  font-size:14px;
  font-weight:700;
  color:var(--dark);
  line-height:1.35;
}

#pricing .hl-savings .cr-lbl,
#pricing .hl-net .cr-lbl{
  color:var(--dark);
  font-weight:700;
}

#pricing .hl-savings .cr-val{
  color:var(--gold);
  font-size:15px;
}

#pricing .hl-net{
  margin-top:6px;
  padding-top:14px;
}

#pricing .hl-net .cr-val{
  color:var(--dark);
  font-size:16px;
  font-weight:800;
}

#pricing .calc-disclaimer{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid rgba(32,44,56,0.08);
  font-size:11px;
  line-height:1.55;
  color:#70808d;
}

@media(max-width:980px){
  #pricing .calc-grid{
    grid-template-columns:1fr;
  }
}


/* ===== Pricing Icons (clean patch) ===== */
#pricing .pricing-card h3{
  display:flex;
  align-items:center;
  gap:10px;
}
#pricing .pricing-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
  color:var(--gold);
  flex-shrink:0;
}
#pricing .pricing-icon svg{
  width:100%;
  height:100%;
}


/* ===== Remove horizontal lines in calculator results ===== */
#pricing .calc-results .cr-row{
  border-top:none !important;
}
#pricing .calc-results .calc-disclaimer{
  border-top:none !important;
}


/* ===== Fix overflow & alignment in results ===== */
#pricing .calc-results{
  overflow:hidden;
}
#pricing .cr-row{
  align-items:center !important;
}
#pricing .cr-lbl{
  max-width:60%;
}
#pricing .cr-val{
  max-width:40%;
  text-align:right;
  word-break:break-word;
}


/* ===== Fix clipped savings row ===== */
#pricing .calc-results{
  padding:24px !important;
  overflow:visible !important;
}

#pricing .cr-row{
  width:100%;
  box-sizing:border-box;
}

#pricing .hl-savings{
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap:16px !important;
  padding:8px 0 14px !important;
  margin:0 !important;
}

#pricing .hl-savings .cr-lbl{
  flex:1 1 52% !important;
  min-width:0 !important;
  max-width:none !important;
  white-space:normal !important;
}

#pricing .hl-savings .cr-val{
  flex:1 1 48% !important;
  min-width:0 !important;
  max-width:none !important;
  text-align:right !important;
  white-space:normal !important;
  word-break:normal !important;
  overflow-wrap:anywhere !important;
}

#pricing .cr-lbl,
#pricing .cr-val{
  box-sizing:border-box;
}


/* ===== Calculator result row typography refinements ===== */

/* Row 2: Einsparpotenzial – full row same bold blue style */
#pricing .hl-savings .cr-lbl,
#pricing .hl-savings .cr-val{
  color: var(--dark) !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  line-height: 1.3 !important;
}

/* Row 3: Typische Projektkosten – value same style as label */
#pricing .calc-results .cr-row:not(.hl-savings):not(.hl-net) .cr-lbl,
#pricing .calc-results .cr-row:not(.hl-savings):not(.hl-net) .cr-val{
  font-size: 13px !important;
  font-weight: 400 !important;
  color: #2e3944 !important;
  line-height: 1.45 !important;
}

/* Row 4: Nettoeffekt – full row same size, value gold */
#pricing .hl-net .cr-lbl{
  color: #15202a !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  line-height: 1.3 !important;
}

#pricing .hl-net .cr-val{
  color: var(--gold) !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  line-height: 1.3 !important;
}


/* (Floating 3D widget treatment für Pricing entfernt – reduzierte, ruhige Cards) */
#pricing .pricing-model > .pricing-card,
#pricing .calc-wrap{
  border-color: rgba(255,255,255,0.34) !important;
  backdrop-filter: blur(3px);
}

/* keep plus between cards visually centered */
#pricing .pricing-plus{
  align-self:center;
  position:relative;
  z-index:4;
}

@media (max-width: 980px){
  #pricing .pricing-model > .pricing-card::after,
  #pricing .calc-wrap::after{
    left:16px;
    right:16px;
    bottom:-16px;
  }
}


/* ===== Premium floating treatment for pricing widgets ===== */
#pricing{
  position:relative;
  overflow:hidden;
}
#pricing::after{
  content:"";
  position:absolute;
  top:-140px;
  right:-120px;
  width:460px;
  height:460px;
  background:radial-gradient(circle, rgba(173,126,21,0.07) 0%, rgba(173,126,21,0.02) 32%, rgba(173,126,21,0) 72%);
  pointer-events:none;
  z-index:0;
}

#pricing .container{
  position:relative;
  z-index:1;
}

#pricing .pricing-model > .pricing-card,
#pricing .calc-wrap{
  position:relative;
  border:1px solid rgba(255,255,255,0.22) !important;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}

/* bright top rim + subtle side glow */
#pricing .pricing-model > .pricing-card::before,
#pricing .calc-wrap::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.34) 0%, rgba(255,255,255,0.14) 16%, rgba(255,255,255,0.02) 34%, rgba(255,255,255,0.00) 56%),
    linear-gradient(90deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.00) 22%, rgba(255,255,255,0.00) 78%, rgba(255,255,255,0.05) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.44),
    inset 0 -1px 0 rgba(255,255,255,0.06);
  z-index:2;
}

/* deeper ambient shadow */
#pricing .pricing-model > .pricing-card::after,
#pricing .calc-wrap::after{
  content:"";
  position:absolute;
  left:26px;
  right:26px;
  bottom:-22px;
  height:34px;
  border-radius:50%;
  background:radial-gradient(ellipse at center, rgba(7,12,19,0.34) 0%, rgba(7,12,19,0.16) 42%, rgba(7,12,19,0.00) 76%);
  filter:blur(12px);
  pointer-events:none;
  z-index:0;
}

#pricing .pricing-model > .pricing-card{
  box-shadow:
    0 34px 72px rgba(7,12,19,0.30),
    0 14px 26px rgba(7,12,19,0.18),
    0 2px 0 rgba(255,255,255,0.07) inset !important;
  transform:translateY(-2px);
}

#pricing .calc-wrap{
  box-shadow:
    0 42px 90px rgba(7,12,19,0.34),
    0 18px 34px rgba(7,12,19,0.20),
    0 2px 0 rgba(255,255,255,0.08) inset !important;
  transform:translateY(-4px);
}

/* slightly lift the white panels inside the calculator */
#pricing .calc-inputs,
#pricing .calc-results{
  box-shadow:
    0 12px 24px rgba(21,31,42,0.10),
    inset 0 1px 0 rgba(255,255,255,0.75) !important;
  border-color:rgba(33,46,60,0.10) !important;
}

/* mobile adjustments */
@media (max-width:980px){
  #pricing::after{
    width:320px;
    height:320px;
    top:-80px;
    right:-80px;
  }
  #pricing .pricing-model > .pricing-card::after,
  #pricing .calc-wrap::after{
    left:18px;
    right:18px;
    bottom:-18px;
  }
}


/* ===== Contact CTA button same as hero (always gold) ===== */
#kontakt .btn,
#kontakt .cta-btn,
#kontakt a.button{
  background: linear-gradient(180deg, #D4A82A 0%, #AD7E15 100%) !important;
  color: #ffffff !important;
  border: none !important;
  box-shadow: 
    0 10px 24px rgba(173,126,21,0.35),
    inset 0 1px 0 rgba(255,255,255,0.35) !important;
  transition: all 0.3s ease;
}

#kontakt .btn:hover,
#kontakt .cta-btn:hover,
#kontakt a.button:hover{
  transform: translateY(-2px);
  box-shadow: 
    0 16px 32px rgba(173,126,21,0.45),
    inset 0 1px 0 rgba(255,255,255,0.4) !important;
}


body.custom-savingspartners-theme{margin:0;}

.sp-page-main {
  background: var(--light);
  min-height: 100vh;
}

.sp-page-section {
  padding: var(--section-pad) var(--r24) var(--section-pad);
}

.sp-page-container {
  max-width: var(--container-max);
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}

.sp-page-card {
  background: #fff;
  border: 1px solid rgba(32, 44, 56, 0.1);
  border-radius: 18px;
  padding: 30px 28px;
  box-shadow: 0 10px 28px rgba(32, 44, 56, 0.08);
}

.sp-page-header {
  margin-bottom: 32px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(32, 44, 56, 0.1);
}

.sp-page-title {
  margin: 0;
  max-width: var(--measure);
  font-size: clamp(28px, 3.6vw, 44px);
  line-height: 1.15;
  letter-spacing: -0.4px;
  color: var(--dark);
  overflow-wrap: anywhere;
  word-break: break-word;
}

.sp-page-content {
  max-width: var(--measure);
  color: #111;
  font-size: 15px;
  line-height: 1.7;
}

.sp-page-content h2,
.sp-page-content h3,
.sp-page-content h4 {
  color: var(--dark);
  overflow-wrap: anywhere;
  word-break: break-word;
}

.sp-page-content h2 {
  margin: 48px 0 32px;
  font-size: clamp(22px, 2.6vw, 30px);
}

.sp-page-content h2:first-child {
  margin-top: 0;
}

.sp-page-content h3 {
  margin: 0 0 24px;
  font-size: clamp(18px, 2.2vw, 22px);
}

.sp-page-content p {
  margin: 0 0 24px;
}

.sp-page-content ul,
.sp-page-content ol {
  margin: 0 0 24px 22px;
}

.sp-page-content li {
  margin-bottom: 24px;
}

.sp-page-content a {
  color: #1f5f8f;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.sp-page-content hr {
  border: 0;
  border-top: 1px solid rgba(32, 44, 56, 0.15);
  margin: 22px 0;
}

.modal-box-legal {
  width: min(880px, calc(100vw - 32px));
  max-height: 88vh;
  overflow-y: auto;
  padding: 32px 28px 28px;
  border-radius: 20px;
  box-sizing: border-box;
}

.legal-content {
  color: #111;
  font-size: 15px;
  line-height: 1.65;
}

.legal-content h2 {
  margin: 0 0 20px;
  font-size: 30px;
  line-height: 1.2;
  font-weight: 700;
}

.legal-content h3 {
  margin: 28px 0 12px;
  font-size: 20px;
  line-height: 1.3;
  font-weight: 700;
}

.legal-content p {
  margin: 0 0 14px;
}

.legal-content ul {
  margin: 0 0 16px 20px;
  padding: 0;
}

.legal-content li {
  margin: 0 0 8px;
}

.legal-content a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
  word-break: break-word;
}

.legal-content strong {
  font-weight: 700;
}

.legal-copyright {
  margin-top: 40px;
  padding-top: 18px;
  border-top: 1px solid rgba(0, 0, 0, 0.12);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 12px;
  line-height: 1.4;
  color: rgba(0, 0, 0, 0.65);
}

.legal-copyright-logo img {
  display: block;
  max-width: 170px;
  width: 100%;
  height: auto;
  border: 0;
}

.legal-copyright-date {
  white-space: nowrap;
}

@media (max-width: 767px) {
  .sp-page-section {
    padding: 96px 14px 56px;
  }

  .sp-page-card {
    padding: 22px 16px;
    border-radius: 14px;
  }

  .sp-page-header {
    margin-bottom: 14px;
    padding-bottom: 10px;
  }

  .sp-page-content {
    font-size: 14px;
    line-height: 1.62;
  }

  #hero .hero-cta-footnote,
  #savingspotential .sp-calc-footnote,
  #proof .proof-footnote,
  #contact .contact-cta-footnote{
    font-size: 11px;
    line-height: 1.45;
  }

  .modal-box-legal {
    width: calc(100vw - 20px);
    max-height: 90vh;
    padding: 24px 18px 22px;
    border-radius: 16px;
  }

  .legal-content {
    font-size: 14px;
    line-height: 1.6;
  }

  .legal-content h2 {
    font-size: 24px;
    margin-bottom: 16px;
    padding-right: 28px;
  }

  .legal-content h3 {
    font-size: 18px;
    margin: 24px 0 10px;
  }

  .legal-content ul {
    margin-left: 18px;
  }

  .legal-copyright {
    margin-top: 32px;
    gap: 10px;
  }

  .legal-copyright-date {
    white-space: normal;
  }
}

/* ===== FINAL MOBILE FIXES: value, cases, about, arbeitsweise ===== */
@media (max-width: 980px) {
  /* Generic overflow safety inside the affected sections */
  #value .container,
  #cases .container,
  #about .container,
  #perception .container {
    min-width: 0;
  }

  #value *,
  #cases *,
  #about *,
  #perception * {
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: normal;
  }

  /* 1) Supplier Savings Program — stacked */
  #value .value-layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 28px !important;
  }

  #value .value-copy {
    padding: 0 !important;
    max-width: 640px !important;
  }

  #value .value-visual {
    min-height: 0 !important;
    transform: none !important;
    max-width: var(--measure) !important;
  }

  #value .value-visual .program-image {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    aspect-ratio: 16 / 9 !important;
    object-fit: cover !important;
    object-position: center 58% !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    transform: none !important;
    margin-bottom: 0 !important;
    filter: brightness(0.94) contrast(1.04) saturate(0.92) !important;
  }

  /* 2) Projektbeispiele (editorial) */
  #cases .cases-intro-title,
  #cases .cases-item-title,
  #cases .cases-item-company-sub,
  #cases .cases-item-company-text,
  #cases .cases-block-text {
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  /* 3) Wer wir sind */
  #about .signature,
  #about .link-muted {
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  #about .container {
    display: flex !important;
    flex-direction: column !important;
    gap: 48px !important;
  }

  #about .portrait img {
    width: 100% !important;
    height: auto !important;
    max-width: 320px !important;
    object-fit: cover !important;
  }
}

/* ===== MOBILE PASS LEVEL 2: typography tuning ===== */
@media (max-width: 980px) {
  /* Supplier Savingsprogramm */
  #value .value-header h2 {
    font-size: clamp(28px, 6.6vw, 38px) !important;
    line-height: 1.16 !important;
    letter-spacing: -0.35px !important;
  }

  #value .value-copy-intro,
  #quote .quote-position-sub {
    font-size: 15px !important;
    line-height: 1.65 !important;
  }

  #value .value-statement-line {
    font-size: clamp(22px, 4.8vw, 26px) !important;
    line-height: 1.3 !important;
    font-weight: 500 !important;
    letter-spacing: -0.01em !important;
    color: #202C38 !important;
  }

  /* Aus der Praxis */
  #cases .dynamic-case-title {
    font-size: clamp(23px, 5.8vw, 31px) !important;
    line-height: 1.2 !important;
  }

  #cases .dynamic-case-company,
  #cases .dynamic-case-body .case-field-text {
    font-size: 14px !important;
    line-height: 1.6 !important;
  }

  /* Wer wir sind */
  #about .about-statement {
    font-size: clamp(30px, 6.8vw, 44px) !important;
    line-height: 1.15 !important;
  }

  #perception .perception-h2 {
    font-size: clamp(26px, 6.2vw, 38px) !important;
    line-height: 1.2 !important;
  }
}

@media (max-width: 640px) {
  /* Section rhythm aligned with global tokens */
  #value.section,
  #cases.section,
  #about.section,
  #perception.section {
    padding-top: var(--section-pad) !important;
    padding-bottom: var(--section-pad) !important;
  }

  /* Supplier Savingsprogramm */
  #value .value-header h2 {
    font-size: clamp(25px, 8.2vw, 31px) !important;
    line-height: 1.17 !important;
  }

  #value .value-copy-intro,
  #quote .quote-position-sub {
    font-size: 14px !important;
    line-height: 1.58 !important;
  }

  #value .value-statement-line {
    font-size: clamp(21px, 6vw, 26px) !important;
    line-height: 1.3 !important;
    font-weight: 500 !important;
    letter-spacing: -0.01em !important;
    color: #202C38 !important;
  }

  #value .value-copy > h2 {
    margin-top: 0 !important;
  }

  /* Projektbeispiele (editorial) */
  #cases .cases-intro {
    margin-bottom: 48px !important;
  }

  #cases .cases-intro-title {
    font-size: clamp(26px, 8vw, 34px) !important;
    line-height: 1.16 !important;
  }

  #cases .cases-item {
    margin-bottom: 56px !important;
  }

  #cases .cases-stack > .cases-item:first-child {
    margin-bottom: var(--section-pad) !important;
  }

  #cases .cases-stack > .cases-item:not(:first-child) .cases-item-title {
    font-size: clamp(18px, 5.1vw, 22px) !important;
    line-height: 1.25 !important;
  }

  #cases .cases-stack > .cases-item:not(:first-child) .cases-block-text {
    font-size: 14px !important;
    line-height: 1.65 !important;
  }

  /* Wer wir sind */
  #about .about-intro {
    margin-bottom: 40px !important;
  }

  #about .about-statement {
    font-size: clamp(26px, 8.2vw, 34px) !important;
    line-height: 1.16 !important;
  }

  #about .signature {
    font-size: 20px !important;
  }

  #perception .perception-h2 {
    font-size: clamp(24px, 7.2vw, 32px) !important;
    line-height: 1.2 !important;
  }
}

/* ===== Process section: value-first refinements ===== */
#process .process-header p{
  max-width: var(--measure);
}

#process .process-timeline-nav{
  opacity: 0.9;
}

#process .process-timeline-line{
  opacity: 0.35 !important;
  width: 1px !important;
}

#process .process-step-nav{
  background: transparent !important;
  box-shadow: none !important;
}

#process .process-detail-panel{
  background: #f8f8f5 !important;
  border: 1px solid rgba(32,44,56,0.12) !important;
  box-shadow: 0 14px 34px rgba(32,44,56,0.09) !important;
}

#process .process-v2-headline{
  margin-bottom: 10px !important;
}

#process .process-v2-outcome{
  margin: 0 0 16px !important;
  padding: 10px 12px !important;
  border-left: 3px solid var(--gold) !important;
  background: rgba(255,255,255,0.9) !important;
  color: #22303b !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  font-weight: 600 !important;
}

#process .process-v2-visual-label{
  margin: 0 0 8px !important;
  color: #5a6874 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}

#process .process-v2-visual{
  border-radius: 8px !important;
  box-shadow: 0 10px 24px rgba(32,44,56,0.18) !important;
  border: 1px solid rgba(32,44,56,0.15) !important;
}

/* ===== Process staircase layout ===== */
#process .process-staircase-v2{
  position: relative;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 18px;
  margin-top: 34px;
}

#process .process-staircase-line{
  position: absolute;
  left: 4%;
  right: 4%;
  top: 56%;
  height: 2px;
  background: linear-gradient(90deg, rgba(173,126,21,0.35) 0%, rgba(173,126,21,0.8) 100%);
  transform: rotate(-16deg);
  transform-origin: left center;
  z-index: 0;
}

#process .process-step-card{
  position: relative;
  z-index: 1;
  background: #fbfaf7;
  border: 1px solid rgba(32,44,56,0.18);
  box-shadow: 0 16px 34px rgba(32,44,56,0.12);
  border-radius: 10px;
  padding: 16px;
}

#process .process-step-card-1{ grid-column: 1 / span 6; margin-top: 140px; }
#process .process-step-card-2{ grid-column: 4 / span 6; margin-top: 92px; }
#process .process-step-card-3{ grid-column: 7 / span 6; margin-top: 44px; }
#process .process-step-card-4{ grid-column: 9 / span 4; margin-top: 0; }

#process .process-step-kicker{
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: #6a7782;
  margin-bottom: 6px;
}

#process .process-step-card h3{
  margin: 0 0 8px;
  font-size: clamp(22px, 2.1vw, 30px);
  line-height: 1.15;
  color: var(--dark);
}

#process .process-step-outcome{
  /* Basis-Style; konkrete Ausprägung weiter unten bei .process-copy-panel .process-step-outcome */
}

#process .process-step-card ul{
  /* Basis-Reset; konkrete Ausprägung je Layout weiter unten */
}

#process .process-step-card li{
  /* Basis-Reset; konkrete Ausprägung je Layout weiter unten */
}

#process .process-step-proof{
  margin-bottom: 8px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #5f6d78;
}

#process .process-step-visual{
  background: #fff;
  border: 1px solid rgba(32,44,56,0.16);
  box-shadow: 0 8px 20px rgba(32,44,56,0.14);
  border-radius: 6px;
  overflow: hidden;
  height: 190px;
}

#process .process-step-visual iframe{
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

@media (max-width: 1100px){
  #process .process-staircase-line{
    transform: rotate(-12deg);
    top: 50%;
  }
  #process .process-step-card-1{ grid-column: 1 / span 7; margin-top: 96px; }
  #process .process-step-card-2{ grid-column: 3 / span 7; margin-top: 64px; }
  #process .process-step-card-3{ grid-column: 6 / span 7; margin-top: 32px; }
  #process .process-step-card-4{ grid-column: 7 / span 6; margin-top: 0; }
}

@media (max-width: 860px){
  #process .process-staircase-v2{
    grid-template-columns: 1fr;
    gap: 16px;
  }
  #process .process-staircase-line{
    display: none;
  }
  #process .process-step-card-1,
  #process .process-step-card-2,
  #process .process-step-card-3,
  #process .process-step-card-4{
    grid-column: 1;
    margin-top: 0;
  }
  #process .process-step-visual{
    height: 220px;
  }
}

/* ===== Process compact staircase (single card visible) ===== */
#process .process-stair-compact{
  position: relative;
  margin-top: 26px;
  display: block;
}

#process .process-main-col{
  max-width: none;
}

#process .process-main-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
  gap: 56px;
  align-items: flex-start;
}

#process .process-main-text{
  min-height: 340px;
}

#process .process-main-visual{
  display: flex;
  justify-content: flex-end;
}

#process .process-left-col .process-header{
  margin-bottom: 30px;
}

#process .process-schematic{
  position: relative;
  margin-bottom: 0;
  height: 520px;
}

#process .process-schematic-svg{
  width: 100%;
  height: 520px;
  display: block;
}

#process .process-axis-line{
  fill: none;
  stroke: rgba(32,44,56,0.24);
  stroke-width: 4;
  stroke-linecap: round;
}

#process .process-schematic-step{
  position: absolute;
  display: block;
  font-size: 11.5px;
  font-weight: 700;
  color: #3f4f5b;
  letter-spacing: 0.02em;
  z-index: 1;
  transform: translate(-50%, -50%);
}

#process .process-schematic-step.step-1{ left: 50%; top: 10%; }
#process .process-schematic-step.step-2{ left: 50%; top: 32%; }
#process .process-schematic-step.step-3{ left: 50%; top: 55%; }
#process .process-schematic-step.step-4{ left: 50%; top: 78%; }

#process .process-schematic-step .process-stair-step{
  transform: none;
}

#process .process-schematic-labels{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 20px;
  font-size: 11.5px;
  font-weight: 700;
  color: #3f4f5b;
  letter-spacing: 0.02em;
}

#process .process-schematic-labels span{
  position: absolute;
  left: 50%;
  transform: translateX(26px);
  white-space: nowrap;
}

#process .process-schematic-labels .step-1{ top: 10%; }
#process .process-schematic-labels .step-2{ top: 32%; }
#process .process-schematic-labels .step-3{ top: 55%; }
#process .process-schematic-labels .step-4{ top: 78%; }

#process .process-step-tabs{
  margin-top: 26px;
  border-radius: 999px;
  background: #f5f3ec;
  border: 1px solid rgba(32,44,56,0.12);
  padding: 6px 10px;
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

#process .process-step-tab{
  flex: 1 1 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: #2f3d48;
  transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

#process .process-step-tab-index{
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid rgba(32,44,56,0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}

#process .process-step-tab-label{
  white-space: nowrap;
}

#process .process-step-tab.is-active{
  background: #202c38;
  color: #f5f5f0;
  box-shadow: 0 10px 22px rgba(32,44,56,0.26);
}

#process .process-step-tab.is-active .process-step-tab-index{
  border-color: transparent;
  background: #f5f5f0;
  color: #202c38;
}

#process .process-schematic-step .process-stair-step{
  box-shadow: 0 5px 10px rgba(32,44,56,0.14);
}

#process .process-copy-panels{
  margin: 10px 0 26px;
  max-width: var(--measure);
}

#process .process-copy-panel{
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

#process .process-copy-panel .process-step-outcome{
  margin: 0 0 14px;
  padding: 14px 18px;
  background: #eef2f5;
  border-left: 3px solid var(--gold);
  color: #1f2a34;
  font-size: 17px;
  line-height: 1.5;
}

#process .process-copy-panel ul{
  margin: 0;
  padding-left: 0;
  list-style: none;
  font-size: 16px;
  line-height: 1.6;
}

#process .process-copy-panel ul li{
  position: relative;
  padding-left: 18px;
}

#process .process-copy-panel ul li::before{
  content: '•';
  position: absolute;
  left: 4px;
  top: 0.15em;
  font-size: 0.85em;
  color: #5f6d78;
}

#process .process-stair-step{
  /* reused as base class for tabs; visual styles kommen bei .process-step-tab */
}

#process .process-visual-panels{
  position: relative;
  z-index: 1;
  margin-top: 10px;
  max-width: 100%;
}

#process .process-visual-panels .process-step-card{
  margin-top: 0 !important;
  grid-column: unset !important;
  background: #1f2a34 !important;
  border: none !important;
  box-shadow: 0 18px 40px rgba(32,44,56,0.28) !important;
  border-radius: 0 !important;
  padding: 14px !important;
  min-height: 0;
  display: none;
  align-items: center;
  justify-content: center;
}

#process .process-visual-panels .process-visual-card.is-active{
  display: flex;
}

#process .process-visual-panels .process-step-visual{
  width: 100%;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  height: auto !important;
}

#process .process-slide-placeholder{
  width: 100%;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #f0f2f4 0%, #dfe4e8 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
}

@keyframes process-slide-in-forward{
  from{
    opacity: 0;
    transform: translateX(120px);
  }
  to{
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes process-slide-in-backward{
  from{
    opacity: 0;
    transform: translateX(-120px);
  }
  to{
    opacity: 1;
    transform: translateX(0);
  }
}

#process .process-copy-panel.is-active.is-forward,
#process .process-visual-card.is-active.is-forward{
  animation: process-slide-in-forward 0.9s ease-out;
}

#process .process-copy-panel.is-active.is-backward,
#process .process-visual-card.is-active.is-backward{
  animation: process-slide-in-backward 0.9s ease-out;
}

#process .process-slide-placeholder-inner{
  text-align: left;
  padding: var(--r24);
  max-width: 100%;
}

#process .process-slide-kicker{
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #5f6d78;
  font-weight: 700;
  margin-bottom: 8px;
}

#process .process-slide-title{
  font-size: 20px;
  line-height: 1.2;
  color: #1f2a34;
  font-weight: 800;
  margin-bottom: 8px;
}

#process .process-slide-note{
  font-size: 12px;
  line-height: 1.5;
  color: #5f6d78;
}

@media (max-width: 980px){
  #process .process-copy-panels{
    margin-bottom: 8px;
  }

  #process .process-slide-title{
    font-size: 16px;
  }
}

/* ══════════════════════════════════════════
   PROCESS — Linear (vier Blöcke, kein Tab/Visual)
══════════════════════════════════════════ */
#process .process-core{
  max-width:640px;
}
#process .process-header{
  margin-bottom:56px;
}
#process .process-steps{
  margin-top:8px;
}
#process .process-step-block{
  margin:0;
  padding:0;
  background:transparent;
  border:none;
  box-shadow:none;
}
#process .process-step-block + .process-step-block{
  margin-top:80px;
}
#process .process-step-label{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  margin:0 0 16px;
  font-weight:inherit;
  line-height:1.2;
}
#process .process-step-num{
  display:block;
  font-size:14px;
  font-weight:400;
  color:var(--muted);
  letter-spacing:0;
}
#process .process-step-title{
  display:block;
  font-size:22px;
  font-weight:600;
  letter-spacing:-0.02em;
  color:var(--dark);
  line-height:1.25;
}
#process .process-step-lead{
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  color:var(--text-secondary);
  margin:0 0 20px;
  max-width:640px;
}
#process .process-step-points{
  list-style:none;
  margin:0;
  padding:0;
  max-width:640px;
}
#process .process-step-points li{
  margin:0 0 10px;
  padding-left:0.35em;
  margin-left:0.85em;
  font-size:15px;
  line-height:1.55;
  font-weight:400;
  /* 2./3. Punkt: etwas heller als Standard-Fließtext */
  color:color-mix(in srgb, var(--muted) 72%, var(--white));
  list-style-type:'\2013\00a0';
  list-style-position:outside;
}
#process .process-step-points li::marker{
  /* Strich minimal heller als der jeweilige Listen-Text */
  color:color-mix(in srgb, var(--muted) 52%, var(--white));
}
#process .process-step-points li:first-child{
  font-weight:600;
  color:var(--dark);
}
#process .process-step-points li:first-child::marker{
  color:var(--muted);
}
#process .process-step-points li:last-child{
  margin-bottom:0;
}
@media (max-width:640px){
  #process .process-step-block + .process-step-block{
    margin-top:64px;
  }
  #process .process-step-lead{
    font-size:16px;
  }
}

/* ══════════════════════════════════════════
   CASES — editorial linear (keine Cards/Tabs)
══════════════════════════════════════════ */
#cases{
  background:var(--white);
  color:var(--text);
}
#cases .cases-intro{
  margin-bottom:48px;
  max-width:640px;
}
#cases .cases-intro-title{
  font-size:clamp(32px,4vw,44px);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-0.03em;
  color:var(--dark);
}
#cases .cases-stack{
  margin:0;
  padding:0;
}
#cases .cases-item{
  position:relative;
  margin:0 0 64px;
  padding:0 0 0 24px;
  background:transparent;
  border:none;
  box-shadow:none;
}
#cases .cases-item::before{
  content:"";
  position:absolute;
  left:0;
  top:8px;
  width:2px;
  height:calc(100% - 16px);
  background:var(--light2);
}
/* Signature-Case: deutlich mehr Luft vor den folgenden Stories */
#cases .cases-stack > .cases-item:first-child{
  margin-bottom:var(--section-pad);
}
#cases .cases-stack > .cases-item:first-child .cases-item-head{
  margin-bottom:32px;
}
#cases .cases-stack > .cases-item:first-child .cases-item-title{
  font-size:clamp(24px,3.1vw,30px);
}
#cases .cases-stack > .cases-item:first-child .cases-item-company-sub{
  font-size:clamp(21px,2.6vw,26px);
}
#cases .cases-stack > .cases-item:first-child .cases-item-company-text{
  font-size:15px;
}
#cases .cases-stack > .cases-item:first-child .cases-block-text{
  font-size:18px;
  line-height:1.72;
}
#cases .cases-item-head{
  margin-bottom:32px;
  max-width:640px;
}
/* Case 2+: leicht kleiner als Signature, gleiche Stufenfolge Title → Sub → Meta → Body */
#cases .cases-item-title{
  font-size:clamp(20px,2.55vw,26px);
  font-weight:600;
  line-height:1.25;
  letter-spacing:-0.02em;
  color:var(--dark);
}
#cases .cases-item-company-sub{
  margin:0;
  max-width:640px;
  font-size:clamp(18px,2.15vw,22px);
  font-weight:600;
  line-height:1.2;
  letter-spacing:-0.02em;
  color:var(--dark);
}
#cases .cases-item-company-text{
  margin:0;
  max-width:640px;
  font-size:13px;
  line-height:1.55;
  font-weight:400;
  color:var(--muted);
  letter-spacing:0.01em;
}
#cases .cases-item-body{
  max-width:640px;
}
#cases .cases-block{
  margin-bottom:48px;
}
#cases .cases-block-text{
  font-size:16px;
  line-height:1.68;
  color:var(--text-secondary);
  font-weight:400;
}
@media (max-width:980px){
  #cases .cases-item{
    margin-bottom:64px;
  }
  #cases .cases-item-head{
    margin-bottom:32px;
  }
  #cases .cases-stack > .cases-item:first-child .cases-item-head{
    margin-bottom:32px;
  }
}
@media (max-width:640px){
  #cases .cases-intro{
    margin-bottom:48px;
  }
  #cases .cases-stack > .cases-item:first-child .cases-item-title{
    font-size:clamp(23px,6.4vw,27px);
  }
  #cases .cases-stack > .cases-item:not(:first-child) .cases-item-company-sub{
    font-size:clamp(17px,4.4vw,20px);
  }
  #cases .cases-stack > .cases-item:first-child .cases-item-company-sub{
    font-size:clamp(19px,5.1vw,22px);
  }
  #cases .cases-stack > .cases-item:not(:first-child) .cases-item-company-text{
    font-size:12px;
    line-height:1.5;
  }
  #cases .cases-stack > .cases-item:first-child .cases-item-company-text{
    font-size:14px;
    line-height:1.5;
  }
  #cases .cases-stack > .cases-item:not(:first-child) .cases-block-text{
    font-size:15px;
    line-height:1.65;
  }
  #cases .cases-stack > .cases-item:first-child .cases-block-text{
    font-size:17px;
    line-height:1.68;
  }
  #cases .cases-block{
    margin-bottom:32px;
  }
}