/* ===========================================================
   Grill & Green – gemeinsames Stylesheet (alle Seiten)
   =========================================================== */
:root{
  --black:#0F100E;--black-soft:#16180F;--panel:#1C1F16;
  --green:#3DAE52;--green-bright:#5FCB5F;--green-deep:#143C1C;
  --orange:#F08A24;--orange-light:#F7A23E;--cream:#F4EFE3;--muted:#9DA694;
  --line:rgba(244,239,227,.10);--radius:18px;--shadow:0 18px 50px rgba(0,0,0,.45);
  --header-h:74px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 12px)}
body{font-family:'Inter',system-ui,sans-serif;background:var(--black);color:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,h5,.display{font-family:'Fredoka',sans-serif;font-weight:600;line-height:1.12}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 26px}
.accent{color:var(--green-bright)}
.accent-o{color:var(--orange-light)}
.kicker{font-family:'Fredoka';text-transform:uppercase;letter-spacing:3px;font-size:12px;color:var(--green-bright);margin-bottom:10px}
.center{text-align:center}
.section{padding:74px 0;border-bottom:1px solid var(--line)}
.section h2{font-size:34px}
.section .sub{color:var(--muted);max-width:600px;margin:8px auto 0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;background:var(--orange);color:#1a1206;border-radius:12px;padding:11px 22px;font-family:'Fredoka';font-weight:600;line-height:1.05;text-align:center;transition:transform .15s,background .15s;cursor:pointer;border:none}
.btn small{font-size:9px;text-transform:uppercase;letter-spacing:1.5px;opacity:.85;font-family:'Inter';font-weight:600}
.btn:hover{transform:translateY(-2px);background:var(--orange-light)}
.btn.ghost{background:transparent;border:1.5px solid var(--green);color:var(--green-bright)}
.btn.ghost:hover{background:rgba(61,174,82,.12)}
.btn.green{background:var(--green);color:#06180b}
.btn.green:hover{background:var(--green-bright)}
.btn.lg{padding:15px 32px;font-size:18px}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);display:flex;align-items:center;background:rgba(15,16,14,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:background .3s}
.site-header.scrolled{background:rgba(15,16,14,.97)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:18px;width:100%}
.site-logo{height:50px;width:auto}
.nav{display:flex;gap:24px;font-size:15px;color:#D7D2C4;font-weight:500}
.nav a{position:relative;padding:4px 0}
.nav a:hover{color:var(--green-bright)}
.nav a.active{color:var(--cream)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--orange);border-radius:2px}
.header-right{display:flex;align-items:center;gap:16px}
.socials{display:flex;gap:9px}
.socials a{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);display:grid;place-items:center;font-size:13px;color:var(--muted);transition:.15s}
.socials a:hover{color:var(--green-bright);border-color:var(--green)}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:9px;width:42px;height:42px;color:var(--cream);font-size:20px;cursor:pointer}
.mobile-nav{position:fixed;inset:var(--header-h) 0 auto 0;background:rgba(15,16,14,.98);border-bottom:1px solid var(--line);transform:translateY(-120%);transition:transform .3s;z-index:99;padding:16px 26px}
.mobile-nav.open{transform:translateY(0)}
.mobile-nav a{display:block;padding:13px 0;font-family:'Fredoka';font-size:17px;border-bottom:1px solid var(--line)}
.mobile-nav a:last-child{border-bottom:none}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:88vh;display:grid;align-items:center;padding:calc(var(--header-h) + 40px) 0 60px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,11,9,.92) 0%,rgba(10,11,9,.78) 45%,rgba(10,11,9,.4) 100%)}
.hero-inner{position:relative;z-index:1;max-width:600px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--green-bright);border:1px solid var(--line);background:rgba(0,0,0,.3);border-radius:999px;padding:7px 16px;margin-bottom:20px}
.hero h1{font-size:64px;margin-bottom:16px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.hero-claim{font-size:46px;line-height:1.12;margin-bottom:18px}
.hero-logo-col{display:flex;justify-content:center;align-items:center}
.hero-logo{width:min(460px,100%);height:auto;filter:drop-shadow(0 14px 36px rgba(0,0,0,.5))}
.hero p{color:#E2DCCD;max-width:460px;margin-bottom:28px;font-size:17px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- USP ---------- */
.usp{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-bottom:1px solid var(--line)}
.usp div{background:var(--black-soft);padding:26px 20px;text-align:center}
.usp .big{font-family:'Fredoka';font-size:16px;color:var(--green-bright);margin-bottom:3px}
.usp small{color:var(--muted);font-size:12.5px}

/* ---------- Deals (marquee) ---------- */
.deals{padding:48px 0;background:radial-gradient(800px 260px at 50% -40%,rgba(61,174,82,.16),transparent),var(--black-soft);border-bottom:1px solid var(--line)}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.marquee-track{display:flex;gap:14px;width:max-content;animation:scrollx 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.deal{flex:none;width:230px;background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.deal img{width:100%;height:140px;object-fit:cover}
.deal-badge{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#1a1206;background:var(--orange);font-family:'Fredoka';border-radius:6px;padding:2px 8px;margin:8px 0 0 12px}
.deal .d-body{padding:8px 14px 14px;display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.deal .d-body b{font-family:'Fredoka';font-weight:500;font-size:14.5px}
.deal .d-body span{color:var(--orange-light);font-family:'Fredoka';font-size:13.5px;white-space:nowrap}

/* ---------- Menu ---------- */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:22px 0 28px;justify-content:center}
.tab{font-family:'Fredoka';font-weight:500;font-size:14.5px;padding:9px 20px;border-radius:999px;border:1px solid var(--line);color:#CFC9BB;cursor:pointer;transition:.15s;background:transparent}
.tab:hover{border-color:var(--green)}
.tab.active{background:var(--green);color:#06180b;border-color:var(--green)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,border-color .15s}
.card:hover{transform:translateY(-4px);border-color:rgba(95,203,95,.45)}
.card-img{aspect-ratio:16/11;position:relative;overflow:hidden;border-bottom:1px solid var(--line);background:#0c0d0a}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .card-img img{transform:scale(1.06)}
.badge-diet{position:absolute;top:10px;left:10px;z-index:2;font-size:10px;letter-spacing:.5px;text-transform:uppercase;background:rgba(20,40,20,.85);color:var(--green-bright);border:1px solid rgba(95,203,95,.5);border-radius:6px;padding:3px 8px}
.badge-diet.veg{background:rgba(60,40,10,.85);color:var(--orange-light);border-color:rgba(240,138,36,.5)}
.card-body{padding:16px 17px 18px;display:flex;flex-direction:column;flex:1}
.card-body .name{font-family:'Fredoka';font-weight:600;font-size:17.5px;display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.card-body .price{color:var(--orange-light);font-family:'Fredoka';white-space:nowrap}
.card-body .ing{color:var(--muted);font-size:12.5px;margin:7px 0 14px;flex:1}
.card-body .order{font-family:'Fredoka';font-weight:500;font-size:13px;color:var(--green-bright);display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;text-align:left;padding:0}
.card-body .order:hover{color:var(--orange-light)}
.menu-foot{text-align:center;margin-top:24px;color:var(--muted);font-size:12.5px}

/* price list & juices */
.pl{display:grid;grid-template-columns:1fr 1fr;gap:6px 36px;margin-top:6px}
.pl .di{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px dashed var(--line)}
.pl .di b{font-family:'Fredoka';font-weight:500}
.pl .di small{color:var(--muted);font-size:11.5px;display:block;font-weight:400;font-family:'Inter'}
.pl .di .p{color:var(--orange-light);font-family:'Fredoka';white-space:nowrap}
.juice-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:8px 0 24px}
.juice-row figure{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel)}
.juice-row img{width:100%;aspect-ratio:3/4;object-fit:cover}
.juice-row figcaption{font-family:'Fredoka';font-size:12.5px;padding:9px 8px 4px;text-align:center}
.juice-row span{display:block;font-size:10px;color:var(--muted);padding:0 6px 9px;text-align:center}

/* ---------- Quality timeline ---------- */
.timeline{position:relative;max-width:960px;margin:34px auto 0;padding:6px 0}
.timeline .spine{position:absolute;left:50%;top:0;bottom:0;width:3px;background:var(--line);transform:translateX(-50%);border-radius:3px;overflow:hidden}
.timeline .spine .fill{position:absolute;left:0;top:0;width:100%;height:0;background:linear-gradient(180deg,var(--green-bright),var(--orange))}
.tl-item{position:relative;width:50%;padding:22px 50px;box-sizing:border-box}
.tl-item.left{left:0;text-align:right}
.tl-item.right{left:50%;text-align:left}
.tl-node{position:absolute;top:32px;width:20px;height:20px;border-radius:6px;background:var(--orange);border:3px solid var(--black);box-shadow:0 0 0 2px var(--orange);z-index:2}
.tl-item.left .tl-node{right:-10px}
.tl-item.right .tl-node{left:-10px}
.tl-card .h{font-family:'Fredoka';font-size:21px;display:inline-block;border-bottom:3px solid var(--green);padding-bottom:4px;margin-bottom:14px}
.tl-card img{display:block;width:100%;max-width:390px;aspect-ratio:16/10;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.tl-item.left .tl-card img{margin-left:auto}
.tl-sub{font-family:'Fredoka';font-weight:500;margin:14px 0 6px;color:var(--green-bright);font-size:15px}
.tl-card p{color:var(--muted);font-size:13.5px;max-width:390px;display:inline-block;margin:0}
.tl-item.left .tl-card p{margin-left:auto}

/* ---------- Ambiente ---------- */
.ambiente{display:grid;grid-template-columns:1.1fr .9fr;gap:0;align-items:stretch;border-bottom:1px solid var(--line)}
.ambiente .txt{padding:60px 40px;display:flex;flex-direction:column;justify-content:center}
.ambiente .txt h2{font-size:32px;margin-bottom:12px}
.ambiente .txt p{color:#D7D2C4;font-size:15px;margin-bottom:10px;max-width:440px}
.ambiente .pic img{width:100%;height:100%;object-fit:cover;min-height:340px}

/* ---------- Franchise + cities ---------- */
.franchise{position:relative;display:grid;grid-template-columns:1fr 1fr;align-items:stretch;border-bottom:1px solid var(--line)}
.franchise .pic{position:relative;overflow:hidden;min-height:360px}
.franchise .pic img{width:100%;height:100%;object-fit:cover}
.franchise .pic::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(15,16,14,.6))}
.franchise .txt{padding:60px 40px;background:radial-gradient(600px 320px at 90% 0%,rgba(240,138,36,.12),transparent),var(--black-soft);display:flex;flex-direction:column;justify-content:center}
.franchise .txt h2{font-size:32px;margin-bottom:6px}
.franchise .txt .frsub{font-family:'Fredoka';color:var(--green-bright);margin-bottom:14px;font-size:16px}
.franchise .txt p{color:#D7D2C4;font-size:15px;margin-bottom:12px;max-width:440px}
.fr-points{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 22px}
.fr-points span{font-size:12.5px;border:1px solid var(--line);border-radius:999px;padding:6px 13px;color:var(--muted)}
.cities{padding:54px 0;text-align:center;background:var(--black);border-bottom:1px solid var(--line)}
.city-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.city{min-width:220px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px 24px;text-align:left}
.city b{font-family:'Fredoka';font-size:19px;display:block}
.city small{color:var(--muted);font-size:12.5px}
.city .st{display:inline-flex;align-items:center;gap:6px;font-size:11px;text-transform:uppercase;letter-spacing:1px;font-family:'Fredoka';margin-top:12px;border-radius:999px;padding:4px 11px}
.city.open{border-color:rgba(95,203,95,.45)}
.city.open .st{color:var(--green-bright);background:rgba(61,174,82,.14)}
.city.soon .st{color:var(--orange-light);background:rgba(240,138,36,.14)}
.city .st .dot{width:7px;height:7px;border-radius:50%;background:currentColor}

/* ---------- Reviews ---------- */
.google{display:inline-flex;align-items:center;gap:10px;margin-top:8px;font-size:14px;color:var(--muted)}
.google b{font-family:'Fredoka';color:var(--cream);font-size:24px}
.stars{color:#FFC83D;font-size:14px;letter-spacing:2px}
.rev{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
.rev .r{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px}
.rev .r p{font-size:14px;color:#E2DCCD;margin:10px 0 14px}
.rev .r .who{font-size:12.5px;color:var(--muted)}
.rev-marquee{margin-top:18px}
.chip-rev{flex:none;width:320px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.chip-rev .stars{font-size:12px}
.chip-rev p{font-size:13px;color:#E2DCCD;margin:6px 0 8px}
.chip-rev .who{font-size:11.5px;color:var(--muted)}

/* ---------- Gallery ---------- */
.gal{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:135px;gap:12px;margin-top:26px}
.gal figure{overflow:hidden;border-radius:14px;border:1px solid var(--line)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gal figure:hover img{transform:scale(1.08)}
.gal .tall{grid-row:span 2}.gal .wide{grid-column:span 2}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:26px auto 0}
.faq .item{border:1px solid var(--line);border-radius:12px;margin-bottom:11px;overflow:hidden;background:var(--panel)}
.faq .q{padding:18px 22px;font-family:'Fredoka';font-weight:500;font-size:16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq .q .plus{color:var(--green-bright);font-size:22px;transition:transform .2s}
.faq .a{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--muted);font-size:14px}
.faq .a p{padding:0 22px 20px}
.faq .item.open .a{max-height:260px}.faq .item.open .plus{transform:rotate(45deg)}

/* ---------- Contact ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;margin-top:26px}
.form{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:28px}
.form label{font-size:12px;color:var(--muted);display:block;margin:14px 0 6px}
.form input,.form textarea{width:100%;background:var(--black);border:1px solid var(--line);border-radius:10px;padding:13px 14px;color:var(--cream);font-family:inherit;font-size:14px}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--green)}
.form textarea{min-height:100px;resize:vertical}
.chk{display:flex;gap:10px;align-items:flex-start;margin:16px 0;font-size:12px;color:var(--muted)}
.contact-info h2{font-size:30px;margin-bottom:10px}
.contact-info p{color:var(--muted);font-size:15px;margin-bottom:8px}
.contact-info a{color:var(--green-bright)}
.map{margin-top:18px;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.map iframe{width:100%;height:220px;border:0;display:block;filter:grayscale(.3) contrast(1.05)}

/* ---------- Footer ---------- */
.site-footer{background:#0a0b09;padding:54px 0 30px;border-top:2px solid var(--green-deep)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
.site-footer h5{font-family:'Fredoka';font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--green-bright);margin-bottom:14px}
.site-footer .fcol a,.site-footer .fcol p{display:block;color:var(--muted);font-size:13.5px;margin-bottom:9px;transition:.15s}
.site-footer .fcol a:hover{color:var(--cream)}
.claim{font-family:'Fredoka';font-size:17px;color:var(--cream);margin:10px 0}
.footer-bottom{margin-top:38px;padding-top:20px;border-top:1px solid var(--line);display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;color:var(--muted);font-size:12.5px}
.footer-bottom a:hover{color:var(--cream)}

/* ---------- Page banner (subpages) ---------- */
.page-banner{position:relative;padding:calc(var(--header-h) + 70px) 0 60px;overflow:hidden;border-bottom:1px solid var(--line)}
.page-banner .pb-bg{position:absolute;inset:0;z-index:0}
.page-banner .pb-bg img{width:100%;height:100%;object-fit:cover}
.page-banner .pb-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,11,9,.82),rgba(10,11,9,.92))}
.page-banner .container{position:relative;z-index:1}
.page-banner h1{font-size:46px}
.page-banner p{color:#D7D2C4;max-width:560px;margin-top:10px;font-size:16px}
.breadcrumb{font-size:13px;color:var(--muted);margin-bottom:12px}
.breadcrumb a:hover{color:var(--green-bright)}

/* ---------- Legal / prose ---------- */
.prose{max-width:780px;margin:0 auto}
.prose h2{font-size:24px;margin:28px 0 10px;color:var(--cream)}
.prose h3{font-size:18px;margin:20px 0 8px;color:var(--green-bright)}
.prose p,.prose li{color:#CFC9BB;font-size:14.5px;margin-bottom:10px}
.prose ul{margin:0 0 12px 20px}
.prose a{color:var(--green-bright)}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
.reveal.from-right{transform:translateX(60px)}
.reveal.from-right.in{transform:none}
.reveal.from-left{transform:translateX(-60px)}
.reveal.from-left.in{transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .nav,.header-right .socials{display:none}
  .burger{display:grid;place-items:center}
  .hero h1{font-size:46px}
  .hero-grid{grid-template-columns:1fr;gap:24px}
  .hero-logo-col{order:-1;justify-content:flex-start}
  .hero-logo{width:min(340px,72%)}
  .hero-claim{font-size:40px}
  .contact,.ambiente,.franchise{grid-template-columns:1fr}
  .grid,.rev{grid-template-columns:1fr 1fr}
  .usp{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gal{grid-template-columns:repeat(3,1fr)}
  .juice-row{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  .hero h1{font-size:38px}
  .grid,.rev,.pl,.juice-row,.usp,.footer-grid{grid-template-columns:1fr}
  .gal{grid-template-columns:repeat(2,1fr)}
  .section{padding:54px 0}
  .section h2{font-size:28px}
  .timeline .spine{left:16px}
  .tl-item{width:100%;left:0;text-align:left;padding:16px 0 16px 44px}
  .tl-item.left,.tl-item.right{left:0;text-align:left}
  .tl-item .tl-node{left:7px;right:auto}
  .tl-item.left .tl-card img,.tl-item.left .tl-card p{margin-left:0}
  .reveal.from-left,.reveal.from-right{transform:translateY(26px)}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none}
  .marquee-track{animation:none}
}
