/* ====== Variables ====== */
:root{
  --bg:#070707;
  --card:#0f0f0f;
  --muted:#bdbdbd;
  --accent1:#b30000;
  --accent2:#ff3b3b;
  --white:#ffffff;
  --container:1100px;
  --radius:12px;
  --glass: rgba(255,255,255,0.03);
  --font: 'Poppins', sans-serif;
}

/* ====== Base ====== */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  background: linear-gradient(180deg,#050505 0%, #120000 100%);
  color:var(--white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}



/* ====== Container helper ====== */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 18px;
}

.css-marquee { overflow:hidden; white-space:nowrap; background: linear-gradient(90deg,#0b0b0b,#3b0000); padding:20px 0; }
.css-marquee span { display:inline-block; padding-left:100%; animation: slide 24s linear infinite; font-weight:700; color:yellow; }
@keyframes slide { 0% { transform: translateX(0); } 100% { transform: translateX(-100%); } }


/* ====== Header ====== */
.site-header{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.25));
  border-bottom:1px solid rgba(255,255,255,0.03);
  position:sticky; top:0; z-index:1200;
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 20px;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--white)}
.brand-logo{
    height: 100px;
    width: 100px;
    object-fit: cover;
    /* border-radius: 50%; */
    /* border: 1px solid rgba(255, 255, 255, 0.04); */
    /* background-color: rgb(255 255 255); */
}
.brand-title{font-weight:700;font-size:1.5rem}
.brand-title .herbs {
  color: green;
}

.brand-title .two {
  color: white;
}

.brand-title .heart {
  color: red;
}

.site-nav{display:flex;gap:18px;align-items:center}
.site-nav .nav-link{color:var(--muted);text-decoration:none;font-weight:600}
.site-nav .nav-link:hover{ color: red;}

.hamburger{display:none;background:transparent;border:0;cursor:pointer;padding: 0;}
.hamburger span{display:block;width:22px;height:2px;background:var(--white);margin:4px 0;border-radius:2px}

/* ====== Product hero ====== */
.product-hero{
    display: flex;
    gap: 28px;
    padding: 20px;
    align-items: flex-start;
}
.gallery{flex:0 0 48%;min-width:280px}
.main-photo{background:var(--card);border-radius:var(--radius);border:1px solid rgba(255,255,255,0.03)}
.main-photo img{width:100%;height:auto;border-radius:8px;display:block}
.thumbs{display:flex;gap:8px;margin-top:10px;justify-content:flex-start;flex-wrap:wrap}
.thumb{width:64px;height:64px;object-fit:cover;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:transform .15s, border-color .15s}
.thumb:hover{transform:translateY(-6px);border-color:rgba(255,59,59,0.6)}

.thumbs {
  overflow-x: auto;
  flex-wrap: nowrap;
  scrollbar-width: none;
}
.thumbs::-webkit-scrollbar {
  display: none;
}

.product-info {
    flex: 1;
    min-width: 260px;
    background: linear-gradient(180deg, rgb(49 49 49), rgb(85 85 85 / 18%));
    padding: 22px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.03);
}
.title{font-size:1.6rem;margin:0 0 8px}
.short-desc{
  font-family: "Noto Nastaliq Urdu", "Noto Nastaleeq", "Urdu Typesetting", serif;
  direction: rtl;    /* Urdu ke liye */
  font-size: 17px;   /* apni zarurat ke mutabiq */
color:var(--muted);
margin-bottom:14px;
    direction: rtl;
}
.col-md-12{
padding-left: 20px;
padding-right: 20px;
}
/* price */
.price-row{display:flex;align-items:baseline;gap:16px;margin-bottom:12px}
.price-old .strike{text-decoration:line-through;color:rgba(255,255,255,0.6)}
.price-now{font-size:1.5rem;font-weight:700;color:var(--accent2)}

/* timer */
.timer-card{
background:rgb(255, 255, 255);
padding:12px;
border-radius:8px;
border:1px solid rgba(255,255,255,0.02);
margin:12px 0;
text-align: center;
}
.timer-label{
    font-size: 0.9rem;
    color: #000000;
    margin-bottom: 8px;
    font-weight: 700;
}
.countdown{display:flex;gap:10px;align-items:center;justify-content: center;}
.countdown div{
    background: linear-gradient(180deg, rgb(1 1 1 / 84%), rgb(255 0 0));
    padding: 8px 12px;
    border-radius: 8px;
    text-align: center;
    min-width: 72px;
}
.countdown span{display:block;font-weight:700;font-size:1.1rem}
.countdown small{display:block;color:#ffffff;font-size:0.75rem}
.timer-note{
    font-size: 0.9rem;
    color: #000000;
    margin-bottom: 8px;
    font-weight: 500;
}

/* actions */
.action-row{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
.btn{padding:10px 16px;border-radius:10px;border:0;cursor:pointer;font-weight:700}
.btn-primary{
    background: green;
    color: var(--white);
    box-shadow: 0 10px 30px rgba(179, 0, 0, 0.14);
    width: -webkit-fill-available;
    padding: 15px;
    font-size: 1rem;
}

.bounce-animation{
    animation: bounce 1.1s infinite;
}

.btn:hover{
  cursor: pointer;
}

@keyframes bounce {
  0% {transform: scale(.85);}
  50% {transform: scale(1);}
  100%{transform: scale(.85);}

}

.btn-outline{background:transparent;border:1px solid rgba(255,255,255,0.06);color:var(--white)}

/* quick features */
.quick-features{list-style:none;margin-top:14px;padding-left:0;color:var(--muted)}
.quick-features li{margin:6px 0}

/* promo block */
.promo{display:flex;gap:18px;padding:20px;align-items:center}
.promo-left{flex:1}
.promo-left p {
  direction: rtl;
  font-family: "Noto Nastaliq Urdu", "Noto Nastaleeq", "Urdu Typesetting", serif;
  direction: rtl;    /* Urdu ke liye */
  font-size: 1.2rem;   /* apni zarurat ke mutabiq */

}
.promo-right{flex:0 0 260px;display:flex;flex-direction:column;align-items:center;gap:12px}
.promo-badge{background:linear-gradient(90deg,var(--accent1),var(--accent2));padding:6px 12px;border-radius:999px;font-weight:700;color:#fff}
.promo-image img{width:220px;height:auto;border-radius:10px;border:1px solid rgba(255,255,255,0.04)}
.promo-left ul{
  direction: rtl;
  font-family: "Noto Nastaliq Urdu", "Noto Nastaleeq", "Urdu Typesetting", serif;
  direction: rtl;    /* Urdu ke liye */
  font-size: 1.2rem;   /* apni zarurat ke mutabiq */
}

/*  product description */

.product-description{
    margin: 18px auto;
    padding: 18px;
    border-radius: 10px;
    background-color: #d2d2d2;
    color: #000;
}
.product-description h3{margin:0 0 8px}
.product-description p{
  direction: rtl;
  font-family: "Noto Nastaliq Urdu", "Noto Nastaleeq", "Urdu Typesetting", serif;
  direction: rtl;    /* Urdu ke liye */
  font-size: 1.2rem;   /* apni zarurat ke mutabiq */
}

/* content sections */
.content-section{
    margin: 18px auto;
    padding: 18px;
    border-radius: 10px;
    background: linear-gradient(180deg, rgb(245 5 5), rgb(3 3 3));
    border: 1px solid rgb(255 0 0);
}
.content-section h3{margin:0 0 8px}
.specs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px;color:#2d2d2d}

.testimonials-section {
  padding: 40px 20px;
  background: linear-gradient(180deg, #0b0b0b, #141414);
  color: #fff;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.section-title {
  text-align: center;
  font-size: 2rem;
  margin-bottom: 30px;
  font-weight: 700;
}

.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.review-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: transform .2s ease;
}
.review-card:hover {
  transform: translateY(-5px);
}

.review-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .9rem;
  color: #bbb;
}

.customer-name {
  font-weight: 600;
  color: #fff;
}

.review-date {
  font-size: .8rem;
}

.review-stars {
  color: gold;
  font-size: 1.2rem;
  letter-spacing: 2px;
}

.review-text {
  font-size: .95rem;
  line-height: 1.5;
  color: #e0e0e0;
}

/* ===== Responsive ===== */
@media (max-width: 900px) {
  .reviews-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 600px) {
  .reviews-grid {
    grid-template-columns: 1fr;
  }
}

.write-review {
  max-width: 500px;
  margin: 40px auto;
  padding: 20px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.5); /* Transparent */
  backdrop-filter: blur(6px);
  font-family: Arial, sans-serif;
  color: #fff;
}

.write-review h2 {
  text-align: center;
  margin-bottom: 20px;
  color: #FFD700; /* Golden heading */
}

.form-group {
  margin-bottom: 15px;
}

.form-group label {
  display: block;
  margin-bottom: 6px;
  font-weight: bold;
  color: #eee;
}

.form-group input,
.form-group textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 6px;
  font-size: 14px;
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: #ccc;
}

.rating .stars {
  display: flex;
  gap: 5px;
  font-size: 22px;
  cursor: pointer;
  color: #555;
}

.rating .stars .selected {
  color: #FFD700;
}

.submit-btn {
  display: block;
  width: 100%;
  padding: 12px;
  background: linear-gradient(90deg, #b30000, #000);
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: 0.3s ease;
}

.submit-btn:hover {
  opacity: 0.9;
}

/* Responsive */
@media (max-width: 600px) {
  .write-review {
    margin: 20px;
    padding: 15px;
  }
}

.reviews-pagination {
  display: flex;
  justify-content: center;   /* center align */
  align-items: center;
  flex-wrap: nowrap;         /* row mein rakhega, neeche ni girega */
  gap: 8px;
  margin-top: 16px;
  font-family: inherit;
}

.reviews-pagination .page-btn {
  min-width: 40px;
  padding: 8px 14px;
  border-radius: 8px;
  border: 1px solid #ddd;
  background: #fff;             /* White background */
  color: #333;                  /* Dark text */
  cursor: pointer;
  font-weight: 600;
  transition: all 0.2s ease;
  flex-shrink: 0;               /* Mobile pe bhi size kam na ho */
}

.reviews-pagination .page-btn:hover:not([disabled]) {
  background: #f5f5f5;
  border-color: #bbb;
}

.reviews-pagination .page-btn[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.reviews-pagination .page-number.active {
  background: #333;             /* Active = dark */
  color: #fff;                  /* Text = white */
  border-color: #333;
}

/* Mobile responsive */
@media (max-width: 420px) {
  .reviews-pagination .page-btn {
    padding: 6px 10px;
    min-width: 34px;
    font-size: 14px;
  }
}
html, body {
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: #0d1117;
  color: #ccc;
  font-family: 'Poppins', sans-serif;
}

/* Ensures main content takes remaining height */
main {
  flex: 1;
}

/* Footer Styling */
footer {
  background-color: #111;
  padding: 40px 20px;
  text-align: center;
  width: 100%;
  margin-top: auto; /* keeps footer at bottom */
}

.footer-container {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 50px;
  max-width: 1000px;
  margin: 0 auto;
}

.footer-section {
  flex: 1 1 250px;
  max-width: 300px;
}

.footer-section h3 {
  color: #ff3333;
  margin-bottom: 10px;
}

.footer-section p {
  line-height: 1.6;
}

.footer-section a {
  color: #ccc;
  text-decoration: none;
  transition: 0.3s;
}

.footer-section a:hover {
  color: #ff3333;
}

.copy {
  font-size: 14px;
  border-top: 1px solid #333;
  padding-top: 15px;
  margin-top: 25px;
}

/* Responsive: mobile view vertical layout */
@media (max-width: 768px) {
  .footer-container {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 25px;
  }

  .footer-section {
    max-width: 100%;
  }
}

/* modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,0.75);display:none;align-items:center;justify-content:center;padding:20px;z-index:1000}
.modal.show{display:flex}
.modal-content{background:white;padding:18px;border-radius:12px;max-width:520px;width:100%;border:1px solid rgba(255,255,255,0.03);position:relative}
.modal-close{position:absolute;right:10px;top:8px;background:transparent;border:0;color:var(--accen t2);font-size:22px;cursor:pointer}
.modal-content h4{margin:0 0 10px; color: black; }
.modal-content form{display:flex;flex-direction:column;gap:10px;}
.modal-content input, .modal-content textarea{padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,0.04);background:rgb(233, 225, 225);color:black}
.btn.wide{width:100%}

/* small helpers */
.strike{text-decoration:line-through}
.small{font-size:0.85rem;color:var(--muted)}

/* ====== Responsive ====== */
@media (max-width: 1000px){
  .product-hero{flex-direction:column}
  .gallery{width:100%}
  .promo{flex-direction:column-reverse;align-items:center}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .specs-grid{grid-template-columns:1fr}
}

@media (max-width: 700px){
  .site-nav{display:none}
  .hamburger{display:block}
  .promo-image img{width:180px}
  .reviews-grid{grid-template-columns:1fr}
  .thumb{width:56px;height:56px}
  .countdown div{min-width:60px}
  .brand-title{display:none}
}

@media (max-width:420px){
  .thumb{width:48px;height:48px}
  .promo-image img{width:140px}
  .price-now{font-size:1.25rem}
}


.loader-box{
    display: none;
    justify-content: center;
    align-items: center;
    position: fixed;
    height: 100%;
    width: 100%;
    top: 0;
z-index: 1200;
    background-color: #0000008f;
}

.loader {
  width: 100px;
  height: 100px;
  border: 5px solid #f50000;
  border-radius: 50%;
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  animation: pulse 1s linear infinite;
}
.loader:after {
  content: '';
  position: absolute;
  width: 100px;
  height: 100px;
  border: 5px solid #FFF;
  border-radius: 50%;
  display: inline-block;
  box-sizing: border-box;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  animation: scaleUp 1s linear infinite;
}

@keyframes scaleUp {
  0% { transform: translate(-50%, -50%) scale(0) }
  60% , 100% { transform: translate(-50%, -50%)  scale(1)}
}
@keyframes pulse {
  0% , 60% , 100%{ transform:  scale(1) }
  80% { transform:  scale(1.2)}
}
