/* =====================================================================
   Kropp Feinkost – Marken-Design (portiert aus den HTML-Mockups)
   Tokens hell/dunkel, Typografie, Buttons, Cards, Header/Nav, Hero, Footer
   ===================================================================== */

/* ---------- Design-Tokens: HELL (Standard) ---------- */
:root{
  --head-bar:#282828; --head-text:#f3e9d6;
  --bg:#FAF3E5; --bg2:#F3E9D6; --surface:#ffffff;
  --text:#2c2823; --muted:#6f675a; --head:#282828;
  --accent:#A8472A; --accent-h:#90391f; --on-accent:#fff;
  --wood:#785F44; --line:#e7dcc4;
  --card-sh:0 14px 36px rgba(60,40,20,.12);

  /* Hero */
  --hero-img:url('../img/hero-light.jpg'); --hero-op:1;
  --hero-veil:linear-gradient(95deg,var(--bg) 0%,rgba(250,243,229,.94) 32%,rgba(250,243,229,.5) 50%,rgba(250,243,229,.04) 66%,transparent 80%);
  --disc:radial-gradient(circle at 50% 36%,#ffffff,#efe3cd);
  --disc-ring:rgba(120,95,68,.16); --scrim:rgba(250,243,229,.74);
}

/* ---------- Design-Tokens: DUNKEL ---------- */
:root[data-theme="dark"]{
  --head-bar:#0e0e0e; --head-text:#efe7d6;
  --bg:#161514; --bg2:#1d1b19; --surface:#242220;
  --text:#e8e0d2; --muted:#a99f8d; --head:#f5efe2;
  --accent:#cf6e4b; --accent-h:#e07d59; --on-accent:#1a1410;
  --wood:#8a6f50; --line:#34302b;
  --card-sh:0 16px 40px rgba(0,0,0,.5);

  --hero-img:url('../img/hero-dark.jpg'); --hero-op:1;
  --hero-veil:linear-gradient(95deg,rgba(18,17,16,.96) 0%,rgba(18,17,16,.9) 32%,rgba(18,17,16,.5) 50%,rgba(18,17,16,.08) 66%,transparent 80%);
  --disc:url('../img/woodgrain.jpg') center/cover;
  --disc-ring:rgba(0,0,0,.35); --scrim:rgba(18,17,16,.74);
}

/* ---------- Grundlagen ---------- */
body{
  background:var(--bg); color:var(--text);
  font-family:'Libre Franklin',Arial,sans-serif; line-height:1.6;
  transition:background .35s,color .35s;
}
h1,h2,h3,h4{
  font-family:'Fraunces','Georgia',serif; font-weight:900;
  color:var(--head); line-height:1.12; letter-spacing:-.01em;
}
a{color:inherit;}
img{display:block;max-width:100%;}

/* ---------- Buttons ---------- */
.kropp-btn,
.wp-block-button__link{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--accent); color:#fff!important;
  border:none; border-radius:8px;
  padding:13px 22px; font-weight:600; font-family:inherit;
  text-decoration:none; cursor:pointer; transition:.2s;
}
.kropp-btn:hover,
.wp-block-button__link:hover{ background:var(--accent-h); }
.kropp-btn--ghost{
  background:transparent; color:var(--accent)!important;
  border:1.5px solid var(--accent);
}
.kropp-btn--ghost:hover{ background:var(--accent); color:#fff!important; }

/* ---------- Cards ---------- */
.kropp-card{
  background:var(--surface); border:1px solid var(--line);
  border-radius:14px; padding:18px 20px; box-shadow:var(--card-sh);
}

/* ---------- Header / Kopfleiste ---------- */
.kropp-header{
  background:var(--head-bar); position:sticky; top:0; z-index:80;
  box-shadow:0 2px 14px rgba(0,0,0,.18); transition:background .35s;
}
.kropp-nav{
  display:flex; flex-wrap:wrap; align-items:center; gap:10px 16px;
  max-width:1140px; margin:0 auto; padding:12px 24px;
}
.kropp-nav .brand img{ height:42px; filter:invert(1) brightness(1.6); }
.kropp-menu{ display:flex; gap:20px; align-items:center; }
.kropp-menu>a,.navitem>a{
  color:var(--head-text); text-decoration:none; font-size:15.5px;
  font-weight:500; opacity:.92; padding:4px 0;
  border-bottom:2px solid transparent; transition:.2s; white-space:nowrap;
}
.kropp-menu>a:hover,.navitem>a:hover,
.kropp-menu>a.active,.navitem.active>a{ opacity:1; border-bottom-color:var(--accent); }

/* Dropdown-Untermenüs */
.navitem{position:relative;}
.navitem>a.drop{cursor:pointer;}
.navitem::after{content:"";position:absolute;top:100%;left:0;right:0;height:10px;}
.submenu{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(6px);min-width:230px;
  background:var(--surface);border:1px solid var(--line);border-radius:12px;
  box-shadow:0 16px 40px rgba(0,0,0,.3);padding:8px;display:flex;flex-direction:column;
  opacity:0;visibility:hidden;transition:.18s;z-index:95;
}
.navitem:hover .submenu,.navitem:focus-within .submenu{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);
}
.submenu a{
  color:var(--text)!important;opacity:1;padding:10px 14px;border-radius:8px;
  font-size:14.5px;border:none!important;text-decoration:none;white-space:nowrap;
}
.submenu a:hover{ background:var(--bg2); color:var(--accent)!important; }

/* ---------- Theme-Umschalter ---------- */
.kropp-toggle{
  display:inline-flex; align-items:center; gap:7px; cursor:pointer;
  background:rgba(255,255,255,.1); color:var(--head-text);
  border:1px solid rgba(255,255,255,.22); border-radius:22px;
  height:40px; padding:0 14px; font-family:inherit; font-size:13.5px;
  font-weight:600; white-space:nowrap; transition:.2s;
}
.kropp-toggle:hover{ background:rgba(255,255,255,.18); }
.kropp-toggle .lbl-dark{display:none;}
:root[data-theme="dark"] .kropp-toggle .lbl-light{display:none;}
:root[data-theme="dark"] .kropp-toggle .lbl-dark{display:inline;}

/* ---------- HERO (Startseite) ---------- */
.kropp-hero{position:relative;overflow:hidden;background:var(--bg2);}
.kropp-hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:var(--hero-img) right center/cover no-repeat;
  opacity:var(--hero-op);transition:opacity .4s ease;
}
.kropp-hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to bottom,transparent 76%,var(--bg)),
             radial-gradient(120% 95% at 84% 6%,rgba(168,71,42,.12),transparent 55%),
             var(--hero-veil);
}
.kropp-hero .heroin{
  position:relative;z-index:2;max-width:1140px;margin:0 auto;
  padding:84px 24px 96px;min-height:560px;display:flex;align-items:center;
}
.kropp-hero .herotext{max-width:470px;position:relative;}
.herophoto{position:absolute;left:48%;top:50%;transform:translateY(-50%);width:320px;aspect-ratio:1;z-index:2;}
.herophoto .disc{
  position:absolute;inset:0;border-radius:50%;background:var(--disc);
  box-shadow:0 30px 70px rgba(40,25,10,.4),inset 0 0 0 6px var(--disc-ring);
}
.herophoto .prod{
  position:absolute;inset:7%;width:86%;height:86%;object-fit:contain;z-index:2;
  filter:drop-shadow(0 22px 28px rgba(0,0,0,.42));animation:floaty 6s ease-in-out infinite;
}
.herobadge{
  position:absolute;right:-4px;bottom:6%;z-index:3;background:var(--accent);color:#fff;
  width:92px;height:92px;border-radius:50%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;font-family:'Fraunces',serif;line-height:1;
  box-shadow:0 12px 26px rgba(0,0,0,.32);transform:rotate(-8deg);
}
.herobadge b{font-size:25px;}
.herobadge span{font-size:10.5px;letter-spacing:1.5px;margin-top:3px;font-family:'Libre Franklin';font-weight:600;}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ---------- Footer ---------- */
.kropp-footer{
  background:#141312;color:#cabfae;border-top:5px solid var(--accent);
  padding:40px 0 26px;font-size:14.5px;margin-top:30px;
}
.kropp-footer h4{font-family:'Fraunces',serif;color:#fff;font-size:18px;margin-bottom:10px;font-weight:600;}
.kropp-footer a{color:#cabfae;text-decoration:none;}
.kropp-footer a:hover{color:var(--accent);}

/* ---------- Responsive Nav (drei Stufen, wie in den Mockups) ---------- */
@media(max-width:860px){
  .kropp-menu{order:3;flex-basis:100%;justify-content:center;flex-wrap:wrap;margin-left:0;}
  .kropp-toggle{order:2;}
}
@media(max-width:560px){
  .kropp-menu{flex-direction:column;align-items:center;gap:10px;}
  .submenu{
    position:static;transform:none;visibility:visible;box-shadow:none;border:none;
    background:transparent;padding:0 0 0 14px;min-width:0;max-height:0;opacity:0;
    overflow:hidden;transition:max-height .28s ease,opacity .2s ease;
  }
  .navitem.open .submenu{max-height:340px;opacity:1;}
  .navitem>a.drop{display:flex;justify-content:space-between;align-items:center;}
  .submenu a{padding:6px 0;font-size:13.5px;color:var(--head-text)!important;}
  .navitem::after{display:none;}
  .herophoto{position:relative;left:auto;top:auto;transform:none;width:min(240px,62%);margin:10px auto 0;}
}
