/* ===================================================================
   Gold Room Props — v3  "The Catalog"
   Light industrial / spec-sheet. Simple, straight, to the point.
   =================================================================== */
:root{
  --paper:#f4f2ec;
  --paper-2:#ece8df;
  --card:#ffffff;
  --ink:#16171a;
  --ink-2:#3c3f44;
  --muted:#615f58;        /* warm gray — AA on paper */
  --line:#d9d4c8;
  --line-2:#c5bfb0;
  --accent:#c2410d;       /* burnt safety orange — AA on white + paper */
  --accent-2:#a5360b;     /* darker for hover/ink */
  --ok:#2f6b3a;
  --ff-disp:"Archivo", system-ui, -apple-system, sans-serif;
  --ff-body:"Inter", system-ui, -apple-system, sans-serif;
  --ff-mono:"IBM Plex Mono", ui-monospace, "SF Mono", monospace;
  --wrap:1180px;
  --rule:1px solid var(--line);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--ff-body);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(18px,4vw,40px)}

/* faint blueprint grid, very subtle */
.gridbg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--ink) 1px,transparent 1px),
                   linear-gradient(90deg,var(--ink) 1px,transparent 1px);
  background-size:46px 46px;opacity:.025;
}
main,header,footer{position:relative;z-index:1}

/* ---- type ---- */
h1,h2,h3,h4{font-family:var(--ff-disp);margin:0;font-weight:800;letter-spacing:-.01em;line-height:1.02}
.eyebrow{
  font-family:var(--ff-mono);font-size:.7rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.24em;color:var(--accent);display:inline-flex;align-items:center;gap:.6em;margin:0;
}
.eyebrow::before{content:"";width:18px;height:2px;background:var(--accent);display:inline-block}
.eyebrow.plain::before{display:none}
.sect-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:2.2rem}
.sect-title{font-size:clamp(1.7rem,3.6vw,2.7rem);text-transform:uppercase}
.lead{font-size:clamp(1rem,1.4vw,1.16rem);color:var(--ink-2);max-width:54ch}
.mono{font-family:var(--ff-mono)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;cursor:pointer;
  font-family:var(--ff-mono);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.13em;
  padding:.92rem 1.5rem;border:1.5px solid var(--ink);border-radius:0;background:transparent;color:var(--ink);
  transition:background .18s,color .18s,border-color .18s,transform .18s;line-height:1;
}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(4px)}
.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-2);border-color:var(--accent-2)}
.btn-line:hover{background:var(--ink);color:var(--paper)}
.btn-ghost{border-color:var(--line-2);color:var(--ink-2)}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn-sm{padding:.62rem 1rem;font-size:.66rem}

/* ---- utility top bar ---- */
.ubar{background:var(--ink);color:#cfcabd;font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase}
.ubar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:.5rem;padding-bottom:.5rem}
.ubar a{color:#fff}
.ubar a:hover{color:var(--accent)}
.ubar .dot{color:var(--accent)}
.ubar .right{display:flex;gap:1.4rem}
@media(max-width:640px){.ubar .hideS{display:none}}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(244,242,236,.9);backdrop-filter:blur(10px);border-bottom:var(--rule)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.7rem;padding-bottom:.7rem}
.brand{display:flex;align-items:center;gap:.7rem}
.brand img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:1.4rem}
.nav-menu{display:flex;align-items:center;gap:1.8rem}
.nav-links .lnk{font-family:var(--ff-mono);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-2);transition:color .15s}
.nav-links .lnk:hover{color:var(--accent)}
.nav-burger{display:none;background:none;border:1.5px solid var(--ink);padding:.5rem .6rem;cursor:pointer}
.nav-burger span{display:block;width:18px;height:2px;background:var(--ink);margin:3px 0;transition:.2s}
.nav.open .nav-burger span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.nav.open .nav-burger span:nth-child(2){opacity:0}
.nav.open .nav-burger span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}
@media(max-width:860px){
  .nav-menu{display:none}
  .nav.open .nav-menu{display:flex;flex-direction:column;align-items:stretch;position:absolute;top:100%;left:0;right:0;
    background:var(--paper);border-bottom:2px solid var(--ink);padding:.3rem 0;box-shadow:0 18px 30px -22px rgba(22,23,26,.45);z-index:60}
  .nav.open .nav-menu .lnk{padding:.95rem clamp(18px,4vw,40px);border-top:1px solid var(--line);font-size:.78rem}
  .nav-burger{display:block}
}

/* ---- hero ---- */
.hero{padding:clamp(2.6rem,6vw,5rem) 0 clamp(2.2rem,5vw,4rem)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.hero h1{font-size:clamp(2.4rem,6.4vw,4.7rem);text-transform:uppercase;margin:1.1rem 0 0}
.hero h1 .amp{color:var(--accent)}
.hero p.lead{margin:1.3rem 0 1.9rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-facts{display:flex;gap:0;margin-top:2.3rem;border-top:2px solid var(--ink);border-bottom:var(--rule)}
.hero-facts .f{flex:1;padding:.95rem 0;border-right:var(--rule)}
.hero-facts .f:last-child{border-right:none}
.hero-facts .k{font-family:var(--ff-mono);font-size:1.35rem;font-weight:600;color:var(--ink)}
.hero-facts .v{font-family:var(--ff-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-top:.2rem}
/* framed hero image */
.framed{position:relative;background:var(--card);border:1.5px solid var(--ink);padding:10px}
.framed img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.framed .sku{position:absolute;top:18px;left:18px;background:var(--ink);color:var(--paper);font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.1em;padding:.34rem .6rem}
.framed .cap{position:absolute;bottom:18px;right:18px;background:var(--accent);color:#fff;font-family:var(--ff-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;padding:.34rem .6rem}
.tick{position:absolute;width:13px;height:13px;border:2px solid var(--accent);z-index:2}
.tick.tl{top:-2px;left:-2px;border-right:none;border-bottom:none}
.tick.tr{top:-2px;right:-2px;border-left:none;border-bottom:none}
.tick.bl{bottom:-2px;left:-2px;border-right:none;border-top:none}
.tick.br{bottom:-2px;right:-2px;border-left:none;border-top:none}
@media(max-width:820px){.hero-grid{grid-template-columns:1fr}.hero-media{order:-1}}

/* hazard rule */
.haz{height:9px;background:repeating-linear-gradient(45deg,var(--ink) 0 14px,var(--accent) 14px 28px);opacity:.92}

/* ---- section frame ---- */
.section{padding:clamp(3rem,7vw,5.4rem) 0}
.section.alt{background:var(--paper-2)}
.count{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ---- category index chips ---- */
.cat-nav{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.6rem}
.cat-nav a{font-family:var(--ff-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;
  padding:.5rem .85rem;border:var(--rule);background:var(--card);color:var(--ink-2);transition:.15s}
.cat-nav a:hover{border-color:var(--ink);color:var(--ink)}
.cat-nav a .n{color:var(--accent);margin-right:.4em}

/* ---- category block ---- */
.cat-block{padding:2.4rem 0;border-top:2px solid var(--ink)}
.cat-block:first-of-type{border-top:2px solid var(--ink)}
.cat-top{display:grid;grid-template-columns:1fr;gap:.5rem;margin-bottom:1.6rem}
.cat-top .code{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.18em;color:var(--accent);text-transform:uppercase}
.cat-top h3{font-size:clamp(1.5rem,3vw,2.2rem);text-transform:uppercase}
.cat-top .dress{font-family:var(--ff-mono);font-size:.72rem;color:var(--muted);letter-spacing:.04em}
.cat-top .dress b{color:var(--ink-2);font-weight:600}
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
@media(max-width:680px){.prod-grid{grid-template-columns:1fr}}

/* ---- product card ---- */
.card{background:var(--card);border:1px solid var(--line);position:relative;display:flex;flex-direction:column;
  transition:border-color .18s,transform .18s,box-shadow .18s}
.card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 14px 30px -18px rgba(22,23,26,.5)}
.card .media{position:relative;overflow:hidden}
.card .media img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s ease}
.card:hover .media img{transform:scale(1.04)}
.card .sku{position:absolute;top:12px;left:12px;background:var(--ink);color:var(--paper);font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.08em;padding:.3rem .55rem}
.card .body{padding:1.1rem 1.15rem 1.2rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.card .tag{font-family:var(--ff-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
.card .nm{font-family:var(--ff-disp);font-weight:700;font-size:1.12rem;line-height:1.12;text-transform:uppercase;letter-spacing:-.01em}
.card .desc{font-size:.9rem;color:var(--ink-2);line-height:1.5;margin:0}
.card .actions{display:flex;gap:.6rem;align-items:center;margin-top:auto;padding-top:.6rem}
.card .view{font-family:var(--ff-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);border-bottom:1.5px solid var(--accent);padding-bottom:2px}
.card .view:hover{color:var(--accent)}
.card .stretch{position:absolute;inset:0;z-index:1}        /* whole-card link */
.card .actions{position:relative;z-index:2}

/* small + Pull button used on cards (styled in pull.css too, base here) */
.pulltick{display:inline-flex;align-items:center;gap:.4em;font-family:var(--ff-mono);font-size:.66rem;
  text-transform:uppercase;letter-spacing:.08em;border:1.5px solid var(--line-2);background:var(--paper);
  color:var(--ink-2);padding:.42rem .7rem;cursor:pointer;transition:.15s;border-radius:0}
.pulltick:hover{border-color:var(--accent);color:var(--accent)}
.pulltick.added{background:var(--ink);border-color:var(--ink);color:#fff}
.pulltick svg{width:13px;height:13px}

/* ---- capabilities strip ---- */
.caps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:2px solid var(--ink)}
.caps .cap{padding:1.6rem 1.3rem;border-right:var(--rule)}
.caps .cap:last-child{border-right:none}
.caps .n{font-family:var(--ff-mono);font-size:.66rem;color:var(--accent);letter-spacing:.14em}
.caps h4{font-family:var(--ff-disp);font-size:1.08rem;text-transform:uppercase;margin:.55rem 0 .4rem}
.caps p{font-size:.86rem;color:var(--ink-2);margin:0}
@media(max-width:780px){.caps{grid-template-columns:repeat(2,1fr)}.caps .cap:nth-child(2){border-right:none}.caps .cap:nth-child(1),.caps .cap:nth-child(2){border-bottom:var(--rule)}}
@media(max-width:460px){.caps{grid-template-columns:1fr}.caps .cap{border-right:none;border-bottom:var(--rule)}.caps .cap:last-child{border-bottom:none}}

/* ---- how it works (pull list steps) ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:2rem}
.step{background:var(--card);border:1px solid var(--line);padding:1.5rem 1.4rem;position:relative}
.step .num{font-family:var(--ff-mono);font-size:.72rem;color:var(--accent);letter-spacing:.1em}
.step h4{font-family:var(--ff-disp);font-size:1.12rem;text-transform:uppercase;margin:.7rem 0 .5rem}
.step p{font-size:.9rem;color:var(--ink-2);margin:0}
.step::before{content:"";position:absolute;top:0;left:0;width:36px;height:3px;background:var(--accent)}
@media(max-width:720px){.steps{grid-template-columns:1fr}}
.steps.s4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.steps.s4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps.s4{grid-template-columns:1fr}}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.6rem,4vw,3rem);align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact-facts{font-family:var(--ff-mono);font-size:.84rem}
.contact-facts .row{display:flex;gap:.8rem;padding:.85rem 0;border-bottom:var(--rule)}
.contact-facts .row:first-child{border-top:var(--rule)}
.contact-facts .lbl{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:.64rem;min-width:78px;padding-top:.15rem}
.contact-facts .val{color:var(--ink)}
.contact-facts a:hover{color:var(--accent)}
.form{background:var(--card);border:1.5px solid var(--ink);padding:clamp(1.4rem,3vw,2rem)}
.form .frow{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
@media(max-width:520px){.form .frow{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.9rem}
.field label{font-family:var(--ff-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}
.field input,.field textarea{font-family:var(--ff-body);font-size:.95rem;padding:.7rem .8rem;border:1px solid var(--line-2);background:var(--paper);color:var(--ink);border-radius:0;transition:border-color .15s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field textarea{resize:vertical;min-height:96px}
.form .fnote{font-family:var(--ff-mono);font-size:.66rem;color:var(--muted);margin:.4rem 0 0;text-align:center}
.form .fnote.ok{color:var(--ok)}.form .fnote.err{color:var(--accent-2)}

/* ---- cta band ---- */
.ctaband{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
  background:var(--ink);color:var(--paper);padding:clamp(1.6rem,3.5vw,2.4rem) clamp(1.6rem,4vw,2.6rem);border-left:8px solid var(--accent)}
.ctaband h3{font-family:var(--ff-disp);font-size:clamp(1.3rem,2.6vw,1.9rem);text-transform:uppercase;color:#fff}
.ctaband p{color:#cbc6ba;margin:.5rem 0 0;font-size:.95rem;max-width:46ch}
.ctaband .btn-accent{border-color:var(--accent)}

/* ---- breadcrumb (product page) ---- */
.crumb{font-family:var(--ff-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:1.4rem 0 0}
.crumb a:hover{color:var(--accent)}
.crumb .sep{margin:0 .5em;color:var(--line-2)}
.crumb .cur{color:var(--ink)}
@media(max-width:520px){.crumb{font-size:.6rem;letter-spacing:.05em}.crumb .sep{margin:0 .35em}}

/* ---- product detail ---- */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3rem);align-items:start;padding:1.8rem 0 0}
@media(max-width:820px){.pd{grid-template-columns:1fr}}
.pd-body h1{font-size:clamp(1.9rem,4vw,3rem);text-transform:uppercase;margin:.9rem 0 1rem}
.pd-body .lead{margin-bottom:1.6rem}
.spec{border:1.5px solid var(--ink);background:var(--card)}
.spec .sh{font-family:var(--ff-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.16em;color:#fff;background:var(--ink);padding:.55rem .9rem}
.spec dl{margin:0;padding:.4rem .9rem .7rem}
.spec dl>div{display:grid;grid-template-columns:120px 1fr;gap:1rem;padding:.6rem 0;border-bottom:var(--rule)}
.spec dl>div:last-child{border-bottom:none}
@media(max-width:520px){.spec dl>div{grid-template-columns:1fr;gap:.2rem}.spec dt{padding-top:0}}
.spec dt{font-family:var(--ff-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding-top:.1rem}
.spec dd{margin:0;font-size:.92rem;color:var(--ink)}
.pd-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.6rem 0 0}
.instock{display:inline-flex;align-items:center;gap:.5em;font-family:var(--ff-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ok);margin-bottom:.4rem}
.instock .d{width:8px;height:8px;border-radius:50%;background:var(--ok)}

/* ---- footer ---- */
footer{background:var(--paper-2);border-top:2px solid var(--ink)}
.foot-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:2.4rem 0}
.foot-inner img{height:54px;width:auto}
.foot-meta{font-family:var(--ff-mono);font-size:.78rem;color:var(--ink-2);line-height:1.9;text-align:right}
.foot-meta a:hover{color:var(--accent)}
@media(max-width:560px){.foot-inner{flex-direction:column}.foot-meta{text-align:left}}

/* ---- reveal ---- */
.rv{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}.card:hover{transform:none}}

/* ===================================================================
   CATALOG BROWSER  (full 1,234-piece inventory: search / filter / grid)
   =================================================================== */
:root{--navh:58px}
.inv-intro{display:flex;align-items:flex-end;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;margin-bottom:.4rem}

/* sticky toolbar under the nav */
.cat-toolbar{position:sticky;top:var(--navh);z-index:40;background:rgba(244,242,236,.96);backdrop-filter:blur(9px);
  border-top:2px solid var(--ink);border-bottom:var(--rule);margin-top:1.4rem}
.tb-row{display:flex;gap:.9rem;align-items:center;flex-wrap:wrap;padding:.8rem 0 .2rem}
.search{position:relative;flex:1;min-width:230px}
.search input{width:100%;font-family:var(--ff-body);font-size:.95rem;padding:.72rem .9rem .72rem 2.3rem;
  border:1.5px solid var(--line-2);background:var(--card);color:var(--ink);border-radius:0;transition:border-color .15s}
.search input:focus{outline:none;border-color:var(--accent)}
.search .sic{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted);pointer-events:none}
.tb-count{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.chips{display:flex;gap:.45rem;overflow-x:auto;padding:.55rem 0 .7rem;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.chips::-webkit-scrollbar{height:5px}.chips::-webkit-scrollbar-thumb{background:var(--line-2)}
.chip{flex:0 0 auto;font-family:var(--ff-mono);font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;
  padding:.5rem .8rem;border:1px solid var(--line-2);background:var(--card);color:var(--ink-2);cursor:pointer;white-space:nowrap;border-radius:0;transition:.15s}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip.on{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.chip .cn{color:var(--accent);margin-left:.4em}
.chip.on .cn{color:#e79b6b}

/* product grid */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:1rem;margin-top:1.6rem}
@media(max-width:520px){.pgrid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem}}
.pcard{background:var(--card);border:1px solid var(--line);position:relative;display:flex;flex-direction:column;cursor:pointer;
  transition:border-color .16s,transform .16s,box-shadow .16s}
.pcard:hover,.pcard:focus-visible{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 14px 28px -18px rgba(22,23,26,.5);outline:none}
.pmedia{aspect-ratio:4/3;overflow:hidden;background:var(--paper-2)}
.pmedia img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.pcard:hover .pmedia img{transform:scale(1.05)}
.pcard-b{padding:.7rem .8rem .55rem;display:flex;flex-direction:column;gap:.28rem;flex:1}
.pc-top{display:flex;justify-content:space-between;gap:.5rem;align-items:baseline}
.pc-code{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.05em;color:var(--accent);font-weight:600}
.pc-cat{font-family:var(--ff-mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);text-align:right;line-height:1.3}
.pc-name{font-family:var(--ff-disp);font-weight:700;font-size:.92rem;line-height:1.12;text-transform:uppercase;letter-spacing:-.01em}
.pc-meta{font-family:var(--ff-mono);font-size:.65rem;color:var(--ink-2);margin-top:.05rem}
.pc-meta.dim{color:var(--muted)}
.pcard .pulltick{margin:0 .8rem .8rem;justify-content:center;width:calc(100% - 1.6rem)}
@media(max-width:520px){.pc-name{font-size:.82rem}.pcard-b{padding:.55rem .6rem .4rem}.pcard .pulltick{margin:0 .6rem .6rem;width:calc(100% - 1.2rem);font-size:.6rem;padding:.4rem .5rem}}

#sentinel{height:1px}
.noRes{display:none;text-align:center;padding:3.4rem 0;font-family:var(--ff-mono);color:var(--muted);font-size:.85rem}
.noRes b{color:var(--ink)}
.loadmore-wrap{text-align:center;margin-top:1.8rem}

/* ===================================================================
   PRODUCT DETAIL MODAL
   =================================================================== */
.pm{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:clamp(10px,3vw,38px)}
.pm.open{display:flex}
.pm-ov{position:fixed;inset:0;background:rgba(18,18,20,.74);backdrop-filter:blur(3px)}
.pm-box{position:relative;z-index:1;width:100%;max-width:1040px;max-height:90vh;display:grid;grid-template-columns:1.12fr .88fr;
  background:var(--paper);border:1.5px solid var(--ink);overflow:hidden;box-shadow:0 40px 90px -34px rgba(0,0,0,.65)}
.pm-x{position:absolute;top:0;right:0;z-index:4;width:42px;height:42px;border:none;border-left:1px solid rgba(255,255,255,.25);border-bottom:1px solid rgba(255,255,255,.25);
  background:rgba(20,20,22,.55);color:#fff;font-size:1rem;cursor:pointer;transition:background .15s}
.pm-x:hover{background:var(--accent)}
.pm-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:40px;height:52px;border:none;background:rgba(20,20,22,.42);
  color:#fff;font-size:1.7rem;line-height:1;cursor:pointer;transition:background .15s}
.pm-nav:hover{background:var(--accent)}
.pm-nav.prev{left:0}.pm-nav.next{left:calc(56% - 40px)}
.pm-media{background:#0e0f11;display:flex;flex-direction:column;min-height:0;min-width:0}
.pm-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:16px;min-height:0;overflow:hidden}
.pm-stage img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}
.pm-thumbs{display:flex;gap:6px;padding:0 14px 14px;overflow-x:auto;scrollbar-width:thin}
.pm-th{flex:0 0 auto;width:56px;height:44px;border:1px solid #3a3a3d;background:none;padding:0;cursor:pointer;opacity:.55;transition:.15s}
.pm-th.on,.pm-th:hover{opacity:1;border-color:var(--accent)}
.pm-th img{width:100%;height:100%;object-fit:cover;display:block}
.pm-info{padding:clamp(1.3rem,2.6vw,2.1rem);overflow-y:auto;display:flex;flex-direction:column}
.pm-eyebrow{font-family:var(--ff-mono);font-size:.64rem;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:var(--accent)}
.pm-title{font-family:var(--ff-disp);font-size:clamp(1.5rem,3vw,2.1rem);text-transform:uppercase;letter-spacing:-.01em;line-height:1.04;margin:.55rem 0 .2rem}
.pm-code{font-family:var(--ff-mono);font-size:.82rem;letter-spacing:.1em;color:var(--ink-2)}
.pm-stock{display:inline-flex;align-items:center;gap:.5em;font-family:var(--ff-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ok);margin:.9rem 0 .3rem}
.pm-stock .d{width:8px;height:8px;border-radius:50%;background:var(--ok)}
.pm-spec{margin:.9rem 0 0;border-top:var(--rule)}
.pm-spec>div{display:grid;grid-template-columns:118px 1fr;gap:1rem;padding:.6rem 0;border-bottom:var(--rule)}
.pm-spec dt{font-family:var(--ff-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0}
.pm-spec dd{margin:0;font-size:.9rem;color:var(--ink)}
.pm-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin:1.5rem 0 0}
.pm-cta .btn{font-size:.66rem}
.pm-fine{font-family:var(--ff-mono);font-size:.64rem;line-height:1.6;color:var(--muted);margin:1rem 0 0}
@media(max-width:760px){
  .pm-box{grid-template-columns:1fr;max-height:93vh}
  .pm-media{max-height:42vh}
  .pm-nav{top:21vh;transform:translateY(-50%);height:48px}
  .pm-nav.next{left:auto;right:0}
}
