/* =========================================================
   ELIF MOSCHEEDESIGN — styles.css (v7, curtain + synced heights)
========================================================= */

/* 0) Variablen */
:root{
  --topbar-h: 80px;
  --logo-h:   65px;
  --onyx-1:#111214; --onyx-2:#1a1c20;
  --gold:#d4af37;  --gold-2:#f0d16a;
  --text:#e9e9ea;  --muted:#b6b8bd;
  --card:#16181c;  --rail:#ffffff44; --glass:#ffffff22;
}

/* 1) Reset & Basics */
*{box-sizing:border-box}
html,body{
  margin:0;
  padding:0;
  -webkit-text-size-adjust: 100%; /* Safari Zoom verhindern */

}
body{
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial;
  background:var(--onyx-1);color:var(--text);
  padding-top: var(--topbar-h); /* Platz für fixe Topbar */
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 18px}
.grid{display:grid;gap:16px}
.cols-3{grid-template-columns:repeat(3,1fr)}

/* 2) Buttons / Badges */
.icon-btn{
  appearance:none;border:0;cursor:pointer;
  background:#ffffff10;color:#fff;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  transition:background .2s ease, transform .2s ease;
}
.icon-btn:hover{background:#ffffff1f}
.icon-btn:active{transform:scale(.98)}
.badge{position:relative;display:inline-flex;align-items:center}
.badge .count{position:absolute;right:-8px;top:-8px;background:var(--gold);color:#000;border:1px solid #000;border-radius:999px;padding:1px 6px;font-size:12px;font-weight:800}
.icon-svg img{width:18px;height:18px;display:block}
.topbar .label, .topbar a{color:#fff}

/* 3) Topbar (fixiert, immer sichtbar) */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:linear-gradient(135deg,var(--onyx-2),#0f0f11);
  border-bottom:1px solid #23262b;
  transition: box-shadow .25s ease;
}
body.menu-open .topbar{ box-shadow:0 10px 30px #0006; }

.topbar__row{
  height:var(--topbar-h);
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:10px;
}
.top-left,.top-center,.top-right{display:flex;align-items:center}
.top-left{gap:8px;color:#fff;opacity:.9}
.top-center{justify-content:center}
.top-right{justify-content:flex-end;gap:18px}
.brand-img{height:var(--logo-h); width:auto; filter:drop-shadow(0 2px 4px #0008)}

/* Sichtbarkeit rechts */
.top-right .hide-when-menu{ display:flex; }                /* Standard sichtbar */
.menu-open .top-right .hide-when-menu{ display:none; }     /* bei offenem Menü aus */
.top-right .lang-only{ display:none; }                     /* Standard aus */
.menu-open .top-right .lang-only{ display:flex; }          /* bei offenem Menü an */

/* Hamburger → X */
.icon-btn .hamburger{display:inline-block;width:24px;height:18px;position:relative}
.icon-btn .hamburger span{
  position:absolute;left:0;right:0;height:2px;background:currentColor;border-radius:2px;transform-origin:center;
  transition:transform .28s ease, opacity .2s ease, top .28s ease;
}
.icon-btn .hamburger span:nth-child(1){top:0}
.icon-btn .hamburger span:nth-child(2){top:8px}
.icon-btn .hamburger span:nth-child(3){top:16px}
#openMenu .label{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0;border:0;height:1px;width:1px;overflow:hidden}
body.menu-open .icon-btn#openMenu .hamburger span:nth-child(1){top:8px;transform:rotate(45deg)}
body.menu-open .icon-btn#openMenu .hamburger span:nth-child(2){opacity:0}
body.menu-open .icon-btn#openMenu .hamburger span:nth-child(3){top:8px;transform:rotate(-45deg)}

/* 4) Suchleiste */
.searchbar{
  position:fixed; left:0; right:0; top:var(--topbar-h);
  display:none; z-index:950;
  background:linear-gradient(135deg,var(--onyx-2),#0f0f11);
  border-bottom:1px solid #23262b;
}
.searchbar .inner{max-width:980px;margin:0 auto;padding:14px 18px; display:grid; gap:12px}
.searchbar input[type="search"]{width:100%; padding:14px 18px; border-radius:999px; background:#111316; border:1px solid #2a2d33; color:var(--text);}
body.search-open .searchbar{display:block}

/* Zuletzt gesucht / Löschen */
.recent-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.recent-row .pill,
.recent-row .clear{
  padding:8px 12px;border:1px solid #2a2d33;border-radius:999px;background:#111316;color:#e9e9ea;cursor:pointer;
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}
.recent-row .pill:hover,
.recent-row .clear:hover{background:#16181c;border-color:#3a3e45}
.recent-row .clear{margin-left:auto;opacity:.9}
.recent-row .muted{opacity:.8}

/* 5) Panel (Leinwand) */
#panel{
  position:fixed; left:0; right:0; top:var(--topbar-h);
  height:calc(100dvh - var(--topbar-h));
  z-index:900; color:#fff;
  background:linear-gradient(135deg,#121416,#1a1c20);
  backdrop-filter:blur(6px);
  transform:translateY(-100%); pointer-events:none;
  transition: transform .36s cubic-bezier(.22,.61,.36,1);
}
#panel::before{content:""; position:absolute; left:0; right:0; top:0; height:14px; background:linear-gradient(to bottom,#00000066,transparent); pointer-events:none;}
body.menu-open #panel{ transform:translateY(0); pointer-events:auto; }
#panel .panel-row{display:grid; grid-template-columns:320px 1fr; gap:28px; max-width:1200px; margin:0 auto; padding:28px 18px;}
#panel .panel-row > *{ transform:translateY(-8px); opacity:0; transition:transform .36s ease .05s, opacity .36s ease .05s;}
body.menu-open #panel .panel-row > *{ transform:none; opacity:1; }
#panel .left a{display:block;font-size:22px;padding:10px 0;color:#fff;opacity:.95}
#panel .left a:hover{opacity:1}
#panel .right .grid{grid-template-columns:repeat(3,1fr)}
#panel .panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
#panel .icon-btn img{display:block}

/* 6) Sprache-Modal */
#lang{position:fixed;inset:0;z-index:1100;color:#fff;background:#0f0f12e6;backdrop-filter:blur(6px);display:none}
#lang.open{display:block}
#lang .wrap{max-width:1100px;margin:0 auto;padding:28px 18px}
#lang .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
#lang .grid a{padding:10px 14px;border:1px solid #23262b;border-radius:10px;background:#16181c;color:#fff}

/* 7) Hero */
.hero{position:relative;min-height:56svh;display:grid;place-items:center;overflow:hidden;
  background:radial-gradient(1000px 500px at 70% 20%, #ffffff10 0, #0000 60%),linear-gradient(135deg,#0e0e10,#1a1c20)}
.hero__content{position:relative;z-index:1;text-align:center;width:min(92%,840px);padding:20px 8px}
.eyebrow{letter-spacing:.22em;text-transform:uppercase;font-size:12px;color:var(--gold-2);margin:0 0 8px}
h1{font-size:46px;line-height:1.06;margin:.2rem 0 1rem;color:#fff}
.cta{display:inline-block;padding:12px 18px;border-radius:999px;background:var(--glass);color:#fff;border:1px solid #ffffff22}
.cta:hover{border-color:#ffffff55}
.hero-video{position:relative;isolation:isolate}
.hero-video__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-video__bg video{position:absolute;inset:0;width:100%;height:100%;min-width:100%;min-height:100%;object-fit:cover;filter:contrast(1.05) saturate(1.05)}
.hero-video__overlay{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,.35), rgba(0,0,0,.35))}
.hero-video__content{position:relative;z-index:1;color:#fff;padding:72px 0 84px;text-align:center}
.hero-video .eyebrow{color:var(--gold-2)}

/* 8) Sections & Cards + Herz */
.section{padding:30px 0}
.card{background:var(--card);border:1px solid #23262b;border-radius:16px;overflow:hidden;box-shadow:0 10px 30px #0008}
.card .img{height:200px;background:#222;background-size:cover;background-position:center}
.card .body{padding:14px}
.prod{position:relative}
.heart{
  position:absolute; right:10px; top:10px;
  display:grid; place-items:center; width:40px; height:40px; border-radius:999px;
  background:#0f0f12b3; border:1px solid #2a2d33; color:var(--gold); font-size:20px; cursor:pointer;
  transition: background .2s ease, transform .15s ease, color .2s ease, border-color .2s ease;
}
.heart:hover{ background:#16181c; border-color:#3a3e45; transform:scale(1.06); }
.heart.active{ background:var(--gold); color:#000; border-color:#000; }
.price{color:var(--gold);font-weight:700}

/* 9) Rep badge */
.rep-badge{position:fixed;left:12px;bottom:18px;z-index:850;display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:#0f0f12cc;color:#fff;border:1px solid #23262b;backdrop-filter:blur(6px)}
.rep-badge img{height:22px}

/* Basis – Desktop (Icon + Text) */
.whatsapp-btn{
  position: fixed;
  right: 12px;
  bottom: 18px;
  z-index: 850;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(15,15,18,0.85);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.15);
  backdrop-filter: blur(6px);
  text-decoration: none;
  font-weight: 500;
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
  transition: all .25s ease;
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Harte Begrenzung fürs Icon (verhindert iOS/Global-Resets) */
.whatsapp-btn > img{
  width: 22px !important;
  height: 22px !important;
  max-width: none !important;   /* überschreibt img{max-width:100%} */
  flex: 0 0 22px;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 0 6px rgba(37,211,102,.5));
  animation: pulseGlow 2.8s infinite ease-in-out;
}

@media (hover:hover){
  .whatsapp-btn:hover{
    background: rgba(20,20,24,.92);
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(37,211,102,.4);
  }
}

/* 🔁 Mobile: nur Icon, runde Pille, Text ausblenden */
@media (max-width: 767px){
  .whatsapp-btn{
    padding: 0;                /* fixe Größe steuert die Pille */
    width: 48px;
    height: 48px;
    justify-content: center;   /* Icon zentrieren */
    gap: 0;
  }
  .whatsapp-btn > span{ display: none; }
}

/* ♿ Bewegungs-Reduzierung respektieren */
@media (prefers-reduced-motion: reduce){
  .whatsapp-btn{ transition: none; }
  .whatsapp-btn > img{ animation: none; }
}

/* Pulsierender Premium-Glow (Icon) */
@keyframes pulseGlow{
  0%,100%{ filter: drop-shadow(0 0 6px rgba(37,211,102,.5)); }
  50%{    filter: drop-shadow(0 0 12px rgba(37,211,102,.85)); }
}



/* 10) Footer */
.footer{background:#0f0f12;border-top:1px solid #23262b;margin-top:28px}
.footer .cols{display:grid;gap:18px;grid-template-columns:repeat(4,1fr);padding:18px 0}
.footer small{display:block;padding:12px 0;color:#a1a4aa;border-top:1px solid #23262b}

/* 11) Formulare */
input,textarea{background:#0f0f12;border:1px solid #2a2d33;color:#e9e9ea;border-radius:10px;padding:12px 12px;font:inherit}
input::placeholder,textarea::placeholder{color:#8b8f96}

/* 12) Animations */
[data-animate]{opacity:0;transform:translateY(12px);transition:opacity .5s ease, transform .5s ease}
[data-animate].in{opacity:1;transform:none}

/* 13) Responsive */
@media(max-width:980px){
  .cols-3{grid-template-columns:1fr 1fr}
  .footer .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  #panel .panel-row{grid-template-columns:1fr}
  #panel .right .grid{grid-template-columns:1fr 1fr}
  #lang .grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  /* Nur die rechte Seite: Textlabels ausblenden */
  .top-right .label,
  .top-right #langLabel {
    position: absolute !important;
    clip: rect(1px,1px,1px,1px);
    padding: 0; border: 0; height: 1px; width: 1px;
    overflow: hidden;
  }

  /* Buttons etwas kompakter, damit Icon-Only gut wirkt */
  .top-right .icon-btn{
    padding: 8px;            /* rundere, kompakte Buttons */
    gap: 0;                   /* kein Abstand zwischen Icon & (verstecktem) Label */
  }

  /* Icongröße konsistent */
  .top-right .icon-svg img{
    width: 20px;
    height: 20px;
    display: block;
  }

  /* Badge-Zähler weiter sichtbar/positioniert */
  .top-right .badge .count{
    right: -6px;
    top: -6px;
  }
}
/* 14) Reduced motion */
@media (prefers-reduced-motion: reduce){
  .icon-btn .hamburger span{transition:none}
  #panel{transition:none}
  [data-animate]{transition:none}
}
