/* ==========================================================================
   VOVAN GLOBAL — Redesign 2026 "Fresh Trade"
   Modern B2B Food & Trend Distribution
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap');

/* ==========================================================================
   1. DESIGN TOKENS
   ========================================================================== */
:root{
  --brand-primary:#2DD4BF;
  --brand-primary-deep:#0F766E;
  --brand-secondary:#C7B8FF;
  --brand-secondary-deep:#6B5BD6;
  --accent-candy:#FFB3C7;
  --accent-candy-deep:#E8588A;
  --accent-butter:#FFE27A;
  --accent-butter-deep:#D4A20E;
  --accent-coral:#FF8A65;
  --accent-coral-deep:#D55A3A;

  --bg-base:#FAF7F2;
  --bg-alt:#F3EEE6;
  --surface-card:#FFFFFF;
  --surface-tinted-mint:#E8FBF7;
  --surface-tinted-lilac:#F1ECFF;
  --surface-tinted-candy:#FFECF1;
  --surface-tinted-butter:#FFF7D6;
  --surface-tinted-coral:#FFEFE8;

  --text-primary:#1A1B2E;
  --text-secondary:#5A5B70;
  --text-muted:#8A8BA0;
  --text-on-brand:#FFFFFF;

  --border-soft:#ECE6DC;
  --border-strong:#D8D0C2;

  --state-success:#22C55E;
  --state-warning:#F59E0B;
  --state-error:#EF4444;

  --page-accent:#2DD4BF;
  --page-accent-deep:#0F766E;
  --page-accent-tint:#E8FBF7;
  --page-mesh-a:#2DD4BF;
  --page-mesh-b:#C7B8FF;

  --radius-xs:8px; --radius-sm:12px; --radius-md:14px;
  --radius-lg:20px; --radius-xl:24px; --radius-2xl:28px;
  --radius-3xl:32px; --radius-pill:999px;

  --space-1:4px; --space-2:8px; --space-3:12px;
  --space-4:16px; --space-5:20px; --space-6:24px;
  --space-8:32px; --space-10:40px; --space-12:48px;
  --space-16:64px; --space-20:80px; --space-24:96px; --space-32:128px;

  --shadow-xs:0 1px 2px rgba(26,27,46,.04);
  --shadow-sm:0 1px 2px rgba(26,27,46,.04),0 4px 12px -4px rgba(26,27,46,.06);
  --shadow-md:0 4px 8px -2px rgba(26,27,46,.06),0 12px 32px -12px rgba(26,27,46,.1);
  --shadow-lg:0 8px 16px -4px rgba(26,27,46,.08),0 24px 56px -20px rgba(26,27,46,.14);
  --shadow-mint:0 12px 32px -12px rgba(45,212,191,.35);
  --shadow-focus:0 0 0 3px rgba(45,212,191,.28);

  --font-display:'Geist','General Sans',system-ui,-apple-system,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;
  --font-mono:'Geist Mono','JetBrains Mono',ui-monospace,monospace;

  --fs-h1:clamp(2.75rem,5.5vw,5.5rem);
  --fs-h2:clamp(1.875rem,3.2vw,3.25rem);
  --fs-h3:clamp(1.375rem,2vw,2rem);
  --fs-h4:clamp(1.125rem,1.4vw,1.5rem);
  --fs-subhead:1.125rem;
  --fs-body:1rem;
  --fs-small:.875rem;
  --fs-caption:.8125rem;
  --fs-kpi:clamp(2.25rem,4vw,4rem);

  --lh-tight:1.02; --lh-snug:1.2; --lh-body:1.6;

  --maxw:1280px;
  --container-pad:clamp(20px,4vw,48px);

  --btn-h-sm:40px; --btn-h-md:48px; --btn-h-lg:56px;

  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --ease-in-out:cubic-bezier(0.65,0,0.35,1);
  --dur-fast:180ms; --dur-base:240ms; --dur-slow:400ms; --dur-xslow:600ms;

  /* Legacy compat shims */
  --bg:var(--bg-base); --bg-2:var(--bg-alt);
  --text:var(--text-primary); --muted:var(--text-secondary);
  --card:var(--surface-card);
  --brand:var(--brand-primary); --brand-2:var(--brand-primary-deep);
  --accent:var(--accent-candy);
  --success:var(--state-success); --warning:var(--state-warning);
  --shadow:var(--shadow-lg);
  --step-0:clamp(1rem,.9rem + .4vw,1.125rem);
  --step-1:clamp(1.25rem,1.05rem + .8vw,1.5rem);
  --step-2:clamp(1.75rem,1.4rem + 1.4vw,2.5rem);
  --step-3:clamp(2.25rem,1.8rem + 2vw,3.5rem);
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* ==========================================================================
   2. BASE
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:hidden;max-width:100vw}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:var(--lh-body);
  color:var(--text-primary);
  background:var(--bg-base);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  max-width:100vw;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand-primary-deep);text-decoration:none;transition:color var(--dur-fast) var(--ease-out)}
a:hover{color:var(--text-primary)}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  font-weight:600;
  color:var(--text-primary);
  margin:0 0 .5em;
  letter-spacing:-.02em;
}
h1{font-size:var(--fs-h1);line-height:var(--lh-tight)}
h2{font-size:var(--fs-h2);line-height:var(--lh-snug)}
h3{font-size:var(--fs-h3);line-height:var(--lh-snug)}
h4{font-size:var(--fs-h4);line-height:var(--lh-snug)}
p{margin:0 0 1em;color:var(--text-secondary)}
strong{color:var(--text-primary);font-weight:600}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-40px;left:0;background:var(--text-primary);color:var(--text-on-brand);padding:8px 16px;z-index:9999;transition:top var(--dur-fast) var(--ease-out);border-radius:0 0 var(--radius-sm) 0}
.skip-link:focus{top:0}
:focus-visible{outline:2px solid var(--brand-primary);outline-offset:3px;border-radius:4px}

/* ==========================================================================
   3. LAYOUT
   ========================================================================== */
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--container-pad)}
.section{padding:var(--space-20) 0}
.section-alt{background:var(--bg-alt)}
.section-white{background:var(--surface-card)}
.section-tinted{background:var(--page-accent-tint)}
.section-head{margin-bottom:var(--space-10);max-width:760px}
.section-head h2{margin:0 0 var(--space-3)}
.section-head .eyebrow{
  display:inline-block;
  font-family:var(--font-body);
  font-size:var(--fs-caption);
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--page-accent-deep);
  margin-bottom:var(--space-3);
}
.section-subtitle,.hint{
  color:var(--text-secondary);
  font-size:var(--fs-subhead);
  line-height:var(--lh-body);
  margin:0;
}

.scroll-progress{
  position:fixed;top:0;left:0;
  height:3px;width:0%;
  background:linear-gradient(90deg,var(--brand-primary),var(--brand-secondary));
  z-index:9999;
  transition:width .1s linear;
  border-radius:0 3px 3px 0;
}

/* ==========================================================================
   4. HEADER / NAVIGATION
   ========================================================================== */
#header,.header{
  position:sticky;top:0;z-index:100;
  background:rgba(250,247,242,.82);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:border-color var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out);
}
#header.scrolled,.header.scrolled{
  border-bottom-color:var(--border-soft);
  background:rgba(250,247,242,.95);
}
#header nav,.header nav{
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--space-6);
  height:72px;
}
.brand{display:inline-flex;align-items:center;gap:10px;flex-shrink:0;transition:transform var(--dur-fast) var(--ease-out)}
.brand:hover{transform:scale(1.02)}
.brand img{height:40px;width:auto;max-width:180px;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:var(--space-2);flex-wrap:nowrap;margin-left:auto}
.nav-links>a{
  position:relative;padding:10px 14px;
  color:var(--text-primary);
  font-family:var(--font-display);
  font-size:.9375rem;font-weight:500;
  border-radius:var(--radius-sm);
  transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out);
}
.nav-links>a:hover{color:var(--brand-primary-deep);background:var(--surface-tinted-mint)}

.nav-dropdown{position:relative}
.nav-dropdown-toggle{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 14px;
  font-family:var(--font-display);
  font-size:.9375rem;font-weight:500;
  color:var(--text-primary);
  border-radius:var(--radius-sm);
  transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out);
}
.nav-dropdown-toggle:hover,.nav-dropdown:hover .nav-dropdown-toggle{color:var(--brand-primary-deep);background:var(--surface-tinted-mint)}
.nav-dropdown-toggle svg{transition:transform var(--dur-fast) var(--ease-out)}
.nav-dropdown:hover .nav-dropdown-toggle svg{transform:rotate(180deg)}
.nav-dropdown-menu{
  position:absolute;top:calc(100% + 8px);right:0;
  min-width:280px;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xl);
  padding:var(--space-2);
  box-shadow:var(--shadow-lg);
  opacity:0;visibility:hidden;
  transform:translateY(-8px);
  transition:all var(--dur-base) var(--ease-out);
  z-index:50;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-menu a{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;
  border-radius:var(--radius-sm);
  color:var(--text-primary);
  font-size:.9375rem;font-weight:500;
  transition:background var(--dur-fast) var(--ease-out);
}
.nav-dropdown-menu a:hover{background:var(--surface-tinted-mint);color:var(--brand-primary-deep)}
.nav-dropdown-menu a svg{flex-shrink:0;color:var(--page-accent-deep);opacity:.8}

.lang-toggle{
  display:inline-flex;
  background:var(--bg-alt);
  border-radius:var(--radius-pill);
  padding:3px;
  margin-left:var(--space-2);
}
.lang-btn{
  padding:6px 12px;
  font-size:.8125rem;font-weight:600;
  color:var(--text-secondary);
  border-radius:var(--radius-pill);
  transition:all var(--dur-fast) var(--ease-out);
}
.lang-btn.active{background:var(--surface-card);color:var(--text-primary);box-shadow:var(--shadow-xs)}
.lang-btn:hover:not(.active){color:var(--text-primary)}

.nav-links .cta-btn{
  display:inline-flex;align-items:center;justify-content:center;
  height:40px;padding:0 18px;
  background:var(--text-primary);
  color:var(--text-on-brand);
  font-family:var(--font-display);
  font-size:.9375rem;font-weight:500;
  border-radius:var(--radius-md);
  transition:background var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);
}
.nav-links .cta-btn:hover{background:var(--brand-primary);transform:translateY(-1px);color:#fff}
.nav-links .cta-btn.secondary{background:transparent;color:var(--text-primary);border:1.5px solid var(--text-primary)}
.nav-links .cta-btn.secondary:hover{background:var(--text-primary);color:var(--text-on-brand)}

.mobile-menu-toggle{
  display:none;
  flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:44px;padding:0;
  border-radius:var(--radius-sm);
  transition:background var(--dur-fast) var(--ease-out);
}
.mobile-menu-toggle:hover{background:var(--bg-alt)}
.hamburger-line{
  width:22px;height:2px;
  background:var(--text-primary);
  border-radius:2px;
  transition:all var(--dur-base) var(--ease-out);
}
.mobile-menu-toggle[aria-expanded=true] .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-menu-toggle[aria-expanded=true] .hamburger-line:nth-child(2){opacity:0}
.mobile-menu-toggle[aria-expanded=true] .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:1100px){
  .mobile-menu-toggle{display:flex}
  .nav-links{
    position:fixed;inset:72px 0 0 0;
    flex-direction:column;align-items:stretch;gap:var(--space-1);
    padding:var(--space-6);
    background:var(--bg-base);
    overflow-y:auto;
    transform:translateX(100%);
    transition:transform var(--dur-base) var(--ease-out);
    z-index:99;
  }
  .nav-links.active{transform:translateX(0)}
  .nav-links>a{font-size:1.125rem;padding:14px 16px}
  .nav-dropdown{width:100%}
  .nav-dropdown-menu{
    position:static;box-shadow:none;border:0;
    background:var(--bg-alt);
    opacity:1;visibility:visible;transform:none;
    min-width:0;margin-top:var(--space-2);
  }
  .nav-dropdown-toggle{width:100%;justify-content:space-between;font-size:1.125rem;padding:14px 16px}
}

/* ==========================================================================
   5. BUTTONS
   ========================================================================== */
.btn,button.btn,a.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;
  height:var(--btn-h-md);padding:0 28px;
  font-family:var(--font-display);
  font-size:.9375rem;font-weight:500;
  letter-spacing:-.01em;
  color:var(--text-on-brand);
  background:var(--text-primary);
  border:1.5px solid var(--text-primary);
  border-radius:var(--radius-md);
  cursor:pointer;
  transition:all var(--dur-fast) var(--ease-out);
  text-decoration:none;
  white-space:nowrap;
}
.btn:hover{background:var(--brand-primary);border-color:var(--brand-primary);color:var(--text-on-brand);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn:active{transform:translateY(0) scale(.98)}
.btn.primary{background:var(--text-primary);color:#fff;border-color:var(--text-primary)}
.btn.primary:hover{background:var(--brand-primary);border-color:var(--brand-primary)}
.btn.secondary,.btn.ghost{background:transparent;color:var(--text-primary);border:1.5px solid var(--text-primary)}
.btn.secondary:hover,.btn.ghost:hover{background:var(--text-primary);color:var(--text-on-brand)}
.btn.accent{background:var(--page-accent);border-color:var(--page-accent);color:#fff}
.btn.accent:hover{background:var(--page-accent-deep);border-color:var(--page-accent-deep)}
.btn-large{height:var(--btn-h-lg);padding:0 36px;font-size:1rem}
.btn-small{height:var(--btn-h-sm);padding:0 20px;font-size:.875rem}
.btn-group{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-6)}

/* ==========================================================================
   6. BADGES / PILLS
   ========================================================================== */
.badge,.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;
  font-family:var(--font-body);
  font-size:.8125rem;font-weight:500;
  letter-spacing:.01em;
  background:var(--page-accent-tint);
  color:var(--page-accent-deep);
  border-radius:var(--radius-pill);
  border:1px solid transparent;
}
.badge-new,.badge-trending,.badge-fresh,.badge-success,.badge-upcoming,.badge-schmeckt,.badge-hot{
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:.75rem;font-weight:600;
}
.badge-new{background:var(--surface-tinted-candy);color:var(--accent-candy-deep)}
.badge-trending,.badge-hot{background:var(--surface-tinted-coral);color:var(--accent-coral-deep)}
.badge-fresh{background:var(--surface-tinted-mint);color:var(--brand-primary-deep)}
.badge-success{background:#DCFCE7;color:#15803D}
.badge-upcoming{background:var(--surface-tinted-butter);color:var(--accent-butter-deep)}
.badge-schmeckt{background:var(--surface-tinted-lilac);color:var(--brand-secondary-deep)}
.badge-brand{background:var(--text-primary);color:var(--text-on-brand)}
.badge-italia{background:var(--surface-tinted-butter);color:var(--accent-coral-deep)}
.flag-mini{display:inline-flex;gap:2px;width:18px;height:12px;border-radius:2px;overflow:hidden}
.flag-mini span{flex:1}
.flag-mini span:nth-child(1){background:#008C45}
.flag-mini span:nth-child(2){background:#F4F5F0}
.flag-mini span:nth-child(3){background:#CD212A}

/* ==========================================================================
   7. HERO
   ========================================================================== */
.hero{
  position:relative;
  padding:var(--space-16) 0 var(--space-24);
  background:var(--bg-base);
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;top:-10%;right:-15%;
  width:800px;height:800px;
  background:radial-gradient(circle at center,var(--page-mesh-a) 0%,transparent 60%);
  filter:blur(80px);
  opacity:.35;
  pointer-events:none;
  z-index:0;
}
.hero::after{
  content:"";
  position:absolute;bottom:-20%;left:-10%;
  width:600px;height:600px;
  background:radial-gradient(circle at center,var(--page-mesh-b) 0%,transparent 60%);
  filter:blur(80px);
  opacity:.3;
  pointer-events:none;
  z-index:0;
}
.hero>.container{position:relative;z-index:1}
.parallax-bg{display:none}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:var(--space-16);
  align-items:center;
}
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:var(--space-10)}
  .hero{padding:var(--space-12) 0 var(--space-16)}
}
.hero h1{
  font-size:var(--fs-h1);
  line-height:1.02;
  letter-spacing:-.03em;
  margin:var(--space-4) 0 var(--space-5);
  color:var(--text-primary);
}
.hero h1 .typing-text{display:inline;color:var(--text-primary)}
.typing-cursor{
  display:inline-block;
  width:4px;
  background:var(--brand-primary);
  margin-left:4px;
  animation:blink 1s step-end infinite;
  color:transparent;
  border-radius:2px;
}
@keyframes blink{50%{opacity:0}}
.hero p{
  font-size:var(--fs-subhead);
  line-height:1.55;
  color:var(--text-secondary);
  max-width:56ch;
  margin:0 0 var(--space-6);
}
.hero-media{
  position:relative;
  aspect-ratio:1/1;
  max-width:560px;
  margin-left:auto;
  display:grid;place-items:center;
}
.hero-media::before{
  content:"";
  position:absolute;inset:5%;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--page-mesh-a) 0%,var(--page-mesh-b) 60%,transparent 100%);
  opacity:.55;
  filter:blur(20px);
  animation:float 8s ease-in-out infinite;
}
.hero-media img{
  position:relative;
  width:85%;height:auto;
  border-radius:var(--radius-3xl);
  box-shadow:var(--shadow-lg);
  z-index:1;
  animation:floatSmall 6s ease-in-out infinite;
}
@keyframes float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.03)}}
@keyframes floatSmall{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.hero-stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--space-4);
  margin-top:var(--space-8);
}
@media (max-width:700px){.hero-stats-grid{grid-template-columns:repeat(2,1fr)}}
.hero-stat{
  padding:var(--space-5) var(--space-4);
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-xs);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.hero-stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.hero-stat-number{
  font-family:var(--font-mono);
  font-size:clamp(1.75rem,2.5vw,2.5rem);
  font-weight:600;
  line-height:1;
  color:var(--text-primary);
  letter-spacing:-.02em;
  display:flex;align-items:baseline;gap:2px;
}
.hero-stat-number .counter{color:var(--page-accent-deep)}
.hero-stat-number span:last-child{color:var(--page-accent)}
.hero-stat-label{
  font-size:var(--fs-caption);
  font-weight:500;
  color:var(--text-secondary);
  margin-top:var(--space-2);
  letter-spacing:.02em;
}

.trust-badges{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-6)}
.trust-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-pill);
  box-shadow:var(--shadow-xs);
}
.trust-badge-icon{
  width:32px;height:32px;
  display:grid;place-items:center;
  background:var(--surface-tinted-mint);
  border-radius:var(--radius-pill);
  font-size:.875rem;
  color:var(--brand-primary-deep);
  flex-shrink:0;
}
.trust-badge-text{display:flex;flex-direction:column;line-height:1.1}
.trust-badge-text strong{font-size:.8125rem;font-weight:600;color:var(--text-primary)}
.trust-badge-text span{font-size:.75rem;color:var(--text-secondary)}

/* ==========================================================================
   8. ITALIA / ASIA / USA (shared grid)
   ========================================================================== */
.italia-section{background:var(--surface-tinted-butter)!important;padding:var(--space-20) 0}
.asia-section{background:var(--surface-tinted-candy)!important;padding:var(--space-20) 0}
.usa-section{background:var(--surface-tinted-lilac)!important;padding:var(--space-20) 0}
.italia-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-16);
  align-items:center;
}
@media (max-width:900px){.italia-grid{grid-template-columns:1fr;gap:var(--space-10)}}
.italia-content h2{font-size:var(--fs-h2);margin:var(--space-3) 0 var(--space-4)}
.italia-content .text-red{color:var(--accent-coral-deep)}
.italia-content p{font-size:var(--fs-subhead);color:var(--text-secondary);margin-bottom:var(--space-6);max-width:56ch}
.italia-brands{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:var(--space-6);
  margin-bottom:var(--space-6);
  opacity:.85;
}
.italia-brands img{max-height:42px;width:auto;object-fit:contain;filter:grayscale(30%);transition:filter var(--dur-base) var(--ease-out)}
.italia-brands img:hover{filter:grayscale(0)}
.italia-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-3);
  margin-bottom:var(--space-6);
}
.italia-stat{
  padding:var(--space-4);
  background:var(--surface-card);
  border-radius:var(--radius-lg);
  text-align:center;
}
.italia-stat strong{
  display:block;
  font-family:var(--font-mono);
  font-size:1.75rem;font-weight:600;
  color:var(--text-primary);
}
.italia-stat span{font-size:var(--fs-caption);color:var(--text-secondary)}
.italia-image{position:relative;border-radius:var(--radius-2xl);overflow:hidden}
.italia-image a{display:block;position:relative}
.italia-image img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius-2xl);
  transition:transform var(--dur-slow) var(--ease-out);
}
.italia-image:hover img{transform:scale(1.03)}
.italia-image-overlay{
  position:absolute;
  inset:auto 20px 20px 20px;
  padding:var(--space-4) var(--space-5);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);
  border-radius:var(--radius-lg);
  font-weight:600;
  color:var(--text-primary);
  opacity:0;
  transform:translateY(10px);
  transition:all var(--dur-base) var(--ease-out);
}
.italia-image:hover .italia-image-overlay{opacity:1;transform:translateY(0)}
.italia-btn{background:var(--text-primary);border-color:var(--text-primary);color:#fff}
.italia-btn:hover{background:var(--brand-primary);border-color:var(--brand-primary)}

/* ==========================================================================
   9. MARQUEE
   ========================================================================== */
.marquee{
  position:relative;
  overflow:hidden;
  padding:var(--space-6) 0;
  mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);
  -webkit-mask-image:linear-gradient(to right,transparent,#000 6%,#000 94%,transparent);
  height:auto;
  margin-top:var(--space-4);
}
.marquee .track{
  display:flex;align-items:center;
  gap:var(--space-8);
  animation:marq 60s linear infinite;
  will-change:transform;
}
.marquee:hover .track{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-tile{
  flex:0 0 auto;
  width:180px;height:80px;
  display:grid;place-items:center;
  padding:var(--space-3);
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-xs);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.logo-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.logo-tile img{
  max-height:50px;
  width:auto;
  object-fit:contain;
  filter:grayscale(60%);
  opacity:.75;
  transition:all var(--dur-base) var(--ease-out);
}
.logo-tile:hover img{filter:grayscale(0);opacity:1}

/* ==========================================================================
   10. CARDS / PROJECTS / PRODUCTS
   ========================================================================== */
.card{
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xl);
  padding:var(--space-6);
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}

.projects-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:var(--space-6);
  margin-top:var(--space-8);
}
.project-card{
  display:flex;flex-direction:column;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.project-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.project-image{
  position:relative;
  aspect-ratio:4/3;
  background:var(--surface-tinted-mint);
  overflow:hidden;
}
.project-image img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform var(--dur-slow) var(--ease-out);
}
.project-card:hover .project-image img{transform:scale(1.04)}
.project-badges{
  position:absolute;top:16px;left:16px;
  display:flex;flex-wrap:wrap;gap:6px;
  z-index:2;
}
.project-content{padding:var(--space-6)}
.project-content h3{font-size:1.375rem;margin-bottom:var(--space-2);color:var(--text-primary)}
.project-content p{color:var(--text-secondary);margin-bottom:var(--space-4)}
.project-content strong{color:var(--text-primary)}
.project-content ul{margin:var(--space-3) 0;padding-left:var(--space-5);color:var(--text-secondary)}
.project-content ul li{margin-bottom:var(--space-1)}
.project-meta{
  display:flex;flex-wrap:wrap;gap:var(--space-4);
  padding-top:var(--space-4);
  margin-top:var(--space-4);
  border-top:1px solid var(--border-soft);
}
.project-meta small{color:var(--text-muted);font-size:var(--fs-caption)}
/* Overlay variant: only when nested inside .project-image / .product-image */
.project-image .project-fallback,
.project-image .project-placeholder,
.project-image .image-placeholder,
.product-image .project-fallback,
.product-image .project-placeholder,
.product-image .image-placeholder{
  position:absolute;inset:0;
  display:grid;place-items:center;
  padding:var(--space-6);
  background:linear-gradient(135deg,var(--surface-tinted-mint),var(--surface-tinted-lilac));
  text-align:center;
}
/* Standalone card variant (e.g. "Weitere Innovationen in Planung") */
.project-card.project-placeholder{
  position:relative;
  min-height:320px;
  display:grid;place-items:center;
  padding:var(--space-10) var(--space-6);
  background:linear-gradient(135deg,var(--surface-tinted-mint),var(--surface-tinted-lilac));
  text-align:center;
  border:1px dashed var(--border-strong);
}
.project-placeholder-content{max-width:240px}
.placeholder-icon{
  width:72px;height:72px;
  margin:0 auto var(--space-3);
  display:grid;place-items:center;
  background:var(--surface-card);
  border-radius:50%;
  color:var(--brand-primary-deep);
  box-shadow:var(--shadow-sm);
}
.placeholder-icon svg{width:32px;height:32px}
.image-placeholder h3{color:var(--text-primary);margin-bottom:var(--space-2)}
.image-placeholder p{color:var(--text-secondary);font-size:var(--fs-small)}

.available-products-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:var(--space-6);
  margin-top:var(--space-8);
}
.product-card{
  display:flex;flex-direction:column;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
  position:relative;
}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.product-link{display:block;color:inherit}
.product-image,.product-image-froozly{
  position:relative;
  aspect-ratio:1/1;
  background:var(--surface-tinted-mint);
  overflow:hidden;
}
.product-image img,.product-image-froozly img{
  width:100%;height:100%;
  object-fit:contain;
  padding:var(--space-6);
  transition:transform var(--dur-slow) var(--ease-out);
}
.product-card:hover .product-image img,
.product-card:hover .product-image-froozly img{transform:scale(1.05)}
.product-badge{
  position:absolute;top:14px;left:14px;
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 11px;
  font-size:.6875rem;font-weight:600;
  letter-spacing:.05em;text-transform:uppercase;
  border-radius:var(--radius-pill);
  z-index:2;
  background:var(--surface-card);
  color:var(--text-primary);
  box-shadow:var(--shadow-xs);
}
.product-badge svg{width:12px;height:12px}
.product-info{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}
.product-info h3{font-size:1.125rem;margin:0;color:var(--text-primary)}
.product-info p{color:var(--text-secondary);font-size:var(--fs-small);margin:0}
.product-meta{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:var(--space-3);
  margin-top:auto;
}
.availability-tag{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.75rem;font-weight:500;
  color:var(--state-success);
}
.availability-tag svg{width:14px;height:14px}
.product-cta{font-size:.875rem;font-weight:500;color:var(--brand-primary-deep)}
.products-cta{display:flex;justify-content:center;margin-top:var(--space-10)}

.future-product-card{background:var(--surface-tinted-butter);border-color:transparent}
.future-product-details{padding:var(--space-2) 0}
.future-product-details h4{font-size:1rem;margin:var(--space-3) 0 var(--space-2);color:var(--text-primary)}
.variants-list{list-style:none;margin:0;padding:0}
.variants-list li{
  position:relative;
  padding-left:18px;
  font-size:var(--fs-small);
  color:var(--text-secondary);
  margin-bottom:var(--space-1);
}
.variants-list li::before{
  content:"";
  position:absolute;left:0;top:9px;
  width:8px;height:2px;
  background:var(--page-accent);
  border-radius:2px;
}
.variants-list li strong{color:var(--text-primary);font-weight:600}
.future-meta{
  margin-top:var(--space-3);
  padding-top:var(--space-3);
  border-top:1px solid var(--border-soft);
  font-size:var(--fs-caption);
  color:var(--text-muted);
}
.future-meta strong{color:var(--text-primary)}
.future-placeholder{
  padding:var(--space-10);
  text-align:center;
  background:linear-gradient(135deg,var(--surface-tinted-lilac),var(--surface-tinted-candy));
  border-radius:var(--radius-2xl);
}
.future-placeholder h3{font-size:1.25rem;color:var(--text-primary)}
.future-placeholder p{color:var(--text-secondary)}

.case-bites{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:var(--space-4);
  margin-top:var(--space-6);
}
.bite{
  padding:var(--space-5);
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-xs);
}
.bite strong{
  display:block;
  font-family:var(--font-mono);
  font-size:1.5rem;font-weight:600;
  color:var(--text-primary);
  margin-bottom:var(--space-1);
}
.bite p{color:var(--text-secondary);margin:0;font-size:var(--fs-small)}

/* ==========================================================================
   11. INFLUENCER MARQUEE
   ========================================================================== */
.influencer-marquee{
  position:relative;
  overflow:hidden;
  padding:var(--space-4) 0;
  mask-image:linear-gradient(to right,transparent,#000 5%,#000 95%,transparent);
}
.influencer-marquee .track{
  display:flex;gap:var(--space-4);
  animation:marq 80s linear infinite;
  will-change:transform;
}
.influencer-marquee:hover .track{animation-play-state:paused}
.influencer-tile{
  flex:0 0 auto;
  width:260px;
  aspect-ratio:9/16;
  background:var(--surface-card);
  border-radius:var(--radius-xl);
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.influencer-tile:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-lg)}
.influencer-tile img{width:100%;height:100%;object-fit:cover}
.influencer-tile .influencer-name{
  position:absolute;bottom:0;left:0;right:0;
  padding:var(--space-5) var(--space-4) var(--space-3);
  background:linear-gradient(to top,rgba(0,0,0,.7),transparent);
  color:#fff;
  font-weight:600;
  font-size:.875rem;
}
.marquee-nav{display:flex;gap:var(--space-2);justify-content:center;margin-top:var(--space-6)}
.marquee-nav button,.marquee-nav-prev,.marquee-nav-next{
  width:44px;height:44px;
  display:grid;place-items:center;
  background:var(--surface-card);
  border:1.5px solid var(--border-soft);
  border-radius:50%;
  color:var(--text-primary);
  transition:all var(--dur-fast) var(--ease-out);
}
.marquee-nav button:hover,.marquee-nav-prev:hover,.marquee-nav-next:hover{background:var(--text-primary);color:#fff;border-color:var(--text-primary)}

.influencer-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:var(--space-6);
  margin-top:var(--space-8);
}
.influencer-card{
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.influencer-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.video-link{display:block;position:relative;color:inherit}
.video-thumbnail{position:relative;aspect-ratio:9/16;overflow:hidden;background:var(--surface-tinted-candy)}
.video-thumbnail img{width:100%;height:100%;object-fit:cover}
.play-overlay{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:72px;height:72px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.92);
  border-radius:50%;
  color:var(--text-primary);
  box-shadow:var(--shadow-md);
  transition:transform var(--dur-base) var(--ease-out);
}
.influencer-card:hover .play-overlay{transform:translate(-50%,-50%) scale(1.08)}
.play-overlay svg circle{stroke:var(--text-primary)}
.instagram-badge{
  position:absolute;top:14px;right:14px;
  padding:6px 10px;
  background:linear-gradient(135deg,#833AB4,#E1306C,#FCAF45);
  color:#fff;
  font-size:.6875rem;font-weight:600;
  border-radius:var(--radius-pill);
}
.influencer-info{padding:var(--space-5)}
.influencer-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}
.influencer-profile{display:flex;align-items:center;gap:var(--space-3);flex:1}
.profile-pic-placeholder{
  width:48px;height:48px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent-candy),var(--brand-secondary));
  color:#fff;font-weight:700;font-size:1.125rem;
  border-radius:50%;
}
.influencer-details{display:flex;flex-direction:column;gap:2px}
.influencer-name{font-weight:600;color:var(--text-primary);font-size:.9375rem}
.influencer-handle{font-size:.8125rem;color:var(--text-muted)}
.follower-count{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.75rem;color:var(--text-secondary);
  margin-left:auto;
}
.follower-count svg{width:14px;height:14px}
.video-description h4{font-size:1rem;margin-bottom:var(--space-1);color:var(--text-primary)}
.video-description p{font-size:var(--fs-small);color:var(--text-secondary);margin:0}
.video-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-top:var(--space-4);margin-top:var(--space-4);border-top:1px solid var(--border-soft)}
.product-tag{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 10px;
  font-size:.75rem;font-weight:500;
  background:var(--surface-tinted-mint);
  color:var(--brand-primary-deep);
  border-radius:var(--radius-pill);
}
.product-tag svg{width:12px;height:12px}
.view-cta{font-size:.8125rem;font-weight:600;color:var(--brand-primary-deep)}

.influencer-placeholder{
  padding:var(--space-8);
  background:linear-gradient(135deg,var(--surface-tinted-candy),var(--surface-tinted-lilac));
  border-radius:var(--radius-2xl);
  text-align:center;
}
.placeholder-thumbnail{display:grid;place-items:center;aspect-ratio:9/16;max-height:200px;margin:0 auto}
.influencer-placeholder h4{color:var(--text-primary);margin-bottom:var(--space-2)}
.influencer-placeholder p{color:var(--text-secondary);font-size:var(--fs-small)}

/* ==========================================================================
   12. WIDE VISUAL CTA PANELS
   ========================================================================== */
.wide-visual{
  position:relative;
  padding:var(--space-16) var(--space-10);
  background:linear-gradient(135deg,var(--surface-tinted-mint),var(--surface-tinted-lilac));
  border-radius:var(--radius-3xl);
  overflow:hidden;
  min-height:280px;
  display:grid;
  align-items:end;
}
.wide-visual::before{
  content:"";
  position:absolute;
  inset:-30% -10% auto auto;
  width:420px;height:420px;
  background:radial-gradient(circle,var(--accent-candy) 0%,transparent 60%);
  filter:blur(60px);
  opacity:.5;
}
.wide-visual .label{position:relative;z-index:1}
.wide-visual .label strong{
  display:block;
  font-family:var(--font-display);
  font-size:clamp(1.5rem,2.4vw,2.25rem);
  font-weight:600;
  color:var(--text-primary);
  letter-spacing:-.02em;
  margin-bottom:var(--space-2);
}
.wide-visual .label span,
.wide-visual .label p{color:var(--text-secondary);font-size:var(--fs-subhead)}

/* ==========================================================================
   13. INSTAGRAM EMBED RESET
   ========================================================================== */
.instagram-feed-container{
  background:var(--surface-card);
  border-radius:var(--radius-2xl);
  overflow:hidden;
  border:1px solid var(--border-soft);
  padding:var(--space-6);
}
.embedsocial-hashtag,.embedsocial-instagram{background:transparent!important}
.embedsocial-hashtag .es-feed-header,
.embedsocial-hashtag .es-feed-container{background:transparent!important;color:var(--text-primary)!important}
.embedsocial-hashtag .es-feed-header{padding:var(--space-3) 0!important;margin-bottom:var(--space-4)!important;border-bottom:1px solid var(--border-soft)!important}
.embedsocial-hashtag .es-feed-header .es-feed-avatar{border-radius:50%!important}
.embedsocial-hashtag .es-feed-header h3,
.embedsocial-hashtag .es-feed-header p,
.embedsocial-hashtag .es-feed-header a{color:var(--text-primary)!important}
.embedsocial-hashtag .es-feed-header button,
.embedsocial-hashtag .es-feed-header .es-follow-btn{
  background:var(--text-primary)!important;color:#fff!important;
  border:0!important;border-radius:var(--radius-pill)!important;
  padding:8px 16px!important;font-weight:500!important;
}
.embedsocial-hashtag .es-feed-header button:hover,
.embedsocial-hashtag .es-feed-header .es-follow-btn:hover{background:var(--brand-primary)!important}
.instagram-feed-container .embedsocial-hashtag .es-feed-item,
.instagram-feed-container .embedsocial-hashtag .es-post{
  background:var(--surface-card)!important;
  border-radius:var(--radius-lg)!important;
  overflow:hidden;
  box-shadow:var(--shadow-xs)!important;
}
.instagram-feed-container .embedsocial-hashtag img{border-radius:0!important}
.embedsocial-hashtag .es-post-footer,
.embedsocial-hashtag .es-post-meta{color:var(--text-secondary)!important}
.embedsocial-hashtag .es-post-footer svg,
.embedsocial-hashtag .es-post-meta svg{fill:var(--text-muted)!important}
.feed-powered-by-es,.es-widget-branding,
.embedsocial-hashtag a[href*="embedsocial.com"],
.feed-powered-by-es-feed-img,.es-widget-branding-text{display:none!important}
.embedsocial-hashtag .es-load-more-btn{
  background:var(--text-primary)!important;color:#fff!important;
  border:0!important;border-radius:var(--radius-pill)!important;
  padding:10px 24px!important;
}
.embedsocial-hashtag .es-load-more-btn:hover{background:var(--brand-primary)!important}

/* ==========================================================================
   14. FOOTER
   ========================================================================== */
footer,.footer,#footer{
  background:var(--bg-alt);
  border-top:1px solid var(--border-soft);
  padding:var(--space-16) 0 var(--space-8);
  color:var(--text-secondary);
  font-size:var(--fs-small);
}
.footer-grid,.footer-content{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:var(--space-10);
  margin-bottom:var(--space-10);
}
@media (max-width:900px){.footer-grid,.footer-content{grid-template-columns:1fr 1fr;gap:var(--space-8)}}
@media (max-width:560px){.footer-grid,.footer-content{grid-template-columns:1fr}}
footer h4,.footer h4,.footer-col h4{
  font-family:var(--font-display);
  font-size:.9375rem;
  font-weight:600;
  color:var(--text-primary);
  margin-bottom:var(--space-4);
  letter-spacing:.02em;
}
footer ul,.footer ul,.footer-col ul{list-style:none;padding:0;margin:0}
footer ul li,.footer ul li,.footer-col ul li{margin-bottom:var(--space-2)}
footer ul a,.footer ul a,.footer-col ul a{color:var(--text-secondary);transition:color var(--dur-fast) var(--ease-out)}
footer ul a:hover,.footer ul a:hover,.footer-col ul a:hover{color:var(--brand-primary-deep)}
.footer-bottom{
  padding-top:var(--space-6);
  border-top:1px solid var(--border-soft);
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:var(--space-4);
  font-size:var(--fs-caption);
  color:var(--text-muted);
}

/* ==========================================================================
   15. FORMS
   ========================================================================== */
input[type=text],input[type=email],input[type=tel],input[type=url],input[type=password],input[type=search],input[type=number],textarea,select{
  width:100%;
  height:var(--btn-h-md);
  padding:0 var(--space-4);
  font-family:var(--font-body);
  font-size:var(--fs-body);
  color:var(--text-primary);
  background:var(--surface-card);
  border:1.5px solid var(--border-strong);
  border-radius:var(--radius-sm);
  transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);
  appearance:none;
}
textarea{height:auto;min-height:120px;padding:var(--space-3) var(--space-4);line-height:1.5;resize:vertical}
select{padding-right:40px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235A5B70' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
input:focus,textarea:focus,select:focus{outline:0;border-color:var(--brand-primary);box-shadow:var(--shadow-focus)}
label{display:block;font-size:var(--fs-caption);font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:6px}

/* ==========================================================================
   16. LOADING SCREEN
   ========================================================================== */
.loading-screen{
  position:fixed;inset:0;
  background:var(--bg-base);
  display:flex;align-items:center;justify-content:center;
  z-index:9998;
  transition:opacity var(--dur-slow) var(--ease-out),visibility var(--dur-slow) var(--ease-out);
}
.loading-screen.loaded{opacity:0;visibility:hidden;pointer-events:none}
.loading-content{text-align:center;max-width:480px;padding:var(--space-6)}
.loading-logo-big{position:relative;width:120px;margin:0 auto var(--space-8);display:grid;place-items:center}
.loading-logo-big img{width:100%;height:auto;position:relative;z-index:1}
.loading-glow{
  position:absolute;inset:-20%;
  background:radial-gradient(circle,var(--brand-primary) 0%,transparent 70%);
  filter:blur(30px);
  opacity:.35;
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:.55;transform:scale(1.08)}}
.loading-spinner-modern{
  width:44px;height:44px;
  margin:0 auto var(--space-6);
  border:3px solid var(--border-soft);
  border-top-color:var(--brand-primary);
  border-radius:50%;
  animation:spin .9s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-quote-container{position:relative;min-height:64px;margin-bottom:var(--space-6)}
.loading-quote{
  position:absolute;inset:0;
  color:var(--text-secondary);
  font-size:var(--fs-small);
  font-style:italic;
  opacity:0;
  transition:opacity var(--dur-slow) var(--ease-out);
}
.loading-quote.active{opacity:1}
.loading-progress-bar{
  width:240px;height:4px;
  margin:0 auto;
  background:var(--border-soft);
  border-radius:var(--radius-pill);
  overflow:hidden;
}
.loading-progress-fill{
  height:100%;
  background:linear-gradient(90deg,var(--brand-primary),var(--brand-secondary));
  width:0;
  animation:loadFill 2.4s var(--ease-out) forwards;
}
@keyframes loadFill{to{width:100%}}

/* ==========================================================================
   17. UTILITIES
   ========================================================================== */
.mesh-bg{position:relative;background:var(--bg-base);overflow:hidden}
.mesh-bg::before{
  content:"";
  position:absolute;top:-20%;left:-10%;
  width:60%;height:120%;
  background:radial-gradient(circle at center,var(--page-mesh-a) 0%,transparent 50%);
  filter:blur(80px);
  opacity:.4;
  pointer-events:none;
  z-index:0;
}
.mesh-bg::after{
  content:"";
  position:absolute;bottom:-20%;right:-10%;
  width:60%;height:120%;
  background:radial-gradient(circle at center,var(--page-mesh-b) 0%,transparent 50%);
  filter:blur(80px);
  opacity:.4;
  pointer-events:none;
  z-index:0;
}
.mesh-bg>*{position:relative;z-index:1}

.product-disc{
  position:relative;
  aspect-ratio:1/1;
  display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,var(--page-mesh-a) 0%,var(--page-mesh-b) 70%);
  border-radius:50%;
}

.text-gradient{
  background:linear-gradient(135deg,var(--brand-primary-deep),var(--brand-secondary-deep));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

.divider{height:1px;background:var(--border-soft);border:0;margin:var(--space-10) 0}
.text-center{text-align:center}
.text-right{text-align:right}
.hidden{display:none!important}

/* Reveal on scroll */
[data-reveal]{
  opacity:0;
  transform:translateY(24px);
  transition:opacity var(--dur-xslow) var(--ease-out),transform var(--dur-xslow) var(--ease-out);
}
[data-reveal].revealed{opacity:1;transform:none}

/* Lang toggle EN/DE */
html[lang=en] [data-de]:not([data-en=""]){display:none}
html[lang=en] [data-en]{display:inline-block}

/* ==========================================================================
   18. COOKIE BANNER
   ========================================================================== */
.cookie-banner,#cookie-banner{
  position:fixed;bottom:24px;right:24px;
  max-width:420px;
  padding:var(--space-5);
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  box-shadow:var(--shadow-lg);
  z-index:200;
  font-size:var(--fs-small);
}
.cookie-banner h4{font-size:1rem;margin-bottom:var(--space-2)}
.cookie-banner p{color:var(--text-secondary);margin-bottom:var(--space-4)}
.cookie-banner .btn-group{margin-top:var(--space-3)}

/* ==========================================================================
   19. LOGISTICS / TABLES
   ========================================================================== */
.logistics-table,table.logistics{
  width:100%;
  border-collapse:separate;border-spacing:0;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xl);
  overflow:hidden;
  font-family:var(--font-body);
  font-size:var(--fs-small);
}
.logistics-table th,.logistics-table td,
table.logistics th,table.logistics td{
  padding:var(--space-3) var(--space-4);
  text-align:left;
  border-bottom:1px solid var(--border-soft);
}
.logistics-table th,table.logistics th{
  background:var(--bg-alt);
  font-family:var(--font-display);
  font-weight:600;
  color:var(--text-primary);
  font-size:var(--fs-caption);
  letter-spacing:.04em;
  text-transform:uppercase;
}
.logistics-table tbody tr:last-child td,
table.logistics tbody tr:last-child td{border-bottom:0}
.logistics-table tbody tr:hover,
table.logistics tbody tr:hover{background:var(--page-accent-tint)}
.logistics-table td.num,table.logistics td.num{
  font-family:var(--font-mono);
  font-variant-numeric:tabular-nums;
}

/* ==========================================================================
   20. BLOG
   ========================================================================== */
.blog-article,article.post,.article-content{
  max-width:720px;
  margin:0 auto;
  padding:var(--space-12) var(--container-pad);
}
.blog-article h1,.blog-article h2,.blog-article h3,
article.post h1,article.post h2,article.post h3,
.article-content h1,.article-content h2,.article-content h3{
  margin-top:var(--space-10);
  margin-bottom:var(--space-4);
}
.blog-article p,article.post p,.article-content p{
  font-size:1.0625rem;
  line-height:1.75;
  color:var(--text-primary);
  margin-bottom:var(--space-5);
}
.blog-meta{
  display:flex;flex-wrap:wrap;gap:var(--space-4);
  padding-bottom:var(--space-6);
  margin-bottom:var(--space-10);
  border-bottom:1px solid var(--border-soft);
  font-size:var(--fs-caption);
  color:var(--text-muted);
  letter-spacing:.04em;
  text-transform:uppercase;
}
.blog-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:var(--space-6);
  margin-top:var(--space-10);
}
.blog-card{
  display:flex;flex-direction:column;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.blog-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.blog-card-body{padding:var(--space-6)}
.blog-card-body h3{font-size:1.25rem;margin-bottom:var(--space-2);color:var(--text-primary)}
.blog-card-body p{color:var(--text-secondary);font-size:var(--fs-small);margin-bottom:var(--space-4)}

/* ==========================================================================
   21. LEGACY COMPAT / OVERRIDES
   ========================================================================== */
/* Old dark hero */
.hero.dark,.hero-dark{background:var(--bg-base)!important;color:var(--text-primary)!important}

/* Old KPI */
.kpi{
  padding:var(--space-5);
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-xs);
}
.kpi strong{
  font-family:var(--font-mono);
  font-size:2rem;font-weight:600;
  color:var(--text-primary);
  display:block;
  margin-bottom:var(--space-1);
}
.kpi span,.kpi p{color:var(--text-secondary);font-size:var(--fs-small);margin:0}

.ribbon{
  display:inline-block;
  padding:6px 14px;
  background:var(--accent-candy);
  color:var(--text-primary);
  font-size:.8125rem;font-weight:600;
  border-radius:var(--radius-pill);
}

/* Override old inline-gradient dark backgrounds on sections */
section[style*="background:linear-gradient(135deg,rgba(196,30,58"],
section[style*="background:linear-gradient(135deg,rgba(0,40,104"]{
  background:var(--bg-alt)!important;
}
.asia-section[style],.usa-section[style]{
  background:var(--surface-tinted-lilac)!important;
}

/* Hero badge size compat */
.badge{font-size:.8125rem}

/* ==========================================================================
   22. SCROLL-TOP BUTTON
   ========================================================================== */
.scroll-top-btn{
  position:fixed;
  bottom:32px;left:24px;
  width:56px;height:56px;
  display:grid;place-items:center;
  background:var(--surface-card);
  border:1.5px solid var(--border-soft);
  border-radius:50%;
  box-shadow:var(--shadow-md);
  color:var(--text-primary);
  cursor:pointer;
  z-index:150;
  opacity:0;visibility:hidden;
  transform:scale(.85) translateY(20px);
  transition:opacity var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),visibility var(--dur-base) var(--ease-out),background var(--dur-fast) var(--ease-out);
}
.scroll-top-btn.visible{opacity:1;visibility:visible;transform:scale(1) translateY(0)}
.scroll-top-btn:hover{background:var(--text-primary);color:#fff;transform:scale(1.05)}
.scroll-top-progress{position:absolute;inset:0;transform:rotate(-90deg)}
.scroll-top-track{fill:none;stroke:var(--border-soft);stroke-width:3}
.scroll-top-fill{fill:none;stroke:var(--brand-primary);stroke-width:3;stroke-linecap:round;stroke-dasharray:150.8;stroke-dashoffset:150.8;transition:stroke-dashoffset .1s linear}
.scroll-top-arrow{position:relative;z-index:2}
.scroll-top-label{position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:.6875rem;font-weight:600;color:var(--brand-primary-deep);opacity:0;transition:opacity var(--dur-fast) var(--ease-out)}
.scroll-top-btn:hover .scroll-top-label{opacity:1}

/* ==========================================================================
   23. CONTACT BAR
   ========================================================================== */
.contact-bar{
  position:fixed;
  bottom:32px;right:24px;
  z-index:140;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  box-shadow:var(--shadow-lg);
  padding:var(--space-3) var(--space-4);
  max-width:calc(100vw - 48px);
}
.contact-bar-inner{
  display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-4);
}
.contact-bar-info{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:center}
.contact-bar-phone,.contact-bar-hours{
  display:inline-flex;align-items:center;gap:8px;
  font-size:var(--fs-small);
  color:var(--text-primary);
}
.contact-bar-hours{color:var(--text-secondary);font-size:var(--fs-caption)}
.phone-number{font-family:var(--font-mono);font-weight:600}
.contact-bar-buttons{display:inline-flex;gap:8px}
.contact-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;
  font-size:var(--fs-caption);font-weight:500;
  border-radius:var(--radius-pill);
  transition:all var(--dur-fast) var(--ease-out);
  text-decoration:none;
}
.contact-btn-phone{background:var(--text-primary);color:#fff}
.contact-btn-phone:hover{background:var(--brand-primary);color:#fff}
.contact-btn-whatsapp{background:#25D366;color:#fff}
.contact-btn-whatsapp:hover{background:#1EA952;color:#fff}
@media (max-width:720px){
  .contact-bar{bottom:auto;top:auto;right:12px;left:12px;bottom:12px}
  .contact-bar-hours{display:none}
  .contact-bar-inner{justify-content:space-between;width:100%}
  .btn-text{display:none}
}

/* ==========================================================================
   24. SITE FOOTER (modern, not legacy)
   ========================================================================== */
.site-footer{
  background:var(--bg-alt);
  border-top:1px solid var(--border-soft);
  padding:var(--space-20) 0 var(--space-8);
  color:var(--text-secondary);
  font-size:var(--fs-small);
}
.site-footer a{color:var(--text-secondary);transition:color var(--dur-fast) var(--ease-out)}
.site-footer a:hover{color:var(--brand-primary-deep)}
.site-footer .footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:var(--space-10);
  margin-bottom:var(--space-10);
}
@media (max-width:900px){.site-footer .footer-grid{grid-template-columns:1fr 1fr;gap:var(--space-8)}}
@media (max-width:560px){.site-footer .footer-grid{grid-template-columns:1fr}}
.site-footer h4{
  font-family:var(--font-display);
  font-size:.9375rem;font-weight:600;
  color:var(--text-primary);
  margin-bottom:var(--space-4);
  letter-spacing:.02em;
}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{margin-bottom:var(--space-2)}
.footer-brand-col p{color:var(--text-secondary);font-size:var(--fs-small);margin-top:12px}
.footer-brand{display:inline-block}
.footer-socials{display:flex;gap:10px;margin-top:16px}
.footer-social{
  width:36px;height:36px;
  display:inline-grid;place-items:center;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:50%;
  color:var(--text-primary);
  transition:all var(--dur-fast) var(--ease-out);
}
.footer-social:hover{background:var(--text-primary);color:#fff;border-color:var(--text-primary);transform:translateY(-2px)}

/* ==========================================================================
   25. MODAL SHEETS (impressum, datenschutz)
   ========================================================================== */
.sheet{
  position:fixed;inset:0;
  background:rgba(26,27,46,.5);
  backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  padding:var(--space-4);
  z-index:300;
  opacity:0;visibility:hidden;
  transition:opacity var(--dur-base) var(--ease-out),visibility var(--dur-base) var(--ease-out);
}
.sheet.open,.sheet[aria-hidden="false"]{opacity:1;visibility:visible}
.sheet .panel,.sheet .legal-panel{
  position:relative;
  width:100%;max-width:720px;
  max-height:85vh;
  overflow-y:auto;
  background:var(--surface-card);
  border-radius:var(--radius-2xl);
  padding:var(--space-10);
  box-shadow:var(--shadow-lg);
}
.sheet .close-x{
  position:absolute;top:16px;right:16px;
  width:40px;height:40px;
  display:grid;place-items:center;
  background:var(--bg-alt);
  border-radius:50%;
  font-size:1.5rem;line-height:1;
  color:var(--text-primary);
  cursor:pointer;
  transition:background var(--dur-fast) var(--ease-out);
}
.sheet .close-x:hover{background:var(--text-primary);color:#fff}
.legal-content h2{margin-bottom:var(--space-6)}
.legal-content h3{margin-top:var(--space-8);margin-bottom:var(--space-3);font-size:1.125rem}
.legal-content h4{margin-top:var(--space-5);margin-bottom:var(--space-2);font-size:1rem}
.legal-content p{color:var(--text-secondary);margin-bottom:var(--space-3)}
.legal-content strong{color:var(--text-primary)}

/* ==========================================================================
   26. COOKIE BANNER
   ========================================================================== */
.cookie-consent,#cookieConsent{
  position:fixed;bottom:24px;right:24px;left:24px;
  max-width:480px;margin-left:auto;
  padding:var(--space-5);
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  box-shadow:var(--shadow-lg);
  z-index:200;
  font-size:var(--fs-small);
}
.cookie-text h4{font-size:1rem;margin-bottom:var(--space-2);color:var(--text-primary)}
.cookie-text p{color:var(--text-secondary);margin-bottom:var(--space-3);font-size:var(--fs-small)}
.cookie-link{color:var(--brand-primary-deep);font-weight:500}
.cookie-banner-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}
.cookie-btn{
  padding:10px 18px;
  font-size:.875rem;font-weight:500;
  border-radius:var(--radius-md);
  cursor:pointer;
  transition:all var(--dur-fast) var(--ease-out);
  border:1.5px solid transparent;
}
.cookie-btn-primary{background:var(--text-primary);color:#fff}
.cookie-btn-primary:hover{background:var(--brand-primary)}
.cookie-btn-secondary{background:transparent;color:var(--text-primary);border-color:var(--border-strong)}
.cookie-btn-secondary:hover{background:var(--bg-alt)}

/* ==========================================================================
   27. BLOG ARTICLE HEADER + HERO (fuer bestehende Blog-Artikel)
   ========================================================================== */
.blog-hero,.article-hero{
  padding:var(--space-16) 0 var(--space-12);
  background:var(--bg-base);
  position:relative;
  overflow:hidden;
}
.blog-hero::before,.article-hero::before{
  content:"";position:absolute;inset:-20% auto auto -10%;
  width:60%;height:100%;
  background:radial-gradient(circle,var(--page-mesh-a) 0%,transparent 50%);
  filter:blur(80px);opacity:.35;pointer-events:none;
}
.blog-hero::after,.article-hero::after{
  content:"";position:absolute;inset:auto -10% -20% auto;
  width:60%;height:100%;
  background:radial-gradient(circle,var(--page-mesh-b) 0%,transparent 50%);
  filter:blur(80px);opacity:.3;pointer-events:none;
}
.blog-hero>.container,.article-hero>.container{position:relative;z-index:1}
.article-hero h1{max-width:20ch}

/* ==========================================================================
   28. STATS SECTION (Erfolg in Zahlen)
   ========================================================================== */
.stats-section{
  padding:var(--space-20) 0;
  background:var(--bg-alt);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-6);
  margin-top:var(--space-10);
}
@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.stats-grid{grid-template-columns:1fr}}
.stat-card{
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  padding:var(--space-6);
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
  display:flex;flex-direction:column;gap:var(--space-3);
}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.stat-highlight{
  background:linear-gradient(135deg,var(--surface-tinted-mint),var(--surface-tinted-lilac));
  border-color:transparent;
}
.stat-icon{
  font-size:1.5rem;line-height:1;
  width:52px;height:52px;
  display:inline-grid;place-items:center;
  background:var(--surface-tinted-mint);
  border-radius:var(--radius-pill);
  flex-shrink:0;
}
.stat-highlight .stat-icon{background:rgba(255,255,255,.7)}
.stat-number{
  display:flex;align-items:baseline;gap:2px;
  font-family:var(--font-mono);
  font-size:clamp(2rem,3vw,2.75rem);
  font-weight:600;
  color:var(--text-primary);
  letter-spacing:-.02em;
  line-height:1;
}
.stat-number .counter{color:var(--brand-primary-deep)}
.stat-plus,.stat-unit{color:var(--brand-primary);font-size:.7em;font-weight:600}
.stat-label{
  color:var(--text-secondary);
  font-size:var(--fs-small);
  font-weight:500;
  letter-spacing:.02em;
}
.stat-chart{
  width:100%;
  height:48px;
  overflow:hidden;
  margin-top:auto;
}
.mini-chart{
  width:100%;
  height:100%;
  display:block;
  max-width:100%;
}
.chart-line{
  stroke:var(--brand-primary);
  stroke-width:2;
  fill:none;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.chart-line-glow{
  stroke:var(--brand-primary);
  stroke-width:5;
  fill:none;
  opacity:.25;
  stroke-linecap:round;
  stroke-linejoin:round;
}
/* Constrain any SVG inside stat/bite/kpi/fact cards so they never overflow */
.stat-card svg,.bite svg,.kpi svg,.fact-card-epic svg,.achievement-icon svg{
  max-width:100%;
  height:auto;
}

/* ACHIEVEMENT BANNER */
.achievement-banner{
  margin-top:var(--space-12);
  padding:var(--space-8) var(--space-10);
  background:linear-gradient(135deg,var(--surface-tinted-mint),var(--surface-tinted-lilac));
  border-radius:var(--radius-3xl);
  display:flex;align-items:center;gap:var(--space-6);
  flex-wrap:wrap;
}
.achievement-icon{
  font-size:2.5rem;line-height:1;
  width:80px;height:80px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.7);
  border-radius:50%;
  flex-shrink:0;
}
.achievement-content{flex:1;min-width:280px}
.achievement-content h3{font-size:1.5rem;margin:0 0 var(--space-2);color:var(--text-primary)}
.achievement-content p{color:var(--text-secondary);margin:0;font-size:var(--fs-subhead)}

/* ==========================================================================
   29. FLIPBOOK / CATALOG
   ========================================================================== */
.katalog-section{background:var(--surface-card);padding:var(--space-20) 0}
.flipbook-wrapper{
  margin-top:var(--space-10);
  padding:var(--space-10) var(--space-8);
  background:var(--bg-alt);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-3xl);
}
.flipbook-container{
  min-height:400px;
  max-width:900px;
  margin:0 auto;
  display:grid;
  place-items:center;
  background:var(--surface-card);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-md);
  overflow:hidden;
}
.flipbook-controls{
  display:flex;justify-content:center;align-items:center;
  gap:var(--space-4);
  margin-top:var(--space-6);
}
.flipbook-btn,.flipbook-btn-fullscreen{
  width:44px;height:44px;
  display:grid;place-items:center;
  background:var(--surface-card);
  border:1.5px solid var(--border-soft);
  border-radius:50%;
  color:var(--text-primary);
  cursor:pointer;
  transition:all var(--dur-fast) var(--ease-out);
}
.flipbook-btn:hover,.flipbook-btn-fullscreen:hover{
  background:var(--text-primary);color:#fff;border-color:var(--text-primary);
  transform:translateY(-1px);
}
.flipbook-page-info{font-family:var(--font-mono);color:var(--text-secondary);font-size:.875rem;min-width:100px;text-align:center}
.flipbook-actions{display:flex;justify-content:center;margin-top:var(--space-6)}
.katalog-download-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 24px;
  background:var(--text-primary);
  color:#fff;
  font-family:var(--font-display);
  font-weight:500;
  border-radius:var(--radius-md);
  text-decoration:none;
  transition:all var(--dur-fast) var(--ease-out);
}
.katalog-download-btn:hover{background:var(--brand-primary);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.katalog-hint{
  text-align:center;
  margin-top:var(--space-4);
  color:var(--text-muted);
  font-size:.875rem;
}

/* ==========================================================================
   30. LOGO BRAND (bigger, more prominent)
   ========================================================================== */
.brand img{height:64px;width:auto;max-width:220px;object-fit:contain}
@media(max-width:640px){.brand img{height:48px;max-width:160px}}
#header nav,.header nav{height:88px}
@media(max-width:640px){#header nav,.header nav{height:72px}}
#header.scrolled .brand img{height:48px}
@media(max-width:640px){#header.scrolled .brand img{height:40px}}

/* ==========================================================================
   31. TRUST BADGES — fix emoji flag fallback
   ========================================================================== */
.trust-badge-icon{font-size:1rem;font-family:'Apple Color Emoji','Segoe UI Emoji','Noto Color Emoji',sans-serif}

/* ==========================================================================
   32. TYPING CURSOR CONTRAST
   ========================================================================== */
.typing-cursor{color:var(--brand-primary);background:var(--brand-primary)}

/* ==========================================================================
   33. HERO — contain the hero media to fixed frame
   ========================================================================== */
.hero{z-index:0}
.hero-media{z-index:2}
.hero .parallax-bg,.hero>.container{z-index:1}

/* ==========================================================================
   34. UEBER-UNS team grid guard
   ========================================================================== */
.team-grid-epic{
  display:grid!important;
  grid-template-columns:repeat(4,1fr)!important;
  gap:var(--space-6)!important;
}
@media(max-width:1100px){.team-grid-epic{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:560px){.team-grid-epic{grid-template-columns:1fr!important}}
.team-image-epic{
  position:relative!important;
  height:260px!important;
  overflow:hidden!important;
  border-radius:var(--radius-xl) var(--radius-xl) 0 0!important;
}
.team-image-epic img{
  width:100%!important;height:100%!important;
  object-fit:cover!important;
  display:block!important;
}

/* ==========================================================================
   35. FAQ / details styling
   ========================================================================== */
details{
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:var(--space-4) var(--space-5);
  margin-bottom:var(--space-3);
  transition:box-shadow var(--dur-fast) var(--ease-out);
}
details[open]{box-shadow:var(--shadow-sm)}
details summary{
  font-family:var(--font-display);
  font-weight:500;
  font-size:1rem;
  color:var(--text-primary);
  cursor:pointer;
  list-style:none;
  padding-right:var(--space-8);
  position:relative;
}
details summary::-webkit-details-marker{display:none}
details summary::after{
  content:'+';
  position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-size:1.5rem;font-weight:400;
  color:var(--brand-primary-deep);
  transition:transform var(--dur-fast) var(--ease-out);
}
details[open] summary::after{content:'×'}
details p,details div{
  color:var(--text-secondary);
  padding-top:var(--space-3);
  margin:0;
}

/* ==========================================================================
   36. NEW HOMEPAGE 2026 (styles-fresh only)
   ========================================================================== */

.container-narrow{max-width:820px}
.center{text-align:center;margin-left:auto;margin-right:auto}

.eyebrow{
  display:inline-block;
  font-family:var(--font-body);
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--brand-primary-deep);
  margin-bottom:var(--space-3);
}
.eyebrow-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;
  background:var(--surface-tinted-mint);
  color:var(--brand-primary-deep);
  font-size:.8125rem;font-weight:500;letter-spacing:.02em;
  border-radius:var(--radius-pill);
  margin-bottom:var(--space-4);
}
.section-sub{
  color:var(--text-secondary);
  font-size:var(--fs-subhead);
  max-width:60ch;
  margin:0;
}
.center .section-sub{margin-left:auto;margin-right:auto}
.text-accent{
  background:linear-gradient(120deg,var(--brand-primary-deep) 0%,var(--brand-secondary-deep) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}

/* ---------- HERO (new) ---------- */
.hero{
  padding:var(--space-16) 0 var(--space-20);
  background:var(--bg-base);
  position:relative;overflow:hidden;
}
.hero::before,.hero::after{content:"";position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0}
.hero::before{top:-15%;right:-10%;width:640px;height:640px;background:radial-gradient(circle,var(--brand-primary) 0,transparent 60%);opacity:.28}
.hero::after{bottom:-20%;left:-15%;width:560px;height:560px;background:radial-gradient(circle,var(--brand-secondary) 0,transparent 60%);opacity:.26}
.hero .container{position:relative;z-index:1}
.hero-grid{
  display:grid;grid-template-columns:1.15fr 1fr;gap:var(--space-12);align-items:center;
}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:var(--space-10)}}
.hero-copy h1{
  font-size:clamp(2.5rem,5vw,5rem);
  font-weight:600;line-height:1.02;letter-spacing:-.035em;
  color:var(--text-primary);
  margin:0 0 var(--space-5);
}
.hero-copy h1 br{display:block}
.hero-sub{
  font-size:var(--fs-subhead);color:var(--text-secondary);
  line-height:1.55;max-width:54ch;margin:0 0 var(--space-6);
}
.hero-copy .btn-group{margin-top:0}

.hero-trust{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);
  margin-top:var(--space-10);
  padding-top:var(--space-6);
  border-top:1px solid var(--border-soft);
}
@media(max-width:540px){.hero-trust{grid-template-columns:repeat(2,1fr)}}
.hero-trust-item{display:flex;flex-direction:column;gap:2px;line-height:1.2}
.hero-trust-item strong{font-family:var(--font-display);font-size:.9375rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}
.hero-trust-item span{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}

.hero-visual{
  position:relative;
  aspect-ratio:1/1;
  max-width:560px;margin-left:auto;
  display:grid;place-items:center;
}
.hero-disc{
  position:absolute;inset:6%;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--brand-primary) 0%,var(--brand-secondary) 55%,var(--accent-candy) 100%);
  opacity:.45;
  filter:blur(30px);
  animation:floatDisc 9s ease-in-out infinite;
  z-index:0;
}
@keyframes floatDisc{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-18px) scale(1.04)}}
.hero-visual img{
  position:relative;z-index:1;
  width:88%;height:auto;
  border-radius:var(--radius-3xl);
  box-shadow:0 20px 56px -12px rgba(26,27,46,.28);
  animation:floatImg 7s ease-in-out infinite;
}
@keyframes floatImg{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ---------- KPI STRIP ---------- */
.kpis-strip{
  background:var(--surface-card);
  border-top:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
  padding:var(--space-10) 0;
}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}
@media(max-width:760px){.kpi-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-8)}}
.kpi-cell{text-align:center}
.kpi-num{
  font-family:var(--font-mono);
  font-size:clamp(2.25rem,3.4vw,3.25rem);
  font-weight:600;line-height:1;
  color:var(--text-primary);
  letter-spacing:-.02em;
  margin-bottom:var(--space-2);
}
.kpi-num .counter{color:var(--brand-primary-deep)}
.kpi-label{
  font-size:.8125rem;font-weight:500;color:var(--text-secondary);
  letter-spacing:.04em;
}

/* ---------- BENTO (Eigenmarken) ---------- */
.bento-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:320px;
  gap:var(--space-5);
  margin-top:var(--space-10);
}
@media(max-width:1100px){.bento-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.bento-grid{grid-template-columns:1fr}}
.bento-card{
  position:relative;
  border-radius:var(--radius-2xl);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
  text-decoration:none;color:inherit;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  display:flex;flex-direction:column;
}
.bento-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
/* Bento colors */
.bento-lyoshot{background:var(--surface-tinted-coral)}
.bento-mytcha{background:var(--surface-tinted-mint)}
.bento-froozly{background:#DEF7F9}
.bento-losbubos{background:var(--surface-tinted-lilac)}
.bento-dtt{background:var(--surface-tinted-candy)}
.bento-patifruits{background:var(--surface-tinted-candy)}
.bento-framini{background:var(--surface-tinted-mint)}
.bento-tabby{background:var(--surface-tinted-butter)}

.bento-media{
  flex:1;min-height:160px;
  display:block;
  overflow:hidden;
  position:relative;
}
.bento-media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform var(--dur-slow) var(--ease-out);
}
.bento-card:hover .bento-media img{transform:scale(1.04)}
.bento-label{
  padding:var(--space-4) var(--space-5);
  background:rgba(255,255,255,.6);
  backdrop-filter:blur(6px);
  border-top:1px solid rgba(255,255,255,.5);
  flex-shrink:0;
}
.bento-label h3{
  font-size:1.25rem;font-weight:600;
  color:var(--text-primary);
  margin:0 0 4px;
  letter-spacing:-.01em;
}
.bento-label p{
  font-size:.8125rem;color:var(--text-secondary);
  margin:0;line-height:1.45;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.bento-tag{
  display:inline-block;
  font-size:.6875rem;font-weight:600;
  color:var(--accent-coral-deep);
  letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:4px;
}

/* ---------- COUNTRY HUBS ---------- */
.country-hubs{background:var(--bg-alt)}
.country-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--space-6);margin-top:var(--space-10);
}
@media(max-width:960px){.country-grid{grid-template-columns:1fr}}
.country-card{
  display:flex;flex-direction:column;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  text-decoration:none;color:inherit;
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.country-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.country-img{aspect-ratio:16/10;overflow:hidden;background:var(--surface-tinted-butter)}
.country-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out)}
.country-card:hover .country-img img{transform:scale(1.04)}
.country-body{padding:var(--space-6)}
.country-badge{
  display:inline-block;
  font-size:.75rem;font-weight:600;
  color:var(--text-primary);
  background:var(--bg-alt);
  padding:4px 10px;border-radius:var(--radius-pill);
  margin-bottom:var(--space-3);
}
.country-body h3{font-size:1.5rem;margin:0 0 var(--space-2);color:var(--text-primary)}
.country-body .heart{color:var(--accent-coral-deep)}
.country-body p{color:var(--text-secondary);font-size:.9375rem;margin-bottom:var(--space-3)}
.country-meta{
  display:block;font-size:.8125rem;color:var(--text-muted);
  padding-top:var(--space-3);border-top:1px solid var(--border-soft);
}
.country-meta strong{color:var(--text-primary);font-family:var(--font-mono);font-weight:600}

/* ---------- CATALOG CTA ---------- */
.catalog-cta{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:var(--space-12);
  align-items:center;
  padding:var(--space-12);
  background:linear-gradient(135deg,var(--surface-tinted-mint) 0%,var(--surface-tinted-lilac) 100%);
  border-radius:var(--radius-3xl);
  position:relative;overflow:hidden;
}
.catalog-cta::before{
  content:"";position:absolute;top:-40%;right:-20%;
  width:400px;height:400px;
  background:radial-gradient(circle,var(--accent-candy) 0%,transparent 60%);
  filter:blur(60px);opacity:.5;
}
.catalog-cta-copy{position:relative;z-index:1}
.catalog-cta-copy h2{font-size:clamp(1.75rem,2.8vw,2.5rem);margin:0 0 var(--space-3)}
.catalog-cta-copy p{color:var(--text-secondary);margin-bottom:var(--space-6);max-width:48ch}
.catalog-cta-visual{position:relative;z-index:1;perspective:1000px}
.mock-catalog{position:relative;width:100%;max-width:320px;margin:0 auto}
.mock-page,.mock-page-2{
  width:100%;aspect-ratio:3/4;
  background:var(--surface-card);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  background-image:linear-gradient(180deg,rgba(0,0,0,.02) 0%,rgba(0,0,0,0) 20%),
    repeating-linear-gradient(0deg,transparent 0,transparent 14px,var(--border-soft) 14px,var(--border-soft) 15px);
  transform:rotate(-4deg);
}
.mock-page-2{position:absolute;top:0;left:0;transform:rotate(4deg) translateX(16px);opacity:.85}
@media(max-width:900px){.catalog-cta{grid-template-columns:1fr;padding:var(--space-8)}
  .catalog-cta-visual{display:none}}

/* ---------- SERVICES ---------- */
.service-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);
  margin-top:var(--space-10);
}
@media(max-width:900px){.service-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.service-grid{grid-template-columns:1fr}}
.service-card{
  padding:var(--space-6);
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-xs);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.service-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.service-icon{
  width:52px;height:52px;
  display:grid;place-items:center;
  background:var(--surface-tinted-mint);
  color:var(--brand-primary-deep);
  border-radius:var(--radius-pill);
  margin-bottom:var(--space-4);
}
.service-card h3{font-size:1.125rem;margin:0 0 var(--space-2);color:var(--text-primary)}
.service-card p{color:var(--text-secondary);font-size:.9375rem;margin:0;line-height:1.55}

/* ---------- MARQUEE REVERSE (partners) ---------- */
.marquee-rev .track{animation-direction:reverse}

.partner-text-tile,.partner-logo-tile{
  flex:0 0 auto;
  width:200px;min-width:200px;max-width:200px;height:80px;
  display:grid;place-items:center;
  padding:0 var(--space-6);
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-xs);
  font-family:var(--font-display);
  font-size:1.125rem;font-weight:600;
  letter-spacing:-.01em;
  color:var(--text-primary);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out);
}
.partner-logo-tile{padding:14px 24px;overflow:hidden}
.partner-logo-tile img{
  width:100%;height:100%;
  min-width:0;min-height:0;
  object-fit:contain;
  display:block;
  filter:grayscale(1) opacity(.82);
  transition:filter var(--dur-base) var(--ease-out);
}
.partner-logo-tile:hover img{filter:grayscale(0) opacity(1)}
.partner-text-tile:hover,.partner-logo-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);color:var(--brand-primary-deep)}

/* ---------- FAQ ---------- */
.faq-list{margin-top:var(--space-10)}
.faq-list details{
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:var(--space-5) var(--space-6);
  margin-bottom:var(--space-3);
  transition:box-shadow var(--dur-fast) var(--ease-out);
}
.faq-list details[open]{box-shadow:var(--shadow-sm)}
.faq-list details summary{
  font-family:var(--font-display);font-weight:500;font-size:1.0625rem;
  color:var(--text-primary);cursor:pointer;
  list-style:none;padding-right:var(--space-8);position:relative;
}
.faq-list details summary::-webkit-details-marker{display:none}
.faq-list details summary::after{
  content:'+';position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-size:1.5rem;font-weight:300;color:var(--brand-primary-deep);
  transition:transform var(--dur-fast) var(--ease-out);
}
.faq-list details[open] summary::after{content:'×'}
.faq-list details p{
  color:var(--text-secondary);
  padding-top:var(--space-3);margin:0;line-height:1.65;
}
.faq-list details a{color:var(--brand-primary-deep);text-decoration:underline}

/* ---------- CTA BANNER ---------- */
.cta-banner-section{padding-top:var(--space-12);padding-bottom:var(--space-24)}
.cta-banner{
  display:grid;grid-template-columns:1.6fr 1fr;
  gap:var(--space-8);align-items:center;
  padding:var(--space-12) var(--space-10);
  background:linear-gradient(135deg,var(--accent-candy) 0%,var(--brand-secondary) 50%,var(--brand-primary) 100%);
  border-radius:var(--radius-3xl);
  color:var(--text-primary);
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background:rgba(255,255,255,.5);
  backdrop-filter:blur(2px);
  z-index:0;
}
.cta-banner>*{position:relative;z-index:1}
.cta-banner h2{
  font-size:clamp(1.75rem,3vw,2.75rem);
  margin:0 0 var(--space-3);
  color:var(--text-primary);
  letter-spacing:-.02em;
}
.cta-banner p{color:var(--text-primary);opacity:.8;margin:0;max-width:50ch}
.cta-banner-actions{display:flex;flex-direction:column;gap:var(--space-3)}
.cta-banner-actions .btn{width:100%;justify-content:center}
.cta-banner-actions .btn.ghost{background:rgba(255,255,255,.6);border-color:transparent;color:var(--text-primary)}
.cta-banner-actions .btn.ghost:hover{background:var(--text-primary);color:#fff}
@media(max-width:780px){.cta-banner{grid-template-columns:1fr;padding:var(--space-8)}}

/* ---------- FOOTER touch ups ---------- */
.footer-legal-links{display:flex;gap:var(--space-4)}

/* ==========================================================================
   36b. KATALOG (Blätterkatalog – page-flip 2.0.7)
   ========================================================================== */
.katalog-section{padding:var(--space-20) 0}
.flipbook-wrapper{
  max-width:1400px;
  margin:var(--space-10) auto 0;
  text-align:center;
}
.flipbook-container{
  position:relative;
  background:var(--surface-card);
  border-radius:12px;
  padding:16px;
  border:1px solid var(--border-soft);
  box-shadow:var(--shadow-lg);
  max-width:1100px;
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:600px;
  overflow:hidden;
  margin:0 auto;
}
.flipbook-container .stf__wrapper{flex:1 1 100%;width:100%}
.flipbook-page{background:#fff;overflow:hidden}
.flipbook-page img{width:100%;height:100%;object-fit:fill;display:block}
@media(max-width:768px){
  .katalog-section{padding:var(--space-12) 0}
  .flipbook-wrapper{margin-top:var(--space-6);padding:0}
  .flipbook-container{
    padding:0;
    min-height:0;
    border-radius:8px;
    box-shadow:var(--shadow-md);
    overflow:hidden;
  }
  .flipbook-controls{gap:var(--space-2);margin-top:var(--space-4);flex-wrap:wrap}
  .flipbook-btn{width:44px;height:44px}
  .flipbook-page-info{font-size:.8125rem;min-width:90px}
  .flipbook-actions{margin-top:var(--space-4)}
  /* Mobile Carousel (replaces PageFlip) */
  .mobile-carousel{display:block!important;padding:0!important}
  .mobile-katalog-track{
    display:flex;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    width:100%;
    aspect-ratio:550/778;
    max-height:78vh;
  }
  .mobile-katalog-track::-webkit-scrollbar{display:none}
  .mobile-katalog-page{
    flex:0 0 100%;
    width:100%;
    height:100%;
    object-fit:contain;
    scroll-snap-align:start;
    background:#fff;
    user-select:none;
    -webkit-user-drag:none;
  }
}
.flipbook-controls{
  display:flex;justify-content:center;align-items:center;gap:var(--space-4);
  margin-top:var(--space-6);
}
.flipbook-btn{
  width:48px;height:48px;
  display:grid;place-items:center;
  background:var(--surface-card);
  border:1.5px solid var(--border-soft);
  border-radius:50%;
  color:var(--text-primary);
  cursor:pointer;
  transition:all var(--dur-fast) var(--ease-out);
}
.flipbook-btn:hover{background:var(--text-primary);color:#fff;border-color:var(--text-primary);transform:translateY(-1px)}
.flipbook-btn:disabled{opacity:.4;cursor:not-allowed}
.flipbook-btn:disabled:hover{background:var(--surface-card);color:var(--text-primary);transform:none}
.flipbook-page-info{
  font-family:var(--font-mono);
  color:var(--text-secondary);
  font-size:.875rem;
  min-width:110px;text-align:center;
}
.flipbook-actions{
  display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;
  margin-top:var(--space-6);
}
.katalog-hint{
  text-align:center;margin-top:var(--space-4);
  color:var(--text-muted);font-size:.875rem;
}

/* ==========================================================================
   37. UEBER-UNS: TIMELINE + TEAM
   ========================================================================== */
.timeline{
  margin-top:var(--space-10);
  position:relative;
  padding-left:var(--space-16);
}
.timeline::before{
  content:"";
  position:absolute;
  top:0;bottom:0;left:60px;
  width:2px;
  background:linear-gradient(180deg,var(--brand-primary) 0%,var(--brand-secondary) 50%,var(--accent-candy) 100%);
  border-radius:2px;
}
.timeline-item{
  display:grid;
  grid-template-columns:60px 1fr;
  gap:var(--space-8);
  padding:var(--space-6) 0;
  position:relative;
}
.timeline-item::before{
  content:"";
  position:absolute;
  left:53px;top:calc(var(--space-6) + 10px);
  width:16px;height:16px;
  background:var(--surface-card);
  border:3px solid var(--brand-primary);
  border-radius:50%;
  z-index:1;
}
.timeline-year{
  font-family:var(--font-mono);
  font-size:1.25rem;font-weight:600;
  color:var(--text-primary);
  letter-spacing:-.02em;
  line-height:1;
  padding-top:10px;
}
.timeline-body h3{
  font-size:1.25rem;font-weight:600;
  color:var(--text-primary);
  margin:0 0 var(--space-2);
}
.timeline-body p{
  color:var(--text-secondary);
  margin:0;line-height:1.6;
}
@media(max-width:640px){
  .timeline{padding-left:var(--space-8)}
  .timeline::before{left:20px}
  .timeline-item{grid-template-columns:44px 1fr;gap:var(--space-4)}
  .timeline-item::before{left:13px}
  .timeline-year{font-size:1rem}
}

/* Team grid */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-6);
  margin-top:var(--space-10);
}
@media(max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.team-grid{grid-template-columns:1fr}}
.team-card{
  display:flex;flex-direction:column;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.team-img{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:linear-gradient(135deg,var(--surface-tinted-mint) 0%,var(--surface-tinted-lilac) 100%);
}
.team-img img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform var(--dur-slow) var(--ease-out);
}
.team-card:hover .team-img img{transform:scale(1.04)}
.team-body{padding:var(--space-5) var(--space-6) var(--space-6)}
.team-body h3{
  font-size:1.25rem;font-weight:600;
  color:var(--text-primary);
  margin:0 0 var(--space-1);
}
.team-role{
  display:inline-block;
  font-size:.8125rem;font-weight:500;
  color:var(--brand-primary-deep);
  letter-spacing:.02em;
  margin-bottom:var(--space-3);
}
.team-body p{
  color:var(--text-secondary);
  font-size:.9375rem;line-height:1.55;
  margin-bottom:var(--space-4);
}
.team-skills{
  display:flex;flex-wrap:wrap;gap:6px;
  padding-top:var(--space-3);
  border-top:1px solid var(--border-soft);
}
.team-skills span{
  display:inline-block;
  padding:4px 10px;
  background:var(--surface-tinted-mint);
  color:var(--brand-primary-deep);
  font-size:.75rem;font-weight:500;
  letter-spacing:.02em;
  border-radius:var(--radius-pill);
}

/* Anchor-Scroll offset für sticky header */
section[id],main[id]{scroll-margin-top:100px}

/* End of styles-fresh.css */


/* ==========================================================================
   40. LEAD-MAGNET MODAL
   ========================================================================== */
.leadmagnet-modal{
  position:fixed;inset:0;z-index:9999;
  display:none;
  align-items:center;justify-content:center;
  background:rgba(10,20,30,.72);
  backdrop-filter:blur(6px);
  padding:var(--space-4);
  opacity:0;
  transition:opacity var(--dur-base) var(--ease-out);
}
.leadmagnet-modal.is-open{display:flex;opacity:1;animation:leadFade var(--dur-base) var(--ease-out)}
@keyframes leadFade{from{opacity:0}to{opacity:1}}
.leadmagnet-card{
  background:var(--surface-card);
  border-radius:var(--radius-2xl);
  padding:var(--space-10);
  max-width:500px;width:100%;
  position:relative;
  box-shadow:0 30px 80px rgba(0,0,0,.35);
  transform:translateY(20px);
  animation:leadSlide var(--dur-base) var(--ease-out) forwards;
}
@keyframes leadSlide{to{transform:translateY(0)}}
.leadmagnet-close{
  position:absolute;top:16px;right:16px;
  width:36px;height:36px;
  display:grid;place-items:center;
  background:transparent;border:0;border-radius:50%;
  font-size:1.5rem;color:var(--text-secondary);
  cursor:pointer;
}
.leadmagnet-close:hover{background:var(--bg-alt);color:var(--text-primary)}
.leadmagnet-card h3{
  font-size:1.5rem;font-weight:600;
  color:var(--text-primary);
  margin:0 0 8px;
  letter-spacing:-.01em;
}
.leadmagnet-card .sub{
  color:var(--text-secondary);
  margin:0 0 var(--space-6);
  font-size:.9375rem;
  line-height:1.5;
}
.leadmagnet-card .field{margin-bottom:var(--space-4)}
.leadmagnet-card label{
  display:block;
  font-size:.8125rem;font-weight:500;
  color:var(--text-secondary);
  margin-bottom:6px;
}
.leadmagnet-card input[type=email],
.leadmagnet-card input[type=text]{
  width:100%;
  padding:12px 14px;
  font-size:.9375rem;
  border:1.5px solid var(--border-soft);
  border-radius:var(--radius-md);
  background:var(--bg-base);
  font-family:inherit;
  transition:border-color var(--dur-fast) var(--ease-out);
}
.leadmagnet-card input:focus{outline:none;border-color:var(--brand-primary)}
.leadmagnet-card .consent{
  display:flex;align-items:flex-start;gap:10px;
  font-size:.8125rem;color:var(--text-secondary);
  line-height:1.4;
  margin-bottom:var(--space-5);
}
.leadmagnet-card .consent input{margin-top:2px;flex-shrink:0}
.leadmagnet-card button[type=submit]{
  width:100%;
  padding:14px 20px;
  background:var(--text-primary);
  color:#fff;
  border:0;border-radius:var(--radius-md);
  font-family:var(--font-display);
  font-size:.9375rem;font-weight:600;
  cursor:pointer;
  transition:background var(--dur-fast) var(--ease-out);
}
.leadmagnet-card button[type=submit]:hover:not(:disabled){background:var(--brand-primary-deep)}
.leadmagnet-card button[type=submit]:disabled{opacity:.55;cursor:wait}
.leadmagnet-msg{margin-top:var(--space-3);font-size:.875rem;min-height:1.2em}
.leadmagnet-msg.ok{color:#059669}
.leadmagnet-msg.err{color:#dc2626}
.leadmagnet-honeypot{position:absolute;left:-9999px;opacity:0;pointer-events:none}
@media(max-width:560px){
  .leadmagnet-card{padding:var(--space-6)}
  .leadmagnet-card h3{font-size:1.25rem}
}

/* ==========================================================================
   41. SOCIAL PROOF BLOCK
   ========================================================================== */
.social-proof{padding:var(--space-16) 0;background:var(--bg-alt)}
.social-proof .container{max-width:1200px}
.social-proof-eyebrow{
  display:inline-block;
  font-family:var(--font-mono);
  font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brand-primary-deep);
  margin-bottom:var(--space-4);
}
.social-proof h2{
  font-size:clamp(1.5rem,3vw,2rem);
  font-weight:600;
  color:var(--text-primary);
  margin:0 0 var(--space-10);
  letter-spacing:-.02em;
  max-width:720px;
}
.sp-kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:var(--space-4);
  margin-bottom:var(--space-14);
}
@media(max-width:900px){.sp-kpi-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.sp-kpi-grid{grid-template-columns:1fr 1fr}}
.sp-kpi{
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-xl);
  padding:var(--space-6) var(--space-5);
  text-align:left;
}
.sp-kpi-num{
  font-family:var(--font-display);
  font-size:clamp(1.75rem,4vw,2.5rem);
  font-weight:700;
  color:var(--brand-primary-deep);
  line-height:1.05;
  margin-bottom:8px;
  letter-spacing:-.02em;
}
.sp-kpi-label{
  font-size:.8125rem;color:var(--text-secondary);
  letter-spacing:.02em;line-height:1.35;
}
.sp-logos-title{
  font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-muted);
  text-align:center;
  margin-bottom:var(--space-6);
  font-weight:500;
}
.sp-logos{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:var(--space-4);
  align-items:center;
  margin-bottom:var(--space-14);
  opacity:.78;
}
@media(max-width:900px){.sp-logos{grid-template-columns:repeat(3,1fr)}}
@media(max-width:500px){.sp-logos{grid-template-columns:repeat(2,1fr)}}
.sp-logo-tile{
  aspect-ratio:3/1;
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  display:grid;place-items:center;
  padding:var(--space-3);
  font-family:var(--font-mono);
  font-size:.6875rem;letter-spacing:.08em;
  color:var(--text-muted);
  text-transform:uppercase;
}
.sp-logo-tile img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(1);opacity:.85}
.sp-testimonials{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:var(--space-6);
}
@media(max-width:760px){.sp-testimonials{grid-template-columns:1fr}}
.sp-testimonial{
  background:var(--surface-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-2xl);
  padding:var(--space-8);
  position:relative;
}
.sp-testimonial::before{
  content:"\201E";
  position:absolute;top:var(--space-3);left:var(--space-6);
  font-size:5rem;
  font-family:Georgia,serif;
  color:var(--brand-primary);
  opacity:.15;
  line-height:1;
}
.sp-testimonial blockquote{
  margin:0 0 var(--space-6);
  font-size:1rem;line-height:1.55;
  color:var(--text-primary);
  font-style:italic;
}
.sp-testimonial footer{
  display:flex;gap:12px;align-items:center;
}
.sp-testimonial .avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--surface-tinted-mint);
  display:grid;place-items:center;
  font-family:var(--font-display);
  font-weight:600;font-size:.875rem;
  color:var(--brand-primary-deep);
  flex-shrink:0;
}
.sp-testimonial .who-name{font-weight:600;font-size:.875rem;color:var(--text-primary)}
.sp-testimonial .who-role{font-size:.75rem;color:var(--text-secondary);margin-top:2px}

/* ==========================================================================
   42. STICKY CTA
   ========================================================================== */
#sticky-cta{
  position:fixed;
  right:var(--space-6);bottom:var(--space-6);
  z-index:60;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;
  background:var(--text-primary);
  color:#fff;
  font-family:var(--font-display);
  font-weight:600;font-size:.9375rem;
  border-radius:999px;
  box-shadow:0 10px 30px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.1);
  text-decoration:none;
  transform:translateY(120%);
  opacity:0;
  pointer-events:none;
  transition:transform .35s var(--ease-out), opacity .35s var(--ease-out), background var(--dur-fast);
}
#sticky-cta.is-visible{transform:translateY(0);opacity:1;pointer-events:auto}
#sticky-cta:hover{background:var(--brand-primary-deep)}
#sticky-cta svg{width:16px;height:16px}
@media(max-width:640px){
  #sticky-cta{
    right:var(--space-3);left:var(--space-3);bottom:var(--space-3);
    justify-content:center;
    padding:14px 16px;
    font-size:.875rem;
  }
}

/* ==========================================================================
   43. LANGUAGE SWITCH (DE/EN)
   ========================================================================== */
.lang-switch{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:38px;height:38px;
  padding:0 10px;
  font-family:var(--font-mono,ui-monospace,monospace);
  font-size:.75rem;font-weight:600;
  letter-spacing:.08em;
  color:var(--text-secondary);
  border:1.5px solid var(--border-soft);
  border-radius:999px;
  text-decoration:none;
  transition:all var(--dur-fast) var(--ease-out);
  margin-right:8px;
}
.lang-switch:hover{
  color:var(--brand-primary-deep);
  border-color:var(--brand-primary);
  background:var(--surface-tinted-mint);
}
@media(max-width:1100px){
  .lang-switch{margin-right:0;width:100%;height:auto;padding:12px 16px;justify-content:flex-start;font-size:1rem;border-radius:8px}
}

/* ==========================================================================
   44. WHATSAPP BUTTON
   ========================================================================== */
#whatsapp-btn{
  position:fixed;
  right:var(--space-6);bottom:calc(var(--space-6) + 70px);
  z-index:60;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  width:56px;height:56px;
  background:#25D366;
  color:#fff;
  border-radius:50%;
  box-shadow:0 8px 24px rgba(37,211,102,.35),0 2px 6px rgba(0,0,0,.15);
  text-decoration:none;
  transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),background var(--dur-fast);
  overflow:hidden;
}
#whatsapp-btn::before{
  content:"";position:absolute;inset:-4px;border-radius:50%;background:#25D366;
  opacity:.3;animation:wa-pulse 2.2s ease-out infinite;z-index:-1;
}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.3}70%{transform:scale(1.25);opacity:0}100%{transform:scale(1.25);opacity:0}}
#whatsapp-btn:hover{background:#1ebe57;transform:scale(1.06)}
#whatsapp-btn svg{width:28px;height:28px;flex-shrink:0}
#whatsapp-btn span{display:none}
@media(max-width:640px){
  #whatsapp-btn{right:var(--space-3);bottom:calc(var(--space-3) + 64px);width:52px;height:52px}
  #whatsapp-btn svg{width:26px;height:26px}
}
