:root{
  --bt-shop-radius:18px;
}
body{
  padding-top:72px;
}
.bt-page-title{
  font-family:var(--bt-title);
  font-size:clamp(1.8rem,3vw,2.4rem);
  margin:0;
}
.bt-shop-hero{
  padding:18px 0 8px;
}
.bt-shop-hero .bt-lead{
  margin-bottom:0;
}
.bt-navbar{
  padding-top:.55rem;
  padding-bottom:.55rem;
}
.bt-shop-search{
  width:min(760px, 62vw);
}
@media (max-width: 992px){
  .bt-shop-search{width:100%}
}
.bt-shop-search .form-control{
  background:rgba(3,2,10,.55);
  border:1px solid rgba(250,241,233,.10);
  color:var(--bt-cream);
}
.bt-shop-search .form-control::placeholder{color:rgba(250,241,233,.55)}
.bt-shop-search .form-control:focus{
  background:rgba(3,2,10,.65);
  border-color:rgba(18,227,235,.55);
  box-shadow:0 0 0 .25rem rgba(18,227,235,.12);
  color:var(--bt-cream);
}
.bt-shop-search .btn{
  border:1px solid rgba(250,241,233,.10);
}
.bt-shop-pillbar{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  justify-content:center;
}
.shop-pill{
  border:1px solid rgba(250,241,233,.10);
  background:rgba(3,2,10,.35);
  color:rgba(250,241,233,.82);
  padding:.55rem .9rem;
  border-radius:999px;
  font-weight:700;
  transition:transform .12s ease, border-color .12s ease, background-color .12s ease;
}
.shop-pill:hover{transform:translateY(-1px); border-color:rgba(18,227,235,.40)}
.shop-pill.active{
  background:linear-gradient(135deg, rgba(18,227,235,.90), rgba(209,21,121,.90));
  color:#0b0a14;
  border-color:rgba(250,241,233,.10);
}
.shop-product{
  border-radius:var(--bt-shop-radius);
  background:rgba(30,28,51,.72);
  border:1px solid rgba(250,241,233,.08);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  overflow:hidden;
  min-height:100%;
  color:rgba(250,241,233,.92);
}
.shop-product h5,
.shop-product .fw-semibold{
  color:rgba(250,241,233,.96) !important;
}
.shop-product .text-muted{color:rgba(250,241,233,.62) !important}
.shop-product-img{
  height:140px;
  border-radius:14px;
  background:rgba(3,2,10,.35);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border:1px solid rgba(250,241,233,.08);
}
.shop-product-img img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.shop-product-img i{
  font-size:2rem;
  color:rgba(18,227,235,.85);
}
.shop-price{
  font-weight:900;
  font-size:1.08rem;
  color:rgba(250,241,233,.95);
}
.shop-price-old{
  margin-left:.5rem;
  color:rgba(250,241,233,.55);
  text-decoration:line-through;
  font-weight:700;
}
.bt-feature{
  padding:10px 0 20px;
}
.bt-shop-featured{
  padding:6px 0 10px;
}
.bt-link{
  color:rgba(18,227,235,.90);
  text-decoration:none;
  font-weight:800;
}
.bt-link:hover{color:rgba(18,227,235,1); text-decoration:underline}
.bt-featured-row{
  display:flex;
  gap:14px;
  overflow:auto;
  padding-bottom:8px;
  scroll-snap-type:x mandatory;
}
.bt-featured-row::-webkit-scrollbar{height:10px}
.bt-featured-row::-webkit-scrollbar-thumb{background:rgba(250,241,233,.12); border-radius:999px}
.bt-featured-card{
  flex:0 0 auto;
  width:min(320px, 78vw);
  display:flex;
  gap:12px;
  align-items:center;
  border-radius:18px;
  padding:12px;
  border:1px solid rgba(250,241,233,.10);
  background:rgba(30,28,51,.60);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  color:rgba(250,241,233,.92);
  text-decoration:none;
  scroll-snap-align:start;
  transition:transform .12s ease, border-color .12s ease;
}
.bt-featured-card:hover{transform:translateY(-1px); border-color:rgba(18,227,235,.35)}
.bt-featured-img{
  width:76px;
  height:76px;
  border-radius:16px;
  background:rgba(3,2,10,.35);
  border:1px solid rgba(250,241,233,.08);
  overflow:hidden;
  display:grid;
  place-items:center;
}
.bt-featured-img img{width:100%; height:100%; object-fit:cover}
.bt-featured-img i{font-size:1.6rem; color:rgba(18,227,235,.85)}
.bt-featured-rubro{
  font-size:.78rem;
  color:rgba(250,241,233,.62);
}
.bt-featured-title{
  font-weight:900;
  line-height:1.15;
}
.bt-featured-price{
  margin-top:2px;
  font-weight:900;
  color:rgba(250,241,233,.92);
}
.bt-feature-slide{
  border-radius:22px;
  border:1px solid rgba(250,241,233,.10);
  background:
    radial-gradient(700px 280px at 10% 40%, rgba(18,227,235,.22), transparent 60%),
    radial-gradient(700px 280px at 85% 55%, rgba(209,21,121,.22), transparent 62%),
    rgba(3,2,10,.40);
  box-shadow:0 20px 60px rgba(0,0,0,.55);
  padding:22px 22px;
  overflow:hidden;
}
.bt-feature-kicker{
  display:inline-block;
  font-weight:900;
  letter-spacing:.3px;
  color:rgba(18,227,235,.92);
}
.bt-feature-title{
  font-family:var(--bt-title);
  font-size:1.55rem;
  margin-top:.25rem;
}
.bt-feature-sub{
  color:rgba(250,241,233,.72);
  margin-top:.35rem;
}
.bt-feature-icon{
  width:74px;
  height:74px;
  border-radius:24px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(18,227,235,.20), rgba(209,21,121,.18));
  border:1px solid rgba(250,241,233,.10);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  margin-left:auto;
}
.bt-feature-icon i{
  font-size:2rem;
  color:rgba(250,241,233,.92);
}
.carousel-control-prev-icon,
.carousel-control-next-icon{
  filter:invert(1) grayscale(1);
  opacity:.9;
}
.shop-cart-btn{
  position:relative;
  border-radius:14px;
  padding:.4rem .55rem;
  color:rgba(250,241,233,.9);
}
.shop-cart-badge{
  position:absolute;
  top:-6px;
  right:-6px;
  min-width:20px;
  height:20px;
  padding:0 6px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:.75rem;
  font-weight:900;
  background:linear-gradient(135deg, rgba(18,227,235,.95), rgba(209,21,121,.95));
  color:#0b0a14;
  border:1px solid rgba(250,241,233,.14);
}
.offcanvas{
  background:rgba(3,2,10,.92);
  color:var(--bt-cream);
  border-left:1px solid rgba(250,241,233,.10);
}
.offcanvas .btn-close{
  filter:invert(1) grayscale(1);
}
.offcanvas .border{
  border-color:rgba(250,241,233,.12) !important;
  background:rgba(30,28,51,.55);
}
.offcanvas .form-control{
  background:rgba(3,2,10,.55);
  border:1px solid rgba(250,241,233,.10);
  color:var(--bt-cream);
}
.offcanvas .form-control:focus{
  border-color:rgba(18,227,235,.55);
  box-shadow:0 0 0 .25rem rgba(18,227,235,.12);
}
.bt-shop-btn{
  background:linear-gradient(135deg, rgba(18,227,235,.92), rgba(209,21,121,.92));
  color:#0b0a14;
  border:none;
  font-weight:900;
  border-radius:999px;
  padding:.7rem 1.05rem;
}
.bt-shop-btn:hover{filter:saturate(120%)}
.bt-shop-btn-outline{
  background:rgba(3,2,10,.35);
  color:var(--bt-cream);
  border:1px solid rgba(18,227,235,.28);
  border-radius:999px;
  padding:.7rem 1.05rem;
  font-weight:900;
}
.bt-shop-btn-outline:hover{border-color:rgba(18,227,235,.45)}
.shop-cart-anim{animation:btPop .35s ease}
.shop-cart-badge-anim{animation:btPop .35s ease}
@keyframes btPop{0%{transform:scale(1)}50%{transform:scale(1.15)}100%{transform:scale(1)}}
.shop-fly{mix-blend-mode:screen}

.bt-product-media{
  border-radius:22px;
  border:1px solid rgba(250,241,233,.10);
  background:rgba(30,28,51,.55);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  padding:14px;
}
.bt-product-main{
  border-radius:18px;
  overflow:hidden;
  background:rgba(3,2,10,.35);
  border:1px solid rgba(250,241,233,.08);
  height:min(520px, 62vh);
  display:grid;
  place-items:center;
}
.bt-product-main img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.bt-product-empty{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  color:rgba(18,227,235,.85);
  font-size:2rem;
}
.bt-product-thumbs{
  display:flex;
  gap:10px;
  overflow:auto;
  padding-bottom:4px;
}
.bt-thumb{
  border:none;
  padding:0;
  border-radius:14px;
  overflow:hidden;
  width:74px;
  height:74px;
  flex:0 0 auto;
  background:rgba(3,2,10,.35);
  border:1px solid rgba(250,241,233,.10);
  opacity:.85;
}
.bt-thumb img{width:100%; height:100%; object-fit:cover; display:block}
.bt-thumb.active{opacity:1; border-color:rgba(18,227,235,.35)}

.bt-product-card{
  border-radius:22px;
  border:1px solid rgba(250,241,233,.10);
  background:
    radial-gradient(700px 280px at 10% 40%, rgba(18,227,235,.18), transparent 60%),
    radial-gradient(700px 280px at 85% 55%, rgba(209,21,121,.18), transparent 62%),
    rgba(30,28,51,.55);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  padding:18px;
  color:rgba(250,241,233,.92);
}
.bt-product-price{
  font-weight:900;
  font-size:1.45rem;
  color:rgba(250,241,233,.95);
}
.bt-product-price-old{
  color:rgba(250,241,233,.55);
  text-decoration:line-through;
  font-weight:800;
}
.bt-product-desc{
  color:rgba(250,241,233,.75);
  line-height:1.55;
}

.bt-shop-footer{
  margin-top:3rem;
  background:rgba(3,2,10,.92);
  border-top:3px solid rgba(18,227,235,.75);
  color:rgba(250,241,233,.86);
}
.bt-shop-footer-title{
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.4px;
  font-size:.92rem;
  margin-bottom:.75rem;
  color:rgba(250,241,233,.92);
}
.bt-shop-footer-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:.45rem;
}
.bt-shop-footer-link{
  color:rgba(250,241,233,.86);
  text-decoration:none;
  font-weight:700;
}
.bt-shop-footer-link:hover{
  color:rgba(18,227,235,1);
  text-decoration:underline;
}
.bt-footer-social a{
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(250,241,233,.14);
  background:rgba(30,28,51,.35);
  color:rgba(250,241,233,.92);
  text-decoration:none;
}
.bt-footer-social a:hover{
  border-color:rgba(18,227,235,.45);
  color:rgba(18,227,235,1);
}
.bt-shop-footer-bottom{
  border-top:1px solid rgba(250,241,233,.10);
  background:rgba(30,28,51,.55);
}
