
:root {
  --green: #94c01b;
  --gray: #565655;
  --dark: #151716;
  --light: #f7f9f3;
  --white: #ffffff;
  --soft: #eef5df;
  --line: rgba(86,86,85,.18);
  --shadow: 0 24px 60px rgba(0,0,0,.12);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Myriad Pro','Segoe UI',Arial,sans-serif;
  background: radial-gradient(circle at top left, rgba(148,192,27,.20), transparent 38%), linear-gradient(180deg,#fff 0%,#f5f7f1 100%);
  color: var(--gray);
  line-height: 1.6;
}
.site-shell { min-height: 100vh; position: relative; overflow: hidden; }
.orb { position: fixed; border-radius: 999px; filter: blur(2px); opacity: .22; z-index: -1; }
.orb.one { width: 360px; height: 360px; background: var(--green); right: -90px; top: 130px; }
.orb.two { width: 260px; height: 260px; background: var(--gray); left: -110px; bottom: 60px; }
.nav { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.86); backdrop-filter: blur(18px); border-bottom: 1px solid var(--line); }
.nav-inner { max-width: 1180px; margin: auto; display: flex; align-items: center; gap: 24px; padding: 14px 22px; }
.brand { display: flex; align-items: center; gap: 14px; text-decoration: none; color: var(--gray); font-weight: 800; letter-spacing: .02em; }
.brand img { height: 48px; width: auto; }
.links { margin-left: auto; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.links a { color: var(--gray); text-decoration: none; font-weight: 700; font-size: .92rem; padding: 10px 12px; border-radius: 999px; }
.links a:hover, .links a.active { background: var(--green); color: #152000; }
.cta { border: 1px solid var(--green)!important; }
.menu-toggle { display:none; margin-left:auto; border:1px solid var(--line); background:#fff; border-radius:14px; padding:8px 12px; font-size:1.2rem; }
.hero { max-width: 1180px; margin: 0 auto; padding: 78px 22px 42px; display: grid; grid-template-columns: 1.1fr .9fr; gap: 40px; align-items: center; }
.eyebrow { display: inline-flex; gap: 9px; align-items: center; padding: 8px 13px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.74); font-weight: 800; font-size: .88rem; }
.dot { width: 10px; height: 10px; background: var(--green); border-radius: 999px; box-shadow: 0 0 0 6px rgba(148,192,27,.16); }
h1 { font-size: clamp(2.4rem,6vw,5.7rem); line-height: .92; margin: 24px 0 18px; color: #303230; letter-spacing: -.06em; }
h2 { font-size: clamp(1.8rem,3.4vw,3rem); line-height: 1.05; margin: 0 0 18px; color: #303230; }
h3 { margin: 0 0 8px; color: #303230; }
.lead { font-size: 1.2rem; max-width: 740px; }
.hero-card, .panel, .tile, .quick, .photo-card { background: rgba(255,255,255,.82); border: 1px solid var(--line); box-shadow: 0 16px 45px rgba(0,0,0,.05); }
.hero-card { position: relative; border-radius: 38px; padding: 30px; overflow: hidden; box-shadow: var(--shadow); }
.hero-card:before { content: 'M'; position: absolute; right: -15px; bottom: -84px; font-size: 21rem; font-weight: 900; color: rgba(148,192,27,.20); line-height: 1; }
.logo-stage { min-height: 320px; display: grid; place-items: center; }
.logo-stage img { max-width: 96%; filter: drop-shadow(0 16px 20px rgba(0,0,0,.12)); }
.quick-grid { max-width: 1180px; margin: 0 auto 70px; padding: 0 22px; display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.quick { display: block; padding: 22px; border-radius: 26px; text-decoration: none; color: var(--gray); transition: .25s; }
.quick:hover { transform: translateY(-5px); border-color: var(--green); }
.quick b { display: block; color: #303230; margin-bottom: 6px; }
.section { max-width: 1180px; margin: 0 auto; padding: 54px 22px; }
.panel { border-radius: 34px; padding: 34px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.tile { padding: 26px; border-radius: 28px; min-height: 180px; }
.tile .num { font-size: 2.8rem; font-weight: 900; color: var(--green); line-height: 1; }
.visual, .video-stage, .photo-placeholder { border-radius: 30px; background: linear-gradient(135deg, rgba(148,192,27,.85), rgba(86,86,85,.88)), repeating-linear-gradient(45deg, transparent 0 18px, rgba(255,255,255,.16) 19px 20px); display: grid; place-items: center; color: white; text-align: center; padding: 20px; overflow: hidden; font-weight: 900; }
.visual { min-height: 260px; }
.visual span { font-size: clamp(2rem,5vw,4.5rem); letter-spacing: -.06em; }
.visual-logo { max-width: 80%; }
.video-stage { min-height: 320px; font-size: clamp(2rem,5vw,4.5rem); }
.timeline { display: grid; gap: 16px; }
.time { display: grid; grid-template-columns: 120px 1fr; gap: 18px; align-items: start; }
.year { font-weight: 900; color: var(--green); font-size: 1.6rem; }
.gallery { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.photo-card { border-radius: 28px; padding: 16px; }
.photo-card img { width: 100%; height: 220px; object-fit: cover; border-radius: 22px; display: block; margin-bottom: 14px; }
.photo-placeholder { min-height: 220px; margin-bottom: 14px; font-size: 1.8rem; }
.press { border-left: 8px solid var(--green); }
.legal { max-width: 920px; }
.form { display: grid; gap: 14px; }
.form input, .form textarea { width: 100%; border: 1px solid var(--line); border-radius: 18px; padding: 15px; font: inherit; }
.button { display: inline-flex; align-items: center; justify-content: center; border: 0; border-radius: 999px; background: var(--green); color: #152000; font-weight: 900; padding: 13px 20px; text-decoration: none; cursor: pointer; }
.footer { margin-top: 70px; background: #202220; color: #e9efe4; }
.footer-inner { max-width: 1180px; margin: auto; padding: 38px 22px; display: grid; grid-template-columns: 1fr auto; gap: 20px; align-items: center; }
.footer a { color: #fff; }
.muted { color: #777; }
.badge-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.badge { padding: 8px 12px; border-radius: 999px; background: var(--soft); font-weight: 800; color: #334; }
.page-head { max-width: 1180px; margin: 0 auto; padding: 56px 22px 18px; }
.page-head h1 { font-size: clamp(2.3rem,5vw,4.8rem); }
@media(max-width:860px) {
  .hero, .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .quick-grid { grid-template-columns: 1fr 1fr; }
  .menu-toggle { display:block; }
  .links { display:none; width:100%; margin-left:0; }
  .links.open { display:flex; }
  .gallery { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; }
  .time { grid-template-columns: 1fr; }
  .hero { padding-top: 44px; }
}
@media(max-width:520px) {
  .quick-grid { grid-template-columns: 1fr; }
  .brand span { display: none; }
}


/* BRANDPORTAL-ERWEITERUNG */
.brand-hero-head { padding-bottom: 8px; }
.brand-intro .image-visual { min-height: 360px; background: #202220; }
.image-visual img { width: 100%; height: 100%; object-fit: contain; max-height: 320px; filter: drop-shadow(0 22px 35px rgba(0,0,0,.18)); }
.section-title-row { display: grid; grid-template-columns: 1fr minmax(240px, 420px); gap: 22px; align-items: end; margin-bottom: 22px; }
.asset-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.asset-card, .showcase-card, .social-visual { text-decoration: none; color: var(--gray); background: rgba(255,255,255,.86); border: 1px solid var(--line); border-radius: 28px; padding: 18px; box-shadow: 0 16px 45px rgba(0,0,0,.055); transition: transform .25s, border-color .25s, box-shadow .25s; overflow: hidden; }
.asset-card:hover, .showcase-card:hover, .social-visual:hover { transform: translateY(-5px); border-color: var(--green); box-shadow: 0 22px 55px rgba(0,0,0,.09); }
.asset-card img { width: 100%; height: 128px; object-fit: contain; display: block; margin-bottom: 16px; }
.asset-card b, .showcase-card b { display: block; color: #303230; font-size: 1.05rem; }
.asset-card span, .showcase-card span, .social-visual span { display: block; color: #6f726e; font-size: .92rem; }
.dark-card { background: linear-gradient(135deg, #202220, #565655); color: #fff; }
.dark-card b, .dark-card span { color: #fff; }
.showcase-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.showcase-card { display: grid; gap: 14px; padding: 14px; }
.showcase-card.large { grid-row: span 2; }
.showcase-card img { width: 100%; height: 230px; object-fit: cover; border-radius: 22px; display: block; background: var(--soft); }
.showcase-card.large img { height: 430px; object-fit: contain; background: #f7f9f3; }
.showcase-card div { padding: 0 6px 6px; }
.social-panel { align-items: center; }
.social-list { list-style: none; padding: 0; margin: 24px 0 0; display: flex; flex-wrap: wrap; gap: 10px; }
.social-list li a { display: inline-flex; align-items: center; gap: 8px; text-decoration: none; color: #303230; background: var(--soft); border: 1px solid var(--line); border-radius: 999px; padding: 11px 15px; font-weight: 900; }
.social-list li.active a, .social-list li a:hover { background: var(--green); color: #152000; }
.social-visual { display: grid; place-items: center; min-height: 360px; background: linear-gradient(135deg, rgba(148,192,27,.22), rgba(86,86,85,.12)); }
.social-visual img { width: min(360px, 90%); height: auto; border-radius: 28px; box-shadow: 0 18px 45px rgba(0,0,0,.16); }
.social-visual span { margin-top: 16px; font-weight: 900; }
.edit-hint code { background: var(--soft); padding: 3px 7px; border-radius: 8px; }
.footer-links { text-align: right; line-height: 1.9; }
.lightbox { position: fixed; inset: 0; background: rgba(15,17,16,.86); z-index: 100; display: none; place-items: center; padding: 28px; }
.lightbox.open { display: grid; }
.lightbox img { max-width: min(1100px, 94vw); max-height: 86vh; object-fit: contain; border-radius: 24px; background: #fff; box-shadow: 0 30px 90px rgba(0,0,0,.45); }
.lightbox-close { position: fixed; right: 24px; top: 18px; width: 46px; height: 46px; border: 0; border-radius: 999px; background: var(--green); color: #152000; font-size: 2rem; font-weight: 900; cursor: pointer; }
@media(max-width: 980px) { .asset-grid, .showcase-grid { grid-template-columns: repeat(2, 1fr); } .section-title-row { grid-template-columns: 1fr; } .showcase-card.large { grid-row: auto; } .showcase-card.large img { height: 300px; } }
@media(max-width: 620px) { .asset-grid, .showcase-grid { grid-template-columns: 1fr; } .asset-card img { height: 150px; } .footer-links { text-align: left; } }
