/* ── BRAND TOKENS — DARK (padrão) ── */
:root{
  --verde:       #1E4A3C;
  --verde-deep:  #122E25;
  --verde-mid:   #1A3D32;
  --verde-light: #2A6050;
  --ouro:        #8B7A42;
  --ouro-light:  #A89860;
  --ouro-dim:    rgba(139,122,66,.28);
  --ouro-faint:  rgba(139,122,66,.10);
  --branco:      #F5F5F0;
  --branco-dim:  rgba(245,245,240,.65);
  --branco-muted:rgba(245,245,240,.38);

  /* semânticos */
  --bg:          var(--verde);
  --bg-header:   rgba(18,46,37,.96);
  --bg-hero:     var(--verde-mid);
  --bg-card:     linear-gradient(160deg,#1a3d32 0%,#122e25 100%);
  --bg-foot:     var(--verde-deep);
  --bg-inspo:    rgba(18,46,37,.5);
  --border-card: rgba(139,122,66,.14);
  --border-card-hover: rgba(139,122,66,.38);
  --text-main:   var(--branco);
  --text-dim:    rgba(245,245,240,.65);
  --text-muted:  rgba(245,245,240,.38);
  --slide-light-bg: #F0EDE8;
  --slide-dark-bg:  #F0EDE8;
  --num-color:   rgba(139,122,66,.45);
  --badge-f-bg:  rgba(255,255,255,.12);
  --badge-f-bd:  rgba(255,255,255,.25);
  --badge-f-c:   rgba(255,255,255,.8);
  --badge-m-bg:  rgba(30,74,60,.5);
  --badge-m-bd:  rgba(42,96,80,.6);
  --badge-m-c:   rgba(168,222,200,.85);
  --filter-c:    var(--branco-muted);
  --filter-c-h:  var(--branco);
  --pyramid-top: rgba(220,195,120,.7);
  --pyramid-heart:rgba(200,175,175,.65);
  --pyramid-base:rgba(140,195,165,.65);
  --shadow-hover: 0 16px 48px rgba(0,0,0,.28);
}

/* ── BRAND TOKENS — LIGHT ── */
[data-theme="light"]{
  --bg:          #F7F3EC;
  --bg-header:   rgba(253,249,244,.97);
  --bg-hero:     #EFE9DF;
  --bg-card:     linear-gradient(160deg,#FFFFFF 0%,#F7F2EA 100%);
  --bg-foot:     #EDE7DB;
  --bg-inspo:    rgba(30,74,60,.06);
  --border-card: rgba(139,122,66,.18);
  --border-card-hover: rgba(139,122,66,.5);
  --text-main:   #1E4A3C;
  --text-dim:    rgba(30,74,60,.72);
  --text-muted:  rgba(30,74,60,.45);
  --slide-light-bg: #F0EDE8;
  --slide-dark-bg:  #F0EDE8;
  --num-color:   rgba(139,122,66,.4);
  --badge-f-bg:  rgba(139,122,66,.08);
  --badge-f-bd:  rgba(139,122,66,.28);
  --badge-f-c:   #8B7A42;
  --badge-m-bg:  rgba(30,74,60,.07);
  --badge-m-bd:  rgba(30,74,60,.22);
  --badge-m-c:   #1E4A3C;
  --filter-c:    rgba(30,74,60,.5);
  --filter-c-h:  #1E4A3C;
  --pyramid-top: rgba(120,95,30,.75);
  --pyramid-heart:rgba(130,60,60,.6);
  --pyramid-base:rgba(30,100,70,.65);
  --shadow-hover: 0 16px 48px rgba(0,0,0,.10);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text-main);
  font-family:'Dubai',sans-serif;
  min-height:100vh;
  transition:background .4s,color .4s
}

/* ── HEADER ── */
.header{
  background-color:var(--bg-header);
  border-bottom:1px solid var(--ouro-dim);
  position:sticky;top:0;z-index:100;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  transition:background-color .4s
}
.header-inner{
  max-width:1400px;margin:0 auto;
  padding:16px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  flex-wrap:wrap;position:relative
}
.header-logo{
  position:absolute;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:10px;text-decoration:none
}
.header-logo img{height:62px;width:auto;object-fit:contain;display:block}
.header-logo .logo-light{display:none}
[data-theme="light"] .header-logo .logo-dark{display:none}
[data-theme="light"] .header-logo .logo-light{display:block}
.header-brand{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:clamp(14px,1.5vw,18px);letter-spacing:5px;
  color:var(--text-main);text-transform:uppercase;white-space:nowrap
}
.header-title{
  font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:clamp(13px,1.4vw,16px);letter-spacing:6px;
  color:var(--ouro-light);text-transform:uppercase
}
.header-count{
  font-family:'Dubai',sans-serif;font-weight:400;
  font-size:11px;letter-spacing:4px;color:var(--text-muted)
}

/* ── HERO ── */
.hero{
  text-align:center;padding:72px 24px 52px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;inset:-40px;
  background:url('banners/fundohero.png') center/cover no-repeat;
  filter:blur(5px);
  transform:scale(1.05);
  z-index:0;
}
.hero::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(18,46,37,.52);
  z-index:1;
}
.hero > *{position:relative;z-index:2}
.hero-label{
  font-family:'Dubai',sans-serif;font-size:10px;font-weight:400;
  letter-spacing:8px;color:#A89860;text-transform:uppercase;margin-bottom:18px;
  opacity:.8
}
.hero-title{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:clamp(38px,5vw,68px);color:#F5F5F0;letter-spacing:2px;line-height:1.1
}
.hero-title span{color:#A89860;font-style:italic}
.gd{
  width:56px;height:1px;
  background:linear-gradient(90deg,transparent,#8B7A42 40%,transparent);
  margin:22px auto
}
.hero-sub{
  font-family:'Dubai',sans-serif;font-size:clamp(13px,1.2vw,15px);font-weight:400;
  color:rgba(245,245,240,.65);letter-spacing:.6px;max-width:520px;margin:0 auto;line-height:1.7
}

/* ── ENTRANCE ANIMATIONS ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(22px)}
  to  {opacity:1;transform:translateY(0)}
}
@keyframes fadeIn{
  from{opacity:0}
  to  {opacity:1}
}
@keyframes slideDown{
  from{opacity:0;transform:translateY(-12px)}
  to  {opacity:1;transform:translateY(0)}
}
@keyframes lineGrow{
  from{transform:scaleX(0)}
  to  {transform:scaleX(1)}
}

/* hero children stagger */
.hero-label  {animation:fadeUp .6s ease both;animation-delay:.1s}
.hero-title  {animation:fadeUp .7s ease both;animation-delay:.22s}
.gd          {animation:lineGrow .6s ease both;animation-delay:.42s;transform-origin:center}
.hero-sub    {animation:fadeUp .6s ease both;animation-delay:.52s}

/* header fade-down */
.header{animation:slideDown .5s ease both}

/* filters fade-in */
.filters{animation:fadeIn .6s ease both;animation-delay:.3s}

/* cards: reveal on scroll via JS .card-visible */
.card{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .55s ease, transform .55s ease,
             border-color .4s, box-shadow .4s, background .4s
}
.card.card-visible{
  opacity:1;
  transform:translateY(0)
}
/* keep hover lift only after visible */
.card.card-visible:hover{
  transform:translateY(-3px)
}

/* filter btn active press */
.filter-btn:active{transform:scale(.94)}

/* footer fade */
.foot{animation:fadeIn .6s ease both;animation-delay:.1s}

/* ── FILTERS ── */
.filters{
  max-width:1400px;margin:0 auto;
  padding:36px 32px 0;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap
}
.filter-label{
  font-family:'Dubai',sans-serif;font-size:10px;font-weight:400;
  letter-spacing:5px;color:var(--ouro-light);text-transform:uppercase;
  margin-right:6px;opacity:.7
}
.filter-btn{
  border:1px solid rgba(139,122,66,.3);background:transparent;
  color:var(--filter-c);
  font-family:'Dubai',sans-serif;font-size:11px;font-weight:400;
  letter-spacing:3px;text-transform:uppercase;
  padding:8px 20px;cursor:pointer;transition:all .25s
}
.filter-btn:hover{border-color:var(--ouro);color:var(--filter-c-h)}
.filter-btn.active{
  border-color:var(--ouro);color:var(--ouro-light);
  background:rgba(139,122,66,.12)
}
.sort-label{margin-left:8px}
.search-wrap{
  position:relative;display:flex;align-items:center;
  margin-left:auto
}
.search-ico{
  position:absolute;left:12px;color:var(--filter-c);
  pointer-events:none;opacity:.7
}
.search-input{
  border:1px solid rgba(139,122,66,.3);background:transparent;
  color:var(--filter-c-h);
  font-family:'Dubai',sans-serif;font-size:12px;font-weight:300;
  letter-spacing:.5px;
  padding:9px 14px 9px 32px;width:240px;
  transition:all .25s;outline:none
}
.search-input::placeholder{color:var(--filter-c);opacity:.6}
.search-input:focus{border-color:var(--ouro)}
@media(max-width:640px){
  .search-wrap{margin-left:0;width:100%}
  .search-input{width:100%}
}

/* ── GRID ── */
.catalog{
  max-width:1400px;margin:0 auto;
  padding:32px 32px 88px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px
}
/* ── THEME TOGGLE ── */
.theme-toggle{
  background:transparent;
  border:1px solid var(--ouro-dim);
  color:var(--ouro-light);
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:border-color .25s,color .25s;
  flex-shrink:0
}
.theme-toggle:hover{border-color:var(--ouro);color:var(--ouro)}

@media(max-width:1100px){.catalog{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){
  .catalog{grid-template-columns:1fr;padding:20px 14px 64px}
  .filters{padding:24px 14px 0;gap:8px;justify-content:center}
  .filter-label{display:none}
  .header-inner{padding:12px 14px;justify-content:space-between}
  .header-title{display:none}
  .hero{padding:48px 16px 36px;text-align:center}
  .hero-label{text-align:center}
  .card-body{padding:16px 16px 18px;align-items:stretch}
  .card-name{text-align:center}
  .card-family{text-align:center}
  .card-term{text-align:center}
  .pyramid-title{text-align:center}
  .specs{grid-template-columns:1fr 1fr;gap:10px 12px}
  .spec{align-items:center;text-align:center}
  .fix-highlight{padding:10px 4px}
  .card-inspo{text-align:center}
  .inspo-label{text-align:center}
  .foot{padding:36px 16px 32px}
}

/* ── CARD ── */
.card{
  border:1px solid var(--border-card);
  background:var(--bg-card);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden
}
.card:hover{
  border-color:var(--border-card-hover);
  box-shadow:var(--shadow-hover)
}
.card.hidden{display:none}

/* ── CAROUSEL ── */
.card-img{height:300px;position:relative;overflow:hidden}
@media(max-width:640px){
  .card-img{height:320px}
}
.carousel{width:100%;height:100%;position:relative;overflow:hidden}
.carousel-track{
  display:flex;height:100%;
  transition:transform .38s cubic-bezier(.4,0,.2,1);
  will-change:transform
}
.carousel-slide{
  min-width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0
}
.slide-dark{background:var(--slide-dark-bg)}
.slide-light{background:var(--slide-light-bg)}
.carousel-slide img{
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  object-fit:contain;object-position:center;
  display:block;
  transition:transform .45s ease
}
.card:hover .carousel-slide img{transform:scale(1.04)}
/* arrows */
.car-prev,.car-next{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(12,30,22,.72);
  border:1px solid rgba(139,122,66,.35);
  color:rgba(245,245,240,.85);
  width:30px;height:30px;
  display:flex;align-items:center;justify-content:center;
  font-size:17px;line-height:1;cursor:pointer;
  opacity:0;transition:opacity .2s,background .2s;z-index:5
}
.card-img:hover .car-prev,
.card-img:hover .car-next{opacity:1}
.car-prev{left:8px}
.car-next{right:8px}
.car-prev:hover,.car-next:hover{background:rgba(30,74,60,.92);border-color:var(--ouro)}
/* dots */
.car-dots{
  position:absolute;bottom:9px;left:50%;transform:translateX(-50%);
  display:flex;gap:5px;z-index:5
}
.car-dot{
  width:5px;height:5px;border-radius:50%;
  background:rgba(245,245,240,.28);
  transition:background .2s,transform .2s;cursor:pointer
}
.car-dot.active{background:var(--ouro-light);transform:scale(1.4)}

/* category badge */
.card-badge{
  position:absolute;top:12px;right:12px;z-index:2;
  font-family:'Dubai',sans-serif;
  font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;
  padding:5px 10px;
}
.badge-f{
  background:var(--badge-f-bg);
  border:1px solid var(--badge-f-bd);
  color:var(--badge-f-c)
}
.badge-m{
  background:var(--badge-m-bg);
  border:1px solid var(--badge-m-bd);
  color:var(--badge-m-c)
}
.badge-u{
  background:rgba(139,122,66,.15);
  border:1px solid rgba(139,122,66,.38);
  color:var(--ouro-light)
}

/* num badge */
.card-num{
  position:absolute;top:12px;left:14px;z-index:2;
  font-family:'Cormorant Garamond',serif;font-weight:300;font-size:12px;
  color:var(--num-color);letter-spacing:2px
}

/* card body */
.card-body{padding:20px 20px 22px;flex:1;display:flex;flex-direction:column;gap:0}

.card-name{
  font-family:'Cormorant Garamond',serif;font-weight:700;
  font-size:clamp(21px,2vw,27px);color:var(--text-main);letter-spacing:3px;
  line-height:1.1;margin-bottom:4px
}
.card-family{
  font-family:'Dubai',sans-serif;font-size:11px;font-weight:500;letter-spacing:1.5px;
  color:var(--ouro-light);margin-bottom:5px;opacity:.9
}
.card-term{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:14px;color:rgba(245,245,240,.42);margin-bottom:16px;
  letter-spacing:.3px
}

.divider{height:1px;background:linear-gradient(90deg,var(--ouro-dim),transparent);margin:14px 0}

/* pirâmide olfativa */
.pyramid-title{
  font-family:'Dubai',sans-serif;font-size:9px;font-weight:500;
  letter-spacing:5px;text-transform:uppercase;
  color:rgba(139,122,66,.6);margin-bottom:10px
}
.pyramid-row{display:flex;gap:8px;margin-bottom:7px;align-items:flex-start}
.pyramid-label{
  font-family:'Dubai',sans-serif;font-size:9px;font-weight:500;
  letter-spacing:2px;text-transform:uppercase;min-width:52px;padding-top:1px
}
.label-top{color:var(--pyramid-top)}
.label-heart{color:var(--pyramid-heart)}
.label-base{color:var(--pyramid-base)}
.pyramid-notes{
  font-family:'Dubai',sans-serif;font-size:12px;font-weight:400;
  color:var(--text-dim);line-height:1.55;letter-spacing:.2px
}

.divider2{height:1px;background:linear-gradient(90deg,var(--ouro-faint),transparent);margin:14px 0}

/* specs grid */
.specs{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-top:4px}
.spec{display:flex;flex-direction:column;gap:3px}
.spec-label{
  font-family:'Dubai',sans-serif;font-size:9px;font-weight:500;
  letter-spacing:4px;text-transform:uppercase;color:rgba(139,122,66,.5)
}
.spec-value{
  font-family:'Dubai',sans-serif;font-size:12px;font-weight:400;
  color:var(--text-dim);letter-spacing:.2px
}

/* fixação highlight */
.fix-highlight{
  margin-top:16px;
  border-top:1px solid rgba(139,122,66,.18);
  border-bottom:1px solid rgba(139,122,66,.18);
  padding:10px 0;
  display:flex;align-items:center;justify-content:space-between
}
.fix-ico{
  color:rgba(139,122,66,.45);
  display:flex;align-items:center
}
.fix-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.fix-num{
  font-family:'Cormorant Garamond',serif;font-weight:400;font-style:italic;
  font-size:22px;color:var(--ouro-light);letter-spacing:1px;line-height:1
}
.fix-tag{
  font-family:'Dubai',sans-serif;font-size:8px;font-weight:400;
  letter-spacing:4px;text-transform:uppercase;color:rgba(139,122,66,.45)
}

/* por que pedem assim */
.card-reason{
  margin-bottom:16px;padding:9px 12px;
  background:var(--bg-inspo);
  border-left:2px solid rgba(139,122,66,.3)
}

/* inspiração */
.card-inspo{
  margin-top:12px;padding:9px 12px;
  background:var(--bg-inspo);
  border-left:2px solid rgba(139,122,66,.3)
}
.inspo-label{
  font-family:'Dubai',sans-serif;font-size:9px;font-weight:500;
  letter-spacing:4px;text-transform:uppercase;
  color:rgba(139,122,66,.45);margin-bottom:3px
}
.inspo-value{
  font-family:'Dubai',sans-serif;font-size:12px;font-weight:400;
  color:var(--text-muted);letter-spacing:.3px
}

/* ── LIGHTBOX ── */
.lb-overlay{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.92);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .25s
}
.lb-overlay.open{opacity:1;pointer-events:all}
.lb-img-wrap{
  position:relative;
  max-width:90vw;max-height:88vh;
  overflow:hidden;
  cursor:zoom-in;
  display:flex;align-items:center;justify-content:center;
  user-select:none;-webkit-user-select:none
}
.lb-img-wrap.zoomed{cursor:grab}
.lb-img-wrap.dragging{cursor:grabbing}
.lb-img{
  display:block;
  max-width:90vw;max-height:88vh;
  width:auto;height:auto;
  object-fit:contain;
  transform-origin:0 0;
  transition:transform .15s ease;
  pointer-events:none
}
.lb-img-wrap.dragging .lb-img{transition:none}
.lb-close{
  position:fixed;top:20px;right:24px;
  background:transparent;border:1px solid rgba(139,122,66,.4);
  color:rgba(245,245,240,.8);
  width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;line-height:1;cursor:pointer;
  transition:border-color .2s,color .2s;z-index:10001
}
.lb-close:hover{border-color:var(--ouro);color:#fff}
.lb-prev,.lb-next{
  position:fixed;top:50%;transform:translateY(-50%);
  background:rgba(12,30,22,.72);
  border:1px solid rgba(139,122,66,.35);
  color:rgba(245,245,240,.85);
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;cursor:pointer;
  transition:background .2s,border-color .2s;z-index:10001
}
.lb-prev{left:16px}
.lb-next{right:16px}
.lb-prev:hover,.lb-next:hover{background:rgba(30,74,60,.92);border-color:var(--ouro)}
.lb-hint{
  position:fixed;bottom:18px;left:50%;transform:translateX(-50%);
  font-family:'Dubai',sans-serif;font-size:10px;letter-spacing:3px;
  color:rgba(245,245,240,.3);text-transform:uppercase;z-index:10001;
  pointer-events:none
}
.lb-counter{
  position:fixed;bottom:18px;right:24px;
  font-family:'Cormorant Garamond',serif;font-size:13px;
  color:rgba(139,122,66,.5);letter-spacing:2px;z-index:10001
}

/* make carousel images show pointer */
.carousel-slide img{cursor:zoom-in}

/* ── FOOTER ── */
.foot{
  border-top:1px solid rgba(139,122,66,.14);
  padding:48px 32px 40px;text-align:center;
  background:var(--bg-foot);
  transition:background .4s
}
.foot-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:16px}
.foot-logo img{height:140px;object-fit:contain;display:block;opacity:.8}
.foot-brand{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:14px;letter-spacing:6px;color:var(--ouro-light);text-transform:uppercase;opacity:.7}
.foot-text{
  font-family:'Dubai',sans-serif;font-size:11px;font-weight:400;
  letter-spacing:4px;color:rgba(139,122,66,.4);text-transform:uppercase
}
