/* ===== RESET & BASIS ===== */
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#222;background:#f9f9f9;line-height:1.6}

/* ===== CONTAINER ===== */
.container{width:98%;max-width:1400px;margin:0 auto;padding:0 20px}

/* ===== HEADER + NAV (immer Hamburger) ===== */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid #eee}
.header-flex{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;position:relative}
.logo{max-height:80px;height:auto;display:block}

/* Hamburger immer sichtbar */
.menu-toggle{
  display:inline-flex!important;align-items:center;justify-content:center;
  width:44px;height:44px;font-size:22px;border:0;background:transparent;cursor:pointer;color:#333
}

/* Panel-Navigation (standardmäßig zu) */
.main-nav{display:none}
.main-nav.show{
  display:block;position:absolute;top:100%;left:0;right:0;background:#fff;z-index:1000;
  border-top:1px solid rgba(0,0,0,.06);box-shadow:0 12px 24px rgba(0,0,0,.08)
}

/* Vertikale Liste im Panel */
.nav-list{list-style:none;margin:0;padding:.25rem .75rem;display:flex;flex-direction:column;gap:0}
.nav-item{position:relative}
.nav-link{display:block;padding:.9rem .5rem;text-decoration:none;color:#333;font-weight:600;background:transparent}

/* Hover wie bei deinen Links: Farbwechsel, kein grauer Kasten */
.site-header nav a:hover,.nav-link:hover,.nav-link:focus{color:#007BFF;background:transparent}

/* Submenü – optisch wie normale Links; nur Einrückung */
.submenu{display:none;margin:0;padding:.25rem 0;list-style:none}
.nav-item.open>.submenu{display:block}
.submenu .nav-link{display:block;padding:.6rem .5rem;padding-left:1.25rem}

/* Panel-Layout im aufgeklappten Zustand */
.main-nav.show .nav-list{flex-direction:column;align-items:stretch;gap:0}
.main-nav.show .nav-item{width:100%}
.main-nav.show .nav-link{padding:.9rem 0;width:100%;justify-content:space-between}

/* ===== HERO ===== */
.hero{position:relative;overflow:hidden;min-height:80vh;text-align:center;color:#fff;display:flex;align-items:center;justify-content:center;padding:0 20px}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);z-index:1}
.hero-content{position:relative;z-index:2;max-width:1000px}
.hero h1{font-size:3.2rem;font-weight:800;text-shadow:2px 2px 8px rgba(0,0,0,.6);margin-bottom:20px}
.hero p{font-size:1.3rem;margin-bottom:30px;text-shadow:1px 1px 6px rgba(0,0,0,.6)}
.btn-hero{display:inline-block;background:#c8102e;color:#fff;padding:14px 28px;font-size:1.1rem;font-weight:700;border-radius:6px;text-decoration:none;transition:background .3s}
.btn-hero:hover{background:#880000}
@media (max-width:768px){
  .hero h1{font-size:2rem}
  .hero p{font-size:1.1rem}
  .btn-hero{padding:12px 24px;font-size:1rem}
  .logo{max-height:60px}
}


/* ===== BIKE OF THE MONTH ===== */
.bike-of-the-month{padding:3rem 1.5rem;background:#fff;border-top:5px solid #009900;margin:3rem 0}
.bike-container{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:center;gap:2rem}
.bike-image{position:relative}
.badge{position:absolute;top:-8px;left:-8px;background:#009900;color:#fff;padding:.4rem 1rem;font-size:.85rem;font-weight:700;border-radius:6px}
.bike-image img{max-width:420px;width:100%;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.1);transition:transform .3s}
.bike-image img:hover{transform:scale(1.04)}
.bike-details{max-width:500px}
.bike-details h2{font-size:2rem;color:#333;margin-bottom:1rem;text-align:left}
.price-box{background:#f9fff9;border:2px solid #009900;border-radius:10px;text-align:center;padding:1rem;margin-bottom:1.5rem}
.price{font-size:1.5rem;margin-bottom:.3rem}
.old-price{text-decoration:line-through;color:#777;margin-right:.8rem}
.new-price{color:#d60000;font-weight:700;font-size:2rem}
.savings{color:#009900;font-size:1rem;font-weight:600}
.bike-description{font-size:1rem;color:#444;margin-bottom:1rem}
.target-group,.features{list-style:disc;padding-left:1.2rem;margin-bottom:1.2rem;color:#444}
.bike-button{display:inline-block;background:#009900;color:#fff;text-decoration:none;padding:.9rem 1.8rem;border-radius:8px;font-size:1rem;font-weight:700;transition:background .3s,transform .2s}
.bike-button:hover{background:#007700;transform:scale(1.02)}
.email-button{margin-top:1rem}
@media (max-width:768px){
  .bike-container{flex-direction:column;align-items:center;padding:0 1rem}
  .bike-details h2{font-size:1.6rem;text-align:center}
  .price-box,.bike-details{width:100%;padding:0 .5rem}
  .bike-button{width:100%;text-align:center}
  .badge{font-size:.75rem}
}

/* ===== BLOG-TEASER „Wer sind wir?“ (neutral) ===== */
.blog-post{max-width:800px;margin:60px auto;padding:20px;background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.05);line-height:1.6;color:#333}
.blog-post h3{font-size:1.5rem;margin-bottom:10px;color:#003366}

/* ===== SHIMANO SERVICE CENTER TEASER ===== */
:root{--ssc-border:#e5e7eb;--ssc-blue:#0ea5e9}
.ssc-teaser{padding:12px 20px}
.ssc-card{
  display:grid;grid-template-columns:140px 1fr;gap:18px;align-items:center;text-decoration:none;color:#0f172a;
  background:#fff;border:1px solid var(--ssc-border);border-radius:18px;box-shadow:0 1px 2px rgba(2,8,23,.06);padding:18px;position:relative;overflow:hidden;transition:transform .18s,box-shadow .25s,border-color .25s
}
.ssc-card:hover{transform:translateY(-3px);border-color:#cbd5e1;box-shadow:0 12px 34px rgba(2,8,23,.1)}
.ssc-media{display:grid;place-items:center;background:#f1f5f9;border:1px solid var(--ssc-border);border-radius:14px;padding:12px}
.ssc-logo{max-width:110px;height:auto;display:block}
.ssc-eyebrow{margin:0;font-size:12px;letter-spacing:.4px;text-transform:uppercase;color:var(--ssc-blue);font-weight:700}
.ssc-title{margin:0;font-size:22px;line-height:1.25}
.ssc-title span{color:var(--ssc-blue)}
.ssc-text{margin:0;color:#475569}
.ssc-cta{margin-top:8px;display:inline-block;font-weight:600;font-size:14px;padding:10px 14px;border-radius:999px;border:1px solid var(--ssc-border);background:#f8fafc;color:#0f172a}
.ssc-card:hover .ssc-cta{border-color:#bfdbfe;background:#eef6ff}
@media (max-width:720px){.ssc-card{grid-template-columns:1fr}}

/* ===== SPONSORING-TEASER (JSV/Meppen) ===== */
:root{--s-border:#e5e7eb;--s-card:#fff;--s-muted:#475569}
.sponsoring-teaser{padding:20px}
.sponsoring-card{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:center;background:var(--s-card);
  border:1px solid var(--s-border);border-radius:18px;box-shadow:0 1px 3px rgba(0,0,0,.08);padding:20px;transition:transform .2s,box-shadow .25s
}
.sponsoring-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.12)}
.sponsoring-media{border-radius:18px;overflow:hidden}
.sponsoring-img{width:100%;height:auto;display:block;border-radius:18px}
.sponsoring-content{display:flex;flex-direction:column;gap:8px}
.sponsoring-eyebrow{font-size:12px;text-transform:uppercase;color:#16a34a;letter-spacing:.4px;font-weight:700;margin:0}
.sponsoring-title{margin:0;font-size:22px;line-height:1.3}
.sponsoring-text{margin:0;color:var(--s-muted)}
@media (max-width:720px){.sponsoring-card{grid-template-columns:1fr}}

/* ===== SOCIAL HIGHLIGHTS + HERO ===== */
.social-highlights{--sh-gap:16px;--sh-radius:16px;--sh-border:#ececec;--sh-bg:#f8f8f8;--sh-btn:#111;--sh-btn-text:#fff;max-width:1200px;margin:40px auto;padding:0 20px}
.sh-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.sh-head h2{margin:0;font-size:clamp(1.25rem,2vw,1.6rem)}
.sh-btn{background:var(--sh-btn);color:var(--sh-btn-text);text-decoration:none;padding:10px 14px;border-radius:999px;font-size:.95rem;transition:opacity .2s}
.sh-btn:hover{opacity:.9}
.sh-grid{display:grid;gap:var(--sh-gap);grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.sh-card{display:block;border:1px solid var(--sh-border);border-radius:var(--sh-radius);overflow:hidden;background:#fff;text-decoration:none;color:inherit;transition:transform .15s,box-shadow .15s}
.sh-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.06)}
.sh-card img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:var(--sh-bg)}
.sh-meta{padding:12px}
.sh-badge{display:inline-block;font-size:.72rem;background:#efefef;border-radius:999px;padding:3px 9px;margin-bottom:6px}
.sh-meta p{margin:.25rem 0 0;font-size:.95rem;line-height:1.35}
.social-hero{max-width:1200px;margin:40px auto;padding:0 20px}
.sh-hero-link{position:relative;display:block;border-radius:20px;overflow:hidden}
.sh-hero-video{width:100%;height:auto;display:block;object-fit:cover;max-height:520px}
.sh-hero-overlay{position:absolute;inset:auto 16px 16px 16px;background:rgba(0,0,0,.45);backdrop-filter:saturate(120%) blur(2px);color:#fff;padding:14px 16px;border-radius:14px;display:inline-flex;flex-direction:column;gap:4px}

/* ===== BIKE-BERATER (Startseiten-Tool) ===== */
.bike-berater{background:linear-gradient(to right,#fdfdfd,#f5f5f5);padding:80px 20px;border-top:1px solid #ddd;border-bottom:1px solid #ddd}
.bike-berater .container{max-width:700px;margin:0 auto;text-align:center}
.bike-berater h2{font-size:2rem;margin-bottom:16px;color:#aa0000}
.bike-berater p{font-size:1rem;color:#333;margin-bottom:30px;max-width:600px;margin-inline:auto}
#beratungForm{background:#fff;padding:30px;border-radius:10px;box-shadow:0 0 8px rgba(0,0,0,.05);text-align:left}
#beratungForm label{display:block;font-weight:600;margin:20px 0 10px;color:#444}
#beratungForm select{width:100%;padding:12px;font-size:1rem;border-radius:6px;border:1px solid #ccc;background:#fff;transition:border-color .3s}
#beratungForm select:focus{border-color:#aa0000;outline:none}
.bike-berater button{display:block;margin:30px auto 0;background:linear-gradient(to right,#aa0000,#cc3333);color:#fff;padding:14px 28px;font-size:1rem;font-weight:600;border:0;border-radius:8px;cursor:pointer;box-shadow:0 4px 10px rgba(0,0,0,.1);transition:transform .2s,background .3s}
.bike-berater button:hover{background:linear-gradient(to right,#880000,#bb2222);transform:scale(1.05)}
.empfehlung-box{display:none;margin-top:40px;background:#fff4f4;padding:20px 30px;border-left:6px solid #aa0000;border-radius:6px;max-width:600px;margin-inline:auto;font-weight:700;color:#222;box-shadow:0 0 8px rgba(0,0,0,.05);transition:all .3s}

/* ===== KUNDENSTIMMEN ===== */
.kundenstimmen-section{background:#f9f9f9;padding:60px 20px;text-align:center}
.kundenstimmen-section h2{font-size:2.2rem;margin-bottom:40px;color:#003366}
.rezensionen-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px}
.rezension-box{background:#fff;padding:25px 20px;border-radius:10px;box-shadow:0 4px 12px rgba(0,0,0,.05);transition:transform .3s,box-shadow .3s;text-align:left}
.rezension-box:hover{transform:translateY(-5px);box-shadow:0 6px 20px rgba(0,0,0,.08)}
.sterne{color:#ffc107;font-size:1.4rem;margin-bottom:10px;font-weight:700}
.kunde{font-style:italic;margin-top:15px;color:#666}

/*=== Sponsoring Abteil ====*/
.sponsoring {--sp-gap: 18px;--sp-radius: 16px;--sp-border: #e9e9e9;--sp-bg: #fafafa; --sp-text: #111;max-width: 1200px;margin: 48px auto; padding: 0 20px;color: var(--sp-text);}
  .sp-head h2 {margin: 0 0 6px; font-size: clamp(1.35rem, 2.4vw, 1.8rem);}
  .sp-head p { margin: 0 0 18px;opacity: .9;}
  .sp-grid { display: grid;gap: var(--sp-gap);grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));}
  .sp-card {display: block; border: 1px solid var(--sp-border);border-radius: var(--sp-radius);background: #fff; text-decoration: none;color: inherit;padding: 14px;transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;}
  .sp-card:hover {transform: translateY(-2px);box-shadow: 0 10px 24px rgba(0,0,0,.06); border-color: #ddd;}
  .sp-card img {width: 100%; height: 120px;object-fit: contain;display: block;background: var(--sp-bg);border-radius: 12px;}
  .sp-meta {padding: 10px 4px 2px;}
  .sp-meta strong {display: block;font-size: 1rem;line-height: 1.25;}
  .sp-meta span {display: block;font-size: .9rem;opacity: .85; margin-top: 2px;}
  .sp-cta { margin-top: 20px;text-align: center;}
  .sp-cta a {font-weight: 600;text-underline-offset: 3px;}

/* ===== FEATURES-GRID ===== */
.features-grid{background:#f9f9f9;padding:60px 20px}
.features-heading{text-align:center;margin-bottom:40px;font-size:2rem;color:#222}
.features-wrapper{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px}
.feature-card{background:#fff;border-radius:8px;padding:25px;box-shadow:0 4px 12px rgba(0,0,0,.05);text-align:center;transition:transform .3s,box-shadow .3s}
.feature-card:hover{transform:translateY(-5px);box-shadow:0 6px 20px rgba(0,0,0,.08)}
.feature-card h3{font-size:1.2rem;margin-bottom:10px;color:#aa0000}
.feature-card p{font-size:.95rem;color:#555}

/* ===== FOOTER ===== */
.site-footer{background:#003366;color:#fff;padding:3rem 1rem 2rem;margin-top:100px}
.footer-flex{display:flex;justify-content:space-between;flex-wrap:wrap;gap:2rem;max-width:1200px;margin:0 auto}
.footer-info,.footer-kontakt,.footer-links{flex:1 1 250px}
.footer-logo{max-width:120px;margin-bottom:10px;display:block}
.footer-kontakt a,.footer-links a{color:#fff;text-decoration:none;display:block;margin:.3rem 0;transition:color .2s}
.footer-kontakt a:hover,.footer-links a:hover{color:#aad4ff;text-decoration:underline}
footer .copyright{border-top:1px solid rgba(255,255,255,.2);margin-top:2.5rem;padding-top:1rem;text-align:center;font-size:.9rem;color:#ddd}
@media (max-width:768px){
  .footer-flex{flex-direction:column;gap:1.5rem}
  .footer-info,.footer-kontakt,.footer-links{flex:1 1 100%}
}

