:root{
  --ink:#16130f; --ink-2:#3a352e; --muted:#7a7064; --line:#e7e1d6;
  --cream:#f6f3ee; --paper:#fffdfa; --accent:#16130f; --out:#b3261e;
  --maxw:1180px; --radius:12px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.55;font-size:15px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.narrow{max-width:620px}
.center{text-align:center}
.muted{color:var(--muted)}

/* ---------- header ---------- */
.hd{position:sticky;top:0;z-index:50;background:rgba(255,253,250,.92);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--line)}
.hd__top{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;max-width:var(--maxw);margin:0 auto;padding:14px 20px}
.hd__search{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;padding:7px 14px;background:var(--paper);max-width:300px}
.hd__search button{background:none;border:0;color:var(--muted);display:flex}
.hd__search input{border:0;outline:0;background:none;font-size:14px;width:100%}
.hd__brand{justify-self:center}
.hd__brand img{height:46px;width:auto}
.hd__icons{display:flex;gap:18px;justify-self:end;align-items:center}
.hd__icons a{color:var(--ink);display:flex;position:relative}
.hd__badge{position:absolute;top:-7px;right:-9px;background:var(--ink);color:#fff;font-size:10px;min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.hd__nav{display:flex;gap:22px;justify-content:center;padding:0 20px 12px;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
.hd__nav a{font-size:13px;letter-spacing:.02em;color:var(--ink-2);padding:4px 0;border-bottom:1.5px solid transparent}
.hd__nav a:hover{color:var(--ink)}
.hd__nav a.is-active{color:var(--ink);border-bottom-color:var(--ink)}

/* ---------- hero strip ---------- */
.hero-strip{background:var(--ink);color:#f1ece4}
.hero-strip .container{display:flex;gap:14px;justify-content:center;padding:11px 20px;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.hero-strip .sep{opacity:.4}

/* ---------- sections ---------- */
section.container{padding-top:46px;padding-bottom:10px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.sec-title{font-family:var(--serif);font-size:30px;font-weight:600;letter-spacing:.01em}
.tabs{display:flex;gap:6px}
.tab{background:none;border:0;font-size:14px;color:var(--muted);padding:6px 14px;border-radius:999px;font-weight:600}
.tab.is-active{background:var(--ink);color:#fff}

/* ---------- grid + cards ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:20px}
.tab-panel{display:none}.tab-panel.is-active{display:grid}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -18px rgba(20,16,12,.4)}
.card__media{position:relative;aspect-ratio:1;background:var(--cream) center/cover no-repeat;display:block}
.badge{position:absolute;top:10px;left:10px;background:var(--ink);color:#fff;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:4px}
.badge--out{background:#6f675a;left:auto;right:10px}
.card__body{padding:13px 14px 15px;display:flex;flex-direction:column;gap:8px;flex:1}
.card__name{font-size:14px;line-height:1.35;font-weight:500;color:var(--ink)}
.card__price{font-size:15px;display:flex;align-items:baseline;gap:8px;margin-top:auto}
.card__price s{color:#b6ac9c;font-size:13px}
.card__price strong{font-weight:700}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--ink);color:#fff;border:1px solid var(--ink);padding:11px 20px;border-radius:8px;font-size:14px;font-weight:600;transition:.15s}
.btn:hover{background:#000;border-color:#000}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--cream)}
.btn--add{width:100%;padding:9px}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---------- category tiles ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:20px}
.cat-tile{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;background:var(--ink) center/cover no-repeat;display:flex;align-items:flex-end;padding:16px;color:#fff}
.cat-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.55))}
.cat-tile span{position:relative;z-index:1;font-family:var(--serif);font-size:22px;font-weight:600}

/* ---------- breadcrumb ---------- */
.crumb{font-size:13px;color:var(--muted);margin-bottom:22px}
.crumb a:hover{color:var(--ink)}

/* ---------- catalog ---------- */
.catalog{display:grid;grid-template-columns:230px 1fr;gap:32px;align-items:start}
.filters h3{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:18px 0 10px}
.filter-cats{list-style:none}
.filter-cats li a{display:block;padding:6px 0;font-size:14px;color:var(--ink-2)}
.filter-cats li a:hover,.filter-cats li a.is-active{color:var(--ink);font-weight:600}
.filter-form{display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.check{display:flex;align-items:center;gap:8px;font-size:14px}
.range{display:flex;gap:8px}
.range input{width:90px}
input[type=number],input[type=text],input[type=email],input[type=search],select{border:1px solid var(--line);border-radius:8px;padding:9px 11px;font-size:14px;font-family:inherit;background:var(--paper);color:var(--ink)}
.catalog__bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:16px;flex-wrap:wrap}
.sortf label{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px}
.empty{padding:40px 0}

/* ---------- product page ---------- */
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;margin-bottom:20px}
.pdp__main{aspect-ratio:1;background:var(--cream) center/cover no-repeat;border-radius:var(--radius);border:1px solid var(--line)}
.pdp__thumbs{display:flex;gap:10px;margin-top:12px}
.pdp__thumb{width:64px;height:64px;border-radius:8px;border:1px solid var(--line);background:var(--cream) center/cover no-repeat;cursor:pointer}
.pdp__thumb.is-active{outline:2px solid var(--ink)}
.pdp__name{font-family:var(--serif);font-size:34px;font-weight:600;line-height:1.1;margin-bottom:14px}
.pdp__price{display:flex;align-items:baseline;gap:12px;font-size:24px;margin-bottom:8px}
.pdp__price s{color:#b6ac9c;font-size:18px}
.pdp__price strong{font-weight:700}
.pdp__stock{font-size:14px;color:#1e6b34;margin-bottom:22px}
.pdp__stock.is-out{color:var(--out)}
.pdp__buy{display:flex;gap:12px;margin-bottom:28px}
.qty{width:72px;text-align:center}
.pdp__desc h3{font-size:15px;margin-bottom:8px}
.pdp__desc p{color:var(--ink-2)}

/* ---------- footer ---------- */
.ft{margin-top:64px;border-top:1px solid var(--line);background:var(--cream)}
.ft__strip{display:flex;gap:14px;justify-content:center;padding:16px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);border-bottom:1px solid var(--line)}
.ft__dot{opacity:.4}
.ft__cols{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:30px;padding:42px 20px}
.ft__brand img{height:46px;margin-bottom:12px}
.ft__brand p{color:var(--muted);font-size:14px}
.ft__col h4{font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.ft__col a,.ft__col p{display:block;color:var(--ink-2);font-size:14px;padding:3px 0}
.ft__col a:hover{color:var(--ink)}
.ft__base{text-align:center;padding:18px;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}
.display{font-family:var(--serif);font-size:64px}

/* ---------- add form en card ---------- */
.card .add-form{margin-top:auto}
.card .add-form .btn--add{margin-top:0}

/* ---------- carrito / checkout ---------- */
.cart,.checkout{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start;margin-top:8px}
.citem{display:grid;grid-template-columns:84px 1fr 90px 110px;gap:16px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}
.citem__img{width:84px;height:84px;border-radius:10px;background:var(--cream) center/cover no-repeat;border:1px solid var(--line)}
.citem__name{font-weight:500;display:block;margin-bottom:4px}
.citem__line{text-align:right;font-weight:700}
.cart__actions{margin-top:18px}
.summary{border:1px solid var(--line);border-radius:var(--radius);padding:22px;background:var(--cream)}
.summary h3{font-size:16px;margin-bottom:14px}
.summary__row{display:flex;justify-content:space-between;gap:12px;padding:7px 0;font-size:14px}
.summary__total{border-top:1px solid var(--line);margin-top:6px;padding-top:12px;font-size:17px}
.checkout__form{display:flex;flex-direction:column;gap:14px}
.checkout__form h3{font-size:16px}
.checkout__form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);font-weight:600}
.checkout__form input,.checkout__form textarea{font-weight:400;color:var(--ink);width:100%}
.checkout__method{background:var(--cream);border:1px solid var(--line);border-radius:10px;padding:14px 16px;font-size:14px;line-height:1.7}
.err{color:var(--out);font-size:12px;font-weight:500}

/* ---------- pedido recibido ---------- */
.received{padding-top:60px}
.received__check{color:#1e6b34;display:flex;justify-content:center;margin-bottom:8px}
.received__box{border:1px solid var(--line);border-radius:var(--radius);padding:22px;background:var(--cream);text-align:left;max-width:460px;margin:24px auto}
.btn--wa{background:#25d366;border-color:#25d366;color:#06321a}
.btn--wa:hover{background:#1ebe5b;border-color:#1ebe5b}

/* ---------- legal ---------- */
.legal{padding-top:40px;line-height:1.7}
.legal h1{margin-bottom:18px}
.legal h3{margin:24px 0 8px;font-size:17px}
.legal ul{margin:0 0 8px 20px}
.legal p{margin-bottom:10px;color:var(--ink-2)}
.display.sm{font-size:40px}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .catalog{grid-template-columns:1fr}
  .filters{border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
  .pdp{grid-template-columns:1fr;gap:24px}
  .ft__cols{grid-template-columns:1fr 1fr;gap:24px}
  .cart,.checkout{grid-template-columns:1fr}
}
@media(max-width:560px){
  .hd__top{grid-template-columns:1fr auto;row-gap:10px}
  .hd__search{grid-row:2;grid-column:1/-1;max-width:none}
  .hd__brand{order:-1}
  .grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .sec-title{font-size:24px}
  .ft__cols{grid-template-columns:1fr}
}
