/*
Theme Name: Sportalm Bayrischzell
Theme URI: https://sportalm-bistro-bayrischzell.de/
Author: Sportalm Bayrischzell
Description: Restaurant, Bistro & Sportsbar — modernes Block-Editor-Theme mit pflegbaren Speisekarten-Tafeln. Speziell für die Sportalm Bayrischzell entwickelt.
Version: 1.0.0
Requires at least: 6.4
Requires PHP: 8.0
License: Proprietär
Text Domain: sportalm
*/

/* Sportalm Bayrischzell — Theme-Styles
   Wird sowohl von index.html als auch von allen Speisekarten-Unterseiten
   verwendet. Spiegelt die spätere WordPress-Theme-Struktur (style.css). */

:root{
    /* Hauptpalette */
    --white:#ffffff;
    --bg:#f8f3e6;          /* Hauptbackground sehr hell, leicht warm */
    --paper:#f4e9d0;       /* Karten-/Boxen-Background */
    --paper-deep:#eddfbe;
    --kraft:#c9a875;
    --cork:#b6926a;
    --cork-dark:#8d6c44;

    --tafel:#1d2a1f;
    --kreide:#f6efd9;

    /* Sportalm-Brand-Farben (aus dem Original-Logo abgeleitet).
       Variablen heißen aus Legacy-Gründen noch --blechrot/--blechrot-dark.
       Werte sind das Sportalm-Blau. */
    --blechrot:#3e5687;        /* Sportalm-Dunkelblau */
    --blechrot-dark:#2a3d63;   /* tieferes Blau für Hover & Outlines */
    --brand-blue-soft:#8ea7cd; /* helles Sportsbar-Blau */
    --blechcream:#ead9a8;

    --gruen:#7ea552;
    --gruen-dark:#4a6531;
    --gruen-soft:#c5d6a8;

    --terra:#a8593a;

    --ink:#2d1f12;
    --ink-soft:#4a3826;
    --mute:#7a614a;

    /*
      --ff-headline ist die Hauptschrift der Wirtshaus-Headlines.
      Wenn die echte Sportalm-Schrift bekannt ist, hier einfach austauschen.
      Aktuell: Amatic SC (Google Fonts) — kommt der Beispielvorlage sehr nah.
    */
    /* Drei Schriften — mehr nicht. */
    --ff-headline:"Amatic SC", "Trebuchet MS", sans-serif;  /* Display + Tafel */
    --ff-body:"Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
    --ff-hand:"Caveat", "Marker Felt", cursive;             /* Handschrift-Akzente */
    /* Aliase, damit alter Code nicht bricht — alle auf die 3 Hauptschriften gemappt */
    --ff-display:var(--ff-body);
    --ff-stamp:var(--ff-body);
    --ff-chalk:var(--ff-headline);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--bg);
    color:var(--ink);
    font-family:var(--ff-body);
    font-size:17px;
    line-height:1.65;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  img{display:block;max-width:100%;height:auto}
  a{color:inherit;text-decoration:none}

  h1,h2,h3,h4{
    font-family:var(--ff-headline);
    font-weight:700;
    line-height:1.02;
    letter-spacing:.01em;
    color:var(--ink);
  }
  /* Amatic SC ist condensed — daher größer skalieren, damit sie wirken */
  h1{font-size:clamp(3.6rem,9vw,8rem)}
  h2{font-size:clamp(2.6rem,5.5vw,5rem);font-weight:700}
  h3{font-size:clamp(1.7rem,2.4vw,2.2rem)}

  .container{max-width:1240px;margin:0 auto;padding:0 28px;position:relative}

  /* ============= KARTEN-BOX (Schüttalm-Style) ============= */
  .card{
    background:var(--paper);
    padding:80px 64px;
    position:relative;
    /* dezente Leinen-/Sackstoff-Textur */
    background-image:
      repeating-linear-gradient(0deg, transparent 0 2px, rgba(141,108,68,.045) 2px 3px),
      repeating-linear-gradient(90deg, transparent 0 2px, rgba(141,108,68,.04) 2px 3px),
      radial-gradient(circle at 20% 30%, rgba(184,154,109,.06), transparent 40%),
      radial-gradient(circle at 80% 70%, rgba(184,154,109,.05), transparent 40%);
    box-shadow:
      0 1px 0 rgba(0,0,0,.03),
      0 24px 50px -30px rgba(58,42,28,.18);
  }
  .card.tight{padding:60px 48px}
  .card-eyebrow{
    font-family:var(--ff-body);font-weight:600;
    font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
    color:var(--blechrot);
    display:inline-flex;align-items:center;gap:14px;
    margin-bottom:20px;
  }
  .card-eyebrow::before{
    content:"";width:32px;height:1px;
    background:repeating-linear-gradient(90deg, var(--blechrot) 0 4px, transparent 4px 6px);
  }
  .card h2 em{color:var(--blechrot);font-style:normal;font-weight:700}
  h1 .accent, h2 em{color:var(--blechrot);font-style:normal}

  /* ============= BILDER (klassisch, kein Polaroid) ============= */
  .img-frame{
    position:relative;
    overflow:hidden;
    box-shadow:
      0 1px 0 rgba(0,0,0,.05),
      0 20px 40px -20px rgba(58,42,28,.3);
  }
  .img-frame img{width:100%;height:100%;object-fit:cover;display:block}
  .img-frame::after{
    content:"";position:absolute;inset:0;
    box-shadow:inset 0 0 0 6px rgba(255,255,255,.92);
    pointer-events:none;
  }

  /* ============= TAFEL (dünner Rahmen, keine Nägel) ============= */
  .tafel{
    background:linear-gradient(135deg, #6b4a2a 0%, #4d3219 30%, #7a5634 50%, #3d2913 75%, #6b4628 100%);
    padding:10px;position:relative;
    box-shadow:
      0 22px 38px -12px rgba(0,0,0,.5),
      0 2px 0 rgba(0,0,0,.12);
    background-image:
      linear-gradient(135deg, #6b4a2a 0%, #4d3219 30%, #7a5634 50%, #3d2913 75%, #6b4628 100%),
      repeating-linear-gradient(90deg, rgba(0,0,0,.07) 0 2px, transparent 2px 18px),
      repeating-linear-gradient(90deg, rgba(255,255,255,.03) 0 1px, transparent 1px 22px);
    background-blend-mode:normal, multiply, screen;
  }
  .tafel-inner{
    background:var(--tafel);
    background-image:
      radial-gradient(ellipse at 30% 25%, rgba(255,255,255,.05), transparent 55%),
      radial-gradient(ellipse at 75% 75%, rgba(255,255,255,.04), transparent 50%),
      radial-gradient(circle at 80% 20%, rgba(255,255,255,.025) 1px, transparent 2px),
      radial-gradient(circle at 15% 60%, rgba(255,255,255,.025) 1px, transparent 2px),
      radial-gradient(circle at 60% 85%, rgba(255,255,255,.02) 1px, transparent 2px);
    background-size: 100% 100%, 100% 100%, 60px 60px, 80px 80px, 70px 70px;
    padding:54px 52px;
    color:var(--kreide);
    position:relative;
    box-shadow:inset 0 0 80px rgba(0,0,0,.55), inset 0 2px 6px rgba(0,0,0,.5);
  }
  /* Nägel/Schrauben entfernt — bewusst leer gelassen */

  .chalk-white{color:#f6efd9}
  .chalk-orange{color:#f08c3c}
  .chalk-pink{color:#e85f7d}
  .chalk-blue{color:#7cc7e3}
  .chalk-green{color:#a8d669}
  .chalk-yellow{color:#ffd66b}
  .chalk-red{color:#e85a3a}

  .tafel .chalk-line{
    height:1px;
    background:repeating-linear-gradient(90deg, var(--kreide) 0 8px, transparent 8px 12px);
    opacity:.5;margin:14px 0;
  }
  .tafel .hand-title{
    font-family:var(--ff-headline);font-weight:700;
    font-size:clamp(3rem,5.6vw,4.8rem);
    line-height:.95;letter-spacing:.02em;display:block;
  }
  .tafel .hand-script{
    font-family:var(--ff-hand);
    font-size:clamp(2.2rem,3.6vw,3rem);
    line-height:1;display:inline-block;
    transform:rotate(-2deg);
  }
  .tafel .preis-big{
    font-family:var(--ff-hand);
    font-size:clamp(3rem,5.2vw,4.2rem);
    line-height:1;color:#f6efd9;
    transform:rotate(-3deg);display:inline-block;
  }
  .tafel .item{
    font-family:var(--ff-hand);
    font-size:1.7rem;line-height:1.2;
    color:#a8d669;
    display:flex;align-items:flex-start;gap:12px;margin-top:10px;
  }
  .tafel .item::before{
    content:"✱";color:#a8d669;font-size:1.5rem;line-height:1;flex-shrink:0;margin-top:2px;
  }
  .tafel-new{
    position:absolute;
    font-family:var(--ff-hand);font-weight:700;
    font-size:1.7rem;color:#f08c3c;
    text-shadow:0 0 6px rgba(255,140,60,.25);
    z-index:3;line-height:1;
  }
  .tafel-new.tl{top:36px;left:32px;transform:rotate(-18deg)}
  .tafel-new.tr{top:36px;right:32px;transform:rotate(16deg)}
  .chalk-sun{
    position:absolute;width:54px;height:54px;z-index:3;color:#f6efd9;
  }
  .chalk-sun.center-top{top:30px;left:50%;margin-left:-27px}
  .chalk-heart{color:#e85a3a;font-size:1.2rem;font-family:var(--ff-hand);display:inline-block}

  /* Tafel-Row (für Wochenkarte) */
  .tafel-row{
    display:flex;justify-content:space-between;align-items:baseline;
    margin:14px 0;gap:14px;
  }
  .tafel-row .name{
    font-family:var(--ff-headline);font-weight:700;
    font-size:2rem;line-height:1;letter-spacing:.02em;
  }
  .tafel-row .name small{
    display:block;font-family:var(--ff-hand);font-size:1.4rem;
    color:#a8d669;margin-top:6px;font-weight:400;line-height:1;
  }
  .tafel-row .dots{
    flex:1;height:1px;
    background:repeating-linear-gradient(90deg, rgba(246,239,217,.45) 0 3px, transparent 3px 8px);
    transform:translateY(-8px);
  }
  .tafel-row{margin:22px 0 !important;align-items:center !important}
  .tafel-row .price{
    font-family:var(--ff-hand);font-size:2.2rem;
    color:#ffd66b;line-height:1;
  }

  /* ============= STICKER-KREIS ============= */
  .sticker-circle{
    width:200px;height:200px;border-radius:50%;
    background:var(--paper);
    border:2px dashed var(--cork-dark);
    outline:8px solid var(--paper);
    outline-offset:-14px;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:24px;
    box-shadow:0 12px 24px -10px rgba(0,0,0,.28);
    position:relative;color:var(--ink);
  }
  .sticker-circle.white{background:var(--white);outline-color:var(--white)}
  .sticker-circle .heart-icon{margin-bottom:6px;color:var(--blechrot)}
  .sticker-circle .label{
    font-family:var(--ff-hand);font-size:1.5rem;line-height:1.05;color:var(--ink);
  }
  .sticker-circle .num-small{
    margin-top:8px;font-family:var(--ff-stamp);font-size:.85rem;
    letter-spacing:.12em;color:var(--blechrot);
  }
  .sticker-circle .badge{
    font-family:var(--ff-stamp);font-size:.6rem;letter-spacing:.28em;
    text-transform:uppercase;color:var(--blechrot);
  }

  /* ============= WOLF (mask-image-Variante) =============
     Das Wolf-Logo (wolf.png) wird per CSS-Mask in die jeweilige Farbe gefärbt.
     Schwarzer Hintergrund vom PNG fällt dabei automatisch weg.
     ====================================================== */
  .wolfmark, .wolfpin, .wolf-img{
    display:inline-block;
    background-color:currentColor;
    -webkit-mask-image: url('assets/wolf.png');
            mask-image: url('assets/wolf.png');
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-position: center;
            mask-position: center;
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    /* PNG ist freigestellt (transparent) — Alpha-Kanal als Maske nutzen */
    -webkit-mask-mode: alpha;
            mask-mode: alpha;
  }
  .wolfmark{
    width:60px;height:40px;
    color:var(--ink);
    transition:transform .35s ease, color .25s ease;
    vertical-align:middle;
  }
  .wolfmark:hover{transform:rotate(-4deg)}

  .wolfpin{
    position:absolute;
    width:46px;height:32px;
    color:var(--blechrot);z-index:6;
    filter:drop-shadow(0 3px 4px rgba(0,0,0,.35));
  }
  .wolfpin.dark{color:var(--ink)}
  .wolfpin.green{color:var(--gruen-dark)}
  .wolfpin.tilt-l{transform:rotate(-14deg)}
  .wolfpin.tilt-r{transform:rotate(14deg)}

  /* ============= HEADER ============= */
  header.site{
    position:fixed;top:0;left:0;right:0;z-index:50;
    padding:18px 28px;
    display:flex;align-items:center;justify-content:space-between;
    transition:all .35s ease;
  }
  header.site::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(to bottom, rgba(20,12,6,.4), rgba(20,12,6,0));
    z-index:-1;transition:background .35s ease;
  }
  header.site.scrolled::before{
    background:rgba(248,243,230,.97);
    backdrop-filter:saturate(150%) blur(6px);
    box-shadow:0 1px 0 rgba(141,108,68,.2);
  }
  .brand{display:flex;align-items:center;gap:14px;color:var(--white)}
  .scrolled .brand{color:var(--ink)}
  .brand .wolfmark{width:64px;height:42px;color:var(--white)}
  .scrolled .brand .wolfmark{color:var(--ink)}
  .wordmark{
    font-family:var(--ff-headline);
    font-weight:700;
    font-size:2.4rem;line-height:.95;
    letter-spacing:.02em;
  }
  .wordmark small{
    display:block;font-family:var(--ff-stamp);font-style:normal;
    font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;
    color:var(--blechcream);margin-top:2px;
  }
  .scrolled .wordmark small{color:var(--blechrot)}

  nav.primary{display:flex;gap:30px;align-items:center}
  nav.primary a{
    color:var(--white);
    font-family:var(--ff-stamp);font-size:.74rem;
    letter-spacing:.22em;text-transform:uppercase;
    position:relative;padding:6px 0;
    transition:color .25s ease;
  }
  .scrolled nav.primary a{color:var(--ink)}
  nav.primary a::after{
    content:"";position:absolute;left:0;right:0;bottom:-2px;height:3px;
    background:repeating-linear-gradient(90deg, var(--blechrot) 0 4px, transparent 4px 6px);
    opacity:0;transition:opacity .25s ease;
  }
  nav.primary a:hover::after{opacity:1}
  .nav-phone{
    display:inline-flex;align-items:center;gap:8px;
    background:var(--blechrot);color:#fff !important;
    padding:9px 18px !important;
    font-family:var(--ff-body) !important;font-weight:500;
    font-size:.85rem !important;letter-spacing:.06em !important;text-transform:none !important;
    box-shadow:0 4px 10px -4px rgba(0,0,0,.4);
    transition:transform .25s ease;
  }
  .nav-phone::after{display:none}
  .nav-phone:hover{transform:translateY(-1px)}
  .nav-phone svg{width:14px;height:14px}
  .nav-toggle{display:none;background:none;border:0;color:var(--white);font-size:1.6rem;cursor:pointer}
  .scrolled .nav-toggle{color:var(--ink)}

  /* ============= HERO mit Slider ============= */
  .hero{
    position:relative;
    height:100vh;min-height:680px;
    overflow:hidden;
    color:var(--white);
  }
  .hero-slider{position:absolute;inset:0;z-index:0}
  .hero-slider .slide{
    position:absolute;inset:0;
    background-size:cover;background-position:center;
    opacity:0;
    transition:opacity 1.6s ease-in-out, transform 8s ease-out;
    transform:scale(1.06);
    filter:saturate(1.02) contrast(1.04);
  }
  .hero-slider .slide.is-active{
    opacity:1;
    transform:scale(1.0);
  }
  .hero-overlay{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background:linear-gradient(180deg, rgba(20,12,6,.28) 0%, rgba(20,12,6,.5) 55%, rgba(20,12,6,.82) 100%);
  }

  .slider-dots{
    position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
    display:flex;gap:12px;z-index:3;
  }
  .slider-dots .dot{
    width:38px;height:3px;
    background:rgba(255,255,255,.4);
    border:0;cursor:pointer;padding:0;
    transition:background .3s ease, width .3s ease;
  }
  .slider-dots .dot.is-active{background:var(--white);width:54px}
  .slider-dots .dot:hover{background:rgba(255,255,255,.7)}

  .slider-arrow{
    position:absolute;top:50%;z-index:3;
    width:48px;height:48px;border:0;cursor:pointer;
    background:rgba(255,255,255,.12);
    color:var(--white);
    display:flex;align-items:center;justify-content:center;
    backdrop-filter:blur(4px);
    transition:background .25s ease;
    transform:translateY(-50%);
  }
  .slider-arrow:hover{background:rgba(255,255,255,.25)}
  .slider-arrow.prev{left:24px}
  .slider-arrow.next{right:24px}
  .slider-arrow svg{width:22px;height:22px}
  .hero-inner{
    position:relative;z-index:2;
    height:100%;
    display:flex;flex-direction:column;justify-content:flex-end;
    padding:0 28px 90px;
    max-width:1240px;margin:0 auto;
  }
  .hero .eyebrow{
    font-family:var(--ff-body);font-weight:600;
    font-size:.76rem;letter-spacing:.28em;text-transform:uppercase;
    color:var(--white);opacity:.95;
    margin-bottom:24px;
    display:flex;align-items:center;gap:14px;
    text-shadow:0 1px 8px rgba(0,0,0,.5);
  }
  .hero .eyebrow::before{content:"";width:36px;height:1px;background:var(--white)}
  .hero h1{
    max-width:18ch;
    color:var(--white);
    text-shadow:0 2px 24px rgba(0,0,0,.4);
  }
  .hero h1 .accent{color:var(--blechcream)}
  .hero p.lede{
    font-family:var(--ff-body);
    font-size:clamp(1.05rem,1.3vw,1.3rem);
    font-weight:400;
    margin-top:22px;
    max-width:50ch;
    color:rgba(255,255,255,.94);
    text-shadow:0 2px 16px rgba(0,0,0,.5);
    line-height:1.55;
  }
  .hero-meta{
    display:flex;gap:24px;align-items:center;
    margin-top:42px;flex-wrap:wrap;
  }
  .btn{
    display:inline-flex;align-items:center;gap:12px;
    padding:16px 32px;
    font-family:var(--ff-body);font-weight:600;
    font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
    background:var(--blechrot);color:var(--white);
    border:1px solid var(--blechrot);
    transition:all .25s ease;cursor:pointer;
  }
  .btn:hover{background:transparent;color:var(--white);border-color:var(--white)}
  .btn.ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.6)}
  .btn.ghost:hover{background:var(--white);color:var(--ink);border-color:var(--white)}
  .btn svg{width:14px;height:14px}

  /* Reservierungs-Sticker, rechts unten im Hero */
  .hero-sticker{
    position:absolute;
    right:60px;bottom:80px;
    transform:rotate(-6deg);
    z-index:3;
  }

  .scroll-hint{
    position:absolute;bottom:70px;right:40px;
    color:var(--white);opacity:.85;
    font-family:var(--ff-stamp);
    font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;
    z-index:2;
    animation: bob 2.4s ease-in-out infinite;
    writing-mode:vertical-rl;
    transform:rotate(180deg);
  }
  .scroll-hint::after{
    content:"";display:block;width:1px;height:30px;background:var(--white);
    margin:8px auto 0;
  }
  @keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

  /* ============= SECTION-Architektur ============= */
  section.section{padding:90px 0;background:var(--bg);position:relative}

  /* ============= STORY ============= */
  .story-grid{
    display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:center;
  }
  .story-text h2{margin-bottom:20px}
  .story-text p{margin-bottom:18px;max-width:54ch;color:var(--ink-soft)}
  .story-text .sig{
    margin-top:32px;
    font-family:var(--ff-hand);font-size:1.9rem;
    color:var(--ink);display:inline-block;
    transform:rotate(-1.5deg);
  }
  .story-text .sig small{
    display:block;
    font-family:var(--ff-stamp);font-style:normal;font-size:.62rem;letter-spacing:.32em;
    text-transform:uppercase;color:var(--mute);margin-top:4px;transform:rotate(1.5deg);
  }
  .story-img{aspect-ratio:4/5;width:100%;max-height:560px}

  /* ============= QUOTE-CARD ============= */
  .quote-card{
    background:var(--white);
    padding:80px 56px;
    text-align:center;
    position:relative;
    box-shadow:0 24px 50px -30px rgba(58,42,28,.18);
  }
  .quote-card::before, .quote-card::after{
    content:"";position:absolute;left:50%;transform:translateX(-50%);
    width:60%;max-width:420px;height:1px;
    background:repeating-linear-gradient(90deg, var(--cork-dark) 0 6px, transparent 6px 12px);
    opacity:.4;
  }
  .quote-card::before{top:32px}
  .quote-card::after{bottom:32px}
  .quote-card .wolf{
    display:block;
    width:140px;height:94px;color:var(--blechrot);
    margin:0 auto 28px;
    filter:drop-shadow(0 6px 0 rgba(0,0,0,.06));
  }
  .quote-card .big-q{
    font-family:var(--ff-body);font-weight:300;
    font-size:clamp(1.5rem,2.6vw,2.3rem);line-height:1.35;
    color:var(--ink);max-width:32ch;margin:0 auto;
    letter-spacing:-.005em;
  }
  .quote-card .big-q em{color:var(--blechrot);font-style:normal;font-weight:500}
  .quote-card .cred{
    margin-top:26px;
    font-family:var(--ff-hand);font-size:1.4rem;color:var(--gruen-dark);
    transform:rotate(-1.5deg);display:inline-block;
  }

  /* ============= MENU/TAFEL-CARD ============= */
  .menu-head{
    text-align:center;
    max-width:760px;margin:0 auto 60px;
  }
  .menu-head h2{margin-bottom:14px}
  .menu-head .hand{
    font-family:var(--ff-hand);font-size:1.4rem;color:var(--gruen-dark);
    transform:rotate(-1.5deg);display:inline-block;
  }
  .menu-layout{
    display:flex;flex-direction:column;gap:60px;
    max-width:920px;margin:0 auto;
  }

  .menu-pills{
    margin-top:54px;
    display:flex;justify-content:center;gap:12px;flex-wrap:wrap;
  }
  .menu-pills a{
    font-family:var(--ff-stamp);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;
    color:var(--ink);border:2px solid var(--ink);
    padding:12px 20px;background:var(--white);
    transition:all .25s ease;transform:rotate(-1deg);
  }
  .menu-pills a:nth-child(2n){transform:rotate(1deg)}
  .menu-pills a:hover{background:var(--blechrot);color:var(--white);border-color:var(--blechrot);transform:rotate(0)}

  /* ============= SPORTSBAR-CARD ============= */
  .sportsbar{
    background:linear-gradient(135deg, #1a1109 0%, #2d1f12 50%, #1a1109 100%);
    color:var(--white);
    padding:90px 64px;
    position:relative;
    overflow:hidden;
    box-shadow:0 24px 50px -30px rgba(0,0,0,.4);
  }
  .sportsbar::before{
    content:"";position:absolute;inset:0;
    background-image:
      radial-gradient(circle at 15% 20%, rgba(62,86,135,.32), transparent 40%),
      radial-gradient(circle at 85% 80%, rgba(142,167,205,.16), transparent 45%);
    pointer-events:none;
  }
  .sportsbar-grid{
    position:relative;
    display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;
  }
  .sportsbar-text .card-eyebrow{color:var(--brand-blue-soft)}
  .sportsbar-text .card-eyebrow::before{background:repeating-linear-gradient(90deg, var(--brand-blue-soft) 0 4px, transparent 4px 6px)}
  .sportsbar-text h2{color:var(--white)}
  .sportsbar-text h2 em{color:var(--brand-blue-soft);font-style:normal}
  .sportsbar-text p{color:rgba(255,255,255,.78);margin-top:14px;max-width:48ch;font-size:1.05rem}

  .channels{
    margin-top:36px;
    display:flex;gap:18px;flex-wrap:wrap;align-items:center;
  }
  .channel-chip{
    display:inline-flex;align-items:center;gap:12px;
    padding:14px 22px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.18);
    color:var(--white);
    font-family:var(--ff-body);font-weight:700;
    font-size:1.05rem;letter-spacing:.06em;
    text-transform:uppercase;
    transition:all .25s ease;
  }
  .channel-chip:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.32)}
  .channel-chip .dot{
    width:8px;height:8px;border-radius:50%;
    background:#ff4444;box-shadow:0 0 0 4px rgba(255,68,68,.2);
    animation: pulse 1.8s ease-in-out infinite;
  }
  @keyframes pulse{
    0%,100%{opacity:1;transform:scale(1)}
    50%{opacity:.55;transform:scale(.85)}
  }
  .sportsbar-features{
    list-style:none;margin-top:30px;
    display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;
  }
  .sportsbar-features li{
    font-family:var(--ff-hand);font-size:1.25rem;color:rgba(255,255,255,.85);
    display:flex;align-items:flex-start;gap:10px;line-height:1.15;
  }
  .sportsbar-features li::before{
    content:"✓";color:var(--brand-blue-soft);font-family:var(--ff-headline);font-weight:700;
    font-size:1.4rem;line-height:1;flex-shrink:0;
  }

  /* großer "Screen"-Block rechts: TV-Optik */
  .sportsbar-screen{
    position:relative;
    aspect-ratio:16/9;
    background:#0a0a0a;
    border-radius:8px;
    overflow:hidden;
    box-shadow:
      0 30px 60px -20px rgba(0,0,0,.6),
      inset 0 0 0 2px #2a2a2a,
      inset 0 0 0 8px #0a0a0a;
  }
  .sportsbar-screen::before{
    content:"";position:absolute;inset:14px;
    background:
      radial-gradient(circle at 30% 30%, rgba(255,200,80,.3), transparent 55%),
      radial-gradient(circle at 70% 70%, rgba(80,180,255,.25), transparent 55%),
      linear-gradient(135deg, #1a3060 0%, #0a1830 50%, #2a1010 100%);
  }
  .sportsbar-screen::after{
    content:"LIVE";position:absolute;top:24px;left:24px;
    font-family:var(--ff-body);font-weight:800;font-size:.75rem;
    letter-spacing:.18em;color:var(--white);
    padding:5px 10px;background:#cc0000;
    border-radius:2px;z-index:2;
  }
  .sportsbar-screen .scoreline{
    position:absolute;bottom:24px;left:24px;right:24px;
    background:rgba(0,0,0,.65);
    backdrop-filter:blur(6px);
    padding:14px 20px;
    display:flex;justify-content:space-between;align-items:center;
    color:var(--white);
    z-index:2;
    border-radius:4px;
  }
  .sportsbar-screen .scoreline .team{
    font-family:var(--ff-body);font-weight:700;letter-spacing:.04em;
    font-size:1.05rem;
  }
  .sportsbar-screen .scoreline .score{
    font-family:var(--ff-headline);font-weight:700;
    font-size:1.7rem;color:#f0c46a;letter-spacing:.04em;
  }

  /* ============= BIERGARTEN-CARD ============= */
  .bg-grid{
    display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;
  }
  .bg-grid .images{
    display:grid;grid-template-columns:1fr 1fr;gap:18px;
  }
  .bg-grid .images .img-frame{aspect-ratio:3/4}
  .bg-grid .images .img-frame:nth-child(1){margin-top:30px}
  .features{
    list-style:none;
    display:grid;grid-template-columns:1fr 1fr;gap:14px 28px;margin-top:30px;
  }
  .features li{
    font-family:var(--ff-hand);font-size:1.3rem;line-height:1.15;
    color:var(--ink);display:flex;align-items:flex-start;gap:10px;
  }
  .features li::before{
    content:"✓";color:var(--blechrot);font-family:var(--ff-display);font-style:italic;
    font-size:1.3rem;line-height:1;flex-shrink:0;
  }

  /* ============= TELEFON-STRIP ============= */
  .phone-strip{padding:60px 28px;background:var(--bg);position:relative}
  .phone-strip .big-sign{
    max-width:880px;margin:0 auto;
    background:var(--blechrot);
    outline:3px solid var(--blechrot-dark);outline-offset:8px;
    border:6px solid var(--blechrot);
    color:var(--blechcream);text-align:center;
    padding:50px 40px;
    transform:rotate(-1.5deg);
    box-shadow:0 24px 50px -20px rgba(0,0,0,.45);
    position:relative;
  }
  .phone-strip .big-sign::before, .phone-strip .big-sign::after,
  .phone-strip .corner-bl, .phone-strip .corner-br{
    content:"";position:absolute;width:14px;height:14px;border-radius:50%;
    background:radial-gradient(circle at 30% 30%, #ddd 0 3px, #888 4px, #333);
    box-shadow:0 1px 3px rgba(0,0,0,.5);
  }
  .phone-strip .big-sign::before{top:10px;left:10px}
  .phone-strip .big-sign::after{top:10px;right:10px}
  .phone-strip .corner-bl{bottom:10px;left:10px}
  .phone-strip .corner-br{bottom:10px;right:10px}
  .phone-strip .label{
    font-family:var(--ff-stamp);
    font-size:.78rem;letter-spacing:.42em;text-transform:uppercase;
    color:var(--blechcream);opacity:.9;margin-bottom:14px;
  }
  .phone-strip .number{
    font-family:var(--ff-headline);font-weight:700;
    font-size:clamp(2.8rem,7vw,5.6rem);line-height:1;color:var(--blechcream);
    display:inline-flex;align-items:center;gap:24px;
    letter-spacing:.02em;
  }
  .phone-strip .number svg{width:42px;height:42px;opacity:.9}
  .phone-strip .sub{
    margin-top:14px;
    font-family:var(--ff-hand);font-size:1.4rem;color:#ffd66b;
    transform:rotate(-1deg);display:inline-block;
  }

  /* ============= KONTAKT ============= */
  .contact-grid{
    display:grid;grid-template-columns:1fr 1fr 1fr;gap:50px;
  }
  .contact-block h3{
    font-family:var(--ff-headline);font-weight:700;
    color:var(--blechrot);
    margin-bottom:18px;
    font-size:2.2rem;letter-spacing:.02em;line-height:1;
  }
  .contact-block p{color:var(--ink);line-height:1.85}
  .contact-block ul{list-style:none}
  .contact-block .row{
    display:flex;justify-content:space-between;gap:24px;
    border-bottom:1px solid rgba(141,108,68,.25);padding:10px 0;
  }
  .contact-block .row:last-child{border-bottom:0}
  .contact-block .row span:first-child{
    color:var(--mute);letter-spacing:.04em;font-size:.85rem;text-transform:uppercase;
  }
  .contact-block .row span:last-child{
    font-family:var(--ff-body);font-weight:500;font-size:1rem;color:var(--ink);
  }
  .contact-block .note{
    margin-top:10px;font-size:.88rem;color:var(--mute);font-style:italic;
  }
  .contact-block a.big{
    font-family:var(--ff-headline);font-weight:700;
    font-size:2rem;color:var(--ink);letter-spacing:.02em;line-height:1;
    display:block;margin-top:10px;
    border-bottom:2px solid var(--blechrot);padding-bottom:6px;width:fit-content;
  }
  .contact-block a.big:hover{color:var(--blechrot)}

  /* ============= FOOTER ============= */
  footer.site{
    background:var(--ink);
    color:rgba(244,234,208,.75);
    padding:54px 0 32px;
    font-size:.85rem;text-align:center;
  }
  footer.site .wolfmark{
    width:80px;height:54px;color:var(--bg);
    display:block;margin:0 auto 14px;opacity:.92;
  }
  footer.site .stamp{
    display:inline-block;
    font-family:var(--ff-stamp);font-size:.68rem;letter-spacing:.4em;text-transform:uppercase;
    border:2px solid var(--blechcream);color:var(--blechcream);
    padding:6px 14px;margin-bottom:18px;opacity:.85;transform:rotate(-2deg);
  }
  footer.site .mark{
    font-family:var(--ff-headline);font-weight:700;
    color:var(--bg);font-size:2.2rem;letter-spacing:.02em;
    line-height:1;margin-bottom:6px;
  }
  footer.site .legal{
    margin-top:24px;display:flex;gap:24px;justify-content:center;flex-wrap:wrap;
    font-family:var(--ff-stamp);font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;
  }
  footer.site .legal a:hover{color:var(--bg)}

  /* ============= MOBILE DRAWER ============= */
  .drawer{
    position:fixed;inset:0;background:var(--bg);z-index:60;
    display:none;flex-direction:column;padding:120px 40px 40px;
  }
  .drawer.open{display:flex}
  .drawer a{
    color:var(--ink);font-family:var(--ff-headline);font-weight:700;
    font-size:2.6rem;letter-spacing:.02em;line-height:1;
    padding:18px 0;border-bottom:1px dashed rgba(141,108,68,.4);
  }
  .drawer a:last-child{color:var(--blechrot)}
  .drawer .close{
    position:absolute;top:24px;right:28px;background:none;border:0;
    color:var(--ink);font-size:2.2rem;cursor:pointer;
  }

  /* ============= RESPONSIVE ============= */
  @media (max-width: 980px){
    nav.primary{display:none}
    .nav-toggle{display:block}
    .card{padding:60px 32px}
    .hero{min-height:600px}
    .hero-sticker{right:24px;bottom:120px;transform:rotate(-6deg) scale(.85)}
    .story-grid,
    .menu-layout,
    .bg-grid,
    .contact-grid{grid-template-columns:1fr;gap:50px}
    .menu-stickers{grid-template-columns:1fr 1fr;gap:18px}
    .features{grid-template-columns:1fr}
    section.section{padding:60px 0}
    .quote-card{padding:60px 28px}
  }
  @media (max-width: 560px){
    .card{padding:48px 24px}
    .hero h1{font-size:2.6rem}
    .hero-sticker{display:none}
    .hero-meta{flex-direction:column;align-items:flex-start;gap:16px}
    .menu-stickers{grid-template-columns:1fr}
    .sticker-circle{width:170px;height:170px}
    .bg-grid .images{grid-template-columns:1fr}
    .bg-grid .images .img-frame:nth-child(1){margin-top:0}
  }

/* ============= PAGE HEADER (für Unterseiten) ============= */
.page-header{
  position:relative;
  min-height:380px;
  color:var(--white);
  overflow:hidden;
  display:flex;align-items:flex-end;
  padding:120px 28px 60px;
}
.page-header .page-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  filter:saturate(1.02) contrast(1.04);
}
.page-header .page-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, rgba(20,12,6,.35) 0%, rgba(20,12,6,.55) 60%, rgba(20,12,6,.85) 100%);
}
.page-header .container{position:relative;z-index:2;max-width:1240px;margin:0 auto}
.page-header .back-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-body);font-weight:500;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.85);
  margin-bottom:20px;
  border-bottom:1px solid transparent;
  padding-bottom:2px;
  transition:border-color .2s ease, color .2s ease;
}
.page-header .back-link:hover{border-color:var(--white);color:var(--white)}
.page-header .eyebrow{
  font-family:var(--ff-body);font-weight:600;
  font-size:.76rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--white);opacity:.95;
  margin-bottom:14px;
  display:flex;align-items:center;gap:14px;
}
.page-header .eyebrow::before{
  content:"";width:36px;height:1px;background:var(--white);
}
.page-header h1{
  color:var(--white);
  text-shadow:0 2px 24px rgba(0,0,0,.4);
  font-size:clamp(3rem,7vw,6rem);
  line-height:.95;
}
.page-header .lede{
  font-family:var(--ff-body);
  font-size:clamp(1rem,1.2vw,1.2rem);
  max-width:50ch;margin-top:16px;
  color:rgba(255,255,255,.9);
  line-height:1.55;
}

/* Cross-sell-Sektion auf Unterseiten */
.cross-sell{text-align:center}
.cross-sell h2{margin-bottom:32px}

@media (max-width: 980px){
  .page-header{min-height:300px;padding:100px 24px 40px}
}

/* ============= GALERIE ============= */
.sp-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:14px;
}
.sp-gallery-item{
  display:block;
  aspect-ratio:1/1;
  overflow:hidden;
  cursor:zoom-in;
  position:relative;
  background:var(--paper-deep);
  border-radius:2px;
  box-shadow:0 4px 12px -4px rgba(58,42,28,.18);
}
.sp-gallery-item img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform .5s ease;
}
.sp-gallery-item:hover img{transform:scale(1.06)}

/* Homepage-Teaser: kompakter, max 8 Bilder */
.sp-gallery.sp-gallery-teaser{
  grid-template-columns:repeat(4, 1fr);
}
@media (max-width: 780px){
  .sp-gallery.sp-gallery-teaser{ grid-template-columns:repeat(2, 1fr); }
}

/* ============= LIGHTBOX ============= */
.sp-lightbox{
  position:fixed;inset:0;
  z-index:1000;
  background:rgba(15,10,5,.94);
  display:none;
  align-items:center;justify-content:center;
  animation:sp-fade-in .25s ease;
}
.sp-lightbox.is-open{display:flex}
@keyframes sp-fade-in{from{opacity:0}to{opacity:1}}
.sp-lightbox img{
  max-width:90vw;max-height:88vh;
  object-fit:contain;
  box-shadow:0 24px 60px rgba(0,0,0,.5);
}
.sp-lightbox-close,
.sp-lightbox-prev,
.sp-lightbox-next{
  position:absolute;
  background:rgba(255,255,255,.08);
  color:var(--white);
  border:0;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  transition:background .2s ease;
}
.sp-lightbox-close:hover,
.sp-lightbox-prev:hover,
.sp-lightbox-next:hover{ background:rgba(255,255,255,.18) }
.sp-lightbox-close{
  top:24px;right:24px;width:44px;height:44px;font-size:24px;line-height:1;
}
.sp-lightbox-prev,.sp-lightbox-next{
  top:50%;transform:translateY(-50%);width:56px;height:56px;font-size:30px;line-height:1;
}
.sp-lightbox-prev{ left:24px }
.sp-lightbox-next{ right:24px }
.sp-lightbox-counter{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.7);
  font-family:var(--ff-body);font-size:.85rem;letter-spacing:.06em;
}
@media (max-width:560px){
  .sp-lightbox-prev,.sp-lightbox-next{width:44px;height:44px;font-size:24px}
  .sp-lightbox-prev{left:8px} .sp-lightbox-next{right:8px}
}

/* ============= HOMEPAGE-GALERIE-TEASER ============= */
.gallery-block{ text-align:center }
.gallery-block .menu-pills{ margin-top:36px; justify-content:center }
