/* FTS Store V78 — contained editorial shop shelf.
   Direction: premium FTS retail first. Less game inventory, more quiet streetwear store. */

body[data-section="shop"] .page{width:min(1440px,calc(100vw - 64px));}
body[data-section="shop"] .shop-hero{
  border-color: rgba(242,239,232,.13);
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.006));
}
body[data-section="shop"] .shop-hero h1{letter-spacing:-.035em;}
body[data-section="shop"] .store-card-image{min-height:210px;opacity:.62;filter:grayscale(1) contrast(1.04) brightness(.72);}

/* Featured / Top Shelf */
body[data-section="shop"] .top-shelf-feature{margin-top:24px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;display:grid;grid-template-columns:260px minmax(0,1fr);gap:24px;align-items:stretch;}
body[data-section="shop"] .top-shelf-feature h2{font-size:clamp(34px,3.8vw,62px);line-height:.88;}
body[data-section="shop"] .top-shelf-feature p{font-size:13px;line-height:1.55;margin:10px 0 0;color:rgba(242,239,232,.62);}
body[data-section="shop"] .top-shelf-track{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;min-width:0;}
body[data-section="shop"] .top-shelf-slide{position:relative;min-height:220px;border:1px solid var(--line);background:linear-gradient(135deg,rgba(242,239,232,.055),rgba(242,239,232,.012));overflow:hidden;text-align:left;color:var(--ink);padding:18px;display:flex;flex-direction:column;justify-content:space-between;}
body[data-section="shop"] .top-shelf-slide:before{content:'';position:absolute;inset:0;background:var(--slide-image,linear-gradient(135deg,rgba(183,196,154,.14),rgba(168,109,72,.10))) center/cover no-repeat;filter:grayscale(1) contrast(1.04) brightness(.56);opacity:.42;}
body[data-section="shop"] .top-shelf-slide:after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,8,7,.82),rgba(8,8,7,.22));}
body[data-section="shop"] .top-shelf-slide>*{position:relative;z-index:2;}
body[data-section="shop"] .top-shelf-slide span{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,239,232,.62);}
body[data-section="shop"] .top-shelf-slide b{display:block;font-family:var(--display);font-size:clamp(26px,2.4vw,42px);line-height:.9;text-transform:uppercase;letter-spacing:-.01em;}
body[data-section="shop"] .top-shelf-slide small{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:rgba(242,239,232,.64);}
body[data-section="shop"] .top-shelf-slide:hover{border-color:var(--line2);}
body[data-section="shop"] .top-shelf-slide:nth-child(1){--slide-image:url('ASH_OLLIE_FTS.JPG');}
body[data-section="shop"] .top-shelf-slide:nth-child(2){--slide-image:url('Ash-and-joe.JPG');}
body[data-section="shop"] .top-shelf-slide:nth-child(3){--slide-image:url('ASH_OLLIE_FTS.JPG');}

/* Category controls */
body[data-section="shop"] .category-dropdowns{gap:10px;margin-top:22px;}
body[data-section="shop"] .store-category{background:transparent;border-color:rgba(242,239,232,.14);}
body[data-section="shop"] .store-category summary{font-size:clamp(20px,1.65vw,28px);letter-spacing:.01em;padding:16px 18px;}
body[data-section="shop"] .store-category summary:after{color:var(--muted);}
body[data-section="shop"] .subcats{padding:0 18px 16px;gap:7px;}
body[data-section="shop"] .subcats button{color:rgba(242,239,232,.58);border:0;border-bottom:1px solid rgba(242,239,232,.10);background:transparent;padding:8px 0;font-size:9px;}
body[data-section="shop"] .subcats button:hover,body[data-section="shop"] .subcats button.active{background:transparent;color:var(--ink);border-bottom-color:var(--ink);}
body[data-section="shop"] .filter-row{margin:18px 0 8px;gap:7px;}
body[data-section="shop"] .filter-row button{background:transparent;border-color:rgba(242,239,232,.16);color:rgba(242,239,232,.60);padding:8px 11px;font-size:9px;}
body[data-section="shop"] .filter-row button.active,body[data-section="shop"] .filter-row button:hover{background:var(--cream,var(--ink));color:var(--black,var(--bg));border-color:var(--ink);}
body[data-section="shop"] .shop-note{border:0;border-top:1px solid rgba(242,239,232,.12);border-bottom:1px solid rgba(242,239,232,.08);background:transparent;padding:12px 0;max-width:none;font-size:12px;letter-spacing:.04em;}

/* Sticky left shelf navigation + contained product area */
body[data-section="shop"] .shop-body{display:grid;grid-template-columns:178px minmax(0,1fr);gap:28px;margin-top:34px;border-left:1px solid var(--line);border-right:1px solid var(--line);padding:0 clamp(18px,2.2vw,32px);}
body[data-section="shop"] .shop-rail{position:sticky;top:22px;align-self:start;padding-top:5px;display:grid;gap:7px;}
body[data-section="shop"] .shop-rail-title{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
body[data-section="shop"] .shop-rail button{width:100%;text-align:left;background:transparent;border:0;border-bottom:1px solid var(--line);padding:9px 0;color:var(--muted);font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;}
body[data-section="shop"] .shop-rail button:hover,body[data-section="shop"] .shop-rail button.active{color:var(--ink);border-bottom-color:var(--ink);}
body[data-section="shop"] .section#storefront{margin-top:0;min-width:0;}
body[data-section="shop"] #storefront .section-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(230px,390px);align-items:end;gap:24px;margin-bottom:20px;}
body[data-section="shop"] #storefront .section-head h2{font-size:clamp(34px,4.2vw,68px);letter-spacing:-.04em;line-height:.88;}
body[data-section="shop"] #storefront .section-head p{max-width:420px;font-size:13px;line-height:1.5;color:rgba(242,239,232,.62);}

body[data-section="shop"] .product-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:46px 22px;align-items:start;}
body[data-section="shop"] .product-card{padding:0;border:0;background:transparent;box-shadow:none;gap:0;min-width:0;transition:transform .18s ease, opacity .18s ease;}
body[data-section="shop"] .product-card:hover{transform:translateY(-2px);}
body[data-section="shop"] .product-card.is-hidden{display:none!important;}
body[data-section="shop"] .product-art{height:auto;aspect-ratio:1/1.16;margin:0 0 12px;border:1px solid rgba(242,239,232,.13);background:linear-gradient(180deg,rgba(242,239,232,.045),rgba(242,239,232,.01)),radial-gradient(circle at 22% 16%,rgba(242,239,232,.08),transparent 31%),linear-gradient(135deg,rgba(33,33,29,.92),rgba(11,11,10,.96));position:relative;}
body[data-section="shop"] .product-art:before{content:'';position:absolute;inset:10px;border:1px solid rgba(242,239,232,.08);opacity:.7;}
body[data-section="shop"] .product-art:after{content:'FTS';position:absolute;left:10px;bottom:9px;font-family:var(--mono);font-size:7px;letter-spacing:.2em;color:rgba(242,239,232,.22);}
body[data-section="shop"] .product-card .tag{display:block;padding:0;margin:0 0 6px;border:0;background:transparent;color:rgba(242,239,232,.42);font-size:8px;letter-spacing:.16em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
body[data-section="shop"] .product-card h3{font-family:var(--body);font-size:clamp(13px,1vw,17px);font-weight:800;line-height:1.05;letter-spacing:-.01em;text-transform:uppercase;margin:0 0 5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
body[data-section="shop"] .product-card p{display:none;}
body[data-section="shop"] .product-bottom{display:grid;grid-template-columns:1fr;align-items:start;gap:8px;padding-top:0;border-top:0;}
body[data-section="shop"] .product-bottom strong{font-family:var(--body);font-size:15px;font-weight:800;line-height:1;color:var(--ink);}
body[data-section="shop"] .product-bottom .btn.small{justify-content:flex-start;min-height:0;padding:0;border:0;background:transparent;color:rgba(242,239,232,.58);font-size:8px;letter-spacing:.13em;text-decoration:underline;text-underline-offset:4px;}
body[data-section="shop"] .product-bottom .btn.small:hover{background:transparent;color:var(--ink);}

html[data-theme="light"] body[data-section="shop"] .shop-hero{background:rgba(255,255,255,.28);border-color:rgba(10,10,10,.12);}
html[data-theme="light"] body[data-section="shop"] .top-shelf-feature{border-color:rgba(10,10,10,.13);}
html[data-theme="light"] body[data-section="shop"] .top-shelf-feature p{color:rgba(10,10,10,.62);}
html[data-theme="light"] body[data-section="shop"] .top-shelf-slide{border-color:rgba(10,10,10,.12);background:rgba(255,255,255,.24);}
html[data-theme="light"] body[data-section="shop"] .top-shelf-slide:before{filter:grayscale(1) contrast(1.05) brightness(1.08);opacity:.30;}
html[data-theme="light"] body[data-section="shop"] .top-shelf-slide:after{background:linear-gradient(0deg,rgba(242,239,232,.84),rgba(242,239,232,.22));}
html[data-theme="light"] body[data-section="shop"] .top-shelf-slide span,html[data-theme="light"] body[data-section="shop"] .top-shelf-slide small{color:rgba(10,10,10,.58);}
html[data-theme="light"] body[data-section="shop"] .store-category{background:transparent;border-color:rgba(10,10,10,.12);}
html[data-theme="light"] body[data-section="shop"] .subcats button,html[data-theme="light"] body[data-section="shop"] .filter-row button{color:rgba(10,10,10,.58);border-color:rgba(10,10,10,.15);}
html[data-theme="light"] body[data-section="shop"] .subcats button:hover,html[data-theme="light"] body[data-section="shop"] .subcats button.active{color:var(--ink);border-bottom-color:var(--ink);}
html[data-theme="light"] body[data-section="shop"] .filter-row button.active,html[data-theme="light"] body[data-section="shop"] .filter-row button:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);}
html[data-theme="light"] body[data-section="shop"] .shop-note{border-color:rgba(10,10,10,.12);}
html[data-theme="light"] body[data-section="shop"] .shop-body{border-color:rgba(10,10,10,.13);}
html[data-theme="light"] body[data-section="shop"] #storefront .section-head p{color:rgba(10,10,10,.60);}
html[data-theme="light"] body[data-section="shop"] .product-art{border-color:rgba(10,10,10,.11);background:linear-gradient(180deg,rgba(10,10,10,.032),rgba(10,10,10,.004)),radial-gradient(circle at 22% 16%,rgba(10,10,10,.06),transparent 31%),linear-gradient(135deg,rgba(234,230,220,.96),rgba(249,246,238,.94));}
html[data-theme="light"] body[data-section="shop"] .product-art:before{border-color:rgba(10,10,10,.08);}
html[data-theme="light"] body[data-section="shop"] .product-art:after,html[data-theme="light"] body[data-section="shop"] .product-card .tag{color:rgba(10,10,10,.38);}
html[data-theme="light"] body[data-section="shop"] .product-bottom .btn.small{color:rgba(10,10,10,.55);}
html[data-theme="light"] body[data-section="shop"] .product-bottom .btn.small:hover{color:var(--ink);}

@media(max-width:1280px){body[data-section="shop"] .product-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:42px 20px;}body[data-section="shop"] .shop-body{grid-template-columns:150px minmax(0,1fr);}}
@media(max-width:1020px){body[data-section="shop"] .top-shelf-feature{grid-template-columns:1fr;}body[data-section="shop"] .top-shelf-track{grid-template-columns:repeat(3,minmax(220px,1fr));overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:4px;}body[data-section="shop"] .top-shelf-slide{scroll-snap-align:start;}body[data-section="shop"] .category-dropdowns{grid-template-columns:repeat(2,minmax(0,1fr));}body[data-section="shop"] .shop-body{grid-template-columns:1fr;border-left:0;border-right:0;padding:0;}body[data-section="shop"] .shop-rail{position:relative;top:auto;display:flex;overflow-x:auto;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px 0;margin-bottom:10px;}body[data-section="shop"] .shop-rail-title{display:none;}body[data-section="shop"] .shop-rail button{flex:0 0 auto;width:auto;border-bottom:0;border-right:1px solid var(--line);padding:8px 14px;}}
@media(max-width:860px){body[data-section="shop"] .page{width:min(100vw - 34px,1440px);}body[data-section="shop"] .product-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:34px 16px;}body[data-section="shop"] #storefront .section-head{grid-template-columns:1fr;}body[data-section="shop"] .product-card h3{font-size:12px;}body[data-section="shop"] .product-bottom strong{font-size:13px;}body[data-section="shop"] .product-bottom .btn.small{font-size:7px;}}
@media(max-width:620px){body[data-section="shop"] .page{width:min(100vw - 24px,1440px);}body[data-section="shop"] .shop-hero{grid-template-columns:1fr;}body[data-section="shop"] .store-card-image{min-height:150px;}body[data-section="shop"] .category-dropdowns{grid-template-columns:1fr;}body[data-section="shop"] .product-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:30px 14px;}body[data-section="shop"] #storefront .section-head h2{font-size:42px;}body[data-section="shop"] .product-art:before{inset:8px;}}
@media(max-width:380px){body[data-section="shop"] .product-grid{grid-template-columns:1fr 1fr;gap:26px 10px;}body[data-section="shop"] .product-card h3{font-size:11px;}body[data-section="shop"] .top-shelf-track{grid-template-columns:repeat(3,minmax(190px,1fr));}}

/* V100 safety audit fix: keep the sticky Store Menu below the sticky site header instead of tucking underneath it. */
@media(min-width:1021px){
  body[data-section="shop"] .shop-rail{
    top:86px!important;
    max-height:calc(100svh - 104px);
    overflow:auto;
    padding-right:4px;
    scrollbar-width:none;
  }
  body[data-section="shop"] .shop-rail::-webkit-scrollbar{display:none;}
}


/* V117 General Store final refinement: calmer editorial shelf, clearer current category, less bulky commerce UI. */
body[data-section="shop"] .shop-hero{
  position:relative;
  overflow:hidden;
}
body[data-section="shop"] .shop-hero:before{
  content:'GENERAL STORE';
  position:absolute;
  right:clamp(18px,3vw,42px);
  top:18px;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.34em;
  color:var(--muted);
  opacity:.45;
}
body[data-section="shop"] .shop-hero .button-row{
  gap:8px;
}
body[data-section="shop"] .top-shelf-feature{
  padding:28px 0;
}
body[data-section="shop"] .top-shelf-slide{
  min-height:242px;
}
body[data-section="shop"] .top-shelf-slide:hover,
body[data-section="shop"] .top-shelf-slide.active{
  border-color:var(--ink);
}
body[data-section="shop"] .category-dropdowns{
  margin-top:26px;
}
body[data-section="shop"] .store-category{
  transition:border-color .18s ease, background .18s ease;
}
body[data-section="shop"] .store-category[open]{
  border-color:rgba(242,239,232,.22);
  background:rgba(255,255,255,.018);
}
body[data-section="shop"] .shop-body{
  margin-top:38px;
}
body[data-section="shop"] .shop-rail{
  gap:5px;
}
body[data-section="shop"] .rail-group-label{
  margin-top:13px;
  padding-top:13px;
  border-top:1px solid var(--line);
  color:rgba(242,239,232,.38);
}
body[data-section="shop"] .shop-rail button.active{
  color:var(--ink);
  padding-left:8px;
}
body[data-section="shop"] .shop-rail button.active:before{
  content:'— ';
}
body[data-section="shop"] .store-status-row{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:10px 0;
  margin:-4px 0 24px;
  display:flex;
  flex-wrap:wrap;
  gap:10px 18px;
  align-items:center;
  justify-content:space-between;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
body[data-section="shop"] .store-status-row b,
body[data-section="shop"] .store-status-row a{
  color:var(--ink);
}
body[data-section="shop"] .store-status-row a{
  text-decoration:none;
}
body[data-section="shop"] .product-grid{
  gap:52px 24px;
}
body[data-section="shop"] .product-card{
  position:relative;
}
body[data-section="shop"] .product-art{
  overflow:hidden;
  transition:border-color .18s ease, transform .18s ease, background .18s ease;
}
body[data-section="shop"] .product-card:hover .product-art{
  border-color:rgba(242,239,232,.34);
  transform:translateY(-1px);
}
body[data-section="shop"] .product-card[data-category="apparel"] .product-art{
  background:linear-gradient(180deg,rgba(242,239,232,.04),rgba(242,239,232,.006)),linear-gradient(135deg,rgba(42,42,38,.92),rgba(10,10,9,.98));
}
body[data-section="shop"] .product-card[data-category="essentials"] .product-art{
  background:linear-gradient(180deg,rgba(183,196,154,.06),rgba(242,239,232,.006)),linear-gradient(135deg,rgba(32,36,27,.95),rgba(10,10,9,.98));
}
body[data-section="shop"] .product-card[data-category="glass"] .product-art{
  background:linear-gradient(180deg,rgba(142,196,255,.05),rgba(242,239,232,.006)),linear-gradient(135deg,rgba(26,31,35,.95),rgba(10,10,9,.98));
}
body[data-section="shop"] .product-card[data-category="lifestyle"] .product-art{
  background:linear-gradient(180deg,rgba(168,109,72,.06),rgba(242,239,232,.006)),linear-gradient(135deg,rgba(37,30,25,.95),rgba(10,10,9,.98));
}
body[data-section="shop"] .product-card .tag{
  opacity:.8;
}
body[data-section="shop"] .product-card h3{
  font-size:clamp(12px,.95vw,16px);
}
body[data-section="shop"] .product-bottom{
  grid-template-columns:1fr auto;
  align-items:center;
  gap:8px;
}
body[data-section="shop"] .product-bottom .btn.small{
  white-space:nowrap;
  text-align:right;
}
body[data-section="shop"] .store-empty{
  border:1px solid var(--line);
  padding:28px;
  margin-top:18px;
  color:var(--muted);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  text-align:center;
}
html[data-theme="light"] body[data-section="shop"] .store-category[open]{
  border-color:rgba(10,10,10,.2);
  background:rgba(17,16,14,.018);
}
html[data-theme="light"] body[data-section="shop"] .rail-group-label{
  color:rgba(10,10,10,.42);
}
html[data-theme="light"] body[data-section="shop"] .product-card:hover .product-art{
  border-color:rgba(10,10,10,.24);
}
html[data-theme="light"] body[data-section="shop"] .product-card[data-category="apparel"] .product-art{
  background:linear-gradient(180deg,rgba(10,10,10,.032),rgba(10,10,10,.004)),linear-gradient(135deg,rgba(232,229,220,.96),rgba(249,246,238,.94));
}
html[data-theme="light"] body[data-section="shop"] .product-card[data-category="essentials"] .product-art{
  background:linear-gradient(180deg,rgba(111,141,72,.065),rgba(10,10,10,.004)),linear-gradient(135deg,rgba(235,233,222,.96),rgba(249,246,238,.94));
}
html[data-theme="light"] body[data-section="shop"] .product-card[data-category="glass"] .product-art{
  background:linear-gradient(180deg,rgba(70,115,145,.055),rgba(10,10,10,.004)),linear-gradient(135deg,rgba(232,236,235,.96),rgba(249,246,238,.94));
}
html[data-theme="light"] body[data-section="shop"] .product-card[data-category="lifestyle"] .product-art{
  background:linear-gradient(180deg,rgba(138,101,79,.06),rgba(10,10,10,.004)),linear-gradient(135deg,rgba(235,230,222,.96),rgba(249,246,238,.94));
}
@media(max-width:1020px){
  body[data-section="shop"] .store-status-row{
    position:sticky;
    top:0;
    z-index:5;
    background:var(--bg);
  }
}
@media(max-width:620px){
  body[data-section="shop"] .shop-hero:before{display:none;}
  body[data-section="shop"] .product-bottom{
    grid-template-columns:1fr;
    align-items:start;
  }
  body[data-section="shop"] .product-bottom .btn.small{
    text-align:left;
  }
  body[data-section="shop"] .store-status-row{
    justify-content:flex-start;
  }
}


/* V126 store responsive safety pass */
@media(max-width:920px){
  body[data-section="shop"] .top-shelf-feature{
    gap:16px;
  }
  body[data-section="shop"] .category-dropdowns{
    grid-template-columns:1fr 1fr!important;
  }
  body[data-section="shop"] .shop-rail{
    position:relative!important;
    top:auto!important;
    max-height:none!important;
    overflow-x:auto!important;
  }
  body[data-section="shop"] .store-status-row{
    position:relative!important;
    top:auto!important;
  }
}
@media(max-width:700px){
  body[data-section="shop"] .shop-hero{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .top-shelf-track{
    grid-template-columns:repeat(3,minmax(210px,1fr))!important;
  }
  body[data-section="shop"] .category-dropdowns{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .product-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:30px 14px!important;
  }
}
@media(max-width:420px){
  body[data-section="shop"] .product-grid{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .top-shelf-track{
    grid-template-columns:repeat(3,minmax(185px,1fr))!important;
  }
}


/* V127 shop readability/click-target refinement. */
body[data-section="shop"] .product-card h3{
  font-size:clamp(15px,1.08vw,19px)!important;
  line-height:1.08!important;
  white-space:normal!important;
  overflow:visible!important;
  text-overflow:clip!important;
}
body[data-section="shop"] .product-card .tag{
  font-size:9px!important;
}
body[data-section="shop"] .product-bottom{
  grid-template-columns:1fr!important;
  gap:10px!important;
}
body[data-section="shop"] .product-bottom strong{
  font-size:17px!important;
}
body[data-section="shop"] .product-bottom .btn.small{
  border:1px solid var(--line)!important;
  background:var(--soft)!important;
  color:var(--ink)!important;
  min-height:38px!important;
  padding:10px 11px!important;
  justify-content:center!important;
  text-align:center!important;
  text-decoration:none!important;
  font-size:9px!important;
  letter-spacing:.13em!important;
  width:100%!important;
}
body[data-section="shop"] .product-bottom .btn.small:hover,
body[data-section="shop"] .product-bottom .btn.small:focus{
  border-color:var(--line2)!important;
  background:var(--ink)!important;
  color:var(--bg)!important;
  outline:0!important;
}
html[data-theme="light"] body[data-section="shop"] .product-bottom .btn.small{
  background:rgba(17,16,14,.035)!important;
  border-color:rgba(10,10,10,.16)!important;
  color:var(--ink)!important;
}
html[data-theme="light"] body[data-section="shop"] .product-bottom .btn.small:hover,
html[data-theme="light"] body[data-section="shop"] .product-bottom .btn.small:focus{
  background:var(--ink)!important;
  color:var(--bg)!important;
}
@media(max-width:700px){
  body[data-section="shop"] .product-card h3{
    font-size:16px!important;
  }
  body[data-section="shop"] .product-bottom .btn.small{
    min-height:42px!important;
    font-size:10px!important;
  }
}


/* V128 store polish: readable but still editorial on desktop. */
body[data-section="shop"] .product-card .tag{
  margin-bottom:8px!important;
}
body[data-section="shop"] .product-bottom .btn.small{
  margin-top:2px;
}
body[data-section="shop"] .store-status-row{
  color:var(--muted);
}


/* V129 restore subtler desktop shop typography/buttons after V127.
   Desktop returns closer to the earlier editorial feel; mobile remains easier to tap. */
@media(min-width:701px){
  body[data-section="shop"] .product-card h3{
    font-size:clamp(13px,.95vw,16px)!important;
    line-height:1.05!important;
  }
  body[data-section="shop"] .product-card .tag{
    font-size:8px!important;
  }
  body[data-section="shop"] .product-bottom strong{
    font-size:15px!important;
  }
  body[data-section="shop"] .product-bottom .btn.small{
    min-height:32px!important;
    padding:8px 9px!important;
    font-size:8px!important;
    letter-spacing:.13em!important;
  }
}
@media(max-width:700px){
  body[data-section="shop"] .product-card h3{
    font-size:15px!important;
  }
  body[data-section="shop"] .product-bottom .btn.small{
    min-height:40px!important;
    font-size:9px!important;
  }
}


/* V132 shop mock product visuals.
   These are lightweight FTS placeholders, not scraped product photos.
   They make the shelf less samey now and can be replaced with real/supplier images later. */
body[data-section="shop"] .product-art{
  display:grid;
  place-items:center;
  isolation:isolate;
}
body[data-section="shop"] .product-art:before{
  inset:12px!important;
}
body[data-section="shop"] .product-art:after{
  content:''!important;
}
body[data-section="shop"] .product-art::marker{display:none;}
body[data-section="shop"] .product-art.mock-cap,
body[data-section="shop"] .product-art.mock-tee,
body[data-section="shop"] .product-art.mock-socks,
body[data-section="shop"] .product-art.mock-hoodie,
body[data-section="shop"] .product-art.mock-tote,
body[data-section="shop"] .product-art.mock-papers,
body[data-section="shop"] .product-art.mock-filters,
body[data-section="shop"] .product-art.mock-tips,
body[data-section="shop"] .product-art.mock-grinder,
body[data-section="shop"] .product-art.mock-lighter,
body[data-section="shop"] .product-art.mock-wraps,
body[data-section="shop"] .product-art.mock-bong,
body[data-section="shop"] .product-art.mock-pipe,
body[data-section="shop"] .product-art.mock-vase,
body[data-section="shop"] .product-art.mock-candle,
body[data-section="shop"] .product-art.mock-tray,
body[data-section="shop"] .product-art.mock-ashtray,
body[data-section="shop"] .product-art.mock-print{
  background:
    radial-gradient(circle at 50% 38%,rgba(242,239,232,.08),transparent 37%),
    linear-gradient(135deg,rgba(242,239,232,.04),rgba(242,239,232,.008)),
    linear-gradient(135deg,rgba(33,33,29,.92),rgba(11,11,10,.96))!important;
}
body[data-section="shop"] .product-art.mock-cap:after{content:'CAP'!important;}
body[data-section="shop"] .product-art.mock-tee:after{content:'TEE'!important;}
body[data-section="shop"] .product-art.mock-socks:after{content:'SOCKS'!important;}
body[data-section="shop"] .product-art.mock-hoodie:after{content:'HOODIE'!important;}
body[data-section="shop"] .product-art.mock-tote:after{content:'TOTE'!important;}
body[data-section="shop"] .product-art.mock-papers:after{content:'PAPERS'!important;}
body[data-section="shop"] .product-art.mock-filters:after{content:'FILTERS'!important;}
body[data-section="shop"] .product-art.mock-tips:after{content:'TIPS'!important;}
body[data-section="shop"] .product-art.mock-grinder:after{content:'GRINDER'!important;}
body[data-section="shop"] .product-art.mock-lighter:after{content:'LIGHTER'!important;}
body[data-section="shop"] .product-art.mock-wraps:after{content:'WRAPS'!important;}
body[data-section="shop"] .product-art.mock-bong:after{content:'GLASS'!important;}
body[data-section="shop"] .product-art.mock-pipe:after{content:'PIPE'!important;}
body[data-section="shop"] .product-art.mock-vase:after{content:'VASE'!important;}
body[data-section="shop"] .product-art.mock-candle:after{content:'CANDLE'!important;}
body[data-section="shop"] .product-art.mock-tray:after{content:'TRAY'!important;}
body[data-section="shop"] .product-art.mock-ashtray:after{content:'ASH'!important;}
body[data-section="shop"] .product-art.mock-print:after{content:'PRINT'!important;}

body[data-section="shop"] .product-art[class*="mock-"]:after{
  position:relative!important;
  left:auto!important;
  bottom:auto!important;
  z-index:2;
  font-family:var(--display);
  font-size:clamp(22px,2.1vw,36px)!important;
  letter-spacing:.06em!important;
  color:rgba(242,239,232,.46)!important;
  text-align:center;
}
body[data-section="shop"] .product-art[class*="mock-"]:before{
  content:'FTS'!important;
  position:absolute!important;
  left:12px!important;
  top:11px!important;
  right:auto!important;
  bottom:auto!important;
  width:auto!important;
  height:auto!important;
  border:0!important;
  font-family:var(--mono);
  font-size:7px;
  letter-spacing:.22em;
  color:rgba(242,239,232,.26);
  opacity:1!important;
}
body[data-section="shop"] .product-art.mock-hoodie:after,
body[data-section="shop"] .product-art.mock-bong:after,
body[data-section="shop"] .product-art.mock-grinder:after{
  font-size:clamp(19px,1.8vw,30px)!important;
}
html[data-theme="light"] body[data-section="shop"] .product-art[class*="mock-"]{
  background:
    radial-gradient(circle at 50% 38%,rgba(10,10,10,.05),transparent 37%),
    linear-gradient(135deg,rgba(10,10,10,.026),rgba(10,10,10,.004)),
    linear-gradient(135deg,rgba(234,230,220,.96),rgba(249,246,238,.94))!important;
}
html[data-theme="light"] body[data-section="shop"] .product-art[class*="mock-"]:after{
  color:rgba(10,10,10,.42)!important;
}
html[data-theme="light"] body[data-section="shop"] .product-art[class*="mock-"]:before{
  color:rgba(10,10,10,.30)!important;
}


/* V133 product visual cream surfaces: break up the samey black cards with FTS off-white mock-image boxes. */
body[data-section="shop"] .product-art[class*="mock-"]{
  background:
    radial-gradient(circle at 50% 38%,rgba(17,16,14,.055),transparent 38%),
    linear-gradient(135deg,#f5f0e5,#e8dfcf)!important;
  border-color:rgba(242,239,232,.56)!important;
}

body[data-section="shop"] .product-art[class*="mock-"]:after{
  color:rgba(17,16,14,.48)!important;
}

body[data-section="shop"] .product-art[class*="mock-"]:before{
  color:rgba(17,16,14,.36)!important;
}

body[data-section="shop"] .product-card:hover .product-art[class*="mock-"]{
  transform:translateY(-2px);
  border-color:rgba(242,239,232,.9)!important;
}

html[data-theme="light"] body[data-section="shop"] .product-art[class*="mock-"]{
  background:
    radial-gradient(circle at 50% 38%,rgba(17,16,14,.045),transparent 38%),
    linear-gradient(135deg,#fffaf0,#ece3d3)!important;
}


/* V134 product image white test.
   Product mock/image boxes use the same off-white family as the main text for stronger contrast. */
body[data-section="shop"] .product-art[class*="mock-"]{
  background:#f2efe8!important;
  border-color:rgba(242,239,232,.82)!important;
}

body[data-section="shop"] .product-art[class*="mock-"]:after{
  color:rgba(17,16,14,.50)!important;
}

body[data-section="shop"] .product-art[class*="mock-"]:before{
  color:rgba(17,16,14,.36)!important;
}

body[data-section="shop"] .product-card:hover .product-art[class*="mock-"]{
  background:#fffaf0!important;
  border-color:#f2efe8!important;
}

html[data-theme="light"] body[data-section="shop"] .product-art[class*="mock-"]{
  background:#f2efe8!important;
  border-color:rgba(17,16,14,.18)!important;
}


/* V140 Product-ready Store setup.
   The shop becomes a first-drop/demand-testing shelf instead of pretending stock is fully live. */
body[data-section="shop"] .store-mode-panel{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin:18px 0 30px;
}
body[data-section="shop"] .store-mode-panel article{
  border:1px solid var(--line);
  background:linear-gradient(135deg,rgba(242,239,232,.055),rgba(242,239,232,.014));
  padding:16px;
  min-height:145px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
body[data-section="shop"] .store-mode-panel span,
body[data-section="shop"] .product-slot-status,
body[data-section="shop"] .store-readiness-cta span{
  font-family:var(--mono);
  font-size:8px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--accent);
}
body[data-section="shop"] .store-mode-panel b{
  display:block;
  font-family:var(--display);
  font-size:clamp(26px,2.3vw,38px);
  line-height:.9;
  text-transform:uppercase;
}
body[data-section="shop"] .store-mode-panel p{
  color:var(--muted);
  line-height:1.45;
  margin:10px 0 0;
}
body[data-section="shop"] .product-slot-card{
  position:relative;
}
body[data-section="shop"] .product-slot-status{
  display:inline-block;
  margin:2px 0 9px;
  color:rgba(183,196,154,.86);
}
body[data-section="shop"] .product-slot-card h3{
  margin-top:0!important;
}
body[data-section="shop"] .product-slot-card p{
  min-height:3.6em;
}
body[data-section="shop"] .product-bottom{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:8px!important;
}
body[data-section="shop"] .product-bottom strong{
  border-top:1px solid var(--line);
  padding-top:10px;
  margin-top:2px;
}
body[data-section="shop"] .product-bottom .wishlist-action{
  background:transparent!important;
  color:var(--muted)!important;
  border-color:var(--line)!important;
}
body[data-section="shop"] .product-bottom .wishlist-action:hover,
body[data-section="shop"] .product-bottom .wishlist-action:focus{
  background:var(--soft)!important;
  color:var(--ink)!important;
  border-color:var(--line2)!important;
}
body[data-section="shop"] .store-readiness-cta{
  border:1px solid var(--line2);
  margin-top:28px;
  padding:16px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
  background:linear-gradient(135deg,rgba(242,239,232,.065),rgba(242,239,232,.018));
}
body[data-section="shop"] .store-readiness-cta div{
  margin-right:auto;
}
body[data-section="shop"] .store-readiness-cta b{
  display:block;
  font-size:clamp(20px,2vw,30px);
  line-height:1;
}
html[data-theme="light"] body[data-section="shop"] .store-mode-panel article,
html[data-theme="light"] body[data-section="shop"] .store-readiness-cta{
  background:rgba(255,255,255,.42);
  border-color:rgba(17,16,14,.15);
}
html[data-theme="light"] body[data-section="shop"] .product-slot-status{
  color:#70472f;
}
@media(max-width:900px){
  body[data-section="shop"] .store-mode-panel{
    grid-template-columns:1fr;
  }
}
@media(max-width:620px){
  body[data-section="shop"] .store-readiness-cta{
    display:grid;
    grid-template-columns:1fr;
  }
  body[data-section="shop"] .store-readiness-cta .btn{
    width:100%;
  }
}

/* V149 store mobile responsive polish */
/* Store mobile polish: keep product cards neat without pretending stock is live. */
@media(max-width:760px){
  body[data-section="shop"] .page{width:min(100vw - 20px,1440px)!important;}
  body[data-section="shop"] .top-shelf-feature{gap:16px;padding:18px 0;}
  body[data-section="shop"] .top-shelf-track{display:flex!important;overflow-x:auto;gap:10px;padding-bottom:6px;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
  body[data-section="shop"] .top-shelf-track::-webkit-scrollbar{display:none;}
  body[data-section="shop"] .top-shelf-slide{flex:0 0 min(78vw,300px);min-height:190px;}
  body[data-section="shop"] .category-dropdowns{display:grid;grid-template-columns:1fr!important;}
  body[data-section="shop"] .shop-body{margin-top:24px!important;padding:0!important;border-left:0!important;border-right:0!important;}
  body[data-section="shop"] .shop-rail{margin-left:-10px;margin-right:-10px;padding:9px 10px!important;}
  body[data-section="shop"] #storefront .section-head{display:block!important;}
  body[data-section="shop"] .product-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:28px 13px!important;}
  body[data-section="shop"] .product-card h3{white-space:normal!important;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:2.15em;}
  body[data-section="shop"] .product-card .tag{white-space:normal!important;overflow-wrap:anywhere;}
  body[data-section="shop"] .product-bottom .btn.small{width:auto!important;min-height:26px!important;text-align:left!important;justify-content:flex-start!important;}
  body[data-section="shop"] .store-mode-panel{gap:8px;}
}
@media(max-width:390px){
  body[data-section="shop"] .product-grid{gap:24px 10px!important;}
  body[data-section="shop"] .product-art{margin-bottom:9px!important;}
  body[data-section="shop"] .product-card h3{font-size:11px!important;}
}

/* V150 store mobile QA polish */
@media(max-width:760px){
  body[data-section="shop"] .shop-rail{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
  body[data-section="shop"] .shop-rail::-webkit-scrollbar{display:none;}
  body[data-section="shop"] .product-card{min-width:0;}
  body[data-section="shop"] .product-bottom{display:grid!important;grid-template-columns:1fr!important;gap:8px!important;align-items:stretch!important;}
  body[data-section="shop"] .product-bottom .btn,
  body[data-section="shop"] .product-bottom .price{width:100%;justify-content:center;text-align:center;}
  body[data-section="shop"] .product-art{aspect-ratio:1/1;min-height:0!important;}
}
@media(max-width:420px){
  body[data-section="shop"] .product-grid{grid-template-columns:1fr 1fr!important;}
  body[data-section="shop"] .product-card{gap:8px;}
  body[data-section="shop"] .product-bottom .price{font-size:10px;}
}


/* V152 Store category and resize polish */
body[data-section="shop"] .store-category summary{cursor:pointer;}
body[data-section="shop"] .store-category summary:hover{color:var(--ink);}
body[data-section="shop"] .category-dropdowns{overflow:visible;}
body[data-section="shop"] .subcats button{min-height:36px;text-align:left;}
@media(max-width:1180px) and (min-width:861px){
  body[data-section="shop"] .shop-hero{grid-template-columns:minmax(0,1fr) minmax(240px,360px)!important;}
  body[data-section="shop"] .shop-hero h1{font-size:clamp(58px,7vw,96px)!important;}
}
@media(max-width:1020px){
  body[data-section="shop"] .category-dropdowns{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px;}
  body[data-section="shop"] .store-category{scroll-snap-align:start;min-width:0;}
  body[data-section="shop"] .shop-body{margin-top:22px!important;}
}
@media(max-width:620px){
  body[data-section="shop"] .category-dropdowns{grid-template-columns:1fr;overflow:visible;}
  body[data-section="shop"] .shop-hero h1{font-size:clamp(48px,16vw,72px)!important;}
  body[data-section="shop"] .shop-hero .button-row{grid-template-columns:1fr!important;}
}


/* V155 General Store finished-shell polish.
   Goal: premium product-ready shelf, no horizontal overflow, clear Top Shelf / Wishlist / Basket labels. */
body[data-section="shop"]{
  overflow-x:clip;
}
body[data-section="shop"] .page,
body[data-section="shop"] .shop-hero,
body[data-section="shop"] .top-shelf-feature,
body[data-section="shop"] .category-dropdowns,
body[data-section="shop"] .shop-body,
body[data-section="shop"] #storefront,
body[data-section="shop"] .product-grid{
  max-width:100%;
  min-width:0;
}
body[data-section="shop"] .shop-hero{
  grid-template-columns:minmax(0,1.38fr) minmax(240px,.62fr)!important;
  gap:clamp(18px,2.4vw,34px)!important;
  align-items:center;
}
body[data-section="shop"] .shop-hero h1{
  max-width:9.5ch;
}
body[data-section="shop"] .shop-hero .button-row{
  display:grid!important;
  grid-template-columns:minmax(210px,1.15fr) repeat(4,minmax(128px,.85fr));
  gap:10px!important;
  max-width:100%;
}
body[data-section="shop"] .shop-hero .button-row .btn{
  width:100%;
  min-width:0;
  padding-inline:12px;
  white-space:nowrap;
}
body[data-section="shop"] .shop-basket-inline,
body[data-section="shop"] .store-status-basket{
  gap:9px!important;
}
body[data-section="shop"] .shop-basket-inline .cart-count-badge,
body[data-section="shop"] .store-status-basket .cart-count-badge{
  margin-left:8px!important;
  flex:0 0 auto;
}
body[data-section="shop"] .top-shelf-feature{
  grid-template-columns:minmax(180px,235px) minmax(0,1fr)!important;
  gap:clamp(16px,2vw,28px)!important;
  overflow:hidden;
}
body[data-section="shop"] .top-shelf-feature .kicker::after{
  content:''!important;
}
body[data-section="shop"] .top-shelf-feature h2{
  max-width:none!important;
  font-size:clamp(38px,4.2vw,70px)!important;
}
body[data-section="shop"] .top-shelf-feature p{
  max-width:24ch;
}
body[data-section="shop"] .top-shelf-track{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:14px!important;
  width:100%;
  min-width:0;
  overflow:visible;
}
body[data-section="shop"] .top-shelf-slide{
  min-width:0;
  width:100%;
  min-height:216px!important;
  padding:clamp(16px,1.6vw,22px)!important;
}
body[data-section="shop"] .top-shelf-slide b{
  max-width:10ch;
}
body[data-section="shop"] .category-dropdowns{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:12px!important;
  overflow:hidden;
}
body[data-section="shop"] .store-category{
  min-width:0;
  overflow:hidden;
}
body[data-section="shop"] .store-category summary{
  word-break:normal;
  overflow-wrap:anywhere;
}
body[data-section="shop"] .shop-note{
  font-size:clamp(12px,1.15vw,16px)!important;
  line-height:1.65!important;
}
body[data-section="shop"] .store-mode-panel{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:12px!important;
}
body[data-section="shop"] .store-mode-panel article{
  min-width:0;
  min-height:128px;
}
body[data-section="shop"] .shop-body{
  grid-template-columns:minmax(150px,178px) minmax(0,1fr)!important;
  gap:clamp(18px,2vw,28px)!important;
  overflow:visible;
}
body[data-section="shop"] .store-status-row{
  gap:10px 16px!important;
}
body[data-section="shop"] .product-grid{
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
  gap:46px 20px!important;
}
body[data-section="shop"] .product-card{
  min-width:0;
}
body[data-section="shop"] .product-art{
  aspect-ratio:1 / 1.08;
}
body[data-section="shop"] .product-slot-status{
  letter-spacing:.12em!important;
}
body[data-section="shop"] .product-bottom .wishlist-action{
  color:rgba(242,239,232,.64)!important;
}
@media(max-width:1320px){
  body[data-section="shop"] .shop-hero .button-row{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  body[data-section="shop"] .product-grid{
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
  }
}
@media(max-width:1080px){
  body[data-section="shop"] .shop-hero{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .store-card-image{
    min-height:170px;
  }
  body[data-section="shop"] .top-shelf-feature{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .top-shelf-feature p{
    max-width:640px;
  }
  body[data-section="shop"] .category-dropdowns{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  body[data-section="shop"] .shop-body{
    grid-template-columns:1fr!important;
    border-left:0!important;
    border-right:0!important;
    padding-inline:0!important;
  }
  body[data-section="shop"] .shop-rail{
    position:relative!important;
    top:auto!important;
    max-height:none!important;
  }
  body[data-section="shop"] .product-grid{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
  }
}
@media(max-width:760px){
  body[data-section="shop"] .page{
    width:min(100vw - 22px,1440px)!important;
  }
  body[data-section="shop"] .shop-hero .button-row{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .top-shelf-track{
    display:flex!important;
    overflow-x:auto!important;
    gap:10px!important;
    padding-bottom:8px;
    scroll-snap-type:x mandatory;
  }
  body[data-section="shop"] .top-shelf-slide{
    flex:0 0 min(82vw,310px)!important;
    scroll-snap-align:start;
  }
  body[data-section="shop"] .category-dropdowns,
  body[data-section="shop"] .store-mode-panel{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .product-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:30px 13px!important;
  }
  body[data-section="shop"] .store-readiness-cta{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .store-readiness-cta .btn{
    width:100%;
  }
}
@media(max-width:420px){
  body[data-section="shop"] .product-grid{
    grid-template-columns:1fr!important;
  }
}


/* V160 Store navigation hierarchy polish
   Categories now sit high on the page as the primary browsing control;
   the sticky side rail remains for deeper shelf navigation. */
body[data-section="shop"] .store-category-strip{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:14px 0 16px;
  margin:18px 0 18px;
}
body[data-section="shop"] .store-category-strip > .kicker{
  margin:0 0 5px;
}
body[data-section="shop"] .store-category-strip > p{
  margin:0 0 12px;
  color:var(--muted);
  font-size:13px;
  max-width:720px;
}
body[data-section="shop"] .store-category-strip .category-dropdowns{
  margin-top:0!important;
}
body[data-section="shop"] .top-shelf-feature{
  margin-top:0!important;
}
@media(max-width:760px){
  body[data-section="shop"] .store-category-strip{padding:12px 0;margin:14px 0;}
  body[data-section="shop"] .store-category-strip > p{font-size:12px;}
}

/* V165: store route buttons remain concise: Top Shelf / Basket / Checkout. */


/* V166: Store hero button label clarity */
.store-hero-actions a,
.store-hero-actions button,
.shop-hero-actions a,
.shop-hero-actions button {
  white-space: nowrap;
}
.store-hero-actions .basket-count,
.shop-hero-actions .basket-count,
.store-hero-actions [data-cart-count],
.shop-hero-actions [data-cart-count] {
  margin-left: .75em;
}


/* V174: stable store filter layout */
[data-product-card].is-hidden {
  display: none !important;
}

.storefront-title,
.current-shelf-title,
.shelf-title,
[data-store-current-title],
[data-shelf-title] {
  display: inline !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  writing-mode: horizontal-tb !important;
  transform: none !important;
}

.store-category summary {
  cursor: pointer;
}

.store-category[open] {
  background: rgba(255,255,255,.018);
}

.shop-rail [data-store-filter].active,
.shop-rail [data-store-subfilter].active,
.category-dropdowns [data-store-subfilter].active {
  color: var(--cream, #f4efe7);
  border-bottom-color: var(--cream, #f4efe7);
}


/* V224 General Store request box refinement */
body[data-section="shop"] .store-readiness-cta{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(300px,520px)!important;
  align-items:stretch!important;
  gap:18px!important;
  padding:24px 28px!important;
  margin-top:30px!important;
  justify-content:initial!important;
}
body[data-section="shop"] .store-readiness-cta .store-cta-copy{
  margin-right:0!important;
  align-self:center!important;
  max-width:760px;
}
body[data-section="shop"] .store-readiness-cta .store-cta-copy b{
  max-width:720px;
  font-size:clamp(30px,3.3vw,54px)!important;
  line-height:.9!important;
  letter-spacing:-.015em;
}
body[data-section="shop"] .store-readiness-cta .store-cta-copy small{
  max-width:620px;
  margin-top:8px;
  font-size:10px!important;
  line-height:1.7!important;
}
body[data-section="shop"] .store-cta-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
body[data-section="shop"] .store-cta-link{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
  min-height:58px;
  padding:14px 16px;
  border:1px solid var(--line2);
  background:rgba(242,239,232,.045);
  color:var(--ink);
  font-family:var(--mono);
  font-size:11px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  text-decoration:none;
}
body[data-section="shop"] .store-cta-link::after{
  content:'→';
  font-size:16px;
  line-height:1;
  opacity:.78;
}
body[data-section="shop"] .store-cta-link small{
  grid-column:1 / -1;
  margin-top:-8px;
  font-size:9px!important;
  letter-spacing:.12em!important;
  line-height:1.45!important;
  color:var(--muted);
}
body[data-section="shop"] .store-cta-link.primary{
  background:var(--ink);
  color:var(--bg);
  border-color:var(--ink);
}
body[data-section="shop"] .store-cta-link.primary small{
  color:rgba(8,8,7,.68);
}
body[data-section="shop"] .store-cta-link:hover,
body[data-section="shop"] .store-cta-link:focus{
  border-color:var(--accent);
  background:rgba(183,196,154,.12);
  outline:0;
}
body[data-section="shop"] .store-cta-link.primary:hover,
body[data-section="shop"] .store-cta-link.primary:focus{
  background:var(--accent2);
  color:#080807;
}
html[data-theme="light"] body[data-section="shop"] .store-cta-link{
  background:rgba(17,16,14,.035);
  border-color:rgba(17,16,14,.18);
  color:#11100e;
}
html[data-theme="light"] body[data-section="shop"] .store-cta-link.primary{
  background:#11100e;
  color:#f4f0e7;
  border-color:#11100e;
}
html[data-theme="light"] body[data-section="shop"] .store-cta-link.primary small{
  color:rgba(244,240,231,.72);
}
@media(max-width:980px){
  body[data-section="shop"] .store-readiness-cta{
    grid-template-columns:1fr!important;
    padding:20px!important;
  }
}
@media(max-width:620px){
  body[data-section="shop"] .store-readiness-cta{
    padding:16px!important;
  }
  body[data-section="shop"] .store-readiness-cta .store-cta-copy b{
    font-size:clamp(28px,11vw,42px)!important;
  }
}

/* V225 General Store request box space refinement */
body[data-section="shop"] .store-readiness-cta{
  grid-template-columns:minmax(340px,.78fr) minmax(560px,1.22fr)!important;
  gap:28px!important;
  padding:28px 30px!important;
  min-height:360px;
}
body[data-section="shop"] .store-readiness-cta .store-cta-copy{
  max-width:680px!important;
}
body[data-section="shop"] .store-readiness-cta .store-cta-copy b{
  max-width:640px!important;
  font-size:clamp(34px,3vw,50px)!important;
  line-height:.92!important;
}
body[data-section="shop"] .store-readiness-cta .store-cta-copy small{
  max-width:610px!important;
}
body[data-section="shop"] .store-cta-actions{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
  align-content:center;
}
body[data-section="shop"] .store-cta-link{
  min-height:128px!important;
  padding:20px 22px!important;
  align-content:start;
  align-items:start!important;
}
body[data-section="shop"] .store-cta-link.primary{
  grid-column:1 / -1;
  min-height:112px!important;
}
body[data-section="shop"] .store-cta-link small{
  margin-top:4px!important;
  max-width:34ch;
}
body[data-section="shop"] .store-cta-link::after{
  align-self:end;
}
@media(max-width:1100px){
  body[data-section="shop"] .store-readiness-cta{
    grid-template-columns:1fr!important;
    min-height:0;
  }
  body[data-section="shop"] .store-cta-actions{
    align-content:initial;
  }
}
@media(max-width:720px){
  body[data-section="shop"] .store-cta-actions{
    grid-template-columns:1fr!important;
  }
  body[data-section="shop"] .store-cta-link.primary{
    grid-column:auto;
  }
  body[data-section="shop"] .store-cta-link{
    min-height:92px!important;
  }
}

/* V226 General Store request box alignment refinement */
@media(min-width:1101px){
  body[data-section="shop"] .store-readiness-cta{
    grid-template-columns:minmax(340px,.68fr) minmax(680px,1.32fr)!important;
    gap:34px!important;
  }
  body[data-section="shop"] .store-cta-actions{
    justify-self:end!important;
    width:min(880px,100%)!important;
  }
}

/* V227 General Store request box containment fix */
@media(min-width:1101px){
  body[data-section="shop"] .store-readiness-cta{
    grid-template-columns:minmax(320px,.38fr) minmax(560px,.62fr)!important;
    gap:clamp(32px,3.6vw,70px)!important;
    padding:56px 64px!important;
    overflow:hidden!important;
    box-sizing:border-box!important;
  }
  body[data-section="shop"] .store-cta-actions{
    justify-self:center!important;
    width:100%!important;
    max-width:980px!important;
    box-sizing:border-box!important;
  }
  body[data-section="shop"] .store-cta-link{
    box-sizing:border-box!important;
    max-width:100%!important;
  }
}
@media(min-width:1101px) and (max-width:1300px){
  body[data-section="shop"] .store-readiness-cta{
    grid-template-columns:minmax(300px,.4fr) minmax(480px,.6fr)!important;
    gap:28px!important;
    padding:42px 46px!important;
  }
}

/* V228 General Store hero full-bleed skate image background */
body[data-section="shop"] .shop-hero{
  position:relative!important;
  overflow:hidden!important;
  display:block!important;
  min-height:clamp(430px,34vw,620px)!important;
  padding:clamp(24px,3.2vw,42px)!important;
  background:linear-gradient(135deg,rgba(8,8,7,.84),rgba(8,8,7,.58) 42%,rgba(8,8,7,.72))!important;
  isolation:isolate;
}
body[data-section="shop"] .shop-hero .store-card-image{
  position:absolute!important;
  inset:0!important;
  z-index:0!important;
  min-height:0!important;
  width:100%!important;
  height:100%!important;
  border:0!important;
  opacity:.74!important;
  filter:grayscale(1) contrast(1.08) brightness(.86)!important;
  background:url('ASH_OLLIE_FTS.JPG') center 45% / cover no-repeat!important;
  pointer-events:none!important;
}
body[data-section="shop"] .shop-hero .store-card-image::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(8,8,7,.92) 0%,rgba(8,8,7,.70) 34%,rgba(8,8,7,.42) 66%,rgba(8,8,7,.68) 100%),
    linear-gradient(0deg,rgba(8,8,7,.80) 0%,rgba(8,8,7,.20) 45%,rgba(8,8,7,.54) 100%);
}
body[data-section="shop"] .shop-hero::before{
  z-index:3!important;
}
body[data-section="shop"] .shop-hero > div:first-child{
  position:relative!important;
  z-index:2!important;
  max-width:min(1060px,72%)!important;
}
body[data-section="shop"] .shop-hero h1,
body[data-section="shop"] .shop-hero .lead,
body[data-section="shop"] .shop-hero p,
body[data-section="shop"] .shop-hero .kicker,
body[data-section="shop"] .shop-hero .btn{
  text-shadow:0 2px 18px rgba(0,0,0,.62);
}
body[data-section="shop"] .shop-hero .button-row{
  max-width:min(960px,100%)!important;
  margin-top:clamp(22px,2.6vw,34px)!important;
}
@media(max-width:1080px){
  body[data-section="shop"] .shop-hero{
    min-height:520px!important;
  }
  body[data-section="shop"] .shop-hero > div:first-child{
    max-width:100%!important;
  }
  body[data-section="shop"] .shop-hero .store-card-image{
    background-position:62% 45%!important;
  }
  body[data-section="shop"] .shop-hero .store-card-image::after{
    background:
      linear-gradient(90deg,rgba(8,8,7,.94),rgba(8,8,7,.66)),
      linear-gradient(0deg,rgba(8,8,7,.84),rgba(8,8,7,.24) 46%,rgba(8,8,7,.60));
  }
}
@media(max-width:620px){
  body[data-section="shop"] .shop-hero{
    min-height:560px!important;
  }
  body[data-section="shop"] .shop-hero .store-card-image{
    background-position:64% 46%!important;
    opacity:.62!important;
  }
}

/* V228 QA brightness pass: keep the hero readable, but let the skate image show through more clearly. */
body[data-section="shop"] .shop-hero .store-card-image{
  opacity:.90!important;
  filter:grayscale(1) contrast(1.08) brightness(1.02)!important;
}
body[data-section="shop"] .shop-hero .store-card-image::after{
  background:
    linear-gradient(90deg,rgba(8,8,7,.86) 0%,rgba(8,8,7,.62) 32%,rgba(8,8,7,.22) 66%,rgba(8,8,7,.34) 100%),
    linear-gradient(0deg,rgba(8,8,7,.58) 0%,rgba(8,8,7,.10) 45%,rgba(8,8,7,.36) 100%)!important;
}
@media(max-width:1080px){
  body[data-section="shop"] .shop-hero .store-card-image{
    opacity:.82!important;
  }
  body[data-section="shop"] .shop-hero .store-card-image::after{
    background:
      linear-gradient(90deg,rgba(8,8,7,.88),rgba(8,8,7,.44)),
      linear-gradient(0deg,rgba(8,8,7,.62),rgba(8,8,7,.10) 46%,rgba(8,8,7,.38))!important;
  }
}
@media(max-width:620px){
  body[data-section="shop"] .shop-hero .store-card-image{
    opacity:.70!important;
  }
}

/* V228 final visual balance: clearer full-bleed skate photo while preserving dark FTS contrast. */
body[data-section="shop"] .shop-hero .store-card-image{
  opacity:1!important;
  filter:grayscale(1) contrast(1.08) brightness(1.18)!important;
}
body[data-section="shop"] .shop-hero .store-card-image::after{
  background:
    linear-gradient(90deg,rgba(8,8,7,.78) 0%,rgba(8,8,7,.50) 33%,rgba(8,8,7,.16) 66%,rgba(8,8,7,.18) 100%),
    linear-gradient(0deg,rgba(8,8,7,.32) 0%,rgba(8,8,7,.04) 45%,rgba(8,8,7,.20) 100%)!important;
}
@media(max-width:1080px){
  body[data-section="shop"] .shop-hero .store-card-image{
    opacity:.90!important;
    filter:grayscale(1) contrast(1.08) brightness(1.05)!important;
  }
  body[data-section="shop"] .shop-hero .store-card-image::after{
    background:
      linear-gradient(90deg,rgba(8,8,7,.82),rgba(8,8,7,.34)),
      linear-gradient(0deg,rgba(8,8,7,.42),rgba(8,8,7,.06) 46%,rgba(8,8,7,.24))!important;
  }
}


/* V231 subtle hero image nudge: keep hero size unchanged, move the skate shot down slightly. */
body[data-section="shop"] .shop-hero .store-card-image{
  background-position:center 40%!important;
}
@media(max-width:1080px){
  body[data-section="shop"] .shop-hero .store-card-image{
    background-position:62% 42%!important;
  }
}
@media(max-width:620px){
  body[data-section="shop"] .shop-hero .store-card-image{
    background-position:64% 43%!important;
  }
}


/* V232 General Store fold balance:
   Keep the hero design, but move the whole hero block up and tighten the fold
   so the four main category boxes are visible underneath on first load. */
body[data-section="shop"] .page{
  padding-top:clamp(18px,2.2vw,28px)!important;
}
body[data-section="shop"] .shop-hero{
  min-height:clamp(355px,29vw,470px)!important;
  padding:clamp(18px,2.45vw,34px)!important;
  margin-top:0!important;
}
body[data-section="shop"] .shop-hero h1{
  font-size:clamp(76px,8.6vw,142px)!important;
  line-height:.82!important;
}
body[data-section="shop"] .shop-hero .lead{
  margin-top:clamp(16px,1.7vw,24px)!important;
}
body[data-section="shop"] .shop-hero p{
  max-width:1040px!important;
  margin-top:clamp(14px,1.6vw,22px)!important;
}
body[data-section="shop"] .shop-hero .button-row{
  margin-top:clamp(16px,1.9vw,26px)!important;
}

/* Pull the category strip closer to the hero so all four closed boxes sit in the first fold. */
body[data-section="shop"] .category-shell{
  margin-top:18px!important;
  padding-top:18px!important;
}
body[data-section="shop"] .category-dropdowns{
  margin-top:14px!important;
}
body[data-section="shop"] .category-card{
  min-height:86px!important;
}
body[data-section="shop"] .category-card-header{
  min-height:86px!important;
  padding:24px 28px!important;
}

/* Category click: closed cards remain compact; opening them scrolls the user down to the subcategory area. */
body[data-section="shop"] .category-card:not(.is-open) .category-panel{
  display:none!important;
}

@media(max-width:1080px){
  body[data-section="shop"] .page{
    padding-top:18px!important;
  }
  body[data-section="shop"] .shop-hero{
    min-height:430px!important;
  }
  body[data-section="shop"] .shop-hero h1{
    font-size:clamp(58px,9.4vw,96px)!important;
  }
  body[data-section="shop"] .category-card,
  body[data-section="shop"] .category-card-header{
    min-height:80px!important;
  }
}
@media(max-width:620px){
  body[data-section="shop"] .shop-hero{
    min-height:520px!important;
  }
  body[data-section="shop"] .category-dropdowns{
    grid-template-columns:1fr!important;
  }
}


/* V233 General Store categories occupy fold:
   Remove the Shop Categories label/copy area and let the four category boxes fill that space. */
body[data-section="shop"] .category-shell .section-kicker,
body[data-section="shop"] .category-shell .section-head,
body[data-section="shop"] .category-shell > .kicker,
body[data-section="shop"] .category-shell > h2,
body[data-section="shop"] .category-shell > p{
  display:none!important;
}

body[data-section="shop"] .category-shell{
  margin-top:16px!important;
  padding-top:14px!important;
}

body[data-section="shop"] .category-dropdowns{
  margin-top:0!important;
}

body[data-section="shop"] .category-card,
body[data-section="shop"] .category-card-header{
  min-height:104px!important;
}

body[data-section="shop"] .category-card-header{
  padding:30px 28px!important;
}

@media(max-width:1080px){
  body[data-section="shop"] .category-card,
  body[data-section="shop"] .category-card-header{
    min-height:92px!important;
  }
  body[data-section="shop"] .category-card-header{
    padding:26px 24px!important;
  }
}

@media(max-width:620px){
  body[data-section="shop"] .category-shell{
    margin-top:14px!important;
    padding-top:12px!important;
  }
}


/* V235 definitive category-strip cleanup:
   Remove the top Shop Categories intro line and let the 4 boxes occupy that space. */
body[data-section="shop"] .store-category-strip > .kicker,
body[data-section="shop"] .store-category-strip > p{
  display:none!important;
}
body[data-section="shop"] .store-category-strip{
  margin-top:16px!important;
  padding-top:14px!important;
}
body[data-section="shop"] .store-category-strip .category-dropdowns{
  margin-top:0!important;
}
body[data-section="shop"] .shop-rail-title{
  text-transform:uppercase!important;
}


/* V237 category scroll target support */
body[data-section="shop"] .store-category-strip{
  scroll-margin-top:96px;
}
