/* ═══════════════════════════════════════════
   IS Outlets – Pro Shop Grid
   shop-grid.css v1.0.0
═══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@500;600;700&family=DM+Sans:wght@400;500;600;700&display=swap');

:root{
  --iso-gold:#c9a84c;
  --iso-gold2:#f0d080;
  --iso-dark:#0b0b0b;
  --iso-card:#141414;
  --iso-panel:#1c1c1c;
  --iso-border:#242424;
  --iso-text:#f0ece4;
  --iso-muted:#666;
  --iso-red:#e84040;
  --iso-green:#27ae60;
  --iso-radius:4px;
}

/* ── WRAP ── */
.iso-shop-wrap{
  background:var(--iso-dark);
  padding:48px 0 64px;
  font-family:'DM Sans',sans-serif;
  color:var(--iso-text);
}

/* ── TOP BAR ── */
.iso-shop-topbar{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:28px;
  flex-wrap:wrap;
}
.iso-eyebrow{
  display:block;
  font-size:10px;
  letter-spacing:5px;
  text-transform:uppercase;
  color:var(--iso-gold);
  margin-bottom:6px;
}
.iso-shop-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(36px,6vw,72px);
  letter-spacing:3px;
  line-height:.95;
  color:var(--iso-text);
}
.iso-shop-title span{color:var(--iso-gold);}

/* Search */
.iso-shop-search-wrap{
  position:relative;
  flex-shrink:0;
}
.iso-search-input{
  background:var(--iso-panel);
  border:1px solid var(--iso-border);
  border-radius:var(--iso-radius);
  color:var(--iso-text);
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  padding:10px 40px 10px 14px;
  outline:none;
  width:240px;
  transition:border-color .2s,box-shadow .2s;
}
.iso-search-input:focus{
  border-color:var(--iso-gold);
  box-shadow:0 0 0 3px rgba(201,168,76,.1);
}
.iso-search-input::placeholder{color:#444;}
.iso-search-icon{
  position:absolute;right:12px;top:50%;
  transform:translateY(-50%);
  width:16px;height:16px;
  stroke:var(--iso-muted);fill:none;stroke-width:2;
  pointer-events:none;
}

/* ── FILTER ROW ── */
.iso-filter-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:16px;
  flex-wrap:wrap;
  border-bottom:1px solid var(--iso-border);
  padding-bottom:16px;
}
.iso-filter-tabs{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.iso-ftab{
  background:none;
  border:1px solid var(--iso-border);
  color:var(--iso-muted);
  font-family:'DM Sans',sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:1.5px;
  text-transform:uppercase;
  padding:7px 14px;
  border-radius:2px;
  cursor:pointer;
  transition:all .2s;
  display:flex;
  align-items:center;
  gap:6px;
}
.iso-ftab:hover{border-color:var(--iso-gold);color:var(--iso-text);}
.iso-ftab.active{
  background:var(--iso-gold);
  border-color:var(--iso-gold);
  color:var(--iso-dark);
}
.iso-ftab-count{
  background:rgba(255,255,255,.12);
  padding:1px 6px;
  border-radius:10px;
  font-size:9px;
  font-weight:700;
}
.iso-ftab.active .iso-ftab-count{
  background:rgba(0,0,0,.2);
}

/* Sort */
.iso-sort-select{
  background:var(--iso-panel);
  border:1px solid var(--iso-border);
  border-radius:var(--iso-radius);
  color:var(--iso-text);
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  padding:8px 14px;
  outline:none;
  cursor:pointer;
  transition:border-color .2s;
}
.iso-sort-select:focus{border-color:var(--iso-gold);}

/* ── RESULTS BAR ── */
.iso-results-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:20px;
}
.iso-results-bar span{
  font-size:12px;
  color:var(--iso-muted);
}
.iso-results-bar strong{color:var(--iso-gold);}
.iso-view-toggle{display:flex;gap:4px;}
.iso-view-btn{
  width:32px;height:32px;
  background:var(--iso-panel);
  border:1px solid var(--iso-border);
  border-radius:3px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.iso-view-btn svg{
  width:14px;height:14px;
  fill:var(--iso-muted);transition:fill .2s;
}
.iso-view-btn:hover{border-color:var(--iso-gold);}
.iso-view-btn.active{background:var(--iso-gold);border-color:var(--iso-gold);}
.iso-view-btn.active svg{fill:var(--iso-dark);}

/* ── GRID ── */
.iso-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  transition:opacity .3s;
}
.iso-grid.loading{opacity:.4;pointer-events:none;}

/* List view */
.iso-grid.list-view{
  grid-template-columns:1fr;
  gap:12px;
}
.iso-grid.list-view .iso-card{
  display:grid;
  grid-template-columns:200px 1fr;
  align-items:center;
}
.iso-grid.list-view .iso-img-wrap{
  aspect-ratio:1/1;
  height:200px;
}
.iso-grid.list-view .iso-card-body{
  padding:20px 24px;
}
.iso-grid.list-view .iso-card-name{
  font-size:20px;
  -webkit-line-clamp:2;
}

/* ── CARD ── */
.iso-card{
  background:var(--iso-card);
  border:1px solid var(--iso-border);
  border-radius:var(--iso-radius);
  overflow:hidden;
  position:relative;
  transition:transform .3s,box-shadow .3s,border-color .3s;
  animation:isoCardIn .45s ease both;
}
@keyframes isoCardIn{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:translateY(0);}
}
.iso-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.55);
  border-color:rgba(201,168,76,.35);
}

/* Badge */
.iso-badge{
  position:absolute;top:12px;left:12px;
  font-size:10px;font-weight:700;letter-spacing:1px;
  text-transform:uppercase;padding:3px 9px;
  border-radius:2px;z-index:3;
}
.iso-badge-sale{background:var(--iso-red);color:#fff;}
.iso-badge-new{background:var(--iso-green);color:#fff;}

/* Wishlist */
.iso-wish-btn{
  position:absolute;top:10px;right:10px;
  width:33px;height:33px;
  background:rgba(10,10,10,.8);
  border:1px solid var(--iso-border);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  z-index:3;cursor:pointer;
  transition:all .2s;
  backdrop-filter:blur(4px);
}
.iso-wish-btn:hover{border-color:var(--iso-gold);}
.iso-wish-btn svg{
  width:13px;height:13px;
  fill:none;stroke:var(--iso-gold);stroke-width:2;
  transition:all .2s;
}
.iso-wish-btn.active svg{fill:var(--iso-red);stroke:var(--iso-red);}

/* Image */
.iso-img-link{display:block;}
.iso-img-wrap{
  width:100%;aspect-ratio:3/4;
  overflow:hidden;
  background:#1a1a1a;
  position:relative;
}
.iso-img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s ease;
  display:block;
}
.iso-card:hover .iso-img{transform:scale(1.06);}

/* Overlay */
.iso-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(10,10,10,.9) 0%,rgba(10,10,10,.1) 60%,transparent);
  display:flex;flex-direction:column;
  align-items:center;justify-content:flex-end;
  gap:8px;padding:16px;
  opacity:0;transition:opacity .3s;
}
.iso-card:hover .iso-img-overlay{opacity:1;}
.iso-quick-view{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;
  font-family:'DM Sans',sans-serif;
  font-size:11px;font-weight:600;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:8px 18px;border-radius:2px;cursor:pointer;
  transition:all .2s;width:100%;
}
.iso-quick-view:hover{background:rgba(255,255,255,.2);}
.iso-shop-btn{
  display:block;width:100%;
  background:var(--iso-gold);
  color:var(--iso-dark);
  font-family:'DM Sans',sans-serif;
  font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:9px;border-radius:2px;
  text-align:center;text-decoration:none;
  transition:background .2s;
}
.iso-shop-btn:hover{background:var(--iso-gold2);}

/* Card body */
.iso-card-body{padding:14px 14px 16px;}
.iso-cat-label{
  font-size:9px;letter-spacing:3px;
  text-transform:uppercase;color:var(--iso-gold);
  display:block;margin-bottom:4px;
}
.iso-card-name{
  font-family:'Barlow Condensed',sans-serif;
  font-size:16px;font-weight:700;letter-spacing:.3px;
  line-height:1.3;margin-bottom:8px;
  display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.iso-card-name a{color:var(--iso-text);text-decoration:none;transition:color .2s;}
.iso-card-name a:hover{color:var(--iso-gold);}

/* Stars */
.iso-stars-row{display:flex;align-items:center;gap:1px;margin-bottom:8px;}
.iso-star{font-size:11px;color:var(--iso-border);}
.iso-star.on{color:var(--iso-gold);}
.iso-review-ct{font-size:10px;color:var(--iso-muted);margin-left:4px;}

/* Price */
.iso-price-row{
  display:flex;align-items:baseline;gap:8px;
  flex-wrap:wrap;margin-bottom:12px;
}
.iso-price-now{
  font-family:'Bebas Neue',sans-serif;
  font-size:26px;color:var(--iso-gold);letter-spacing:1px;
}
.iso-price-old{
  font-size:12px;color:var(--iso-muted);
  text-decoration:line-through;
}
.iso-save-tag{
  font-size:9px;font-weight:700;
  background:rgba(232,64,64,.15);
  border:1px solid rgba(232,64,64,.3);
  color:var(--iso-red);
  padding:2px 7px;border-radius:2px;
  letter-spacing:.5px;
}

/* Footer */
.iso-card-footer{
  display:flex;align-items:center;
  justify-content:space-between;gap:8px;
}
.iso-atc-btn{
  flex:1;
  background:var(--iso-panel);
  border:1px solid var(--iso-border);
  color:var(--iso-text);
  font-family:'DM Sans',sans-serif;
  font-size:11px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:9px 10px;border-radius:2px;
  cursor:pointer;transition:all .2s;
}
.iso-atc-btn:hover{
  background:var(--iso-gold);
  border-color:var(--iso-gold);
  color:var(--iso-dark);
}
.iso-atc-btn.adding{
  background:var(--iso-green);
  border-color:var(--iso-green);
  color:#fff;pointer-events:none;
}
.iso-free-tag{
  font-size:9px;color:var(--iso-green);
  font-weight:700;letter-spacing:.5px;
  white-space:nowrap;
}

/* ── EMPTY STATE ── */
.iso-empty{
  grid-column:1/-1;
  text-align:center;padding:80px 20px;
}
.iso-empty-icon{font-size:48px;margin-bottom:16px;}
.iso-empty h3{
  font-family:'Bebas Neue',sans-serif;
  font-size:36px;letter-spacing:3px;
  color:var(--iso-border);margin-bottom:8px;
}
.iso-empty p{color:var(--iso-muted);font-size:13px;}

/* ── SKELETON LOADER ── */
.iso-skeleton{
  background:var(--iso-card);
  border:1px solid var(--iso-border);
  border-radius:var(--iso-radius);
  overflow:hidden;animation:isoCardIn .3s ease both;
}
.iso-skel-img{
  width:100%;aspect-ratio:3/4;
  background:linear-gradient(90deg,#1a1a1a 25%,#222 50%,#1a1a1a 75%);
  background-size:200% 100%;
  animation:isoShimmer 1.4s infinite;
}
.iso-skel-body{padding:14px;}
.iso-skel-line{
  height:10px;border-radius:3px;margin-bottom:8px;
  background:linear-gradient(90deg,#1a1a1a 25%,#222 50%,#1a1a1a 75%);
  background-size:200% 100%;
  animation:isoShimmer 1.4s infinite;
}
.iso-skel-line.w70{width:70%;}
.iso-skel-line.w50{width:50%;}
.iso-skel-line.w40{width:40%;}
@keyframes isoShimmer{
  0%{background-position:200% 0;}
  100%{background-position:-200% 0;}
}

/* ── LOAD MORE ── */
.iso-load-more-wrap{
  text-align:center;
  margin-top:40px;
  padding-top:32px;
  border-top:1px solid var(--iso-border);
}
.iso-load-more{
  background:transparent;
  border:1px solid var(--iso-gold);
  color:var(--iso-gold);
  font-family:'DM Sans',sans-serif;
  font-size:12px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;
  padding:14px 40px;border-radius:2px;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:10px;
  transition:all .2s;margin-bottom:20px;
}
.iso-load-more:hover{
  background:var(--iso-gold);
  color:var(--iso-dark);
}
.iso-load-more:disabled{
  opacity:.4;cursor:not-allowed;
}
.iso-lm-count{
  background:rgba(201,168,76,.15);
  padding:2px 10px;border-radius:10px;
  font-size:10px;
}
.iso-lm-spinner{
  animation:isoSpin 1s linear infinite;
  font-size:18px;
}
@keyframes isoSpin{to{transform:rotate(360deg);}}

/* Progress bar */
.iso-progress-bar{
  width:240px;height:3px;
  background:var(--iso-border);
  border-radius:3px;margin:0 auto 10px;
  overflow:hidden;
}
.iso-progress-fill{
  height:100%;
  background:linear-gradient(90deg,var(--iso-gold),var(--iso-gold2));
  border-radius:3px;
  transition:width .4s ease;
}
.iso-progress-text{
  font-size:11px;color:var(--iso-muted);
  letter-spacing:1px;
}

/* ── TOAST ── */
.iso-toast{
  position:fixed;bottom:28px;left:50%;
  transform:translateX(-50%) translateY(16px);
  background:var(--iso-card);
  border:1px solid var(--iso-gold);
  color:var(--iso-gold);
  font-family:'DM Sans',sans-serif;
  font-size:12px;font-weight:600;
  letter-spacing:1px;
  padding:11px 24px;border-radius:3px;
  opacity:0;pointer-events:none;
  transition:opacity .3s,transform .3s;
  white-space:nowrap;z-index:9999;
  box-shadow:0 8px 30px rgba(0,0,0,.5);
}
.iso-toast.show{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .iso-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:768px){
  .iso-shop-wrap{padding:32px 0 48px;}
  .iso-shop-topbar{flex-direction:column;align-items:flex-start;gap:14px;}
  .iso-search-input{width:100%;}
  .iso-shop-search-wrap{width:100%;}
  .iso-filter-row{flex-direction:column;align-items:flex-start;}
  .iso-sort-select{width:100%;}
  .iso-grid{grid-template-columns:repeat(2,1fr);gap:12px;}
  .iso-grid.list-view{grid-template-columns:1fr;}
  .iso-grid.list-view .iso-card{grid-template-columns:130px 1fr;}
  .iso-grid.list-view .iso-img-wrap{height:130px;}
  .iso-grid.list-view .iso-card-body{padding:12px 14px;}
  .iso-grid.list-view .iso-card-name{font-size:16px;}
}
@media(max-width:420px){
  .iso-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
  .iso-card-body{padding:10px 10px 12px;}
  .iso-card-name{font-size:13px;}
  .iso-price-now{font-size:21px;}
  .iso-atc-btn{font-size:10px;padding:8px 6px;letter-spacing:1px;}
  .iso-free-tag{display:none;}
}
