.black,
.black .cms-section-default.boxed .cms-block:not(.twt-cms-block-reset):not(.bg-color) {
    background: #000 !important;
}

.modal .cms-block-container {
    padding: 0 !important;
}



@media (max-width: 767.98px) {
    .js-pseudo-modal .modal-body {
        padding: 8px;
    }

    .modal .cms-block-container {
        padding: 0 !important;
    }
}

   :root {
      --red: #c90000;
      --dark-red: #8f0000;
      --black: #101010;
      --dark: #181818;
      --grey: #f5f5f5;
      --text: #222222;
      --muted: #666666;
      --white: #ffffff;
      --gold: #d8a72f;
      --border: #e5e5e5;
      --shadow: 0 18px 45px rgba(0, 0, 0, 0.16);
      --radius: 22px;
    }

.wm .boxed {
    width: min(1180px, calc(100% - 40px));
}
    
.hero {
    background:
        radial-gradient(circle at 80% 20%, rgba(216, 167, 47, 0.45), transparent 30%),
        radial-gradient(circle at 10% 10%, rgba(201, 0, 0, 0.5), transparent 35%),
        linear-gradient(135deg, #0d0d0d 0%, #1b1b1b 48%, #2a0000 100%);
        color: var(--white);
        padding: 95px 0 80px;
}


    .hero-grid {
      position: relative;
      z-index: 2;
      display: grid;
      grid-template-columns: 1.08fr 0.92fr;
      gap: 52px;
      align-items: center;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: rgba(255, 255, 255, 0.12);
      border: 1px solid rgba(255, 255, 255, 0.2);
      border-radius: 999px;
      padding: 8px 14px;
      font-size: 14px;
      margin-bottom: 22px;
      color: #f7f7f7;
    }

    .hero h1 {
      font-size: clamp(44px, 7vw, 82px);
      line-height: 0.95;
      margin-bottom: 24px;
      color: #f7f7f7;
    }

    .hero h1 span {
      color: var(--gold);
    }

    .hero p {
      font-size: 20px;
      max-width: 650px;
      color: rgba(255, 255, 255, 0.86);
      margin-bottom: 28px;
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      align-items: center;
      margin-bottom: 28px;
    }

    .hero-bullets {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 12px;
      margin-top: 34px;
    }

    .hero-bullet {
      background: rgba(255, 255, 255, 0.1);
      border: 1px solid rgba(255, 255, 255, 0.16);
      border-radius: 16px;
      padding: 14px;
      font-weight: 700;
      font-size: 14px;
      text-align: center;
    }

    .hero-card {
      background: rgba(255, 255, 255, 0.12);
      border: 1px solid rgba(255, 255, 255, 0.2);
      border-radius: var(--radius);
      padding: 30px;
      box-shadow: var(--shadow);
      backdrop-filter: blur(16px);
    }

    .hero-card .big-number {
      font-size: 62px;
      line-height: 1;
      font-weight: 900;
      color: var(--gold);
      margin-bottom: 10px;
    }

    .hero-card h2 {
      font-size: 26px;
      margin-bottom: 16px;
      color: #f7f7f7;
    }

    .hero-card p {
      font-size: 18px;
      margin-bottom: 22px;
    }

    .mini-table {
      display: grid;
      gap: 10px;
      margin-top: 18px;
    }

    .mini-row {
      display: flex;
      justify-content: space-between;
      gap: 16px;
      background: rgba(255, 255, 255, 0.1);
      border-radius: 12px;
      padding: 12px 14px;
      font-weight: 700;
    }

    .hero section {
      padding: 82px 0;
    }

    .section-head {
      max-width: 760px;
      margin-bottom: 42px;
    }

    .section-head.center {
      text-align: center;
      margin: 0 auto 42px;
    }

     .section-kicker {
      color: var(--red);
      font-weight: 800;
      text-transform: uppercase;
      font-size: 13px;
      margin-bottom: 10px;
    }

    h2.section-title {
      font-size: clamp(32px, 4vw, 52px);
      line-height: 1.05;
      margin-bottom: 16px;
    }

    .section-text {
      color: var(--muted);
      font-size: 18px;
    }

    .steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
    }

    .step-card, .prize-card, .info-card, .faq-item {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 26px;
      box-shadow: 0 10px 28px rgba(0, 0, 0, 0.06);
    }

    .step-number {
      width: 42px;
      height: 42px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--red);
      color: var(--white);
      font-weight: 800;
      margin-bottom: 18px;
    }

    .step-card h3, .prize-card h3, .info-card h3 {
      font-size: 21px;
      margin-bottom: 10px;
      line-height: 1.25;
    }

    .step-card p, .prize-card p, .info-card p, .faq-item p {
      color: var(--muted);
    }

    .prizes {
      background: var(--grey);
    }

    .prize-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
      margin-bottom: 22px;
    }

    .prize-card {
      position: relative;
      overflow: hidden;
      min-height: 230px;
    }

    .prize-card::before {
      content: "";
      position: absolute;
      right: -45px;
      top: -45px;
      width: 120px;
      height: 120px;
      background: rgba(201, 0, 0, 0.08);
      border-radius: 50%;
    }

    .week-label {
      display: inline-block;
      background: #fff1f1;
      color: var(--red);
      border-radius: 999px;
      padding: 7px 12px;
      font-size: 13px;
      font-weight: 800;
      margin-bottom: 20px;
    }

    .prize-icon {
      font-size: 38px;
      margin-bottom: 12px;
    }

    .main-prize {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 24px;
      align-items: center;
      background: linear-gradient(135deg, var(--black), #2b0000);
      color: var(--white);
      border-radius: var(--radius);
      padding: 34px;
      box-shadow: var(--shadow);
    }

    .main-prize h3 {
      font-size: clamp(28px, 4vw, 46px);
      line-height: 1.05;
      margin: 8px 0 10px;
      color: var(--white);
    }

    .main-prize p {
      color: rgba(255, 255, 255, 0.8);
      font-size: 18px;
    }

    .main-prize-icon {
      font-size: 82px;
    }

    .calculation-grid {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 30px;
      align-items: start;
    }

    .highlight-box {
      background: var(--red);
      color: var(--white);
      border-radius: var(--radius);
      padding: 34px;
      box-shadow: var(--shadow);
    }

    .highlight-box h2 {
      font-size: 42px;
      line-height: 1.05;
      margin-bottom: 16px;
      color: var(--white);
    }

    .calc-table {
      width: 100%;
      border-collapse: collapse;
      overflow: hidden;
      border-radius: var(--radius);
      box-shadow: 0 10px 28px rgba(0, 0, 0, 0.06);
    }

    .calc-table th, .calc-table td {
      padding: 18px 20px;
      text-align: left;
      border-bottom: 1px solid var(--border);
      background: var(--white);
    }

    .calc-table th {
      background: var(--black);
      color: var(--white);
    }

    .calc-table tr:last-child td {
      border-bottom: 0;
    }

    .info-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 20px;
    }

    .cta-section {
      background: linear-gradient(135deg, var(--red), var(--dark-red));
      color: var(--white);
      text-align: center;
    }

    .cta-section h2 {
      font-size: clamp(34px, 5vw, 58px);
      line-height: 1.05;
      margin-bottom: 18px;
      color: var(--white);
    }

    .cta-section p {
      max-width: 720px;
      margin: 0 auto 28px;
      color: rgba(255, 255, 255, 0.86);
      font-size: 19px;
    }

    .faq {
      background: var(--grey);
    }

    .faq-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 18px;
    }

    .faq-item h3 {
      font-size: 19px;
      margin-bottom: 8px;
    }

    .legal {
      font-size: 14px;
      color: var(--muted);
      background: var(--white);
    }

    .legal-box {
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 26px;
      background: #fafafa;
    }

     .funktion {
      background: #fff !important;
    }










     @media (max-width: 980px) {
      .hero-grid,
      .calculation-grid {
        grid-template-columns: 1fr;
      }

      .steps,
      .prize-grid,
      .info-grid {
        grid-template-columns: repeat(2, 1fr);
      }

      .nav-links {
        display: none;
      }
    }

    @media (max-width: 640px) {
      .container {
        width: min(100% - 28px, 1180px);
      }

      .hero {
        padding: 70px 0 60px;
      }

      .hero-bullets,
      .steps,
      .prize-grid,
      .info-grid,
      .faq-grid {
        grid-template-columns: 1fr;
      }

      .main-prize {
        grid-template-columns: 1fr;
      }

      .main-prize-icon {
        font-size: 64px;
      }

      .btn {
        width: 100%;
      }

      .hero section {
        padding: 62px 0;
      }
    }