/* =========================================================
   MODA FINA — Boutique de Autor
   Editorial fashion · off-white + ink + walnut · Bodoni Moda
   ========================================================= */

:root{
  --white:    #f5efe1;       /* warm off-white */
  --white-2:  #ebe2cf;       /* deeper sand */
  --bone:     #ddd1ba;
  --ink:      #16110b;       /* deep warm black, higher contrast */
  --ink-2:    #2a221a;
  --ink-soft: #2d251c;       /* much darker for body text legibility */
  --mute:     #6a5d4a;       /* darker mute for better contrast */

  --walnut:   #4a2f18;       /* deeper walnut accent */
  --camel:    #8a6d44;       /* warm camel */
  --gold:     #b8945e;       /* deeper champagne */

  --line:     rgba(22,17,11,.14);
  --line-2:   rgba(22,17,11,.08);

  --display:  'Cormorant Garamond', 'Times New Roman', serif;
  --sans:     'Inter', -apple-system, sans-serif;

  --max:  1480px;
  --pad:  clamp(20px, 5vw, 80px);
  --pad-y: clamp(80px, 12vw, 180px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--white);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

/* ===== Common ===== */
.kicker{
  display:inline-block;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--walnut);
  font-weight:600;
}
.kicker--light{color:var(--gold)}

.display{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(46px, 6.4vw, 110px);
  line-height:1;
  letter-spacing:-.015em;
  color:var(--ink);
}
.display em{
  font-style:italic;
  font-weight:500;
  color:var(--walnut);
}
.display--light{color:var(--white)}
.display--light em{color:var(--gold)}

/* ============== ANNOUNCEMENT ============== */
.ann{
  background:var(--ink);
  color:var(--white);
  padding:11px 0;
  overflow:hidden;
  white-space:nowrap;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  border-bottom:1px solid rgba(246,241,230,.08);
}
.ann__track{
  display:inline-flex;
  gap:32px;
  align-items:center;
  animation:slideAnn 36s linear infinite;
  padding-left:32px;
}
.ann__track i{color:var(--gold);font-style:normal;font-size:6px}
@keyframes slideAnn{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============== NAV ============== */
.nav{
  position:fixed;
  top:34px; left:0; right:0;
  z-index:50;
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:32px;
  padding:14px clamp(20px, 4vw, 50px);
  color:var(--white);
  transition:background .35s ease, padding .35s ease, top .35s ease, transform .4s ease, color .35s ease, border-color .35s ease;
}
.nav--solid{
  background:rgba(246,241,230,.96);
  backdrop-filter:blur(16px);
  color:var(--ink);
  border-bottom:1px solid var(--line-2);
  top:0;
}
.nav--hide{transform:translateY(-100%)}

/* Toggle (hamburger) */
.nav__toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  width:34px;height:34px;
  justify-content:center;align-items:center;
  background:none;border:0;cursor:pointer;color:inherit;
}
.nav__toggle span{
  display:block;width:22px;height:1px;
  background:currentColor;
  transition:transform .35s ease, opacity .25s;
}
body.mob-open .nav__toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.mob-open .nav__toggle span:nth-child(2){opacity:0}
body.mob-open .nav__toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Menu */
.nav__menu{
  display:flex;
  gap:30px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.nav__menu a{
  padding:8px 0;
  position:relative;
  color:inherit;
  transition:color .25s ease;
}
.nav__menu a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:2px;
  height:1px;
  background:currentColor;
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .35s ease;
}
.nav__menu a:hover::after{transform:scaleX(1)}

/* Brand */
.nav__brand{
  justify-self:center;
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(22px, 2.4vw, 30px);
  letter-spacing:-.005em;
  line-height:1;
  display:inline-flex;
  align-items:baseline;
  gap:.18em;
  color:inherit;
  white-space:nowrap;
}
.nav__brand em{
  font-style:italic;
  font-weight:400;
  color:var(--gold);
  transition:color .35s ease;
}
.nav--solid .nav__brand em{color:var(--walnut)}
.nav__dot{
  display:inline-block;
  font-style:normal;
  color:var(--gold);
  margin-left:-.05em;
  transition:color .35s ease;
}
.nav--solid .nav__dot{color:var(--walnut)}

/* Tools */
.nav__tools{
  display:flex;
  align-items:center;
  gap:6px;
  justify-self:end;
}
.nav__tool{
  width:42px;height:42px;
  display:grid;place-items:center;
  background:transparent;
  border:0;
  color:inherit;
  cursor:pointer;
  border-radius:50%;
  position:relative;
  transition:background .25s ease, color .25s ease, transform .25s ease;
}
.nav__tool:hover{background:rgba(20,17,13,.06);color:var(--walnut)}
.nav:not(.nav--solid) .nav__tool:hover{background:rgba(246,241,230,.16);color:var(--gold)}
.nav__tool svg{display:block;stroke:currentColor}

/* Bag badge */
.nav__bag{position:relative}
.nav__badge{
  position:absolute;
  top:6px;right:6px;
  min-width:18px;height:18px;padding:0 5px;
  background:var(--walnut);
  color:var(--white);
  border-radius:999px;
  font-family:var(--sans);
  font-size:10px;
  font-weight:500;
  letter-spacing:0;
  display:grid;place-items:center;
  line-height:1;
  transition:transform .25s ease, background .25s ease;
  border:1px solid var(--white);
}
.nav:not(.nav--solid) .nav__badge{
  background:var(--gold);
  color:var(--ink);
  border-color:var(--ink);
}
.nav__badge.bump{
  animation:bump .45s ease;
}
@keyframes bump{
  0%{transform:scale(1)}
  40%{transform:scale(1.4)}
  100%{transform:scale(1)}
}

@media(max-width:1024px){
  .nav{
    grid-template-columns:auto 1fr auto;
    gap:8px;
    padding:12px 16px;
    top:34px;
  }
  .nav--solid{padding:10px 16px;top:0}
  .nav__menu{display:none}
  .nav__tool--account{display:none}
  .nav__toggle{display:flex}
  .nav__brand{justify-self:center;font-size:20px}
  .nav__tools{gap:0}
  .nav__tool{width:38px;height:38px}
}
@media(max-width:480px){
  .nav{padding:10px 12px;gap:4px}
  .nav__brand{font-size:18px}
  .nav__tool{width:36px;height:36px}
  .nav__tool svg{width:18px;height:18px}
  .nav__badge{top:4px;right:4px;min-width:16px;height:16px;font-size:9px}
  .nav__toggle{width:30px;height:30px}
  .nav__toggle span{width:20px}
}
@media(max-width:340px){
  .nav__brand{font-size:16px}
  .nav__tool{width:32px;height:32px}
}

/* ============== SEARCH OVERLAY ============== */
.search{
  position:fixed;
  top:0;left:0;right:0;
  z-index:55;
  background:var(--white);
  border-bottom:1px solid var(--line);
  padding:30px clamp(20px, 4vw, 50px) 36px;
  transform:translateY(-100%);
  visibility:hidden;
  transition:transform .4s cubic-bezier(.5,.05,.2,1), visibility 0s linear .4s;
}
body.search-open .search{
  transform:translateY(0);
  visibility:visible;
  transition:transform .4s cubic-bezier(.5,.05,.2,1);
}
.search__inner{
  max-width:880px;
  margin:0 auto;
  position:relative;
}
.search__inner .kicker{display:block;margin-bottom:14px}
.search__form{
  display:flex;
  align-items:center;
  gap:14px;
  border-bottom:1px solid var(--ink);
  padding:6px 0 8px;
}
.search__form input{
  flex:1;
  background:transparent;
  border:0;
  outline:none;
  font-family:var(--display);
  font-style:italic;
  font-size:clamp(22px, 3.4vw, 38px);
  font-weight:400;
  color:var(--ink);
  padding:6px 0;
}
.search__form input::placeholder{color:var(--mute);opacity:.7}
.search__form button{
  background:transparent;
  border:0;
  color:var(--ink);
  cursor:pointer;
  display:grid;place-items:center;
  width:42px;height:42px;
  transition:color .3s;
}
.search__form button:hover{color:var(--walnut)}
.search__suggest{
  margin-top:24px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.search__suggest > span{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--mute);
}
.search__chips{
  display:flex;flex-wrap:wrap;gap:8px;
}
.search__chips button{
  padding:8px 16px;
  border:1px solid var(--line);
  background:transparent;
  color:var(--ink-soft);
  border-radius:999px;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .25s;
}
.search__chips button:hover{
  background:var(--ink);
  color:var(--white);
  border-color:var(--ink);
  transform:translateY(-1px);
}
.search__close{
  position:absolute;
  top:-12px;right:0;
  width:38px;height:38px;
  background:transparent;
  border:1px solid var(--line);
  border-radius:50%;
  color:var(--ink);
  cursor:pointer;
  display:grid;place-items:center;
  transition:all .3s;
}
.search__close:hover{background:var(--ink);color:var(--white);border-color:var(--ink);transform:rotate(90deg)}

@media(max-width:560px){
  .search{padding:20px 18px 24px}
  .search__close{top:-2px;right:-4px}
}

/* mobile menu overlay */
.mob-menu{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:var(--ink);
  color:var(--white);
  z-index:40;
  display:flex;flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:14px;
  padding:120px var(--pad) 60px;
  font-family:var(--display);
  font-size:42px;
  font-weight:400;
  opacity:0;
  visibility:hidden;
  transition:opacity .35s ease, visibility 0s .35s;
}
.mob-menu a{
  width:100%;
  padding:10px 0;
  border-bottom:1px solid rgba(246,241,230,.12);
  font-style:italic;
  color:var(--white);
  transition:padding-left .25s, color .25s;
}
.mob-menu a:hover{padding-left:14px;color:var(--gold)}
.mob-menu__sub{
  margin-top:32px;
  display:flex;flex-direction:column;
  gap:10px;
  width:100%;
}
.mob-menu__sub a{
  font-family:var(--sans);
  font-size:13px;
  font-style:normal;
  letter-spacing:.22em;
  text-transform:uppercase;
  border:0;
  padding:6px 0;
  color:rgba(246,241,230,.7);
}
.mob-menu__sub a:hover{color:var(--gold);padding-left:0}
body.mob-open .mob-menu{
  opacity:1;visibility:visible;
  transition:opacity .35s ease;
}
body.mob-open{overflow:hidden}
@media(min-width:1025px){.mob-menu{display:none}}

/* ============== HERO — full-bleed photo + solid text panel ============== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  padding:140px var(--pad) 70px;
  overflow:hidden;
}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__photo{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1539109136881-3be0616acf4b?w=2400&q=92') center 30%/cover no-repeat;
  filter:saturate(.96) contrast(1.04);
  animation:slowZoom 28s ease-out forwards;
}
@keyframes slowZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero__veil{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(20,17,13,.18) 0%, rgba(20,17,13,0) 30%, rgba(20,17,13,.35) 100%);
}

.hero__inner{
  position:relative;
  z-index:1;
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  opacity:0;transform:translateY(20px);
  transition:all 1s ease .2s;
}
.hero__inner.in{opacity:1;transform:none}

/* Solid text panel — high contrast, photo stays clean */
.hero__panel{
  background:var(--white);
  color:var(--ink);
  max-width:540px;
  padding:42px 44px 38px;
  display:flex;flex-direction:column;
  gap:28px;
  box-shadow:0 30px 80px -30px rgba(20,17,13,.5);
}

.hero__edition{
  display:inline-block;
  font-size:11px;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--walnut);
  font-weight:500;
  position:relative;
  padding-left:30px;
}
.hero__edition::before{
  content:"";
  position:absolute;
  left:0;top:50%;
  width:18px;height:1px;
  background:var(--walnut);
}

.hero__display{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(38px, 5.4vw, 76px);
  line-height:.98;
  letter-spacing:-.022em;
  color:var(--ink);
  margin:0;
}
.hero__display em{
  font-style:italic;
  font-weight:500;
  color:var(--walnut);
}

.hero__cta{
  align-self:flex-start;
  display:inline-flex;align-items:center;
  gap:14px;
  padding:6px 28px 6px 6px;
  background:var(--ink);
  color:var(--white);
  border-radius:999px;
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  font-weight:500;
  transition:all .35s;
}
.hero__cta-circle{
  width:42px;height:42px;
  background:var(--gold);
  color:var(--ink);
  border-radius:50%;
  display:grid;place-items:center;
  transition:transform .4s ease;
}
.hero__cta:hover{transform:translateY(-2px);box-shadow:0 16px 36px -16px rgba(20,17,13,.45)}
.hero__cta:hover .hero__cta-circle{transform:rotate(-45deg)}

@media(max-width:780px){
  .hero{padding:110px 18px 36px;align-items:flex-end;min-height:90vh}
  .hero__panel{
    padding:28px 26px 26px;
    gap:22px;
    max-width:100%;
  }
  .hero__display{font-size:clamp(32px, 8.4vw, 50px)}
}


/* ============== EDIT ============== */
.edit{
  padding:var(--pad-y) var(--pad);
  background:var(--white);
  max-width:1180px;
  margin:0 auto;
}
.edit__head{
  display:grid;
  grid-template-columns:auto 1.4fr 1fr;
  gap:60px;
  align-items:end;
  margin-bottom:80px;
  padding-bottom:40px;
  border-bottom:1px solid var(--line);
  opacity:0;transform:translateY(20px);
  transition:all 1s ease;
}
.edit__head.in{opacity:1;transform:none}
.edit__head .kicker{align-self:start}
.edit__intro{
  font-family:var(--sans);
  font-size:15px;
  line-height:1.65;
  color:var(--ink-soft);
  font-weight:400;
  letter-spacing:.005em;
}

.edit__grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:clamp(20px, 2.4vw, 36px);
}

.look{
  opacity:0;transform:translateY(30px);
  transition:all .9s ease;
  display:flex;flex-direction:column;
}
.look.in{opacity:1;transform:none}
.look--feat .look__meta{margin-top:auto}

.look__photo{
  aspect-ratio:3/4;
  background-size:cover;
  background-position:center;
  filter:saturate(.96) contrast(1.04);
  transition:transform .8s ease;
  margin-bottom:18px;
}
.look:hover .look__photo{transform:scale(1.015)}
.look__photo--1{background-image:url('https://images.unsplash.com/photo-1483985988355-763728e1935b?w=1400&q=92')}
.look__photo--2{background-image:url('https://images.unsplash.com/photo-1521577352947-9bb58764b69a?w=1400&q=92')}
.look__photo--3{background-image:url('https://images.unsplash.com/photo-1475180098004-ca77a66827be?w=1400&q=92')}
.look__photo--4{background-image:url('https://images.unsplash.com/photo-1488426862026-3ee34a7d66df?w=1400&q=92')}

.look__meta{
  display:flex;flex-direction:column;
  gap:6px;
  padding-top:12px;
  border-top:1px solid var(--line);
}
.look__meta > div{display:flex;flex-direction:column;gap:4px}
.look__meta--dark{
  background:var(--ink);
  color:var(--white);
  padding:18px;
  border:0;
  align-self:stretch;
  gap:14px;
}
.look__num{
  display:block;
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--walnut);
  margin-bottom:4px;
}
.look__meta--dark .look__num{color:var(--gold)}
.look__name{
  font-family:var(--display);
  font-weight:500;
  font-size:20px;
  line-height:1.05;
  letter-spacing:-.005em;
  color:var(--ink);
  margin-bottom:0;
}
.look__name em{font-style:italic;color:var(--walnut)}
.look__meta--dark .look__name{color:var(--white)}
.look__meta--dark .look__name em{color:var(--gold)}
.look__cat{
  font-size:11px;
  color:var(--mute);
  letter-spacing:.02em;
}
.look__meta--dark .look__cat{color:rgba(246,241,230,.65)}
.look__price{
  font-family:var(--display);
  font-style:italic;
  font-size:17px;
  color:var(--walnut);
  white-space:nowrap;
  font-weight:500;
  margin-top:6px;
}
.look__meta--dark .look__price{color:var(--gold)}
.add-btn{margin-top:12px}
.look .add-btn{font-size:10px;padding:11px 12px;letter-spacing:.16em}

.edit__more{
  display:inline-flex;
  align-items:center;
  gap:14px;
  margin-top:80px;
  font-family:var(--display);
  font-style:italic;
  font-size:24px;
  color:var(--ink);
  border-bottom:1px solid var(--ink);
  padding-bottom:8px;
  transition:all .35s;
}
.edit__more-arrow{font-style:normal;transition:transform .35s}
.edit__more:hover{color:var(--walnut);border-color:var(--walnut)}
.edit__more:hover .edit__more-arrow{transform:translateX(8px)}

@media(max-width:980px){
  .edit__head{grid-template-columns:1fr;gap:24px}
  .edit__grid{grid-template-columns:repeat(3, 1fr);gap:20px}
}
@media(max-width:680px){
  .edit__grid{grid-template-columns:repeat(2, 1fr);gap:14px}
  .look__name{font-size:17px}
  .look__price{font-size:15px}
}
@media(max-width:380px){
  .edit__grid{grid-template-columns:1fr;gap:28px}
}

/* ============== BAND ============== */
.band{
  position:relative;
  min-height:80vh;
  overflow:hidden;
  display:flex;align-items:center;
  justify-content:center;
  padding:80px var(--pad);
}
.band__photo{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1485518882345-15568b007407?w=2400&q=92') center/cover no-repeat;
  filter:saturate(.9) contrast(1.05);
  transform:scale(1);
  transition:transform 1.5s ease;
}
.band.in .band__photo{transform:scale(1.04)}
.band::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(20,17,13,.4) 0%, rgba(20,17,13,.5) 100%);
  z-index:0;
  pointer-events:none;
}

/* Solid card with the quote — no transparency, real readability */
.band__overlay{
  position:relative;
  z-index:1;
  background:var(--ink);
  color:var(--white);
  text-align:left;
  padding:48px 52px;
  max-width:680px;
  border:1px solid rgba(246,241,230,.08);
  box-shadow:0 30px 80px -30px rgba(20,17,13,.6);
}
.band__quote{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(22px, 2.6vw, 36px);
  line-height:1.35;
  letter-spacing:-.005em;
  color:var(--white);
  font-style:italic;
  margin:0;
}
.band__quote em{
  color:var(--gold);
  font-style:italic;
  font-weight:500;
}
.band__caption{
  position:absolute;
  bottom:30px;left:30px;
  z-index:2;
  display:flex;flex-direction:column;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(246,241,230,.85);
  gap:2px;
  text-shadow:0 1px 8px rgba(20,17,13,.6);
}

@media(max-width:780px){
  .band{min-height:60vh;padding:60px 18px}
  .band__overlay{padding:32px 28px}
  .band__caption{font-size:10px;left:14px;bottom:14px}
}

/* ============== CATEGORIAS ============== */
.cats{
  padding:var(--pad-y) var(--pad);
  background:var(--white);
  max-width:var(--max);
  margin:0 auto;
}
.cats__head{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:50px;
  margin-bottom:70px;
  padding-bottom:30px;
  border-bottom:1px solid var(--line);
  align-items:end;
  opacity:0;transform:translateY(20px);
  transition:all 1s ease;
}
.cats__head.in{opacity:1;transform:none}
.cats__grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
.cat{
  position:relative;
  display:block;
  background:var(--white-2);
  overflow:hidden;
  aspect-ratio:3/4;
  opacity:0;transform:translateY(20px);
  transition:all .9s ease;
}
.cat.in{opacity:1;transform:none}
.cat__img{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  filter:saturate(.96) contrast(1.04);
  transition:transform .8s ease, filter .6s ease;
}
.cat:hover .cat__img{transform:scale(1.04);filter:saturate(.96) contrast(1.04) brightness(.85)}
.cat::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(20,17,13,.7) 100%);
  z-index:1;
  pointer-events:none;
}
.cat--1 .cat__img{background-image:url('https://images.unsplash.com/photo-1483985988355-763728e1935b?w=1200&q=92')}
.cat--2 .cat__img{background-image:url('https://images.unsplash.com/photo-1556905055-8f358a7a47b2?w=1200&q=92')}
.cat--3 .cat__img{background-image:url('https://images.unsplash.com/photo-1521577352947-9bb58764b69a?w=1200&q=92')}
.cat--4 .cat__img{background-image:url('https://images.unsplash.com/photo-1492707892479-7bc8d5a4ee93?w=1200&q=92')}

.cat__body{
  position:absolute;
  bottom:0;left:0;right:0;
  z-index:2;
  padding:32px;
  color:var(--white);
}
.cat__body h3{
  font-family:var(--display);
  font-weight:500;
  font-size:34px;
  letter-spacing:-.01em;
  margin-bottom:8px;
}
.cat__body p{
  font-family:var(--sans);
  font-size:13px;
  line-height:1.5;
  color:rgba(246,241,230,.92);
  margin-bottom:18px;
  font-weight:400;
}
.cat__cta{
  display:inline-block;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  border-bottom:1px solid var(--gold);
  padding-bottom:4px;
  transition:all .3s;
}
.cat:hover .cat__cta{padding-left:6px;color:var(--white);border-color:var(--white)}

@media(max-width:980px){
  .cats__grid{grid-template-columns:repeat(2, 1fr)}
  .cats__head{grid-template-columns:1fr;gap:20px}
}
/* Carousel index (only visible in mobile carousel mode) */
.cats__dots,
.cats__counter{display:none}

@media(max-width:780px){
  /* Carrossel lateral em mobile */
  .cats__grid{
    display:flex;
    grid-template-columns:none;
    gap:14px;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding:4px 18px 14px;
    margin:0 -18px;
  }
  .cats__grid::-webkit-scrollbar{display:none}
  .cat{
    flex:0 0 78%;
    scroll-snap-align:start;
    aspect-ratio:3/4;
  }
  .cats__grid::after{
    content:"";
    flex:0 0 4px;
  }

  /* Dots */
  .cats__dots{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:10px;
    margin-top:24px;
  }
  .cdot{
    width:8px;height:8px;
    border:0;
    background:transparent;
    border:1px solid var(--ink);
    border-radius:50%;
    cursor:pointer;
    padding:0;
    transition:all .35s ease;
  }
  .cdot.is-on{
    background:var(--ink);
    transform:scale(1.4);
  }

  /* Numeric counter */
  .cats__counter{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:14px;
    margin-top:14px;
    font-family:var(--display);
    font-style:italic;
    font-size:14px;
    color:var(--mute);
    letter-spacing:.04em;
  }
  .cats__counter #catsIdx{color:var(--ink);font-weight:500}
  .cats__counter-rule{
    width:60px;height:1px;
    background:var(--line);
    display:inline-block;
  }
}
@media(max-width:480px){
  .cat{flex-basis:82%}
  .cat__body{padding:24px}
  .cat__body h3{font-size:28px}
}

/* ============== ATELIER ============== */
.atelier{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  background:var(--ink);
  color:var(--white);
}
.atelier__photo{
  background:url('https://images.unsplash.com/photo-1490481651871-ab68de25d43d?w=1600&q=92') center/cover no-repeat;
  min-height:90vh;
  filter:saturate(.92) contrast(1.04);
  opacity:0;
  transition:opacity 1s ease;
}
.atelier__photo.in{opacity:1}
.atelier__body{
  padding:var(--pad-y) var(--pad);
  display:flex;flex-direction:column;
  justify-content:center;
  max-width:720px;
  opacity:0;transform:translateX(20px);
  transition:all 1s ease .15s;
}
.atelier__body.in{opacity:1;transform:none}
.atelier__body .kicker{color:var(--gold);margin-bottom:24px}
.atelier__body .display{margin-bottom:36px}
.atelier__body p{
  font-family:var(--sans);
  font-size:15px;
  line-height:1.75;
  color:rgba(246,241,230,.85);
  margin-bottom:14px;
  max-width:540px;
  font-weight:400;
  letter-spacing:.005em;
}
.atelier__stats{
  display:flex;
  gap:48px;
  margin:48px 0 40px;
  padding:32px 0;
  border-top:1px solid rgba(246,241,230,.16);
  border-bottom:1px solid rgba(246,241,230,.16);
}
.atelier__stats > div{display:flex;flex-direction:column;gap:6px}
.atelier__stats strong{
  font-family:var(--display);
  font-weight:500;
  font-size:42px;
  color:var(--gold);
  letter-spacing:-.015em;
  font-style:italic;
}
.atelier__stats span{
  font-size:11px;
  letter-spacing:.22em;
  color:rgba(246,241,230,.6);
  text-transform:uppercase;
  line-height:1.4;
}
.atelier__cta{
  display:inline-flex;align-items:center;
  gap:18px;
  padding:18px 32px;
  border:1px solid var(--white);
  border-radius:999px;
  align-self:flex-start;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  transition:all .35s;
}
.atelier__cta:hover{
  background:var(--gold);
  border-color:var(--gold);
  color:var(--ink);
  transform:translateY(-2px);
}
.atelier__cta span:last-child{font-size:18px}

@media(max-width:980px){
  .atelier{grid-template-columns:1fr}
  .atelier__photo{min-height:60vh}
  .atelier__stats{gap:24px}
  .atelier__stats strong{font-size:30px}
}

/* ============== SERVICES ============== */
.services{
  padding:var(--pad-y) var(--pad);
  background:var(--white-2);
}
.services__head{
  max-width:var(--max);
  margin:0 auto 80px;
  text-align:center;
}
.services__head .kicker{display:block;margin-bottom:24px}
.services__grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:60px;
}
.srv{
  display:flex;flex-direction:column;
  padding-top:30px;
  border-top:1px solid var(--line);
  opacity:0;transform:translateY(20px);
  transition:all .9s ease;
}
.srv.in{opacity:1;transform:none}
.srv__num{
  font-family:var(--display);
  font-style:italic;
  font-size:18px;
  color:var(--walnut);
  margin-bottom:24px;
  font-weight:500;
}
.srv h3{
  font-family:var(--display);
  font-weight:500;
  font-size:32px;
  line-height:1.05;
  letter-spacing:-.01em;
  color:var(--ink);
  margin-bottom:20px;
}
.srv p{
  font-family:var(--sans);
  font-size:15px;
  line-height:1.7;
  color:var(--ink-soft);
  margin-bottom:24px;
  letter-spacing:.005em;
  flex:1;
  font-weight:400;
}
.srv__sub{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--walnut);
  padding-top:18px;
  border-top:1px solid var(--line);
}
@media(max-width:880px){
  .services__grid{grid-template-columns:1fr;gap:30px}
}

/* ============== NEWSLETTER ============== */
.news{
  padding:var(--pad-y) var(--pad);
  background:var(--ink);
  color:var(--white);
  position:relative;
  overflow:hidden;
}
.news::before{
  content:"";
  position:absolute;
  top:-200px;right:-200px;
  width:520px;height:520px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(200,168,117,.18), transparent 70%);
  pointer-events:none;
}
.news__inner{
  max-width:880px;
  margin:0 auto;
  text-align:center;
  position:relative;
  opacity:0;transform:translateY(20px);
  transition:all 1s ease;
}
.news__inner.in{opacity:1;transform:none}
.news__inner .kicker{display:block;margin-bottom:30px}
.news__inner .display{margin-bottom:30px}
.news__inner > p{
  font-family:var(--sans);
  font-size:15px;
  line-height:1.7;
  color:rgba(246,241,230,.85);
  max-width:680px;
  letter-spacing:.005em;
  margin:0 auto 50px;
  font-weight:400;
}

.news__form{
  display:flex;
  gap:14px;
  max-width:540px;
  margin:0 auto;
  padding-bottom:14px;
  border-bottom:1px solid rgba(246,241,230,.3);
}
.news__form input{
  flex:1;
  background:transparent;
  border:0;
  outline:none;
  color:var(--white);
  font-family:var(--display);
  font-style:italic;
  font-size:18px;
  padding:14px 0;
  font-weight:400;
}
.news__form input::placeholder{color:rgba(246,241,230,.4)}
.news__form button{
  display:inline-flex;align-items:center;
  gap:10px;
  padding:10px 20px;
  background:transparent;
  color:var(--white);
  border:1px solid rgba(246,241,230,.5);
  border-radius:999px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .35s;
}
.news__form button:hover{
  background:var(--gold);color:var(--ink);
  border-color:var(--gold);
}
.news__ok{
  margin-top:24px;
  font-family:var(--display);
  font-style:italic;
  color:var(--gold);
  font-size:16px;
}
.news__fine{
  margin-top:32px !important;
  font-family:var(--sans) !important;
  font-size:11px !important;
  letter-spacing:.18em !important;
  text-transform:uppercase;
  color:rgba(246,241,230,.45) !important;
}

@media(max-width:560px){
  .news__form{flex-direction:column;gap:18px}
  .news__form button{width:100%;justify-content:center;padding:14px}
}

/* ============== LOJAS ============== */
.shops{
  padding:var(--pad-y) var(--pad);
  background:var(--white);
}
.shops__head{
  max-width:var(--max);
  margin:0 auto 70px;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:50px;
  align-items:end;
  padding-bottom:30px;
  border-bottom:1px solid var(--line);
}
.shops__grid{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
}
.shop{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:center;
  background:var(--white-2);
  overflow:hidden;
  opacity:0;transform:translateY(20px);
  transition:all .9s ease;
}
.shop.in{opacity:1;transform:none}
.shop__photo{
  aspect-ratio:4/5;
  background-size:cover;
  background-position:center;
  filter:saturate(.95) contrast(1.04);
}
.shop__photo--sp{background-image:url('https://images.unsplash.com/photo-1567401893414-76b7b1e5a7a5?w=1200&q=92'),linear-gradient(135deg,#2a221c,#5a3a22)}
.shop__photo--rj{background-image:url('https://images.unsplash.com/photo-1490481651871-ab68de25d43d?w=1200&q=92'),linear-gradient(135deg,#2a221c,#9c7a4f)}

.shop__body{
  padding:36px 32px;
  display:flex;flex-direction:column;
  gap:14px;
}
.shop__city{
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--walnut);
  font-weight:500;
}
.shop__body h3{
  font-family:var(--display);
  font-weight:500;
  font-style:italic;
  font-size:42px;
  letter-spacing:-.015em;
  color:var(--ink);
  line-height:.95;
  margin-bottom:6px;
}
.shop__addr{
  font-size:14px;
  line-height:1.6;
  color:var(--ink-soft);
  font-family:var(--sans);
  font-weight:400;
  letter-spacing:.005em;
}
.shop__hours{
  list-style:none;
  border-top:1px solid var(--line);
  padding-top:14px;
  margin-top:6px;
  font-size:13px;
  display:flex;flex-direction:column;
  gap:4px;
}
.shop__hours li{
  display:flex;justify-content:space-between;
  color:var(--ink-soft);
  letter-spacing:.04em;
}
.shop__hours span:first-child{color:var(--walnut);text-transform:uppercase;font-size:10px;letter-spacing:.22em}
.shop__link{
  margin-top:14px;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--walnut);
  border-bottom:1px solid var(--walnut);
  padding-bottom:4px;
  align-self:flex-start;
  transition:all .3s;
}
.shop__link em{font-style:normal;margin-left:4px;display:inline-block;transition:transform .3s}
.shop__link:hover em{transform:translate(2px, -2px)}

@media(max-width:980px){
  .shops__grid{grid-template-columns:1fr}
  .shops__head{grid-template-columns:1fr;gap:20px}
}
@media(max-width:560px){
  .shop{grid-template-columns:1fr;gap:0}
}

/* ============== FOOTER ============== */
.foot{
  background:var(--ink);
  color:var(--white);
  padding:80px var(--pad) 32px;
  position:relative;
  overflow:hidden;
}
.foot__big{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(80px, 18vw, 280px);
  line-height:.85;
  letter-spacing:-.04em;
  color:var(--white);
  text-align:center;
  margin-bottom:60px;
}
.foot__big em{font-style:italic;color:var(--gold);font-weight:400}

.foot__cols{
  max-width:var(--max);
  margin:0 auto 50px;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(246,241,230,.12);
}
.foot__cols h4{
  font-size:11px;
  letter-spacing:.28em;
  color:var(--gold);
  text-transform:uppercase;
  margin-bottom:20px;
  font-weight:500;
}
.foot__cols a{
  display:block;
  font-family:var(--display);
  font-size:15px;
  color:rgba(246,241,230,.7);
  padding:5px 0;
  transition:all .3s;
}
.foot__cols a:hover{color:var(--gold);transform:translateX(3px)}

.foot__base{
  max-width:var(--max);
  margin:0 auto;
  display:flex;justify-content:space-between;
  flex-wrap:wrap;
  gap:14px;
  font-size:11px;
  letter-spacing:.18em;
  color:rgba(246,241,230,.45);
  text-transform:uppercase;
}

@media(max-width:880px){
  .foot__cols{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:560px){
  .foot__cols{grid-template-columns:1fr}
}

/* ============== ADD-TO-CART BUTTON ============== */
.add-btn{
  margin-top:18px;
  display:inline-flex;align-items:center;justify-content:center;
  width:100%;
  padding:14px 18px;
  background:transparent;
  color:var(--ink);
  border:1px solid var(--ink);
  border-radius:999px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  cursor:pointer;
  transition:all .35s ease;
}
.add-btn:hover{
  background:var(--ink);
  color:var(--white);
  transform:translateY(-2px);
}
.add-btn--mini{padding:11px 14px;font-size:10px;letter-spacing:.18em;margin-top:14px}
.add-btn--dark{
  border-color:var(--gold);
  color:var(--gold);
}
.add-btn--dark:hover{
  background:var(--gold);
  color:var(--ink);
}

/* ============== SHOP GRID / Loja ============== */
.shop-grid{
  padding:var(--pad-y) var(--pad);
  background:var(--white-2);
  max-width:100vw;
  overflow-x:hidden;
}
.shop-grid__head{
  max-width:var(--max);
  margin:0 auto 60px;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:40px;
  flex-wrap:wrap;
  padding-bottom:30px;
  border-bottom:1px solid var(--line);
  opacity:0;transform:translateY(20px);
  transition:all 1s ease;
}
.shop-grid__head.in{opacity:1;transform:none}
.shop-grid__title .kicker{display:block;margin-bottom:14px}

.shop-grid__lead{
  max-width:440px;
  font-family:var(--sans);
  font-size:14px;
  line-height:1.65;
  color:var(--ink-soft);
  letter-spacing:.005em;
}

.shop-grid__items{
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:32px;
}

.prod{
  display:flex;flex-direction:column;
  background:var(--white);
  padding:14px;
  opacity:0;transform:translateY(20px);
  transition:opacity .8s ease, transform .8s ease, box-shadow .35s ease;
}
.prod.in{opacity:1;transform:none}
.prod.hidden{display:none}
.prod:hover{box-shadow:0 22px 40px -28px rgba(20,17,13,.25)}
.prod__photo{
  aspect-ratio:4/5;
  background-size:cover;
  background-position:center;
  filter:saturate(.96) contrast(1.04);
  transition:transform .8s ease;
  margin-bottom:16px;
}
.prod:hover .prod__photo{transform:scale(1.02)}
.prod__info{
  display:flex;flex-direction:column;
  gap:4px;
  padding:0 4px;
  flex:1;
}
.prod__cat{
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--walnut);
  margin-bottom:2px;
}
.prod__info h3{
  font-family:var(--display);
  font-weight:500;
  font-size:22px;
  line-height:1.1;
  letter-spacing:-.005em;
  color:var(--ink);
}
.prod__price{
  font-family:var(--display);
  font-style:italic;
  font-size:18px;
  color:var(--walnut);
  font-weight:500;
  margin-top:4px;
}
.prod .add-btn{margin-top:16px}

@media(max-width:1100px){
  .shop-grid__items{grid-template-columns:repeat(3, 1fr);gap:24px}
}
@media(max-width:780px){
  .shop-grid__items{grid-template-columns:repeat(2, 1fr);gap:16px}
  .shop-grid__head{flex-direction:column;align-items:flex-start;gap:18px;padding-bottom:20px}
  .shop-grid__lead{font-size:13.5px}
}
@media(max-width:480px){
  .prod{padding:8px}
  .prod__info h3{font-size:15px;line-height:1.15}
  .prod__price{font-size:14px}
  .prod__cat{font-size:9px}
  .prod .add-btn--mini{padding:9px 8px;font-size:9px;letter-spacing:.12em}
}
@media(max-width:380px){
  .shop-grid__items{grid-template-columns:1fr;gap:18px}
  .shop-grid__items .prod__photo{aspect-ratio:5/4}
}

/* ============== CART DRAWER ============== */
.cart-overlay{
  position:fixed;inset:0;
  background:rgba(20,17,13,.55);
  backdrop-filter:blur(2px);
  z-index:60;
  opacity:0;
  visibility:hidden;
  transition:opacity .35s ease, visibility 0s linear .35s;
}
body.cart-open .cart-overlay{
  opacity:1;visibility:visible;
  transition:opacity .35s ease;
}
.cart{
  position:fixed;
  top:0;right:0;bottom:0;
  width:min(440px, 92vw);
  background:var(--white);
  z-index:61;
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .4s cubic-bezier(.5,.05,.2,1);
  box-shadow:-30px 0 80px -40px rgba(20,17,13,.4);
}
body.cart-open .cart{transform:translateX(0)}
.cart__head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  padding:30px 28px 20px;
  border-bottom:1px solid var(--line);
}
.cart__head .kicker{display:block;margin-bottom:6px}
.cart__title{
  font-family:var(--display);
  font-weight:500;
  font-size:32px;
  letter-spacing:-.01em;
  color:var(--ink);
}
.cart__title em{font-style:italic;color:var(--walnut);font-size:.65em}
.cart__close{
  width:38px;height:38px;
  display:grid;place-items:center;
  border:1px solid var(--line);
  border-radius:50%;
  color:var(--ink);
  cursor:pointer;
  transition:all .3s;
}
.cart__close:hover{background:var(--ink);color:var(--white);border-color:var(--ink);transform:rotate(90deg)}

.cart__items{
  flex:1;
  overflow-y:auto;
  padding:18px 28px;
  display:flex;
  flex-direction:column;
  gap:20px;
}
.cart__items[hidden]{display:none}
.cart__items::-webkit-scrollbar{width:4px}
.cart__items::-webkit-scrollbar-thumb{background:var(--line);border-radius:2px}

.ci{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:16px;
  padding-bottom:18px;
  border-bottom:1px solid var(--line);
}
.ci__photo{
  width:80px;height:100px;
  background-size:cover;
  background-position:center;
  background-color:var(--white-2);
  filter:saturate(.94);
}
.ci__info{display:flex;flex-direction:column;gap:4px}
.ci__cat{
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--walnut);
}
.ci__info h4{
  font-family:var(--display);
  font-weight:500;
  font-size:18px;
  letter-spacing:-.005em;
  color:var(--ink);
  margin:0;
}
.ci__price{
  font-family:var(--display);
  font-style:italic;
  font-size:16px;
  color:var(--walnut);
  font-weight:500;
}
.ci__qty{
  margin-top:8px;
  display:flex;align-items:center;gap:8px;
}
.ci__qty button{
  width:26px;height:26px;
  border:1px solid var(--line);
  background:transparent;
  color:var(--ink);
  cursor:pointer;
  border-radius:50%;
  font-size:14px;
  display:grid;place-items:center;
  transition:all .3s;
}
.ci__qty button:hover{background:var(--ink);color:var(--white);border-color:var(--ink)}
.ci__qty span{
  min-width:22px;
  text-align:center;
  font-family:var(--display);
  font-style:italic;
  font-size:16px;
  color:var(--ink);
}
.ci__remove{
  margin-left:auto;
  font-size:10px !important;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--mute) !important;
  background:none !important;
  border:0 !important;
  width:auto !important;
  height:auto !important;
  border-radius:0 !important;
  padding:4px 0 !important;
  border-bottom:1px solid var(--line) !important;
}
.ci__remove:hover{color:var(--walnut) !important;border-bottom-color:var(--walnut) !important;background:none !important;transform:none !important}

.cart__empty{
  flex:1;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  padding:30px;
}
.cart__empty[hidden]{display:none}
.cart__empty p{
  font-family:var(--sans);
  font-size:15px;
  letter-spacing:.005em;
  color:var(--mute);
  line-height:1.5;
}
.cart__empty a{
  color:var(--walnut);
  text-decoration:underline;
  text-underline-offset:3px;
}

.cart__foot{
  padding:24px 28px 28px;
  border-top:1px solid var(--line);
  background:var(--white-2);
}
.cart__total{
  display:flex;justify-content:space-between;
  align-items:baseline;
  margin-bottom:14px;
}
.cart__total span{
  font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.cart__total strong{
  font-family:var(--display);
  font-weight:500;
  font-style:italic;
  font-size:32px;
  color:var(--ink);
  letter-spacing:-.01em;
}
.cart__note{
  font-size:12px;
  letter-spacing:.005em;
  color:var(--mute);
  margin-bottom:16px;
  font-family:var(--sans);
  line-height:1.5;
}
.cart__checkout{
  display:flex;align-items:center;justify-content:center;
  gap:12px;
  width:100%;
  padding:18px;
  background:#25D366;
  color:#fff;
  border:0;
  border-radius:8px;
  font-family:var(--sans);
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:500;
  cursor:pointer;
  transition:all .3s ease;
}
.cart__checkout:hover{background:#128C7E;transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(37,211,102,.5)}
.cart__checkout:disabled{
  background:var(--line);color:var(--mute);
  cursor:not-allowed;transform:none;box-shadow:none;
}
.cart__checkout .arr{display:inline-block;transition:transform .3s}
.cart__checkout:hover .arr{transform:translateX(4px)}

body.cart-open{overflow:hidden}

@media(max-width:560px){
  .cart{width:100%}
  .cart__head{padding:22px 18px 16px}
  .cart__items{padding:14px 18px}
  .cart__foot{padding:18px 18px 22px}
  .cart__title{font-size:24px}
  .ci{grid-template-columns:64px 1fr;gap:12px}
  .ci__photo{width:64px;height:80px}
  .ci__info h4{font-size:16px}
}

/* ============== "Ver todos" CTA ============== */
.shop-grid__all{
  max-width:var(--max);
  margin:60px auto 0;
  display:inline-flex;
  align-items:center;
  gap:18px;
  padding:14px 28px 14px 14px;
  background:var(--ink);
  color:var(--white);
  border-radius:999px;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  transition:all .35s ease;
  box-shadow:0 18px 40px -22px rgba(20,17,13,.5);
}
.shop-grid__all-mark{
  width:42px;height:42px;
  display:grid;place-items:center;
  background:var(--gold);
  color:var(--ink);
  border-radius:50%;
  font-size:18px;
  transition:transform .35s ease;
}
.shop-grid__all-count{
  font-family:var(--display);
  font-style:italic;
  letter-spacing:0;
  text-transform:none;
  font-size:14px;
  color:var(--gold);
  font-weight:400;
}
.shop-grid__all:hover{transform:translateY(-2px);box-shadow:0 22px 50px -20px rgba(20,17,13,.6)}
.shop-grid__all:hover .shop-grid__all-mark{transform:rotate(-45deg) scale(1.05)}

@media(max-width:560px){
  .shop-grid__all{
    margin:36px auto 0;
    width:100%;
    justify-content:space-between;
    padding:10px 20px 10px 10px;
    font-size:11px;
    letter-spacing:.16em;
    gap:12px;
  }
  .shop-grid__all-mark{width:36px;height:36px;font-size:16px;flex-shrink:0}
  .shop-grid__all > span:nth-child(2){flex:1;text-align:left}
  .shop-grid__all-count{font-size:12px;flex-shrink:0}
}

/* ============== ALLP — Todos os Produtos overlay ============== */
.allp{
  position:fixed;
  inset:0;
  z-index:62;
  background:var(--white);
  overflow-y:auto;
  display:flex;flex-direction:column;
  transform:translateY(2vh);
  opacity:0;
  visibility:hidden;
  transition:opacity .35s ease, transform .4s cubic-bezier(.5,.05,.2,1), visibility 0s linear .4s;
}
body.allp-open{overflow:hidden}
body.allp-open .allp{
  opacity:1;visibility:visible;transform:none;
  transition:opacity .35s ease, transform .4s cubic-bezier(.5,.05,.2,1);
}

.allp__head{
  position:sticky;
  top:0;
  z-index:5;
  background:var(--white);
  border-bottom:1px solid var(--line);
  padding:0 clamp(20px, 4vw, 50px);
}
.allp__head-inner{
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:30px;
  padding:30px 0 20px;
}
.allp__title .kicker{display:block;margin-bottom:10px}
.allp__title .display{
  font-size:clamp(36px, 4.6vw, 68px);
  margin-bottom:6px;
}
.allp__count{
  font-family:var(--sans);
  font-size:13px;
  letter-spacing:.04em;
  color:var(--mute);
}
.allp__close{
  width:44px;height:44px;
  background:transparent;
  border:1px solid var(--line);
  border-radius:50%;
  color:var(--ink);
  cursor:pointer;
  display:grid;place-items:center;
  transition:all .3s ease;
  flex-shrink:0;
}
.allp__close:hover{background:var(--ink);color:var(--white);border-color:var(--ink);transform:rotate(90deg)}

.allp__tabs{
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  gap:30px;
  overflow-x:auto;
  padding:6px 0 0;
  border-top:1px solid var(--line);
  scrollbar-width:none;
}
.allp__tabs::-webkit-scrollbar{display:none}
.allp__tab{
  position:relative;
  background:transparent;
  border:0;
  padding:18px 0;
  font-family:var(--display);
  font-weight:500;
  font-size:18px;
  letter-spacing:0;
  color:var(--mute);
  cursor:pointer;
  white-space:nowrap;
  transition:color .3s;
}
.allp__tab::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-1px;
  height:2px;
  background:var(--ink);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .3s ease;
}
.allp__tab:hover{color:var(--ink)}
.allp__tab.is-on{color:var(--ink);font-style:italic}
.allp__tab.is-on::after{transform:scaleX(1)}

.allp__bar{
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:18px 0 18px;
  border-top:1px solid var(--line);
  flex-wrap:wrap;
}
.allp__chips{
  display:flex;
  gap:8px;
  overflow-x:auto;
  scrollbar-width:none;
  flex:1;
  min-width:0;
}
.allp__chips::-webkit-scrollbar{display:none}
.chip{
  flex-shrink:0;
  padding:8px 16px;
  background:transparent;
  border:1px solid var(--line);
  border-radius:999px;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
  cursor:pointer;
  transition:all .25s;
  font-family:var(--sans);
}
.chip:hover{border-color:var(--walnut);color:var(--walnut)}
.chip.is-on{background:var(--ink);color:var(--white);border-color:var(--ink)}

.allp__sort{
  display:flex;align-items:center;
  gap:10px;
  flex-shrink:0;
}
.allp__sort label{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--mute);
}
.allp__sort select{
  background:transparent;
  border:1px solid var(--line);
  padding:9px 14px;
  border-radius:999px;
  font-family:var(--sans);
  font-size:12px;
  color:var(--ink);
  cursor:pointer;
  transition:border-color .25s;
}
.allp__sort select:hover{border-color:var(--ink)}

.allp__grid{
  max-width:var(--max);
  margin:0 auto;
  padding:40px clamp(20px, 4vw, 50px) 80px;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:32px;
  width:100%;
}
/* Force visibility on dynamically rendered products (override base .prod opacity:0) */
.allp__grid .prod{
  opacity:1;
  transform:none;
  animation:fadeUp .5s ease forwards;
}
.allp__grid .prod:nth-child(even){animation-delay:.05s}
.allp__grid .prod:nth-child(3n){animation-delay:.08s}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.allp__empty{
  text-align:center;
  padding:80px 20px;
  font-family:var(--sans);
  font-size:15px;
  color:var(--mute);
  line-height:1.7;
}
.allp__empty .link{
  color:var(--walnut);
  border:0;background:none;
  text-decoration:underline;
  text-underline-offset:3px;
  cursor:pointer;
  font-family:inherit;
  font-style:italic;
  font-size:inherit;
}
.allp__empty .link:hover{color:var(--ink)}

@media(max-width:1100px){
  .allp__grid{grid-template-columns:repeat(3, 1fr);gap:24px}
}
@media(max-width:780px){
  .allp__head{padding:0 18px}
  .allp__head-inner{padding:20px 0 12px}
  .allp__title .kicker{margin-bottom:8px;font-size:10px}
  .allp__title .display{font-size:28px;line-height:.95;margin-bottom:4px}
  .allp__count{font-size:13px}
  .allp__close{width:38px;height:38px}
  .allp__tabs{gap:20px;padding-top:4px}
  .allp__tab{font-size:15px;padding:12px 0}
  .allp__bar{padding:12px 0;gap:12px;flex-wrap:nowrap}
  .allp__chips{gap:6px}
  .chip{padding:7px 12px;font-size:10px;letter-spacing:.14em}
  .allp__sort{flex-shrink:0}
  .allp__sort label{display:none}
  .allp__sort select{padding:7px 10px;font-size:11px}
  .allp__grid{grid-template-columns:repeat(2, 1fr);gap:14px;padding:20px 14px 60px}
  .allp__grid .prod{padding:8px}
  .allp__grid .prod__info h3{font-size:15px;line-height:1.15}
  .allp__grid .prod__price{font-size:14px}
  .allp__grid .prod__cat{font-size:9px}
  .allp__grid .add-btn--mini{padding:9px 8px;font-size:9px;letter-spacing:.12em}
}
@media(max-width:380px){
  .allp__title .display{font-size:24px}
  .allp__tabs{gap:14px}
  .allp__tab{font-size:14px}
  .allp__grid{grid-template-columns:1fr;gap:14px}
  .allp__grid .prod{padding:10px}
  .allp__grid .prod__photo{aspect-ratio:5/4}
}

/* ============== FLOATING CART BUTTON ============== */
.cart-fab{
  position:fixed;
  bottom:24px;right:24px;
  z-index:55;
  width:58px;height:58px;
  display:grid;place-items:center;
  background:var(--ink);
  color:var(--white);
  border:1px solid var(--ink);
  border-radius:50%;
  cursor:pointer;
  box-shadow:0 18px 40px -12px rgba(20,17,11,.4);
  transition:opacity .35s ease, transform .35s ease, background .25s ease;
  opacity:0;
  pointer-events:none;
  transform:translateY(20px) scale(.92);
}
.cart-fab.show{
  opacity:1;
  pointer-events:auto;
  transform:none;
}
.cart-fab:hover{
  background:var(--walnut);
  transform:translateY(-3px);
  box-shadow:0 22px 50px -10px rgba(20,17,11,.5);
}
.cart-fab__count{
  position:absolute;
  top:-2px;right:-2px;
  min-width:22px;height:22px;
  padding:0 6px;
  display:grid;place-items:center;
  background:var(--gold);
  color:var(--ink);
  border:2px solid var(--white);
  border-radius:999px;
  font-family:var(--sans);
  font-size:11px;
  font-weight:600;
  line-height:1;
  letter-spacing:0;
  transition:transform .25s ease;
}
.cart-fab__count.bump{animation:bump .45s ease}
.cart-fab[data-empty="true"] .cart-fab__count{display:none}

@media(max-width:560px){
  .cart-fab{
    bottom:18px;right:18px;
    width:52px;height:52px;
  }
  .cart-fab__count{min-width:20px;height:20px;font-size:10px}
}

/* hide fab while cart drawer is open (already accessible there) */
body.cart-open .cart-fab{
  opacity:0;
  pointer-events:none;
  transform:translateY(20px) scale(.92);
}

/* ============== PRODUCT DETAIL MODAL ============== */
.pd{
  position:fixed;
  inset:0;
  z-index:60;
  display:grid;
  place-items:center;
  padding:0;
  opacity:0;
  visibility:hidden;
  transition:opacity .35s ease, visibility 0s linear .35s;
  cursor:pointer;
}
body.pd-open .pd{
  opacity:1;
  visibility:visible;
  transition:opacity .35s ease;
}
body.pd-open{overflow:hidden}
.pd__overlay{
  position:absolute;
  inset:0;
  background:rgba(20,17,13,.7);
  backdrop-filter:blur(4px);
}
.pd__panel{
  position:relative;
  background:var(--white);
  width:100%;
  max-width:1180px;
  height:min(900px, 92vh);
  display:grid;
  grid-template-columns:1.1fr 1fr;
  cursor:default;
  box-shadow:0 40px 100px -30px rgba(20,17,13,.5);
  transform:translateY(20px);
  transition:transform .4s cubic-bezier(.5,.05,.2,1);
  overflow:hidden;
}
body.pd-open .pd__panel{transform:none}

.pd__close{
  position:absolute;
  top:18px;right:18px;
  width:40px;height:40px;
  background:rgba(245,239,225,.9);
  border:1px solid rgba(22,17,11,.14);
  border-radius:50%;
  color:var(--ink);
  cursor:pointer;
  z-index:5;
  display:grid;place-items:center;
  transition:all .25s;
}
.pd__close:hover{background:var(--ink);color:var(--white);border-color:var(--ink);transform:rotate(90deg)}

/* gallery */
.pd__gallery{
  background:var(--white-2);
  display:flex;
  flex-direction:column;
  position:relative;
}
.pd__main{
  flex:1;
  background-size:cover;
  background-position:center;
  background-color:var(--white-2);
  position:relative;
  transition:background-image .25s;
}
.pd__nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:42px;height:42px;
  background:rgba(245,239,225,.92);
  border:1px solid rgba(22,17,11,.1);
  border-radius:50%;
  color:var(--ink);
  cursor:pointer;
  display:grid;place-items:center;
  transition:all .25s;
  opacity:0;
}
.pd__main:hover .pd__nav,
.pd__nav:focus-visible{opacity:1}
.pd__nav--prev{left:14px}
.pd__nav--next{right:14px}
.pd__nav:hover{background:var(--ink);color:var(--white);border-color:var(--ink)}

.pd__thumbs{
  display:flex;
  gap:8px;
  padding:12px 16px 16px;
  overflow-x:auto;
  scrollbar-width:none;
  background:var(--paper);
  border-top:1px solid var(--line);
}
.pd__thumbs::-webkit-scrollbar{display:none}
.pd__thumb{
  flex-shrink:0;
  width:64px;height:80px;
  background-size:cover;
  background-position:center;
  border:2px solid transparent;
  cursor:pointer;
  background-color:var(--white-2);
  transition:border-color .2s, transform .2s;
  padding:0;
}
.pd__thumb:hover{transform:translateY(-2px)}
.pd__thumb.is-on{border-color:var(--ink)}

/* info */
.pd__info{
  padding:54px 48px 36px;
  display:flex;
  flex-direction:column;
  gap:18px;
  overflow-y:auto;
}
.pd__info::-webkit-scrollbar{width:5px}
.pd__info::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}

.pd__info .kicker{
  margin:0;
  font-size:11px;
}
.pd__name{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(28px, 3vw, 42px);
  line-height:1.05;
  letter-spacing:-.012em;
  color:var(--ink);
  margin:4px 0 4px;
}

.pd__prices{
  display:flex;
  align-items:baseline;
  gap:14px;
  padding-bottom:20px;
  border-bottom:1px solid var(--line);
  margin-bottom:6px;
}
.pd__price{
  font-family:var(--display);
  font-style:italic;
  font-size:28px;
  color:var(--walnut);
  font-weight:500;
}
.pd__compare{
  font-size:16px;
  color:var(--mute);
  text-decoration:line-through;
  font-weight:400;
}

.pd__desc{
  font-size:14.5px;
  line-height:1.7;
  color:var(--ink-soft);
  font-family:var(--sans);
  letter-spacing:.005em;
}

.pd__sizes-wrap{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.pd__label-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.pd__label{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--mute);
  font-weight:600;
}
.pd__guide{
  font-size:11px;
  letter-spacing:.04em;
  color:var(--walnut);
  text-decoration:underline;
  text-underline-offset:3px;
}

.pd__sizes{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.pd__size{
  position:relative;
  min-width:60px;
  padding:14px 22px;
  background:transparent;
  border:1px solid var(--ink);
  border-radius:0;
  font-family:var(--sans);
  font-size:13px;
  font-weight:600;
  letter-spacing:.06em;
  color:var(--ink);
  cursor:pointer;
  transition:all .25s ease;
}
.pd__size:hover:not(.is-off){
  background:var(--ink);
  color:var(--white);
}
.pd__size.is-on{
  background:var(--ink);
  color:var(--white);
}
.pd__size.is-off{
  border-color:rgba(22,17,11,.18);
  color:rgba(22,17,11,.32);
  cursor:not-allowed;
  text-decoration:line-through;
  text-decoration-color:rgba(22,17,11,.4);
  background:rgba(22,17,11,.02);
}
.pd__size.is-off span{
  display:block;
  font-size:8px;
  letter-spacing:.18em;
  margin-top:2px;
  text-decoration:none;
  color:var(--mute);
}

.pd__qty-wrap{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.pd__qty{
  display:inline-flex;
  align-items:center;
  border:1px solid var(--line);
  width:fit-content;
  background:var(--paper);
}
.pd__qty button{
  width:42px;height:42px;
  background:transparent;border:0;
  cursor:pointer;
  font-size:18px;line-height:1;
  color:var(--ink);
  transition:background .15s;
}
.pd__qty button:hover{background:rgba(184,148,94,.12)}
.pd__qty span{
  min-width:50px;
  text-align:center;
  font-family:var(--display);
  font-style:italic;
  font-size:18px;
  color:var(--ink);
}

.pd__add{
  margin-top:6px;
  width:100%;
  padding:18px;
  background:var(--ink);
  color:var(--white);
  border:0;
  font-family:var(--sans);
  font-size:12px;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .25s;
}
.pd__add:hover:not(:disabled){background:var(--walnut);transform:translateY(-2px);box-shadow:0 16px 36px -16px rgba(20,17,13,.45)}
.pd__add:disabled{
  background:rgba(22,17,11,.2);
  cursor:not-allowed;
}

.pd__details{
  margin-top:14px;
  display:flex;
  flex-direction:column;
}
.pd__details details{
  border-top:1px solid var(--line);
  padding:14px 0;
}
.pd__details details:last-child{border-bottom:1px solid var(--line)}
.pd__details summary{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink);
  font-weight:600;
  cursor:pointer;
  list-style:none;
  display:flex;
  justify-content:space-between;
}
.pd__details summary::after{content:"+";font-size:14px}
.pd__details details[open] summary::after{content:"−"}
.pd__details p{
  font-size:13.5px;
  line-height:1.7;
  color:var(--ink-soft);
  margin-top:10px;
}

@media(max-width:880px){
  .pd__panel{
    grid-template-columns:1fr;
    height:100vh;
    max-height:100vh;
    overflow-y:auto;
  }
  .pd__gallery{aspect-ratio:4/5;max-height:60vh}
  .pd__main{min-height:50vh}
  .pd__info{padding:32px 24px 80px}
  .pd__name{font-size:24px}
  .pd__price{font-size:22px}
  .pd__close{top:12px;right:12px;width:36px;height:36px}
}
@media(max-width:480px){
  .pd__info{padding:28px 20px 80px}
  .pd__thumb{width:50px;height:62px}
}

/* ============== TOAST ============== */
.toast{
  position:fixed;
  bottom:30px;left:50%;
  transform:translate(-50%, 100px);
  background:var(--ink);
  color:var(--white);
  padding:14px 22px;
  border-radius:999px;
  font-size:13px;
  font-family:var(--sans);
  z-index:70;
  box-shadow:0 24px 50px -16px rgba(20,17,13,.4);
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease, transform .4s cubic-bezier(.5,.05,.2,1);
  white-space:nowrap;
  max-width:calc(100vw - 40px);
}
.toast.on{
  opacity:1;
  transform:translate(-50%, 0);
}

/* ============== Mobile typography & overflow guard ============== */
@media(max-width:600px){
  html, body{overflow-x:hidden;max-width:100vw}
  .hero, .strip, .edit, .band, .cats, .atelier, .services, .news, .shops, .foot, .shop-grid, .allp{
    max-width:100vw;
    overflow-x:hidden;
  }
  .display{font-size:clamp(34px, 9vw, 56px);letter-spacing:-.02em}
  .hero{padding:110px 18px 36px;min-height:auto}
  .hero__top{
    font-size:9.5px;letter-spacing:.18em;
    margin-bottom:28px;padding-bottom:18px;
    flex-direction:column;align-items:flex-start;gap:4px;
  }
  .hero__display{
    font-size:clamp(40px, 13vw, 60px);
    margin:0 0 26px;line-height:.92;
  }
  .hero__display span:nth-child(2),
  .hero__display span:last-child{padding-left:0}
  .hero__bottom{margin-top:14px;padding-top:18px;gap:18px}
  .hero__cta{font-size:10.5px;padding:5px 18px 5px 5px;letter-spacing:.14em}
  .hero__cta-circle{width:36px;height:36px}
  .hero__lede{font-size:13.5px;line-height:1.5;text-align:left;max-width:100%}
  .strip{padding:14px 0}
  .strip__track{font-size:16px;gap:22px}
  .strip__track i{font-size:11px}
  .band__quote{font-size:clamp(20px, 6vw, 32px);padding:0 8px}
  .band{height:55vh;min-height:340px}
  .band__caption{font-size:10px;left:14px;bottom:14px}
  .foot__big{font-size:clamp(54px, 18vw, 100px);margin-bottom:40px}
  .foot{padding:60px 18px 24px}
  .look__name, .srv h3, .cat__body h3, .shop__body h3{font-size:24px}
  .look__price{font-size:18px}
  .look__meta--dark{padding:24px}
  .atelier__stats{flex-wrap:wrap;gap:20px;padding:24px 0;margin:36px 0 30px}
  .atelier__stats > div{flex:1 1 calc(33% - 14px);min-width:72px;gap:4px}
  .atelier__stats strong{font-size:24px}
  .atelier__stats span{font-size:9.5px;letter-spacing:.16em}
  .atelier__photo{min-height:46vh}
  .atelier__body{padding:60px 22px 56px}
  .atelier__body p{font-size:15.5px}
  .atelier__body .display{margin-bottom:28px}
  .news{padding:80px 22px}
  .news__inner > p{font-size:15.5px;margin-bottom:32px}
  .news__form{padding-bottom:10px}
  .news__form input{font-size:16px;padding:10px 0}
  .shop__body{padding:24px 20px}
  .shop__body h3{font-size:32px}
  .ann{font-size:9.5px;letter-spacing:.14em;padding:9px 0}
  .ann__track{gap:24px;padding-left:24px}
  .edit{padding:80px 18px}
  .cats{padding:80px 18px}
  .services{padding:70px 18px}
  .shops{padding:70px 18px}
  .shop-grid{padding:80px 14px 90px}
  .edit__head .display{font-size:36px}
  .edit__intro{font-size:15.5px}
  .filters{margin:0 -2px}
  /* sticky search overlay close on mobile */
  .search{padding:18px 16px 22px}
  .search__form input{font-size:20px}
  .search__close{top:0;right:0;width:34px;height:34px}
}
