/* Dorfkorb Kunden-App - Premium Design-System (Light Mode) */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700;display=swap');
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;display=swap');

:root{
  --green:#2f9e54; --green-d:#1f6b39; --green-x:#16502d; --forest:#10331f;
  --accent:#ff6a2b; --accent-d:#c44a12; --accent-soft:#fff1e7; --lime:#bfe65a;
  --bg:#f4f1e8; --surface:#fffdf9; --surface-2:#efeadd;
  --ink:#19231c; --ink-2:#5e6a5f; --ink-3:#9aa298;
  --line:#e6e1d2; --line-soft:#eee9dc;
  --tint:#e9f4ea; --tint-2:#dcecdd; --sand:#f3ecda;
  --hero:linear-gradient(155deg,#34a85b 0%,#23824a 50%,#16502d 100%);
  --grad:linear-gradient(135deg,#3fb567,#1f7a40);
  --grad-orange:linear-gradient(135deg,#ff8a4d,#ff6a2b 55%,#e85618);
  --tile-grad:linear-gradient(140deg,#eaf4e6,#f3ecda);
  --r:24px; --r-md:18px; --r-sm:14px;
  --sh-1:0 1px 2px rgba(22,40,28,.05),0 8px 22px rgba(22,40,28,.07);
  --sh-2:0 2px 4px rgba(22,40,28,.06),0 18px 44px rgba(22,40,28,.13);
  --glow:0 12px 28px rgba(31,107,57,.28);
  --glow-orange:0 12px 26px rgba(255,106,43,.30);
  --f-disp:'Fraunces',Georgia,serif;
  --f-ui:'Plus Jakarta Sans','Poppins',system-ui,sans-serif;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0}
body{
  color:var(--ink);
  font-family:var(--f-ui);
  font-size:17px;line-height:1.55;
  padding-bottom:128px;
  background-color:var(--bg);
  background-image:
    radial-gradient(120% 70% at 0% 0%,rgba(47,158,84,.10),transparent 55%),
    radial-gradient(110% 60% at 100% 2%,rgba(255,106,43,.06),transparent 55%),
    radial-gradient(140% 80% at 50% 100%,rgba(47,158,84,.05),transparent 60%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
::selection{background:rgba(47,158,84,.22)}

/* HERO / TOP-BAR */
.bar{
  position:sticky;top:0;z-index:20;color:#fff;
  display:flex;align-items:center;gap:.75rem;
  padding:1.15rem 1.2rem 1.35rem;
  border-radius:0 0 30px 30px;
  background:
    radial-gradient(85% 130% at 88% -20%,rgba(255,255,255,.24),transparent 58%),
    radial-gradient(70% 120% at 5% 120%,rgba(191,230,90,.20),transparent 60%),
    var(--hero);
  box-shadow:0 12px 32px rgba(16,80,45,.32);
  overflow:hidden;
}
.bar::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(120deg,rgba(255,255,255,.14),transparent 42%);
}
.bar .back,.bar .home{
  position:relative;z-index:1;color:#fff;text-decoration:none;
  background:rgba(255,255,255,.18);backdrop-filter:blur(6px);
  width:46px;height:46px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.55rem;line-height:1;flex:none;
  border:1px solid rgba(255,255,255,.16);
  transition:transform .12s ease,background .15s ease;
}
.bar .back:active,.bar .home:active{transform:scale(.92);background:rgba(255,255,255,.28)}
.bar .bar-title{
  position:relative;z-index:1;flex:1;
  font-family:var(--f-disp);font-weight:600;font-size:1.42rem;letter-spacing:-.01em;
  text-shadow:0 1px 10px rgba(0,40,20,.18);
}

main.app{max-width:600px;margin:0 auto;padding:1.2rem 1.15rem}

/* UEBERSCHRIFTEN / SEKTIONEN */
h2{
  font-family:var(--f-disp);font-weight:600;
  font-size:1.7rem;line-height:1.18;letter-spacing:-.01em;
  margin:.4rem 0 1.1rem;color:var(--ink);
}
.cat{
  display:flex;align-items:center;gap:.7rem;
  font-family:var(--f-ui);font-size:.8rem;font-weight:800;color:var(--ink-2);
  letter-spacing:.14em;text-transform:uppercase;margin:1.7rem 0 .85rem;
}
.cat::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);flex:none;box-shadow:0 0 0 4px rgba(47,158,84,.14)}
.cat::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--line),transparent)}

/* HERO-BEGRUESSUNG */
.hello{
  font-family:var(--f-disp);font-weight:600;
  font-size:2rem;line-height:1.16;letter-spacing:-.01em;
  margin:.5rem 0 1.3rem;color:var(--ink);
}
.hello span{color:var(--green-d);font-weight:700;font-style:italic}

/* GROSSE AKTIONS-BUTTONS */
.big-btn{
  position:relative;display:flex;align-items:center;gap:1rem;width:100%;
  min-height:64px;border:0;border-radius:var(--r-md);
  padding:1.2rem 1.25rem;margin-bottom:1rem;
  font:700 1.3rem/1.2 var(--f-ui);color:#fff;text-align:left;text-decoration:none;
  background:var(--hero);box-shadow:var(--glow);
  cursor:pointer;overflow:hidden;
  transition:transform .13s ease,box-shadow .13s ease;
}
.big-btn::after{
  content:"";position:absolute;left:0;right:0;top:0;height:46%;
  background:linear-gradient(180deg,rgba(255,255,255,.18),transparent);
  pointer-events:none;
}
.big-btn:active{transform:translateY(2px) scale(.985);box-shadow:0 6px 16px rgba(31,107,57,.26)}
.big-btn small{display:block;font-weight:500;font-size:.92rem;opacity:.9;margin-top:.12rem}
.big-btn .ico{
  flex:none;width:46px;height:46px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.65rem;line-height:1;
  background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25);
}
.big-btn.alt{
  background:var(--surface);color:var(--green-d);
  box-shadow:var(--sh-1);border:1px solid var(--line);
}
.big-btn.alt::after{display:none}
.big-btn.alt .ico{background:var(--tint);color:var(--green-d);border:1px solid var(--tint-2);box-shadow:none}
.big-btn.alt:active{transform:translateY(1px) scale(.99);box-shadow:var(--sh-2)}
.big-btn.angebote{background:var(--grad-orange);color:#fff;box-shadow:var(--glow-orange);border:0}
.big-btn.angebote .ico{background:rgba(255,255,255,.22);color:#fff;border:1px solid rgba(255,255,255,.2)}
.big-btn:first-of-type:not(.alt){box-shadow:var(--glow),0 0 0 2px rgba(191,230,90,.35)}

/* PRODUKTKARTE */
.tile{
  position:relative;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--sh-1);
  display:flex;align-items:center;gap:1rem;
  padding:.8rem;margin-bottom:.9rem;
  transition:box-shadow .15s ease,transform .12s ease;
}
.tile::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);pointer-events:none;
}
.tile:active{transform:translateY(1px)}
.tile.in-cart{box-shadow:0 0 0 2px var(--green),var(--sh-1)}
.tile.in-cart::after{
  content:"";position:absolute;left:0;top:16px;bottom:16px;width:5px;
  border-radius:0 6px 6px 0;background:var(--grad);
}
.thumb{
  width:84px;height:84px;flex:none;border-radius:18px;overflow:hidden;position:relative;
  display:flex;align-items:center;justify-content:center;
  font-size:2.6rem;line-height:1;
  background:var(--tile-grad);
  box-shadow:inset 0 0 0 1px rgba(31,107,57,.08),inset 0 -10px 20px rgba(255,255,255,.4);
}
.thumb img{width:100%;height:100%;object-fit:cover}
.tile .info{flex:1 1 0;min-width:0}
.tile .name{
  font-weight:700;font-size:1.15rem;line-height:1.26;letter-spacing:-.01em;color:var(--ink);
  display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;
}
.tile .price{
  color:var(--green-d);font-weight:800;font-size:1.18rem;margin-top:.22rem;
  font-variant-numeric:tabular-nums;
}
.tile .price s{color:var(--ink-3);font-weight:500;font-size:.95rem;margin-right:.4rem}
.tile .unit,.unit{color:var(--ink-2);font-weight:500;font-size:.9rem}
.tile .price .unit{font-size:.85rem}

.badge{
  display:inline-block;padding:.2rem .58rem;border-radius:999px;
  font:800 .72rem/1 var(--f-ui);text-transform:uppercase;letter-spacing:.04em;
  background:var(--grad-orange);color:#fff;vertical-align:middle;
  box-shadow:0 4px 10px rgba(255,106,43,.32);
  transform:rotate(-3deg);
}
.badge.bio{background:var(--tint-2);color:var(--green-d);box-shadow:none;transform:none}

/* MENGEN-STEPPER */
.qty{
  display:flex;align-items:center;gap:.35rem;flex:none;
  background:var(--surface-2);padding:.28rem;border-radius:var(--r-md);
  box-shadow:inset 0 1px 2px rgba(22,40,28,.06);
}
.qty button{
  width:52px;height:52px;border:0;border-radius:var(--r-sm);
  font-size:1.7rem;font-weight:700;line-height:1;cursor:pointer;
  background:var(--tint);color:var(--green-d);
  transition:transform .1s ease,filter .12s ease;
}
.qty button:active{transform:scale(.9)}
.qty button.plus{background:var(--hero);color:#fff;box-shadow:var(--glow)}
.qty button.plus:active{transform:scale(.88)}
.qty input{
  width:46px;text-align:center;border:0;background:transparent;padding:0;
  font:800 1.25rem var(--f-ui);color:var(--ink);font-variant-numeric:tabular-nums;
}

/* SCHWEBENDE GLAS-BOTTOMBAR */
.bottombar{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:calc(14px + env(safe-area-inset-bottom,0px));
  width:min(452px,calc(100% - 24px));
  background:rgba(255,253,249,.85);backdrop-filter:blur(18px) saturate(1.6);
  -webkit-backdrop-filter:blur(18px) saturate(1.6);
  border:1px solid var(--line);border-radius:24px;box-shadow:var(--sh-2);
  padding:.7rem .8rem .7rem 1.25rem;
  display:flex;align-items:center;gap:1rem;z-index:30;
  animation:barUp .35s cubic-bezier(.2,.9,.3,1);
}
@keyframes barUp{from{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%,0)}}
.bottombar .sum{
  font:800 1.35rem var(--f-ui);white-space:nowrap;letter-spacing:-.01em;
  font-variant-numeric:tabular-nums;color:var(--ink);
}
.bottombar .sum small,.bottombar .sum .muted{
  display:block;font:600 .72rem var(--f-ui);color:var(--ink-2);margin-top:.05rem;
}
.bottombar .big-btn{margin:0;flex:1;justify-content:center;font-size:1.15rem;min-height:54px;padding:1rem}

/* BESTELL-STATUS */
.status{
  position:relative;display:flex;gap:.9rem;align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:1.1rem 1.15rem;margin-bottom:.9rem;box-shadow:var(--sh-1);
}
.status::before{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 1px 0 rgba(255,255,255,.9);pointer-events:none}
.status strong{font-weight:700}
.status .back{
  width:48px;height:48px;border-radius:14px;flex:none;
  display:flex;align-items:center;justify-content:center;text-decoration:none;
  background:var(--tint);color:var(--green-d);font-size:1.4rem;
  border:1px solid var(--tint-2);transition:transform .12s ease;
}
.status .back:active{transform:scale(.92)}
.dot{
  width:14px;height:14px;border-radius:50%;flex:none;
  box-shadow:0 0 0 4px rgba(47,158,84,.12);
}

/* FORMULARE */
label{display:block;font-weight:700;margin:1.15rem 0 .4rem;font-size:.95rem;color:var(--ink)}
input.f,select.f{
  width:100%;padding:1.05rem 1.05rem;
  font:500 1.1rem var(--f-ui);color:var(--ink);
  border:1.5px solid var(--line);border-radius:var(--r-sm);
  background:var(--surface);
  transition:border-color .15s ease,box-shadow .15s ease;
}
select.f{
  background-image:linear-gradient(45deg,transparent 50%,var(--green-d) 50%),linear-gradient(135deg,var(--green-d) 50%,transparent 50%);
  background-position:calc(100% - 22px) 1.45rem,calc(100% - 15px) 1.45rem;
  background-size:7px 7px,7px 7px;background-repeat:no-repeat;
  padding-right:2.8rem;appearance:none;-webkit-appearance:none;
}
input.f:focus,select.f:focus{
  outline:none;border-color:var(--green);
  box-shadow:0 0 0 4px rgba(47,158,84,.16);
}
input.f::placeholder{color:var(--ink-3)}

.muted{color:var(--ink-2)}
.note{text-align:center;color:var(--ink-2);margin:1.3rem 0;font-size:.98rem}
.note a{color:var(--green-d);font-weight:700;text-decoration:none}
.note a:active{text-decoration:underline}

.msg{
  position:relative;background:var(--surface);
  border:1px solid var(--line);border-left:5px solid var(--green);
  border-radius:var(--r-sm);padding:1rem 1.1rem;margin-bottom:1.1rem;
  box-shadow:var(--sh-1);font-weight:500;
}
.msg.err{border-left-color:var(--accent);background:var(--accent-soft)}
.msg a{color:var(--green-d);font-weight:700}

/* KARTE / ZENTRIERTE ZUSTAENDE / DANKE */
.card{
  position:relative;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:1.4rem;box-shadow:var(--sh-1);
}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 1px 0 rgba(255,255,255,.9);pointer-events:none}

.center{text-align:center}
.big-emoji{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:120px;height:120px;margin:1.6rem auto .6rem;border-radius:50%;
  font-size:3.6rem;line-height:1;
  background:radial-gradient(circle at 50% 38%,var(--tint),var(--surface-2));
  box-shadow:var(--sh-2),inset 0 0 0 1px rgba(31,107,57,.1);
}
.big-emoji::after{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid rgba(47,158,84,.35);
  animation:ring 1.8s ease-out infinite;
}
@keyframes ring{0%{transform:scale(.95);opacity:.8}70%{transform:scale(1.18);opacity:0}100%{opacity:0}}

/* LEERE ZUSTAENDE - optionaler Markup-Hook .empty zusaetzlich an .muted */
.empty{
  text-align:center;font-size:1.15rem;font-weight:500;color:var(--ink-2);
  padding:2.4rem 1rem 1.4rem;
}
.empty::before{
  content:"\01F9FA";display:block;font-size:3.4rem;margin-bottom:.6rem;
  filter:drop-shadow(0 8px 14px rgba(22,40,28,.14));
}

/* KLEINERE PHONES */
/* Vektor-Icons in Buttons & Bar */
.big-btn .ico svg{width:26px;height:26px}
.bar .back svg,.bar .home svg{width:24px;height:24px}

/* HERO-BANNER (Startseite) */
.herobanner{position:relative;border-radius:24px;overflow:hidden;margin:.2rem 0 1.4rem;
  aspect-ratio:16/10;box-shadow:var(--sh-2);border:1px solid var(--line)}
.herobanner img{width:100%;height:100%;object-fit:cover}
.herobanner::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(16,51,31,.55),transparent 55%)}
.herobanner-cap{position:absolute;left:1.1rem;bottom:1rem;z-index:1;color:#fff;
  font-family:var(--f-disp);font-weight:600;font-size:1.7rem;line-height:1.05;letter-spacing:-.01em;
  text-shadow:0 2px 14px rgba(0,0,0,.45)}

/* ====== SUCHE + PRODUKT-RASTER (Top-App) ====== */
.searchbar{display:flex;align-items:center;gap:.6rem;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;padding:.85rem 1rem;margin:.1rem 0 1.2rem;box-shadow:var(--sh-1);color:var(--ink-2)}
.searchbar svg{width:21px;height:21px;flex:none}
.searchbar input{flex:1;border:0;background:transparent;font:inherit;font-size:1.05rem;color:var(--ink);outline:none}
.searchbar input::placeholder{color:var(--ink-3)}

.grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:.3rem}

.pcard{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:20px;
  overflow:hidden;box-shadow:var(--sh-1);display:flex;flex-direction:column;transition:box-shadow .15s ease,transform .12s ease}
.pcard.active{box-shadow:0 0 0 2px var(--green),var(--sh-2)}
.pcard-img{position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pcard-img img{width:100%;height:100%;object-fit:cover}
.pcard-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.06));pointer-events:none}
.pcard-ic{color:var(--green-d);opacity:.85}
.pcard-ic svg{width:48px;height:48px}
.pcard-badge{position:absolute;top:.55rem;left:.55rem;z-index:2;background:var(--grad-orange);color:#fff;
  font-size:.68rem;font-weight:800;padding:.22rem .55rem;border-radius:999px;box-shadow:var(--glow-orange);letter-spacing:.03em;text-transform:uppercase}
.pcard-body{padding:.7rem .8rem .85rem}
.pcard-name{font-weight:700;font-size:1rem;line-height:1.25;color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.5em}
.pcard-price{color:var(--green-d);font-weight:800;font-size:1.1rem;margin-top:.3rem;font-variant-numeric:tabular-nums}
.pcard-price s{color:var(--ink-3);font-weight:500;font-size:.82rem;margin-right:.25rem}
.pcard-unit{color:var(--ink-2);font-weight:500;font-size:.8rem}

.pcard-ctrl{position:absolute;right:.5rem;bottom:.5rem;z-index:2;display:flex;align-items:center;gap:.1rem;
  background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border-radius:999px;padding:.22rem;
  box-shadow:0 6px 16px rgba(22,40,28,.24)}
.pcard-ctrl .plus{width:40px;height:40px;border:0;border-radius:50%;background:var(--grad);color:#fff;
  font-size:1.6rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(31,107,57,.4);transition:transform .1s ease}
.pcard-ctrl .plus:active{transform:scale(.86)}
.pcard-ctrl .minus,.pcard-ctrl .qn{display:none}
.pcard.active .pcard-ctrl .minus{display:flex;width:36px;height:36px;border:0;border-radius:50%;
  background:var(--tint);color:var(--green-d);font-size:1.5rem;line-height:1;cursor:pointer;align-items:center;justify-content:center}
.pcard.active .pcard-ctrl .qn{display:flex;min-width:22px;align-items:center;justify-content:center;font-weight:800;font-size:1.05rem;color:var(--ink)}

@media(max-width:430px){
  main.app{padding:.9rem .8rem}
  .hello{font-size:1.78rem}
  h2{font-size:1.5rem}
  .thumb{width:64px;height:64px;font-size:2rem;border-radius:15px}
  .tile{gap:.5rem;padding:.5rem}
  .tile .name{font-size:1.02rem}
  .tile .price{font-size:1.06rem}
  .tile{gap:.75rem;padding:.65rem}
  .tile .name{font-size:1.08rem}
  .tile .price{font-size:1.1rem}
  .qty{gap:.15rem;padding:.18rem}
  .qty button{width:46px;height:46px;font-size:1.5rem}
  .qty input{width:24px;font-size:1.1rem}
  .bottombar .big-btn{font-size:1.05rem}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none;transition:none}
}
/* ====== DESKTOP/TABLET: zentrierte App-Shell auf Premium-Ambient ====== */
.shell{position:relative}
@media(min-width:740px){
  body{
    padding-bottom:0;
    background:#10331f;
    background-image:
      radial-gradient(70% 55% at 50% -5%, #1e5e38, transparent 70%),
      radial-gradient(90% 60% at 50% 105%, #0a2716, transparent 65%),
      linear-gradient(160deg,#15492b,#0c2a19);
    background-attachment:fixed;
    display:flex;justify-content:center;
  }
  .shell{
    width:480px;max-width:480px;min-height:100vh;
    background-color:var(--bg);
    background-image:
      radial-gradient(120% 60% at 0% 0%,rgba(47,158,84,.10),transparent 55%),
      radial-gradient(110% 50% at 100% 2%,rgba(255,106,43,.06),transparent 55%);
    box-shadow:0 30px 90px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.04);
    padding-bottom:128px;
  }
  .bar{border-radius:0 0 28px 28px}
  main.app{max-width:none}
}

/* ============ TOP-APP KOMPONENTEN (nach Higgsfield-Mockup) ============ */
body{padding-bottom:150px}

/* Bottom-Tab-Bar */
.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:0;z-index:30;width:min(480px,100%);
  display:flex;background:rgba(255,253,249,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--line);box-shadow:0 -6px 22px rgba(22,40,28,.08);
  padding:.35rem .2rem calc(.35rem + env(safe-area-inset-bottom,0px))}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:.12rem;padding:.4rem 0;
  text-decoration:none;color:var(--ink-3);font-size:.68rem;font-weight:700;transition:color .12s}
.tabbar a svg{width:23px;height:23px}
.tabbar a.on{color:var(--green-d)}

/* dunkelgrüne Warenkorb-Leiste (über der Tab-Bar) */
.bottombar{bottom:calc(74px + env(safe-area-inset-bottom,0px)) !important;
  background:var(--hero) !important;border:0 !important;box-shadow:0 14px 34px rgba(16,80,45,.42) !important}
.bottombar .sum{color:#fff}
.bottombar .sum small{color:rgba(255,255,255,.82)}
.bottombar .big-btn{background:var(--grad-orange);box-shadow:var(--glow-orange)}

/* Hero-Promo (Home) */
.promo{position:relative;border-radius:24px;overflow:hidden;margin:.3rem 0 .6rem;aspect-ratio:16/11;box-shadow:var(--sh-2);border:1px solid var(--line)}
.promo img{width:100%;height:100%;object-fit:cover}
.promo::after{content:"";position:absolute;inset:0;background:linear-gradient(95deg,rgba(11,42,25,.85),rgba(11,42,25,.15) 72%)}
.promo-in{position:absolute;inset:0;z-index:1;padding:1.2rem 1.3rem;display:flex;flex-direction:column;justify-content:center;gap:.45rem;max-width:78%}
.promo-badge{align-self:flex-start;background:rgba(255,255,255,.16);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.32);color:#fff;font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .6rem;border-radius:999px}
.promo-h{font-family:var(--f-disp);color:#fff;font-weight:600;font-size:1.65rem;line-height:1.06;letter-spacing:-.01em}
.promo-sub{color:rgba(255,255,255,.9);font-size:.9rem;line-height:1.3}
.promo-btn{align-self:flex-start;margin-top:.3rem;background:var(--grad-orange);color:#fff;font-weight:800;padding:.6rem 1.15rem;border-radius:999px;text-decoration:none;box-shadow:var(--glow-orange);font-size:.92rem}

/* Sektion-Kopf */
.sec{display:flex;align-items:center;justify-content:space-between;margin:1.6rem 0 .9rem}
.sec h3{font-family:var(--f-disp);font-weight:600;font-size:1.32rem;margin:0;letter-spacing:-.01em}
.sec a{color:var(--green-d);font-weight:700;font-size:.85rem;text-decoration:none}

/* horizontale Scroller */
.hscroll{display:flex;gap:.8rem;overflow-x:auto;margin:0 -1.15rem;padding:.2rem 1.15rem .5rem;scrollbar-width:none}
.hscroll::-webkit-scrollbar{display:none}

/* Kategorie-Kachel */
.ctile{flex:none;width:90px;text-decoration:none;text-align:center}
.ctile .ph{width:90px;height:90px;border-radius:22px;overflow:hidden;box-shadow:var(--sh-1);border:1px solid var(--line);background:var(--tile-grad)}
.ctile .ph img{width:100%;height:100%;object-fit:cover}
.ctile .nm{display:block;margin-top:.45rem;font-size:.78rem;font-weight:700;color:var(--ink);line-height:1.2}

/* Empfehlungs-Karte */
.rcard{flex:none;width:152px;background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--sh-1);text-decoration:none;display:block}
.rcard .ph{aspect-ratio:1/1;overflow:hidden}
.rcard .ph img{width:100%;height:100%;object-fit:cover}
.rcard .bd{padding:.55rem .7rem .7rem}
.rcard .nm{font-weight:700;font-size:.92rem;color:var(--ink);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.3em}
.rcard .pr{color:var(--green-d);font-weight:800;margin-top:.25rem;font-size:1.02rem}
.rcard .pr small{color:var(--ink-2);font-weight:500}

/* Trust-Badges */
.trust{display:flex;gap:.5rem;margin:1.5rem 0 .3rem}
.trust div{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:.8rem .4rem;text-align:center;font-size:.68rem;font-weight:700;color:var(--ink-2);box-shadow:var(--sh-1);line-height:1.25}
.trust svg{width:22px;height:22px;color:var(--green);display:block;margin:0 auto .3rem}

/* Kategorie-Chips (Katalog) */
.chips{display:flex;gap:.5rem;overflow-x:auto;margin:0 -1.15rem 1.1rem;padding:.1rem 1.15rem;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:none;padding:.55rem .95rem;border-radius:999px;background:var(--surface);border:1px solid var(--line);font-weight:700;font-size:.85rem;color:var(--ink-2);text-decoration:none;white-space:nowrap;box-shadow:var(--sh-1)}
.chip.on{background:var(--hero);color:#fff;border-color:transparent;box-shadow:var(--glow)}

@media(min-width:740px){ .shell{padding-bottom:150px} }

/* ============ PREMIUM AUTH (Login/Registrierung) ============ */
body.auth{padding-bottom:0;background:#10331f}
.auth-shell{min-height:100vh;display:flex;flex-direction:column}
.auth-hero{position:relative;flex:1 1 auto;min-height:44vh;background:#0c2a19 center/cover no-repeat;
  background-image:url('/assets/hero.jpg');display:flex;align-items:flex-end}
.auth-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,42,25,.22) 25%,rgba(11,42,25,.92))}
.auth-hero-in{position:relative;z-index:1;padding:2rem 1.6rem 3.4rem}
.auth-brand{font-family:var(--f-disp);font-weight:600;font-size:2.8rem;color:#fff;line-height:1;letter-spacing:-.02em;text-shadow:0 2px 18px rgba(0,0,0,.4)}
.auth-tag{color:rgba(255,255,255,.92);font-size:1.05rem;margin-top:.55rem;line-height:1.35;max-width:18em}
.auth-sheet{position:relative;z-index:2;margin-top:-26px;flex:none;background:var(--surface);
  border-radius:30px 30px 0 0;padding:1.8rem 1.5rem 2.4rem;box-shadow:0 -14px 36px rgba(0,0,0,.18)}
.auth-h{font-family:var(--f-disp);font-weight:600;font-size:1.85rem;margin:.1rem 0 .35rem;letter-spacing:-.01em}
.auth-p{color:var(--ink-2);margin:0 0 1.3rem;font-size:1rem}
.authlink{display:block;text-align:center;margin-top:1.3rem;color:var(--ink-2);text-decoration:none;font-weight:500;font-size:1.02rem}
.authlink b{color:var(--green-d);font-weight:800}
.auth label{margin-top:0}

/* ============ PREMIUM BUTTONS (kein langweiliges Flach mehr) ============ */
.big-btn{border-radius:999px;min-height:62px;padding:1.05rem 1.5rem;letter-spacing:.01em;
  box-shadow:var(--glow), inset 0 1px 0 rgba(255,255,255,.25)}
.big-btn::after{height:50%;border-radius:999px 999px 40% 40%/999px 999px 60% 60%;background:linear-gradient(180deg,rgba(255,255,255,.22),transparent)}
.big-btn:not(.alt) .ico{background:rgba(255,255,255,.22)}
.big-btn.alt{border-radius:18px}
.promo-btn{padding:.7rem 1.3rem;box-shadow:var(--glow-orange),inset 0 1px 0 rgba(255,255,255,.3)}
/* primärer Submit in der Auth-Sheet richtig fett */
.auth .big-btn{width:100%;justify-content:center;font-size:1.2rem}
