/* ============================================================
   ETERNA main.css v7  |  Underscores (_s)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

:root {
  --clr-hero:#8B6248; --clr-bg:#FDF7F1; --clr-dark:#33271D;
  --clr-cat:#603630;  --clr-white:#FFF;  --clr-body:#2a2a2a;
  --clr-muted:#888;   --clr-border:rgba(96,54,48,.15);
  --clr-nav:rgba(255,255,255,.85);
  --ff:'Space Grotesk',sans-serif;
  --fs-marquee:clamp(80px,9vw,140px);
  --fs-cat-name:clamp(60px,10vw,160px);
  --fs-section-lbl:clamp(40px,4.5vw,75px);
  --fs-nav:13px; --fs-body:14px; --fs-desc:13px;
  --fw-heading:700; --fw-nav:400;
  --pad:160px; --header-top:80px; --hh:50px;
  --btn-pad-v:30px; --btn-pad-h:60px;
  --btn-bg:#33271D; --btn-color:#FFF;
  --dur-marquee:24s;
  --ease:cubic-bezier(.22,1,.36,1);
  --max-w:1600px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ff);color:var(--clr-body);background:var(--clr-bg);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ── WordPress wrappers: must NOT interfere with hero ── */
#page.site,
.site-main{overflow:visible !important;padding:0 !important;margin:0 !important}

/* ── BUTTON ── */
.btn{display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--ff);font-size:var(--fs-body);font-weight:500;
  letter-spacing:.2px;gap:10px;line-height:1;white-space:nowrap;
  padding:var(--btn-pad-v) var(--btn-pad-h);
  transition:background .3s var(--ease),transform .3s var(--ease),box-shadow .3s var(--ease)}
.btn--dark{background:var(--btn-bg);color:var(--btn-color)}
.btn--dark:hover{background:#1e150d;transform:translateY(-2px);box-shadow:0 8px 28px rgba(51,39,29,.3)}

/* ══════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding-top:var(--header-top);background:transparent;
  transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .3s ease}
.site-header.is-scrolled{
  padding-top:0;background:rgba(22,9,3,.95);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(255,255,255,.05)}
.admin-bar .site-header{top:32px}
.header-inner{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  height:var(--hh);max-width:var(--max-w);margin-inline:auto;padding-inline:var(--pad)}
.site-branding{display:flex;justify-content:center}
.site-logo-link{display:flex;align-items:center}
.logo-img{height:32px;width:auto}
.logo-text{font-family:var(--ff);font-size:28px;font-weight:700;
  color:var(--clr-white);letter-spacing:-.5px;line-height:1}
.header-nav{display:flex;align-items:center}
.header-nav--left{justify-content:flex-start}
.header-nav--right{justify-content:flex-end}
.header-nav .nav-menu{display:flex;align-items:center;gap:32px}
.header-nav .nav-menu a{font-size:var(--fs-nav);font-weight:var(--fw-nav);
  color:var(--clr-nav);letter-spacing:.2px;transition:color .25s ease;white-space:nowrap}
.header-nav .nav-menu a:hover,
.header-nav .nav-menu .current-menu-item>a{color:var(--clr-white)}
.hamburger{display:none;flex-direction:column;justify-content:center;
  gap:5px;width:40px;height:40px;padding:6px;flex-shrink:0}
.hamburger__bar{display:block;width:22px;height:2px;background:var(--clr-white);
  border-radius:2px;transition:transform .35s var(--ease),opacity .25s ease;transform-origin:center}
.hamburger.is-active .hamburger__bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-active .hamburger__bar:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.is-active .hamburger__bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE NAV ── */
.mobile-nav{position:fixed;inset:0;background:rgba(16,5,1,.97);z-index:980;
  display:flex;align-items:center;justify-content:center;
  transform:translateX(100%);opacity:0;visibility:hidden;
  transition:transform .45s var(--ease),opacity .35s ease,visibility .45s}
.mobile-nav.is-open{transform:translateX(0);opacity:1;visibility:visible}
.mobile-nav__close{position:absolute;top:24px;right:24px;font-size:24px;
  color:rgba(255,255,255,.7);transition:color .25s}
.mobile-nav__close:hover{color:var(--clr-white)}
.mobile-nav__inner{width:100%;text-align:center}
.mobile-nav__menu{display:flex;flex-direction:column;width:100%}
.mobile-nav__menu+.mobile-nav__menu{border-top:1px solid rgba(255,255,255,.06)}
.mobile-nav__menu li{border-bottom:1px solid rgba(255,255,255,.06);width:100%}
.mobile-nav__menu li:first-child{border-top:1px solid rgba(255,255,255,.06)}
.mobile-nav__menu a{display:block;width:100%;padding:22px 0;font-size:22px;
  font-weight:700;color:rgba(255,255,255,.9);letter-spacing:-.03em;
  transition:color .25s,background .25s}
.mobile-nav__menu a:hover{color:var(--clr-white);background:rgba(255,255,255,.04)}
.mobile-nav__backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:970;
  opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s}
.mobile-nav__backdrop.is-open{opacity:1;visibility:visible}

/* ══════════════════════════════════════════════
   HERO SECTION
   ══════════════════════════════════════════════

   The hero is a self-contained block. It uses:
     width:100%  height:100vh  position:relative  overflow:hidden
   Every child is position:absolute.
   Nothing renders outside this box.

   You have ONE photo? → Put it in Background only. Leave Foreground empty.
   Foreground is ONLY for a PNG with transparent background (model cutout).
   ══════════════════════════════════════════════ */
.hero-section{
  position:relative;
  display:block;
  width:100%;
  height:100vh;
  min-height:560px;
  overflow:hidden;
  background:var(--clr-hero);
  /* Reset any inherited flex/grid from parent */
  flex:none;
  grid-area:unset;
}
/* Kill max-width:100% from global img reset inside hero */
.hero-section img{
  max-width:none;
}

/* Layer 1 — background: fills entire hero box */
.hero-bg-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  z-index:1;
  pointer-events:none;
}
.hero-bg-fallback{
  position:absolute;inset:0;z-index:1;background:var(--clr-hero)}

/* Layer 2 — marquee: vertically centered */
.hero-marquee-wrap{
  position:absolute;
  top:50%;left:0;right:0;
  transform:translateY(-50%);
  z-index:2;
  overflow:hidden;
  pointer-events:none;
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 5%,#000 95%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0%,#000 5%,#000 95%,transparent 100%);
}
.hero-marquee{
  display:flex;width:max-content;
  animation:marquee-scroll var(--dur-marquee) linear infinite;
  will-change:transform}
.hero-marquee:hover{animation-play-state:paused}
.hero-marquee__text{
  display:block;white-space:nowrap;padding-right:80px;
  font-family:var(--ff);font-size:var(--fs-marquee);font-weight:var(--fw-heading);
  line-height:1;letter-spacing:-.04em;color:rgba(255,255,255,.88)}
@keyframes marquee-scroll{
  0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Layer 3 — foreground PNG (transparent PNG only, optional) */
.hero-fg-img{
  position:absolute;
  top:0;right:0;
  height:100%;
  width:auto;
  max-width:65%;
  object-fit:contain;
  object-position:bottom right;
  z-index:3;
  pointer-events:none;
}

/* Layer 4 — gradient overlay */
.hero-section::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(
    to top,
    rgba(10,4,1,.92) 0%,
    rgba(10,4,1,.50) 28%,
    rgba(10,4,1,.10) 52%,
    transparent      68%);
  z-index:4;pointer-events:none}

/* Layer 5 — text + button, bottom-left inside the hero */
.hero-content{
  position:absolute;
  bottom:80px;
  left:var(--pad);
  z-index:5;
  max-width:480px;
}
.hero-description{
  font-size:var(--fs-desc);font-weight:300;
  color:rgba(255,255,255,.80);line-height:1.75;margin-bottom:28px}

/* container (used in other sections) */
.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--pad)}

/* ══════════════════════════════════════════════
   CATEGORIES
   ══════════════════════════════════════════════ */
.categories-section{background:var(--clr-bg);padding:80px 0 120px}
.section-label{
  font-family:var(--ff);font-size:var(--fs-section-lbl);
  font-weight:var(--fw-heading);color:var(--clr-dark);
  letter-spacing:-.03em;line-height:.9}
.categories-list{display:flex;flex-direction:column;margin-top:48px}
.cat-divider{border:none;border-top:1px solid var(--clr-border);margin:0}
.category-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:36px 0;gap:40px;cursor:pointer;overflow:visible}
.category-item__left{flex:1;min-width:0}

/* Ghost → fill name */
.category-item__name{
  font-family:var(--ff);font-size:var(--fs-cat-name);
  font-weight:var(--fw-heading);line-height:1;letter-spacing:-.05em;
  margin-bottom:12px;display:block;
  color:transparent;-webkit-text-stroke:1.5px rgba(96,54,48,.25);
  background:linear-gradient(to right,var(--clr-cat) 50%,transparent 50%);
  background-size:200% 100%;background-position:100% 0;
  -webkit-background-clip:text;background-clip:text;
  transition:background-position .6s var(--ease),-webkit-text-stroke .5s var(--ease)}
.category-item:hover .category-item__name{
  background-position:0% 0;-webkit-text-stroke:1.5px transparent}
.category-item__desc{
  font-size:var(--fs-desc);color:var(--clr-muted);
  line-height:1.65;margin-bottom:20px;max-width:400px;
  opacity:.65;transition:opacity .4s var(--ease)}
.category-item:hover .category-item__desc{opacity:1}

/* Thumbnail — desktop: hidden → rotates in on hover */
.category-item__thumb{
  flex-shrink:0;
  width:200px;height:200px;aspect-ratio:1/1;
  border-radius:8px;overflow:hidden;
  /* HIDDEN state */
  transform:translate(70px,60px) rotate(20deg) scale(0.4);
  opacity:0;pointer-events:none;transform-origin:bottom right;
  transition:transform .65s var(--ease),opacity .45s ease}
.category-item:hover .category-item__thumb{
  /* VISIBLE state — rests at -8deg tilt */
  transform:translate(0,0) rotate(-8deg) scale(1);
  opacity:1;pointer-events:auto}
.category-item__thumb img{
  width:100%;height:100%;object-fit:cover;
  max-width:none; /* override global reset */
  transition:transform .7s var(--ease)}
.category-item:hover .category-item__thumb img{transform:scale(1.05)}

/* Scroll fade-up */
.animate-fade-up{opacity:0;transform:translateY(28px);
  transition:opacity .65s var(--ease),transform .65s var(--ease);
  transition-delay:var(--delay,0s)}
.animate-fade-up.is-visible{opacity:1;transform:translateY(0)}

/* ── PRODUCTS ── */
.products-section{background:var(--clr-bg);padding:80px 0 120px;border-top:1px solid var(--clr-border)}
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.product-card{display:flex;flex-direction:column}
.product-card__img-wrap{display:block;aspect-ratio:3/4;overflow:hidden;margin-bottom:16px;border-radius:2px}
.product-card__img{width:100%;height:100%;object-fit:cover;max-width:none;transition:transform .6s var(--ease)}
.product-card:hover .product-card__img{transform:scale(1.04)}
.product-card__title{font-size:15px;font-weight:600;margin-bottom:4px}
.product-card__price{font-size:13px;color:var(--clr-muted)}

/* ══════════════════════════════════════════════
   TABLET
   ══════════════════════════════════════════════ */
@media(max-width:1200px){
  :root{--pad:60px;--fs-cat-name:clamp(52px,8vw,120px);--fs-section-lbl:clamp(36px,5vw,60px)}
  .hero-content{bottom:60px;left:60px}
  .category-item__thumb{width:160px;height:160px}
}

/* ══════════════════════════════════════════════
   MOBILE ≤768px
   ══════════════════════════════════════════════ */
@media(max-width:768px){
  :root{
    --pad:20px;--hh:56px;--fs-desc:13px;
    --fs-cat-name:clamp(38px,11vw,68px);
    --fs-section-lbl:clamp(28px,8vw,44px);
    --btn-pad-v:14px;--btn-pad-h:24px}

  /* Header: static, transparent */
  .site-header{
    position:relative !important;top:auto !important;
    padding-top:16px !important;background:transparent !important;
    backdrop-filter:none !important;-webkit-backdrop-filter:none !important;
    box-shadow:none !important}
  .site-header.is-scrolled{
    position:relative !important;padding-top:16px !important;
    background:transparent !important}
  .admin-bar .site-header{top:auto !important}
  .header-inner{grid-template-columns:auto 1fr auto;padding-inline:16px}
  .header-nav--left,.header-nav--right{display:none}
  .site-branding{justify-content:flex-start}
  .hamburger{display:flex}

  /* ─── HERO MOBILE ───
     Only bg image shows. Marquee + fg image are hidden.
     Content sits at bottom inside the section.
     The section height is 100svh — NOT auto.                 */
  .hero-section{
    height:100svh !important;
    min-height:480px !important;
    overflow:hidden !important}
  .hero-bg-img{
    object-position:center center !important}
  .hero-marquee-wrap{display:none !important}
  .hero-fg-img{display:none !important}
  .hero-section::before{
    background:linear-gradient(
      to top,
      rgba(8,3,1,.95) 0%,
      rgba(8,3,1,.70) 20%,
      rgba(8,3,1,.30) 46%,
      transparent     66%) !important}
  .hero-content{
    bottom:44px !important;
    left:20px !important;
    right:20px !important;
    max-width:none !important}
  .hero-description{margin-bottom:20px;max-width:340px}

  /* ─── CATEGORIES MOBILE ───
     Thumbnail always visible, tilted -8deg, 1:1 square.    */
  .categories-section{padding:40px 0 60px}
  .category-item{gap:16px;padding:24px 0;align-items:center;flex-direction:row}
  .category-item__left{flex:1;min-width:0}
  .category-item__thumb{
    flex-shrink:0 !important;
    width:120px !important;height:120px !important;
    aspect-ratio:1/1 !important;border-radius:8px !important;
    overflow:hidden !important;
    transform:rotate(-8deg) !important;
    opacity:1 !important;pointer-events:auto !important;
    transition:none !important;
    box-shadow:0 6px 20px rgba(0,0,0,.20) !important}
  .category-item__thumb img{
    width:100% !important;height:100% !important;
    object-fit:cover !important;transform:none !important;max-width:none !important}

  .products-grid{grid-template-columns:repeat(2,1fr);gap:12px}
}
@media(max-width:400px){
  .category-item__thumb{width:90px !important;height:90px !important}
  .hero-content{bottom:32px !important}}
@media screen and (max-width:782px){.admin-bar .site-header{top:auto !important}}
