/* Latin Grocer — mercado latino
   Palette sampled from brand: logo papel, ink; IG habanero rust, market verde */
:root{
  --papel:#F4EDE4;
  --papel-2:#ECE2D2;
  --ink:#211A11;
  --ink-soft:#4A4033;
  --rust:#8A330D;
  --rust-deep:#7A2B08;
  --verde:#173712;
  --line:#D8CCB8;
  --gold:#B98A2F;
  --maxw:1180px;
  --serif:"Fraunces",Georgia,serif;
  --sys:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important}}
body{margin:0;background:var(--papel);color:var(--ink);font-family:var(--sys);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit}
img{max-width:100%;height:auto;display:block}

/* ---------- header ---------- */
.hdr{border-bottom:1px solid var(--line);background:var(--papel);position:sticky;top:0;z-index:20}
.hdr-in{max-width:var(--maxw);margin:0 auto;padding:10px 20px;display:flex;align-items:center;gap:14px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand img{width:auto;height:36px}
.brand b{font-family:var(--serif);font-weight:600;font-size:1.25rem;letter-spacing:-.01em;white-space:nowrap}
.brand small{display:block;font-size:.62rem;letter-spacing:.32em;text-transform:lowercase;color:var(--ink-soft);font-family:var(--serif);font-style:italic}
.hdr-spc{flex:1}
.hdr a.nav{text-decoration:none;font-size:.85rem;color:var(--ink-soft);padding:6px 8px}
.hdr a.nav:hover{color:var(--ink)}
.btn-wa{background:var(--rust);color:#fff;text-decoration:none;font-weight:600;font-size:.85rem;padding:9px 16px;border-radius:999px;white-space:nowrap}
.btn-wa:hover{background:var(--rust-deep)}

/* ---------- hero ---------- */
.hero{max-width:var(--maxw);margin:0 auto;padding:40px 20px 26px;text-align:center}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,4.4vw,2.8rem);line-height:1.08;margin:0 auto 10px;letter-spacing:-.015em;max-width:24ch}
.hero h1 em{font-style:italic;color:var(--rust)}
.hero p{margin:0 auto 20px;color:var(--ink-soft);max-width:58ch}
.hero p b{color:var(--ink)}

/* ---------- directory (El Índice) ---------- */
.indice{max-width:var(--maxw);margin:0 auto;padding:8px 20px 48px}
.indice-head{display:flex;align-items:baseline;gap:12px;border-bottom:2px solid var(--ink);padding-bottom:8px;margin-bottom:4px}
.indice-head h2{font-family:var(--serif);font-weight:600;font-size:1.15rem;margin:0}
.indice-head span{font-size:.78rem;color:var(--ink-soft)}
.cols{column-count:3;column-gap:40px}
@media(max-width:960px){.cols{column-count:2}}
@media(max-width:640px){.cols{column-count:1}}
.cat{break-inside:avoid;padding:16px 0 6px}
.cat summary,.cat .cat-h{list-style:none;cursor:pointer;display:flex;align-items:baseline;gap:8px}
.cat summary::-webkit-details-marker{display:none}
.cat h3{font-family:var(--serif);font-weight:600;font-size:1.02rem;margin:0;color:var(--verde)}
.cat .n{font-size:.72rem;color:var(--ink-soft)}
/* pyramid-step rule under category names */
.cat .steps{height:7px;margin:6px 0 8px;background:
  linear-gradient(var(--ink),var(--ink)) 0 100%/56px 2px no-repeat,
  linear-gradient(var(--ink),var(--ink)) 8px 3px/40px 2px no-repeat,
  linear-gradient(var(--ink),var(--ink)) 16px 0/24px 2px no-repeat;opacity:.85}
ul.rows{list-style:none;margin:0;padding:0}
.rows li{padding:0}
.rows a,.rows .soon{display:flex;align-items:baseline;gap:6px;text-decoration:none;padding:4.5px 2px;border-radius:4px;font-size:.875rem}
.rows a:hover{background:var(--papel-2)}
.rows .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1}
.rows .dots{flex:1;border-bottom:1.5px dotted var(--line);transform:translateY(-3px);min-width:12px}
.rows .pr{color:var(--ink-soft);font-size:.8rem;white-space:nowrap;font-variant-numeric:tabular-nums}
.rows .pr b{color:var(--ink);font-weight:600}
.tagx{display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.06em;color:var(--rust);border:1px solid currentColor;border-radius:3px;padding:0 4px;transform:translateY(-1px)}
.heatd{display:inline-flex;gap:2px;transform:translateY(-1px)}
.heatd i{width:9px;height:3.5px;background:var(--line);border-radius:1px}
.heatd i.on{background:var(--rust)}
li.hidden{display:none}
.cat.hidden{display:none}

/* ---------- product page ---------- */
.crumb{max-width:var(--maxw);margin:0 auto;padding:14px 20px 0;font-size:.78rem;color:var(--ink-soft)}
.crumb a{text-decoration:none;color:inherit}
.crumb a:hover{color:var(--ink)}
.pd{max-width:var(--maxw);margin:0 auto;padding:18px 20px 42px;display:grid;grid-template-columns:minmax(0,460px) 1fr;gap:44px;align-items:start}
@media(max-width:820px){.pd{grid-template-columns:1fr;gap:22px}}
.pd-img{background:var(--papel-2);border:1px solid var(--line);border-radius:14px;overflow:hidden;aspect-ratio:1}
.pd-img img{width:100%;height:100%;object-fit:cover}
.pd-img.ph{display:grid;place-items:center;position:relative}
.pd-img.ph span{position:absolute;bottom:14px;left:0;right:0;text-align:center;font-size:.75rem;color:var(--ink-soft)}
.pd-img.ph img{width:44%;height:auto;opacity:.16;object-fit:contain}
.eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rust);font-weight:700;margin:2px 0 6px}
.pd h1{font-family:var(--serif);font-weight:600;font-size:clamp(1.5rem,3.4vw,2.2rem);line-height:1.1;margin:0 0 4px;letter-spacing:-.01em}
.pd .sub{color:var(--ink-soft);font-style:italic;font-family:var(--serif);margin:0 0 12px}
.meta-badges{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.badge{font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink-soft)}
.badge.only{background:var(--verde);border-color:var(--verde);color:var(--papel)}
.heat{display:flex;align-items:center;gap:10px;margin:0 0 16px}
.heat .lbl{font-size:.72rem;font-weight:700;letter-spacing:.14em}
.heat .bar{display:flex;gap:5px}
.heat .bar i{width:26px;height:6px;border-radius:2px;background:var(--line)}
.heat .bar i.on{background:var(--rust)}
.price{font-family:var(--serif);font-weight:600;font-size:1.9rem;margin:4px 0 2px;font-variant-numeric:tabular-nums}
.price small{font-size:.9rem;color:var(--ink-soft);font-family:var(--sys);font-weight:400}
.vars{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 20px}
.vpill{font:inherit;font-size:.85rem;cursor:pointer;padding:9px 15px;border-radius:999px;border:1.5px solid var(--line);background:#fff;color:var(--ink)}
.vpill[aria-pressed="true"]{border-color:var(--ink);background:var(--ink);color:var(--papel);font-weight:600}
.cta{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 10px}
.cta .buy{flex:1 1 220px;text-align:center;background:var(--rust);color:#fff;text-decoration:none;font-weight:700;font-size:.95rem;padding:14px 20px;border-radius:12px}
.cta .buy:hover{background:var(--rust-deep)}
.mkts{display:flex;gap:10px;margin:0 0 22px}
.mkts a{flex:1;text-align:center;text-decoration:none;font-size:.82rem;font-weight:600;padding:10px;border:1.5px solid var(--line);border-radius:10px;color:var(--ink-soft);background:#fff}
.mkts a:hover{border-color:var(--ink);color:var(--ink)}
.pd-desc{border-top:1px solid var(--line);padding-top:16px;color:var(--ink-soft);max-width:60ch}
.pd-desc h2{font-family:var(--serif);font-size:1rem;color:var(--ink);margin:0 0 8px}
.pd-desc p{margin:0 0 10px}
.facts{list-style:none;margin:14px 0 0;padding:0;font-size:.85rem}
.facts li{display:flex;gap:8px;padding:6px 0;border-bottom:1px dotted var(--line)}
.facts b{min-width:110px;color:var(--ink);font-weight:600}
.rel{max-width:var(--maxw);margin:0 auto;padding:0 20px 50px}
.rel h2{font-family:var(--serif);font-size:1.05rem;border-bottom:2px solid var(--ink);padding-bottom:8px}
.rel ul{list-style:none;margin:0;padding:0;column-count:2;column-gap:40px}
@media(max-width:640px){.rel ul{column-count:1}}

/* ---------- footer ---------- */
.ftr{background:var(--ink);color:var(--papel)}
.ftr-in{max-width:var(--maxw);margin:0 auto;padding:34px 20px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
@media(max-width:760px){.ftr-in{grid-template-columns:1fr}}
.ftr h4{font-family:var(--serif);font-weight:600;margin:0 0 10px;font-size:1rem}
.ftr p,.ftr a{color:#CBBFA9;font-size:.85rem;margin:0 0 6px;text-decoration:none;display:block}
.ftr a:hover{color:#fff}
.ftr .fine{grid-column:1/-1;border-top:1px solid #3A3226;padding-top:14px;font-size:.75rem;color:#8E8271}


/* ---------- category tiles (home) ---------- */
.aisles{max-width:var(--maxw);margin:0 auto;padding:6px 20px 10px}
.aisles-head{display:flex;align-items:baseline;gap:12px;border-bottom:2px solid var(--ink);padding-bottom:8px;margin-bottom:18px}
.aisles-head h2{font-family:var(--serif);font-weight:600;font-size:1.15rem;margin:0}
.aisles-head span{font-size:.78rem;color:var(--ink-soft)}
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:960px){.tile-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tile-grid{grid-template-columns:repeat(2,1fr);gap:10px}}
.tile{display:block;text-decoration:none;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
 transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.tile:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:0 8px 22px rgba(33,26,17,.08)}
.tile .im{display:block;aspect-ratio:3/2;background:var(--papel-2);position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.tile .im img.photo{width:100%;height:100%;object-fit:cover}
.imgph{position:absolute;inset:0;display:grid;place-items:center;background:var(--papel-2)}
.imgph img{width:30%;max-width:84px;opacity:.12}
.tile .tx{display:block;padding:12px 14px 14px}
.tile h3{font-family:var(--serif);font-weight:600;font-size:1.05rem;margin:0;letter-spacing:-.01em;color:var(--ink)}
.tile .idn{font-family:var(--serif);font-style:italic;font-size:.78rem;color:var(--ink-soft);display:block;margin-top:1px}
.tile .cnt{font-size:.72rem;font-weight:700;letter-spacing:.08em;color:var(--rust);display:block;margin-top:7px}

/* store info band */
.band{max-width:var(--maxw);margin:26px auto 0;padding:0 20px 44px}
.band-in{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:760px){.band-in{grid-template-columns:1fr}}
.band a{display:block;text-decoration:none;background:var(--papel-2);border:1px solid var(--line);border-radius:14px;padding:18px}
.band a:hover{border-color:var(--ink)}
.band b{font-family:var(--serif);font-weight:600;font-size:1rem;display:block;margin-bottom:4px;color:var(--ink)}
.band span{font-size:.8rem;color:var(--ink-soft)}

/* ---------- aisle page: pill bar + product card grid ---------- */
.pillbar{position:sticky;top:66px;z-index:15;background:var(--papel);border-bottom:1px solid var(--line)}
.pillbar-in{max-width:var(--maxw);margin:0 auto;padding:10px 20px;display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.pillbar-in::-webkit-scrollbar{display:none}
.pillbar a{flex:0 0 auto;font-size:.8rem;text-decoration:none;padding:7px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--ink-soft);white-space:nowrap}
.pillbar a:hover{border-color:var(--ink);color:var(--ink)}
.pillbar a[aria-current]{background:var(--ink);border-color:var(--ink);color:var(--papel);font-weight:600}
.aisle-top{max-width:var(--maxw);margin:0 auto;padding:24px 20px 6px}
.aisle-top h1{font-family:var(--serif);font-weight:600;font-size:clamp(1.5rem,3.6vw,2.2rem);line-height:1.08;margin:0 0 2px;letter-spacing:-.015em}
.aisle-top .idn{font-family:var(--serif);font-style:italic;color:var(--ink-soft);margin:0 0 8px}
.aisle-top p.intro{margin:0;color:var(--ink-soft);max-width:64ch;font-size:.92rem}
.pgrid{max-width:var(--maxw);margin:0 auto;padding:18px 20px 46px;display:grid;
 grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:14px}
@media(max-width:560px){.pgrid{grid-template-columns:repeat(2,1fr);gap:10px}}
.pcard{display:flex;flex-direction:column;text-decoration:none;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;
 transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.pcard:hover{transform:translateY(-2px);border-color:var(--ink);box-shadow:0 6px 16px rgba(33,26,17,.07)}
.pcard .im{display:block;aspect-ratio:1;background:var(--papel-2);position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.pcard .im img.photo{width:100%;height:100%;object-fit:cover}
.pcard .tx{padding:10px 12px 12px;display:flex;flex-direction:column;flex:1}
.pcard h3{font-size:.88rem;font-weight:600;margin:0;color:var(--ink);line-height:1.3;
 display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pcard .idn{font-size:.72rem;color:var(--ink-soft);font-style:italic;font-family:var(--serif);margin-top:1px}
.pcard .heatd{margin-top:5px}
.pcard .pr{margin-top:auto;padding-top:8px;font-size:.8rem;color:var(--ink-soft)}
.pcard .pr b{color:var(--ink);font-weight:600;font-size:.92rem}
.other-aisles{max-width:var(--maxw);margin:0 auto;padding:0 20px 50px}
.other-aisles h2{font-family:var(--serif);font-size:1.02rem;border-bottom:2px solid var(--ink);padding-bottom:8px}
.other-aisles .links{display:flex;flex-wrap:wrap;gap:8px}
.other-aisles .links a{font-size:.8rem;text-decoration:none;padding:7px 13px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--ink-soft)}
.other-aisles .links a:hover{border-color:var(--ink);color:var(--ink)}

/* action buttons */
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px;justify-content:center}
.btn{display:inline-block;text-decoration:none;font-size:.88rem;font-weight:600;padding:11px 18px;
 border-radius:999px;border:1.5px solid var(--ink);color:var(--ink);background:transparent}
.btn:hover{background:var(--papel-2)}
.btn.solid{background:var(--rust);border-color:var(--rust);color:#fff}
.btn.solid:hover{background:var(--rust-deep);border-color:var(--rust-deep)}

/* request banner (home) */
.req-banner{max-width:var(--maxw);margin:30px auto 0;padding:0 20px 46px}
.req-in{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
 background:var(--verde);color:var(--papel);border-radius:16px;padding:24px 26px}
.req-in h2{font-family:var(--serif);font-weight:600;font-size:1.3rem;margin:0 0 4px}
.req-in p{margin:0;font-size:.88rem;color:#D9D2C0;max-width:52ch}
.req-in .btn.solid{background:var(--papel);border-color:var(--papel);color:var(--verde)}
.req-in .btn.solid:hover{background:#fff;border-color:#fff}

/* request line (aisle pages) */
.req-line{max-width:var(--maxw);margin:-18px auto 0;padding:0 20px 46px;font-size:.85rem;color:var(--ink-soft)}
.req-line a{color:var(--rust);font-weight:600}

/* request form */
.req-form{max-width:620px;margin:0 auto;padding:20px 20px 56px}
.req-form label{display:block;font-size:.85rem;font-weight:600;margin:0 0 16px;color:var(--ink)}
.req-form .opt{font-weight:400;color:var(--ink-soft)}
.req-form input,.req-form textarea{display:block;width:100%;margin-top:6px;font:inherit;font-size:.92rem;
 padding:11px 14px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--ink)}
.req-form input:focus,.req-form textarea:focus{outline:none;border-color:var(--rust);box-shadow:0 0 0 3px rgba(138,51,13,.15)}
.req-form button{font:inherit;cursor:pointer;width:100%;margin-top:4px}
.req-form .alt{font-size:.82rem;color:var(--ink-soft);text-align:center;margin-top:14px}
.req-form .alt a{color:var(--rust);font-weight:600}
.req-form .ok{margin-top:14px;background:var(--verde);color:var(--papel);padding:12px 16px;border-radius:10px;font-size:.9rem;text-align:center}

/* contact page */
.aisle-top.center{text-align:center}
.aisle-top.center .intro{margin:0 auto}
.req-h{font-family:var(--serif);font-weight:600;font-size:clamp(1.3rem,3vw,1.8rem);margin:8px 0 4px;letter-spacing:-.01em}
.chan-wrap{max-width:var(--maxw);margin:0 auto;padding:22px 20px 8px}
.chan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:980px;margin:0 auto}
@media(max-width:960px){.chan-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.chan-grid{grid-template-columns:1fr}}
.chan{display:block;text-decoration:none;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;
 transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.chan:hover{transform:translateY(-2px);border-color:var(--ink);box-shadow:0 6px 16px rgba(33,26,17,.07)}
.chan b{font-family:var(--serif);font-weight:600;font-size:1.02rem;display:block;color:var(--ink);margin-bottom:2px}
.chan span{display:block;font-size:.86rem;color:var(--rust);font-weight:600}
.chan .d{font-size:.76rem;color:var(--ink-soft);font-weight:400;margin-top:5px}

/* topline banner */
.topline{background:var(--verde);color:var(--papel);text-align:center;font-size:.78rem;padding:8px 16px;letter-spacing:.01em}

/* header order dropdown */
.order-dd{position:relative}
.order-dd summary{list-style:none;cursor:pointer;display:inline-block;padding:9px 16px;font-size:.85rem}
.order-dd summary::-webkit-details-marker{display:none}
.order-dd .car{font-size:.7em;margin-left:3px}
.dd-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:170px;background:#fff;border:1px solid var(--line);
 border-radius:12px;box-shadow:0 10px 26px rgba(33,26,17,.14);padding:6px;z-index:40}
.dd-menu a{display:block;text-decoration:none;font-size:.88rem;font-weight:600;color:var(--ink);padding:10px 12px;border-radius:8px}
.dd-menu a:hover{background:var(--papel-2)}

/* hours */
.ftr .hours{margin-top:10px;font-size:.8rem;color:#CBBFA9;line-height:1.6}
.ftr .hours b{color:var(--papel)}
.hours-note{max-width:980px;margin:14px auto 0;text-align:center;font-size:.8rem;color:var(--ink-soft)}

.tl-short{display:none}
@media(max-width:640px){
 .topline{font-size:.72rem;padding:7px 12px}
 .tl-full{display:none}.tl-short{display:inline}
 .brand span{display:none}
 .hdr-in{gap:10px}
}
