:root {
  --bg: #060708;
  --panel: #0f1208;
  --panel-2: #11140b;
  --line: rgba(255, 255, 255, .08);
  --cream: #f0ead6;
  --muted: #b7b3a4;
  --soft: #d7d3c6;
  --green: #8ec63f;
  --green-bright: #9ed64a;
  --red: #e0392e;
  --yellow: #f2c14e;
  --display: 'Anton', 'Arial Narrow', system-ui, sans-serif;
  --label: 'Oswald', system-ui, sans-serif;
  --body: 'Oswald', system-ui, -apple-system, Segoe UI, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--cream);
  font-family: var(--body);
  font-weight: 400;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  position: relative;
}

.grain {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

main, header, footer { position: relative; z-index: 1; }

.section-frame { max-width: 1120px; margin: 0 auto; padding: 0 28px; }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.g { color: var(--green); }
.r { color: var(--red); }

/* ---------- Header ---------- */
.site-header {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 26px; padding-bottom: 12px;
}
.brand img { height: 56px; width: auto; }
.sale-flag {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--label); font-weight: 600; text-transform: uppercase;
  letter-spacing: .14em; font-size: .82rem; color: var(--cream);
}
.sale-flag .dot {
  width: 11px; height: 11px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 12px rgba(142, 198, 63, .8);
}
.sale-flag:hover { color: var(--green-bright); }

/* ---------- Hero ---------- */
.hero {
  display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; gap: 30px;
  padding-top: 26px; padding-bottom: 40px;
}
.hero-headline {
  margin: 0 0 26px;
  font-family: var(--display);
  font-weight: 400;
  line-height: .92;
  text-transform: uppercase;
  letter-spacing: .005em;
}
.hero-headline span { display: block; }
.line-sustasty { font-size: clamp(2.6rem, 6vw, 4.6rem); margin-bottom: .06em; }
.line-cream { color: var(--cream); font-size: clamp(2.7rem, 6.6vw, 5rem); }
.line-red { color: var(--red); font-size: clamp(2.7rem, 6.6vw, 5rem); }

.hero-lede {
  color: var(--soft); font-size: 1.06rem; line-height: 1.55; font-weight: 400;
  max-width: 44ch; margin: 0 0 16px;
}
.hero-tldr {
  font-family: var(--label); font-weight: 700; text-transform: none;
  font-size: 1.3rem; color: var(--cream); margin: 0 0 26px;
}
.btn-outline {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 15px 34px; border-radius: 999px;
  border: 2px solid var(--green); color: var(--green-bright);
  font-family: var(--label); font-weight: 600; text-transform: uppercase;
  letter-spacing: .12em; font-size: 1rem;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.btn-outline .arrow, .btn-red .arrow { transition: transform .2s ease; }
.btn-outline:hover { background: var(--green); color: #0a1404; transform: translateY(-2px); }
.btn-outline:hover .arrow { transform: translateX(5px); }

.broker {
  display: flex; align-items: center; gap: 10px; margin: 22px 0 0;
  color: var(--muted); font-family: var(--label); font-weight: 500;
  text-transform: uppercase; letter-spacing: .1em; font-size: .76rem;
}
.broker svg { width: 18px; height: 18px; fill: none; stroke: var(--green); stroke-width: 2; flex: none; }

.hero-art { position: relative; display: flex; justify-content: center; align-items: center; }
.hero-pizza {
  width: 100%; max-width: 460px;
  -webkit-mask-image: radial-gradient(ellipse 78% 80% at 52% 46%, #000 62%, transparent 100%);
  mask-image: radial-gradient(ellipse 78% 80% at 52% 46%, #000 62%, transparent 100%);
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.55));
}
.hero-stamp {
  position: absolute; bottom: 2%; right: 2%;
  width: 38%; max-width: 168px;
  -webkit-mask-image: radial-gradient(circle at 50% 46%, #000 64%, transparent 92%);
  mask-image: radial-gradient(circle at 50% 46%, #000 64%, transparent 92%);
}

/* ---------- Perfekt für ---------- */
.perfekt { padding: 40px 28px 30px; }
.section-eyebrow {
  display: flex; align-items: center; justify-content: center; gap: 18px;
  font-family: var(--label); font-weight: 600; text-transform: uppercase;
  letter-spacing: .22em; color: var(--green); font-size: 1rem; margin-bottom: 34px;
}
.section-eyebrow .rule { height: 1px; width: clamp(40px, 16vw, 220px); background: linear-gradient(90deg, transparent, rgba(142,198,63,.5)); }
.section-eyebrow .rule:last-child { background: linear-gradient(90deg, rgba(142,198,63,.5), transparent); }

.uses-row {
  display: flex; align-items: stretch; justify-content: center; gap: 6px;
}
.use {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 14px;
  padding: 8px 6px; text-align: center;
}
.use .ic { width: 52px; height: 52px; fill: none; stroke: var(--green); stroke-width: 2.1; stroke-linejoin: round; stroke-linecap: round; }
.use .ic-pizza circle { fill: var(--green); stroke: none; }
.use p {
  margin: 0; font-family: var(--label); font-weight: 600; text-transform: uppercase;
  letter-spacing: .06em; font-size: .82rem; color: var(--cream); line-height: 1.4;
}
.divider { width: 1px; background: var(--line); align-self: stretch; margin: 6px 0; flex: none; }

/* ---------- Statement ---------- */
.statement { padding: 38px 28px; }
.statement-panel {
  display: grid; grid-template-columns: 1.15fr .85fr; align-items: center; gap: 20px;
  border-radius: 26px; padding: 44px 48px;
  border: 1px solid rgba(142, 198, 63, .14);
  background:
    radial-gradient(120% 120% at 85% 50%, rgba(142, 198, 63, .12), transparent 55%),
    var(--panel);
  overflow: hidden;
}
.statement-copy h2 {
  margin: 0 0 16px; font-family: var(--display); font-weight: 400; text-transform: uppercase;
  font-size: clamp(1.7rem, 3.4vw, 2.7rem); line-height: 1.02; letter-spacing: .01em; color: var(--cream);
}
.statement-copy p {
  margin: 0; font-family: var(--label); font-weight: 700; font-size: clamp(1.1rem, 2vw, 1.5rem); color: var(--cream);
}
.statement-art { display: flex; justify-content: center; }
.statement-art img {
  width: 100%; max-width: 360px; border-radius: 12px;
  -webkit-mask-image: radial-gradient(ellipse 92% 92% at 50% 50%, #000 78%, transparent 100%);
  mask-image: radial-gradient(ellipse 92% 92% at 50% 50%, #000 78%, transparent 100%);
}

/* ---------- USPs ---------- */
.usps { padding: 20px 28px; }
.usp-bar {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
  border-radius: 22px; padding: 30px 24px;
  border: 1px solid var(--line); background: var(--panel-2);
}
.usp { display: flex; flex-direction: column; gap: 8px; padding: 0 14px; }
.usp + .usp { border-left: 1px solid var(--line); }
.usp-ic { font-size: 1.7rem; line-height: 1; }
.usp-ic.green { color: var(--green); }
.usp-ic.red { color: var(--red); }
.usp-ic.yellow { color: var(--yellow); }
.usp strong {
  font-family: var(--label); font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; font-size: .98rem; color: var(--cream);
}
.usp p { margin: 0; color: var(--muted); font-size: .9rem; line-height: 1.45; }

/* ---------- Final CTA ---------- */
.final { padding: 30px 28px 50px; }
.final-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 28px;
  border-radius: 18px; padding: 30px 40px;
  border: 1px solid var(--line);
  background:
    radial-gradient(100% 140% at 0% 50%, rgba(142, 198, 63, .07), transparent 60%),
    var(--panel-2);
}
.final-bar h2 {
  margin: 0; font-family: var(--display); font-weight: 400; text-transform: uppercase;
  font-size: clamp(1.3rem, 2.8vw, 2.1rem); line-height: 1.05; letter-spacing: .01em; color: var(--cream);
}
.btn-red {
  flex: none; display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 32px; border-radius: 11px; background: var(--red); color: #fff;
  font-family: var(--label); font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; font-size: 1rem;
  box-shadow: 0 14px 30px rgba(224, 57, 46, .32);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn-red:hover { transform: translateY(-2px); background: #ec453a; box-shadow: 0 18px 40px rgba(224, 57, 46, .45); }
.btn-red:hover .arrow { transform: translateX(5px); }

/* ---------- Footer ---------- */
.footer { text-align: center; padding: 18px 28px 46px; }
.footer p {
  margin: 0; font-family: var(--label); font-weight: 500;
  color: var(--muted); font-size: .95rem; letter-spacing: .02em;
}
.footer a { font-weight: 700; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; padding-top: 12px; }
  .hero-art { order: -1; max-width: 360px; margin: 0 auto; }
  .uses-row { flex-wrap: wrap; gap: 22px 4px; }
  .use { flex: 0 0 30%; }
  .divider { display: none; }
  .statement-panel { grid-template-columns: 1fr; text-align: center; padding: 36px 28px; }
  .statement-art { order: -1; }
  .usp-bar { grid-template-columns: 1fr 1fr; gap: 22px 0; }
  .usp:nth-child(odd) { border-left: none; }
  .usp:nth-child(3) { border-left: none; }
  .final-bar { flex-direction: column; text-align: center; }
}

@media (max-width: 540px) {
  .site-header { flex-direction: column; gap: 14px; }
  .use { flex: 0 0 45%; }
  .usp-bar { grid-template-columns: 1fr; }
  .usp + .usp { border-left: none; border-top: 1px solid var(--line); padding-top: 18px; }
}
