/* ==========================================================================
   ESS QR MENÜ — assets/css/style.css  v3.0
   Tasarım: Lüks Karanlık/Açık çift mod | Cormorant Garamond + DM Sans
   BUG FIX: Dark modda footer ikonları görünürlük sorunu çözüldü
   ========================================================================== */

/* ── 1. TOKENS ───────────────────────────────────────────────────────────── */
:root {
  /* Renkler (dinamik — theme-options.php tarafından override edilir) */
  --clr-bg:            #0a0a0a;
  --clr-bg-card:       #131313;
  --clr-bg-elevated:   #1a1a1a;
  --clr-bg-glass:      rgba(10,10,10,.88);
  --clr-surface:       #1f1f1f;
  --clr-border:        rgba(255,255,255,.07);
  --clr-border-light:  rgba(255,255,255,.12);
  --clr-text-primary:  #f0ece4;
  --clr-text-secondary:#9e9890;
  --clr-text-muted:    #5e5a55;
  --clr-text-inverse:  #0a0a0a;
  --clr-gold:          #c9a84c;
  --clr-gold-light:    #e2c47a;
  --clr-gold-dim:      rgba(201,168,76,.15);
  --clr-gold-glow:     rgba(201,168,76,.35);
  --clr-danger:        #e05252;
  --clr-warn:          #e8a020;
  --clr-success:       #4caf75;

  /* Tipografi (dinamik) */
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
  --text-xs:   .6875rem; /* 11px @ 16 base */
  --text-sm:   .8125rem;
  --text-base: .9375rem;
  --text-md:  1.0625rem;
  --text-lg:  1.25rem;
  --text-xl:  1.5rem;
  --text-2xl: 1.875rem;
  --text-3xl: 2.5rem;
  --lead-tight:  1.2;
  --lead-snug:   1.4;
  --lead-normal: 1.6;
  --lead-relax:  1.8;

  /* Boşluk */
  --sp-1:.25rem; --sp-2:.5rem;  --sp-3:.75rem; --sp-4:1rem;
  --sp-5:1.25rem;--sp-6:1.5rem; --sp-8:2rem;   --sp-10:2.5rem;
  --sp-12:3rem;  --sp-16:4rem;

  /* Köşe */
  --r-sm:6px; --r-md:12px; --r-lg:18px; --r-xl:24px; --r-full:9999px;

  /* Gölge */
  --sh-sm:0 1px 3px rgba(0,0,0,.4),0 1px 2px rgba(0,0,0,.3);
  --sh-md:0 4px 16px rgba(0,0,0,.5),0 2px 6px rgba(0,0,0,.3);
  --sh-lg:0 10px 40px rgba(0,0,0,.6),0 4px 12px rgba(0,0,0,.4);
  --sh-gold:0 4px 24px var(--clr-gold-glow);

  /* Geçiş */
  --tr-fast:  150ms cubic-bezier(.4,0,.2,1);
  --tr-base:  250ms cubic-bezier(.4,0,.2,1);
  --tr-slow:  400ms cubic-bezier(.4,0,.2,1);
  --tr-spring:350ms cubic-bezier(.34,1.56,.64,1);

  /* Layout */
  --header-h:   56px;
  --footer-h:   60px;
  --max-w:      600px;
  --pad:        var(--sp-4);
  --z-header:   100;
  --z-footer:   100;
  --z-modal:    200;
  --z-overlay:  190;
}

/* ── 2. RESET ────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;height:100%;overflow:hidden}
body{
  font-family:var(--font-body);
  font-size:var(--text-base);
  line-height:var(--lead-normal);
  color:var(--clr-text-primary);
  background:var(--clr-bg);
  min-height:100%;
  overflow-x:hidden;
  overflow-y:auto;
  height:100%;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  transition:background var(--tr-base),color var(--tr-base);
}
body.ess-rtl{direction:rtl;text-align:right}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
:focus-visible{outline:2px solid var(--clr-gold);outline-offset:2px;border-radius:3px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── 3. RENK MODLARI ─────────────────────────────────────────────────────── */
/* Koyu mod (varsayılan — :root ile aynı, body class ile override edilir) */
body.ess-mode-dark{
  --clr-bg:#0a0a0a;--clr-bg-card:#131313;--clr-bg-elevated:#1a1a1a;
  --clr-bg-glass:rgba(10,10,10,.88);--clr-surface:#1f1f1f;
  --clr-border:rgba(255,255,255,.07);--clr-border-light:rgba(255,255,255,.12);
  --clr-text-primary:#f0ece4;--clr-text-secondary:#9e9890;
  --clr-text-muted:#5e5a55;--clr-text-inverse:#0a0a0a;
}
/* Açık mod */
body.ess-mode-light{
  --clr-bg:#faf9f7;--clr-bg-card:#fff;--clr-bg-elevated:#f3f1ee;
  --clr-bg-glass:rgba(250,249,247,.92);--clr-surface:#eeece8;
  --clr-border:rgba(0,0,0,.08);--clr-border-light:rgba(0,0,0,.13);
  --clr-text-primary:#1a1714;--clr-text-secondary:#4a4540;
  --clr-text-muted:#8a8480;--clr-text-inverse:#faf9f7;
}

/* ── 4. APP SARICI ───────────────────────────────────────────────────────── */
.ess-app{min-height:100dvh;display:flex;flex-direction:column;position:relative}
.ess-page{
  display:flex;flex-direction:column;min-height:100dvh;
  padding-top:var(--header-h);padding-bottom:var(--footer-h);
  animation:fadeIn .3s ease both;
}
.ess-main{
  flex:1;width:100%;max-width:var(--max-w);
  margin-inline:auto;padding:var(--sp-4) var(--pad);
}
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .ess-footer-bar{height:calc(var(--footer-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom)}
  .ess-page{padding-bottom:calc(var(--footer-h) + env(safe-area-inset-bottom))}
}
@supports(height:100svh){
  .ess-app{min-height:100svh}
  .ess-page{min-height:100svh}
}

/* ── 5. HEADER ───────────────────────────────────────────────────────────── */
.ess-header{
  position:fixed;top:0;inset-inline:0;height:var(--header-h);z-index:var(--z-header);
  background:var(--clr-bg-glass);
  backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid var(--clr-border);
}
.ess-header::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--clr-gold-dim),transparent);
}
.ess-header__inner{
  height:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--pad);
  display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:var(--sp-2);
}
.ess-header__spacer{width:44px}
.ess-header__back,
.ess-search-btn{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:var(--r-full);
  background:var(--clr-surface);border:1px solid var(--clr-border);
  color:var(--clr-text-secondary);transition:all var(--tr-fast);
}
.ess-header__back:hover,
.ess-search-btn:hover{background:var(--clr-gold-dim);border-color:var(--clr-gold);color:var(--clr-gold)}
.ess-header__brand{text-align:center;overflow:hidden}
.ess-header__logo-link{display:inline-flex;align-items:center;justify-content:center}
.ess-logo-img,.ess-header__logo-link img{max-height:38px;width:auto;object-fit:contain}
.ess-header__site-name{
  font-family:var(--font-display);font-size:var(--text-xl);font-weight:500;
  letter-spacing:.04em;color:var(--clr-gold-light);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ess-header__actions{display:flex;justify-content:flex-end}
.ess-header.is-scrolled{box-shadow:var(--sh-sm)}

/* ── 6. ARAMA OVERLAY ───────────────────────────────────────────────────── */
.ess-search-overlay{
  position:fixed;inset:0;z-index:var(--z-modal);
  background:rgba(0,0,0,.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:none;align-items:flex-start;justify-content:center;
  padding-top:calc(var(--header-h) + 8px);
  opacity:0;transition:opacity var(--tr-base);
}
.ess-search-overlay.is-open{opacity:1}
.ess-search-overlay__inner{
  width:100%;max-width:var(--max-w);margin-inline:auto;
  padding-inline:var(--pad);display:flex;flex-direction:column;gap:var(--sp-2);
  max-height:calc(100dvh - var(--header-h) - var(--footer-h) - 24px);
}
.ess-search-bar{
  display:flex;align-items:center;gap:var(--sp-3);
  background:var(--clr-bg-elevated);border:1px solid var(--clr-border-light);
  border-radius:var(--r-xl);padding:var(--sp-3) var(--sp-4);
  box-shadow:var(--sh-lg);
  transform:translateY(-8px);transition:transform var(--tr-base);
}
.ess-search-overlay.is-open .ess-search-bar{transform:translateY(0)}
.ess-search-input{
  flex:1;background:none;border:none;outline:none;
  font-family:var(--font-body);font-size:var(--text-md);
  color:var(--clr-text-primary);caret-color:var(--clr-gold);
}
.ess-search-input::placeholder{color:var(--clr-text-muted)}
.ess-search-close{
  display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:var(--r-full);
  color:var(--clr-text-muted);transition:all var(--tr-fast);
}
.ess-search-close:hover{background:var(--clr-surface);color:var(--clr-text-primary)}
.ess-search-results{
  background:var(--clr-bg-elevated);border:1px solid var(--clr-border);
  border-radius:var(--r-xl);overflow-y:auto;
  max-height:calc(100dvh - var(--header-h) - 90px - var(--footer-h));
  box-shadow:var(--sh-lg);
}
.ess-search-hint{
  padding:var(--sp-8) var(--sp-6);text-align:center;
  color:var(--clr-text-muted);font-size:var(--text-sm);
}
.ess-search-result{
  display:grid;grid-template-columns:56px 1fr;gap:var(--sp-3);
  align-items:center;padding:var(--sp-3) var(--sp-4);
  border-bottom:1px solid var(--clr-border);transition:background var(--tr-fast);
  text-decoration:none;
}
.ess-search-result:last-child{border-bottom:none}
.ess-search-result:hover{background:var(--clr-gold-dim)}
.ess-search-result__img{width:56px;height:44px;object-fit:cover;border-radius:var(--r-md)}
.ess-search-result__img-empty{
  width:56px;height:44px;background:var(--clr-surface);
  border-radius:var(--r-md);display:flex;align-items:center;
  justify-content:center;font-size:1.2rem;opacity:.5;
}
.ess-search-result__info{display:flex;flex-direction:column;gap:2px;min-width:0}
.ess-search-result__title{
  font-family:var(--font-display);font-size:var(--text-md);
  color:var(--clr-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ess-search-result__price{font-size:var(--text-sm);color:var(--clr-gold);font-weight:600}
.ess-search-result__cat{font-size:var(--text-xs);color:var(--clr-text-muted)}
.ess-search-highlight{background:var(--clr-gold-dim);color:var(--clr-gold-light);border-radius:2px;padding:0 2px}

/* ── 7. BREADCRUMB ───────────────────────────────────────────────────────── */
.ess-breadcrumb{margin-bottom:var(--sp-4)}
.ess-breadcrumb__list{
  display:flex;flex-wrap:wrap;gap:var(--sp-1);align-items:center;
  font-size:var(--text-xs);color:var(--clr-text-muted);
}
.ess-bc-item a{color:var(--clr-text-muted);transition:color var(--tr-fast)}
.ess-bc-item a:hover{color:var(--clr-gold)}
.ess-bc-item.is-cur span{color:var(--clr-text-secondary)}
.ess-bc-sep{opacity:.4}
.ess-rtl .ess-bc-sep{transform:scaleX(-1);display:inline-block}

/* ── 8. BÖLÜM BAŞLIĞI ────────────────────────────────────────────────────── */
.ess-section-header{margin-bottom:var(--sp-5)}
.ess-section-title{
  font-family:var(--font-display);font-size:var(--text-2xl);
  font-weight:400;font-style:normal;color:var(--clr-text-primary);
  line-height:var(--lead-tight);position:relative;padding-bottom:var(--sp-3);
}
.ess-section-title::after{
  content:'';position:absolute;bottom:0;left:0;width:40px;height:1px;background:var(--clr-gold);
}
.ess-rtl .ess-section-title::after{left:auto;right:0}

/* ── 9. BANNER SLIDER ────────────────────────────────────────────────────── */
.ess-slider{
  position:relative;overflow:hidden;border-radius:var(--r-xl);
  margin-bottom:var(--sp-6);aspect-ratio:16/7;background:var(--clr-surface);
}
.ess-slider__track{
  display:flex;height:100%;
  transition:transform .5s cubic-bezier(.4,0,.2,1);will-change:transform;
}
.ess-slider__slide{flex:0 0 100%;position:relative;overflow:hidden}
.ess-slider__img{width:100%;height:100%;object-fit:cover}
.ess-slider__overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.75));
}
.ess-slider__text{position:absolute;bottom:0;left:0;right:0;padding:var(--sp-5)}
.ess-slider__title{
  font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;font-style:normal;
  color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.5);margin-bottom:4px;
}
.ess-slider__sub{font-size:var(--text-sm);color:rgba(255,255,255,.8)}
.ess-slider__dots{
  position:absolute;bottom:var(--sp-3);left:0;right:0;
  display:flex;justify-content:center;gap:6px;
}
.ess-slider__dot{
  width:8px;height:8px;border-radius:var(--r-full);
  background:rgba(255,255,255,.4);transition:all var(--tr-fast);
  cursor:pointer;border:none;
}
.ess-slider__dot.is-active{background:#fff;width:20px}

/* ── 10. KATEGORİ KARTLARI ───────────────────────────────────────────────── */
.ess-cats-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:var(--sp-3);margin-bottom:var(--sp-8);
}
.ess-cat-card{
  border-radius:var(--r-lg);overflow:hidden;background:var(--clr-bg-card);
  border:1px solid var(--clr-border);box-shadow:var(--sh-sm);
  transition:transform var(--tr-base),box-shadow var(--tr-base),border-color var(--tr-base);
  animation:fadeInUp .4s ease both;
}
.ess-cat-card:nth-child(1){animation-delay:.05s}
.ess-cat-card:nth-child(2){animation-delay:.10s}
.ess-cat-card:nth-child(3){animation-delay:.15s}
.ess-cat-card:nth-child(4){animation-delay:.20s}
.ess-cat-card:nth-child(n+5){animation-delay:.25s}
.ess-cat-card:hover,.ess-cat-card:focus-within{
  transform:translateY(-3px);
  box-shadow:var(--sh-md),var(--sh-gold);
  border-color:var(--clr-gold);
}
.ess-cat-card__link{display:flex;flex-direction:column;height:100%}
.ess-cat-card__media{position:relative;aspect-ratio:3/2;overflow:hidden}
.ess-cat-card__img{width:100%;height:100%;object-fit:cover;transition:transform var(--tr-slow)}
.ess-cat-card:hover .ess-cat-card__img{transform:scale(1.06)}
.ess-cat-card__overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.7));
  pointer-events:none;
}
.ess-cat-card__body{padding:var(--sp-3);flex:1;display:flex;flex-direction:column;gap:var(--sp-1)}
.ess-cat-card__title{
  font-family:var(--font-display);font-size:var(--text-md);font-weight:500;
  line-height:var(--lead-snug);color:var(--clr-text-primary);
}
.ess-cat-card__desc{
  font-size:var(--text-xs);color:var(--clr-text-muted);line-height:var(--lead-snug);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.ess-cat-card__count{
  margin-top:auto;font-size:var(--text-xs);color:var(--clr-gold);
  font-weight:500;letter-spacing:.04em;
}

/* Premium ana grid — görsel üzerinde başlık (layout-themes markup) */
.ess-cat-card--premium .ess-cat-card__link{
  position:relative;display:block;
  aspect-ratio:4/5;
  min-height:140px;
  overflow:hidden;
  border-radius:inherit;
}
.ess-cat-card--premium .ess-cat-card__img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:transform var(--tr-slow);
}
.ess-cat-card--premium:hover .ess-cat-card__img,
.ess-cat-card--premium:focus-within .ess-cat-card__img{
  transform:scale(1.06);
}
.ess-cat-card--premium .ess-placeholder{
  position:absolute;inset:0;
  width:100%;height:100%;
}
.ess-cat-card--premium .ess-cat-card__gradient{
  position:absolute;inset:0;pointer-events:none;z-index:1;
  background:linear-gradient(180deg,
    transparent 18%,
    rgba(0,0,0,.45) 55%,
    rgba(0,0,0,.78) 100%);
}
.ess-cat-card--premium .ess-cat-card__label{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:var(--sp-3) var(--sp-3) var(--sp-4);
  text-align:start;
}
.ess-cat-card--premium .ess-cat-card__title{
  margin:0;
  color:rgba(252,250,246,.98);
  text-shadow:0 2px 14px rgba(0,0,0,.55);
  font-size:var(--text-md);
}
@media(min-width:480px){
  .ess-cat-card--premium .ess-cat-card__title{font-size:var(--text-lg)}
}

.ess-placeholder{
  background:var(--clr-surface);display:flex;align-items:center;
  justify-content:center;font-size:1.5rem;opacity:.4;
  width:100%;height:100%;
}

/* ── 11. ÜRÜN KARTLARI (Liste) ───────────────────────────────────────────── */
.ess-items-list{display:flex;flex-direction:column;gap:var(--sp-3);margin-bottom:var(--sp-8)}
.ess-item-card{
  border-radius:var(--r-lg);overflow:hidden;background:var(--clr-bg-card);
  border:1px solid var(--clr-border);
  transition:transform var(--tr-base),box-shadow var(--tr-base),border-color var(--tr-base);
  animation:fadeInUp .35s ease both;position:relative;
}
.ess-item-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:var(--clr-border-light)}
.ess-item-card.is-sold-out{opacity:.62}
.ess-item-card.is-sold-out .ess-item-card__link{pointer-events:none;cursor:default}
.ess-item-card.is-chefs{border-color:rgba(201,168,76,.4)}
.ess-item-card.is-hidden{display:none!important}
.ess-item-card__link{
  display:grid;grid-template-columns:100px 1fr;min-height:90px;
}
.ess-item-card__media{position:relative;overflow:hidden;flex-shrink:0}
.ess-item-card__img{width:100%;height:100%;object-fit:cover;transition:transform var(--tr-slow);display:block}
.ess-item-card:hover .ess-item-card__img{transform:scale(1.08)}
.ess-sold-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;
}
.ess-sold-overlay span{
  background:var(--clr-danger);color:#fff;font-size:var(--text-xs);
  font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 10px;border-radius:var(--r-full);
}
.ess-chefs-pin{
  position:absolute;top:6px;right:6px;font-size:1.1rem;
  background:rgba(0,0,0,.6);border-radius:var(--r-full);
  padding:4px 6px;line-height:1;
}
.ess-rtl .ess-chefs-pin{right:auto;left:6px}
.ess-item-card__content{
  padding:var(--sp-3) var(--sp-3) var(--sp-3) var(--sp-4);
  display:flex;flex-direction:column;justify-content:space-between;gap:var(--sp-1);
}
.ess-rtl .ess-item-card__content{padding:var(--sp-3) var(--sp-4) var(--sp-3) var(--sp-3)}
.ess-item-card__title{
  font-family:var(--font-display);font-size:var(--text-md);font-weight:500;
  line-height:var(--lead-snug);color:var(--clr-text-primary);
}
.ess-item-card__desc{
  font-size:var(--text-xs);color:var(--clr-text-muted);line-height:var(--lead-snug);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.ess-item-card__footer{
  display:flex;align-items:center;gap:var(--sp-2);
  margin-top:var(--sp-2);flex-wrap:wrap;
}
/* Rozet+Kalori: kalori yanında, fotoğraf üstünde DEĞİL */
.ess-item-card__meta{
  display:flex;align-items:center;gap:var(--sp-2);
  flex-wrap:wrap;flex:1;min-width:0;
}
.ess-kcal,.ess-spicy{font-size:var(--text-xs);color:var(--clr-text-muted);white-space:nowrap}
.ess-item-card__price{
  font-family:var(--font-display);font-size:var(--text-md);font-weight:600;
  color:var(--clr-gold);white-space:nowrap;margin-inline-start:auto;
}
.ess-item-card__arrow{color:var(--clr-text-muted);display:flex;align-items:center;flex-shrink:0}
.ess-rtl .ess-item-card__arrow svg{transform:scaleX(-1)}
.ess-item-count{
  font-size:var(--text-xs);color:var(--clr-text-muted);
  margin-bottom:var(--sp-4);letter-spacing:.06em;text-transform:uppercase;
}
.ess-no-filter-msg{display:none;text-align:center;color:var(--clr-text-muted);padding:2rem 0}

/* ── 12. FİLTRE BARI ─────────────────────────────────────────────────────── */
.ess-filter-bar{
  display:flex;gap:var(--sp-2);flex-wrap:nowrap;overflow-x:auto;
  padding-bottom:var(--sp-2);margin-bottom:var(--sp-4);
  scrollbar-width:none;-ms-overflow-style:none;
}
.ess-filter-bar::-webkit-scrollbar{display:none}
.ess-filter-btn{
  padding:6px 14px;border-radius:var(--r-full);
  border:1px solid var(--clr-border);background:transparent;
  color:var(--clr-text-secondary);font-size:var(--text-xs);
  font-weight:500;white-space:nowrap;transition:all var(--tr-fast);cursor:pointer;
}
.ess-filter-btn:hover{border-color:var(--clr-gold);color:var(--clr-gold-light);background:var(--clr-gold-dim)}
.ess-filter-btn.is-active{
  background:var(--clr-gold);border-color:var(--clr-gold);
  color:var(--clr-text-inverse);font-weight:700;
}
.ess-filter-toggle.is-active{background:var(--clr-danger);border-color:var(--clr-danger);color:#fff}

/* ── 13. DİYET ROZETLERİ ─────────────────────────────────────────────────── */
.ess-badges{display:flex;flex-wrap:wrap;gap:var(--sp-1)}
.ess-badge{
  display:inline-flex;align-items:center;gap:4px;padding:3px 7px;
  border-radius:var(--r-full);font-size:10px;font-weight:600;white-space:nowrap;
}
.badge-lbl{font-size:10px;letter-spacing:.03em}
.ess-badges--inline .badge-lbl{display:none} /* Liste'de küçük: sadece ikon */
.ess-badges--large  .badge-lbl{display:inline} /* Detail'de tam etiket */
.badge--vegan     {background:rgba(76,175,117,.18);border:1px solid rgba(76,175,117,.35);color:#4caf75}
.badge--veg       {background:rgba(139,195,74,.18);border:1px solid rgba(139,195,74,.35);color:#8bc34a}
.badge--gf        {background:rgba(255,193,7,.15); border:1px solid rgba(255,193,7,.3);  color:#ffc107}
.badge--halal     {background:rgba(33,150,243,.15);border:1px solid rgba(33,150,243,.3); color:#2196f3}
.badge--new       {background:rgba(201,168,76,.18);border:1px solid rgba(201,168,76,.35);color:var(--clr-gold)}
.badge--popular   {background:rgba(156,39,176,.15);border:1px solid rgba(156,39,176,.3); color:#ce93d8}

/* ── 14. KATEGORİ HERO ───────────────────────────────────────────────────── */
.ess-cat-hero{margin-bottom:var(--sp-6);border-radius:var(--r-xl);overflow:hidden}
.ess-cat-hero__media{position:relative;aspect-ratio:16/7;overflow:hidden}
.ess-cat-hero__img{width:100%;height:100%;object-fit:cover}
.ess-cat-hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.75));
}
.ess-cat-hero__text{position:absolute;bottom:0;left:0;right:0;padding:var(--sp-5)}
.ess-cat-hero__bare{padding:var(--sp-5);background:var(--clr-bg-card)}
.ess-cat-hero__title{
  font-family:var(--font-display);font-size:var(--text-2xl);font-weight:400;
  font-style:normal;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.5);
  line-height:var(--lead-tight);margin-bottom:4px;
}
.ess-cat-hero__bare .ess-cat-hero__title{color:var(--clr-text-primary);text-shadow:none}
.ess-cat-hero__desc{font-size:var(--text-sm);color:rgba(255,255,255,.8);line-height:var(--lead-snug)}
.ess-cat-hero__bare .ess-cat-hero__desc{color:var(--clr-text-secondary)}

/* ── 15. ÜRÜN DETAY (Single Sayfa) ──────────────────────────────────────── */
.ess-item-detail{animation:fadeInUp .4s ease both}
.ess-item-detail__hero{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  border-radius:var(--r-xl);margin-bottom:var(--sp-5);background:var(--clr-surface);
}
.ess-item-detail__hero-img,
.ess-item-detail__video{width:100%;height:100%;object-fit:cover;display:block}
.ess-sold-out-banner{
  position:absolute;top:var(--sp-4);left:var(--sp-4);
  background:var(--clr-danger);color:#fff;font-size:var(--text-xs);
  font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 14px;border-radius:var(--r-full);
}
.ess-chefs-badge{
  position:absolute;bottom:var(--sp-4);left:var(--sp-4);
  background:rgba(0,0,0,.7);backdrop-filter:blur(4px);color:#fff;
  font-size:var(--text-xs);font-weight:600;
  padding:5px 12px;border-radius:var(--r-full);
  border:1px solid rgba(255,255,255,.2);
}
.ess-item-detail__header{margin-bottom:var(--sp-2)}
.ess-item-detail__title{
  font-family:var(--font-display);font-size:var(--text-2xl);
  font-weight:500;font-style:normal;line-height:var(--lead-tight);
  color:var(--clr-text-primary);
}
.ess-item-detail__meta-row{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3)}
.ess-portion,.ess-spicy-level{font-size:var(--text-sm);color:var(--clr-text-secondary)}
.ess-item-detail__price{
  font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;
  color:var(--clr-gold);margin-bottom:var(--sp-3);
}
.ess-item-detail__short{
  font-size:var(--text-base);color:var(--clr-text-secondary);line-height:var(--lead-relax);
  margin-bottom:var(--sp-4);padding-bottom:var(--sp-4);border-bottom:1px solid var(--clr-border);
}
.ess-item-detail__badges{margin-bottom:var(--sp-4)}

/* Bilgi Blokları */
.ess-info-block{
  display:flex;gap:var(--sp-3);padding:var(--sp-4);
  border-radius:var(--r-lg);background:var(--clr-bg-card);
  border:1px solid var(--clr-border);margin-bottom:var(--sp-4);
}
.ess-info-block--ingr     {border-left:3px solid var(--clr-gold)}
.ess-info-block--allergens{border-left:3px solid var(--clr-danger)}
.ess-info-block--calories {border-left:3px solid var(--clr-warn)}
.ess-rtl .ess-info-block--ingr     {border-left:none;border-right:3px solid var(--clr-gold)}
.ess-rtl .ess-info-block--allergens{border-left:none;border-right:3px solid var(--clr-danger)}
.ess-rtl .ess-info-block--calories {border-left:none;border-right:3px solid var(--clr-warn)}
.ess-info-block__icon{font-size:1.25rem;line-height:1;flex-shrink:0;margin-top:2px}
.ess-info-block>div{flex:1;display:flex;flex-direction:column;gap:var(--sp-1)}
.ess-info-block__label{
  font-size:var(--text-xs);font-weight:600;text-transform:uppercase;
  letter-spacing:.08em;color:var(--clr-text-muted);
}
.ess-info-block__value{
  font-family:var(--font-display);font-size:var(--text-xl);
  font-weight:600;color:var(--clr-text-primary);line-height:1;
}
.ess-info-block__hint{font-size:var(--text-xs);color:var(--clr-text-muted)}
.ess-info-block__text{
  font-size:var(--text-sm);color:var(--clr-text-secondary);
  line-height:var(--lead-relax);margin-top:var(--sp-1);
}
.ess-info-block__note{
  font-size:var(--text-xs);color:var(--clr-text-muted);font-style:normal;
  margin-top:var(--sp-2);padding-top:var(--sp-2);border-top:1px solid var(--clr-border);
}
.ess-allergen-list{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:var(--sp-2)}
.ess-allergen-tag{
  display:flex;align-items:center;gap:5px;padding:4px 10px;
  border-radius:var(--r-full);background:rgba(224,82,82,.12);
  border:1px solid rgba(224,82,82,.25);font-size:var(--text-xs);
  color:var(--clr-text-secondary);
}

/* ── 16. PAYLAŞIM ─────────────────────────────────────────────────────────── */
.ess-share-wrap{margin:var(--sp-5) 0;display:flex;gap:var(--sp-2);flex-wrap:wrap}
.ess-share-btn{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-3) var(--sp-5);border-radius:var(--r-full);
  border:1px solid var(--clr-border-light);background:var(--clr-surface);
  color:var(--clr-text-secondary);font-size:var(--text-sm);
  font-weight:500;transition:all var(--tr-fast);cursor:pointer;
}
.ess-share-btn:hover{border-color:var(--clr-gold);color:var(--clr-gold);background:var(--clr-gold-dim)}
.ess-share-wa{color:#25d366;border-color:rgba(37,211,102,.3);background:rgba(37,211,102,.08)}
.ess-share-wa:hover{border-color:#25d366;background:rgba(37,211,102,.15);color:#1da851}

/* ── 17. PAIRS / RELATED ─────────────────────────────────────────────────── */
.ess-pairs,.ess-related{margin-top:var(--sp-8);padding-top:var(--sp-6);border-top:1px solid var(--clr-border)}
.ess-pairs__title,.ess-related__title{
  font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;
  font-style:normal;color:var(--clr-text-primary);margin-bottom:var(--sp-4);
}
.ess-pairs__grid,.ess-related__list{display:flex;flex-direction:column;gap:var(--sp-3)}
.ess-back-wrap{margin-top:var(--sp-8);margin-bottom:var(--sp-4)}
.ess-back-btn{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-3) var(--sp-5);border-radius:var(--r-full);
  border:1px solid var(--clr-border-light);background:var(--clr-bg-card);
  color:var(--clr-text-secondary);font-size:var(--text-sm);
  font-weight:500;transition:all var(--tr-fast);
}
.ess-back-btn:hover{border-color:var(--clr-gold);color:var(--clr-gold);background:var(--clr-gold-dim)}

/* ── 18. MODAL (Bottom Sheet) ────────────────────────────────────────────── */
.ess-modal-overlay{
  position:fixed;inset:0;z-index:var(--z-modal);
  background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:none;align-items:flex-end;justify-content:center;
  opacity:0;transition:opacity var(--tr-base);
}
.ess-modal-overlay.is-open{opacity:1}
.ess-modal{
  width:100%;max-width:var(--max-w);background:var(--clr-bg-elevated);
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  max-height:92dvh;overflow-y:auto;position:relative;
  transform:translateY(100%);
  transition:transform .38s cubic-bezier(.32,0,.67,0);
}
.ess-modal-overlay.is-open .ess-modal{
  transform:translateY(0);
  transition:transform .42s cubic-bezier(.34,1.56,.64,1);
}
/* PHP-rendered handle ve close: yeni tasarımda gizlendi */
.ess-modal__handle{display:none}
.ess-modal__close{display:none}
.ess-modal__content{padding:0}
.ess-modal-loading{display:flex;align-items:center;justify-content:center;padding:var(--sp-12) 0}
.ess-spinner{
  width:32px;height:32px;border:3px solid var(--clr-border);
  border-top-color:var(--clr-gold);border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Yeni Modal İçerik (ess-md) ──────────────────────────────────────────── */
.ess-md{display:flex;flex-direction:column}

/* Hero */
.ess-md__hero{
  position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;
  border-radius:var(--r-xl) var(--r-xl) 0 0;flex-shrink:0;
}
.ess-md__img{width:100%;height:100%;object-fit:cover;display:block}
.ess-md__iframe{border:none}

/* Video — kontrol gizleme & tıklama engeli */
.ess-md__video-wrap{
  position:relative;
  width:100%;height:100%;
}
.ess-md__video-wrap .ess-md__img,
.ess-md__video-wrap .ess-md__iframe{
  pointer-events:none; /* video/iframe etkileşimini tamamen kapat */
}
/* Şeffaf overlay: tüm tıklama/dokunmaları yutar */
.ess-md__video-shield{
  position:absolute;
  inset:0;
  z-index:2;
  cursor:default;
  -webkit-tap-highlight-color:transparent;
  /* Üst ve alt bantlarda kalan platform UI öğelerini (logo, kanal adı) gizle */
  background:
    linear-gradient(to bottom,
      var(--clr-bg) 0%,
      transparent 18%,
      transparent 78%,
      var(--clr-bg) 100%
    );
  pointer-events:all;
}
.ess-md__img--empty{
  display:flex;align-items:center;justify-content:center;
  background:var(--clr-surface);font-size:3rem;
  width:100%;height:100%;
}
.ess-md__sold{
  position:absolute;top:14px;left:14px;
  background:var(--clr-danger);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:5px 14px;border-radius:var(--r-full);
}
.ess-md__chefs{
  position:absolute;bottom:14px;left:14px;
  background:rgba(0,0,0,.65);backdrop-filter:blur(4px);color:#fff;
  font-size:12px;font-weight:600;padding:5px 12px;border-radius:var(--r-full);
}
/* X kapat butonu — imajın üzerinde */
.ess-md__x{
  position:absolute;top:12px;right:12px;
  width:36px;height:36px;border-radius:50%;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);
  border:none;display:flex;align-items:center;justify-content:center;
  color:#fff;cursor:pointer;z-index:3;transition:background var(--tr-fast);
}
.ess-rtl .ess-md__x{right:auto;left:12px}
.ess-md__x:hover{background:rgba(0,0,0,.8)}

/* Gövde */
.ess-md__body{padding:20px 20px 0;}

/* Başlık + Fiyat satırı */
.ess-md__title-row{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:12px;margin-bottom:10px;
}
.ess-md__title{
  font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;
  color:var(--clr-text-primary);line-height:var(--lead-tight);flex:1;
}
.ess-md__price-badge{
  flex-shrink:0;padding:6px 14px;
  border:2px solid var(--clr-text-primary);border-radius:8px;
  font-family:var(--font-display);font-size:var(--text-base);font-weight:700;
  color:var(--clr-text-primary);white-space:nowrap;line-height:1.4;
}
body.ess-mode-light .ess-md__price-badge{border-color:#1a1a1a;color:#1a1a1a}

/* Kalori + meta satırı */
.ess-md__meta-row{
  display:flex;align-items:center;gap:14px;
  margin-bottom:14px;
}
.ess-md__kcal{font-size:var(--text-sm);font-weight:600;color:#e07a20}
.ess-md__portion,.ess-md__spicy{font-size:var(--text-sm);color:var(--clr-text-secondary)}

/* Açıklama */
.ess-md__desc{
  font-size:var(--text-base);color:var(--clr-text-secondary);
  line-height:var(--lead-relax);margin-bottom:16px;
}

/* Diyet etiketleri — outlined pill'ler */
.ess-md__pills{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;
}
.ess-md__pill{
  padding:5px 12px;border-radius:6px;
  border:1.5px solid var(--clr-border);background:transparent;
  font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  color:var(--clr-text-secondary);
}
body.ess-mode-light .ess-md__pill{border-color:#ccc;color:#444}

/* Alerjen tile grid */
.ess-md__allergens{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;
}
.ess-md__al-tile{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:56px;border-radius:8px;padding:8px 4px 6px;gap:3px;
  border:1px solid var(--clr-border);background:transparent;
}
.ess-md__al-icon{font-size:20px;line-height:1}
.ess-md__al-lbl{font-size:9px;font-weight:600;color:var(--clr-text-muted);text-align:center;line-height:1.2;word-break:break-word}
.ess-md__al-note{
  width:100%;font-size:11px;color:var(--clr-text-muted);margin-top:4px;
}

/* İçindekiler */
.ess-md__ingr{
  background:var(--clr-bg-card);border:1px solid var(--clr-border);
  border-left:3px solid var(--clr-gold);border-radius:var(--r-lg);
  padding:12px 14px;margin-bottom:16px;
}
.ess-rtl .ess-md__ingr{border-left:none;border-right:3px solid var(--clr-gold)}
.ess-md__ingr-label{display:block;font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--clr-text-muted);margin-bottom:6px}
.ess-md__ingr-text{font-size:var(--text-sm);color:var(--clr-text-secondary);line-height:var(--lead-relax);margin:0}

/* Paylaş */
.ess-md__share{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.ess-md__share-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:var(--r-full);
  border:1px solid var(--clr-border-light);background:var(--clr-surface);
  color:var(--clr-text-secondary);font-size:var(--text-sm);font-weight:500;
  cursor:pointer;transition:all var(--tr-fast);
}
.ess-md__share-btn:hover{border-color:var(--clr-gold);color:var(--clr-gold);background:var(--clr-gold-dim)}
.ess-md__share-wa{color:#25d366;border-color:rgba(37,211,102,.3);background:rgba(37,211,102,.08)}

/* Pairs */
.ess-md__pairs{margin-bottom:16px;padding-top:16px;border-top:1px solid var(--clr-border)}
.ess-md__pairs-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;color:var(--clr-text-primary);margin-bottom:12px}

/* Kapat butonu — tam genişlik koyu */
.ess-md__kapat{
  display:block;width:calc(100% + 40px);margin:16px -20px 0;
  padding:18px 0;
  background:#1a1a1a;color:#fff;
  font-size:var(--text-base);font-weight:600;letter-spacing:.04em;
  border:none;cursor:pointer;
  transition:background var(--tr-fast);
}
.ess-md__kapat:hover{background:#000}
body.ess-mode-light .ess-md__kapat{background:#1a1a1a;color:#fff}

/* ── 18b. Wi‑Fi bilgisi — ortalanmış pop-up ──────────────────────────────── */
.ess-wifi-overlay{
  position:fixed;inset:0;
  z-index:calc(var(--z-modal) + 8);
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;
  transition:opacity .28s ease;
}
.ess-wifi-overlay.is-open{opacity:1}

.ess-wifi-card{
  position:fixed;inset:0;
  z-index:calc(var(--z-modal) + 12);
  display:flex;align-items:center;justify-content:center;
  padding:max(var(--sp-6),env(safe-area-inset-top)) var(--pad) max(var(--sp-8),env(safe-area-inset-bottom));
  overflow:auto;
  pointer-events:none;
  opacity:0;
  transition:opacity .22s ease;
}
.ess-wifi-card.is-open{opacity:1}
.ess-wifi-card__panel{
  pointer-events:auto;
  width:100%;max-width:380px;
  transform:translateY(18px) scale(.94);
  transition:transform .34s cubic-bezier(.34,1.56,.64,1);
}
.ess-wifi-card.is-open .ess-wifi-card__panel{
  transform:translateY(0) scale(1);
}
.ess-wifi-card__inner{
  position:relative;
  padding:var(--sp-8) var(--sp-6) var(--sp-6);
  border-radius:var(--r-xl);
  background:var(--clr-bg-elevated);
  border:1px solid var(--clr-border-light);
  box-shadow:var(--sh-lg),0 24px 48px rgba(0,0,0,.35);
}
.ess-wifi-card__close{
  position:absolute;top:var(--sp-3);inset-inline-end:var(--sp-3);
  width:38px;height:38px;border-radius:var(--r-full);
  border:1px solid var(--clr-border);
  background:var(--clr-surface);
  color:var(--clr-text-muted);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:background var(--tr-fast),border-color var(--tr-fast),color var(--tr-fast);
}
.ess-wifi-card__close:hover{
  border-color:var(--clr-gold);background:var(--clr-gold-dim);color:var(--clr-gold);
}
.ess-wifi-card__icon{
  display:flex;justify-content:center;
  margin-bottom:var(--sp-3);
  color:var(--clr-gold-light);
}
.ess-wifi-card__title{
  margin:0 0 var(--sp-5);
  font-family:var(--font-display);
  font-size:var(--text-xl);
  font-weight:600;
  text-align:center;
  color:var(--clr-text-primary);
}
.ess-wifi-card__row{
  display:flex;flex-direction:column;gap:var(--sp-1);
  margin-bottom:var(--sp-4);
  padding:var(--sp-3) var(--sp-4);
  border-radius:var(--r-md);
  background:var(--clr-bg-card);
  border:1px solid var(--clr-border);
}
.ess-wifi-card__label{
  font-size:var(--text-xs);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--clr-text-muted);
}
.ess-wifi-card__val{
  font-size:var(--text-md);
  color:var(--clr-text-primary);
  word-break:break-word;
}
.ess-wifi-card__val--mono{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  letter-spacing:.02em;
}
.ess-wifi-card__copy.button-like{
  width:100%;
  margin-top:var(--sp-2);
  padding:var(--sp-3) var(--sp-5);
  border-radius:var(--r-full);
  border:1px solid var(--clr-gold);
  background:var(--clr-gold-dim);
  color:var(--clr-gold-light);
  font-family:var(--font-body);
  font-size:var(--text-sm);
  font-weight:600;
  cursor:pointer;
  transition:background var(--tr-fast),transform var(--tr-fast);
}
.ess-wifi-card__copy.button-like:hover{
  background:var(--clr-gold);color:var(--clr-text-inverse);
}
.ess-wifi-card__copy.button-like:active{transform:scale(.98)}
@media(prefers-reduced-motion:reduce){
  .ess-wifi-overlay,.ess-wifi-card,.ess-wifi-card__panel{transition:none}
}

/* ── 19. FOOTER BAR ─────────────────────────────────────────────────────── */
.ess-footer-info{
  width:100%;max-width:var(--max-w);margin-inline:auto;
  padding:var(--sp-3) var(--pad);
  display:flex;flex-wrap:wrap;gap:var(--sp-4);
  justify-content:center;align-items:center;
  border-top:1px solid var(--clr-border);
  font-size:var(--text-xs);color:var(--clr-text-muted);
}
.ess-fi-vat{font-weight:500}
.ess-fi-date strong{color:var(--clr-text-secondary)}

.ess-footer-bar{
  position:fixed;bottom:0;inset-inline:0;height:var(--footer-h);
  z-index:var(--z-footer);
  background:var(--clr-bg-glass);
  backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-top:1px solid var(--clr-border);
}
.ess-footer-bar::before{
  content:'';position:absolute;top:-1px;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--clr-gold-dim),transparent);
}
.ess-footer-bar__inner{
  height:var(--footer-h);max-width:var(--max-w);margin-inline:auto;
  padding-inline:var(--pad);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--sp-2);
}

/*
 * Footer item colors:
 * - Varsayılan durumda tema değişkenini kullanır.
 * - Body mode class geldiğinde net bir fallback renk uygular.
 * Not: !important kaldırıldı; gereksiz yüksek özgüllük diğer stilleri bozuyordu.
 */
.ess-fb-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;min-width:44px;min-height:44px;
  text-decoration:none;border:none;font-family:inherit;
  background:transparent;cursor:pointer;
  color:var(--clr-text-secondary);
  transition:color var(--tr-fast);
}
/* Koyu mod: footer ikonları açık gri */
body.ess-mode-dark  .ess-fb-item{color:#9e9890}
/* Açık mod: footer ikonları koyu gri */
body.ess-mode-light .ess-fb-item{color:#4a4540}
/* Fallback: mod class henüz eklenmemişse */
.ess-fb-item:hover,.ess-fb-item.is-active{color:var(--clr-gold)}

.ess-fb-item .fb-icon{display:flex;align-items:center;font-size:1.2rem;line-height:1}
.ess-fb-item .fb-label{font-size:10px;font-weight:500;letter-spacing:.04em}
.ess-fb-left{display:flex;align-items:center;justify-content:flex-start;gap:var(--sp-1)}
.ess-fb-right{display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-1)}
.ess-review-btn{text-decoration:none}
.ess-mode-btn{cursor:pointer}

/* Dil Dropdown */
.ess-lang-wrap{position:relative;display:flex;align-items:center;justify-content:center}
.ess-lang-trigger{
  display:flex;align-items:center;gap:5px;padding:6px 10px;
  border-radius:var(--r-full);border:1px solid var(--clr-border);
  background:var(--clr-surface);color:var(--clr-text-primary);
  font-size:var(--text-sm);font-weight:500;transition:all var(--tr-fast);cursor:pointer;
}
.ess-lang-trigger:hover{border-color:var(--clr-gold);background:var(--clr-gold-dim)}
.lang-chevron{display:flex;align-items:center;transition:transform var(--tr-fast);opacity:.6}
.ess-lang-wrap.is-open .lang-chevron{transform:rotate(180deg)}
.ess-lang-list{
  position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(6px) scale(.97);
  min-width:140px;background:var(--clr-bg-elevated);
  border:1px solid var(--clr-border-light);border-radius:var(--r-md);
  box-shadow:var(--sh-lg);padding:var(--sp-2);
  opacity:0;visibility:hidden;transition:all var(--tr-base);z-index:var(--z-modal);
}
.ess-lang-wrap.is-open .ess-lang-list{
  opacity:1;visibility:visible;
  transform:translateX(-50%) translateY(0) scale(1);
}
.ess-lang-opt{
  display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3);
  border-radius:var(--r-sm);font-size:var(--text-sm);
  color:var(--clr-text-secondary);width:100%;transition:all var(--tr-fast);cursor:pointer;
}
.ess-lang-opt:hover{background:var(--clr-gold-dim);color:var(--clr-gold-light)}
.ess-lang-opt.is-active{color:var(--clr-gold);font-weight:600}
.lang-check{margin-inline-start:auto;color:var(--clr-gold)}

/* ── 20. GDPR & POP-UP ───────────────────────────────────────────────────── */
.ess-gdpr-banner{
  position:fixed;bottom:var(--footer-h);inset-inline:0;
  z-index:calc(var(--z-footer) + 5);
  background:var(--clr-bg-elevated);border-top:1px solid var(--clr-border);
  padding:var(--sp-3) var(--pad);
  display:none;align-items:center;justify-content:center;
  gap:var(--sp-4);flex-wrap:wrap;
  transform:translateY(100%);transition:transform var(--tr-base);
}
.ess-gdpr-banner.is-visible{transform:translateY(0)}
.ess-gdpr-banner__text{
  font-size:var(--text-xs);color:var(--clr-text-muted);
  line-height:var(--lead-snug);flex:1;min-width:180px;
}
.ess-gdpr-banner__btn{
  padding:6px 16px;border-radius:var(--r-full);
  background:var(--clr-gold);color:var(--clr-text-inverse);
  font-size:var(--text-xs);font-weight:600;cursor:pointer;
  white-space:nowrap;transition:all var(--tr-fast);
}
.ess-gdpr-banner__btn:hover{background:var(--clr-gold-light)}
.ess-popup-overlay{
  position:fixed;inset:0;z-index:calc(var(--z-modal) + 10);
  background:rgba(0,0,0,.75);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:var(--sp-6);
  opacity:0;transition:opacity var(--tr-base);
}
.ess-popup-overlay.is-open{opacity:1}
.ess-popup{
  background:var(--clr-bg-elevated);border:1px solid var(--clr-border-light);
  border-radius:var(--r-xl);padding:var(--sp-8) var(--sp-6);
  max-width:380px;width:100%;box-shadow:var(--sh-lg);
  display:flex;flex-direction:column;gap:var(--sp-5);
  transform:scale(.93) translateY(16px);transition:transform var(--tr-spring);
}
.ess-popup-overlay.is-open .ess-popup{transform:scale(1) translateY(0)}
.ess-popup__title{
  font-family:var(--font-display);font-size:var(--text-xl);
  font-weight:500;font-style:normal;color:var(--clr-text-primary);
}
.ess-popup__body{font-size:var(--text-sm);color:var(--clr-text-secondary);line-height:var(--lead-relax)}
.ess-popup__btn{
  padding:var(--sp-3) var(--sp-6);border-radius:var(--r-full);
  background:var(--clr-gold);color:var(--clr-text-inverse);
  font-size:var(--text-sm);font-weight:600;align-self:flex-end;
  transition:all var(--tr-fast);cursor:pointer;
}
.ess-popup__btn:hover{background:var(--clr-gold-light)}

/* ── 21. BOŞ DURUM ───────────────────────────────────────────────────────── */
.ess-empty{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:var(--sp-4);
  padding:var(--sp-16) var(--sp-8);text-align:center;
}
.ess-empty>span{font-size:3.5rem;opacity:.3;display:block}
.ess-empty>p{font-size:var(--text-sm);color:var(--clr-text-muted);line-height:var(--lead-relax);max-width:260px}

/* ── 22. ANİMASYONLAR ────────────────────────────────────────────────────── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── 23. TOAST ───────────────────────────────────────────────────────────── */
.ess-toast{
  position:fixed;bottom:calc(var(--footer-h) + 12px);left:50%;
  transform:translateX(-50%) translateY(12px);
  background:var(--clr-bg-elevated);border:1px solid var(--clr-border-light);
  border-radius:var(--r-full);padding:8px 20px;
  font-size:var(--text-xs);font-weight:500;color:var(--clr-text-primary);
  box-shadow:var(--sh-md);z-index:var(--z-modal);
  opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;
  white-space:nowrap;
}
.ess-toast.is-visible{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── 24. RESPONSIVE ─────────────────────────────────────────────────────── */
@media(min-width:480px){
  :root{--pad:var(--sp-6);--header-h:62px}
  .ess-header__site-name{font-size:var(--text-2xl)}
  .ess-item-card__link{grid-template-columns:120px 1fr}
  .ess-cat-hero__title{font-size:var(--text-3xl)}
  .ess-item-detail__title{font-size:var(--text-3xl)}
}
@media(min-width:640px){
  :root{--max-w:680px}
  .ess-cats-grid{grid-template-columns:repeat(3,1fr)}
  .ess-item-card__link{grid-template-columns:140px 1fr;min-height:110px}
}
@media(min-width:900px){:root{--max-w:760px}}

/* Açık mod ince düzeltmeler */
body.ess-mode-light .ess-cat-card,
body.ess-mode-light .ess-item-card{box-shadow:0 2px 8px rgba(0,0,0,.07)}
body.ess-mode-light .ess-cat-card:hover,
body.ess-mode-light .ess-item-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.12),var(--sh-gold)}
body.ess-mode-light .ess-modal{border:1px solid var(--clr-border)}


/* ==========================================================================
   ESS QR MENÜ — Ana sayfa Premium hero + overlap container (layout)
   ========================================================================== */

/* Hero bandı — header sonrası tam genişlik */
.ess-premium-hero{
  position:relative;
  width:100%;
  isolation:isolate;
  min-height:clamp(200px,36vh,340px);
  overflow:hidden;
  background:linear-gradient(165deg,var(--clr-surface) 0%,var(--clr-bg) 100%);
}
.ess-premium-hero--has-bg{
  background:#0f0f0f;
}

.ess-premium-hero__bg{
  position:absolute;inset:0;
  overflow:hidden;
  pointer-events:none;
}
/* Bulanık arkaplan (yalnızca görsel varken) */
.ess-premium-hero--has-bg .ess-premium-hero__blur{
  position:absolute;
  inset:-8%;
  background:center/cover no-repeat var(--hero-bg);
  filter:blur(22px)saturate(1.06);
  transform:scale(1.08);
  opacity:.95;
}
.ess-premium-hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,.45) 0%,
      rgba(0,0,0,.25) 40%,
      rgba(10,10,10,.92) 100%);
}

.ess-premium-hero__content{
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:var(--sp-4);
  max-width:var(--max-w);
  margin-inline:auto;
  padding:var(--sp-10) var(--pad) clamp(var(--sp-12),14vw,var(--sp-16));
  text-align:center;
}

/* Başlık / meta — typography paneli (--typo-hero-*) ile de gelir */
.ess-premium-hero__meta{
  font-size:var(--text-sm);
  color:rgba(245,243,239,.93);
}
.ess-premium-hero__meta-item{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-weight:500;
}

.ess-premium-hero__actions{
  display:flex;flex-wrap:wrap;
  gap:var(--sp-3);
  align-items:center;justify-content:center;
}

/* Wi-Fi / Konum küçük butonları */
a.ess-hero-btn,.ess-hero-btn{
  display:inline-flex;
  align-items:center;gap:6px;
  padding:9px 16px;border-radius:var(--r-full);
  font-family:var(--font-body);
  font-size:var(--text-sm);font-weight:600;
  color:rgba(255,255,255,.95);
  text-decoration:none;
  cursor:pointer;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(0,0,0,.42);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:border-color var(--tr-fast),background var(--tr-fast),transform var(--tr-fast),color var(--tr-fast);
}
a.ess-hero-btn:hover,.ess-hero-btn:hover{
  border-color:rgba(255,255,255,.42);
  background:rgba(0,0,0,.52);
}

.ess-premium-hero__social{
  display:flex;gap:var(--sp-3);
  flex-wrap:wrap;
  align-items:center;justify-content:center;
  padding-top:2px;
}
a.ess-hero-social-btn{
  display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:var(--r-full);
  border:1px solid rgba(255,255,255,.25);
  color:rgba(255,255,255,.88);
  background:rgba(255,255,255,.06);
  transition:background var(--tr-fast),border-color var(--tr-fast),color var(--tr-fast),transform var(--tr-fast);
}
a.ess-hero-social-btn:hover{
  border-color:var(--clr-gold);color:var(--clr-gold-light);
  transform:translateY(-1px);
}

/* Kartı üste bindirilen ana içerik */
.ess-premium-container:not(.ess-premium-container--cat){
  position:relative;
  z-index:3;
  width:100%;max-width:var(--max-w);
  margin-inline:auto;
  margin-top:clamp(-2.85rem,-7vw,-1.6rem);
  padding:clamp(var(--sp-6),4vw,var(--sp-10)) var(--pad) max(var(--sp-16),calc(var(--footer-h) + var(--sp-6)));
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  background:var(--clr-bg);
  box-shadow:0 -14px 40px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.04);
}

/* Hero kapalı — overlap yok */
.ess-page--no-home-hero .ess-premium-container:not(.ess-premium-container--cat){
  margin-top:0;
  border-radius:0;
  padding-top:var(--sp-6);
  box-shadow:none;
}
@media (prefers-reduced-motion:reduce){
  a.ess-hero-social-btn{transition:none;}
}

/* ==========================================================================
   ESS QR MENÜ — Layout Temaları  v3.2
   Bu dosya assets/css/style.css'in sonuna eklenir.
   ========================================================================== */

/* ── v3.5 EKLEMELERİ ─────────────────────────────────────────────────────── */

/* Hero: logo alanı artık hero'da yok, sadece header'da */
.ess-premium-hero__logo { display: none !important; }

/* Premium başlık - düz font (italic yok) */
.ess-premium-hero__title {
  font-style: normal;
  font-weight: 600;
  font-size: clamp(1.5rem, 6vw, 2.5rem);
  letter-spacing: .02em;
  color:rgba(250,248,244,.98);
  text-shadow:0 6px 28px rgba(0,0,0,.42);
}

/* Kategori sayfasında container'ın üst hero kaldırıldı,
   overlap yerine düz başlıyor */
.ess-premium-container--cat {
  margin-top: 0;
  border-radius: 0;
  box-shadow: none;
}

/* Alt kategoriler bölümü başlığı */
.ess-subcats-section {
  margin-bottom: var(--sp-4);
}

/* Ürünler bölümü ayırıcı */
.ess-items-section {
  border-top: 1px solid var(--clr-border);
  padding-top: var(--sp-4);
}

/* Kategori hero başlığı - düz */
.ess-cat-hero__title { font-style: normal !important; }
.ess-cat-hero__desc  { font-style: normal !important; }

/* Section başlıkları - düz */
.ess-section-title   { font-style: normal !important; }

/* Item detail başlık - düz */
.ess-item-detail__title { font-style: normal !important; }
.ess-pairs__title       { font-style: normal !important; }
.ess-related__title     { font-style: normal !important; }

/* Modal ürün başlıkları - düz */
.ess-modal .ess-item-detail__title { font-style: normal !important; }
.ess-md__title { font-style: normal !important; }

/* Cat card başlık - düz */
.ess-cat-card__title    { font-style: normal !important; }

/* Header site adı - düz */
.ess-header__site-name  { font-style: normal !important; }

/* ── v3.6: Sektör preset nüansları ───────────────────────────────────────── */
body.ui-preset-cafe .ess-item-card{
  box-shadow:0 2px 12px rgba(0,0,0,.22);
}

body.ui-preset-fast_food .ess-item-card{
  border-width:2px;
}

/* ── Liste görünümü FAB — kategori (ürün listesi) ───────────────────────── */
.ess-item-view-fab{
  position:fixed;
  inset-inline-end:max(12px,env(safe-area-inset-right));
  bottom:calc(var(--footer-h) + 14px + env(safe-area-inset-bottom));
  z-index:calc(var(--z-modal) - 30);
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:11px 18px;
  border-radius:var(--r-full);
  border:1px solid var(--clr-border-light);
  background:var(--clr-bg-elevated);
  color:var(--clr-text-primary);
  backdrop-filter:saturate(1.05) blur(8px);-webkit-backdrop-filter:saturate(1.05) blur(8px);
  box-shadow:var(--sh-md),0 0 0 1px rgba(0,0,0,.04);
  font-size:var(--text-sm);
  font-weight:600;
  font-family:var(--font-body);
  cursor:pointer;
  transition:transform var(--tr-fast),box-shadow var(--tr-fast),background var(--tr-fast),border-color var(--tr-fast);
}
.ess-item-view-fab:hover{
  border-color:var(--clr-gold);box-shadow:var(--sh-md),var(--sh-gold);
}
.ess-item-view-fab:active{transform:scale(0.98);}
.ess-item-view-fab__icon{font-size:1.2rem;line-height:1;display:inline-flex;}

/* ── Kompakt (fotoğrafsız) ürün satırı ──────────────────────────────────── */
html.ess-item-view-compact .ess-item-card__link{
  grid-template-columns:minmax(0,1fr) auto!important;
  min-height:0!important;
  align-items:center;
}
html.ess-item-view-compact .ess-item-card{min-height:0;}
html.ess-item-view-compact .ess-item-card:hover{transform:translateY(0);}
html.ess-item-view-compact .ess-item-card__media{display:none!important;}
html.ess-item-view-compact .ess-item-card:hover .ess-item-card__img{transform:none;}
html.ess-item-view-compact .ess-chefs-pin{display:none;}
html.ess-item-view-compact .ess-item-card__desc{
  display:-webkit-box;
  -webkit-line-clamp:1;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
html.ess-item-view-compact .ess-item-card__content{
  padding:var(--sp-2) var(--sp-3);gap:4px;
  justify-content:center;
}



/* ═══════════════════════════════════════════════════════════════════════════
   İStek Listesi & Özet Çubuğu  — v3.5
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Modal: İndirimli fiyat satırı ──────────────────────────────────────── */
.ess-md__price-row{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.ess-md__price-orig{
  font-size:var(--text-sm);color:var(--clr-text-muted);
  text-decoration:line-through;font-weight:500;
  opacity:.75;
}
.ess-md__price-disc{
  background:linear-gradient(135deg,#e63946,#c1121f);
  color:#fff;border-color:transparent;
}
.ess-md__discount-badge{
  display:inline-flex;align-items:center;
  background:rgba(230,57,70,.15);color:#e63946;
  font-size:10px;font-weight:700;letter-spacing:.04em;
  padding:2px 6px;border-radius:var(--r-full);
  border:1px solid rgba(230,57,70,.3);
}

/* ── Modal: Makro tablosu ────────────────────────────────────────────────── */
.ess-md__macros{
  display:flex;gap:8px;flex-wrap:wrap;
  margin:10px 0 14px;
}
.ess-md__macro{
  flex:1;min-width:64px;
  display:flex;flex-direction:column;align-items:center;
  padding:8px 6px 6px;
  border:1px solid var(--clr-border-light);
  border-radius:var(--r-md);
  background:var(--clr-surface);
  gap:2px;
}
.ess-md__macro-val{
  font-size:15px;font-weight:700;
  color:var(--clr-text-primary);line-height:1;
}
.ess-md__macro-lbl{
  font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--clr-text-muted);line-height:1;margin-top:2px;
}
.ess-md__macro--protein .ess-md__macro-val{color:#4ade80}
.ess-md__macro--carbs   .ess-md__macro-val{color:#fb923c}
.ess-md__macro--fat     .ess-md__macro-val{color:#facc15}

/* ── Modal: İstek listesi butonu ────────────────────────────────────────── */
.ess-wl-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:calc(100% + 40px);margin:8px -20px 0;
  padding:16px 20px;
  background:transparent;
  border:none;border-top:1px solid var(--clr-border);
  color:var(--clr-text-secondary);
  font-size:var(--text-base);font-weight:600;
  cursor:pointer;
  transition:background var(--tr-fast),color var(--tr-fast);
}
.ess-wl-btn:hover{background:rgba(255,255,255,.04);color:var(--clr-text-primary)}
.ess-wl-btn.is-in{color:#e63946}
.ess-wl-btn.is-in:hover{background:rgba(230,57,70,.06)}
.ess-wl-btn__icon{font-size:20px;line-height:1;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}
.ess-wl-btn:active .ess-wl-btn__icon{transform:scale(1.35)}
body.ess-mode-light .ess-wl-btn{border-top-color:#e0e0e0}
body.ess-mode-light .ess-wl-btn:hover{background:rgba(0,0,0,.03)}

/* ── Özet Çubuğu (floating bottom bar) ─────────────────────────────────── */
.ess-sb{
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:calc(var(--z-modal) - 5);
  background:var(--clr-bg-elevated);
  border-top:1px solid var(--clr-border-light);
  box-shadow:0 -4px 24px rgba(0,0,0,.35);
  transform:translateY(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
  /* safe-area: iPhone home bar */
  padding-bottom:env(safe-area-inset-bottom,0px);
  will-change:transform;
}
.ess-sb.is-visible{transform:translateY(0)}

.ess-sb__row{
  display:flex;align-items:center;
  padding:10px 16px;
  gap:10px;
  min-height:56px;
}

/* Sol: count badge + label */
.ess-sb__left{
  display:flex;align-items:center;gap:8px;
  flex:1;min-width:0;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
}
.ess-sb__count{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  background:#e63946;color:#fff;
  font-size:12px;font-weight:700;
  flex-shrink:0;
}
.ess-sb__label{
  font-size:13px;font-weight:600;color:var(--clr-text-primary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ess-sb__chevron{
  width:14px;height:14px;
  color:var(--clr-text-muted);
  transition:transform .2s ease;
  flex-shrink:0;
}
.ess-sb.is-expanded .ess-sb__chevron{transform:rotate(180deg)}

/* Orta: makro toplamları */
.ess-sb__totals{
  display:flex;align-items:center;gap:12px;flex-wrap:nowrap;overflow:hidden;
}
.ess-sb__stat{
  display:flex;flex-direction:column;align-items:center;
  font-size:10px;color:var(--clr-text-muted);
  white-space:nowrap;line-height:1.2;
}
.ess-sb__stat b{
  font-size:13px;font-weight:700;color:var(--clr-text-primary);
}
.ess-sb__stat--price b{color:var(--clr-gold)}

/* Sağ: Temizle butonu */
.ess-sb__clear{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  background:transparent;border:1px solid var(--clr-border-light);
  color:var(--clr-text-muted);font-size:16px;cursor:pointer;
  transition:all var(--tr-fast);
}
.ess-sb__clear:hover{background:#e63946;border-color:#e63946;color:#fff}

/* Açılır panel (ürün listesi) */
.ess-sb__panel{
  max-height:0;overflow:hidden;
  transition:max-height .32s cubic-bezier(.4,0,.2,1);
  border-top:0px solid var(--clr-border);
}
.ess-sb.is-expanded .ess-sb__panel{
  max-height:320px;overflow-y:auto;
  border-top-width:1px;
}
.ess-sb__item{
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;
  border-bottom:1px solid var(--clr-border);
}
.ess-sb__item:last-child{border-bottom:none}
.ess-sb__item-title{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--clr-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ess-sb__item-price{font-size:12px;font-weight:700;color:var(--clr-gold);flex-shrink:0}
.ess-sb__item-macro{font-size:10px;color:var(--clr-text-muted);flex-shrink:0}
.ess-sb__item-remove{
  width:24px;height:24px;border-radius:50%;
  background:transparent;border:none;
  color:var(--clr-text-muted);font-size:14px;
  cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:color var(--tr-fast),background var(--tr-fast);
}
.ess-sb__item-remove:hover{color:#e63946;background:rgba(230,57,70,.1)}

/* light mode */
body.ess-mode-light .ess-sb{
  background:#fff;
  border-top-color:#e0e0e0;
  box-shadow:0 -4px 24px rgba(0,0,0,.12);
}

/* Küçük ekran: toplamlar gizle, sadece count + price göster */
@media(max-width:360px){
  .ess-sb__stat--kcal,.ess-sb__stat--protein,.ess-sb__stat--carbs{display:none}
}


/* ═══════════════════════════════════════════════════════════════════════════
   Diğer Müşteriler Bunları Beğendi + Upsell Banner  — v3.5
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Modal: Top-Rated bölümü ────────────────────────────────────────────── */
.ess-md__toprated{
  margin-bottom:16px;
  padding-top:16px;
  border-top:1px solid var(--clr-border);
}
.ess-md__toprated-title{
  font-family:var(--font-display);
  font-size:var(--text-sm);font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;
  color:var(--clr-text-muted);
  margin-bottom:12px;
}
.ess-md__toprated-item{
  display:flex;align-items:center;gap:12px;
  width:100%;padding:10px 12px;
  background:var(--clr-surface);
  border:1px solid var(--clr-border-light);
  border-radius:var(--r-md);
  margin-bottom:8px;
  cursor:pointer;text-align:left;
  transition:border-color var(--tr-fast),background var(--tr-fast),transform var(--tr-fast);
}
.ess-md__toprated-item:last-child{margin-bottom:0}
.ess-md__toprated-item:hover{
  border-color:var(--clr-gold);
  background:var(--clr-gold-dim);
  transform:translateX(3px);
}
.ess-md__toprated-img{
  width:52px;height:52px;border-radius:var(--r-sm);
  object-fit:cover;flex-shrink:0;
}
.ess-md__toprated-img--empty{
  width:52px;height:52px;border-radius:var(--r-sm);
  background:var(--clr-bg-muted);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.ess-md__toprated-info{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:3px;
}
.ess-md__toprated-name{
  font-size:var(--text-sm);font-weight:600;
  color:var(--clr-text-primary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ess-md__toprated-stars{
  font-size:12px;color:#f59e0b;letter-spacing:.02em;
}
.ess-md__toprated-stars small{
  font-size:10px;color:var(--clr-text-muted);font-weight:500;
}
.ess-md__toprated-price{
  font-size:12px;font-weight:700;color:var(--clr-gold);
}

/* ── Özet Çubuğu: Upsell banner ────────────────────────────────────────── */
.ess-sb__upsell{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;
  background:linear-gradient(135deg,rgba(34,211,238,.08),rgba(56,189,248,.05));
  border-bottom:1px solid rgba(34,211,238,.2);
  /* animasyon */
  animation: ess-upsell-in .35s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes ess-upsell-in{
  from{opacity:0;transform:translateY(-8px)}
  to  {opacity:1;transform:translateY(0)}
}
.ess-sb__upsell-icon{
  font-size:22px;line-height:1;flex-shrink:0;
  animation: ess-upsell-wobble 1.8s ease-in-out 0.4s infinite;
}
@keyframes ess-upsell-wobble{
  0%,100%{transform:rotate(0deg)}
  20%    {transform:rotate(-12deg)}
  40%    {transform:rotate(10deg)}
  60%    {transform:rotate(-6deg)}
  80%    {transform:rotate(4deg)}
}
.ess-sb__upsell-text{
  font-size:12px;font-weight:600;
  color:var(--clr-text-primary);
  line-height:1.4;
}
body.ess-mode-light .ess-sb__upsell{
  background:linear-gradient(135deg,rgba(14,165,233,.08),rgba(56,189,248,.04));
  border-bottom-color:rgba(14,165,233,.2);
}

/* ═══════════════════════════════════════════════════════════════════════════
   Story Baloncukları  — v3.5
   ═══════════════════════════════════════════════════════════════════════════ */
.ess-stories-wrap{
  padding:16px 0 4px;
  background:var(--clr-bg);
  position:relative;
}
.ess-stories{
  display:flex;
  gap:16px;
  padding:4px var(--pad) 12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.ess-stories::-webkit-scrollbar{display:none}

.ess-story{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;flex-shrink:0;
  scroll-snap-align:start;
  background:none;border:none;cursor:pointer;
  padding:0;
  -webkit-tap-highlight-color:transparent;
  width:68px;
}
.ess-story--sold{ opacity:.5; pointer-events:none; }

/* Gradient ring */
.ess-story__ring{
  width:64px;height:64px;
  border-radius:50%;
  padding:2.5px;
  background:conic-gradient(from 180deg, #f59e0b, #ef4444, #8b5cf6, #06b6d4, #f59e0b);
  transition:transform .2s cubic-bezier(.34,1.56,.64,1), opacity .15s;
  position:relative;
}
.ess-story__ring:hover,
.ess-story:focus-visible .ess-story__ring{
  transform:scale(1.08);
}
.ess-story__ring--sold{
  background:var(--clr-border);
}

/* Inner circle */
.ess-story__img{
  width:100%;height:100%;
  border-radius:50%;
  object-fit:cover;
  display:block;
  border:2.5px solid var(--clr-bg);
  background:var(--clr-surface);
}
.ess-story__img--empty{
  display:flex;align-items:center;justify-content:center;
  font-size:26px;line-height:1;
  border:2.5px solid var(--clr-bg);
  border-radius:50%;
  background:var(--clr-surface);
}

/* Tag icon badge */
.ess-story__tag-icon{
  position:absolute;bottom:0;right:0;
  width:20px;height:20px;border-radius:50%;
  background:var(--clr-bg-elevated);
  border:1.5px solid var(--clr-bg);
  font-size:11px;line-height:20px;text-align:center;
  display:flex;align-items:center;justify-content:center;
}

/* Label */
.ess-story__label{
  font-size:11px;font-weight:600;
  color:var(--clr-text-secondary);
  text-align:center;
  width:68px;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
  line-height:1.2;
}
.ess-story:hover .ess-story__label,
.ess-story:focus-visible .ess-story__label{
  color:var(--clr-text-primary);
}

/* Viewed state — gray ring after user has opened the story */
.ess-story--viewed .ess-story__ring{
  background:var(--clr-border);
  opacity:.65;
}
.ess-story--viewed .ess-story__label{
  color:var(--clr-text-secondary);
  opacity:.65;
}
/* Active pulse on load for unviewed stories */
@keyframes ess-story-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.45)}
  50%{box-shadow:0 0 0 5px rgba(245,158,11,0)}
}
.ess-story:not(.ess-story--viewed):not(.ess-story--sold) .ess-story__ring{
  animation:ess-story-pulse 2.4s ease-in-out infinite;
}

/* Separator between stories and categories */
.ess-stories-wrap + .ess-premium-container{
  margin-top:0;
}
body.ess-mode-light .ess-stories-wrap{ background:var(--clr-bg); }

/* ═══════════════════════════════════════════════════════════════════════════
   Görünüm Modları: Klasik Liste + Masonry Grid  — v3.5
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Klasik Liste (ess-item-view-list) ──────────────────────────────────── */
html.ess-item-view-list .ess-items-grid{
  display:flex !important;
  flex-direction:column;
  gap:0;
}
html.ess-item-view-list .ess-item-card{
  border-radius:0 !important;
  border-bottom:1px solid var(--clr-border) !important;
  box-shadow:none !important;
  min-height:0 !important;
  transform:none !important;
}
html.ess-item-view-list .ess-item-card:last-child{ border-bottom:none !important; }
html.ess-item-view-list .ess-item-card__link{
  grid-template-columns:80px minmax(0,1fr) auto !important;
  align-items:center;
  min-height:80px !important;
  padding:0 !important;
  gap:0 !important;
}
html.ess-item-view-list .ess-item-card__media{
  width:80px !important;
  height:80px !important;
  border-radius:0 !important;
  flex-shrink:0;
}
html.ess-item-view-list .ess-item-card__img{
  width:80px !important;
  height:80px !important;
  border-radius:0 !important;
}
html.ess-item-view-list .ess-item-card__content{
  padding:10px 12px !important;
  gap:2px !important;
  justify-content:center !important;
}
html.ess-item-view-list .ess-item-card__title{
  font-size:var(--text-base) !important;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
html.ess-item-view-list .ess-item-card__desc{
  display:-webkit-box !important;
  -webkit-line-clamp:1 !important;
  -webkit-box-orient:vertical;
  overflow:hidden;
  font-size:var(--text-xs) !important;
}
html.ess-item-view-list .ess-item-card__price-row{
  padding:0 12px 0 0 !important;
  flex-direction:column;
  align-items:flex-end;
  flex-shrink:0;
}
html.ess-item-view-list .ess-item-card:hover{transform:none !important;}
html.ess-item-view-list .ess-chefs-pin{display:none !important;}

/* ── Masonry Grid (ess-item-view-masonry) ───────────────────────────────── */
html.ess-item-view-masonry .ess-items-grid{
  display:grid !important;
  grid-template-columns:repeat(2, 1fr) !important;
  gap:10px !important;
}
html.ess-item-view-masonry .ess-item-card{
  min-height:0 !important;
}
html.ess-item-view-masonry .ess-item-card__link{
  grid-template-columns:1fr !important;
  grid-template-rows:auto 1fr !important;
}
html.ess-item-view-masonry .ess-item-card__media{
  height:130px !important;
  aspect-ratio:unset !important;
}
html.ess-item-view-masonry .ess-item-card__content{
  padding:10px !important;
  gap:4px !important;
}
html.ess-item-view-masonry .ess-item-card__title{
  font-size:var(--text-sm) !important;
}
html.ess-item-view-masonry .ess-item-card__desc{
  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical;
  overflow:hidden;
  font-size:var(--text-xs) !important;
}
@media(min-width:640px){
  html.ess-item-view-masonry .ess-items-grid{
    grid-template-columns:repeat(3,1fr) !important;
  }
}


/* ═══════════════════════════════════════════════════════════════════════════
   İstek Listesi Slide Panel + Footer Badge  — v3.5
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Footer badge & butonu ──────────────────────────────────────────────── */
.ess-wl-fb-btn{ position:relative; }
.ess-wl-fb-heart{ font-size:20px; line-height:1; display:block; }
.ess-wl-badge{
  position:absolute;
  top:-5px; right:-5px;
  min-width:16px; height:16px;
  padding:0 4px;
  border-radius:9px;
  background:#e63946; color:#fff;
  font-size:9px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  border:1.5px solid var(--clr-bg);
  pointer-events:none;
  line-height:1;
}

/* ── Panel overlay ──────────────────────────────────────────────────────── */
.ess-wl-panel-overlay{
  position:fixed; inset:0;
  z-index:calc(var(--z-modal) + 14);
  background:rgba(0,0,0,.52);
  backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px);
  opacity:0; pointer-events:none;
  transition:opacity .28s ease;
}
.ess-wl-panel-overlay.is-open{
  opacity:1; pointer-events:auto;
}

/* ── Slide panel ────────────────────────────────────────────────────────── */
.ess-wl-panel{
  position:fixed;
  left:0; top:0; bottom:0;
  width:min(340px, 92vw);
  z-index:calc(var(--z-modal) + 15);
  background:var(--clr-bg-elevated);
  border-right:1px solid var(--clr-border-light);
  box-shadow:8px 0 40px rgba(0,0,0,.45);
  transform:translateX(-100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column;
  overflow:hidden;
  /* safe-area top (notch) */
  padding-top:env(safe-area-inset-top, 0px);
}
.ess-wl-panel.is-open{
  transform:translateX(0);
}

/* Header */
.ess-wl-panel__head{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 16px 14px;
  border-bottom:1px solid var(--clr-border);
  flex-shrink:0;
  gap:8px;
}
.ess-wl-panel__title{
  font-size:15px; font-weight:700;
  color:var(--clr-text-primary);
  margin:0;
  display:flex; align-items:center; gap:6px;
  line-height:1.2;
}
.ess-wl-panel__count-label{
  font-size:11px; font-weight:500;
  color:var(--clr-text-muted);
  background:var(--clr-surface);
  border:1px solid var(--clr-border-light);
  padding:1px 7px; border-radius:var(--r-full);
}
.ess-wl-panel__head-actions{
  display:flex; align-items:center; gap:6px; flex-shrink:0;
}
.ess-wl-panel__clear-btn{
  font-size:11px; font-weight:600;
  color:var(--clr-text-muted);
  background:none; border:none; cursor:pointer;
  padding:5px 10px; border-radius:var(--r-sm);
  transition:color .15s, background .15s;
}
.ess-wl-panel__clear-btn:hover{ color:#e63946; background:rgba(230,57,70,.08); }
.ess-wl-panel__close-btn{
  width:30px; height:30px; border-radius:50%;
  background:none; border:1px solid var(--clr-border-light);
  color:var(--clr-text-muted); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all .15s;
}
.ess-wl-panel__close-btn:hover{
  background:var(--clr-surface); color:var(--clr-text-primary);
}

/* Body (scrollable list) */
.ess-wl-panel__body{
  flex:1; overflow-y:auto;
  overscroll-behavior:contain;
}
.ess-wl-panel__empty{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:220px; gap:14px;
  color:var(--clr-text-muted);
  padding:20px;
}
.ess-wl-panel__empty-icon{ font-size:44px; line-height:1; }
.ess-wl-panel__empty-msg{
  font-size:14px; font-weight:500;
  text-align:center; line-height:1.5;
}

/* Item row */
.ess-wl-panel__item{
  display:flex; align-items:flex-start; gap:10px;
  padding:13px 16px;
  border-bottom:1px solid var(--clr-border);
  transition:background .12s;
}
.ess-wl-panel__item:last-child{ border-bottom:none; }
.ess-wl-panel__item:hover{ background:var(--clr-surface); }

.ess-wl-panel__item-info{
  flex:1; min-width:0;
  display:flex; flex-direction:column; gap:4px;
}
.ess-wl-panel__item-title{
  font-size:13px; font-weight:600;
  color:var(--clr-text-primary);
  line-height:1.3;
}
.ess-wl-panel__item-price{
  font-size:13px; font-weight:700;
  color:var(--clr-gold);
}
.ess-wl-panel__item-macros{
  font-size:10px; color:var(--clr-text-muted);
  line-height:1.5; display:flex; flex-wrap:wrap; gap:6px;
}
.ess-wl-panel__item-macro-chip{
  display:inline-flex; align-items:center; gap:2px;
  background:var(--clr-surface);
  border:1px solid var(--clr-border-light);
  border-radius:var(--r-full);
  padding:1px 6px; font-size:10px;
}
.ess-wl-panel__item-remove{
  width:28px; height:28px; border-radius:50%; flex-shrink:0;
  background:none; border:none; color:var(--clr-text-muted);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:color .15s, background .15s; margin-top:1px;
}
.ess-wl-panel__item-remove:hover{
  color:#e63946; background:rgba(230,57,70,.1);
}

/* Footer totals */
.ess-wl-panel__footer{
  border-top:2px solid var(--clr-border);
  padding:14px 16px calc(14px + env(safe-area-inset-bottom, 0px));
  flex-shrink:0;
  background:var(--clr-surface);
}
.ess-wl-panel__totals{
  display:grid; grid-template-columns:1fr 1fr; gap:10px 16px;
}
.ess-wl-panel__total{
  display:flex; flex-direction:column; gap:2px;
}
.ess-wl-panel__total-label{
  font-size:10px; font-weight:600; letter-spacing:.05em; text-transform:uppercase;
  color:var(--clr-text-muted);
}
.ess-wl-panel__total-val{
  font-size:15px; font-weight:700;
  color:var(--clr-text-primary);
}
.ess-wl-panel__total--price .ess-wl-panel__total-val{ color:var(--clr-gold); }

/* Light mode adjustments */
body.ess-mode-light .ess-wl-panel{
  background:#fff;
  border-right-color:#e0e0e0;
  box-shadow:8px 0 40px rgba(0,0,0,.18);
}
body.ess-mode-light .ess-wl-panel__footer{ background:#f6f7f7; }
body.ess-mode-light .ess-wl-panel__item:hover{ background:#f9f9f9; }
