/* ============================================================
   Fahrrad Schmidt – modernisiertes Stylesheet
   Design basiert auf dem Original (TT Mussels / Menthol Signature)
   ============================================================ */

/* ---------- Reset ---------- */
*{margin:0;padding:0;border:0;box-sizing:border-box;outline:none;font:inherit;vertical-align:baseline;}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block;}
ul{list-style:none;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
html{-webkit-hyphenate-character:'-';scroll-behavior:smooth;}
html,body{width:100%;-webkit-text-size-adjust:100%;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;}

/* ---------- Variablen ---------- */
:root{
  --green:#384239;
  --green-dark:#2b332c;
  --light-green:#939793;
  --cream:#f4f2ec;
  --white:#fff;
  --font-reg:'TT Mussels Regular',sans-serif;
  --font-bol:'TT Mussels DemiBold',sans-serif;
  --font-sig:'Menthol Signature',cursive;
  --maxw:1300px;
}

/* ---------- Fonts ---------- */
@font-face{font-family:'TT Mussels DemiBold';font-display:swap;
  src:url('../fonts/tt_mussels_bold.woff2') format('woff2'),url('../fonts/tt_mussels_bold.woff') format('woff');}
@font-face{font-family:'TT Mussels Regular';font-display:swap;
  src:url('../fonts/tt_mussels_regular.woff2') format('woff2'),url('../fonts/tt_mussels_regular.woff') format('woff');}
@font-face{font-family:'Menthol Signature';font-display:swap;
  src:url('../fonts/menthol_signature.woff2') format('woff2'),url('../fonts/menthol_signature.woff') format('woff');}

body{font-family:var(--font-reg);color:var(--green);background:var(--white);font-size:18px;line-height:1.55;overflow-x:hidden;}

/* ---------- Helpers ---------- */
.wrap{width:90%;max-width:var(--maxw);margin:0 auto;}
.wrap-narrow{width:90%;max-width:900px;margin:0 auto;}
.center{text-align:center;}
.bol{font-family:var(--font-bol);}
.sig{font-family:var(--font-sig);}
.up{text-transform:uppercase;letter-spacing:.04em;}
.green-bg{background:var(--green);color:var(--white);}
.cream-bg{background:var(--cream);}

/* ---------- Header / Nav ---------- */
header.site{
  position:fixed;top:0;left:0;width:100%;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 5%;transition:background .4s ease,padding .4s ease;
}
header.site.solid{background:var(--green);padding:14px 5%;box-shadow:0 4px 24px rgba(0,0,0,.18);}
header.site .brand{height:66px;display:flex;align-items:center;}
header.site .brand img{height:100%;width:auto;}
header.site .menu-toggle{display:none;align-items:center;gap:14px;cursor:pointer;color:var(--white);z-index:62;}
header.site .menu-toggle span.label{font-family:var(--font-bol);font-size:.8em;text-transform:uppercase;letter-spacing:.06em;}
.burger{width:34px;height:14px;position:relative;}
.burger b{position:absolute;left:0;width:100%;height:2px;background:var(--white);transition:transform .4s ease,top .4s ease,opacity .3s ease;}
.burger b:nth-child(1){top:0;}
.burger b:nth-child(2){top:12px;}
body.nav-open .burger b:nth-child(1){top:6px;transform:rotate(45deg);}
body.nav-open .burger b:nth-child(2){top:6px;transform:rotate(-45deg);}

/* Overlay nav */
#overlay{
  position:fixed;inset:0;z-index:55;background:var(--green);
  display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease;
}
body.nav-open #overlay{opacity:1;visibility:visible;}
#overlay .meta{font-size:1em;text-transform:uppercase;color:var(--light-green);margin-bottom:34px;}
#overlay .meta a{color:var(--light-green);transition:color .3s ease;margin:0 18px;display:inline-block;}
#overlay .meta a:hover{color:var(--white);}
#overlay nav ul li{display:inline-block;padding:0 26px 14px;}
#overlay nav ul li a{
  font-family:var(--font-bol);font-size:2.6em;line-height:1;color:var(--white);
  text-transform:uppercase;position:relative;transition:color .4s ease;
}
#overlay nav ul li a::after{
  content:'';position:absolute;left:0;bottom:2px;width:100%;height:4px;background:var(--light-green);
  transform:scaleX(0);transform-origin:left;transition:transform .35s ease;
}
#overlay nav ul li a:hover{color:var(--light-green);}
#overlay nav ul li a:hover::after,#overlay nav ul li a.active::after{transform:scaleX(1);}
#overlay .claim{font-family:var(--font-sig);font-size:2.6em;color:var(--white);margin-top:38px;}
#overlay .ov-logo{position:absolute;bottom:7%;left:50%;transform:translateX(-50%);height:120px;}
#overlay .ov-logo img{height:100%;}

/* ---------- Sichtbares Top-Menü (Desktop) ---------- */
.mainnav{margin-left:auto;}
.mainnav ul{display:flex;align-items:center;gap:clamp(11px,1.3vw,26px);}
.mainnav li{display:inline-block;padding:0;}
.mainnav a{
  font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.04em;
  font-size:.8em;color:var(--white);position:relative;padding:8px 0;display:inline-block;
  transition:color .3s ease;
}
.mainnav a::after{
  content:'';position:absolute;left:0;bottom:0;width:100%;height:3px;background:var(--light-green);
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.mainnav a:hover{color:var(--light-green);}
.mainnav a:hover::after,.mainnav a.active::after{transform:scaleX(1);}

/* ---------- Caption-Band (Vollbild mit Text) ---------- */
.caption-band{position:relative;overflow:hidden;background:var(--green);}
.caption-band img{width:100%;height:100%;min-height:360px;max-height:560px;object-fit:cover;display:block;}
.caption-band::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,51,44,.20) 0%,rgba(40,51,44,.30) 45%,rgba(40,51,44,.72) 100%);}
.caption-band .cap{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--white);padding:40px 7%;}
.caption-band .cap .eyebrow{color:#cdd3cb;}
.caption-band .cap .t{font-family:var(--font-sig);font-size:clamp(1.9rem,3.8vw,3.1rem);line-height:1.15;margin:12px 0 0;}
.caption-band .cap p{max-width:680px;margin-top:16px;font-size:1.03em;line-height:1.65;}

/* ---------- Hero ---------- */
.hero{position:relative;height:100vh;min-height:560px;overflow:hidden;background:var(--green);}
.hero .bg{position:absolute;inset:0;}
.hero .bg img{width:100%;height:100%;object-fit:cover;display:block;}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,51,44,.45) 0%,rgba(40,51,44,.05) 35%,rgba(40,51,44,.45) 100%);}
.hero .inner{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--white);padding:0 6%;}
.hero h1,.hero .big{font-family:var(--font-bol);text-transform:uppercase;line-height:.95;font-size:clamp(2.4rem,7.5vw,6.5rem);}
.hero .script{font-family:var(--font-sig);font-size:clamp(1.6rem,4vw,3rem);line-height:1;margin-top:.1em;}
.hero .sub{max-width:640px;margin-top:24px;font-size:1.05em;line-height:1.6;}
.hero .hero-logo{position:absolute;bottom:7%;left:50%;transform:translateX(-50%);z-index:2;height:clamp(90px,12vh,150px);}
.hero .hero-logo img{height:100%;}
.hero.compact{height:64vh;min-height:440px;}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease;}
.reveal.in{opacity:1;transform:none;}

/* ---------- Sections ---------- */
section{padding:clamp(70px,12vh,150px) 0;}
.section-script{font-family:var(--font-sig);font-size:clamp(1.8rem,3.4vw,3rem);line-height:1.2;}
.section-title{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.05em;font-size:clamp(1.3rem,2vw,1.7rem);line-height:1.25;}
.lead{font-size:1.05em;line-height:1.7;-webkit-hyphens:auto;hyphens:auto;}
.partner-row{font-size:.95em;line-height:1.7;}
.eyebrow{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.14em;font-size:.78em;color:var(--light-green);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.05em;
  font-size:.82em;padding:18px 46px;border-radius:50px;border:2px solid var(--green);
  position:relative;overflow:hidden;z-index:0;transition:color .4s ease;cursor:pointer;
}
.btn::before{content:'';position:absolute;inset:0;z-index:-1;background:var(--green);transform:scaleX(0);transform-origin:right;transition:transform .4s ease;}
.btn:hover{color:var(--white);}
.btn:hover::before{transform:scaleX(1);transform-origin:left;}
.btn.light{border-color:var(--white);color:var(--white);}
.btn.light::before{background:var(--white);}
.btn.light:hover{color:var(--green);}
.btn.solid{background:var(--green);color:var(--white);border-color:var(--green);}
.btn.solid::before{background:var(--green-dark);}
.btn.solid:hover{color:var(--white);}

/* ---------- Image grid ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-2 .tile,.grid-3 .tile{position:relative;overflow:hidden;border-radius:6px;aspect-ratio:4/3;background:var(--green);}
.grid-2 .tile img,.grid-3 .tile img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;}
.grid-2 .tile:hover img,.grid-3 .tile:hover img{transform:scale(1.06);}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.card{
  background:var(--white);border:1px solid #e3e0d8;border-radius:10px;padding:38px 32px;
  transition:transform .4s ease,box-shadow .4s ease,background .4s ease,color .4s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(40,51,44,.16);background:var(--green);color:var(--white);}
.card:hover .card-num,.card:hover .eyebrow{color:var(--light-green);}
.card .card-num{font-family:var(--font-sig);font-size:2.4em;line-height:1.25;color:var(--green);margin-bottom:14px;transition:color .4s ease;}
.card h3{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.04em;font-size:1.05em;margin-bottom:12px;}
.card p{font-size:.95em;line-height:1.6;}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;}
.split .media{min-height:420px;background-size:cover;background-position:center;}
.split .text{padding:clamp(40px,6vw,90px);display:flex;flex-direction:column;justify-content:center;}
.split.reverse .media{order:2;}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;}
.stats.stats-3{grid-template-columns:repeat(3,1fr);max-width:860px;margin-left:auto;margin-right:auto;}
@media(max-width:640px){.stats.stats-3{grid-template-columns:1fr;}}
.stat .num{font-family:var(--font-bol);font-size:clamp(2.2rem,4vw,3.4rem);line-height:1;}
.stat .lab{font-size:.85em;text-transform:uppercase;letter-spacing:.08em;margin-top:10px;color:var(--light-green);}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;}
.step .n{font-family:var(--font-sig);font-size:2.6em;line-height:1.4;padding:.06em 0;color:var(--light-green);}
.step h3{font-family:var(--font-bol);text-transform:uppercase;font-size:.95em;letter-spacing:.04em;margin:12px 0 8px;}
.step p{font-size:.9em;line-height:1.55;}

/* ---------- Price list ---------- */
.pricelist{max-width:760px;margin:0 auto;}
.pricelist .row{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:18px 0;border-bottom:1px solid rgba(57,66,57,.18);}
.pricelist .row .name{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.03em;font-size:.92em;}
.pricelist .row .desc{font-size:.85em;color:#6b716a;margin-top:4px;}
.pricelist .row .price{font-family:var(--font-bol);white-space:nowrap;}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto;}
.faq .item{border-bottom:1px solid rgba(57,66,57,.2);}
.faq .q{width:100%;text-align:left;background:none;cursor:pointer;padding:22px 40px 22px 0;position:relative;font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.03em;font-size:.95em;color:var(--green);}
.faq .q::after{content:'+';position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:1.4em;transition:transform .3s ease;}
.faq .item.open .q::after{transform:translateY(-50%) rotate(45deg);}
.faq .a{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.faq .a p{padding:0 0 22px;font-size:.95em;line-height:1.65;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;}
.field{margin-bottom:22px;}
.field label{display:block;font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.05em;font-size:.72em;margin-bottom:8px;}
.field input,.field textarea{width:100%;border:0;border-bottom:1px solid var(--green);background:transparent;padding:10px 0;font-family:var(--font-reg);font-size:1em;color:var(--green);}
.field input:focus,.field textarea:focus{border-color:var(--light-green);}
.field textarea{resize:none;height:120px;}
.info-line{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid rgba(57,66,57,.15);}
.info-line .k{font-family:var(--font-bol);text-transform:uppercase;font-size:.78em;letter-spacing:.05em;min-width:120px;}

/* ---------- Footer ---------- */
footer.site{position:relative;color:var(--white);overflow:hidden;}
footer.site .bg{position:absolute;inset:0;}
footer.site .bg img{width:100%;height:100%;object-fit:cover;}
footer.site::after{content:'';position:absolute;inset:0;background:rgba(40,51,44,.78);}
footer.site .inner{position:relative;z-index:2;padding:90px 0 40px;}
footer.site .hash{font-family:var(--font-sig);font-size:clamp(1.6rem,3vw,2.1rem);}
footer.site .social{margin-top:16px;}
footer.site .social a{display:inline-flex;width:42px;height:42px;border:1px solid rgba(255,255,255,.5);border-radius:50%;align-items:center;justify-content:center;margin:0 6px;transition:background .3s ease,color .3s ease;}
footer.site .social a:hover{background:var(--white);color:var(--green);}
footer.site .social svg{width:18px;height:18px;fill:currentColor;}
footer.site .contactbar{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 30px;margin-top:46px;text-transform:uppercase;font-size:.82em;letter-spacing:.04em;}
footer.site .contactbar a{transition:color .3s ease;}
footer.site .contactbar a:hover{color:var(--light-green);}
footer.site .opening{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 40px;margin-top:18px;text-transform:uppercase;font-family:var(--font-bol);font-size:1.1em;letter-spacing:.04em;color:var(--white);}
footer.site .brands-label{margin-top:54px;text-transform:uppercase;letter-spacing:.14em;font-family:var(--font-bol);font-size:.74em;color:var(--light-green);}
footer.site .bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;margin-top:60px;padding-top:24px;border-top:1px solid rgba(255,255,255,.2);font-size:.78em;text-transform:uppercase;letter-spacing:.04em;}
footer.site .bottom .footlogo{height:70px;}
footer.site .bottom a:hover{color:var(--light-green);}
footer.site .madeby{text-align:center;margin-top:16px;font-size:.72em;text-transform:uppercase;letter-spacing:.05em;color:var(--light-green);}
footer.site .madeby a{color:var(--light-green);transition:color .3s ease;}
footer.site .madeby a:hover{color:var(--white);}
footer.site .partners{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 36px;margin-top:54px;font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.08em;font-size:.8em;color:var(--light-green);}

/* ---- Footer: modernes Spalten-Layout ---- */
footer.site .foot-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.35fr;gap:44px 36px;text-align:left;}
footer.site .foot-brand .footlogo{height:60px;width:auto;}
footer.site .foot-brand .brand{display:inline-flex;}
footer.site .foot-tag{margin-top:20px;max-width:320px;font-size:.92em;line-height:1.65;color:#d6dad4;}
footer.site .foot-brand .hash{margin-top:22px;}
footer.site .foot-brand .social{margin-top:18px;display:flex;}
footer.site .foot-brand .social a{margin:0 12px 0 0;}
footer.site .foot-col h4{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.1em;font-size:.76em;color:var(--light-green);margin-bottom:18px;}
footer.site .foot-col ul li{margin-bottom:11px;}
footer.site .foot-col a{font-size:.95em;color:#eef0ed;transition:color .3s ease;}
footer.site .foot-col a:hover{color:var(--light-green);}
footer.site .foot-contact address{font-style:normal;display:flex;flex-direction:column;gap:10px;line-height:1.5;}
footer.site .foot-contact address a{font-size:.95em;color:#eef0ed;transition:color .3s ease;}
footer.site .foot-contact address a:hover{color:var(--light-green);}
footer.site .foot-open{margin-top:16px;display:flex;flex-direction:column;gap:4px;font-size:.9em;color:#d6dad4;}
footer.site .foot-cta{margin-top:24px;padding:13px 30px;font-size:.74em;}
footer.site .foot-brands{margin-top:56px;padding-top:40px;border-top:1px solid rgba(255,255,255,.16);text-align:center;}
footer.site .foot-brands .brands-label{margin-top:0;margin-bottom:20px;}
footer.site .foot-brands a.brands-label:hover{color:var(--white);}
footer.site .foot-bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px 24px;margin-top:40px;padding-top:24px;border-top:1px solid rgba(255,255,255,.16);font-size:.76em;text-transform:uppercase;letter-spacing:.04em;color:#cfd3ce;}
footer.site .foot-legal{display:flex;flex-wrap:wrap;gap:8px 22px;}
footer.site .foot-legal a{transition:color .3s ease;}
footer.site .foot-legal a:hover{color:var(--light-green);}
@media(max-width:900px){ footer.site .foot-top{grid-template-columns:1fr 1fr;gap:38px 28px;} footer.site .foot-brand{grid-column:1 / -1;} }
@media(max-width:560px){ footer.site .foot-top{grid-template-columns:1fr;} footer.site .foot-bottom{flex-direction:column;align-items:flex-start;} }

/* ---------- Map ---------- */
.map iframe{width:100%;height:420px;border:0;display:block;}


/* ---- Partner-Logo-Karten ---- */
.logocard{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:140px;padding:28px;background:var(--white);border:1px solid #e3e0d8;border-radius:10px;transition:transform .4s ease,box-shadow .4s ease;}
.logocard:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(40,51,44,.14);}
.logocard img{max-width:100%;max-height:56px;width:auto;height:auto;object-fit:contain;}
.logocard .logoname{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.05em;font-size:.72em;color:#5c625c;text-align:center;line-height:1.3;}


/* ---- Marken-Karten ---- */
.brand-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.brand-card{display:flex;flex-direction:column;background:var(--white);border:1px solid #e3e0d8;border-radius:10px;overflow:hidden;transition:transform .4s ease,box-shadow .4s ease;}
.brand-card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(40,51,44,.16);}
.brand-card .logo{background:var(--green);display:flex;align-items:center;justify-content:center;height:96px;padding:0 26px;}
.brand-card .logo img{max-height:34px;max-width:150px;width:auto;object-fit:contain;}
.brand-card .body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1;}
.brand-card .cat{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.12em;font-size:.66em;color:var(--light-green);margin-bottom:10px;}
.brand-card h3{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.03em;font-size:1.02em;margin-bottom:10px;}
.brand-card p{font-size:.92em;line-height:1.6;color:#5c625c;}
@media(max-width:1000px){ .brand-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:640px){ .brand-grid{grid-template-columns:1fr;} }

/* ---- Foto-Elemente ---- */
.photo-band{width:100%;}
.photo-band img{width:100%;height:auto;display:block;}
.feature-img{border-radius:10px;overflow:hidden;box-shadow:0 18px 44px rgba(40,51,44,.18);}
.feature-img img{width:100%;height:100%;object-fit:cover;display:block;}

/* ---- Footer Partnerlogos (weiss, auf dunklem Foto) ---- */
footer.site .partner-logos{display:grid;grid-template-columns:repeat(5,1fr);justify-items:center;align-items:center;gap:36px 20px;margin-top:22px;}
footer.site .partner-logos img{height:auto;width:auto;max-height:30px;max-width:100px;object-fit:contain;opacity:.85;transition:opacity .3s ease;}
footer.site .partner-logos img:hover{opacity:1;}
footer.site .partner-logos img[alt="SRAM"]{max-width:82px;}

/* ---- Service-Icon-Karten ---- */
.icon-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.icon-card{text-align:center;padding:34px 22px;background:var(--white);border:1px solid #e3e0d8;border-radius:10px;transition:transform .4s ease,box-shadow .4s ease;}
.icon-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(40,51,44,.14);}
.icon-card img{height:56px;width:auto;margin:0 auto 16px;display:block;}
.icon-card h3{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.04em;font-size:.95em;margin-bottom:8px;}
.icon-card p{font-size:.88em;line-height:1.55;}


/* ---- Blog ---- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;}
.blog-card{display:flex;flex-direction:column;background:var(--white);border:1px solid #e3e0d8;border-radius:10px;overflow:hidden;transition:transform .4s ease,box-shadow .4s ease;}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(40,51,44,.16);}
.blog-card .thumb{aspect-ratio:16/10;overflow:hidden;}
.blog-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;}
.blog-card:hover .thumb img{transform:scale(1.06);}
.blog-card .body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1;}
.blog-card .cat{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.12em;font-size:.66em;color:var(--light-green);margin-bottom:12px;}
.blog-card h3{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.02em;font-size:.98em;line-height:1.3;margin-bottom:12px;overflow-wrap:break-word;hyphens:auto;}
.blog-card p{font-size:.88em;line-height:1.55;color:#5c625c;flex:1;overflow-wrap:break-word;}
.blog-card .more{margin-top:18px;font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.06em;font-size:.72em;color:var(--green);}

/* ---- Blog Artikel ---- */
.article{max-width:780px;margin:0 auto;padding:0 24px;}
.article .kicker{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.12em;font-size:.74em;color:var(--light-green);}
.article h2{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.02em;font-size:1.15em;line-height:1.3;margin:38px 0 16px;color:var(--green);}
.article p{font-size:1.02em;line-height:1.75;margin-bottom:18px;}
.article p strong{font-family:var(--font-bol);}
.article ul{margin:0 0 18px 0;}
.article ul li{position:relative;padding-left:26px;margin-bottom:10px;font-size:1.02em;line-height:1.65;}
.article ul li::before{content:'';position:absolute;left:4px;top:11px;width:8px;height:8px;border-radius:50%;background:var(--light-green);}
.article ol{margin:0 0 18px 22px;}
.article ol li{margin-bottom:10px;font-size:1.02em;line-height:1.65;}
.article blockquote.pullquote{margin:36px 0;padding:6px 0 6px 28px;border-left:4px solid var(--light-green);font-family:var(--font-sig);font-size:clamp(1.5rem,2.8vw,2.1rem);line-height:1.25;color:var(--green);}
.article blockquote.pullquote cite{display:block;margin-top:14px;font-family:var(--font-bol);font-style:normal;text-transform:uppercase;letter-spacing:.04em;font-size:.42em;color:var(--light-green);}
.back-link{display:inline-block;margin-top:50px;font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.05em;font-size:.78em;}
@media(max-width:1000px){ .blog-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:640px){ .blog-grid{grid-template-columns:1fr;} }
.blog-grid.cols-2{grid-template-columns:repeat(2,1fr);}
@media(max-width:640px){ .blog-grid.cols-2{grid-template-columns:1fr;} }


/* ---- Zeitachse / Timeline ---- */
.timeline{position:relative;max-width:920px;margin:0 auto;padding:10px 0;}
.timeline::before{content:'';position:absolute;left:140px;top:0;bottom:0;width:2px;background:#d9d6cd;}
.tl-item{position:relative;padding:0 0 38px 180px;}
.tl-item:last-child{padding-bottom:0;}
.tl-item .tl-date{position:absolute;left:0;top:0;width:120px;text-align:right;font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.04em;font-size:.72em;color:var(--green);line-height:1.35;}
.tl-item .tl-dot{position:absolute;left:133px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--green);border:3px solid var(--cream);box-shadow:0 0 0 2px #d9d6cd;}
.tl-item .tl-body{font-size:1em;line-height:1.6;}
.tl-item .tl-body a{color:var(--green);text-decoration:underline;font-family:var(--font-bol);font-size:.84em;text-transform:uppercase;letter-spacing:.04em;}
.tl-item.milestone .tl-dot{background:var(--light-green);width:20px;height:20px;left:131px;top:2px;}
.tl-item.milestone .tl-body{font-family:var(--font-bol);}

/* ---- Team-Raster ---- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.team-card{text-align:center;}
.team-card .pic{aspect-ratio:1/1;border-radius:50%;overflow:hidden;width:170px;margin:0 auto 18px;background:#e7e4dc;box-shadow:0 14px 34px rgba(40,51,44,.16);}
.team-card .pic img{width:100%;height:100%;object-fit:cover;}
.team-card h3{font-family:var(--font-scr);font-size:1.7em;color:var(--green);margin-bottom:6px;font-weight:400;text-transform:none;letter-spacing:0;}
.team-card p{font-size:.9em;line-height:1.5;color:#5c625c;max-width:240px;margin:0 auto;}

@media(max-width:820px){
  .timeline::before{left:8px;}
  .tl-item{padding-left:42px;}
  .tl-item .tl-date{position:relative;left:auto;top:auto;width:auto;text-align:left;margin-bottom:4px;}
  .tl-item .tl-dot{left:1px;top:2px;}
  .tl-item.milestone .tl-dot{left:-1px;}
  .team-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:560px){ .team-grid{grid-template-columns:1fr 1fr;} }

/* ---------- Mobiles Menü (Burger ab 1200px) ---------- */
@media(max-width:1200px){
  header.site .menu-toggle{display:flex;}
  .mainnav{
    position:fixed;top:0;right:0;height:100vh;width:min(82vw,340px);
    background:var(--green);margin-left:0;padding:96px 38px 40px;
    display:flex;flex-direction:column;justify-content:center;
    transform:translateX(100%);transition:transform .45s ease;
    box-shadow:-12px 0 44px rgba(0,0,0,.28);overflow-y:auto;
  }
  body.nav-open .mainnav{transform:translateX(0);}
  .mainnav ul{flex-direction:column;align-items:flex-start;gap:18px;}
  .mainnav a{font-size:1.45em;color:var(--white);}
  .mainnav a::after{height:4px;}
}

/* ---------- Responsive ---------- */
@media(max-width:1000px){
  .grid-3,.cards,.stats,.steps{grid-template-columns:1fr 1fr;}
  .split{grid-template-columns:1fr;}
  .split.reverse .media{order:0;}
  .split .media{min-height:300px;}
  .contact-grid{grid-template-columns:1fr;gap:40px;}
  #overlay nav ul li{padding:0 16px 10px;}
  #overlay nav ul li a{font-size:2.1em;}
}
@media(max-width:640px){
  body{font-size:17px;}
  .grid-2,.grid-3,.cards,.stats,.steps{grid-template-columns:1fr;}
  #overlay nav ul li{display:block;padding:6px 0;}
  #overlay nav ul li a{font-size:1.9em;}
  footer.site .contactbar span.sep{display:none;}
  header.site .brand{height:50px;}
}

@media(max-width:1000px){ .icon-cards{grid-template-columns:1fr 1fr;} footer.site .partner-logos{gap:30px 14px;} footer.site .partner-logos img{max-height:26px;max-width:86px;} footer.site .partner-logos img[alt="SRAM"]{max-width:72px;} }
@media(max-width:640px){ .icon-cards{grid-template-columns:1fr 1fr;} footer.site .partner-logos{grid-template-columns:repeat(2,1fr);gap:30px 16px;} footer.site .partner-logos img{max-height:28px;max-width:130px;} footer.site .partner-logos img[alt="SRAM"]{max-width:108px;} }


/* ---------- Cookie-Consent & externe Dienste ---------- */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:2000;background:var(--green);color:#fff;transform:translateY(120%);transition:transform .5s cubic-bezier(.2,.7,.2,1);box-shadow:0 -12px 40px rgba(0,0,0,.28);}
.cookie-banner.show{transform:none;}
.cookie-banner .cb-inner{width:90%;max-width:1140px;margin:0 auto;padding:20px 0;display:flex;gap:28px;align-items:center;flex-wrap:wrap;}
.cookie-banner .cb-text{flex:1;min-width:240px;}
.cookie-banner .cb-text strong{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.05em;font-size:.86em;display:block;margin-bottom:7px;}
.cookie-banner .cb-text p{font-size:.84em;line-height:1.55;color:rgba(255,255,255,.86);}
.cookie-banner .cb-text a{color:#fff;text-decoration:underline;}
.cookie-banner .cb-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.cookie-banner .btn{padding:14px 32px;font-size:.76em;border-width:2px;}
.cookie-banner .btn::before{display:none;}
.cookie-banner .cb-accept{background:#fff;border-color:#fff;color:var(--green);}
.cookie-banner .cb-accept:hover{background:#ece9e1;border-color:#ece9e1;color:var(--green);}
.cookie-banner .cb-essential{background:transparent;border-color:rgba(255,255,255,.5);color:#fff;}
.cookie-banner .cb-essential:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff;}
@media(max-width:720px){
  .cookie-banner .cb-inner{gap:16px;}
  .cookie-banner .cb-actions{width:100%;flex-direction:column-reverse;gap:10px;}
  .cookie-banner .cb-actions .btn{width:100%;text-align:center;padding:15px 16px;}
}
.consent-ph{background:var(--cream);border:1px dashed #c7ccc4;border-radius:10px;padding:40px 26px;text-align:center;max-width:680px;margin:0 auto;}
.consent-ph p{font-size:.95em;line-height:1.6;color:#5c625c;margin-bottom:22px;}
.consent-ph .consent-ds{display:block;margin-top:16px;font-size:.74em;text-transform:uppercase;letter-spacing:.08em;color:var(--light-green);text-decoration:none;}
.consent-ph .consent-ds:hover{color:var(--green);}
#cookieSettings{cursor:pointer;}
/* ---------- Checklist (Jobs etc.) ---------- */
.checklist{margin-top:20px;}
.checklist li{position:relative;padding-left:26px;margin-bottom:10px;font-size:.97em;line-height:1.55;}
.checklist li::before{content:'';position:absolute;left:2px;top:9px;width:8px;height:8px;border-radius:50%;background:var(--light-green);}
/* ---------- Stellen-Liste (Jobs) ---------- */
.jobs-list{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:20px;}
.job{background:var(--white);border:1px solid #e3e0d8;border-radius:12px;padding:30px 32px;transition:box-shadow .4s ease,transform .4s ease;}
.job:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(40,51,44,.10);}
.job-head{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:12px;}
.job-head h3{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.02em;font-size:1.12em;color:var(--green);}
.job-tag{font-family:var(--font-bol);text-transform:uppercase;letter-spacing:.05em;font-size:.62em;color:var(--green);background:var(--cream);border:1px solid #e3e0d8;border-radius:50px;padding:7px 15px;white-space:nowrap;}
.job-intro{font-size:.98em;line-height:1.6;color:#4a4f49;}
.job .checklist{margin-top:14px;}
@media(max-width:560px){ .job{padding:24px 22px;} .job-head h3{font-size:1.02em;} }