:root{
  --cream:    #F8F1E2;
  --cream-2:  #F2E9D6;
  --brown:    #6B4226;
  --brown-d:  #54331D;
  --blush:    #EAC7B8;
  --blush-l:  #F1D8CC;
  --olive:    #46452F;
  --line:     rgba(107,66,38,.25);
}

*{ margin:0; padding:0; box-sizing:border-box; border-radius:0 !important; }

html{ scroll-behavior:smooth; }

body{
  background:var(--cream);
  color:var(--brown);
  font-family:'Jost',sans-serif;
  font-weight:300;
  overflow-x:hidden;
}

::selection{ background:var(--blush); color:var(--brown-d); }

button{ font-family:'Jost',sans-serif; }

/* ---------- HEADER ---------- */
header.site{
  position:sticky; top:0; z-index:50;
  background:rgba(248,241,226,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:10px 40px;
  max-width:1500px;
  margin:0 auto;
}
.brand{
  grid-column:2;
  display:flex; flex-direction:column; align-items:center;
  text-decoration:none; color:var(--brown);
  animation:fadeDown .9s ease both;
}
.brand img.brand-logo{ height:56px; width:auto; display:block; }
.brand span.local{
  font-size:.6rem;
  letter-spacing:.55em;
  text-transform:uppercase;
  margin-top:2px;
  color:var(--olive);
}
.cart{
  grid-column:3; justify-self:end;
  display:flex; align-items:center;
  background:transparent;
  border:none;
  color:var(--brown);
  padding:6px;
  cursor:pointer;
  position:relative;
  text-decoration:none;
  transition:transform .3s ease, color .3s ease;
}
.cart:hover{ transform:translateY(-2px); color:var(--brown-d); }
.cart svg{ width:26px; height:26px; }
.cart-count{
  position:absolute; top:-9px; right:-9px;
  background:var(--blush); color:var(--brown-d);
  width:20px; height:20px;
  display:grid; place-items:center;
  font-size:.65rem; letter-spacing:0;
}

/* ---------- MENSAGENS ---------- */
.toasts{
  position:fixed; top:96px; right:24px; z-index:80;
  display:flex; flex-direction:column; gap:10px;
}
.toast{
  background:var(--olive); color:var(--cream);
  padding:14px 22px;
  font-size:.8rem; letter-spacing:.08em;
  border-left:3px solid var(--blush);
  animation:fadeDown .5s ease both;
}

/* ---------- CARROSSEL ---------- */
.hero{ position:relative; overflow:hidden; border-bottom:1px solid var(--line); }
.hero-track{
  display:flex;
  width:max-content;
  animation:slide 55s linear infinite;
}
.hero-track img{
  height:72vh; min-height:480px;
  width:auto;
  aspect-ratio:4/5;
  object-fit:cover;
  flex-shrink:0;
  border-right:1px solid var(--cream);
  filter:saturate(.92) contrast(.98);
}
@keyframes slide{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}
.hero-veil{
  position:absolute; inset:0;
  background:radial-gradient(ellipse at center, rgba(70,69,47,.5) 0%, rgba(70,69,47,.18) 60%, rgba(70,69,47,.34) 100%);
  pointer-events:none;
}
.hero-logo{
  position:absolute; inset:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center;
  pointer-events:none;
  animation:fadeUp 1.4s .3s ease both;
}
.hero-logo img{
  height:clamp(200px, 30vw, 320px);
  display:block; margin:0 auto;
  filter:drop-shadow(0 2px 18px rgba(70,69,47,.35));
}
.hero-logo p{
  margin-top:18px;
  font-size:.68rem;
  letter-spacing:.6em;
  text-transform:uppercase;
  color:var(--cream);
  text-shadow:0 1px 14px rgba(70,69,47,.6);
}

/* ---------- MARQUEE ---------- */
.marquee{
  background:var(--brown);
  color:var(--cream);
  overflow:hidden;
  border-bottom:1px solid var(--line);
  padding:20px 0;
}
.marquee-track{
  display:flex; width:max-content;
  animation:slide 30s linear infinite;
}
.marquee-track span{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:1.55rem;
  letter-spacing:.08em;
  white-space:nowrap;
  padding:0 28px;
  display:flex; align-items:center; gap:56px;
}
.marquee-track span::after{
  content:'✦';
  font-style:normal;
  font-size:.8rem;
  color:var(--blush);
}

/* ---------- CATEGORIAS ---------- */
.collections{ max-width:1500px; margin:0 auto; padding:90px 40px 40px; }
.collections-intro{ margin-bottom:70px; max-width:560px; }
.collections-intro em{
  font-family:'Cormorant Garamond',serif;
  font-size:.95rem; letter-spacing:.35em; text-transform:uppercase; font-style:normal;
  color:var(--olive);
  display:block; margin-bottom:14px;
}
.collections-intro h3{
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  font-size:clamp(2.2rem, 4vw, 3.4rem);
  line-height:1.05;
}

.category{ margin-bottom:90px; }
.category-head{
  display:flex; align-items:baseline; justify-content:space-between;
  border-bottom:1px solid var(--brown);
  padding-bottom:14px; margin-bottom:34px;
}
.category-head h4{
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  font-size:clamp(1.8rem, 3vw, 2.6rem);
  display:flex; align-items:baseline; gap:18px;
}
.category-head h4 small{
  font-family:'Jost',sans-serif;
  font-size:.65rem; letter-spacing:.4em; text-transform:uppercase;
  color:var(--olive); font-weight:300;
}

.row{
  display:flex;
  gap:22px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
}
.row::-webkit-scrollbar{ display:none; }
.card{
  flex:0 0 clamp(240px, 24vw, 330px);
  scroll-snap-align:start;
  position:relative;
  overflow:hidden;
  background:var(--cream-2);
  border:1px solid var(--line);
}
.card img{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  display:block;
  filter:saturate(.92);
  transition:transform .8s cubic-bezier(.2,.6,.2,1), filter .8s;
}
.card:hover img{ transform:scale(1.06); filter:saturate(1); }
.card-info{
  position:absolute; left:0; right:0; bottom:0;
  background:linear-gradient(transparent, rgba(70,69,47,.82));
  color:var(--cream);
  padding:54px 16px 14px;
  display:flex; justify-content:space-between; align-items:flex-end; gap:10px;
  opacity:0; transform:translateY(12px);
  transition:opacity .45s ease, transform .45s ease;
}
.card:hover .card-info,
.card:focus-within .card-info{ opacity:1; transform:translateY(0); }
.card-info b{
  font-family:'Cormorant Garamond',serif;
  font-weight:500; font-size:1.1rem; letter-spacing:.04em;
  display:block;
}
.card-info i{ font-style:normal; font-size:.75rem; letter-spacing:.15em; color:var(--blush-l); }
.btn-sacola{
  background:var(--cream); color:var(--brown-d);
  border:none; cursor:pointer;
  padding:9px 14px;
  font-size:.62rem; letter-spacing:.22em; text-transform:uppercase;
  white-space:nowrap;
  transition:background .3s, color .3s;
}
.btn-sacola:hover{ background:var(--blush); }

/* Seletor de cor/tamanho dentro do card */
.card-info form{ display:flex; flex-direction:column; gap:6px; align-items:flex-end; }
.sel-variacao{
  background:var(--cream); color:var(--brown-d);
  border:none; padding:6px 8px;
  font-family:'Jost',sans-serif; font-size:.62rem;
  letter-spacing:.15em; text-transform:uppercase;
  max-width:130px; cursor:pointer;
}

/* Em telas de toque a legenda fica sempre visível */
@media (hover:none){
  .card-info{ opacity:1; transform:none; }
}

/* ---------- PÁGINAS INTERNAS (carrinho / checkout) ---------- */
.pagina{
  max-width:980px; margin:0 auto;
  padding:70px 24px 90px;
}
.pagina-titulo{
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  font-size:clamp(2.2rem, 4vw, 3.2rem);
  margin-bottom:8px;
}
.pagina-sub{
  font-size:.7rem; letter-spacing:.4em; text-transform:uppercase;
  color:var(--olive); margin-bottom:48px;
}
.linha-item{
  display:grid;
  grid-template-columns:84px 1fr auto auto;
  gap:20px; align-items:center;
  padding:18px 0;
  border-bottom:1px solid var(--line);
}
.linha-item img{ width:84px; height:105px; object-fit:cover; }
.linha-item .nome{
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem; font-weight:500;
}
.linha-item .preco{ font-size:.85rem; letter-spacing:.1em; color:var(--olive); }
.qtd{ display:flex; align-items:center; border:1px solid var(--brown); }
.qtd button{
  background:none; border:none; cursor:pointer; color:var(--brown);
  width:34px; height:34px; font-size:1rem;
}
.qtd button:hover{ background:var(--cream-2); }
.qtd b{ min-width:30px; text-align:center; font-weight:400; }
.remover{
  background:none; border:none; cursor:pointer;
  color:var(--brown); opacity:.6; font-size:.7rem;
  letter-spacing:.2em; text-transform:uppercase;
}
.remover:hover{ opacity:1; }
.total-box{
  display:flex; justify-content:space-between; align-items:center;
  margin-top:36px; padding-top:24px;
}
.total-box .valor{
  font-family:'Cormorant Garamond',serif;
  font-size:2rem; font-weight:500;
}
.btn{
  display:inline-block;
  background:var(--brown); color:var(--cream);
  border:1px solid var(--brown);
  padding:16px 48px;
  font-size:.7rem; letter-spacing:.4em; text-transform:uppercase;
  text-decoration:none; cursor:pointer;
  transition:background .35s, color .35s;
}
.btn:hover{ background:transparent; color:var(--brown); }
.btn-claro{
  background:transparent; color:var(--brown);
}
.btn-claro:hover{ background:var(--brown); color:var(--cream); }
.btn-whats{
  background:#1FA855; border-color:#1FA855; color:#fff;
}
.btn-whats:hover{ background:transparent; color:#1FA855; }

.form-grid{ display:grid; gap:26px; }
.campo label{
  display:block;
  font-size:.68rem; letter-spacing:.32em; text-transform:uppercase;
  margin-bottom:10px; color:var(--olive);
}
.campo input, .campo textarea{
  width:100%;
  background:transparent;
  border:1px solid var(--brown);
  padding:14px 16px;
  font-family:'Jost',sans-serif;
  font-size:1rem; font-weight:300;
  color:var(--brown-d);
  outline:none;
  transition:border-color .3s, box-shadow .3s;
}
.campo input:focus, .campo textarea:focus{
  border-color:var(--brown-d);
  box-shadow:0 0 0 1px var(--brown-d);
}
.campo .erro{
  display:block; margin-top:8px;
  font-size:.78rem; color:#9C3B22; letter-spacing:.04em;
}
.resumo{
  background:var(--cream-2);
  border:1px solid var(--line);
  padding:28px;
}
.resumo h6{
  font-family:'Cormorant Garamond',serif;
  font-size:1.4rem; font-weight:500; margin-bottom:18px;
}
.resumo ul{ list-style:none; }
.resumo li{
  display:flex; justify-content:space-between;
  font-size:.88rem; padding:7px 0;
  border-bottom:1px dashed var(--line);
}
.resumo .resumo-total{
  display:flex; justify-content:space-between;
  margin-top:16px;
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem; font-weight:500;
}

/* ---------- FECHAMENTO / RODAPÉ ---------- */
.closing{
  background:var(--blush);
  border-top:1px solid var(--line);
  text-align:center;
  padding:110px 40px;
}
.closing img{ height:64px; margin-bottom:24px; }
.closing h5{
  font-family:'Cormorant Garamond',serif;
  font-weight:500;
  font-size:clamp(2rem, 4vw, 3.2rem);
  color:var(--brown-d);
  max-width:760px; margin:0 auto 36px;
  line-height:1.15;
}
.closing a{
  display:inline-block;
  border:1px solid var(--brown-d);
  color:var(--brown-d); text-decoration:none;
  padding:16px 52px;
  font-size:.7rem; letter-spacing:.4em; text-transform:uppercase;
  transition:background .35s, color .35s;
}
.closing a:hover{ background:var(--brown-d); color:var(--cream); }

footer.site{
  background:var(--olive); color:var(--cream);
  text-align:center;
  padding:30px 40px;
  font-size:.68rem; letter-spacing:.35em; text-transform:uppercase;
}

/* ---------- ANIMAÇÕES ---------- */
@keyframes fadeDown{ from{ opacity:0; transform:translateY(-14px);} to{ opacity:1; transform:none;} }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(22px);} to{ opacity:1; transform:none;} }
.reveal{ opacity:0; transform:translateY(30px); transition:opacity .9s ease, transform .9s ease; }
.reveal.on{ opacity:1; transform:none; }

/* ---------- PÁGINA DO PRODUTO ---------- */
.produto-voltar{
  display:inline-block; margin-bottom:34px;
  color:var(--olive); text-decoration:none;
  font-size:.7rem; letter-spacing:.25em; text-transform:uppercase;
}
.produto-voltar:hover{ color:var(--brown-d); }
.produto-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:60px;
  align-items:start;
}
.produto-galeria img#fotoPrincipal{
  width:100%; aspect-ratio:4/5; object-fit:cover;
  border:1px solid var(--line);
}
.produto-thumbs{ display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.produto-thumbs img{
  width:64px; height:80px; object-fit:cover; cursor:pointer;
  border:1px solid var(--line); opacity:.65;
  transition:opacity .25s, border-color .25s;
}
.produto-thumbs img:hover{ opacity:1; }
.produto-thumbs img.ativa{ opacity:1; border-color:var(--brown); }
.produto-info em{
  font-family:'Cormorant Garamond',serif; font-style:normal;
  font-size:.85rem; letter-spacing:.35em; text-transform:uppercase;
  color:var(--olive); display:block; margin-bottom:12px;
}
.produto-info h1{
  font-family:'Cormorant Garamond',serif; font-weight:500;
  font-size:clamp(2rem, 3.5vw, 2.9rem); line-height:1.08;
  margin-bottom:14px;
}
.produto-preco{
  font-family:'Cormorant Garamond',serif;
  font-size:2.2rem; font-weight:500;
  color:var(--brown-d);
  margin-bottom:26px;
  padding-bottom:22px;
  border-bottom:1px solid var(--line);
}
.produto-descricao{
  font-size:.95rem; line-height:1.75; color:var(--olive);
  margin-bottom:32px; max-width:46ch;
}
.produto-var-label{
  display:block; font-size:.65rem; letter-spacing:.3em;
  text-transform:uppercase; color:var(--olive); margin-bottom:8px;
}
.produto-var-select{
  display:block; width:100%; max-width:280px;
  padding:12px 14px; margin-bottom:22px;
  background:transparent; border:1px solid var(--brown);
  font-family:'Jost',sans-serif; font-size:.8rem;
  letter-spacing:.12em; color:var(--brown-d); cursor:pointer;
}
.produto-qtd{
  display:inline-flex; align-items:center;
  border:1px solid var(--brown); margin-bottom:26px;
}
.produto-qtd button{
  background:none; border:none; cursor:pointer; color:var(--brown);
  width:42px; height:42px; font-size:1.15rem;
}
.produto-qtd button:hover{ background:var(--cream-2); }
.produto-qtd b{ min-width:40px; text-align:center; font-weight:400; font-size:1rem; }
.produto-info form .btn{ display:block; }

/* O card todo é clicável para abrir o produto */
.card a.card-link{ display:block; color:inherit; text-decoration:none; }
.card-info b a{ color:inherit; text-decoration:none; }

/* ---------- RESPONSIVO ---------- */
@media (max-width:980px){
  .hero-track img{ height:56vh; min-height:380px; }
}
@media (max-width:780px){
  /* Página do produto empilha no celular */
  .produto-grid{ grid-template-columns:1fr; gap:30px; }
}
@media (max-width:620px){
  /* Hero menor no celular: imagens mais baixas e estreitas, logo reduzida */
  .hero-track img{ height:34vh; min-height:220px; }
  /* Faixa animada (marquee) proporcional ao hero menor */
  .marquee{ padding:11px 0; }
  .marquee-track span{ font-size:1.05rem; padding:0 18px; gap:36px; }
  /* Frase de introdução das coleções menor e mais próxima do hero e das categorias */
  .collections-intro h3{ font-size:1.6rem; }
  .collections-intro{ margin-bottom:34px; }
  .hero-logo img{ height:clamp(120px, 34vw, 170px); }
  .hero-logo p{ margin-top:12px; font-size:.55rem; }
  .header-inner{ padding:8px 18px; }
  .brand img.brand-logo{ height:44px; }
  .collections{ padding:30px 18px 20px; }
  .card{ flex-basis:72vw; }
  /* Item do carrinho: foto à esquerda, nome/preço em cima,
     quantidade e remover lado a lado embaixo */
  .linha-item{
    grid-template-columns:64px 1fr auto;
    grid-auto-rows:auto;
    gap:8px 14px;
  }
  .linha-item img{ width:64px; height:80px; grid-row:1 / span 2; }
  .linha-item > div{ grid-column:2 / span 2; align-self:start; }
  .linha-item .nome{ font-size:1.1rem; }
  .linha-item .preco{ font-size:.75rem; }
  .linha-item form.qtd{ grid-column:2; justify-self:start; }
  .linha-item form:not(.qtd){ grid-column:3; justify-self:end; align-self:center; }
  .qtd button{ width:30px; height:30px; }
  .total-box{ flex-direction:column; gap:22px; align-items:stretch; text-align:center; }
  .total-box .btn{ flex:1 1 100%; text-align:center; }
  .toasts{ left:18px; right:18px; top:84px; }
}
