/* ===================================================================
   varejo.lafym.studio — extensão direta da estética institucional
   (mesmos tokens de cor/tipografia do _shared/base.css), com componentes
   próprios de catálogo: card de produto, galeria simples, "onde comprar".
   =================================================================== */
.hero{padding-top:64px;}

/* ── Grid de produtos ─────────────────────────────── */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media(max-width:1024px){.product-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:680px){.product-grid{grid-template-columns:repeat(2,1fr);gap:12px;}}
@media(max-width:400px){.product-grid{grid-template-columns:1fr;}}

/* ── Card de produto ──────────────────────────────── */
.product-card{position:relative;background:var(--bg-card);border:1px solid var(--line);cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left;}
.product-card:hover{border-color:var(--brown);box-shadow:0 4px 18px rgba(74,51,38,.10);}
.product-card-top{position:relative;aspect-ratio:3/2;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--line);
  background-image:repeating-linear-gradient(0deg, rgba(74,51,38,0.07) 0px, rgba(74,51,38,0.07) 1px, transparent 1px, transparent 6px);}
.product-card-top .code{font-family:var(--display);font-weight:700;font-size:30px;color:var(--brown);}
.product-card-top .corner{position:absolute;font-family:var(--mono);font-size:11px;color:var(--blue);}
.product-card-top .corner.tl{top:6px;left:7px;} .product-card-top .corner.tr{top:6px;right:7px;}
.product-card-top .status-tag{position:absolute;bottom:8px;right:8px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);background:var(--blue-light);padding:3px 7px;}
.product-card-body{padding:16px 18px 18px;}
.product-card-body h3{font-family:var(--display);font-weight:600;font-size:15px;line-height:1.35;margin-bottom:8px;}
.product-card-body .price{font-family:var(--mono);font-size:15px;font-weight:700;color:var(--ink);margin:0;}
.product-card-body .see-more{font-family:var(--mono);font-size:11px;color:var(--ink-soft);margin:8px 0 0;letter-spacing:.03em;}

.cat-row-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;}
.cat-row-head h2{font-size:22px;}

/* ── Modal de produto ─────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(30,20,10,.55);z-index:1000;align-items:center;justify-content:center;padding:20px;}
.modal-overlay.open{display:flex;}
.modal-box{background:var(--bg);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;position:relative;border:1px solid var(--line);}
.modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--ink-soft);line-height:1;padding:0;}
.modal-close:hover{color:var(--ink);}
.modal-header{display:flex;align-items:center;gap:16px;padding:24px 24px 0;border-bottom:1px solid var(--line);padding-bottom:20px;}
.modal-header .code{font-family:var(--display);font-weight:700;font-size:28px;color:var(--brown);flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);
  background-image:repeating-linear-gradient(0deg, rgba(74,51,38,0.07) 0px, rgba(74,51,38,0.07) 1px, transparent 1px, transparent 6px);}
.modal-header-text{flex:1;}
.modal-header-text .modal-badge{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);background:var(--blue-light);padding:2px 7px;display:inline-block;margin-bottom:6px;}
.modal-header-text h2{font-family:var(--display);font-size:20px;font-weight:700;margin:0;}
.modal-info{padding:20px 24px 24px;}
.modal-price{font-family:var(--mono);font-size:28px;font-weight:700;color:var(--ink);margin:0 0 12px;}
.modal-desc{font-size:14px;color:var(--ink-soft);margin:0 0 18px;line-height:1.6;}
.specs-table{width:100%;border-collapse:collapse;font-size:13px;margin:0 0 20px;}
.specs-table td{padding:9px 0;border-top:1px solid var(--line);}
.specs-table td:first-child{color:var(--ink-soft);width:42%;}
.buy-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.buy-card{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--ink);padding:13px 15px;font-family:var(--mono);font-size:13px;text-decoration:none;color:var(--ink);}
.buy-card:hover{background:var(--line-soft);}
.modal-footnote{font-size:11px;color:var(--ink-soft);margin:10px 0 0;}

/* ── Página de produto individual ─────────────────── */
.breadcrumb{max-width:1180px;margin:18px auto 0;padding:0 28px;font-size:13px;color:var(--ink-soft);}
.breadcrumb a:hover{color:var(--ink);}
.product-detail{display:grid;grid-template-columns:1.05fr 1fr;gap:40px;}
.product-gallery-main{position:relative;aspect-ratio:4/3;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  background-image:repeating-linear-gradient(0deg, rgba(74,51,38,0.08) 0px, rgba(74,51,38,0.08) 1px, transparent 1px, transparent 6px);}
.product-gallery-main .code{font-family:var(--display);font-weight:700;font-size:40px;color:var(--brown);}
.product-price-lg{font-family:var(--mono);font-size:24px