:root{
  --bg:#130d08; --bg2:#211409; --paper:#fff8eb; --paper2:#f3e2c3; --ink:#2a1609; --muted:#7b6448;
  --gold:#f5b43f; --amber:#d87921; --foam:#fff3d4; --green:#51713a; --hop:#8fb85f; --danger:#b8422d;
  --line:rgba(255,255,255,.18); --shadow:0 24px 70px rgba(30,12,0,.22); --radius:28px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:linear-gradient(135deg,#170e08,#2c1608 48%,#100c08);color:var(--ink);line-height:1.6} a{color:inherit} .container{width:min(1160px,calc(100% - 36px));margin-inline:auto}.narrow{width:min(820px,calc(100% - 36px));}.skip-link{position:absolute;left:-999px;top:12px;background:#fff;padding:.6rem 1rem;border-radius:1rem;z-index:1000}.skip-link:focus{left:12px}.site-header{position:sticky;top:0;z-index:50;background:rgba(19,13,8,.84);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.header-inner,.admin-topbar-inner{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{display:flex;align-items:center;gap:.85rem;text-decoration:none;color:#fff}.brand.compact{color:var(--ink)}.brand-mark{display:grid;place-items:center;width:52px;height:52px;border-radius:18px;background:linear-gradient(145deg,var(--gold),#fff0b6 52%,var(--amber));color:#2a1609;font-weight:950;letter-spacing:-.08em;box-shadow:0 14px 28px rgba(216,121,33,.25)}.brand strong{display:block;font-size:1rem;line-height:1.1}.brand small{display:block;color:#e5cfa6;font-size:.78rem}.main-nav{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap}.main-nav a{color:#f6ead4;text-decoration:none;padding:.7rem .95rem;border-radius:999px;font-weight:750}.main-nav a:hover,.main-nav a.active{background:rgba(255,255,255,.12);color:#fff}.hero{position:relative;overflow:hidden;color:#fff;padding:clamp(56px,8vw,108px) 0;background:radial-gradient(circle at 15% 20%,rgba(245,180,63,.24),transparent 32%),radial-gradient(circle at 80% 30%,rgba(143,184,95,.16),transparent 34%)}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(245,180,63,.08),transparent 45%),repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 80px);mask-image:linear-gradient(#000,transparent 90%)}.hero-grid{position:relative;display:grid;grid-template-columns:1.06fr .72fr;align-items:center;gap:clamp(32px,7vw,90px)}.kicker{display:inline-flex;align-items:center;gap:.5rem;color:#a7d46e;text-transform:uppercase;letter-spacing:.14em;font-weight:900;font-size:.78rem}.hero h1{font-size:clamp(3rem,8vw,6.4rem);line-height:.91;margin:.55rem 0 1rem;letter-spacing:-.075em;max-width:860px}.hero p{max-width:680px;font-size:clamp(1.08rem,2vw,1.35rem);color:#f3dfbd}.hero-actions,.age-actions,.cookie-actions,.actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;padding:.78rem 1.05rem;border:0;border-radius:999px;background:#fff;color:var(--ink);font-weight:900;text-decoration:none;cursor:pointer;box-shadow:0 10px 25px rgba(0,0,0,.12)}.btn.primary{background:linear-gradient(135deg,var(--gold),#ffdf81);color:#2a1609}.btn.glass,.btn.ghost{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff}.btn.small{min-height:34px;padding:.48rem .75rem;font-size:.88rem}.btn.danger{background:#fff1ee;color:#872815}.text-link{font-weight:900;color:#8b4c12;text-decoration:none}.text-link:hover{text-decoration:underline}.beer-visual{position:relative;width:min(360px,70vw);height:460px;margin-inline:auto;border:10px solid rgba(255,255,255,.24);border-top:0;border-radius:32px 32px 72px 72px;background:linear-gradient(90deg,rgba(255,255,255,.19),rgba(255,255,255,.06) 35%,rgba(255,255,255,.19));box-shadow:inset 0 0 40px rgba(255,255,255,.13),0 40px 90px rgba(0,0,0,.34);overflow:hidden}.beer-liquid{position:absolute;left:0;right:0;bottom:0;height:72%;background:linear-gradient(#ffd66b,#ee9c20 55%,#b85b12);animation:sway 4.4s ease-in-out infinite}.beer-liquid:before{content:"";position:absolute;left:-10%;right:-10%;top:-20px;height:42px;border-radius:50%;background:#fff1c4;opacity:.9;animation:wave 5s ease-in-out infinite}.foam{position:absolute;background:#fff4d4;border-radius:50%;z-index:3;box-shadow:0 12px 28px rgba(255,244,212,.18)}.foam-a{width:160px;height:74px;left:12px;top:22px}.foam-b{width:190px;height:92px;left:92px;top:4px}.foam-c{width:110px;height:68px;right:18px;top:58px}.glass-shine{position:absolute;z-index:4;top:55px;left:30px;width:42px;height:330px;border-radius:999px;background:linear-gradient(rgba(255,255,255,.55),transparent);opacity:.42}.bubble{position:absolute;bottom:28px;width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.55);animation:rise 4s infinite ease-in}.b1{left:32%;animation-delay:.1s}.b2{left:55%;animation-delay:1.2s}.b3{left:72%;animation-delay:2.1s}@keyframes rise{from{transform:translateY(0);opacity:.5}to{transform:translateY(-280px);opacity:0}}@keyframes wave{50%{transform:translateX(8%)}}@keyframes sway{50%{filter:saturate(1.18)}}.section{padding:clamp(44px,7vw,86px) 0}.section-head{margin-bottom:1.35rem;color:#fff}.section-head h2,.page-hero h1{font-size:clamp(2rem,4.4vw,4rem);line-height:1;letter-spacing:-.055em;margin:.35rem 0}.section-head p{color:#e5cfa6;margin:.2rem 0}.row-head{display:flex;justify-content:space-between;align-items:end;gap:1rem}.menu-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.menu-card{position:relative;min-height:248px;padding:1.35rem;border-radius:var(--radius);text-decoration:none;color:#2a1609;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:space-between;transition:.22s transform,.22s box-shadow}.menu-card:hover{transform:translateY(-5px);box-shadow:0 35px 85px rgba(0,0,0,.30)}.menu-card:after{content:"";position:absolute;inset:auto -20% -40% -20%;height:70%;border-radius:50%;background:rgba(255,255,255,.23)}.menu-card strong{display:block;font-size:1.3rem;line-height:1.1}.menu-card small{display:block;margin-top:.35rem;color:rgba(42,22,9,.76);font-weight:750}.menu-card .art{position:relative;z-index:1;width:96px;height:96px;display:grid;place-items:center;border-radius:28px;background:rgba(255,255,255,.34)}.menu-card svg{width:70px;height:70px;fill:none;stroke:currentColor;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}.menu-card.amber{background:linear-gradient(145deg,#f7c667,#d8701c)}.menu-card.gold{background:linear-gradient(145deg,#fff0b1,#efaa2f)}.menu-card.green{background:linear-gradient(145deg,#c3dd8b,#6f943f)}.menu-card.cream{background:linear-gradient(145deg,#fffaf0,#d6bd8c)}.split-section{display:grid;grid-template-columns:1.2fr .8fr;gap:1.2rem;align-items:stretch}.card,.post-card,.beer-card,.stat-card,.login-card{background:linear-gradient(145deg,rgba(255,248,235,.98),rgba(243,226,195,.96));border:1px solid rgba(255,255,255,.55);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(1.2rem,3vw,2rem)}.story-card h2{font-size:clamp(2rem,4vw,3.4rem);line-height:1;margin:.35rem 0;color:#2a1609}.feature-stack{display:grid;gap:1rem}.feature-stack div{background:rgba(255,248,235,.94);border-radius:24px;padding:1.25rem;border-left:7px solid var(--gold)}.feature-stack strong{display:block;font-size:1.05rem}.feature-stack span{color:#6d563a}.beer-grid,.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.beer-grid.big{grid-template-columns:repeat(2,1fr)}.post-grid.wide{grid-template-columns:repeat(2,1fr)}.beer-card{position:relative;overflow:hidden}.beer-card:before{content:"";position:absolute;right:-70px;top:-70px;width:170px;height:170px;border-radius:50%;background:rgba(255,255,255,.35)}.beer-card.golden{border-top:8px solid #efaa2f}.beer-card.amber{border-top:8px solid #bd681c}.beer-card.dark{border-top:8px solid #3c2114}.beer-badge,.pill{display:inline-flex;border-radius:999px;background:rgba(42,22,9,.09);padding:.25rem .6rem;font-size:.78rem;font-weight:900;color:#6f3d12}.beer-card h2,.beer-card h3,.post-card h2,.post-card h3{line-height:1.08;margin:.75rem 0 .5rem}.beer-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.beer-meta span{background:#2a1609;color:#fff;border-radius:999px;padding:.35rem .65rem;font-weight:900;font-size:.84rem}.post-card time{font-weight:900;color:#8b4c12}.post-card a{text-decoration:none}.post-card a:hover{text-decoration:underline}.page-hero{color:#fff;padding:clamp(54px,7vw,92px) 0;background:radial-gradient(circle at 20% 20%,rgba(245,180,63,.23),transparent 34%),linear-gradient(135deg,#241107,#100c08)}.page-hero.compact p{max-width:760px;color:#efd7ae;font-size:1.15rem}.page-hero.wood{background:linear-gradient(135deg,rgba(42,22,9,.96),rgba(74,42,16,.9)),repeating-linear-gradient(90deg,#422611 0 28px,#513017 28px 56px)}.prose{font-size:1.06rem}.prose h1,.prose h2,.prose h3{line-height:1.12;color:#2a1609;margin-top:1.3em}.prose p,.prose li{color:#59442b}.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:1.2rem}.form{display:grid;gap:1rem}.form label{display:grid;gap:.35rem;font-weight:850;color:#3b2411}.form input,.form textarea,.form select{width:100%;border:1px solid rgba(42,22,9,.18);border-radius:16px;padding:.85rem 1rem;font:inherit;background:#fff;color:#2a1609}.form textarea{resize:vertical}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.check{display:flex!important;grid-template-columns:auto 1fr!important;align-items:flex-start;gap:.65rem!important;font-weight:650!important}.check input{width:auto;margin-top:.35rem}.standalone{padding:.75rem 0}.flash,.notice,.success-panel{border-radius:18px;padding:1rem;margin-bottom:1rem}.flash.success,.success-panel{background:#eef8e8;color:#28451d}.flash.error{background:#ffeae4;color:#872815}.notice{background:#fff2cf;color:#66400c;border:1px solid rgba(245,180,63,.5)}.age-gate{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:1rem;background:radial-gradient(circle at 50% 20%,rgba(245,180,63,.28),transparent 30%),rgba(16,12,8,.88);backdrop-filter:blur(18px)}.age-gate[hidden]{display:none}.age-card{width:min(560px,100%);padding:2rem;border-radius:34px;background:linear-gradient(145deg,#fff8eb,#f0d9ad);box-shadow:0 50px 130px rgba(0,0,0,.45);color:#2a1609}.age-kicker{font-weight:950;color:#8b4c12;text-transform:uppercase;letter-spacing:.12em;font-size:.75rem}.age-card h2{font-size:clamp(2rem,6vw,3.2rem);line-height:1;margin:.5rem 0}.age-unknown{overflow:hidden}.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:180;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:#fff8eb;color:#2a1609;border-radius:24px;padding:1rem;box-shadow:0 20px 60px rgba(0,0,0,.3);border:1px solid rgba(42,22,9,.12)}.cookie-banner[hidden]{display:none}.cookie-banner p{margin:.2rem 0 0;color:#6d563a}.link-button{border:0;background:transparent;padding:0;color:inherit;text-align:left;cursor:pointer;font:inherit;text-decoration:underline}.site-footer{background:#0e0a07;color:#fff;padding:2.2rem 0;border-top:1px solid var(--line)}.footer-grid{display:grid;grid-template-columns:1.3fr .8fr 1fr;gap:2rem}.site-footer a,.site-footer button{display:block;color:#f3dfbd;margin:.3rem 0}.muted{color:#7b6448}.small{font-size:.86rem}.site-footer .muted{color:#c9b38d}.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 30% 15%,rgba(245,180,63,.25),transparent 32%),linear-gradient(135deg,#170e08,#321708)}.login-shell{width:min(520px,calc(100% - 32px))}.login-brand{color:#2a1609;margin-bottom:1rem}.login-brand small{color:#6d563a}.login-card h1{font-size:2.4rem;line-height:1;margin:.6rem 0}.admin-site{background:#f3ead9;color:#2a1609}.admin-topbar{background:#fff8eb;border-bottom:1px solid rgba(42,22,9,.10);position:sticky;top:0;z-index:60}.admin-user{font-weight:800}.admin-layout{display:grid;grid-template-columns:260px 1fr;gap:1.2rem;padding:1.2rem 0 3rem}.admin-sidebar{position:sticky;top:96px;align-self:start;background:#2a1609;color:#fff;border-radius:24px;padding:.75rem;display:grid;gap:.25rem}.admin-sidebar a{color:#f3dfbd;text-decoration:none;padding:.75rem .85rem;border-radius:16px;font-weight:850}.admin-sidebar a:hover,.admin-sidebar a.active{background:rgba(255,255,255,.12);color:#fff}.admin-content h1{font-size:2.4rem;line-height:1;margin:.2rem 0 1rem}.admin-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem}.stat-card span{display:block;color:#7b6448;font-weight:850}.stat-card strong{font-size:2.5rem;line-height:1}.admin-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.table-wrap{overflow:auto;background:#fff8eb;border-radius:24px;box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:1rem;border-bottom:1px solid rgba(42,22,9,.08);vertical-align:top}th{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:#7b6448}.actions{display:flex;gap:.45rem;align-items:center;flex-wrap:wrap}.actions form{display:inline}.admin-two-col{display:grid;grid-template-columns:300px 1fr;gap:1rem}.page-list{display:grid;gap:.4rem;align-self:start}.page-list a{text-decoration:none;padding:.8rem;border-radius:16px;background:rgba(42,22,9,.06);font-weight:900}.page-list a.active{background:#2a1609;color:#fff}.page-list small{display:block;font-weight:600;opacity:.72}.message-list{display:grid;gap:1rem}.message-card header{display:flex;justify-content:space-between;gap:1rem}.message-card small{display:block;color:#7b6448}.message-card.unread{border-left:8px solid var(--gold)}
@media (max-width:900px){.header-inner{align-items:flex-start;flex-direction:column;padding:1rem 0}.hero-grid,.split-section,.contact-grid,.admin-layout,.admin-two-col{grid-template-columns:1fr}.menu-tiles,.beer-grid,.post-grid,.beer-grid.big,.post-grid.wide,.admin-cards,.footer-grid{grid-template-columns:1fr 1fr}.admin-sidebar{position:static}.form-grid{grid-template-columns:1fr}.beer-visual{height:340px}.cookie-banner{flex-direction:column;align-items:flex-start}.row-head{align-items:flex-start;flex-direction:column}}
@media (max-width:560px){.container,.narrow{width:min(100% - 24px,1160px)}.menu-tiles,.beer-grid,.post-grid,.admin-cards,.footer-grid{grid-template-columns:1fr}.main-nav a{padding:.55rem .7rem}.hero{padding:42px 0}.hero h1{font-size:3rem}.beer-visual{width:230px;height:300px}.card,.post-card,.beer-card,.stat-card,.login-card{border-radius:22px;padding:1rem}.age-card{padding:1.2rem}.admin-head{flex-direction:column;align-items:flex-start}}

/* v0.1.1: bessere Lesbarkeit für rechtliche Seiten */
.legal-page{
  margin-top:clamp(28px,4vw,52px);
  margin-bottom:clamp(42px,6vw,76px);
  padding:clamp(1.35rem,3.4vw,2.6rem)!important;
  background:linear-gradient(145deg,#fffdf7 0%,#fff7e8 58%,#f4e4c8 100%);
  color:#241307;
  border:1px solid rgba(80,43,13,.18);
  border-radius:30px;
  box-shadow:0 26px 80px rgba(17,9,3,.34);
}
.legal-page h1,
.legal-page h2,
.legal-page h3{
  color:#201004;
  letter-spacing:-.025em;
}
.legal-page h2{
  padding-top:.9rem;
  margin-top:1.45rem;
  border-top:1px solid rgba(80,43,13,.14);
}
.legal-page h2:first-child{
  padding-top:0;
  margin-top:0;
  border-top:0;
}
.legal-page p,
.legal-page li,
.legal-page dd{
  color:#302014;
}
.legal-page strong,
.legal-page b{
  color:#170b03;
}
.legal-page a{
  color:#7a3900;
  font-weight:850;
  text-decoration:underline;
  text-underline-offset:.16em;
}
.legal-page a:hover{
  color:#4b2100;
}
.legal-page ul,
.legal-page ol{
  padding-left:1.45rem;
}
.legal-page li::marker{
  color:#9b5a15;
  font-weight:900;
}
.legal-page .notice{
  background:#fff0c7;
  color:#3a2207;
  border-color:rgba(153,92,21,.38);
}
.legal-page .notice strong{
  color:#241307;
}
@media (max-width:700px){
  .legal-page{
    border-radius:22px;
    margin-top:1rem;
    padding:1.1rem!important;
  }
}


/* v0.1.2: grafisches Top-Menü im Stil einer modernen Braumanufaktur */
.site-header{
  background:linear-gradient(180deg,rgba(14,10,7,.97),rgba(22,13,7,.94));
  border-bottom:1px solid rgba(210,139,55,.38);
  box-shadow:0 18px 55px rgba(0,0,0,.28);
}
.header-inner{
  min-height:106px;
}
.brand-mark{
  border-radius:50%;
  background:radial-gradient(circle at 35% 25%,#ffe0a3,#c8792b 48%,#3a1b08 100%);
  color:#fff4d6;
  border:1px solid rgba(255,221,154,.58);
  box-shadow:0 0 0 6px rgba(207,126,42,.12),0 18px 35px rgba(0,0,0,.28);
}
.brand strong{
  font-family:Georgia,'Times New Roman',serif;
  font-size:1.28rem;
  letter-spacing:.01em;
}
.brand small{
  color:#dca85c;
  font-weight:800;
}
.graphic-nav{
  display:grid;
  grid-template-columns:repeat(4,minmax(122px,1fr));
  gap:.65rem;
  flex:1;
  max-width:760px;
  justify-content:end;
}
.graphic-nav .graphic-nav-card,
.main-nav .graphic-nav-card{
  display:grid;
  grid-template-columns:42px 1fr;
  align-items:center;
  gap:.62rem;
  min-height:68px;
  padding:.62rem .72rem;
  border-radius:20px;
  color:#fff4dd;
  text-decoration:none;
  background:linear-gradient(145deg,rgba(44,31,22,.95),rgba(17,12,8,.95));
  border:1px solid rgba(225,153,73,.36);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 14px 28px rgba(0,0,0,.24);
  position:relative;
  overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}
.graphic-nav-card:before{
  content:"";
  position:absolute;
  inset:-70% -40% auto auto;
  width:120px;
  height:120px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(230,157,76,.24),transparent 68%);
}
.graphic-nav-card:hover,
.graphic-nav-card.active{
  transform:translateY(-2px);
  border-color:rgba(255,194,104,.78);
  background:linear-gradient(145deg,rgba(69,43,22,.98),rgba(21,14,9,.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.13),0 20px 42px rgba(0,0,0,.34);
}
.graphic-nav-icon{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:15px;
  color:#ffc66d;
  background:linear-gradient(145deg,rgba(255,207,128,.14),rgba(255,255,255,.04));
  border:1px solid rgba(255,198,109,.28);
  position:relative;
  z-index:1;
}
.graphic-nav-icon svg{
  width:29px;
  height:29px;
  fill:none;
  stroke:currentColor;
  stroke-width:4;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.graphic-nav-text{
  position:relative;
  z-index:1;
  line-height:1.1;
}
.graphic-nav-text strong{
  display:block;
  font-size:.9rem;
  letter-spacing:.01em;
}
.graphic-nav-text small{
  display:block;
  margin-top:.16rem;
  color:#d6b98b;
  font-size:.71rem;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.hero{
  background:
    radial-gradient(circle at 11% 54%,rgba(245,180,63,.2),transparent 24%),
    radial-gradient(circle at 78% 32%,rgba(205,111,31,.24),transparent 30%),
    linear-gradient(120deg,rgba(16,12,8,.78),rgba(25,15,8,.92)),
    repeating-linear-gradient(90deg,#2b1709 0 34px,#3b210f 34px 68px);
}
.hero-copy .kicker{
  color:#ffc66d;
}
.menu-card{
  border:1px solid rgba(255,204,121,.58);
  color:#fff3d9;
  background:linear-gradient(145deg,#2b2016,#100c08)!important;
}
.menu-card:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,194,104,.14),transparent 46%);
  pointer-events:none;
}
.menu-card:after{
  background:radial-gradient(circle,rgba(255,194,104,.13),transparent 65%);
}
.menu-card strong{
  font-family:Georgia,'Times New Roman',serif;
  color:#fff6df;
  font-size:1.52rem;
}
.menu-card small{
  color:#d8bc8d;
}
.menu-card .art{
  color:#ffc66d;
  background:linear-gradient(145deg,rgba(255,207,128,.13),rgba(255,255,255,.035));
  border:1px solid rgba(255,198,109,.32);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
}
.menu-card svg{
  stroke-width:3.1;
}
.menu-card.copper{
  background:linear-gradient(145deg,#332115,#100c08)!important;
}
@media (max-width:1100px){
  .header-inner{
    flex-direction:column;
    align-items:stretch;
    padding:1rem 0;
  }
  .brand{
    justify-content:center;
  }
  .graphic-nav{
    max-width:none;
    width:100%;
  }
}
@media (max-width:760px){
  .graphic-nav{
    grid-template-columns:repeat(2,1fr);
  }
  .graphic-nav .graphic-nav-card,
  .main-nav .graphic-nav-card{
    min-height:64px;
  }
}
@media (max-width:430px){
  .graphic-nav{
    gap:.48rem;
  }
  .graphic-nav .graphic-nav-card,
  .main-nav .graphic-nav-card{
    grid-template-columns:34px 1fr;
    gap:.48rem;
    padding:.5rem;
    border-radius:17px;
  }
  .graphic-nav-icon{
    width:34px;
    height:34px;
    border-radius:12px;
  }
  .graphic-nav-icon svg{
    width:24px;
    height:24px;
  }
  .graphic-nav-text strong{
    font-size:.78rem;
  }
  .graphic-nav-text small{
    display:none;
  }
}

/* v0.1.3: Premium-Startseite näher am gelieferten Braumanufaktur-Mockup */
body.public-site{
  background:#120c08;
}
.premium-header{
  position:sticky;
  top:0;
  z-index:80;
  background:linear-gradient(180deg,#12100d 0%,#0d0b09 100%);
  border-bottom:2px solid rgba(190,116,44,.62);
  box-shadow:0 18px 55px rgba(0,0,0,.34);
}
.premium-header .container{
  width:min(1480px,calc(100% - 42px));
}
.premium-header .header-inner{
  min-height:104px;
  align-items:center;
  display:grid;
  grid-template-columns:minmax(260px,360px) 1fr minmax(230px,330px);
  gap:1.5rem;
}
.premium-header .brand{
  gap:1rem;
}
.premium-header .brand-mark{
  width:72px;
  height:72px;
  border-radius:50%;
  font-family:Georgia,'Times New Roman',serif;
  font-size:2.15rem;
  letter-spacing:-.08em;
  color:#ffe6ad;
  background:
    radial-gradient(circle at 36% 25%,rgba(255,231,176,.35),transparent 24%),
    linear-gradient(145deg,#5a2b0d,#19100a 58%,#090705);
  border:2px solid rgba(214,145,65,.86);
  box-shadow:0 0 0 5px rgba(210,128,49,.12),0 22px 40px rgba(0,0,0,.36);
  position:relative;
}
.premium-header .brand-mark:before,
.premium-header .brand-mark:after{
  content:"";
  position:absolute;
  inset:8px;
  border-radius:50%;
  border:1px solid rgba(255,209,134,.34);
}
.premium-header .brand strong{
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(1.3rem,2vw,2rem);
  color:#fff8ec;
  letter-spacing:.01em;
}
.premium-header .brand small{
  font-family:Georgia,'Times New Roman',serif;
  color:#cf8a45;
  font-size:clamp(.95rem,1.3vw,1.25rem);
  letter-spacing:.04em;
}
.text-nav{
  justify-content:center;
  gap:1.15rem;
  flex-wrap:wrap;
}
.text-nav a{
  color:#efe4d1;
  border-radius:0;
  padding:.65rem .1rem .48rem;
  text-transform:uppercase;
  letter-spacing:.11em;
  font-size:.86rem;
  font-weight:850;
  position:relative;
}
.text-nav a:hover,
.text-nav a.active{
  background:transparent;
  color:#d89445;
}
.text-nav a:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:.08rem;
  height:2px;
  background:linear-gradient(90deg,transparent,#d89445,transparent);
  transform:scaleX(0);
  transition:transform .2s ease;
}
.text-nav a:hover:after,
.text-nav a.active:after{
  transform:scaleX(1);
}
.header-claim{
  justify-self:end;
  color:#d89445;
  border-left:1px solid rgba(218,144,70,.46);
  padding-left:1.35rem;
  display:grid;
  grid-template-columns:36px auto;
  column-gap:.8rem;
  align-items:center;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.header-claim span{
  grid-row:1 / span 2;
  width:36px;
  height:36px;
  display:grid;
  place-items:center;
}
.header-claim svg{
  width:34px;
  height:34px;
  fill:none;
  stroke:currentColor;
  stroke-width:4;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.header-claim strong{
  font-size:.76rem;
  line-height:1.25;
}
.header-claim small{
  color:#f2dfbd;
  font-size:.7rem;
  justify-self:center;
  position:relative;
}
.brewery-hero{
  overflow:visible;
  padding:54px 0 0;
  min-height:660px;
  background:
    linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.22) 76%,rgba(255,248,235,.04) 100%),
    url('../img/hero-brewery-atmosphere.jpg') center/cover no-repeat,
    #120c08;
  border-bottom:0;
}
.brewery-hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 50% 45%,rgba(0,0,0,.04),rgba(0,0,0,.48) 76%),
    linear-gradient(90deg,rgba(0,0,0,.24),transparent 25%,transparent 74%,rgba(0,0,0,.18));
  mask-image:none;
  pointer-events:none;
}
.brewery-hero .container{
  width:min(1420px,calc(100% - 42px));
}
.hero-stage{
  position:relative;
  z-index:2;
  display:grid;
  justify-items:center;
  text-align:center;
}
.hero-ornament{
  display:grid;
  grid-template-columns:120px 24px 120px;
  gap:1rem;
  align-items:center;
  color:#bc7836;
  opacity:.96;
  margin-top:.25rem;
}
.hero-ornament span{
  height:1px;
  background:linear-gradient(90deg,transparent,#bc7836);
}
.hero-ornament span:last-child{
  background:linear-gradient(90deg,#bc7836,transparent);
}
.hero-ornament svg{
  width:24px;
  height:24px;
  fill:none;
  stroke:currentColor;
  stroke-width:4;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.hero-ornament.bottom{
  margin-top:1.15rem;
  grid-template-columns:150px 28px 150px;
}
.premium-copy{
  max-width:1050px;
}
.premium-copy .kicker{
  display:block;
  color:#c78643;
  font-family:Georgia,'Times New Roman',serif;
  text-transform:uppercase;
  letter-spacing:.26em;
  font-size:clamp(.8rem,1.25vw,1.12rem);
  margin:.85rem 0 .65rem;
}
.premium-copy h1{
  margin:0;
  display:grid;
  gap:.1rem;
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(3.5rem,8.3vw,8.3rem);
  line-height:.83;
  letter-spacing:.035em;
  text-transform:uppercase;
  text-shadow:0 10px 32px rgba(0,0,0,.55),0 2px 0 rgba(255,255,255,.1);
  max-width:none;
}
.premium-copy h1 span{
  color:#fff7eb;
}
.premium-copy h1 em{
  font-style:normal;
  color:#c7833e;
  font-size:.56em;
  letter-spacing:.15em;
}
.premium-copy p{
  margin:1rem auto 0;
  max-width:none;
  color:#fff3dc;
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(1.05rem,1.65vw,1.45rem);
  font-style:italic;
  text-shadow:0 3px 18px rgba(0,0,0,.58);
}
.hero-menu-tiles{
  width:100%;
  margin-top:2.65rem;
  display:grid;
  grid-template-columns:repeat(4,minmax(190px,1fr));
  gap:1.25rem;
  transform:translateY(76px);
}
.hero-menu-card{
  min-height:245px;
  border-radius:18px;
  padding:1.35rem 1rem 1.5rem;
  text-decoration:none;
  color:#fff2dd;
  display:grid;
  justify-items:center;
  align-content:center;
  gap:1rem;
  background:
    radial-gradient(circle at 50% 0%,rgba(247,190,106,.13),transparent 38%),
    linear-gradient(145deg,rgba(46,36,27,.98),rgba(15,12,9,.98));
  border:1px solid rgba(221,143,65,.72);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 22px 42px rgba(0,0,0,.42),0 3px 0 rgba(89,44,15,.84);
  position:relative;
  overflow:hidden;
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.hero-menu-card:before{
  content:"";
  position:absolute;
  width:162px;
  height:162px;
  border:1px solid rgba(221,151,76,.55);
  border-radius:50%;
  top:1.25rem;
  left:50%;
  transform:translateX(-50%);
}
.hero-menu-card:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.06),transparent 34%,rgba(205,116,43,.10));
  pointer-events:none;
}
.hero-menu-card:hover{
  transform:translateY(-7px) scale(1.012);
  border-color:#ffc46d;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 32px 56px rgba(0,0,0,.52),0 3px 0 rgba(112,57,20,.92);
}
.hero-menu-icon{
  position:relative;
  z-index:2;
  width:112px;
  height:112px;
  display:grid;
  place-items:center;
  color:#e2a15a;
}
.hero-menu-icon svg{
  width:104px;
  height:104px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.6;
  stroke-linecap:round;
  stroke-linejoin:round;
  filter:drop-shadow(0 3px 0 rgba(0,0,0,.38));
}
.hero-menu-card strong{
  position:relative;
  z-index:2;
  font-family:Georgia,'Times New Roman',serif;
  color:#fff5e6;
  font-size:clamp(1.35rem,1.8vw,1.9rem);
  line-height:1.08;
  letter-spacing:-.02em;
  text-shadow:0 3px 16px rgba(0,0,0,.6);
}
.cream-band{
  background:
    radial-gradient(circle at 6% 10%,rgba(196,125,50,.10),transparent 22%),
    radial-gradient(circle at 94% 8%,rgba(196,125,50,.10),transparent 24%),
    linear-gradient(180deg,#fff4df,#f6e5c7);
}
.first-band{
  padding-top:78px;
}
.dark-band{
  background:linear-gradient(135deg,#160e09,#2c180b 48%,#120d08);
}
.section-title-dark{
  color:#251407;
  text-align:center;
  margin-bottom:1.6rem;
}
.section-title-dark.row-head{
  text-align:left;
}
.section-title-dark span{
  display:inline-flex;
  align-items:center;
  gap:.7rem;
  color:#9d5a1b;
  font-family:Georgia,'Times New Roman',serif;
  font-style:italic;
  font-weight:800;
}
.section-title-dark span:before,
.section-title-dark span:after{
  content:"";
  width:58px;
  height:1px;
  background:linear-gradient(90deg,transparent,#b46e2f);
}
.section-title-dark span:after{
  background:linear-gradient(90deg,#b46e2f,transparent);
}
.section-title-dark.row-head span:before,
.section-title-dark.row-head span:after{
  display:none;
}
.section-title-dark h2{
  margin:.2rem 0 0;
  color:#160d08;
  font-family:Georgia,'Times New Roman',serif;
  text-transform:uppercase;
  letter-spacing:.09em;
  font-size:clamp(2rem,4.2vw,3.8rem);
  line-height:1;
}
.center-action{
  text-align:center;
  margin:1.6rem 0 0;
}
.premium-story{
  background:linear-gradient(145deg,#fff8eb,#ead3aa);
}
.premium-stack div{
  background:rgba(255,248,235,.97);
  border-left-color:#c9823e;
}
.beer-intro-section .beer-card,
.cream-band .post-card{
  box-shadow:0 20px 54px rgba(58,25,6,.17);
}
@media (max-width:1180px){
  .premium-header .header-inner{
    grid-template-columns:1fr;
    justify-items:center;
    padding:1rem 0;
  }
  .header-claim{
    display:none;
  }
  .text-nav{
    width:100%;
  }
  .hero-menu-tiles{
    grid-template-columns:repeat(2,minmax(210px,1fr));
    max-width:760px;
  }
  .brewery-hero{
    min-height:850px;
  }
}
@media (max-width:760px){
  .premium-header .container,
  .brewery-hero .container{
    width:min(100% - 24px,1420px);
  }
  .premium-header .brand-mark{
    width:58px;
    height:58px;
    font-size:1.72rem;
  }
  .text-nav{
    gap:.7rem;
  }
  .text-nav a{
    font-size:.74rem;
    letter-spacing:.08em;
  }
  .brewery-hero{
    min-height:820px;
    padding-top:38px;
    background-position:center;
  }
  .hero-ornament{
    grid-template-columns:76px 22px 76px;
  }
  .premium-copy h1{
    font-size:clamp(2.85rem,15vw,5rem);
  }
  .premium-copy h1 em{
    font-size:.45em;
  }
  .hero-menu-tiles{
    grid-template-columns:repeat(2,1fr);
    gap:.85rem;
    margin-top:2rem;
    transform:translateY(60px);
  }
  .hero-menu-card{
    min-height:176px;
    border-radius:16px;
    padding:1rem .7rem;
  }
  .hero-menu-card:before{
    width:104px;
    height:104px;
    top:.9rem;
  }
  .hero-menu-icon{
    width:78px;
    height:78px;
  }
  .hero-menu-icon svg{
    width:72px;
    height:72px;
  }
  .hero-menu-card strong{
    font-size:1.08rem;
  }
  .first-band{
    padding-top:54px;
  }
  .section-title-dark span:before,
  .section-title-dark span:after{
    width:34px;
  }
}
@media (max-width:460px){
  .text-nav{
    justify-content:flex-start;
    overflow:auto;
    flex-wrap:nowrap;
    padding-bottom:.25rem;
  }
  .text-nav a{
    flex:0 0 auto;
  }
  .hero-menu-tiles{
    grid-template-columns:1fr 1fr;
  }
  .hero-menu-card{
    min-height:154px;
  }
  .hero-menu-icon{
    width:64px;
    height:64px;
  }
  .hero-menu-icon svg{
    width:60px;
    height:60px;
  }
}

/* v0.1.4: Wechselbares Logo */
.brand-logo{
  display:grid;
  place-items:center;
  width:52px;
  height:52px;
  border-radius:18px;
  background:linear-gradient(145deg,rgba(255,248,235,.95),rgba(225,170,92,.72));
  box-shadow:0 14px 28px rgba(216,121,33,.25);
  overflow:hidden;
  flex:0 0 auto;
}
.brand-logo img{
  max-width:88%;
  max-height:88%;
  width:auto;
  height:auto;
  object-fit:contain;
  display:block;
}
.premium-header .brand-logo{
  width:72px;
  height:72px;
  border-radius:50%;
  background:radial-gradient(circle at 36% 25%,rgba(255,231,176,.25),transparent 24%),linear-gradient(145deg,#2c1609,#090705);
  border:2px solid rgba(214,145,65,.86);
  box-shadow:0 0 0 5px rgba(210,128,49,.12),0 22px 40px rgba(0,0,0,.36);
}
.brand.compact .brand-logo,
.compact-logo{
  width:48px;
  height:48px;
  border-radius:16px;
}
.branding-settings{
  display:grid;
  grid-template-columns:minmax(260px,.9fr) minmax(280px,1.1fr);
  gap:1rem;
  align-items:stretch;
}
.branding-preview{
  display:grid;
  gap:.5rem;
}
.branding-preview-label{
  color:#7b6448;
  font-size:.82rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.branding-preview-box{
  min-height:122px;
  display:flex;
  align-items:center;
  gap:1rem;
  padding:1rem;
  border-radius:22px;
  background:linear-gradient(135deg,#17100b,#2a1609);
  color:#fff8ec;
  border:1px solid rgba(214,145,65,.45);
}
.branding-preview-box strong{
  display:block;
  font-family:Georgia,'Times New Roman',serif;
  font-size:1.25rem;
  line-height:1.05;
}
.branding-preview-box small{
  display:block;
  color:#cf8a45;
  font-weight:700;
}
.branding-upload{
  display:grid;
  align-content:start;
  gap:.6rem;
}
@media (max-width:760px){
  .premium-header .brand-logo{
    width:58px;
    height:58px;
  }
  .branding-settings{
    grid-template-columns:1fr;
  }
}

/* v0.1.5: Namenskorrektur und robuste Smartphone-Darstellung */
html,
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}
img,
svg,
video,
canvas{
  max-width:100%;
}
body.public-site,
.site-header,
.premium-header,
.brewery-hero,
.cream-band,
.dark-band,
.site-footer{
  max-width:100vw;
}
.premium-header,
.brewery-hero{
  overflow-x:clip;
}
@supports not (overflow: clip){
  .premium-header,
  .brewery-hero{overflow-x:hidden;}
}
.container,
.narrow,
.premium-header .container,
.brewery-hero .container{
  max-width:100%;
}
.brand,
.brand > span:last-child,
.hero-stage,
.hero-menu-tiles,
.hero-menu-card,
.beer-grid,
.post-grid,
.split-section,
.contact-grid,
.footer-grid{
  min-width:0;
}
.brand strong,
.brand small,
.premium-copy h1,
.premium-copy h1 span,
.premium-copy h1 em,
.hero-menu-card strong{
  overflow-wrap:anywhere;
}

@media (max-width:760px){
  .premium-header{
    position:relative;
  }
  .premium-header .container,
  .brewery-hero .container,
  .container,
  .narrow{
    width:calc(100% - 24px);
  }
  .premium-header .header-inner{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:.75rem;
    min-height:0;
    padding:.85rem 0;
  }
  .premium-header .brand{
    justify-content:flex-start;
    width:100%;
    gap:.75rem;
  }
  .premium-header .brand strong{
    font-size:1.2rem;
    line-height:1.05;
    letter-spacing:.01em;
  }
  .premium-header .brand small{
    font-size:.84rem;
    line-height:1.2;
  }
  .premium-header .brand-logo,
  .premium-header .brand-mark{
    width:52px;
    height:52px;
    flex:0 0 52px;
  }
  .text-nav{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:.48rem;
    width:100%;
    overflow:visible;
    flex-wrap:initial;
    padding-bottom:0;
  }
  .text-nav a{
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:.52rem .45rem;
    border:1px solid rgba(216,148,69,.38);
    border-radius:14px;
    background:linear-gradient(145deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
    text-align:center;
    white-space:normal;
    font-size:.72rem;
    line-height:1.1;
    letter-spacing:.055em;
  }
  .text-nav a:after{
    display:none;
  }
  .brewery-hero{
    min-height:auto;
    padding:30px 0 72px;
    background-position:center top;
  }
  .hero-ornament{
    grid-template-columns:minmax(34px,72px) 20px minmax(34px,72px);
    gap:.6rem;
  }
  .hero-ornament.bottom{
    display:none;
  }
  .premium-copy .kicker{
    font-size:.74rem;
    letter-spacing:.18em;
    margin:.55rem 0 .6rem;
  }
  .premium-copy h1{
    font-size:clamp(2.25rem,12.2vw,4.05rem);
    line-height:.9;
    letter-spacing:.01em;
  }
  .premium-copy h1 em{
    font-size:.50em;
    letter-spacing:.08em;
    word-break:normal;
  }
  .premium-copy p{
    font-size:1rem;
    line-height:1.35;
    margin-top:.8rem;
  }
  .hero-menu-tiles{
    max-width:100%;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:.65rem;
    margin-top:1.35rem;
    transform:none;
  }
  .hero-menu-card{
    min-height:132px;
    border-radius:16px;
    padding:.82rem .52rem .78rem;
    gap:.42rem;
  }
  .hero-menu-card:before{
    width:82px;
    height:82px;
    top:.65rem;
  }
  .hero-menu-icon{
    width:58px;
    height:58px;
  }
  .hero-menu-icon svg{
    width:54px;
    height:54px;
    stroke-width:3;
  }
  .hero-menu-card strong{
    font-size:.98rem;
    line-height:1.05;
  }
  .first-band{
    padding-top:0;
  }
  .beer-grid,
  .post-grid,
  .beer-grid.big,
  .post-grid.wide,
  .split-section,
  .contact-grid,
  .footer-grid{
    grid-template-columns:1fr;
  }
  .row-head{
    align-items:flex-start;
    flex-direction:column;
  }
  .section{
    padding:42px 0;
  }
}

@media (max-width:420px){
  .premium-header .container,
  .brewery-hero .container,
  .container,
  .narrow{
    width:calc(100% - 20px);
  }
  .premium-header .brand strong{
    font-size:1.06rem;
  }
  .premium-header .brand small{
    font-size:.78rem;
  }
  .text-nav{
    gap:.4rem;
  }
  .text-nav a{
    min-height:39px;
    padding:.48rem .32rem;
    font-size:.66rem;
    letter-spacing:.035em;
  }
  .brewery-hero{
    padding-top:24px;
  }
  .premium-copy h1{
    font-size:clamp(2rem,11.5vw,3.15rem);
  }
  .premium-copy h1 em{
    font-size:.52em;
    letter-spacing:.045em;
  }
  .premium-copy p{
    font-size:.93rem;
  }
  .hero-menu-tiles{
    gap:.5rem;
  }
  .hero-menu-card{
    min-height:116px;
    border-radius:14px;
    padding:.62rem .35rem;
  }
  .hero-menu-card:before{
    width:68px;
    height:68px;
    top:.52rem;
  }
  .hero-menu-icon{
    width:48px;
    height:48px;
  }
  .hero-menu-icon svg{
    width:44px;
    height:44px;
  }
  .hero-menu-card strong{
    font-size:.86rem;
  }
  .section-title-dark h2{
    font-size:2rem;
    letter-spacing:.05em;
  }
  .section-title-dark span:before,
  .section-title-dark span:after{
    display:none;
  }
}

/* v0.1.6: Hero-Schrift kompakter, damit "Braumanufaktur" nicht unschön umbricht */
.premium-copy h1,
.premium-copy h1 span,
.premium-copy h1 em{
  overflow-wrap:normal;
  word-break:keep-all;
  hyphens:none;
}
.premium-copy h1{
  font-size:clamp(2.85rem,6.2vw,6.25rem);
  line-height:.9;
  letter-spacing:.012em;
}
.premium-copy h1 span,
.premium-copy h1 em{
  display:block;
  white-space:nowrap;
}
.premium-copy h1 em{
  font-size:.48em;
  letter-spacing:.11em;
}
@media (max-width:760px){
  .premium-copy h1{
    font-size:clamp(2.05rem,9.8vw,3.6rem);
    line-height:.94;
    letter-spacing:0;
  }
  .premium-copy h1 em{
    font-size:.50em;
    letter-spacing:.055em;
  }
}
@media (max-width:420px){
  .premium-copy h1{
    font-size:clamp(1.82rem,9.1vw,2.45rem);
    line-height:.96;
  }
  .premium-copy h1 em{
    font-size:.54em;
    letter-spacing:.025em;
  }
}

/* v0.1.7: Mobile App-Menü und PWA-Komfort */
.mobile-app-nav{
  display:none;
}
@media (max-width:760px){
  body.public-site{
    padding-bottom:calc(82px + env(safe-area-inset-bottom,0px));
  }
  .premium-header{
    position:sticky;
    top:0;
    z-index:90;
  }
  .premium-header .header-inner{
    align-items:center;
  }
  .premium-header .brand{
    justify-content:center;
  }
  .premium-header .brand > span:last-child{
    text-align:left;
  }
  .premium-header .text-nav{
    display:none;
  }
  .brewery-hero{
    padding-bottom:38px;
  }
  .hero-menu-tiles{
    display:none;
  }
  .first-band{
    padding-top:0;
  }
  .mobile-app-nav{
    position:fixed;
    left:10px;
    right:10px;
    bottom:calc(10px + env(safe-area-inset-bottom,0px));
    z-index:170;
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr));
    gap:.25rem;
    padding:.42rem;
    border-radius:26px;
    background:linear-gradient(180deg,rgba(21,16,12,.96),rgba(10,8,6,.98));
    border:1px solid rgba(225,153,73,.42);
    box-shadow:0 18px 46px rgba(0,0,0,.44), inset 0 1px 0 rgba(255,255,255,.08);
    backdrop-filter:blur(18px);
  }
  .mobile-app-nav a{
    min-width:0;
    min-height:58px;
    display:grid;
    justify-items:center;
    align-content:center;
    gap:.18rem;
    border-radius:20px;
    color:#dec49a;
    text-decoration:none;
    font-weight:900;
    -webkit-tap-highlight-color:transparent;
    transition:background .18s ease, color .18s ease, transform .18s ease;
  }
  .mobile-app-nav a:active{
    transform:scale(.96);
  }
  .mobile-app-nav a.active{
    color:#2a1609;
    background:linear-gradient(145deg,#ffd16f,#d68b3d);
    box-shadow:0 9px 22px rgba(216,139,61,.28);
  }
  .mobile-app-nav span{
    width:24px;
    height:24px;
    display:grid;
    place-items:center;
  }
  .mobile-app-nav svg{
    width:23px;
    height:23px;
    fill:none;
    stroke:currentColor;
    stroke-width:4;
    stroke-linecap:round;
    stroke-linejoin:round;
  }
  .mobile-app-nav strong{
    display:block;
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:.67rem;
    line-height:1;
    letter-spacing:.01em;
  }
  .cookie-banner{
    bottom:calc(92px + env(safe-area-inset-bottom,0px));
    left:.75rem;
    right:.75rem;
    border-radius:20px;
  }
}
@media (max-width:380px){
  .mobile-app-nav{
    left:6px;
    right:6px;
    border-radius:22px;
    padding:.34rem;
  }
  .mobile-app-nav a{
    min-height:54px;
    border-radius:17px;
  }
  .mobile-app-nav strong{
    font-size:.61rem;
  }
  .mobile-app-nav svg{
    width:21px;
    height:21px;
  }
}


/* v0.1.8: Mobile Hero vollständig innerhalb der Gerätebreite halten */
@media (max-width:760px){
  .brewery-hero{
    overflow:hidden;
    padding-top:24px;
    padding-bottom:34px;
    min-height:auto;
    background:
      linear-gradient(180deg,rgba(0,0,0,.22),rgba(18,12,8,.72) 42%,rgba(18,12,8,.92) 100%),
      url('../img/hero-brewery-atmosphere.jpg') center top / 100% auto no-repeat,
      radial-gradient(circle at 50% 0%,rgba(208,133,62,.22),transparent 42%),
      linear-gradient(135deg,#120c08,#271309 58%,#100b08);
  }
  .brewery-hero:before{
    background:
      radial-gradient(circle at 50% 18%,rgba(255,198,109,.10),transparent 34%),
      linear-gradient(90deg,rgba(0,0,0,.12),transparent 18%,transparent 82%,rgba(0,0,0,.12));
  }
  .hero-stage,
  .premium-copy,
  .premium-copy h1,
  .premium-copy p{
    width:100%;
    max-width:100%;
    min-width:0;
  }
  .premium-copy h1{
    display:block;
    font-size:clamp(1.7rem,7.8vw,3rem);
    line-height:.98;
    letter-spacing:0;
    text-align:center;
    margin-inline:auto;
  }
  .premium-copy h1 span,
  .premium-copy h1 em{
    display:block;
    max-width:100%;
    white-space:nowrap;
    overflow:visible;
    text-align:center;
  }
  .premium-copy h1 em{
    margin-top:.18rem;
    font-size:.62em;
    letter-spacing:.05em;
  }
  .premium-copy .kicker{
    font-size:.68rem;
    letter-spacing:.13em;
  }
  .premium-copy p{
    font-size:.92rem;
    line-height:1.32;
    padding-inline:.15rem;
  }
  .hero-ornament{
    width:min(220px,100%);
    grid-template-columns:minmax(28px,1fr) 18px minmax(28px,1fr);
    gap:.45rem;
    margin-inline:auto;
  }
  .hero-ornament svg{
    width:18px;
    height:18px;
  }
}
@media (max-width:420px){
  .brewery-hero{
    padding-top:20px;
    padding-bottom:30px;
    background-size:auto, 112% auto, auto, auto;
    background-position:center top, center top, center top, center top;
  }
  .premium-copy h1{
    font-size:clamp(1.42rem,7.1vw,2.05rem);
    line-height:1;
  }
  .premium-copy h1 em{
    font-size:.66em;
    letter-spacing:.035em;
  }
  .premium-copy .kicker{
    font-size:.62rem;
    letter-spacing:.105em;
  }
  .premium-copy p{
    font-size:.86rem;
  }
}
@media (max-width:340px){
  .premium-copy h1{
    font-size:1.34rem;
  }
  .premium-copy h1 em{
    font-size:.68em;
    letter-spacing:.02em;
  }
}

/* v0.1.9: Anfrage-/Reservierungsfunktion ohne Versand */
.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr));}
.availability-list,
.request-items,
.requested-items{display:grid;gap:.75rem;}
.availability-row,
.request-item,
.requested-items div{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;padding:1rem;border-radius:20px;background:rgba(42,22,9,.055);border:1px solid rgba(42,22,9,.09);}
.availability-row strong,.request-item strong,.requested-items strong{display:block;color:#241307;}
.availability-row small,.request-item small,.requested-items small{display:block;color:#7b6448;font-size:.84rem;}
.availability-row p{margin:.4rem 0 0;color:#6b4f32;font-size:.92rem;}
.availability-side{display:grid;justify-items:end;gap:.25rem;text-align:right;}
.pill.availability.available{background:#eaf5da;color:#35581e;}
.pill.availability.low{background:#fff1c8;color:#6a4109;}
.pill.availability.unavailable{background:#ffe4dc;color:#812d19;}
.beer-availability{margin-top:1rem;display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;}
.beer-availability small{font-weight:800;color:#6d563a;}
.reservation-layout{display:grid;grid-template-columns:.95fr 1.05fr;gap:1.2rem;align-items:start;}
.reservation-form-card h2{margin-top:0;}
.request-item{grid-template-columns:1fr minmax(160px,230px);}
.request-item input{margin:0;}
.reservations-admin{align-items:start;}
.reservation-list a.unread-dot{box-shadow:inset 6px 0 0 #d89445;}
.detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;border-bottom:1px solid rgba(42,22,9,.10);padding-bottom:1rem;margin-bottom:1rem;}
.pill.status.new{background:#fff1c8;color:#6a4109;}
.pill.status.in_progress{background:#e6f0ff;color:#163f74;}
.pill.status.confirmed{background:#eaf5da;color:#35581e;}
.pill.status.done{background:#eee7dc;color:#54442d;}
.pill.status.cancelled{background:#ffe4dc;color:#812d19;}
.requested-items div{grid-template-columns:1fr auto;}
.requested-items span{font-weight:900;color:#2a1609;}
.inset-card{margin-top:1.2rem;background:linear-gradient(145deg,#fffdf7,#f4e4c8);box-shadow:none;}
.danger-form{margin-top:1rem;}
@media (min-width:1181px){
  .hero-menu-tiles:has(.hero-menu-card:nth-child(5)){grid-template-columns:repeat(5,minmax(170px,1fr));}
  .hero-menu-tiles:has(.hero-menu-card:nth-child(5)) .hero-menu-card{min-height:220px;}
}
@media (max-width:760px){
  .mobile-app-nav{grid-template-columns:repeat(auto-fit,minmax(48px,1fr));}
  .reservation-layout,.form-grid.two{grid-template-columns:1fr;}
  .availability-row,.request-item,.requested-items div{grid-template-columns:1fr;align-items:start;}
  .availability-side{justify-items:start;text-align:left;}
  .request-item input{width:100%;}
  .detail-head{display:grid;}
}
@media (max-width:380px){
  .mobile-app-nav strong{font-size:.56rem;}
  .mobile-app-nav a{min-height:52px;}
}

/* v0.2.0: echtes Braumanufaktur-Wendhausen-Logo besser integrieren */
.visually-hidden{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  padding:0!important;
  margin:-1px!important;
  overflow:hidden!important;
  clip:rect(0,0,0,0)!important;
  white-space:nowrap!important;
  border:0!important;
}
.premium-header .brand{
  min-width:0;
}
.premium-header .brand-logo-default{
  width:118px;
  height:96px;
  border-radius:0;
  background:transparent;
  border:0;
  box-shadow:none;
  overflow:visible;
}
.premium-header .brand-logo-default img{
  width:100%;
  height:100%;
  max-width:none;
  max-height:none;
  object-fit:contain;
  filter:drop-shadow(0 12px 22px rgba(0,0,0,.45));
}
.premium-header .brand-logo-default + span{
  position:absolute;
  width:1px;
  height:1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
}
.premium-header .brand-logo-custom{
  width:92px;
  height:92px;
  border-radius:22px;
  background:rgba(255,248,235,.96);
  border:1px solid rgba(214,145,65,.72);
  box-shadow:0 0 0 5px rgba(210,128,49,.10),0 18px 36px rgba(0,0,0,.38);
}
.admin-topbar .brand-logo-default,
.brand.compact .brand-logo-default,
.compact-logo.brand-logo-default{
  width:62px;
  height:62px;
  border-radius:14px;
  background:#fff8eb;
  border:1px solid rgba(42,22,9,.14);
  box-shadow:0 10px 24px rgba(42,22,9,.16);
}
.admin-topbar .brand-logo-default img,
.brand.compact .brand-logo-default img{
  width:94%;
  height:94%;
  max-width:none;
  max-height:none;
  object-fit:contain;
}
.branding-preview-box .brand-logo-default{
  width:96px;
  height:96px;
  border-radius:18px;
  background:rgba(255,248,235,.08);
  border:1px solid rgba(245,180,63,.36);
  box-shadow:none;
}
.brewery-hero .premium-copy.with-logo{
  display:grid;
  justify-items:center;
  gap:.52rem;
}
.hero-logo-lockup{
  display:block;
  width:min(560px,78vw);
  max-width:100%;
  margin:.15rem auto .25rem;
  filter:drop-shadow(0 24px 46px rgba(0,0,0,.58));
}
.hero-logo-lockup img{
  display:block;
  width:100%;
  height:auto;
  max-height:clamp(210px,42vh,430px);
  object-fit:contain;
}
.premium-copy.with-logo p{
  margin-top:.2rem;
  font-size:clamp(1.08rem,1.7vw,1.34rem);
  text-shadow:0 4px 22px rgba(0,0,0,.72);
}
.age-card .age-kicker,
.login-card .kicker{
  letter-spacing:.08em;
}
@media (max-width:1180px){
  .premium-header .brand-logo-default{
    width:96px;
    height:82px;
  }
}
@media (max-width:760px){
  .premium-header .brand{
    max-width:100%;
  }
  .premium-header .brand-logo-default{
    width:86px;
    height:74px;
  }
  .premium-header .brand-logo-custom{
    width:58px;
    height:58px;
  }
  .admin-topbar .brand-logo-default,
  .brand.compact .brand-logo-default,
  .compact-logo.brand-logo-default{
    width:52px;
    height:52px;
  }
  .hero-logo-lockup{
    width:min(360px,92vw);
    margin-top:.05rem;
  }
  .hero-logo-lockup img{
    max-height:292px;
  }
  .premium-copy.with-logo p{
    max-width:26rem;
    font-size:.98rem;
  }
}
@media (max-width:420px){
  .premium-header .brand-logo-default{
    width:76px;
    height:66px;
  }
  .hero-logo-lockup{
    width:min(310px,92vw);
  }
  .hero-logo-lockup img{
    max-height:252px;
  }
}


/* v0.2.1: Header-Titel nach Logo-Integration kompakter */
.premium-header .header-inner{
  grid-template-columns:minmax(210px,300px) minmax(420px,1fr) minmax(190px,270px);
  gap:1rem;
  min-height:90px;
}
.premium-header .brand{
  gap:.72rem;
  min-width:0;
}
.premium-header .brand > span:not(.brand-logo){
  min-width:0;
  max-width:190px;
}
.premium-header .brand strong{
  font-size:clamp(.98rem,1.22vw,1.28rem);
  line-height:1.02;
  letter-spacing:.005em;
}
.premium-header .brand small{
  font-size:clamp(.66rem,.82vw,.82rem);
  line-height:1.12;
  letter-spacing:.025em;
}
.premium-header .brand-logo-default{
  width:96px;
  height:78px;
}
.premium-header .brand-logo-custom{
  width:74px;
  height:74px;
  border-radius:18px;
}
.text-nav{
  gap:.86rem;
}
.text-nav a{
  font-size:.78rem;
  letter-spacing:.085em;
}
.header-claim{
  padding-left:1rem;
  column-gap:.62rem;
}
.header-claim strong{
  font-size:.68rem;
}
.header-claim small{
  font-size:.64rem;
}
@media (max-width:1180px){
  .premium-header .header-inner{
    grid-template-columns:minmax(180px,260px) 1fr;
  }
  .premium-header .brand-logo-default{
    width:82px;
    height:66px;
  }
  .premium-header .brand-logo-custom{
    width:66px;
    height:66px;
  }
  .header-claim{
    display:none;
  }
}
@media (max-width:760px){
  .premium-header .header-inner{
    min-height:0;
    padding:.66rem 0;
    gap:.45rem;
  }
  .premium-header .brand{
    justify-content:center;
    gap:.55rem;
  }
  .premium-header .brand > span:not(.brand-logo){
    max-width:min(230px,calc(100vw - 112px));
  }
  .premium-header .brand strong{
    font-size:.98rem;
    line-height:1.02;
  }
  .premium-header .brand small{
    font-size:.68rem;
    line-height:1.12;
  }
  .premium-header .brand-logo-default{
    width:70px;
    height:58px;
  }
  .premium-header .brand-logo-custom{
    width:52px;
    height:52px;
    border-radius:15px;
  }
}
@media (max-width:420px){
  .premium-header .brand > span:not(.brand-logo){
    max-width:190px;
  }
  .premium-header .brand strong{
    font-size:.88rem;
  }
  .premium-header .brand small{
    font-size:.62rem;
  }
  .premium-header .brand-logo-default{
    width:62px;
    height:52px;
  }
  .premium-header .brand-logo-custom{
    width:48px;
    height:48px;
  }
}
