/* ============================================================
   Bäckerei Bergmann — neue Website  ·  ALYXON OS Demo
   Zero externe Requests (DSGVO-sauber). Brand aus dem Logo.
   ============================================================ */

:root{
  --red:#9c1b16;
  --red-dark:#7a140f;
  --gold:#efb000;
  --gold-soft:#f7cd5b;
  --cream:#fbf5ea;
  --cream-2:#f4e9d6;
  --paper:#fffdf8;
  --ink:#2a201a;
  --muted:#7c6c5d;
  --line:#e7dcc6;
  --ok:#2f8f4e;
  --shadow:0 18px 50px -22px rgba(60,30,10,.45);
  --shadow-sm:0 8px 24px -14px rgba(60,30,10,.4);
  --r:18px;
  --serif:Georgia,'Iowan Old Style','Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
section{position:relative}

.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.serif{font-family:var(--serif)}
.eyebrow{
  text-transform:uppercase;letter-spacing:.22em;font-size:.74rem;font-weight:700;
  color:var(--red);display:inline-block;margin-bottom:14px;
}
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.1;letter-spacing:-.01em}
h2.title{font-size:clamp(1.9rem,4vw,3rem);margin-bottom:10px}
.lede{color:var(--muted);font-size:1.08rem;max-width:620px}
.center{text-align:center}
.center .lede{margin:0 auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:14px 26px;border-radius:999px;font-weight:700;font-size:.98rem;
  transition:transform .18s ease,box-shadow .18s ease,background .18s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 26px -12px rgba(156,27,22,.8)}
.btn-red:hover{background:var(--red-dark);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#3a2a06}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid var(--line);color:var(--ink);background:var(--paper)}
.btn-ghost:hover{border-color:var(--red);color:var(--red)}
.btn-lg{padding:17px 34px;font-size:1.05rem}

/* ---------- Top bar ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:background .3s,box-shadow .3s,padding .3s;
  padding:16px 0;
}
header.scrolled{
  background:rgba(251,245,234,.88);backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line);padding:9px 0;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px;width:auto;transition:height .3s}
header.scrolled .brand img{height:36px}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{font-weight:600;font-size:.96rem;color:var(--ink);opacity:.85;transition:opacity .15s,color .15s}
.nav-links a:hover{opacity:1;color:var(--red)}
.nav-cta{display:flex;align-items:center;gap:12px}
.cart-btn{position:relative;display:flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:11px 18px;border-radius:999px;font-weight:700;font-size:.92rem}
.cart-btn:hover{background:var(--red-dark)}
.cart-count{background:var(--gold);color:#3a2a06;border-radius:999px;min-width:21px;height:21px;display:grid;place-items:center;font-size:.78rem;padding:0 5px}
.burger{display:none;flex-direction:column;gap:5px;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px;transition:.25s}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:140px 0 70px;position:relative;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(40,22,14,.86) 0%,rgba(40,22,14,.62) 42%,rgba(40,22,14,.15) 100%);
}
.hero-inner{max-width:680px;color:#fff}
.hero .eyebrow{color:var(--gold-soft)}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero h1 em{color:var(--gold-soft);font-style:normal}
.hero p{font-size:1.22rem;margin:22px 0 34px;max-width:540px;color:#f4ece1}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:26px;margin-top:42px;flex-wrap:wrap}
.hero-badges div{color:#fff}
.hero-badges b{font-family:var(--serif);font-size:1.7rem;display:block;color:var(--gold-soft)}
.hero-badges span{font-size:.85rem;opacity:.85}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:#fff;opacity:.7;font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- Feature strip ---------- */
.strip{background:var(--red);color:#fff;padding:18px 0}
.strip .wrap{display:flex;justify-content:space-around;gap:18px;flex-wrap:wrap;align-items:center}
.strip div{display:flex;align-items:center;gap:10px;font-weight:600;font-size:.97rem}
.strip svg{width:22px;height:22px;flex:none}

/* ---------- Generic section spacing ---------- */
.sec{padding:92px 0}
.sec-head{margin-bottom:46px}

/* ---------- Vorbestellung highlight ---------- */
.order{background:linear-gradient(180deg,var(--cream) 0%,var(--cream-2) 100%)}
.order-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.order-copy .feat-list{list-style:none;margin:26px 0 30px;display:grid;gap:14px}
.order-copy .feat-list li{display:flex;gap:13px;align-items:flex-start;font-size:1.02rem}
.order-copy .feat-list .tick{flex:none;width:26px;height:26px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-size:.85rem;margin-top:2px}
.order-mock{
  background:var(--paper);border-radius:24px;box-shadow:var(--shadow);
  overflow:hidden;border:1px solid var(--line);
}
.om-head{background:var(--red);color:#fff;padding:18px 22px;display:flex;align-items:center;gap:12px}
.om-head img{height:30px}
.om-head .om-title{font-weight:700}
.om-head .om-sub{font-size:.8rem;opacity:.8}
.om-body{padding:20px 22px}
.om-row{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--line)}
.om-row:last-child{border:none}
.om-row img{width:56px;height:56px;border-radius:12px;object-fit:cover;flex:none}
.om-row .om-name{font-weight:600;font-size:.96rem}
.om-row .om-price{color:var(--muted);font-size:.85rem}
.om-add{margin-left:auto;background:var(--gold);color:#3a2a06;width:36px;height:36px;border-radius:10px;font-size:1.3rem;font-weight:700;display:grid;place-items:center;transition:.15s}
.om-add:hover{background:var(--gold-soft);transform:scale(1.08)}
.om-foot{padding:16px 22px;background:var(--cream);display:flex;align-items:center;justify-content:space-between}
.om-foot .pickup{font-size:.82rem;color:var(--muted)}
.om-foot .pickup b{color:var(--ink);display:block;font-size:.95rem}

/* ---------- Products ---------- */
.tabs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.tab{padding:10px 20px;border-radius:999px;border:1.5px solid var(--line);font-weight:600;font-size:.92rem;color:var(--muted);background:var(--paper);transition:.18s}
.tab.active{background:var(--red);color:#fff;border-color:var(--red)}
.tab:hover:not(.active){border-color:var(--red);color:var(--red)}
.grid-prod{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.card{
  background:var(--paper);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);
  transition:transform .22s,box-shadow .22s;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-img{aspect-ratio:1/1;overflow:hidden;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card-img img{transform:scale(1.07)}
.card-tag{position:absolute;top:12px;left:12px;background:rgba(255,253,248,.94);color:var(--red);font-size:.72rem;font-weight:700;padding:5px 11px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.card-body{padding:16px 17px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-size:1.12rem;margin-bottom:5px}
.card-body p{font-size:.86rem;color:var(--muted);flex:1}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.card-foot .price{font-weight:700;font-family:var(--serif);font-size:1.15rem}
.card-foot button{background:var(--red);color:#fff;padding:9px 15px;border-radius:999px;font-weight:700;font-size:.85rem;transition:.15s}
.card-foot button:hover{background:var(--red-dark)}
.allergen-chip{display:inline-block;margin-top:8px;font-size:.74rem;color:var(--muted);background:var(--cream-2);padding:3px 9px;border-radius:6px}

/* ---------- Story / Backstube ---------- */
.story{background:var(--ink);color:#f4ece1;overflow:hidden}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.story h2{color:#fff}
.story .lede{color:#d8cabb}
.story-imgs{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.story-imgs img{border-radius:16px;box-shadow:var(--shadow);width:100%;height:100%;object-fit:cover}
.story-imgs .tall{grid-row:span 2;height:100%}
.story-stats{display:flex;gap:34px;margin-top:30px;flex-wrap:wrap}
.story-stats b{font-family:var(--serif);font-size:2.2rem;color:var(--gold-soft);display:block;line-height:1}
.story-stats span{font-size:.86rem;color:#cdbfb0}

/* ---------- Knusperkarte ---------- */
.knusper{background:linear-gradient(120deg,var(--gold) 0%,var(--gold-soft) 100%);color:#3a2a06}
.knusper-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.knusper h2{color:#3a2a06}
.knusper .perks{list-style:none;display:grid;gap:13px;margin:24px 0 30px}
.knusper .perks li{display:flex;gap:12px;align-items:center;font-weight:600}
.knusper .perks .dot{width:30px;height:30px;border-radius:8px;background:#3a2a06;color:var(--gold);display:grid;place-items:center;flex:none}
.kk-card{
  background:#3a2a06;color:#fff;border-radius:22px;padding:30px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;aspect-ratio:1.6/1;display:flex;flex-direction:column;justify-content:space-between;
}
.kk-card::after{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:rgba(239,176,0,.18)}
.kk-card .kk-logo{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:1.3rem;font-weight:700;color:var(--gold-soft)}
.kk-card .kk-pts{font-family:var(--serif);font-size:2.6rem;color:#fff}
.kk-card .kk-pts span{font-size:1rem;color:#cdbfb0}
.kk-card .kk-name{letter-spacing:.18em;font-size:.9rem;color:#e8dccb}

/* ---------- Filialen ---------- */
.filial-search{display:flex;gap:12px;max-width:520px;margin:0 auto 36px;background:var(--paper);padding:7px 7px 7px 20px;border-radius:999px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.filial-search input{flex:1;border:none;outline:none;font-size:1rem;background:transparent;color:var(--ink)}
.filial-search button{background:var(--red);color:#fff;padding:11px 22px;border-radius:999px;font-weight:700}
.grid-filial{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.fcard{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow-sm);transition:.2s}
.fcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.fcard h3{font-size:1.18rem;margin-bottom:4px}
.fcard .addr{color:var(--muted);font-size:.9rem;margin-bottom:12px}
.fcard .hours{font-size:.86rem;display:flex;gap:8px;align-items:center;margin-bottom:6px}
.fcard .live{display:inline-flex;align-items:center;gap:7px;background:#eaf6ee;color:var(--ok);font-size:.8rem;font-weight:700;padding:5px 11px;border-radius:999px;margin-top:6px}
.fcard .live .pulse{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(47,143,78,.5);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(47,143,78,.5)}70%{box-shadow:0 0 0 9px rgba(47,143,78,0)}100%{box-shadow:0 0 0 0 rgba(47,143,78,0)}}
.fcard .icons{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.fcard .icons span{font-size:.74rem;background:var(--cream-2);color:var(--muted);padding:4px 9px;border-radius:6px}

/* ---------- Jobs ---------- */
.jobs{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.jobs-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.jobs .perks{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}
.jobs .perks div{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px 16px;font-size:.9rem;font-weight:600;display:flex;gap:10px;align-items:center}
.jobs .perks .pi{font-size:1.3rem}
.form-card{background:var(--paper);border-radius:22px;padding:30px;box-shadow:var(--shadow);border:1px solid var(--line)}
.form-card h3{font-size:1.4rem;margin-bottom:6px}
.form-card .sub{color:var(--muted);font-size:.92rem;margin-bottom:20px}
.field{margin-bottom:15px}
.field label{display:block;font-size:.84rem;font-weight:600;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;
  font-size:.96rem;font-family:inherit;background:var(--cream);outline:none;transition:.15s;color:var(--ink);
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--red);background:#fff}
.form-note{font-size:.78rem;color:var(--muted);margin-top:12px}
.ai-hint{background:var(--cream-2);border-radius:11px;padding:13px 15px;font-size:.84rem;color:var(--ink);display:flex;gap:10px;margin:6px 0 18px}
.ai-hint .ai-dot{flex:none;width:30px;height:30px;border-radius:8px;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:700}

/* ---------- News (first-party) ---------- */
.grid-news{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ncard{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.2s}
.ncard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.ncard img{aspect-ratio:16/10;object-fit:cover;width:100%}
.ncard .nb{padding:18px}
.ncard .date{font-size:.78rem;color:var(--red);font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.ncard h3{font-size:1.15rem;margin:7px 0}
.ncard p{font-size:.88rem;color:var(--muted)}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:#cdbfb0;padding:64px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
footer h4{color:#fff;font-family:var(--serif);font-size:1.1rem;margin-bottom:16px}
footer a{display:block;padding:5px 0;font-size:.92rem;transition:.15s}
footer a:hover{color:var(--gold-soft)}
.foot-brand img{height:46px;margin-bottom:16px}
.foot-brand p{font-size:.9rem;max-width:280px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem}
.foot-bottom .made{color:var(--gold-soft)}

/* ---------- Cart drawer ---------- */
.overlay{position:fixed;inset:0;background:rgba(30,18,10,.5);z-index:90;opacity:0;pointer-events:none;transition:.3s}
.overlay.open{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--cream);
  z-index:100;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;box-shadow:-20px 0 60px -20px rgba(0,0,0,.4);
}
.drawer.open{transform:translateX(0)}
.drawer-head{padding:22px;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:space-between}
.drawer-head h3{color:#fff;font-size:1.3rem}
.drawer-head .close{color:#fff;font-size:1.6rem;line-height:1}
.drawer-body{flex:1;overflow-y:auto;padding:16px 22px}
.ci{display:flex;gap:13px;padding:14px 0;border-bottom:1px solid var(--line);align-items:center}
.ci img{width:58px;height:58px;border-radius:10px;object-fit:cover}
.ci .ci-name{font-weight:600;font-size:.95rem}
.ci .ci-price{color:var(--muted);font-size:.85rem}
.ci .qty{display:flex;align-items:center;gap:9px;margin-left:auto}
.ci .qty button{width:28px;height:28px;border-radius:8px;background:var(--cream-2);font-weight:700;font-size:1rem;color:var(--ink)}
.ci .qty button:hover{background:var(--gold-soft)}
.cart-empty{text-align:center;color:var(--muted);padding:50px 20px}
.cart-empty .be{font-size:3rem;margin-bottom:12px}
.pickup-box{padding:16px 22px;border-top:1px solid var(--line);background:var(--paper)}
.pickup-box label{font-size:.82rem;font-weight:600;display:block;margin-bottom:6px}
.pickup-box select{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;background:var(--cream);font-family:inherit;font-size:.92rem;margin-bottom:11px;color:var(--ink)}
.drawer-foot{padding:20px 22px;background:var(--paper);border-top:1px solid var(--line)}
.drawer-foot .tot{display:flex;justify-content:space-between;font-family:var(--serif);font-size:1.4rem;margin-bottom:14px}
.drawer-foot .btn{width:100%;justify-content:center}

/* ---------- AI Chat widget (Brotmeister) ---------- */
.chat-fab{
  position:fixed;bottom:24px;right:24px;z-index:80;background:var(--red);color:#fff;
  border-radius:999px;padding:15px 22px;font-weight:700;display:flex;align-items:center;gap:10px;
  box-shadow:0 14px 34px -10px rgba(156,27,22,.7);transition:transform .2s;
}
.chat-fab:hover{transform:translateY(-3px)}
.chat-fab .av{width:26px;height:26px;border-radius:50%;background:var(--gold);display:grid;place-items:center;font-size:.9rem}
.chat-panel{
  position:fixed;bottom:24px;right:24px;z-index:81;width:380px;max-width:92vw;height:540px;max-height:80vh;
  background:var(--cream);border-radius:22px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;
  transform:translateY(20px) scale(.96);opacity:0;pointer-events:none;transition:.26s;
}
.chat-panel.open{transform:none;opacity:1;pointer-events:auto}
.chat-head{background:var(--red);color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px}
.chat-head .av{width:42px;height:42px;border-radius:50%;background:var(--gold);display:grid;place-items:center;font-size:1.3rem;flex:none}
.chat-head .ch-name{font-weight:700}
.chat-head .ch-status{font-size:.78rem;opacity:.85;display:flex;align-items:center;gap:6px}
.chat-head .ch-status .pulse{width:7px;height:7px;border-radius:50%;background:#7be495}
.chat-head .close{margin-left:auto;color:#fff;font-size:1.5rem}
.chat-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;background:var(--cream)}
.msg{max-width:82%;padding:11px 15px;border-radius:16px;font-size:.92rem;line-height:1.5}
.msg.bot{background:var(--paper);border:1px solid var(--line);border-bottom-left-radius:5px;align-self:flex-start}
.msg.user{background:var(--red);color:#fff;border-bottom-right-radius:5px;align-self:flex-end}
.msg.bot b{color:var(--red)}
.chat-sugg{display:flex;gap:8px;flex-wrap:wrap;padding:0 18px 12px}
.chat-sugg button{font-size:.8rem;background:var(--cream-2);border:1px solid var(--line);color:var(--ink);padding:7px 12px;border-radius:999px;transition:.15s}
.chat-sugg button:hover{background:var(--gold-soft);border-color:var(--gold)}
.chat-input{display:flex;gap:8px;padding:14px 16px;background:var(--paper);border-top:1px solid var(--line)}
.chat-input input{flex:1;border:1.5px solid var(--line);border-radius:999px;padding:11px 16px;outline:none;font-size:.92rem;background:var(--cream);font-family:inherit;color:var(--ink)}
.chat-input input:focus{border-color:var(--red)}
.chat-input button{background:var(--red);color:#fff;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:none}
.typing{display:flex;gap:4px;padding:13px 16px}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:typ 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}
.typing span:nth-child(3){animation-delay:.4s}
@keyframes typ{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(80px);z-index:120;background:var(--ink);color:#fff;padding:14px 24px;border-radius:999px;font-weight:600;font-size:.92rem;box-shadow:var(--shadow);opacity:0;transition:.3s;display:flex;align-items:center;gap:10px}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast .tk{color:var(--gold-soft)}

/* ---------- Legal pages (Impressum / Datenschutz) ---------- */
.legal-hero{background:var(--red);color:#fff;padding:130px 0 50px}
.legal-hero h1{color:#fff;font-size:clamp(2rem,4vw,2.8rem)}
.legal-hero p{opacity:.85;margin-top:8px}
.legal{padding:54px 0 80px;background:var(--cream)}
.legal .wrap{max-width:820px}
.legal h2{font-size:1.5rem;margin:36px 0 12px;color:var(--red)}
.legal h2:first-child{margin-top:0}
.legal h3{font-size:1.12rem;margin:22px 0 8px}
.legal p,.legal li{font-size:1rem;color:var(--ink);margin-bottom:10px}
.legal ul{margin:0 0 14px 22px}
.legal a{color:var(--red);text-decoration:underline}
.legal .box{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:22px 26px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.legal .note{background:var(--cream-2);border-left:4px solid var(--gold);padding:14px 18px;border-radius:8px;font-size:.9rem;color:var(--muted);margin:18px 0}
.back-home{display:inline-flex;align-items:center;gap:8px;margin-bottom:26px;font-weight:600;color:var(--red)}
.back-home:hover{text-decoration:underline}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .grid-prod{grid-template-columns:repeat(2,1fr)}
  .grid-filial,.grid-news{grid-template-columns:repeat(2,1fr)}
  .order-grid,.story-grid,.knusper-grid,.jobs-grid{grid-template-columns:1fr;gap:40px}
  .story-imgs{max-width:440px}
}
@media(max-width:760px){
  .nav-links{
    position:fixed;top:0;right:0;height:100vh;width:75vw;max-width:320px;background:var(--cream);
    flex-direction:column;justify-content:center;gap:28px;transform:translateX(100%);transition:.3s;
    box-shadow:-20px 0 60px -20px rgba(0,0,0,.4);z-index:70;
  }
  .nav-links.open{transform:none}
  .nav-links a{font-size:1.2rem}
  .burger{display:flex}
  .hero p{font-size:1.08rem}
  .strip .wrap{justify-content:flex-start;gap:14px}
  .strip div{font-size:.86rem}
  .jobs .perks{grid-template-columns:1fr}
  .grid-news{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px}
  .sec{padding:66px 0}
}
@media(max-width:520px){
  .grid-prod,.grid-filial{grid-template-columns:1fr}
  .nav-cta .cart-label{display:none}
  .hero-badges{gap:18px}
}
