:root{
  --bg:#0e0f10;
  --card:#17181b;
  --text:#eee;
  --muted:#b8c0cc;
  --accent:#e3b341;
  --accent-2:#9ccfd8;
  --shadow-sm:0 2px 8px rgba(0,0,0,0.2);
  --shadow-md:0 4px 16px rgba(0,0,0,0.3);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.4);
  --shadow-glow:0 0 20px rgba(227,179,65,0.15);
}

*{ box-sizing:border-box }

html,body{
  padding:0; margin:0;
  background:var(--bg); color:var(--text);
  font-family:Montserrat,system-ui,-apple-system,sans-serif;
  line-height:1.6;
  scroll-behavior:smooth;
  position:relative;
}

/* Decorative background pattern */
body::before{
  content:'';
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  width:100%;
  height:100%;
  z-index:0;
  pointer-events:none;
  opacity:0.04;
  background:
    radial-gradient(ellipse 800px 800px at 10% 20%, var(--accent) 0%, rgba(227,179,65,0) 30%, transparent 60%),
    radial-gradient(ellipse 700px 700px at 30% 60%, var(--accent-2) 0%, rgba(156,207,216,0) 35%, transparent 70%),
    radial-gradient(ellipse 600px 600px at 70% 90%, var(--accent) 0%, rgba(227,179,65,0) 30%, transparent 60%),
    radial-gradient(ellipse 800px 800px at 90% 30%, var(--accent) 0%, rgba(227,179,65,0) 30%, transparent 60%),
    radial-gradient(ellipse 650px 650px at 70% 70%, var(--accent-2) 0%, rgba(156,207,216,0) 35%, transparent 70%),
    radial-gradient(ellipse 550px 550px at 20% 10%, var(--accent) 0%, rgba(227,179,65,0) 30%, transparent 60%),
    radial-gradient(ellipse 1100px 1100px at 50% 50%, var(--accent-2) 0%, rgba(156,207,216,0) 40%, transparent 80%);
  background-size:100% 100%;
  background-position:0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%;
  background-repeat:no-repeat;
}

@media (max-width:1200px){
  body::before{
    opacity:0.03;
  }
}

a{ color:var(--accent-2); text-decoration:none; transition:all 0.3s ease }
a:hover{ text-decoration:underline; color:var(--accent); transform:translateY(-1px) }

/* ---------- Header / Nav ---------- */
.site-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px;
  position:sticky; top:0; z-index:100;
  background:rgba(14,15,16,.92); backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--shadow-sm);
  transition:all 0.3s ease;
  position:relative;
  z-index:100;
  width:100%;
  max-width:100vw;
  overflow-x:hidden;
  box-sizing:border-box;
}
.brand{
  font-weight:800; color:var(--text);
  display:flex; align-items:center; gap:12px;
  transition:transform 0.3s ease;
}
.brand:hover{ transform:scale(1.02) }
.brand .logo{ 
  height:32px; width:auto; 
  border-radius:8px; 
  box-shadow:var(--shadow-sm);
  transition:all 0.3s ease;
}
.brand:hover .logo{ box-shadow:var(--shadow-md) }

.nav a{ 
  margin:0 12px; 
  color:var(--muted);
  padding:8px 12px;
  border-radius:12px;
  transition:all 0.3s ease;
  font-weight:600;
}
.nav a:hover{ 
  color:var(--text); 
  background:rgba(227,179,65,0.1);
  transform:translateY(-2px);
  text-decoration:none;
}

/* ---------- Layout ---------- */
.content{ 
  max-width:1200px; 
  margin:0 auto; 
  padding:40px 24px 100px;
  animation:fadeIn 0.6s ease-out;
  position:relative;
  z-index:1;
}

@keyframes fadeIn{
  from{ opacity:0; transform:translateY(10px); }
  to{ opacity:1; transform:translateY(0); }
}

/* ---------- Hero ---------- */
.hero{ 
  text-align:center; 
  padding:48px 0 32px;
  margin-bottom:40px;
}
.hero h1{
  font-family:'DM Serif Display',serif;
  font-size:clamp(24px,5vw,42px);
  margin:20px 0 28px;
  line-height:1.3;
  letter-spacing:-0.5px;
}
.hero-logo{
  max-width:400px; width:85%; height:auto;
  margin:0 auto 20px; display:block; 
  border-radius:20px;
  box-shadow:var(--shadow-lg);
  transition:transform 0.4s ease, box-shadow 0.4s ease;
}
.hero-logo:hover{
  transform:scale(1.02) translateY(-4px);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
}

/* ---------- Why Shop With Us / Benefits Carousel ---------- */
.benefits-carousel-wrapper{
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:24px;
  padding:40px 24px;
  margin:48px 0;
  text-align:center;
  box-shadow:var(--shadow-md);
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  transition:all 0.3s ease;
}

.benefits-carousel-wrapper:hover{
  border-color:rgba(227,179,65,0.2);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
  transform:translateY(-2px);
}

.benefits-carousel-wrapper h2{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,4vw,36px);
  margin-bottom:32px;
  color:var(--text);
}

.benefits-carousel{
  margin:0;
  overflow:hidden;
  position:relative;
  padding:20px 0;
}

.benefits-carousel-track{
  display:flex;
  gap:20px;
  width:fit-content;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  touch-action:pan-y;
  will-change:transform;
  -webkit-overflow-scrolling:touch;
}

.benefits-carousel-track:active{
  cursor:grabbing;
}

.benefit-card{
  flex:0 0 320px;
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:24px;
  padding:32px 24px;
  box-shadow:var(--shadow-md);
  transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  text-align:center;
  display:flex;
  flex-direction:column;
}

.benefit-card:hover{
  transform:translateY(-8px);
  border-color:rgba(227,179,65,0.3);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
}

.benefit-icon{
  font-size:3rem;
  margin-bottom:16px;
  display:block;
  line-height:1;
}

.benefit-card h3{
  font-size:1.3rem;
  margin:0 0 12px 0;
  color:var(--accent);
  font-weight:800;
}

.benefit-card p{
  margin:0;
  color:var(--muted);
  line-height:1.6;
  font-size:0.95rem;
  flex-grow:1;
}

@media (max-width:640px){
  .benefits-carousel-wrapper{
    padding:24px 16px;
    margin:24px 0;
  }
  
  .benefits-carousel-wrapper h2{
    font-size:clamp(22px,5vw,28px);
    margin-bottom:20px;
  }
  
  .benefit-card{
    flex:0 0 280px;
    padding:24px 20px;
  }
  
  .benefit-icon{
    font-size:2.5rem;
    margin-bottom:12px;
  }
  
  .benefit-card h3{
    font-size:1.1rem;
    margin-bottom:8px;
  }
  
  .benefit-card p{
    font-size:0.85rem;
    line-height:1.5;
  }
}

/* ---------- Slide-to-shop ---------- */
.slider-wrap{ 
  max-width:520px; 
  margin:0 auto 20px; 
  position:relative;
}
.slider{
  position:relative; width:100%; height:64px;
  background:var(--card); 
  border:2px solid rgba(255,255,255,0.1);
  border-radius:999px; 
  overflow:hidden;
  box-shadow:var(--shadow-md);
  transition:all 0.3s ease;
}
.slider:hover{
  border-color:rgba(227,179,65,0.3);
  box-shadow:var(--shadow-lg);
}
.slider-handle{
  position:absolute; top:6px; left:6px; 
  border-radius:50%;
  cursor:grab; 
  background:transparent;
  transition:transform 0.2s ease;
}
.slider-handle:active{ cursor:grabbing; transform:scale(0.95) }
.slider-handle img{
  width:52px; height:52px; 
  pointer-events:none; display:block;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.4));
  transition:transform 0.3s ease;
}
.slider-handle:hover img{ transform:scale(1.1) }
.slider-text{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  color:var(--muted); 
  font-weight:700; 
  letter-spacing:.5px; 
  pointer-events:none;
  font-size:1.05rem;
}

.shop-fallback{
  display:inline-block;
  margin-top:20px;
  padding:14px 28px;
  background:var(--accent);
  color:#000;
  border-radius:16px;
  font-weight:700;
  text-decoration:none;
  box-shadow:var(--shadow-md);
  transition:all 0.3s ease;
}
.shop-fallback:hover{
  background:#f4c430;
  transform:translateY(-3px);
  box-shadow:var(--shadow-lg);
  text-decoration:none;
}

/* ---------- Shop Search & Sort ---------- */
.shop-search-container{
  display:flex;
  gap:12px;
  margin:24px 0;
  max-width:800px;
  margin-left:auto;
  margin-right:auto;
  flex-wrap:wrap;
}

.shop-search{
  flex:1;
  min-width:200px;
  padding:14px 18px;
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:16px;
  color:var(--text);
  font-size:1rem;
  font-family:inherit;
  transition:all 0.3s ease;
  box-shadow:var(--shadow-sm);
}

.shop-search:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:var(--shadow-md), var(--shadow-glow);
}

.shop-search::placeholder{
  color:var(--muted);
}

.shop-sort{
  padding:14px 18px;
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:16px;
  color:var(--text);
  font-size:1rem;
  font-family:inherit;
  cursor:pointer;
  transition:all 0.3s ease;
  box-shadow:var(--shadow-sm);
}

.shop-sort:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:var(--shadow-md);
}

.shop-sort option{
  background:var(--card);
  color:var(--text);
}

@media (max-width:640px){
  .shop-search-container{
    display:none;
  }
}

/* ---------- Shop Tabs ---------- */
.shop-tabs{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  margin:24px 0 32px;
}

.tab{
  background:var(--card);
  border:2px solid rgba(255,255,255,0.1);
  color:var(--text);
  padding:14px 24px;
  border-radius:999px;
  font-weight:700;
  font-size:1rem;
  cursor:pointer;
  transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow:var(--shadow-sm);
  position:relative;
  overflow:hidden;
}

.tab::before{
  content:'';
  position:absolute;
  top:0; left:0; right:0; bottom:0;
  background:linear-gradient(135deg, var(--accent), #f4c430);
  opacity:0;
  transition:opacity 0.3s ease;
  z-index:0;
}

.tab:hover{
  background:var(--accent);
  color:#000;
  transform:translateY(-3px) scale(1.05);
  border-color:var(--accent);
  box-shadow:var(--shadow-md), var(--shadow-glow);
  text-decoration:none;
}

.tab.active{
  background:var(--accent);
  color:#000;
  border-color:var(--accent);
  box-shadow:var(--shadow-md), var(--shadow-glow);
  font-weight:800;
}

/* ---------- Product Grid / Cards ---------- */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:24px;
  padding:8px 0;
}

.card{
  background:var(--card); 
  border:2px solid rgba(255,255,255,0.08); 
  border-radius:24px;
  overflow:hidden; 
  display:flex; 
  flex-direction:column;
  box-shadow:var(--shadow-md);
  transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  position:relative;
}

.card:hover{
  transform:translateY(-8px);
  border-color:rgba(227,179,65,0.3);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
}

.card .thumb{
  position:relative;
  width:100%;
  padding-top:100%;
  overflow:hidden;
  background:#0a0b0c;
  border-radius:20px 20px 0 0;
}

.card .thumb img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
  transition:transform 0.5s ease;
}
.card .thumb img[src*="ichy1a.jpg"]{
  object-position:center bottom;
}

.card:hover .thumb img{
  transform:scale(1.08);
}

.card.sold .thumb img{
  opacity:0.6;
  filter:grayscale(40%);
}

.sold-overlay{
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(14,15,16,0.7);
  z-index:10;
  border-radius:20px 20px 0 0;
  font-size:2.5rem;
  font-weight:800;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:4px;
  text-shadow:2px 2px 8px rgba(0,0,0,0.8), 0 0 20px rgba(227,179,65,0.5);
}

.card.sold .thumb{
  position:relative;
  background:transparent;
}

.card .meta{ 
  padding:20px; 
  display:flex; 
  flex-direction:column; 
  gap:12px;
  flex-grow:1;
}

.card .title{
  font-size:1.2rem;
  font-weight:700;
  line-height:1.3;
  margin:0;
}

.card .desc{
  color:var(--muted);
  line-height:1.5;
  font-size:0.95rem;
}

.card .facts{
  list-style:none;
  padding:0;
  margin:0;
  font-size:0.9rem;
  line-height:1.6;
}

.card .facts li{
  padding:4px 0;
  color:var(--muted);
}

.card-buttons{
  display:flex;
  gap:12px;
  margin-top:auto;
  flex-wrap:wrap;
}

.card .btn, .btn{
  display:inline-block;
  padding:14px 20px;
  background:var(--accent);
  color:#000;
  border:none;
  border-radius:16px;
  font-weight:700;
  text-align:center;
  cursor:pointer;
  transition:all 0.3s ease;
  box-shadow:var(--shadow-sm);
  font-size:1rem;
  flex:1;
  min-width:120px;
}

.card .btn:hover, .btn:hover{
  background:#f4c430;
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  text-decoration:none;
}

/* ---------- ⭐ FIX: Make <button class="btn"> exactly match <a class="btn"> ---------- */
button.btn{
  display:inline-block;
  padding:14px 20px;
  background:var(--accent);
  color:#000;
  border:none;
  border-radius:16px;
  font-weight:700;
  text-align:center;
  font-family:inherit;
  font-size:1rem;
  line-height:inherit;
  cursor:pointer;
  transition:all 0.3s ease;
  box-shadow:var(--shadow-sm);
}

.btn-remove-from-cart{
  background:#dc3545;
  color:#fff;
}

.btn-remove-from-cart:hover{
  background:#c82333;
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
button.btn:hover{
  background:#f4c430;
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
/* ---------- END FIX ---------- */

.price{ 
  font-weight:800; 
  font-size:1.3rem;
  color:var(--accent);
  margin:4px 0;
}

/* ---------- Product Page Layout ---------- */
.product{
  display:grid; 
  grid-template-columns:1.1fr 1fr; 
  gap:32px; 
  align-items:start;
  margin-top:24px;
}
.product .gallery{
  background:var(--card); 
  border:2px solid rgba(255,255,255,0.08); 
  border-radius:24px; 
  padding:16px;
  box-shadow:var(--shadow-md);
  transition:all 0.3s ease;
}
.product .gallery:hover{
  box-shadow:var(--shadow-lg);
  border-color:rgba(227,179,65,0.2);
}
.product .gallery img{ 
  width:100%; 
  border-radius:16px;
  transition:transform 0.3s ease;
}
.product .gallery:hover img{
  transform:scale(1.02);
}

/* ---------- Page Title ---------- */
.page-title{
  text-align:center;
  margin-bottom:40px;
  padding:20px 0;
}
.page-title h1{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,5vw,42px);
  margin:0;
  line-height:1.3;
  letter-spacing:-0.5px;
  text-transform:uppercase;
  text-decoration:underline;
  text-decoration-color:var(--accent);
  text-underline-offset:8px;
  text-decoration-thickness:2px;
}

/* ---------- FAQ / Contact / Reviews / About ---------- */
.faq details{
  background:var(--card); 
  border:2px solid rgba(255,255,255,0.08); 
  border-radius:20px;
  padding:20px 24px; 
  margin:16px 0;
  box-shadow:var(--shadow-sm);
  transition:all 0.3s ease;
}
.faq details:hover{
  border-color:rgba(227,179,65,0.2);
  box-shadow:var(--shadow-md);
}
.faq summary{ 
  cursor:pointer; 
  font-weight:700; 
  font-size:1.1rem;
  padding:4px 0;
  transition:color 0.3s ease;
}
.faq summary:hover{
  color:var(--accent);
}

.contact .contact-list{ 
  list-style:none; 
  padding:0;
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:20px;
  padding:24px;
  box-shadow:var(--shadow-md);
  max-width:600px;
  margin:0 auto;
}
.contact .contact-list li{ 
  margin:16px 0;
  font-size:1.1rem;
  padding:12px;
  border-radius:12px;
  transition:background 0.3s ease;
  display:flex;
  align-items:center;
  gap:12px;
}
.contact .contact-list li i{
  color:var(--accent);
  font-size:1.2rem;
  width:24px;
  text-align:center;
}
.contact .contact-list li:hover{
  background:rgba(227,179,65,0.1);
}

.reviews .review{
  background:var(--card); 
  border:2px solid rgba(255,255,255,0.08); 
  border-radius:20px;
  padding:24px; 
  margin:20px 0;
  box-shadow:var(--shadow-md);
  transition:all 0.3s ease;
  line-height:1.7;
}
.reviews .review:hover{
  transform:translateY(-4px);
  border-color:rgba(227,179,65,0.2);
  box-shadow:var(--shadow-lg);
}
.reviews .by{ 
  color:var(--muted);
  font-weight:600;
  margin-top:12px;
  font-style:italic;
}

.about{
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:24px;
  padding:40px;
  margin-bottom:40px;
  box-shadow:var(--shadow-md);
  line-height:1.8;
  transition:all 0.3s ease;
}

.about:hover{
  border-color:rgba(227,179,65,0.2);
  box-shadow:var(--shadow-lg);
}

.about-intro{
  margin-bottom:28px;
  padding-bottom:24px;
  border-bottom:2px solid rgba(255,255,255,0.05);
}

.about-intro h2{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,4vw,36px);
  margin:0 0 16px 0;
  color:var(--text);
  line-height:1.2;
}

.about-lead{
  font-size:1.15rem;
  color:var(--text);
  line-height:1.7;
  margin:0;
}

.about-content{
  margin:24px 0;
}

.about p{
  margin:18px 0;
  font-size:1.05rem;
  color:var(--text);
}

.about strong{
  color:var(--text);
  font-weight:700;
}

.about a{
  color:var(--accent-2);
  text-decoration:underline;
  transition:color 0.3s ease;
}

.about a:hover{
  color:var(--accent);
}

.about .signed{ 
  margin-top:32px; 
  padding-top:24px;
  border-top:2px solid rgba(255,255,255,0.05);
  font-style:italic; 
  color:var(--muted);
  font-size:1.15rem;
  text-align:right;
  font-weight:600;
}

/* About Gallery */
.about-gallery{
  display:flex;
  flex-direction:column;
  gap:40px;
  margin-top:48px;
}

.about-gallery .row{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}

.gallery-image-wrapper{
  width:48%;
  max-width:500px;
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:24px;
  padding:12px;
  box-shadow:var(--shadow-md);
  transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.gallery-image-wrapper:hover{
  transform:translateY(-6px);
  border-color:rgba(227,179,65,0.3);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
}

.about-gallery .row img{
  width:100%;
  height:400px;
  border-radius:16px;
  object-fit:cover;
  display:block;
}

.about-gallery .caption{
  text-align:center;
  color:var(--muted);
  font-style:italic;
  font-size:1rem;
  margin-top:20px;
  padding:16px 24px;
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:20px;
  display:inline-block;
  max-width:700px;
  margin-left:auto;
  margin-right:auto;
  box-shadow:var(--shadow-md);
  width:100%;
}

@media (max-width:900px){
  .about{
    padding:32px 24px;
  }
  
  .gallery-image-wrapper{
    width:100%;
    max-width:500px;
  }
  
  .about-gallery .row img{
    height:350px;
  }
}

@media (max-width:640px){
  .about{
    padding:24px 20px;
    margin-bottom:32px;
  }
  
  .about-intro{
    margin-bottom:20px;
    padding-bottom:20px;
  }
  
  .about-intro h2{
    font-size:24px;
  }
  
  .about-lead{
    font-size:1.05rem;
  }
  
  .about p{
    font-size:1rem;
    margin:16px 0;
  }
  
  .about-gallery{
    gap:32px;
    margin-top:32px;
  }
  
  .about-gallery .row{
    gap:20px;
  }
  
  .gallery-image-wrapper{
    width:100%;
    padding:10px;
    border-radius:20px;
  }
  
  .about-gallery .row img{
    height:300px;
    border-radius:14px;
  }
  
  .about-gallery .caption{
    font-size:0.9rem;
    padding:14px 18px;
    margin-top:16px;
    border-radius:16px;
  }
}

/* ---------- Our Story Section (Homepage) ---------- */
.our-story{
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:24px;
  padding:40px;
  margin:48px 0;
  box-shadow:var(--shadow-md);
  line-height:1.8;
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
  transition:all 0.3s ease;
}

.our-story:hover{
  border-color:rgba(227,179,65,0.2);
  box-shadow:var(--shadow-lg);
}
.our-story h2{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,4vw,36px);
  margin:0 0 24px 0;
  color:var(--text);
}
.our-story h3{
  font-size:1.4rem;
  margin:24px 0 16px 0;
  color:var(--accent);
  font-weight:700;
}
.our-story p{
  margin:16px 0;
  font-size:1.05rem;
  color:var(--text);
}
.our-story .signed{
  margin-top:28px;
  font-style:italic;
  color:var(--muted);
  font-size:1.1rem;
  text-align:right;
}

@media (max-width:640px){
  .our-story{
    padding:24px;
    margin:32px 0;
  }
  .our-story h2{
    font-size:24px;
  }
  .our-story h3{
    font-size:1.2rem;
  }
}

/* ---------- Footer ---------- */
.site-footer{
  border-top:2px solid rgba(255,255,255,0.08); 
  padding:40px 24px; 
  text-align:center; 
  color:var(--muted);
  margin-top:60px;
  background:rgba(14,15,16,0.5);
}
.trust{ 
  margin-bottom:24px;
}
.trust-title{
  font-weight:700;
  font-size:1.1rem;
  margin-bottom:16px;
  color:var(--text);
}
.badges{
  display:flex; 
  gap:12px; 
  align-items:center; 
  justify-content:center; 
  flex-wrap:wrap;
  margin-bottom:16px;
}
.badge{
  width:120px; 
  height:44px; 
  fill:var(--card); 
  stroke:rgba(255,255,255,0.15); 
  stroke-width:2;
  border-radius:12px;
  transition:all 0.3s ease;
  cursor:pointer;
}
.badge:hover{
  fill:rgba(227,179,65,0.1);
  stroke:var(--accent);
  transform:translateY(-2px);
}
.badge text{
  fill:var(--text); 
  font-family:Montserrat,sans-serif; 
  font-weight:700; 
  font-size:15px;
}
.ssl-note{
  font-size:0.9rem;
  color:var(--muted);
  margin-top:12px;
}
.copyright{
  margin-top:20px;
  font-size:0.95rem;
}

/* ---------- Screen Reader Only ---------- */
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border-width:0;
}

/* ---------- Back to Top Button ---------- */
.back-to-top{
  position:fixed;
  bottom:80px;
  right:24px;
  width:56px;
  height:56px;
  background:var(--accent);
  color:#000;
  border:none;
  border-radius:50%;
  font-size:32px;
  font-weight:900;
  cursor:pointer;
  box-shadow:var(--shadow-lg);
  transition:all 0.3s ease;
  z-index:9998;
  display:none;
  align-items:center;
  justify-content:center;
  line-height:1;
  padding:0;
  opacity:0;
  transform:scale(0.8);
}

.back-to-top svg{
  width:28px;
  height:32px;
  display:block;
}

.back-to-top.show{
  display:flex;
  opacity:1;
  transform:scale(1);
}

.back-to-top:hover{
  background:#f4c430;
  transform:scale(1.1) translateY(-3px);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
}

.back-to-top:active{
  transform:scale(1.05);
}

@media (max-width:640px){
  .back-to-top{
    bottom:18px;
    left:16px;
    right:auto;
    width:52px;
    height:52px;
    font-size:28px;
    z-index:9997;
  }
  
  .back-to-top svg{
    width:24px;
    height:28px;
  }
}

/* ---------- Social Proof / Recent Purchases ---------- */
.social-proof{
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:20px;
  padding:24px;
  margin:32px 0;
  box-shadow:var(--shadow-sm);
}

.social-proof h3{
  margin-top:0;
  margin-bottom:16px;
  font-size:1.2rem;
  color:var(--text);
}

.social-proof-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid rgba(255,255,255,0.05);
}

.social-proof-item:last-child{
  border-bottom:none;
}

.social-proof-icon{
  font-size:1.5rem;
}

.social-proof-text{
  flex:1;
  color:var(--muted);
  font-size:0.9rem;
}

.social-proof-text strong{
  color:var(--text);
}

/* ---------- Mobile / Small Tablet ---------- */
@media (max-width:900px){
  .content{ 
    padding:24px 18px 100px;
  }
  .grid{ 
    grid-template-columns:1fr; 
    gap:20px; 
  }
  .card{ 
    max-width:520px; 
    margin-inline:auto; 
  }
  .card .meta{ 
    padding:18px; 
    gap:10px; 
  }
  .card-buttons{
    flex-direction:column;
    gap:10px;
  }
  
  .card .btn{ 
    width:100%; 
    padding:14px; 
    min-width:auto;
  }
  .product{ 
    grid-template-columns:1fr; 
    gap:24px; 
  }
}

/* ---------- Extra small tweaks ---------- */
@media (max-width:640px){
  .content{
    padding:20px 16px 80px;
  }
  
  .hero{ 
    padding:24px 0 20px;
    margin-bottom:24px;
  }
  
  .hero h1{ 
    font-size:clamp(22px,6vw,32px);
    margin:12px 0 16px;
  }
  
  .hero-logo{
    max-width:280px;
    margin-bottom:16px;
  }
  
  .slider{ height:56px }
  .slider-handle img{ width:44px; height:44px }
  .slider-wrap{
    margin-bottom:16px;
  }
  
  .page-title{
    margin-bottom:16px;
    padding:12px 0;
  }
  
  .page-title h1{
    font-size:clamp(36px,8vw,56px);
  }
  
  /* Compact Benefits Carousel */
  .benefits-carousel-wrapper{
    padding:24px 16px;
    margin:24px 0;
  }
  
  .benefits-carousel-wrapper h2{
    font-size:clamp(22px,5vw,28px);
    margin-bottom:20px;
  }
  
  .benefit-card{
    padding:20px 16px;
  }
  
  .benefit-icon{
    font-size:2.2rem;
    margin-bottom:12px;
  }
  
  .benefit-card h3{
    font-size:1.1rem;
    margin-bottom:8px;
  }
  
  .benefit-card p{
    font-size:0.85rem;
    line-height:1.5;
  }
  
  /* Compact Our Story */
  .our-story{
    padding:24px 20px;
    margin:24px 0;
  }
  
  .our-story h2{
    font-size:clamp(22px,5vw,28px);
    margin-bottom:16px;
  }
  
  .our-story h3{
    font-size:1.2rem;
    margin:16px 0 12px;
  }
  
  .our-story p{
    font-size:0.95rem;
    margin:12px 0;
    line-height:1.6;
  }
  
  .our-story .signed{
    margin-top:20px;
    font-size:1rem;
  }
  
  /* Compact Featured Carousel */
  .featured-carousel-wrapper{
    padding:20px 12px;
    margin:24px 0;
  }
  
  /* Compact Social Proof */
  .social-proof{
    padding:20px;
    margin:24px 0;
  }
  
  .social-proof h3{
    font-size:1.1rem;
    margin-bottom:12px;
  }
  
  .social-proof-item{
    padding:10px 0;
    gap:10px;
  }
  
  .social-proof-icon{
    font-size:1.3rem;
  }
  
  .social-proof-text{
    font-size:0.85rem;
  }
}

/* ---------- Mobile Navigation ---------- */
@media (max-width:640px){
  html, body{ overflow-x:hidden; }
  .site-header{
    flex-wrap:wrap;
    padding:12px 12px;
    justify-content:space-between;
    max-width:100vw;
    overflow-x:hidden;
  }
  .brand{ 
    font-size:13px; 
    font-weight:800; 
    gap:6px;
    flex-shrink:0;
    max-width:calc(100% - 100px);
  }
  .brand .logo{ 
    height:24px; 
    width:auto;
    flex-shrink:0;
  }
  .nav{
    display:flex;
    width:100%;
    justify-content:space-between;
    align-items:center;
    flex-wrap:nowrap;
    gap:2px;
    white-space:nowrap;
    overflow-x:auto;
    padding:8px 0;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    max-width:100%;
  }
  .nav::-webkit-scrollbar{ display:none; }
  .nav a{
    margin:0;
    font-size:0.85rem;
    padding:6px 8px;
    flex-shrink:0;
    font-size:12px;
    font-weight:700;
    color:var(--text);
    line-height:1.2;
    padding:6px 10px;
    border-radius:10px;
    white-space:nowrap;
  }
  .nav a:hover{ 
    color:var(--accent);
    background:rgba(227,179,65,0.15);
    transform:none;
  }
}

/* =================== PRODUCT LIGHTBOX =================== */
.lightbox{
  position:fixed; inset:0;
  display:none; align-items:center; justify-content:center;
  background:rgba(0,0,0,.9); z-index:9999;
}
.lightbox.active{ display:flex; }
.lb-img{ max-width:90vw; max-height:90vh; }

.lb-close, .lb-prev, .lb-next{
  position:absolute; 
  background:rgba(255,255,255,.15);
  border:2px solid rgba(255,255,255,.25); 
  color:#fff;
  font-size:28px; 
  width:48px; 
  height:48px; 
  border-radius:16px; 
  cursor:pointer;
  transition:all 0.3s ease;
  backdrop-filter:blur(8px);
}
.lb-close:hover, .lb-prev:hover, .lb-next:hover{
  background:rgba(227,179,65,0.3);
  border-color:var(--accent);
  transform:scale(1.1);
}
.lb-close{ top:24px; right:24px; }
.lb-prev{ left:24px; }
.lb-next{ right:24px; }

/* ============== PRODUCT PAGE: SLIDER =============== */
.product .slider-gallery{
  position:relative; overflow:hidden;
  border:2px solid rgba(255,255,255,0.08); 
  border-radius:24px; 
  padding:0; 
  background:var(--card);
  box-shadow:var(--shadow-md);
}
.product .slider-gallery .slides{
  display:flex; width:100%;
  transition:transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.product .slider-gallery .slides img{
  width:100%; flex:0 0 100%;
  display:block; object-fit:cover; object-position:center 50%; border-radius:22px;
}
.product .slider-gallery .slides img[src*="ichy1a.jpg"],
.product .slider-gallery .slides img[src*="ichy1b.jpg"],
.product .slider-gallery .slides img[src*="ichy1c.jpg"]{
  object-position:center bottom;
}
.product .slider-gallery .slide-btn{
  position:absolute; top:50%;
  transform:translateY(-50%);
  background:rgba(0,0,0,0.5);
  color:#fff; border:2px solid rgba(255,255,255,0.2); 
  font-size:24px;
  width:48px; height:48px; border-radius:16px;
  cursor:pointer; z-index:2;
  transition:all 0.3s ease;
  backdrop-filter:blur(8px);
}
.product .slider-gallery .slide-btn:hover{ 
  background:rgba(227,179,65,0.4);
  border-color:var(--accent);
  transform:translateY(-50%) scale(1.1);
}
.product .slider-gallery .prev{ left:16px; }
.product .slider-gallery .next{ right:16px; }

@media (max-width:640px){
  .product .slider-gallery .slide-btn{
    width:32px; height:32px; font-size:22px;
  }
}

/* ================= MOBILE CARD TEXT ================= */
@media (max-width:640px){
  .card .title,
  .card .meta h3{ font-size:1rem; line-height:1.2; margin:0; }

  .card .desc{
    font-size:0.9rem; line-height:1.25;
    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }

  .card .facts{
    font-size:0.8rem;
    line-height:1.3;
    max-height:none;
    overflow:visible;
  }

  .card .btn{ padding:10px; font-size:0.95rem; width:100%; }
}

/* ---------- Shop Tabs mobile ---------- */
@media (max-width:640px){
  .shop-tabs{
    gap:6px;
    margin:12px 0 18px;
  }
  .tab{
    padding:10px 14px;
    font-size:0.95rem;
  }
}

/* ---------- Slider highlight fix ---------- */
.slider,
.slider-handle,
.slider-text{
  -webkit-user-select:none;
  -moz-user-select:none;
  -ms-user-select:none;
  user-select:none;
}
.slider-handle img{
  -webkit-user-drag:none;
  user-drag:none;
}

/* ===========================================================
   FLOATING CART ICON (UI ONLY) — BOTTOM ONLY
   - Always lives at the bottom so it can't block header
=========================================================== */
.cart-float{
  position:fixed;
  right:16px;
  bottom:calc(16px + env(safe-area-inset-bottom));
  z-index:9999;
}

/* Keep it a nice tappable pill */
.cart-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 18px;
  border-radius:999px;
  background:rgba(23,24,27,.95);
  border:2px solid rgba(255,255,255,.2);
  color:var(--text);
  font-weight:800;
  text-decoration:none;
  box-shadow:var(--shadow-lg);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  transition:all 0.3s ease;
}
.cart-link:hover{
  text-decoration:none;
  transform:translateY(-3px) scale(1.05);
  border-color:var(--accent);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
  background:rgba(23,24,27,1);
}

/* Count bubble */
.cart-link #cart-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  padding:0 7px;
  border-radius:999px;
  background:var(--accent);
  color:#000;
  font-size:13px;
  line-height:1;
}

/* Mobile: center bottom for thumb reach */
@media (max-width:640px){
  .content{ padding-bottom: 110px; } /* prevents overlap with bottom-floating cart */
  .cart-float{
    left:50%;
    right:auto;
    transform:translateX(-50%);
    bottom:calc(14px + env(safe-area-inset-bottom));
  }
}

/* =================== FEATURED CAROUSEL =================== */
.featured-carousel-wrapper{
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:24px;
  padding:40px 24px;
  margin:60px 0;
  box-shadow:var(--shadow-md);
  transition:all 0.3s ease;
  position:relative;
  overflow:hidden;
  text-align:center;
}

.featured-carousel-wrapper:hover{
  border-color:rgba(227,179,65,0.2);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
  transform:translateY(-2px);
}

.featured-carousel-wrapper h2{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,4vw,36px);
  margin:0 0 32px 0;
  color:var(--text);
}

@media (max-width:640px){
  .featured-carousel-wrapper{
    padding:24px 16px;
    margin:24px 0;
  }
  
  .featured-carousel-wrapper h2{
    font-size:clamp(22px,5vw,28px);
    margin-bottom:20px;
  }
}

.featured-carousel{
  margin:0;
  overflow:hidden;
  position:relative;
  padding:20px 0;
}
.carousel-track{
  display:flex;
  gap:20px;
  width:fit-content;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  touch-action:pan-y;
  will-change:transform;
  -webkit-overflow-scrolling:touch;
}
.carousel-track:active{
  cursor:grabbing;
}
.carousel-item{
  flex:0 0 300px;
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:24px;
  padding:24px;
  display:flex;
  flex-direction:column;
  box-shadow:var(--shadow-md);
  transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.featured-product:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
  border-color:rgba(227,179,65,0.3);
}
.featured-review:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
  border-color:rgba(227,179,65,0.3);
}
.featured-product a:hover{
  text-decoration:none;
}
.featured-product a:hover h3{
  color:var(--accent-2);
}
.featured-product{
  text-align:center;
}
.featured-product a{
  text-decoration:none;
  color:inherit;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.featured-product img{
  width:100%;
  height:200px;
  object-fit:cover;
  object-position:center 65%;
  border-radius:16px;
  transition:transform 0.4s ease;
}
.featured-product img[src*="ichy1a.jpg"]{
  object-position:center bottom;
}
.featured-product:hover img{
  transform:scale(1.05);
}
.featured-product h3{
  margin:0;
  font-size:1.2rem;
  color:var(--text);
}
.featured-product .price{
  color:var(--accent);
  font-weight:800;
  font-size:1.1rem;
  margin:0;
}
.featured-review{
  justify-content:center;
}
.featured-review blockquote{
  margin:0;
  font-style:italic;
  line-height:1.6;
  color:var(--text);
  font-size:1rem;
}
.featured-review cite{
  display:block;
  margin-top:12px;
  font-style:normal;
  color:var(--muted);
  font-weight:600;
}
@keyframes scroll{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}
@media (max-width:640px){
  .carousel-item{ flex:0 0 260px; }
  .featured-product img{ height:160px; }
}

/* =================== CHECKOUT PAGE =================== */
.checkout-container{
  max-width:700px;
  margin:0 auto;
  padding:40px 24px;
}

.checkout-cart-summary{
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:20px;
  padding:24px;
  margin-bottom:32px;
  box-shadow:var(--shadow-md);
}

.checkout-cart-summary h2{
  margin-top:0;
  margin-bottom:20px;
  font-size:1.4rem;
  color:var(--text);
}

.checkout-items{
  margin-bottom:16px;
  line-height:1.8;
  color:var(--text);
}

.checkout-totals{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-top:20px;
  padding-top:20px;
  border-top:2px solid rgba(255,255,255,0.1);
}

.checkout-total-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:1rem;
}

/* ---------- Cookie Consent Banner ---------- */
.cookie-banner{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  background:var(--card);
  border-top:2px solid rgba(255,255,255,0.1);
  padding:20px 24px;
  box-shadow:0 -4px 24px rgba(0,0,0,0.4);
  z-index:10000;
  display:none;
  backdrop-filter:blur(10px);
  border-radius:24px 24px 0 0;
}

.cookie-banner.show{
  display:block;
  animation:slideUp 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes slideUp{
  from{
    transform:translateY(100%);
    opacity:0;
  }
  to{
    transform:translateY(0);
    opacity:1;
  }
}

.cookie-banner-content{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}

.cookie-banner-text{
  flex:1;
  min-width:250px;
  color:var(--text);
  font-size:0.95rem;
  line-height:1.6;
}

.cookie-banner-text a{
  color:var(--accent);
  text-decoration:underline;
}

.cookie-banner-buttons{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.cookie-banner-btn{
  padding:12px 24px;
  border-radius:16px;
  font-weight:700;
  font-size:0.95rem;
  cursor:pointer;
  transition:all 0.3s ease;
  border:none;
  font-family:inherit;
}

.cookie-banner-btn.accept{
  background:var(--accent);
  color:#000;
  box-shadow:var(--shadow-sm);
}

.cookie-banner-btn.accept:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md), var(--shadow-glow);
}

.cookie-banner-btn.decline{
  background:transparent;
  color:var(--muted);
  border:2px solid rgba(255,255,255,0.2);
}

.cookie-banner-btn.decline:hover{
  border-color:var(--muted);
  color:var(--text);
}

@media (max-width:640px){
  .cookie-banner{
    padding:16px 20px;
    border-radius:20px 20px 0 0;
  }
  .cookie-banner-content{
    flex-direction:column;
    align-items:stretch;
    gap:16px;
  }
  .cookie-banner-buttons{
    width:100%;
  }
  .cookie-banner-btn{
    flex:1;
    padding:14px 20px;
  }
}

.checkout-total-row.total{
  font-size:1.3rem;
  font-weight:800;
  color:var(--accent);
  padding-top:12px;
  border-top:2px solid rgba(255,255,255,0.1);
  margin-top:8px;
}

.payment-status{
  margin-top:20px;
  padding:16px;
  border-radius:12px;
  background:rgba(255,0,0,0.1);
  border:2px solid rgba(255,0,0,0.3);
  color:#ff6b6b;
  font-weight:600;
  text-align:center;
}

.payment-status.success{
  background:rgba(0,255,0,0.1);
  border-color:rgba(0,255,0,0.3);
  color:#51cf66;
}

#paypal-button-container{
  margin-top:24px;
}

@media (max-width:640px){
  .checkout-container{
    padding:24px 16px;
  }
  .checkout-cart-summary{
    padding:20px;
  }
}

/* ---------- Related Products Section ---------- */
.related-products{
  margin-top:60px;
  padding-top:40px;
  border-top:2px solid rgba(255,255,255,0.1);
}

.related-products h2{
  font-size:clamp(28px,4vw,36px);
  margin:0 0 32px 0;
  color:var(--text);
  text-align:center;
  font-family:'DM Serif Display',serif;
}

.related-products-carousel{
  margin:0 -24px;
  overflow:hidden;
  position:relative;
  padding:20px 0;
  width:calc(100% + 48px);
}

.related-products-track{
  display:flex;
  gap:20px;
  width:fit-content;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  touch-action:pan-y;
  padding:0 24px;
  will-change:transform;
  -webkit-overflow-scrolling:touch;
}

.related-products-track:active{
  cursor:grabbing;
}

.related-product-card{
  flex:0 0 280px;
  background:var(--card);
  border:2px solid rgba(255,255,255,0.08);
  border-radius:24px;
  padding:20px;
  transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow:var(--shadow-md);
  text-decoration:none;
  color:var(--text);
  display:flex;
  flex-direction:column;
  text-align:center;
}

.related-product-card:hover{
  transform:translateY(-6px);
  border-color:rgba(227,179,65,0.3);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
  text-decoration:none;
  color:var(--text);
}

.related-product-card img{
  width:100%;
  height:200px;
  object-fit:cover;
  border-radius:16px;
  margin-bottom:12px;
  transition:transform 0.4s ease;
}

.related-product-card:hover img{
  transform:scale(1.05);
}

.related-product-card h3{
  font-size:1.1rem;
  margin:0 0 8px;
  color:var(--text);
  font-weight:600;
}

.related-product-card:hover h3{
  color:var(--accent-2);
}

.related-product-card .price{
  color:var(--accent);
  font-weight:800;
  font-size:1.1rem;
  margin:0;
}

@media (max-width:640px){
  .related-products{
    margin-top:40px;
    padding-top:32px;
  }
  .related-products h2{
    font-size:clamp(22px,5vw,28px);
    margin-bottom:20px;
  }
  .related-products-carousel{
    margin:0 -16px;
    width:calc(100% + 32px);
  }
  .related-products-track{
    gap:16px;
    padding:0 16px;
  }
  .related-product-card{
    flex:0 0 240px;
    padding:16px;
  }
  .related-product-card img{
    height:160px;
  }
}
