/* === Startseite === */
:root {
      --soil: #541923;
      --soil-soft: #6b2630;
      --corn: #f7b928;
      --corn-dark: #c98212;
      --leaf: #008f45;
      --leaf-dark: #006b35;
      --leaf-soft: #7f9f3b;
      --sky: #fff2bf;
      --cream: #fff8e3;
      --paper: rgba(255, 248, 227, .94);
      --text: #2b2117;
      --muted: #6d5941;
      --shadow: 0 24px 70px rgba(84, 25, 35, .16);
      --radius: 28px;
    }

    * { box-sizing: border-box; }

    html { scroll-behavior: smooth; }

    body {
      margin: 0;
      font-family: ui-rounded, "Avenir Next", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
      color: var(--text);
      background:
        radial-gradient(circle at 10% 5%, rgba(247, 185, 40, .42), transparent 30%),
        radial-gradient(circle at 92% 2%, rgba(0, 143, 69, .18), transparent 28%),
        linear-gradient(180deg, #fff3bf 0%, #f9df8f 38%, #fff8e3 100%);
      line-height: 1.6;
    }

    a { color: inherit; }

    .site-header {
      position: sticky;
      top: 0;
      z-index: 20;
      backdrop-filter: blur(18px);
      background: rgba(255, 248, 227, .86);
      border-bottom: 1px solid rgba(84, 25, 35, .11);
    }

    .nav {
      max-width: 1180px;
      margin: 0 auto;
      padding: 16px 22px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      text-decoration: none;
      font-weight: 900;
      letter-spacing: -.03em;
      font-size: 1.15rem;
    }

    .brand-logo {
      width: 46px;
      height: 46px;
      object-fit: contain;
      filter: drop-shadow(0 8px 18px rgba(63, 41, 23, .14));
    }

    .nav-links {
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      gap: 8px;
      font-size: .95rem;
    }

    .nav-links a {
      text-decoration: none;
      padding: 9px 13px;
      border-radius: 999px;
      color: var(--soil-soft);
      font-weight: 700;
    }

    .nav-links a:hover,
    .nav-links a:focus-visible {
      background: rgba(247, 185, 40, .32);
      outline: none;
    }

    main { overflow: hidden; }

    .hero {
      position: relative;
      max-width: 1180px;
      margin: 0 auto;
      padding: 78px 22px 54px;
      display: grid;
      grid-template-columns: minmax(0, 1.04fr) minmax(300px, .96fr);
      align-items: center;
      gap: 46px;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      margin: 0 0 18px;
      padding: 10px 30px;
      border-radius: 999px;
      background: rgba(255, 248, 227, .82);
      color: var(--leaf-dark);
      font-weight: 900;
      font-size: .82rem;
      line-height: 1.55;
      letter-spacing: .08em;
      text-transform: uppercase;
      box-shadow: 0 8px 30px rgba(84, 25, 35, .08);
    }

    h1, h2, h3 { line-height: 1.08; }

    h1 {
      margin: 0;
      max-width: 780px;
      font-size: clamp(3rem, 8vw, 6.7rem);
      letter-spacing: -.075em;
      color: var(--soil);
    }

    .hero p {
      max-width: 660px;
      margin: 24px 0 0;
      font-size: clamp(1.1rem, 2.1vw, 1.35rem);
      color: var(--muted);
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      margin-top: 34px;
    }

    .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      padding: 13px 20px;
      border-radius: 999px;
      text-decoration: none;
      font-weight: 900;
      border: 2px solid transparent;
    }

    .button.primary {
      background: linear-gradient(135deg, var(--leaf), var(--leaf-dark));
      color: #fffdf5;
      box-shadow: 0 18px 38px rgba(36, 89, 45, .26);
    }

    .button.secondary {
      background: rgba(247, 185, 40, .22);
      border-color: rgba(84, 25, 35, .18);
      color: var(--soil);
    }

    .hero-card {
      position: relative;
      min-height: 520px;
      border-radius: 44px;
      padding: 28px;
      background: #6d5941;
      box-shadow: var(--shadow);
      overflow: hidden;
      isolation: isolate;
    }

    .hero-bg {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
      z-index: -1;
    }

    .hero-card::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 62% 20%, rgba(246, 200, 76, .26), transparent 36%),
        linear-gradient(180deg, rgba(255,249,234,.06), rgba(75,23,32,.38));
      z-index: 0;
    }

    .hero-logo {
      position: absolute;
      right: 34px;
      top: 24px;
      width: min(32%, 195px);
      max-height: 145px;
      object-fit: contain;
      z-index: 2;
      filter: drop-shadow(0 16px 24px rgba(0,0,0,.34));
    }

    .maze {
      position: absolute;
      inset: 26px;
      border-radius: 32px;
      background:
        linear-gradient(90deg, transparent 0 16%, rgba(63,41,23,.19) 16% 19%, transparent 19% 44%, rgba(84,25,35,.19) 44% 47%, transparent 47% 100%),
        linear-gradient(0deg, transparent 0 12%, rgba(84,25,35,.19) 12% 15%, transparent 15% 38%, rgba(84,25,35,.18) 38% 41%, transparent 41% 70%, rgba(84,25,35,.19) 70% 73%, transparent 73% 100%),
        repeating-linear-gradient(45deg, rgba(255,249,234,.12) 0 9px, transparent 9px 22px);
      border: 2px solid rgba(247,185,40,.55);
      opacity: .92;
    }

    .sun {
      position: absolute;
      right: 38px;
      top: 40px;
      width: 98px;
      height: 98px;
      border-radius: 50%;
      background: #fff3a5;
      box-shadow: 0 0 0 18px rgba(255, 243, 165, .22), 0 0 60px rgba(255, 243, 165, .9);
    }

    .sign {
      position: absolute;
      left: 34px;
      bottom: 36px;
      right: 34px;
      z-index: 2;
      border-radius: 28px;
      padding: 24px;
      background: rgba(255, 248, 227, .94);
      box-shadow: 0 18px 45px rgba(84, 25, 35, .18);
    }

    .sign strong {
      display: block;
      font-size: 1.35rem;
      letter-spacing: -.03em;
      color: var(--soil);
    }

    .sign span {
      display: block;
      margin-top: 7px;
      color: var(--muted);
    }

    section {
      max-width: 1180px;
      margin: 0 auto;
      padding: 62px 22px;
    }

    .section-head {
      max-width: 720px;
      margin-bottom: 28px;
    }

    .section-kicker {
      margin: 0 0 10px;
      color: var(--corn-dark);
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .12em;
      font-size: .8rem;
    }

    h2 {
      margin: 0;
      font-size: clamp(2rem, 4.3vw, 4rem);
      letter-spacing: -.055em;
      color: var(--soil);
    }

    .section-head p {
      margin: 16px 0 0;
      color: var(--muted);
      font-size: 1.08rem;
    }

    .grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
    }

    .card {
      border-radius: var(--radius);
      padding: 26px;
      background: var(--paper);
      box-shadow: 0 18px 50px rgba(84, 25, 35, .10);
      border: 1px solid rgba(84, 25, 35, .10);
    }

    .card .icon {
      width: 48px;
      height: 48px;
      display: grid;
      place-items: center;
      margin-bottom: 18px;
      border-radius: 18px;
      background: linear-gradient(135deg, rgba(247,185,40,.52), rgba(0,143,69,.14));
      font-size: 1.35rem;
    }

    .card h3 {
      margin: 0 0 10px;
      font-size: 1.28rem;
      color: var(--soil);
    }

    .card p {
      margin: 0;
      color: var(--muted);
    }

    .info-band {
      max-width: 1180px;
      margin: 24px auto 0;
      padding: 0 22px 62px;
    }

    .band-inner {
      border-radius: 38px;
      padding: clamp(28px, 5vw, 50px);
      color: #fffdf5;
      background:
        radial-gradient(circle at 8% 18%, rgba(247,185,40,.38), transparent 30%),
        linear-gradient(135deg, var(--soil), var(--leaf-dark));
      box-shadow: var(--shadow);
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 30px;
      align-items: center;
    }

    .band-inner h2 { color: #fffdf5; }
    .band-inner p { color: rgba(255, 253, 245, .82); }

    .facts {
      display: grid;
      gap: 12px;
    }

    .fact {
      display: flex;
      justify-content: space-between;
      gap: 18px;
      padding: 14px 0;
      border-bottom: 1px solid rgba(255, 253, 245, .18);
    }

    .fact strong { font-size: 1.08rem; }
    .fact span { color: rgba(255, 253, 245, .78); text-align: right; }

    .map-link {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      color: #fffdf5;
      font-weight: 800;
      text-decoration: underline;
      text-decoration-thickness: 2px;
      text-underline-offset: 4px;
    }

    .map-link::after {
      content: "↗";
      font-size: .9em;
    }

    .fact .map-link {
      padding: 4px 8px;
      border-radius: 999px;
      background: rgba(255, 253, 245, .14);
    }




    .fact a, .visit-card p a {
      color: var(--corn);
      font-weight: 900;
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    .visit-card p a {
      color: var(--soil);
      background: rgba(247,185,40,.42);
      padding: 2px 6px;
      border-radius: 8px;
    }


    .yoga-section {
      padding-top: 40px;
    }

    .yoga-card {
      display: grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 24px;
      align-items: stretch;
      background: linear-gradient(135deg, rgba(255, 248, 227, .96), rgba(255, 242, 191, .95));
      border: 1px solid rgba(84, 25, 35, .12);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 30px;
      overflow: hidden;
      position: relative;
    }

    .yoga-card::after {
      content: "";
      position: absolute;
      right: -90px;
      top: -90px;
      width: 220px;
      height: 220px;
      border-radius: 999px;
      background: rgba(0, 143, 69, .12);
      pointer-events: none;
    }

    .yoga-card h2 {
      margin: 0 0 14px;
      color: var(--soil);
      font-size: clamp(2rem, 4vw, 3.4rem);
      line-height: 1.02;
      letter-spacing: -.04em;
    }

    .yoga-card p { margin: 0 0 16px; color: var(--muted); }

    .date-list {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
      margin: 22px 0 0;
    }

    .date-list span {
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      border-radius: 16px;
      background: #fff;
      color: var(--soil);
      font-weight: 900;
      border: 1px solid rgba(84, 25, 35, .1);
      box-shadow: 0 12px 28px rgba(84, 25, 35, .08);
    }

    .yoga-facts {
      display: grid;
      gap: 12px;
      position: relative;
      z-index: 1;
    }

    .yoga-fact {
      background: rgba(255, 255, 255, .86);
      border: 1px solid rgba(84, 25, 35, .1);
      border-radius: 20px;
      padding: 14px 16px;
    }

    .yoga-fact strong {
      display: block;
      color: var(--leaf-dark);
      font-size: .78rem;
      text-transform: uppercase;
      letter-spacing: .08em;
      margin-bottom: 4px;
    }

    .yoga-fact span, .yoga-fact a { color: var(--text); }

    .yoga-fact a {
      font-weight: 900;
      text-decoration-color: rgba(0, 143, 69, .45);
      text-underline-offset: 3px;
    }


    .price-card {
      display: grid;
      grid-template-columns: 1.05fr .95fr;
      gap: 18px;
    }

    .price-list {
      margin: 0;
      padding: 0;
      list-style: none;
      display: grid;
      gap: 12px;
    }

    .price-list li {
      display: flex;
      justify-content: space-between;
      gap: 14px;
      border-bottom: 1px dashed rgba(63, 41, 23, .18);
      padding-bottom: 12px;
      color: var(--muted);
    }

    .price-list strong { color: var(--soil); }

    .contact-box {
      border-radius: 34px;
      padding: clamp(28px, 5vw, 48px);
      background: linear-gradient(135deg, rgba(247,185,40,.62), rgba(255,248,227,.96));
      border: 1px solid rgba(84, 25, 35, .10);
      box-shadow: var(--shadow);
    }

    .contact-box p { color: var(--muted); }



    .nav-links .nav-instagram {
      background: linear-gradient(135deg, rgba(247,185,40,.50), rgba(0,143,69,.20));
      color: var(--soil);
      border: 1px solid rgba(63, 41, 23, .1);
    }

    .visit-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 18px;
      margin-top: 22px;
    }

    .visit-card {
      border-radius: 30px;
      padding: 28px;
      background: rgba(255, 249, 234, .93);
      border: 1px solid rgba(84, 25, 35, .10);
      box-shadow: 0 18px 50px rgba(84, 25, 35, .10);
    }

    .visit-card.instagram-card {
      background:
        radial-gradient(circle at 92% 10%, rgba(247,185,40,.58), transparent 30%),
        linear-gradient(135deg, rgba(255,248,227,.98), rgba(255,239,184,.95));
    }

    .visit-card.route-card {
      background:
        radial-gradient(circle at 90% 10%, rgba(0,143,69,.25), transparent 33%),
        linear-gradient(135deg, rgba(255,248,227,.98), rgba(255,239,184,.95));
    }

    .visit-card .mini-kicker {
      display: inline-flex;
      margin-bottom: 10px;
      color: var(--leaf-dark);
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .11em;
      font-size: .76rem;
    }

    .visit-card h3 {
      margin: 0 0 10px;
      color: var(--soil);
      font-size: clamp(1.55rem, 3vw, 2.25rem);
      letter-spacing: -.045em;
      line-height: 1.08;
    }

    .visit-card p {
      margin: 0 0 20px;
      color: var(--muted);
    }

    .visit-card .button {
      width: fit-content;
    }

    .map-preview {
      position: relative;
      display: block;
      overflow: hidden;
      margin: 18px 0 20px;
      min-height: 260px;
      border-radius: 24px;
      border: 1px solid rgba(63, 41, 23, .14);
      box-shadow: 0 16px 38px rgba(63, 41, 23, .12);
      background:
        radial-gradient(circle at 68% 42%, rgba(247,185,40,.42), transparent 0 8%, transparent 9%),
        linear-gradient(135deg, rgba(0,143,69,.16), rgba(247,185,40,.22)),
        #fff8e3;
      text-decoration: none;
      color: var(--soil);
    }

    .map-grid {
      position: absolute;
      inset: 0;
      opacity: .45;
      background:
        linear-gradient(90deg, rgba(84,25,35,.1) 1px, transparent 1px),
        linear-gradient(0deg, rgba(84,25,35,.1) 1px, transparent 1px);
      background-size: 46px 46px;
      transform: rotate(-3deg) scale(1.08);
    }

    .map-road {
      position: absolute;
      left: -10%;
      right: -10%;
      height: 34px;
      border-radius: 999px;
      background: rgba(255,253,242,.88);
      box-shadow: inset 0 0 0 2px rgba(84,25,35,.08);
    }

    .road-a { top: 48%; transform: rotate(-10deg); }
    .road-b { top: 35%; transform: rotate(36deg); width: 75%; left: 18%; }

    .map-pin {
      position: absolute;
      left: 50%;
      top: 42%;
      width: 58px;
      height: 58px;
      transform: translate(-50%, -50%);
      display: grid;
      place-items: center;
      border-radius: 50%;
      background: var(--corn);
      color: var(--soil);
      font-size: 2rem;
      font-weight: 900;
      border: 4px solid rgba(255,248,227,.95);
      box-shadow: 0 16px 30px rgba(84,25,35,.24);
      z-index: 2;
    }

    .map-label {
      position: absolute;
      left: 22px;
      right: 22px;
      bottom: 18px;
      z-index: 3;
      padding: 16px 18px;
      border-radius: 20px;
      background: rgba(255,248,227,.92);
      font-weight: 900;
      box-shadow: 0 12px 28px rgba(84,25,35,.12);
    }

    .map-label small {
      display: block;
      margin-top: 3px;
      font-size: .86rem;
      color: var(--muted);
      font-weight: 800;
    }

    .footer {
      margin-top: 34px;
      background: linear-gradient(135deg, var(--soil), #3a1118);
      color: rgba(255, 253, 245, .76);
    }

    .footer-inner {
      max-width: 1180px;
      margin: 0 auto;
      padding: 28px 22px;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      gap: 14px;
      font-size: .95rem;
    }

    .footer a {
      color: #fff4ce;
      text-decoration: none;
      font-weight: 700;
    }

    .footer a:hover { text-decoration: underline; }

    @media (max-width: 900px) {
      .nav { align-items: flex-start; flex-direction: column; }
      .nav-links { justify-content: flex-start; }
      .hero, .band-inner, .price-card, .visit-grid, .yoga-card { grid-template-columns: 1fr; }
      .hero { padding-top: 50px; }
      .hero-card { min-height: 390px; }
      .hero-logo { right: 24px; top: 20px; width: min(30%, 150px); max-height: 118px; }
      .grid { grid-template-columns: 1fr; }
      .date-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    }

/* === Legal-Seiten === */
:root {
      --soil: #541923;
      --soil-soft: #6b2630;
      --corn: #f7b928;
      --corn-dark: #c98212;
      --leaf: #008f45;
      --leaf-dark: #006b35;
      --leaf-soft: #7f9f3b;
      --sky: #fff2bf;
      --cream: #fff8e3;
      --paper: rgba(255, 248, 227, .94);
      --text: #2b2117;
      --muted: #6d5941;
      --shadow: 0 24px 70px rgba(84, 25, 35, .16);
      --radius: 28px;
    }

    * { box-sizing: border-box; }

    html { scroll-behavior: smooth; }

    body {
      margin: 0;
      font-family: ui-rounded, "Avenir Next", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
      color: var(--text);
      background:
        radial-gradient(circle at 10% 5%, rgba(247, 185, 40, .42), transparent 30%),
        radial-gradient(circle at 92% 2%, rgba(0, 143, 69, .18), transparent 28%),
        linear-gradient(180deg, #fff3bf 0%, #f9df8f 38%, #fff8e3 100%);
      line-height: 1.6;
    }

    a { color: inherit; }

    .site-header {
      position: sticky;
      top: 0;
      z-index: 20;
      backdrop-filter: blur(18px);
      background: rgba(255, 248, 227, .86);
      border-bottom: 1px solid rgba(84, 25, 35, .11);
    }

    .nav {
      max-width: 1180px;
      margin: 0 auto;
      padding: 16px 22px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      text-decoration: none;
      font-weight: 900;
      letter-spacing: -.03em;
      font-size: 1.15rem;
    }

    .brand-logo {
      width: 46px;
      height: 46px;
      object-fit: contain;
      filter: drop-shadow(0 8px 18px rgba(63, 41, 23, .14));
    }

    .nav-links {
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      gap: 8px;
      font-size: .95rem;
    }

    .nav-links a {
      text-decoration: none;
      padding: 9px 13px;
      border-radius: 999px;
      color: var(--soil-soft);
      font-weight: 700;
    }

    .nav-links a:hover,
    .nav-links a:focus-visible {
      background: rgba(247, 185, 40, .32);
      outline: none;
    }

    main { overflow: hidden; }

    .hero {
      position: relative;
      max-width: 1180px;
      margin: 0 auto;
      padding: 78px 22px 54px;
      display: grid;
      grid-template-columns: minmax(0, 1.04fr) minmax(300px, .96fr);
      align-items: center;
      gap: 46px;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      margin: 0 0 18px;
      padding: 10px 30px;
      border-radius: 999px;
      background: rgba(255, 248, 227, .82);
      color: var(--leaf-dark);
      font-weight: 900;
      font-size: .82rem;
      line-height: 1.55;
      letter-spacing: .08em;
      text-transform: uppercase;
      box-shadow: 0 8px 30px rgba(84, 25, 35, .08);
    }

    h1, h2, h3 { line-height: 1.08; }

    h1 {
      margin: 0;
      max-width: 780px;
      font-size: clamp(3rem, 8vw, 6.7rem);
      letter-spacing: -.075em;
      color: var(--soil);
    }

    .hero p {
      max-width: 660px;
      margin: 24px 0 0;
      font-size: clamp(1.1rem, 2.1vw, 1.35rem);
      color: var(--muted);
    }

    .hero-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      margin-top: 34px;
    }

    .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      padding: 13px 20px;
      border-radius: 999px;
      text-decoration: none;
      font-weight: 900;
      border: 2px solid transparent;
    }

    .button.primary {
      background: linear-gradient(135deg, var(--leaf), var(--leaf-dark));
      color: #fffdf5;
      box-shadow: 0 18px 38px rgba(36, 89, 45, .26);
    }

    .button.secondary {
      background: rgba(247, 185, 40, .22);
      border-color: rgba(84, 25, 35, .18);
      color: var(--soil);
    }

    .hero-card {
      position: relative;
      min-height: 520px;
      border-radius: 44px;
      padding: 28px;
      background: #6d5941;
      box-shadow: var(--shadow);
      overflow: hidden;
      isolation: isolate;
    }

    .hero-bg {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
      z-index: -1;
    }

    .hero-card::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 62% 20%, rgba(246, 200, 76, .26), transparent 36%),
        linear-gradient(180deg, rgba(255,249,234,.06), rgba(75,23,32,.38));
      z-index: 0;
    }

    .hero-logo {
      position: absolute;
      right: 34px;
      top: 24px;
      width: min(32%, 195px);
      max-height: 145px;
      object-fit: contain;
      z-index: 2;
      filter: drop-shadow(0 16px 24px rgba(0,0,0,.34));
    }

    .maze {
      position: absolute;
      inset: 26px;
      border-radius: 32px;
      background:
        linear-gradient(90deg, transparent 0 16%, rgba(63,41,23,.19) 16% 19%, transparent 19% 44%, rgba(84,25,35,.19) 44% 47%, transparent 47% 100%),
        linear-gradient(0deg, transparent 0 12%, rgba(84,25,35,.19) 12% 15%, transparent 15% 38%, rgba(84,25,35,.18) 38% 41%, transparent 41% 70%, rgba(84,25,35,.19) 70% 73%, transparent 73% 100%),
        repeating-linear-gradient(45deg, rgba(255,249,234,.12) 0 9px, transparent 9px 22px);
      border: 2px solid rgba(247,185,40,.55);
      opacity: .92;
    }

    .sun {
      position: absolute;
      right: 38px;
      top: 40px;
      width: 98px;
      height: 98px;
      border-radius: 50%;
      background: #fff3a5;
      box-shadow: 0 0 0 18px rgba(255, 243, 165, .22), 0 0 60px rgba(255, 243, 165, .9);
    }

    .sign {
      position: absolute;
      left: 34px;
      bottom: 36px;
      right: 34px;
      z-index: 2;
      border-radius: 28px;
      padding: 24px;
      background: rgba(255, 248, 227, .94);
      box-shadow: 0 18px 45px rgba(84, 25, 35, .18);
    }

    .sign strong {
      display: block;
      font-size: 1.35rem;
      letter-spacing: -.03em;
      color: var(--soil);
    }

    .sign span {
      display: block;
      margin-top: 7px;
      color: var(--muted);
    }

    section {
      max-width: 1180px;
      margin: 0 auto;
      padding: 62px 22px;
    }

    .section-head {
      max-width: 720px;
      margin-bottom: 28px;
    }

    .section-kicker {
      margin: 0 0 10px;
      color: var(--corn-dark);
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .12em;
      font-size: .8rem;
    }

    h2 {
      margin: 0;
      font-size: clamp(2rem, 4.3vw, 4rem);
      letter-spacing: -.055em;
      color: var(--soil);
    }

    .section-head p {
      margin: 16px 0 0;
      color: var(--muted);
      font-size: 1.08rem;
    }

    .grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
    }

    .card {
      border-radius: var(--radius);
      padding: 26px;
      background: var(--paper);
      box-shadow: 0 18px 50px rgba(84, 25, 35, .10);
      border: 1px solid rgba(84, 25, 35, .10);
    }

    .card .icon {
      width: 48px;
      height: 48px;
      display: grid;
      place-items: center;
      margin-bottom: 18px;
      border-radius: 18px;
      background: linear-gradient(135deg, rgba(247,185,40,.52), rgba(0,143,69,.14));
      font-size: 1.35rem;
    }

    .card h3 {
      margin: 0 0 10px;
      font-size: 1.28rem;
      color: var(--soil);
    }

    .card p {
      margin: 0;
      color: var(--muted);
    }

    .info-band {
      max-width: 1180px;
      margin: 24px auto 0;
      padding: 0 22px 62px;
    }

    .band-inner {
      border-radius: 38px;
      padding: clamp(28px, 5vw, 50px);
      color: #fffdf5;
      background:
        radial-gradient(circle at 8% 18%, rgba(247,185,40,.38), transparent 30%),
        linear-gradient(135deg, var(--soil), var(--leaf-dark));
      box-shadow: var(--shadow);
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 30px;
      align-items: center;
    }

    .band-inner h2 { color: #fffdf5; }
    .band-inner p { color: rgba(255, 253, 245, .82); }

    .facts {
      display: grid;
      gap: 12px;
    }

    .fact {
      display: flex;
      justify-content: space-between;
      gap: 18px;
      padding: 14px 0;
      border-bottom: 1px solid rgba(255, 253, 245, .18);
    }

    .fact strong { font-size: 1.08rem; }
    .fact span { color: rgba(255, 253, 245, .78); text-align: right; }

    .map-link {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      color: #fffdf5;
      font-weight: 800;
      text-decoration: underline;
      text-decoration-thickness: 2px;
      text-underline-offset: 4px;
    }

    .map-link::after {
      content: "↗";
      font-size: .9em;
    }

    .fact .map-link {
      padding: 4px 8px;
      border-radius: 999px;
      background: rgba(255, 253, 245, .14);
    }




    .fact a, .visit-card p a {
      color: var(--corn);
      font-weight: 900;
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    .visit-card p a {
      color: var(--soil);
      background: rgba(247,185,40,.42);
      padding: 2px 6px;
      border-radius: 8px;
    }


    .yoga-section {
      padding-top: 40px;
    }

    .yoga-card {
      display: grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 24px;
      align-items: stretch;
      background: linear-gradient(135deg, rgba(255, 248, 227, .96), rgba(255, 242, 191, .95));
      border: 1px solid rgba(84, 25, 35, .12);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 30px;
      overflow: hidden;
      position: relative;
    }

    .yoga-card::after {
      content: "";
      position: absolute;
      right: -90px;
      top: -90px;
      width: 220px;
      height: 220px;
      border-radius: 999px;
      background: rgba(0, 143, 69, .12);
      pointer-events: none;
    }

    .yoga-card h2 {
      margin: 0 0 14px;
      color: var(--soil);
      font-size: clamp(2rem, 4vw, 3.4rem);
      line-height: 1.02;
      letter-spacing: -.04em;
    }

    .yoga-card p { margin: 0 0 16px; color: var(--muted); }

    .date-list {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
      margin: 22px 0 0;
    }

    .date-list span {
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      border-radius: 16px;
      background: #fff;
      color: var(--soil);
      font-weight: 900;
      border: 1px solid rgba(84, 25, 35, .1);
      box-shadow: 0 12px 28px rgba(84, 25, 35, .08);
    }

    .yoga-facts {
      display: grid;
      gap: 12px;
      position: relative;
      z-index: 1;
    }

    .yoga-fact {
      background: rgba(255, 255, 255, .86);
      border: 1px solid rgba(84, 25, 35, .1);
      border-radius: 20px;
      padding: 14px 16px;
    }

    .yoga-fact strong {
      display: block;
      color: var(--leaf-dark);
      font-size: .78rem;
      text-transform: uppercase;
      letter-spacing: .08em;
      margin-bottom: 4px;
    }

    .yoga-fact span, .yoga-fact a { color: var(--text); }

    .yoga-fact a {
      font-weight: 900;
      text-decoration-color: rgba(0, 143, 69, .45);
      text-underline-offset: 3px;
    }


    .price-card {
      display: grid;
      grid-template-columns: 1.05fr .95fr;
      gap: 18px;
    }

    .price-list {
      margin: 0;
      padding: 0;
      list-style: none;
      display: grid;
      gap: 12px;
    }

    .price-list li {
      display: flex;
      justify-content: space-between;
      gap: 14px;
      border-bottom: 1px dashed rgba(63, 41, 23, .18);
      padding-bottom: 12px;
      color: var(--muted);
    }

    .price-list strong { color: var(--soil); }

    .contact-box {
      border-radius: 34px;
      padding: clamp(28px, 5vw, 48px);
      background: linear-gradient(135deg, rgba(247,185,40,.62), rgba(255,248,227,.96));
      border: 1px solid rgba(84, 25, 35, .10);
      box-shadow: var(--shadow);
    }

    .contact-box p { color: var(--muted); }



    .nav-links .nav-instagram {
      background: linear-gradient(135deg, rgba(247,185,40,.50), rgba(0,143,69,.20));
      color: var(--soil);
      border: 1px solid rgba(63, 41, 23, .1);
    }

    .visit-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 18px;
      margin-top: 22px;
    }

    .visit-card {
      border-radius: 30px;
      padding: 28px;
      background: rgba(255, 249, 234, .93);
      border: 1px solid rgba(84, 25, 35, .10);
      box-shadow: 0 18px 50px rgba(84, 25, 35, .10);
    }

    .visit-card.instagram-card {
      background:
        radial-gradient(circle at 92% 10%, rgba(247,185,40,.58), transparent 30%),
        linear-gradient(135deg, rgba(255,248,227,.98), rgba(255,239,184,.95));
    }

    .visit-card.route-card {
      background:
        radial-gradient(circle at 90% 10%, rgba(0,143,69,.25), transparent 33%),
        linear-gradient(135deg, rgba(255,248,227,.98), rgba(255,239,184,.95));
    }

    .visit-card .mini-kicker {
      display: inline-flex;
      margin-bottom: 10px;
      color: var(--leaf-dark);
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .11em;
      font-size: .76rem;
    }

    .visit-card h3 {
      margin: 0 0 10px;
      color: var(--soil);
      font-size: clamp(1.55rem, 3vw, 2.25rem);
      letter-spacing: -.045em;
      line-height: 1.08;
    }

    .visit-card p {
      margin: 0 0 20px;
      color: var(--muted);
    }

    .visit-card .button {
      width: fit-content;
    }

    .map-preview {
      position: relative;
      display: block;
      overflow: hidden;
      margin: 18px 0 20px;
      min-height: 260px;
      border-radius: 24px;
      border: 1px solid rgba(63, 41, 23, .14);
      box-shadow: 0 16px 38px rgba(63, 41, 23, .12);
      background:
        radial-gradient(circle at 68% 42%, rgba(247,185,40,.42), transparent 0 8%, transparent 9%),
        linear-gradient(135deg, rgba(0,143,69,.16), rgba(247,185,40,.22)),
        #fff8e3;
      text-decoration: none;
      color: var(--soil);
    }

    .map-grid {
      position: absolute;
      inset: 0;
      opacity: .45;
      background:
        linear-gradient(90deg, rgba(84,25,35,.1) 1px, transparent 1px),
        linear-gradient(0deg, rgba(84,25,35,.1) 1px, transparent 1px);
      background-size: 46px 46px;
      transform: rotate(-3deg) scale(1.08);
    }

    .map-road {
      position: absolute;
      left: -10%;
      right: -10%;
      height: 34px;
      border-radius: 999px;
      background: rgba(255,253,242,.88);
      box-shadow: inset 0 0 0 2px rgba(84,25,35,.08);
    }

    .road-a { top: 48%; transform: rotate(-10deg); }
    .road-b { top: 35%; transform: rotate(36deg); width: 75%; left: 18%; }

    .map-pin {
      position: absolute;
      left: 50%;
      top: 42%;
      width: 58px;
      height: 58px;
      transform: translate(-50%, -50%);
      display: grid;
      place-items: center;
      border-radius: 50%;
      background: var(--corn);
      color: var(--soil);
      font-size: 2rem;
      font-weight: 900;
      border: 4px solid rgba(255,248,227,.95);
      box-shadow: 0 16px 30px rgba(84,25,35,.24);
      z-index: 2;
    }

    .map-label {
      position: absolute;
      left: 22px;
      right: 22px;
      bottom: 18px;
      z-index: 3;
      padding: 16px 18px;
      border-radius: 20px;
      background: rgba(255,248,227,.92);
      font-weight: 900;
      box-shadow: 0 12px 28px rgba(84,25,35,.12);
    }

    .map-label small {
      display: block;
      margin-top: 3px;
      font-size: .86rem;
      color: var(--muted);
      font-weight: 800;
    }

    .footer {
      margin-top: 34px;
      background: linear-gradient(135deg, var(--soil), #3a1118);
      color: rgba(255, 253, 245, .76);
    }

    .footer-inner {
      max-width: 1180px;
      margin: 0 auto;
      padding: 28px 22px;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      gap: 14px;
      font-size: .95rem;
    }

    .footer a {
      color: #fff4ce;
      text-decoration: none;
      font-weight: 700;
    }

    .footer a:hover { text-decoration: underline; }

    @media (max-width: 900px) {
      .nav { align-items: flex-start; flex-direction: column; }
      .nav-links { justify-content: flex-start; }
      .hero, .band-inner, .price-card, .visit-grid, .yoga-card { grid-template-columns: 1fr; }
      .hero { padding-top: 50px; }
      .hero-card { min-height: 390px; }
      .hero-logo { right: 24px; top: 20px; width: min(30%, 150px); max-height: 118px; }
      .grid { grid-template-columns: 1fr; }
      .date-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    }

    .legal-main {
      max-width: 980px;
      margin: 0 auto;
      padding: 58px 22px 76px;
      overflow: visible;
    }

    .legal-card {
      background: var(--paper);
      border: 1px solid rgba(84, 25, 35, .10);
      box-shadow: var(--shadow);
      border-radius: 30px;
      padding: clamp(28px, 5vw, 56px);
    }

    .legal-card h1 {
      font-size: clamp(2.35rem, 6vw, 4.8rem);
      line-height: 1.05;
      letter-spacing: -.06em;
      margin: 0 0 22px;
      color: var(--soil);
    }

    .legal-card h2 {
      margin: 34px 0 10px;
      color: var(--soil);
      line-height: 1.15;
      letter-spacing: -.03em;
    }

    .legal-card p,
    .legal-card li { color: var(--muted); }

    .legal-card a {
      color: var(--soil);
      font-weight: 800;
      text-decoration-color: rgba(247, 185, 40, .95);
      text-decoration-thickness: 2px;
      text-underline-offset: 3px;
    }

    .legal-card ul {
      padding-left: 1.25rem;
    }

    .legal-card strong { color: var(--soil); }

    @media (max-width: 720px) {
      .legal-main { padding-top: 34px; }
      .legal-card { border-radius: 24px; }
    }

/* === 404 Seite === */
.error-hero {
  max-width: 1180px;
  margin: 0 auto;
  padding: 72px 22px 70px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .82fr);
  align-items: center;
  gap: 44px;
}

.error-copy {
  position: relative;
  z-index: 1;
}

.error-copy h1 {
  margin: 0 0 20px;
  max-width: 760px;
  color: var(--soil);
  font-size: clamp(3rem, 8.5vw, 6.9rem);
  line-height: .9;
  letter-spacing: -.075em;
}

.error-copy .lead {
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(1.08rem, 2vw, 1.28rem);
}

.error-visual {
  position: relative;
  min-height: 460px;
  border-radius: 42px;
  overflow: hidden;
  box-shadow: var(--shadow);
  border: 10px solid rgba(255, 248, 227, .86);
  background: var(--cream);
  transform: rotate(1.5deg);
}

.error-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 42%;
  filter: saturate(1.08) contrast(1.02);
}

.error-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(84,25,35,.10), rgba(84,25,35,.42));
}

.error-badge {
  position: absolute;
  left: 24px;
  bottom: 24px;
  z-index: 2;
  display: grid;
  gap: 2px;
  padding: 18px 22px;
  border-radius: 24px;
  background: rgba(255, 248, 227, .92);
  color: var(--soil);
  box-shadow: 0 18px 42px rgba(84,25,35,.18);
}

.error-badge span {
  font-size: clamp(3.1rem, 7vw, 6rem);
  line-height: .84;
  font-weight: 1000;
  letter-spacing: -.08em;
}

.error-badge small {
  color: var(--leaf-dark);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.error-logo {
  position: absolute;
  right: 18px;
  top: 18px;
  z-index: 3;
  width: min(34%, 142px);
  height: auto;
  filter: drop-shadow(0 14px 26px rgba(0,0,0,.24));
}

@media (max-width: 900px) {
  .error-hero { grid-template-columns: 1fr; padding-top: 50px; }
  .error-visual { min-height: 360px; transform: none; }
}

/* === Statistik === */
.stats-page {
  background: linear-gradient(135deg,#ffe08d,#f9f1bf);
}

.stats-wrap {
  max-width: 980px;
  margin: 0 auto;
  padding: 32px 20px 56px;
}

.stats-top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.stats-top img {
  width: 52px;
  height: 52px;
}

.stats-top h1 {
  margin: 0;
  color: var(--soil);
  font-size: clamp(2rem, 5vw, 4rem);
  line-height: 1;
}

.stats-card {
  background: rgba(255,253,242,.9);
  border: 1px solid rgba(85,29,40,.14);
  border-radius: 28px;
  box-shadow: 0 20px 70px rgba(85,29,40,.12);
  padding: 28px;
  margin-top: 22px;
}

.stats-card h2 {
  margin: 0 0 16px;
  color: var(--soil);
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 14px;
  margin-top: 22px;
}

.stats-box {
  background: #fff7dc;
  border: 1px solid rgba(85,29,40,.14);
  border-radius: 22px;
  padding: 18px;
}

.stats-box strong {
  display: block;
  color: var(--soil);
  font-size: clamp(1.8rem,4vw,3rem);
  line-height: 1;
}

.stats-box span {
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: .72rem;
  font-weight: 800;
}

.stats-note {
  font-size: .95rem;
  color: var(--muted);
}

.stats-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 22px;
}

.stats-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 999px;
  background: var(--leaf);
  color: white;
  text-decoration: none;
  font-weight: 800;
}

.stats-button.alt {
  background: var(--soil);
}

.stats-card table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 18px;
}

.stats-card th,
.stats-card td {
  text-align: left;
  padding: 13px 14px;
  border-bottom: 1px solid rgba(85,29,40,.14);
}

.stats-card th {
  color: var(--soil);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
}

.stats-card tr:last-child td {
  border-bottom: none;
}

@media(max-width:760px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .stats-card{padding:22px}
  .stats-card th,.stats-card td{padding:11px 9px}
}
