*, *::before, *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

    :root {
      --bg:        #0e1410;
      --bg-2:      #131a14;
      --bg-3:      #192019;
      --bg-card:   #111811;
      --green:     #1a3a1f;
      --green-mid: #2a4a2f;
      --creme:     #f2ede4;
      --creme-dim: rgba(242, 237, 228, 0.5);
      --gold:      #c9a84c;
      --gold-dim:  rgba(201, 168, 76, 0.12);
      --gold-border: rgba(201, 168, 76, 0.3);
      --red-accent: #8b2020;
      --display:   'Bebas Neue', Impact, sans-serif;
      --serif:     'Cormorant Garamond', Georgia, serif;
      --sans:      'DM Sans', sans-serif;
      --fx-accent: var(--gold);
      --fx-accent-rgb: 201, 168, 76;
      --fx-display: var(--display);
      --fx-bg-rgb: 14, 20, 16;
    }

    html {
      scroll-behavior: smooth;
      background: var(--bg);
    }

    body {
      font-family: var(--sans);
      background: var(--bg);
      color: var(--creme);
      overflow-x: hidden;
    }

    /* NOISE */
    body::before {
      content: '';
      position: fixed;
      inset: 0;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
      opacity: 0.03;
      pointer-events: none;
      z-index: 9999;
    }

    /* ── DEMO BANNER ── */
    .demo-banner {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 200;
      height: 38px;
      background: #0066ff;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 1.25rem;
    }

    .demo-banner-text {
      font-family: var(--sans);
      font-size: 0.68rem;
      font-weight: 500;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #ffffff;
    }

    .demo-banner-dot {
      width: 3px;
      height: 3px;
      border-radius: 50%;
      background: rgba(255,255,255,0.4);
    }

    .demo-banner-link {
      font-family: var(--sans);
      font-size: 0.68rem;
      font-weight: 400;
      letter-spacing: 0.08em;
      color: rgba(255,255,255,0.75);
      text-decoration: none;
      border-bottom: 1px solid rgba(255,255,255,0.3);
      padding-bottom: 1px;
      transition: color 0.2s, border-color 0.2s;
    }

    .demo-banner-link:hover {
      color: #ffffff;
      border-color: #ffffff;
    }

    /* ── NAV ── */
    nav {
      position: fixed;
      top: 38px;
      left: 0;
      right: 0;
      z-index: 100;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 1.25rem 2.5rem;
      background: rgba(14, 20, 16, 0.95);
      border-bottom: 1px solid rgba(201,168,76,0.15);
      backdrop-filter: blur(8px);
    }

    .nav-logo {
      display: flex;
      flex-direction: column;
      line-height: 1;
      text-decoration: none;
    }

    .nav-logo-main {
      font-family: var(--display);
      font-size: 1.5rem;
      letter-spacing: 0.12em;
      color: var(--creme);
    }

    .nav-logo-sub {
      font-family: var(--sans);
      font-size: 0.55rem;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      color: var(--gold);
      margin-top: 1px;
    }

    .nav-links {
      display: flex;
      gap: 2.5rem;
      list-style: none;
    }

    .nav-links a {
      font-size: 0.7rem;
      font-weight: 400;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--creme-dim);
      text-decoration: none;
      transition: color 0.3s;
    }

    .nav-links a:hover { color: var(--gold); }

    .nav-cta {
      font-size: 0.7rem;
      font-weight: 500;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--bg);
      background: var(--gold);
      padding: 0.6rem 1.5rem;
      text-decoration: none;
      transition: opacity 0.3s;
    }

    .nav-cta:hover { opacity: 0.85; }

    /* ── HERO ── */
    #hero {
      position: relative;
      min-height: 100svh;
      display: grid;
      grid-template-columns: 1fr 1fr;
      align-items: center;
      padding-top: 110px;
      overflow: hidden;
    }

    .hero-left {
      padding: 5rem 3rem 5rem 5vw;
      position: relative;
      z-index: 2;
    }

    .hero-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.75rem;
      margin-bottom: 2rem;
      opacity: 0;
      animation: fadeIn 0.8s 0.2s forwards;
    }

    .hero-badge-line {
      width: 28px;
      height: 1px;
      background: var(--gold);
    }

    .hero-badge span {
      font-size: 0.62rem;
      letter-spacing: 0.3em;
      text-transform: uppercase;
      color: var(--gold);
    }

    .hero-headline {
      font-family: var(--display);
      font-size: clamp(4rem, 9vw, 8rem);
      line-height: 0.92;
      letter-spacing: 0.03em;
      color: var(--creme);
      margin-bottom: 1.5rem;
      opacity: 0;
      animation: fadeIn 0.8s 0.4s forwards;
    }

    .hero-headline .gold { color: var(--gold); }

    .hero-sub {
      font-size: 0.88rem;
      font-weight: 300;
      line-height: 1.8;
      color: var(--creme-dim);
      max-width: 36ch;
      margin-bottom: 2.5rem;
      opacity: 0;
      animation: fadeIn 0.8s 0.6s forwards;
    }

    .hero-actions {
      display: flex;
      gap: 1rem;
      flex-wrap: wrap;
      opacity: 0;
      animation: fadeIn 0.8s 0.8s forwards;
    }

    .btn-primary {
      display: inline-block;
      font-size: 0.72rem;
      font-weight: 500;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--bg);
      background: var(--gold);
      padding: 1rem 2.2rem;
      text-decoration: none;
      transition: opacity 0.3s, transform 0.3s;
    }

    .btn-primary:hover {
      opacity: 0.88;
      transform: translateY(-1px);
    }

    .btn-ghost {
      display: inline-block;
      font-size: 0.72rem;
      font-weight: 400;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--creme-dim);
      border: 1px solid rgba(242,237,228,0.2);
      padding: 1rem 2rem;
      text-decoration: none;
      transition: border-color 0.3s, color 0.3s;
    }

    .btn-ghost:hover {
      border-color: var(--gold-border);
      color: var(--gold);
    }

    .hero-stats {
      display: flex;
      gap: 2.5rem;
      margin-top: 3.5rem;
      padding-top: 2rem;
      border-top: 1px solid rgba(201,168,76,0.15);
      opacity: 0;
      animation: fadeIn 0.8s 1s forwards;
    }

    .stat-num {
      font-family: var(--display);
      font-size: 2.2rem;
      color: var(--gold);
      letter-spacing: 0.05em;
      line-height: 1;
    }

    .stat-label {
      font-size: 0.65rem;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--creme-dim);
      margin-top: 0.25rem;
    }

    .hero-right {
      position: relative;
      height: 100%;
      min-height: 100svh;
      display: flex;
      align-items: stretch;
    }

    .hero-visual {
      flex: 1;
      position: relative;
      overflow: hidden;
      transform-style: preserve-3d;
      will-change: transform;
    }

    .hero-visual-img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: brightness(0.5) saturate(0.85);
    }

    .hero-visual-overlay {
      position: absolute;
      inset: 0;
      z-index: 1;
      background:
        linear-gradient(135deg, rgba(14,20,16,0.5) 0%, rgba(14,20,16,0.2) 50%, rgba(14,20,16,0.75) 100%),
        radial-gradient(ellipse 80% 60% at 60% 40%, rgba(201,168,76,0.12) 0%, transparent 70%);
    }

    .hero-visual-text {
      position: absolute;
      bottom: 3rem;
      left: 2rem;
      right: 2rem;
      z-index: 3;
    }

    .hero-visual-quote {
      font-family: var(--serif);
      font-size: 1.1rem;
      font-style: italic;
      color: rgba(242,237,228,0.4);
      line-height: 1.5;
      border-left: 2px solid var(--gold-border);
      padding-left: 1rem;
    }

    .hero-tag {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      font-family: var(--display);
      font-size: clamp(5rem, 12vw, 11rem);
      letter-spacing: 0.05em;
      color: rgba(201,168,76,0.06);
      white-space: nowrap;
      pointer-events: none;
      user-select: none;
    }

    /* ── STRIP ── */
    .strip {
      background: var(--gold);
      padding: 0.8rem 0;
      overflow: hidden;
      white-space: nowrap;
    }

    .strip-inner {
      display: inline-flex;
      gap: 3rem;
      animation: marquee 18s linear infinite;
    }

    .strip-item {
      font-family: var(--display);
      font-size: 0.9rem;
      letter-spacing: 0.2em;
      color: var(--bg);
    }

    @keyframes marquee {
      from { transform: translateX(0); }
      to   { transform: translateX(-50%); }
    }

    /* ── LEISTUNGEN ── */
    #leistungen {
      background: var(--bg-2);
      padding: 7rem 5vw;
    }

    .leistungen-inner {
      max-width: 1100px;
      margin: 0 auto;
    }

    .section-label {
      font-size: 0.62rem;
      letter-spacing: 0.35em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 0.75rem;
    }

    .section-title {
      font-family: var(--display);
      font-size: clamp(2.5rem, 5vw, 4.5rem);
      letter-spacing: 0.05em;
      color: var(--creme);
      line-height: 1;
      margin-bottom: 1rem;
    }

    .section-sub {
      font-size: 0.85rem;
      font-weight: 300;
      line-height: 1.8;
      color: var(--creme-dim);
      max-width: 44ch;
      margin-bottom: 4rem;
    }

    .leistungen-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 1px;
      background: var(--bg);
      perspective: 800px;
    }

    .leistung-card {
      background: var(--bg-card);
      padding: 0;
      position: relative;
      display: flex;
      flex-direction: column;
      overflow: hidden;
      transition: background 0.3s;
    }

    .leistung-card:hover { background: var(--bg-3); }

    .leistung-card-img {
      height: 160px;
      overflow: hidden;
    }

    .leistung-card-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.7s ease;
      filter: brightness(0.75) saturate(0.9);
    }

    .leistung-card:hover .leistung-card-img img {
      transform: scale(1.06);
      filter: brightness(0.85) saturate(1);
    }

    .leistung-card-body {
      padding: 2rem;
      display: flex;
      flex-direction: column;
      gap: 1rem;
      flex: 1;
    }

    .leistung-top {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
    }

    .leistung-icon {
      width: 44px;
      height: 44px;
      border: 1px solid var(--gold-border);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
    }

    .leistung-num {
      font-family: var(--display);
      font-size: 3.5rem;
      color: rgba(201,168,76,0.1);
      line-height: 1;
      letter-spacing: 0.05em;
    }

    .leistung-title {
      font-family: var(--display);
      font-size: 1.6rem;
      letter-spacing: 0.08em;
      color: var(--creme);
      line-height: 1;
    }

    .leistung-desc {
      font-size: 0.82rem;
      font-weight: 300;
      line-height: 1.7;
      color: var(--creme-dim);
      flex: 1;
    }

    .leistung-footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding-top: 1rem;
      border-top: 1px solid rgba(201,168,76,0.12);
    }

    .leistung-price {
      font-family: var(--display);
      font-size: 1.3rem;
      letter-spacing: 0.08em;
      color: var(--gold);
    }

    .leistung-time {
      font-size: 0.68rem;
      letter-spacing: 0.1em;
      color: var(--creme-dim);
      text-transform: uppercase;
    }

    /* ── ÜBER UNS ── */
    #ueber {
      padding: 7rem 5vw;
      background: var(--bg);
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 5rem;
      align-items: center;
      max-width: 1200px;
      margin: 0 auto;
    }

    .ueber-img {
      position: relative;
      aspect-ratio: 3/4;
      overflow: hidden;
      transform-style: preserve-3d;
      will-change: transform;
    }

    .ueber-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: brightness(0.7) saturate(0.9);
    }

    .ueber-img-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to right, transparent 40%, rgba(14,20,16,0.85) 100%);
      pointer-events: none;
    }

    .ueber-img::after {
      content: '';
      position: absolute;
      inset: 12px;
      border: 1px solid var(--gold-border);
      pointer-events: none;
      z-index: 2;
    }

    .ueber-visual-label {
      position: absolute;
      bottom: 2rem;
      left: 2rem;
      right: 2rem;
      text-align: center;
      z-index: 3;
    }

    .ueber-visual-label span {
      font-family: var(--display);
      font-size: 0.9rem;
      letter-spacing: 0.3em;
      color: var(--gold);
      opacity: 0.9;
    }

    .ueber-content .section-title {
      margin-bottom: 1.5rem;
    }

    .ueber-text {
      font-size: 0.88rem;
      font-weight: 300;
      line-height: 1.9;
      color: var(--creme-dim);
      margin-bottom: 1.5rem;
    }

    .ueber-values {
      display: flex;
      flex-direction: column;
      gap: 0;
      margin-top: 2rem;
    }

    .ueber-value {
      display: flex;
      align-items: center;
      gap: 1rem;
      padding: 0.9rem 0;
      border-bottom: 1px solid rgba(201,168,76,0.1);
    }

    .ueber-value-dot {
      width: 6px;
      height: 6px;
      background: var(--gold);
      flex-shrink: 0;
      transform: rotate(45deg);
    }

    .ueber-value span {
      font-size: 0.82rem;
      letter-spacing: 0.08em;
      color: var(--creme);
    }

    /* ── KONTAKT ── */
    #kontakt {
      background: var(--bg-2);
      padding: 7rem 5vw;
      position: relative;
      overflow: hidden;
    }

    #kontakt::before {
      content: 'BB';
      position: absolute;
      right: -2rem;
      top: 50%;
      transform: translateY(-50%);
      font-family: var(--display);
      font-size: 20rem;
      color: rgba(201,168,76,0.03);
      letter-spacing: -0.05em;
      pointer-events: none;
      user-select: none;
    }

    .kontakt-inner {
      max-width: 1200px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 0.85fr 1.15fr 0.75fr;
      gap: 3rem;
      align-items: stretch;
    }

    .kontakt-img {
      position: relative;
      overflow: hidden;
      min-height: 420px;
      transform-style: preserve-3d;
      will-change: transform;
    }

    .kontakt-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: brightness(0.65);
    }

    .kontakt-img-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to right, rgba(14,20,16,0.2), rgba(14,20,16,0.55));
    }

    #kontakt { perspective: 800px; }

    .kontakt-headline {
      font-family: var(--display);
      font-size: clamp(3rem, 6vw, 5.5rem);
      letter-spacing: 0.04em;
      line-height: 0.95;
      color: var(--creme);
      margin-bottom: 2rem;
    }

    .kontakt-headline .gold { color: var(--gold); }

    .kontakt-cta-group {
      display: flex;
      gap: 1rem;
      flex-wrap: wrap;
      margin-bottom: 3rem;
    }

    .kontakt-info-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1.5rem;
    }

    .kontakt-info-item {}

    .kontakt-info-label {
      font-size: 0.6rem;
      letter-spacing: 0.25em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 0.3rem;
    }

    .kontakt-info-value {
      font-size: 0.88rem;
      font-weight: 300;
      color: var(--creme);
      line-height: 1.6;
    }

    .oeffnungszeiten {
      border-top: 1px solid var(--gold-border);
    }

    .oz-label {
      font-size: 0.6rem;
      letter-spacing: 0.25em;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 0.75rem;
    }

    .oz-row {
      display: flex;
      justify-content: space-between;
      padding: 0.85rem 0;
      border-bottom: 1px solid rgba(201,168,76,0.08);
    }

    .oz-row span:first-child {
      font-size: 0.8rem;
      font-weight: 300;
      color: var(--creme-dim);
    }

    .oz-row span:last-child {
      font-family: var(--display);
      font-size: 0.9rem;
      letter-spacing: 0.08em;
      color: var(--creme);
    }

    /* ── FOOTER ── */
    footer {
      background: var(--bg);
      border-top: 1px solid rgba(201,168,76,0.15);
      padding: 2rem 5vw;
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      gap: 1rem;
    }

    .footer-logo {
      font-family: var(--display);
      font-size: 1.1rem;
      letter-spacing: 0.15em;
      color: var(--creme);
    }

    .footer-logo span { color: var(--gold); }

    .footer-copy {
      font-size: 0.65rem;
      letter-spacing: 0.08em;
      color: var(--creme-dim);
    }

    .footer-links {
      display: flex;
      gap: 2rem;
    }

    .footer-links a {
      font-size: 0.65rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--creme-dim);
      text-decoration: none;
      transition: color 0.3s;
    }

    .footer-links a:hover { color: var(--gold); }

    /* ── ANIMATIONS ── */
    @keyframes fadeIn {
      from { opacity: 0; transform: translateY(16px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* ── RESPONSIVE ── */
    @media (max-width: 900px) {
      #hero {
        grid-template-columns: 1fr;
        min-height: auto;
      }

      .hero-left {
        padding: 7rem 1.5rem 3rem;
      }

      .hero-right { display: none; }

      #ueber {
        grid-template-columns: 1fr;
        gap: 3rem;
        padding: 5rem 1.5rem;
      }

      .ueber-img { aspect-ratio: 4/3; }

      .kontakt-inner {
        grid-template-columns: 1fr;
        gap: 3rem;
      }

      .kontakt-img { min-height: 50vw; order: -1; }

      .kontakt-info-grid {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 768px) {
      nav { padding: 1rem 1.5rem; }
      .nav-links, .nav-cta { display: none; }

      #leistungen { padding: 5rem 1.5rem; }
      #kontakt { padding: 5rem 1.5rem; }

      .leistungen-grid { grid-template-columns: 1fr; }

      footer {
        flex-direction: column;
        text-align: center;
      }
    }

    /* ── Site effects integration ── */
    #hero { position: relative; overflow: hidden; }
    .hero-right { position: relative; overflow: hidden; }
    #ueber { perspective: 800px; }

    nav.scrolled {
      background: rgba(14, 20, 16, 0.98) !important;
      border-bottom-color: rgba(201, 168, 76, 0.25) !important;
    }

    .btn-primary:hover { transform: none; opacity: 0.88; }
    .nav-cta { position: relative; overflow: hidden; }

    .kontakt-headline {
      font-family: var(--display);
      font-size: clamp(2.5rem, 5vw, 4.5rem);
      letter-spacing: 0.05em;
      color: var(--creme);
      line-height: 1;
      margin-bottom: 2rem;
    }

    .hero-visual .hero-visual-text { z-index: 4; }
