/* ============================================================
   Components Bundle
   Importiert alle Component-CSS-Dateien
   Einbinden: <link rel="stylesheet" href="/components/components.css">
   ============================================================ */


/* ---- Rubik Font (selbst gehostet, DSGVO-konform) ---- */
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/rubik-v31-latin_latin-ext-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/rubik-v31-latin_latin-ext-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/rubik-v31-latin_latin-ext-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/rubik-v31-latin_latin-ext-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('fonts/rubik-v31-latin_latin-ext-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('fonts/rubik-v31-latin_latin-ext-800.woff2') format('woff2');
}
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('fonts/rubik-v31-latin_latin-ext-900.woff2') format('woff2');
}


*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --ink:   #111;
  --ink2:  #444;
  --ink3:  #888;
  --paper: #fff;
  --paper2:#f5f5f3;
  --paper3:#ebebea;
  --line:  #e0e0de;
  --g:    #6BB646;
  --g-d:  #4a8a2a;
  --g-bg: rgba(107,182,70,.07);
  --r:    #E60063;
  --y:    #FFDE00;
  --rnd:    10px;
  --rnd-sm: 6px;
  --mw:     1060px;
  --nav-h:  58px;
  --font: 'Rubik', sans-serif;
}

body {
  font-family: var(--font);
  background: var(--paper);
  color: var(--ink);
  overflow-x: clip;
  -webkit-font-smoothing: antialiased;
}

img { display: block; width: 100%; height: 100%; object-fit: cover; }
a   { color: inherit; text-decoration: none; }

::-webkit-scrollbar        { width: 3px; }
::-webkit-scrollbar-thumb  { background: var(--g); }

section { padding: 80px 40px; }
.sec-in { max-width: var(--mw); margin: 0 auto; }

/* Scroll-Reveal */
.rv { opacity: 0; transform: translateY(22px); transition: opacity .75s cubic-bezier(.22,1,.36,1), transform .75s cubic-bezier(.22,1,.36,1); }
.rv.v  { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .rv { opacity: 1 !important; transform: none !important; transition: none; } }

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: 7px; padding: 12px 24px; border-radius: 50px; font: 600 .84rem/1 var(--font); letter-spacing: .03em; cursor: pointer; border: none; transition: all .22s; text-decoration: none; }
.btn-p  { background: var(--ink); color: var(--paper); }
.btn-p:hover { background: #333; transform: translateY(-1px); }
.btn-gh { background: none; border: 1.5px solid var(--ink); color: var(--ink); }
.btn-gh:hover { background: var(--paper2); }

/* --- Navbar --- */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 200; height: var(--nav-h); background: rgba(255,255,255,.95); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; padding: 0 40px; transition: box-shadow .25s; }
.nav.scrolled { box-shadow: 0 1px 16px rgba(0,0,0,.07); }
.nav-left  { display: flex; align-items: center; gap: 10px; }
.nav-logo  { display: flex; gap: 3px; align-items: center; }
.nav-name  { font-size: .82rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.nav-links { display: flex; align-items: center; gap: 2px; }
.nav-link  { padding: 6px 12px; border-radius: 50px; font-size: .77rem; font-weight: 400; color: var(--ink2); transition: all .18s; }
.nav-link:hover  { background: var(--paper2); color: var(--ink); }
.nav-link.active { background: var(--paper2); color: var(--ink); font-weight: 600; }
.nav-cta    { padding: 8px 18px; background: var(--ink); color: var(--paper); border-radius: 50px; font-size: .77rem; font-weight: 600; margin-left: 8px; transition: all .2s; }
.nav-cta:hover { background: #333; }
.lang-row  { display: flex; gap: 2px; }
.lang-btn  { background: none; border: 1px solid var(--line); color: var(--ink3); padding: 4px 9px; border-radius: 4px; cursor: pointer; font: 600 .65rem/1 var(--font); letter-spacing: .08em; transition: all .18s; }
.lang-btn.on    { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.lang-btn:hover:not(.on) { border-color: var(--ink); color: var(--ink); }

/* --- Hero --- */
.hero { min-height: 100vh; padding: calc(var(--nav-h) + 60px) 40px 80px; display: flex; align-items: center; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; top: 0; right: 0; bottom: 0; width: 46%; background: linear-gradient(to right, rgba(225,225,220,.12), rgba(200,200,195,.92)); clip-path: polygon(10% 0,100% 0,100% 100%,0 100%); z-index: 1; }
.hero-scene { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero-scene img { width: 100%; height: 100%; object-fit: cover; opacity: .38; filter: grayscale(.1); }
.hero-scene::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to right, rgba(255,255,255,.93) 0%, rgba(255,255,255,.93) 42%, rgba(255,255,255,.07) 100%); }
.hero-in { max-width: var(--mw); margin: 0 auto; width: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 2; }
.hero-eyebrow { font-size: .68rem; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--ink3); margin-bottom: 20px; display: flex; align-items: center; gap: 10px; opacity: 0; animation: fu .6s .1s forwards; }
.hero-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--ink3); flex-shrink: 0; }
.hero-h1 { font-size: clamp(2.8rem, 4.5vw, 4.4rem); font-weight: 800; line-height: 1.02; letter-spacing: -.025em; margin-bottom: 10px; opacity: 0; animation: fu .7s .2s forwards; }
.hero-h1 em { color: var(--g); font-style: normal; }
.hero-tagline { font-size: clamp(1rem, 1.6vw, 1.2rem); font-weight: 300; color: var(--ink2); margin-bottom: 18px; line-height: 1.5; opacity: 0; animation: fu .7s .32s forwards; }
.hero-desc { font-size: .95rem; font-weight: 300; line-height: 1.8; color: var(--ink2); max-width: 440px; margin-bottom: 36px; opacity: 0; animation: fu .7s .44s forwards; }
.hero-btns { display: flex; gap: 10px; flex-wrap: wrap; opacity: 0; animation: fu .7s .56s forwards; }
.hero-tags { margin-top: 36px; opacity: 0; animation: fu .7s .68s forwards; }
.hero-tags p { font-size: .6rem; font-weight: 500; letter-spacing: .18em; text-transform: uppercase; color: var(--ink3); margin-bottom: 9px; }
.htag { padding: 4px 11px; border-radius: 50px; background: var(--paper); border: 1px solid var(--line); font-size: .65rem; font-weight: 400; color: var(--ink2); display: inline-block; margin: 3px 3px 3px 0; transition: all .18s; }
.htag:hover { background: var(--paper2); border-color: var(--g); }
.hero-photo-wrap { position: relative; opacity: 0; animation: fu .9s .35s forwards; }
.hero-photo { width: 100%; aspect-ratio: 4/5; overflow: hidden; border-radius: var(--rnd); background: var(--paper3); }
.hero-photo img { object-position: center; border-radius: var(--rnd); opacity: .22; filter: grayscale(.1); -webkit-mask-image: radial-gradient(ellipse at center, black 55%, transparent 100%); mask-image: radial-gradient(ellipse at center, black 55%, transparent 100%); }
.hero-card { position: absolute; bottom: 0; left: 0; right: 0; background: var(--ink); color: var(--paper); padding: 16px 20px; border-radius: 0 0 var(--rnd) var(--rnd); display: flex; justify-content: space-between; align-items: center; }
.hero-card-name  { font-size: .92rem; font-weight: 700; letter-spacing: .02em; }
.hero-card-role  { font-size: .7rem; font-weight: 300; color: rgba(255,255,255,.5); margin-top: 2px; }
.hero-card-shapes { display: flex; gap: 5px; }
@keyframes fu { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

/* --- TrustBar --- */
.trust-bar { background: var(--ink); padding: 0 40px; }
.trust-in  { max-width: var(--mw); margin: 0 auto; display: grid; grid-template-columns: repeat(3,1fr); }
.trust-item { padding: 24px 0 24px 32px; border-left: 1px solid rgba(255,255,255,.07); display: flex; flex-direction: column; justify-content: center; gap: 6px; }
.trust-item:first-child { border-left: none; padding-left: 0; }
.trust-n { font-size: clamp(1.6rem, 2.5vw, 2.2rem); font-weight: 800; color: var(--paper); line-height: 1; }
.trust-l { font-size: .76rem; font-weight: 400; color: rgba(255,255,255,.45); line-height: 1.4; }

/* --- SectionHeader --- */
.sec-eyebrow { font-size: .63rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: var(--g); margin-bottom: 10px; display: flex; align-items: center; gap: 7px; }
.sec-eyebrow::before, .sec-eyebrow::after { content: ''; display: block; width: 14px; height: 1.5px; background: var(--g); }
.sec-title { font-size: clamp(1.7rem, 2.8vw, 2.4rem); font-weight: 800; line-height: 1.08; letter-spacing: -.025em; margin-bottom: 16px; }

/* --- About --- */
.about { background: var(--paper); }
.about-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 72px; align-items: start; }
.about-photo-wrap { position: sticky; top: calc(var(--nav-h) + 24px); }
.about-photo { width: 100%; aspect-ratio: 3/4; overflow: hidden; border-radius: var(--rnd); background: var(--paper3); }
.about-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 15%; }
.about-text { display: block; }
.about-text h2 { margin-bottom: 20px; }
.about-text p  { font-size: .93rem; font-weight: 300; line-height: 1.85; color: var(--ink2); margin-bottom: 14px; }
.about-text .about-text-lead { font-size: 1rem; font-weight: 700; color: var(--ink); }
.about-text .about-text-body { font-size: .88rem; font-weight: 300; color: var(--ink2); }
.about-pills { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-top: 28px; }
.about-pill { background: var(--paper2); border: 1px solid var(--line); border-radius: var(--rnd); padding: 16px 14px; transition: all .22s; }
.about-pill:hover { border-color: var(--g); transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,0,0,.06); }
.pill-icon  { font-size: 1.5rem; margin-bottom: 8px; }
.pill-title { font-size: .82rem; font-weight: 700; margin-bottom: 4px; }
.pill-desc  { font-size: .72rem; color: var(--ink3); line-height: 1.5; }
.cred-list  { border-top: 1px solid var(--line); margin-top: 20px; }
.cred-item  { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--line); align-items: flex-start; transition: transform .2s ease; }
.cred-item:hover { transform: translateX(4px); }
.cred-text  { font-size: .86rem; font-weight: 400; line-height: 1.6; color: var(--ink); transition: font-weight .2s ease; }
.cred-item:hover .cred-text { font-weight: 700; }
.cred-sym   { flex-shrink: 0; font-size: .9rem; margin-top: 2px; line-height: 1.6; }

/* --- QuoteBanner --- */
.quote-banner { background: var(--ink); padding: 70px 40px; text-align: center; position: relative; overflow: hidden; }
.quote-banner::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 0%, rgba(107,182,70,.06) 0%, transparent 55%); pointer-events: none; }
.quote-inner   { position: relative; z-index: 1; max-width: 680px; margin: 0 auto; }
.quote-text { font-size: clamp(1rem, 1.6vw, 1.5rem); font-weight: 700; color: var(--paper); line-height: 1.5; letter-spacing: -.01em; margin-bottom: 14px; max-width: 640px; margin-left: auto; margin-right: auto; }
.quote-author { font-size: .82rem; font-weight: 400; letter-spacing: .04em; line-height: 1.6; margin-top: 6px; }
.quote-author-name { font-weight: 700; color: var(--g); }

/* --- OffersIntro --- */
.offers-intro { background: var(--paper); padding: 80px 40px 48px; }
.offers-intro-inner { max-width: var(--mw); margin: 0 auto; }
.offers-subtitle { font-size: .93rem; font-weight: 300; color: var(--ink2); line-height: 1.8; max-width: 520px; margin-top: 8px; }
.offers-cards-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 44px; }
.offers-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--rnd); padding: 28px; display: flex; flex-direction: column; transition: all .25s; position: relative; overflow: hidden; }
.offers-card:hover { transform: translateY(-4px); box-shadow: 0 18px 44px rgba(0,0,0,.08); border-color: transparent; }
.offers-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; transform: scaleX(0); transform-origin: left; transition: transform .3s cubic-bezier(.22,1,.36,1); }
.offers-card:hover::before { transform: scaleX(1); }
.offers-card.c1::before { background: var(--r); }
.offers-card.c2::before { background: var(--g); }
.offers-card.c3::before { background: var(--y); }
.offers-card.c1::before { background: var(--r); }
.offers-card.c2::before { background: var(--g); }
.offers-card.c3::before { background: var(--y); }
.offers-card-icon  { font-size: 2rem; margin-bottom: 14px; color: var(--ink2); }
.offers-card-title { font-size: 1.05rem; font-weight: 700; letter-spacing: -.01em; margin-bottom: 12px; }
.offers-card-desc  { font-size: .83rem; font-weight: 300; line-height: 1.75; color: var(--ink2); flex: 1; }
.offers-card-tags  { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--line); font-size: .68rem; color: var(--ink3); font-weight: 300; }
.offers-card-cta { margin-top: 16px; }

/* --- Catalog --- */
.catalog { background: var(--paper); padding: 80px 40px; }
.catalog-inner { max-width: var(--mw); margin: 0 auto; }
.catalog-hd { margin-bottom: 8px; }
.tab-row    { display: flex; gap: 0; align-items: flex-end; position: sticky; top: var(--nav-h); z-index: 20; background: var(--paper); padding: 10px 0 14px; margin-bottom: 16px; justify-content: flex-end; }
.tab-btn { background: none; border: 1px solid var(--line); color: var(--ink3); padding: 7px 16px; cursor: pointer; font: 400 .76rem/1 var(--font); transition: all .18s; margin-left: -1px; }
.tab-btn:first-child { margin-left: 0; border-radius: 50px 0 0 50px; }
.tab-btn:last-child  { border-radius: 0 50px 50px 0; }
.tab-btn.on { background: var(--ink); color: var(--paper); border-color: var(--ink); position: relative; z-index: 1; }
.tab-btn:hover:not(.on) { border-color: var(--ink); color: var(--ink); }
.catalog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--line); }
.catalog-grid-filler { background: var(--paper); }
.wcard-full { background: var(--paper); padding: 28px 24px; display: none; flex-direction: column; position: relative; transition: background .18s; }
.wcard-full.vis { display: flex; }
.wcard-full:hover { background: var(--line); }
.wcat-sym-row { display: flex; align-items: center; margin-bottom: 10px; }
.wcat-sym { display: block; }
.wcat-label { font-size: .6rem; font-weight: 700; color: var(--ink3); margin-left: 6px; }
.wcard-full h3 { font-size: .94rem; font-weight: 700; margin-bottom: 10px; letter-spacing: -.01em; line-height: 1.25; }
.wcard-full p  { font-size: .82rem; font-weight: 300; line-height: 1.75; color: var(--ink2); flex: 1; }
.wcard-full-meta { font-size: .68rem; color: var(--ink3); margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--line); font-weight: 300; line-height: 1.6; }
.wcard-full-price { margin-top: 10px; font-size: .77rem; font-weight: 600; }
.wcard-badge       { display: inline-block; font-size: .58rem; font-weight: 700; padding: 2px 7px; border-radius: 4px; vertical-align: middle; white-space: nowrap; background: rgba(107,182,70,.1); color: #4a8a2a; }
.wcard-badge.red   { background: rgba(230,0,99,.1); color: rgb(230,0,99); }
.wcard-badge.dark  { background: var(--ink); color: #fff; }
.catalog-cta { text-align: center; padding: 44px 0 8px; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.catalog-cta-text { font-size: .88rem; font-weight: 300; color: var(--ink2); line-height: 1.7; white-space: nowrap; }
.catalog-cta-link { font-weight: 700; color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }
.catalog-cta-link:hover { opacity: .65; }
.tab-intro { margin-bottom: 4px !important; display: none; min-height: 2.9rem; }
.tab-intro.vis { display: block; }

/* --- MethSection --- */
.meth-section { background: var(--paper2); padding: 80px 40px; overflow: hidden; }
.meth-section.dark { background: var(--ink); }
.meth-inner   { max-width: var(--mw); margin: 0 auto; }
.meth-subtitle    { font-size: .88rem; font-weight: 300; color: var(--ink2); margin-top: 6px; line-height: 1.6; }
.meth-points-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }

/* Methodology card hover — grüner Balken oben */
.meth-point-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  padding: 28px 24px;
  position: relative;
  overflow: hidden;
  transition: border-color .3s, transform .3s, box-shadow .3s;
}
.meth-point-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1.5px;
  background: linear-gradient(90deg, transparent, var(--g), transparent);
  opacity: 0;
  transition: opacity .3s;
}
.meth-point-card:hover { border-color: rgba(107,182,70,.25); transform: translateY(-3px); box-shadow: 0 18px 48px rgba(0,0,0,.35); }
.meth-point-card:hover::before { opacity: 1; }
.meth-2col { display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px; align-items: start; margin-top: 44px; }
.meth-lead-text { font-size: .95rem; font-weight: 300; line-height: 1.85; color: var(--ink2); }
.meth-lead-text p { margin-bottom: 16px; }
.meth-points { display: flex; flex-direction: column; }
.meth-point  { display: flex; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--line); }
.meth-point:first-child { border-top: 1px solid var(--line); }
.meth-psym   { flex-shrink: 0; margin-top: 2px; }
.meth-pt     { font-size: .88rem; font-weight: 700; margin-bottom: 5px; line-height: 1.3; }
.meth-pd     { font-size: .8rem; font-weight: 300; line-height: 1.75; color: var(--ink2); }

/* --- Testimonials --- */
.ts-section { background: var(--paper2); padding: 80px 40px; overflow: hidden; }
.ts-header  { text-align: center; max-width: 440px; margin: 0 auto 36px; padding: 0 40px; }
.ts-header .sec-eyebrow { justify-content: center; }
.ts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; padding: 0 40px; }
.ts-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--rnd); padding: 22px; transition: all .22s; }
.ts-card:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(0,0,0,.08); }
.ts-bubble { background: transparent; border-radius: 14px 14px 14px 4px; padding: 14px 16px; font-size: 1.05rem; font-weight: 300; line-height: 1.75; color: var(--ink); border: none; position: relative; }
.ts-bubble::before { content: '"'; position: absolute; top: -4px; left: 8px; font-size: 3.5rem; font-weight: 800; color: var(--g); line-height: 1; opacity: 0.25; }
.ts-chat-a { display: flex; align-items: center; gap: 8px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
.ts-av { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .72rem; font-weight: 700; color: var(--paper); }
.ts-name { font-size: .8rem; font-weight: 700; }
.ts-role { font-size: .68rem; color: var(--ink3); font-weight: 300; }

/* --- Process --- */
.process { background: var(--ink); color: var(--paper); padding: 80px 40px; }
.process .sec-eyebrow { color: var(--g); justify-content: center; }
.process .sec-eyebrow::before, .process .sec-eyebrow::after { background: var(--g); }
.process .sec-title { color: var(--paper); text-align: center; }
.pr-p { font-size: .88rem; font-weight: 300; line-height: 1.8; color: rgba(255,255,255,.4); max-width: 520px; margin-top: 14px; }
.proc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(255,255,255,.07); margin-top: 44px; }
.proc-step { background: var(--ink); padding: 32px 26px; }
.proc-n { font-size: 3rem; font-weight: 800; color: rgba(255,255,255,.06); line-height: 1; margin-bottom: 16px; display: block; }
.proc-title { font-size: .84rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 10px; }
.proc-desc { font-size: .8rem; font-weight: 300; line-height: 1.75; color: rgba(255,255,255,.4); }
.proc-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 10px; }
.proc-tag  { padding: 2px 9px; border-radius: 50px; font-size: .6rem; font-weight: 500; background: rgba(255,255,255,.06); color: rgba(255,255,255,.3); }

/* --- Contact --- */
.contact { background: var(--paper2); padding: 80px 40px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 64px; align-items: start; max-width: var(--mw); margin: 0 auto; }
.contact-left h2 { font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 800; letter-spacing: -.025em; line-height: 1.1; margin-bottom: 12px; }
.contact-left h2 em { color: var(--g); font-style: normal; }
.contact-left-p { font-size: .88rem; font-weight: 300; line-height: 1.8; color: var(--ink2); margin-bottom: 24px; }
.contact-chips  { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 24px; }
.chip { display: inline-flex; align-items: center; gap: 5px; padding: 5px 11px; border-radius: 50px; background: var(--paper); border: 1px solid var(--line); font-size: .69rem; font-weight: 400; color: var(--ink2); }
.contact-email { display: inline-flex; align-items: center; gap: 6px; font-size: .88rem; font-weight: 500; color: var(--ink); margin-bottom: 6px; border-bottom: 1px solid var(--line); padding-bottom: 4px; }
.contact-langs { margin-top: 22px; padding-top: 22px; border-top: 1px solid var(--line); }
.clabel { font-size: .6rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--ink3); margin-bottom: 8px; }
.lang-list { display: flex; gap: 12px; font-size: .82rem; font-weight: 600; color: var(--ink2); }
.form-box { background: var(--paper); border: 1px solid var(--line); border-radius: var(--rnd); padding: 28px; }
.form-title { font-size: .94rem; font-weight: 700; letter-spacing: -.01em; margin-bottom: 18px; }
.lead-grid   { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin-bottom: 18px; }
.lead-opt    { position: relative; }
.lead-opt input { position: absolute; opacity: 0; width: 0; height: 0; }
.lead-opt label { display: flex; align-items: center; gap: 7px; padding: 9px 12px; border: 1.5px solid var(--line); border-radius: var(--rnd-sm); cursor: pointer; font-size: .75rem; font-weight: 500; color: var(--ink2); background: var(--paper); transition: all .18s; }
.lead-opt input:checked + label { border-color: var(--ink); background: var(--paper2); color: var(--ink); }
.lead-opt label:hover { border-color: var(--ink3); }
.f-row      { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.f-field    { margin-bottom: 10px; }
.f-field label { display: block; font-size: .62rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--ink3); margin-bottom: 4px; }
.f-field input, .f-field textarea { border: 1.5px solid var(--line); border-radius: var(--rnd-sm); font: .9rem/1.4 var(--font); color: var(--ink); background: var(--paper); padding: 10px 13px; width: 100%; outline: none; transition: border-color .18s; }
.f-field input:focus, .f-field textarea:focus { border-color: var(--ink); }
.f-field textarea { resize: vertical; min-height: 90px; }
.f-select { border: 1.5px solid var(--line); border-radius: var(--rnd-sm); font: .9rem/1.4 var(--font); color: var(--ink); background: var(--paper); padding: 10px 13px; width: 100%; outline: none; transition: border-color .18s; }
.f-select:focus { border-color: var(--ink); }
.f-select.is-placeholder { color: var(--ink3); }
.f-note   { font-size: .63rem; color: var(--ink3); margin-top: 9px; text-align: center; }
.f-ok { display: none; background: #f1faf0; border: 1px solid #b0d9a8; border-radius: var(--rnd-sm); padding: 13px 16px; color: #2a6022; font-size: .85rem; margin-bottom: 12px; }
.btn-submit { width: 100%; justify-content: center; background: var(--ink); color: var(--paper); border-radius: var(--rnd-sm); padding: 12px; }
.btn-submit:hover { background: #333; }

/* --- CtaStrip --- */
.cta-strip { background: var(--g); padding: 70px 40px; text-align: center; position: relative; overflow: hidden; }
.cta-strip::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 0%, rgba(255,255,255,.12) 0%, transparent 60%); pointer-events: none; }
.cta-strip h2 { font-size: clamp(1.7rem, 3.5vw, 2.8rem); font-weight: 800; letter-spacing: -.025em; color: var(--paper); margin-bottom: 10px; position: relative; }
.cta-strip p  { font-size: .95rem; color: rgba(255,255,255,.8); max-width: 420px; margin: 0 auto 28px; position: relative; line-height: 1.7; font-weight: 300; }
.cta-strip .btn-p { background: var(--paper); color: var(--ink); position: relative; }
.cta-strip .btn-p:hover { background: var(--paper2); }

/* --- Footer --- */
footer { background: var(--ink); padding: 44px 40px 28px; }
.footer-in { max-width: var(--mw); margin: 0 auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 32px; margin-bottom: 28px; }
.footer-brand { display: flex; align-items: center; gap: 7px; font: .7rem var(--font); font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--paper); margin-bottom: 9px; }
.footer-desc      { font-size: .75rem; color: rgba(255,255,255,.35); line-height: 1.7; }
.footer-locations { font-size: .68rem; color: rgba(255,255,255,.2); margin-top: 4px; }
.footer-ht   { font-size: .6rem; font-weight: 600; text-transform: uppercase; letter-spacing: .14em; color: rgba(255,255,255,.3); margin-bottom: 11px; }
.footer-links { display: flex; flex-direction: column; gap: 7px; }
.footer-link  { font-size: .77rem; color: rgba(255,255,255,.45); transition: color .18s; cursor: pointer; }
.footer-link:hover { color: var(--paper); }
.footer-bottom { max-width: var(--mw); margin: 0 auto; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.07); font-size: .64rem; color: rgba(255,255,255,.2); text-align: center; }
.footer-legal { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-top: 8px; }
.footer-legal a { font-size: .6rem; color: rgba(255,255,255,.25); transition: color .18s; cursor: pointer; }
.footer-legal a:hover { color: rgba(255,255,255,.6); }

/* Toast */
.toast { position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%) translateY(80px); padding: 10px 20px; border-radius: 50px; font-size: .8rem; font-weight: 600; z-index: 500; white-space: nowrap; transition: transform .3s cubic-bezier(.22,1,.36,1); }
.toast.v { transform: translateX(-50%) translateY(0); }
.toast-o { background: #16a34a; color: #fff; }
.toast-e { background: #dc2626; color: #fff; }

/* Privacy Modal */
.privacy-modal { position: fixed; inset: 0; background: rgba(0,0,0,.5); backdrop-filter: blur(4px); z-index: 600; display: flex; align-items: center; justify-content: center; padding: 20px; opacity: 0; pointer-events: none; transition: opacity .25s; }
.privacy-modal.open { opacity: 1; pointer-events: all; }
.privacy-box { background: var(--paper); border-radius: var(--rnd); padding: 32px; width: 100%; max-width: 580px; max-height: 85dvh; overflow-y: auto; }
.privacy-box h2 { font-size: 1.05rem; font-weight: 700; margin-bottom: 14px; letter-spacing: -.01em; }
.privacy-box p  { font-size: .83rem; line-height: 1.75; color: var(--ink2); margin-bottom: 10px; }
.privacy-box strong { color: var(--ink); }
.privacy-close { float: right; cursor: pointer; font-size: 1.4rem; color: var(--ink3); border: none; background: none; padding: 0 4px; line-height: 1; }

/* --- Responsive --- */
/* ── Hamburger / Mobile menu ── */
.nav-right  { display: flex; align-items: center; gap: 10px; }
.burger     { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.burger span { display: block; width: 22px; height: 2px; background: var(--ink); border-radius: 2px; transition: all .25s; }
.burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-menu { display: none; position: fixed; top: var(--nav-h); left: 0; right: 0; background: rgba(255,255,255,.98); backdrop-filter: blur(16px); border-bottom: 1px solid var(--line); z-index: 199; flex-direction: column; padding: 12px 20px 20px; gap: 4px; }
.mobile-menu.open { display: flex; }
.mobile-link { padding: 12px 16px; border-radius: var(--rnd-sm); font-size: .9rem; font-weight: 500; color: var(--ink2); transition: all .18s; }
.mobile-link:hover { background: var(--paper2); color: var(--ink); }
.mobile-cta  { background: var(--ink); color: var(--paper) !important; font-weight: 700; text-align: center; border-radius: 50px; margin-top: 8px; }
.mobile-cta:hover { background: #333; }

@media (max-width: 960px) {
  html, body { overflow-x: clip; max-width: 100%; }
  section, .hero, .trust-bar, .process, .contact, .cta-strip, footer, .catalog, .meth-section, .quote-banner, .offers-intro, .ts-section { padding-left: 20px; padding-right: 20px; }
  .nav { padding: 0 20px; }
  .nav-links { display: none; }
  .burger { display: flex; }
  section { padding: 48px 20px; }
  .hero { padding-top: calc(var(--nav-h) + 32px); }
  .hero-in, .about-grid, .contact-grid { grid-template-columns: 1fr; gap: 36px; }
  .hero::before { display: none; }
  .trust-in { grid-template-columns: 1fr; }
  .trust-item { border-left: none; border-bottom: 1px solid rgba(255,255,255,.07); padding: 18px 0; margin: 0; }
  .trust-item:last-child { border-bottom: none; }
  .offers-cards-grid, .catalog-grid, .proc-grid, .meth-2col, .about-pills, .lead-grid, .f-row, .meth-points-grid { grid-template-columns: 1fr; }
  .about-photo-wrap { position: static; }
  .about-photo { aspect-ratio: 4/3; }
  .about-photo img { object-position: center 25%; }
  .offers-cards-grid { margin-top: 28px; }
  .meth-points-grid { gap: 12px; }
  .catalog-grid { background: transparent; gap: 0; }
  .catalog-grid-filler { display: none; }
  .footer-in { grid-template-columns: 1fr; gap: 22px; }
  .hero-btns { flex-direction: column; }
  .btn { width: 100%; justify-content: center; }
  .ts-grid { grid-template-columns: 1fr; padding: 0 20px; }
  /* Catalog auf mobile: weniger Abstand zur vorherigen Section */
  .catalog { padding-top: 36px; }
  /* Catalog-hd: titel oben, tab-row darunter volle Breite */
  .catalog-hd { display: flex; flex-direction: column; align-items: flex-start; gap: 16px; margin-bottom: 20px; }
  .tab-row { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap; scrollbar-width: none; padding: 8px 0 4px; justify-content: center; }
  .tab-row::-webkit-scrollbar { display: none; }
  .tab-btn { flex-shrink: 0; }
  /* Catalog CTA kein nowrap + Link auf neuer Zeile */
  .catalog-cta-text { white-space: normal; }
  .catalog-cta-link { display: block; margin-top: 6px; }
  /* Footer legal kein overflow */
  .footer-legal { flex-wrap: wrap; gap: 6px; }
  .footer-bottom { word-break: break-word; }
  /* Hero iPad: weniger vertikaler Abstand */
  .hero { min-height: auto; padding-top: calc(var(--nav-h) + 40px); padding-bottom: 48px; }
}

@media (min-width: 961px) and (max-width: 1100px) {
  .hero { min-height: auto; padding-top: calc(var(--nav-h) + 48px); padding-bottom: 56px; }
}

@media (max-width: 580px) {
  section { padding: 36px 16px; }
  .hero { padding-left: 16px; padding-right: 16px; }
  .trust-bar, .catalog, .meth-section, .quote-banner, .offers-intro, .ts-section, .contact, .cta-strip, footer, .process { padding-left: 16px; padding-right: 16px; }
}
/* ── Missing from index.html (added to complete coverage) ── */
.meth-lead{font-size:.95rem;font-weight:300;line-height:1.85;color:var(--ink2)}
.offer-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--rnd);padding:28px;display:flex;flex-direction:column;transition:all .25s;position:relative;overflow:hidden}
.offer-cta{margin-top:14px}
.offer-desc{font-size:.84rem;font-weight:300;line-height:1.7;color:var(--ink2);flex:1}
.offer-icon{font-size:2rem;margin-bottom:16px}
.offer-title{font-size:1.05rem;font-weight:700;letter-spacing:-.01em;margin-bottom:10px}
.offers{background:var(--paper2);padding:80px 40px}
.offers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px}
.ts-track{display:flex;gap:16px;overflow-x:auto;padding:8px 40px 24px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--g) transparent}
.wcard{background:var(--paper);padding:24px;display:none;flex-direction:column}
.wcard-cat{font-size:.6rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3)}
.wcard-eye{font-size:.6rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink3);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.wcard-price{margin-top:14px;font-size:.77rem;font-weight:600;color:var(--ink);padding-top:11px;border-top:1px solid var(--line)}
.wcard-rec{font-size:.68rem;color:var(--ink3);margin-top:6px;font-weight:300}

/* ---- Climathon symbol filtering ---- */
/* Default: show all symbols (for "Tot" tab) */
.clim-syms svg { display: inline-block; }
/* When specific category tab is active: hide all, then show only the matching one */
body[data-active-tab="a"] .clim-syms svg { display: none; }
body[data-active-tab="a"] .clim-syms svg[data-sym="a"] { display: inline-block; }
body[data-active-tab="d"] .clim-syms svg { display: none; }
body[data-active-tab="d"] .clim-syms svg[data-sym="d"] { display: inline-block; }
body[data-active-tab="c"] .clim-syms svg { display: none; }
body[data-active-tab="c"] .clim-syms svg[data-sym="c"] { display: inline-block; }
