:root{
  --cream:#F4EEE5;     /* fondo nude */
  --cream-2:#EBE1D2;   /* secundario / chips */
  --green:#243A2C;     /* verde profundo */
  --green-deep:#192a1f;
  --gold:#C2A063;      /* dorado acento */
  --gold-deep:#A8854A;
  --pink-soft:#EFE3DC; /* fondo de imagen vacía */
  --ink:#2A2620;
  --muted:#A2967F;
  --card:#FCFAF5;      /* tarjetas, blanco cálido */
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);     /* salida suave (estilo refinado) */
  --ease-soft:cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);font-weight:300;line-height:1.55}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--gold);color:#fff}

.announce{background:var(--green);color:var(--cream);text-align:center;font-size:.68rem;
  letter-spacing:.22em;padding:.6rem;text-transform:uppercase}
.announce b{color:var(--gold);font-weight:500}

/* Header */
.header{position:sticky;top:0;z-index:40;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:1.05rem 1.5rem;background:rgba(244,238,229,.88);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(36,58,44,.1)}
.menu-btn,.cart-btn{background:none;border:none;cursor:pointer;color:var(--green);font-size:1.2rem}
.menu-btn{justify-self:start}
.cart-btn{justify-self:end;position:relative;display:flex;align-items:center}
.cart-count{position:absolute;top:-8px;right:-10px;background:var(--gold);color:#fff;
  font-family:var(--sans);font-size:.62rem;font-weight:500;min-width:18px;height:18px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;padding:0 4px}
.logo{text-align:center;line-height:1}
.logo-name{font-family:var(--serif);font-size:1.85rem;font-weight:600;color:var(--green);letter-spacing:.07em}
.logo-name .tilde{color:var(--gold);font-weight:500;margin:0 -.04em}
.logo-sub{display:block;font-size:.58rem;letter-spacing:.5em;color:var(--gold-deep);margin-top:3px;padding-left:.5em}

/* Hero */
.hero{text-align:center;padding:5rem 1.5rem 4rem;background:
  radial-gradient(130% 100% at 50% -20%, #EFE6D6 0%, var(--cream) 60%);position:relative}
.hero-kicker{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:1.3rem}
.hero-title{font-family:var(--serif);font-weight:500;font-size:clamp(2.6rem,7vw,4.3rem);color:var(--green);line-height:1.04}
.hero-title em{font-style:italic;color:var(--gold-deep)}
.hero-text{max-width:31rem;margin:1.3rem auto 2rem;color:#6a6052;font-size:1.02rem}
.hero-cta{display:inline-block;background:var(--green);color:var(--cream);padding:.9rem 2.4rem;border-radius:999px;
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;transition:.3s}
.hero-cta:hover{background:var(--gold);color:#fff;transform:translateY(-2px);box-shadow:0 10px 24px rgba(194,160,99,.35)}
.hero-kicker,.hero-title,.hero-text,.hero-cta{opacity:0;transform:translateY(16px);animation:fadeUp .9s var(--ease) forwards}
.hero-title{animation-delay:.08s}
.hero-text{animation-delay:.18s}
.hero-cta{animation-delay:.28s}
@keyframes fadeUp{to{opacity:1;transform:none}}
@keyframes cardIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* Shop */
.shop{max-width:1240px;margin:0 auto;padding:3rem 1.3rem 4rem}
.shop-controls{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;
  position:sticky;top:62px;z-index:30;background:var(--cream);padding:.7rem 0;margin-bottom:.3rem}
.cats{display:flex;flex-wrap:wrap;gap:.5rem}
.cat{background:none;border:1px solid rgba(36,58,44,.22);color:var(--green);font-family:var(--sans);
  font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;padding:.5rem 1.15rem;border-radius:999px;cursor:pointer;transition:.22s}
.cat:hover{border-color:var(--gold);color:var(--gold-deep)}
.cat.active{background:var(--green);color:var(--cream);border-color:var(--green)}
.search{border:1px solid rgba(36,58,44,.22);background:var(--card);border-radius:999px;padding:.6rem 1.2rem;
  font-family:var(--sans);font-size:.82rem;min-width:240px;color:var(--ink)}
.search:focus{outline:none;border-color:var(--gold)}
.count-line{font-size:.72rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin:.4rem 0 1.7rem}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:2rem 1.4rem}
.card{background:var(--card);border-radius:12px;overflow:hidden;cursor:pointer;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);display:flex;flex-direction:column;
  opacity:0;animation:cardIn .6s var(--ease) forwards}
.card:hover{transform:translateY(-7px);box-shadow:0 0 0 1.5px var(--gold),0 20px 40px rgba(36,58,44,.16)}
.card-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--pink-soft);border-radius:12px}
.card-img img{width:100%;height:100%;object-fit:cover;opacity:0;
  transition:transform .65s var(--ease),opacity .6s var(--ease-soft)}
.card-img img.loaded{opacity:1}
.card-img.sold img{filter:grayscale(.45);opacity:.55}
.sold-badge{position:absolute;top:.7rem;left:.7rem;background:rgba(36,58,44,.92);color:var(--cream);
  font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .7rem;border-radius:999px}
.low-badge{position:absolute;top:.7rem;left:.7rem;background:rgba(194,160,99,.95);color:#fff;
  font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:.28rem .65rem;border-radius:999px}
.card:hover .card-img img{transform:scale(1.06)}
.card-img.empty{display:flex;align-items:center;justify-content:center;color:#c9b8a6;
  font-family:var(--serif);font-size:1.05rem;letter-spacing:.1em}
.card-body{padding:.85rem .25rem .3rem;display:flex;flex-direction:column;gap:.15rem;flex:1}
.card-name{font-family:var(--serif);font-size:1.12rem;color:var(--green);font-weight:500;line-height:1.18}
.card-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:.4rem}
.card-price{font-family:var(--serif);font-size:1.3rem;color:var(--ink);font-weight:500}
.add-btn{background:var(--green);color:var(--cream);border:none;border-radius:50%;width:34px;height:34px;
  font-size:1.15rem;cursor:pointer;transition:.25s;display:flex;align-items:center;justify-content:center;line-height:1}
.add-btn:hover{background:var(--gold);color:#fff;transform:scale(1.12)}
.add-btn.added{background:var(--gold);color:#fff}

/* Cargar más */
.load-more-wrap{text-align:center;margin-top:3rem}
.load-more{background:none;border:1px solid var(--gold);color:var(--gold-deep);font-family:var(--sans);
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;padding:.85rem 2.6rem;border-radius:999px;cursor:pointer;transition:.25s}
.load-more:hover{background:var(--gold);color:#fff}

/* Footer */
.footer{background:var(--green);color:var(--cream);display:grid;grid-template-columns:repeat(3,1fr);
  gap:2rem;padding:3.5rem 2rem 2.2rem;margin-top:3rem}
.foot-col h3{font-family:var(--serif);font-weight:500;font-size:1.4rem;margin-bottom:.8rem;color:var(--gold)}
.foot-col p{font-size:.82rem;margin-bottom:.4rem;opacity:.88}
.foot-col a{transition:.2s}
.foot-col a:hover{color:var(--gold)}
.foot-logo{grid-column:1/-1;height:46px;width:auto;display:block;box-sizing:content-box;
  margin:1.6rem auto 0;padding-top:1.9rem;border-top:1px solid rgba(244,238,229,.16)}

/* Drawer carrito */
.overlay{position:fixed;inset:0;background:rgba(25,42,31,.5);opacity:0;visibility:hidden;
  transition:opacity .4s var(--ease-soft),visibility .4s;z-index:50}
.overlay.show{opacity:1;visibility:visible}
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:min(400px,90vw);background:var(--cream);z-index:60;
  transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column}
.cart-drawer.show{transform:translateX(0)}
.cart-head{display:flex;justify-content:space-between;align-items:center;padding:1.4rem 1.4rem 1rem;border-bottom:1px solid rgba(36,58,44,.1)}
.cart-head h2{font-family:var(--serif);font-weight:500;font-size:1.7rem;color:var(--green)}
.close-btn{background:none;border:none;font-size:1.15rem;cursor:pointer;color:var(--green)}
.cart-items{flex:1;overflow:auto;padding:1.1rem 1.4rem}
.cart-empty{color:var(--muted);text-align:center;margin-top:3rem;font-size:.9rem}
.ci{display:flex;gap:.85rem;padding:.85rem 0;border-bottom:1px solid rgba(36,58,44,.08)}
.ci img{width:64px;height:64px;object-fit:cover;border-radius:8px;background:var(--pink-soft)}
.ci-info{flex:1}
.ci-name{font-family:var(--serif);font-size:1.08rem;color:var(--green);line-height:1.1}
.ci-code{font-size:.62rem;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;margin-top:.15rem}
.ci-qty{display:flex;align-items:center;gap:.55rem;margin-top:.45rem}
.ci-qty button{width:22px;height:22px;border:1px solid rgba(36,58,44,.28);background:none;border-radius:50%;cursor:pointer;color:var(--green)}
.ci-qty button:hover{border-color:var(--gold);color:var(--gold-deep)}
.ci-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.7rem;align-self:flex-start;text-decoration:underline}
.cart-foot{padding:1.3rem 1.4rem;border-top:1px solid rgba(36,58,44,.12)}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--serif);
  font-size:1.5rem;color:var(--green);margin-bottom:1.1rem}
.cart-total span:last-child{color:var(--gold-deep)}
.checkout-btn{width:100%;color:#fff;border:none;padding:.95rem;border-radius:999px;
  font-family:var(--sans);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:.25s}
.pay-btn{background:#009EE3;margin-bottom:.6rem}
.pay-btn:hover{background:#007eb8}
.pay-btn:disabled{opacity:.6;cursor:default}
.wa-btn{background:var(--green)}
.wa-btn:hover{background:var(--gold)}
.cart-note{font-size:.68rem;color:var(--muted);text-align:center;margin-top:.8rem}

/* Modal producto */
.product-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-46%) scale(.97);z-index:60;
  background:var(--cream);border-radius:16px;width:min(780px,92vw);max-height:90vh;overflow:auto;
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease-soft),transform .5s var(--ease),visibility .35s;
  display:grid;grid-template-columns:1fr 1fr}
.product-modal.show{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.pm-img{aspect-ratio:1/1;background:var(--pink-soft)}
.pm-img img{width:100%;height:100%;object-fit:cover}
.pm-body{padding:2.2rem;display:flex;flex-direction:column;position:relative}
.pm-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--green)}
.pm-cat{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep)}
.pm-name{font-family:var(--serif);font-size:2.1rem;color:var(--green);font-weight:500;line-height:1.1;margin:.4rem 0}
.pm-code{font-size:.7rem;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
.pm-mat{margin:.9rem 0;font-size:.85rem;color:#6a6052}
.pm-mat span{display:inline-block;background:var(--cream-2);padding:.32rem .85rem;border-radius:999px;font-size:.72rem;color:var(--green)}
.pm-price{font-family:var(--serif);font-size:2.3rem;color:var(--ink);margin:.5rem 0 1.5rem;font-weight:500}
.pm-add{background:var(--green);color:var(--cream);border:none;padding:.95rem;border-radius:999px;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:.25s}
.pm-add:hover{background:var(--gold)}

@media(max-width:640px){
  .shop-controls{position:static}
  .grid{grid-template-columns:repeat(2,1fr);gap:1.4rem .9rem}
  .card-name{font-size:1rem}
  .card-price{font-size:1.15rem}
  .footer{grid-template-columns:1fr;gap:1.5rem;text-align:center}
  .product-modal{grid-template-columns:1fr;top:0;left:0;transform:none;width:100vw;height:100%;max-height:100%;border-radius:0}
  .product-modal.show{transform:none}
  .search{flex:1}
}

/* Si el usuario prefiere menos movimiento, desactivamos animaciones */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .card,.hero-kicker,.hero-title,.hero-text,.hero-cta,.card-img img{opacity:1!important;transform:none!important}
}
