@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

:root {
  --primary: #00226B;
  --accent: #e8a020;
  --cream: #f5f0e8;
  --light-bg: #f5f7fa;
  --sky: #4a90b8;
  --dark: #0D1F2D;
  --light-green: #e8f5e9;
  --text-muted: #6b7c93;
  --white: #ffffff;
  --border: #e2e8f0;
  --gradient: linear-gradient(135deg, #01194d 0%, #00226B 60%, #01194d 100%);
}

body {
 font-family: "Inter", sans-serif;
  margin: 0px;
  padding: 0px;
  font-weight: normal;
  background:#fff;
  color: #222;
}

p { font-size: 14px; }

a {
    text-decoration: none !important;
    transition: all 0.2s ease-in;
    color: inherit;
}

.img-responsive { width: 100%; height: auto; }
img { max-width: 100%; border: 0; }

/*------------------common-css-------------------*/

.pa-20{ padding: 16px 0px; }
.pt-30{ padding-top: 30px; }
.pt-50{ padding-top: 50px; }
.pb-50{ padding-bottom: 50px; }
.pt-60{ padding-top: 60px; }
.pt-70{ padding-top: 70px; }
.pt-80{ padding-top: 80px; }
.pb-80{ padding-bottom: 80px; }
.pa-80{ padding: 80px 0; }
.pa-60{ padding: 60px 0; }
.pa-50{ padding: 50px 0; }
.pa-30{ padding: 30px 0; }
.pa-120{ padding: 120px 0; }

 .common-btn{
    font-size: 0.95rem;
    background:var(--accent);
    color: #fff;
    padding: 15px 30px;
    display: inline-block;
    text-decoration: none;
    cursor: pointer;
    line-height: 1;
    border-radius:4px;
    font-weight: 500;
    border:none;
    transition: all 0.3s ease-in-out;
}

.common-btn:hover {
  background:#c8871a; 
  color: #fff;
}

.title-col{ margin-bottom:40px; text-align: center; }

.title {
  position: relative;
  font-size:36px;
  font-weight:700;
  color:#1D1D1F;
  margin-bottom:0px;
  display: inline-block;
  text-transform: uppercase;
}


.title span.red{ color: #E61111; }

.title b{ font-weight: 800; }

.title-para{ font-size:16px; max-width: 900px; margin:20px auto 50px; width: 100%; line-height: 28px; }

.pa-80{ padding: 80px 0px; }

.container-fluid{ padding-left: 30px; padding-right: 30px; }

/*------------------end common-css-------------------*/

/* ========== TOPBAR ========== */
.topbar {
  background: #FDF3CF;
  color: #333;
  font-size: 0.8rem;
  padding: 4px 0;
}
.topbar a { color: #333; text-decoration: none; font-weight: 500; }
.topbar a:hover { color: var(--accent); }

/* ── NAVBAR ── */
.navbar {
    background: url(../images/grass-bg.png) repeat-x #02449c;
    padding: 0px;
    position: sticky;
    top: 0;
    z-index: 99;
    background-size: 10%;
    background-position: bottom;
}
.navbar-brand img { height: 82px; }

.navbar-brand span { color: var(--accent); }
.nav-link {
  font-weight: 500;
  color:#fff !important;
  padding: 6px 14px !important;
  font-size: 0.92rem;
  letter-spacing: 0.02em;
  transition: color 0.2s;
}
.nav-link:hover, .nav-link.active { color: var(--accent) !important; }
.nav-icons a {
  color: #fff;
  font-size: 1.25rem;
  margin-left: 18px;
  position: relative;
  transition: color 0.2s;
}
.nav-icons a:hover { color: var(--accent); }
.badge-cart {
  position: absolute;
  top: -7px; right: -8px;
  background: var(--accent);
  color: #fff;
  font-size: 0.6rem;
  border-radius: 50%;
  width: 16px; height: 16px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
}
.btn-quote {
  background: var(--accent);
  color: var(--white);
  font-weight: 600;
  font-size: 0.85rem;
  padding: 8px 20px;
  border-radius: 4px;
  border: none;
  transition: background 0.2s, transform 0.15s;
  margin-left: 16px;
}
.btn-quote:hover { background: #c8871a; transform: translateY(-1px); color: #fff; }

/* ========== HERO SLIDER ========== */
.hero-slider { position: relative; }
.hero-slide {
  position: relative;
  height: 92vh;
  min-height: 560px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 620px;
}
.hero-tag {
    display: inline-block;
    background: #ecd468;
    color: #000;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    padding: 5px 14px;
    border-radius: 40px;
    margin-bottom: 18px;
}
.hero-content h1 {
  font-size: 3.6rem;
  font-weight: 600;
  color: #01236b;
  line-height: 1.15;
  margin-bottom: 18px;
}
.hero-content p {
  color: #000;
  font-size: 1.2rem;
  line-height: 1.6;
  margin-bottom: 32px;
  font-weight: 400;
}
.btn-hero-primary {
  background: #fff;
  color: #000;
  font-weight: 500;
  padding: 14px 34px;
  border-radius: 4px;
  border: none;
  font-size: 0.95rem;
  letter-spacing: 0.03em;
  margin-right: 12px;
  transition: background 0.2s, transform 0.15s;
  text-decoration: none;
  display: inline-block;
}
.btn-hero-primary:hover { background: #c8871a; transform: translateY(-2px); color: #fff; }
.btn-hero-outline {
  background: transparent;
  color: var(--white);
  font-weight: 600;
  padding: 13px 30px;
  border-radius: 4px;
  border: 2px solid rgba(255,255,255,0.6);
  font-size: 0.95rem;
  transition: border-color 0.2s, background 0.2s;
  text-decoration: none;
  display: inline-block;
}
.btn-hero-outline:hover { border-color: var(--white); background: rgba(255,255,255,0.1); color: #fff; }

/* Owl nav for hero */
.hero-slider  .owl-nav button {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.15) !important;
  border: 2px solid rgba(255, 255, 255, 0.4) !important;
  color: #fff !important;
  width: 52px; height: 52px;
  border-radius: 50% !important;
  font-size: 1.5rem !important;
  backdrop-filter: blur(6px);
  transition: background 0.2s;
}
.hero-slider .owl-nav button:hover { background: rgba(232,160,32,0.8) !important; }
.hero-slider .owl-prev { left: 24px; }
.hero-slider .owl-next { right: 24px; }
.hero-slider .owl-dots {
  position: absolute;
  bottom: 28px;
  left: 50%; transform: translateX(-50%);
}
.hero-slider .owl-dot span {
  background: rgba(255,255,255,0.4) !important;
  width: 10px !important; height: 10px !important;
}
.hero-slider .owl-dot.active span { background: var(--accent) !important; width: 28px !important; border-radius: 5px !important; }

/* ── SECTION HEADERS ── */
.section-label {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: .5rem;
}
.section-title {
  font-size: 2.4rem;
  font-weight: 600;
  color: var(--dark);
  line-height: 1.2;
}
.section-line {
  width: 56px; height: 4px;
  background: var(--accent);
  border-radius: 2px;
  margin: 1rem 0 1.5rem;
}

/* ── PRODUCTS ── */
.products { padding: 70px 0; background: #fff; }
.product-card {
    background: #fff;
    border-radius: 18px;
    overflow: hidden;
    transition: transform .3s, box-shadow .3s;
    height: 100%;
    border: 1px solid #ccc;
}
.product-card:hover { transform: translateY(-8px); box-shadow: 0 24px 60px rgba(0,0,0,.1); }
.product-card-img {
  overflow: hidden;
  background: #fff;
  display: flex; align-items: center; justify-content: center;
}

.product-card-body { padding: 1.5rem; }
.product-badge {
  display: inline-block;
  background: var(--light-green);
  color: var(--primary);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 50px;
  padding: .25rem .8rem;
  margin-bottom: .7rem;
}
.product-card h5 {
  font-weight: 600;
  font-size: 1.2rem;
  margin-bottom: .5rem;
}
.product-card p { font-size: .9rem; color: #555; line-height: 1.6; }



/* ── CATEGORIES ── */
.categories { padding: 90px 0; background: var(--gradient); }
.cat-card {
  background: rgba(255,255,255,.06);
  border: 1.5px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 2.2rem 1.8rem;
  text-align: center;
  transition: background .3s, transform .3s;
  height: 100%;
}
.cat-card:hover { background: rgba(255,255,255,.12); transform: translateY(-6px); }
.cat-icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgb(255 255 255 / 20%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.2rem;
    font-size: 1.6rem;
    color: #fff;
}
.cat-card h5 {
  color: #fff;
  font-size: 1.15rem;
  margin-bottom: .6rem;
}
.cat-card p { color: #ffffffaa; font-size: .88rem; line-height: 1.6; }

/* ── WHY US ── */
.why { padding: 90px 0; background: var(--cream); }
.why-item { display: flex; gap: 1.2rem; margin-bottom: 2.2rem; }
.why-num {
  flex-shrink: 0;
  width: 48px; height: 48px;
  background: var(--accent);
  color: var(--dark);

  font-weight: 900;
  font-size: 1.2rem;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
}
.why-item h6 { font-weight: 700; margin-bottom: .3rem; }
.why-item p { font-size: .9rem; color: #666; line-height: 1.6; }
.why-img img {
  width: 100%; border-radius: 20px;
  box-shadow: 0 20px 60px rgba(0,0,0,.12);
}

/* ========== NEWSLETTER ========== */
.newsletter-section {
  padding: 70px 0;
  background: linear-gradient(135deg, #1a3c5e 0%, #0d2538 100%);
}
.newsletter-section h2 { color: #fff; }
.newsletter-section p { color: #aec6df; font-size: 0.95rem; }
.newsletter-form { max-width: 480px; margin: 0 auto; }
.newsletter-form .form-control {
  border-radius: 4px 0 0 4px;
  border: none;
  padding: 14px 18px;
  font-size: 0.9rem;
  background: rgba(255,255,255,0.95);
}
.newsletter-form .form-control:focus { box-shadow: none; outline: none; }
.newsletter-form .btn-subscribe {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 0 4px 4px 0;
  padding: 14px 24px;
  font-weight: 700;
  font-size: 0.88rem;
  transition: background 0.2s;
}
.newsletter-form .btn-subscribe:hover { background: #c8871a; }

/* ========== FOOTER ========== */
footer {
  background: var(--dark);
  color: #8fa3b4;
  padding: 60px 0 0;
}
.footer-brand {
    font-size: 1.7rem;
    font-weight: 300;
    color: var(--accent);
    letter-spacing: 3px;
}

footer p.footer-desc { font-size: 0.84rem; line-height: 1.7; margin: 14px 0 22px; }
.footer-social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.07);
  color: #8fa3b4;
  margin-right: 8px;
  font-size: 0.95rem;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.footer-social a:hover { background: var(--accent); color: #fff; }
.footer-title { font-size: 0.82rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: #fff; margin-bottom: 18px; }
footer ul { list-style: none; padding: 0; }
footer ul li { margin-bottom: 9px; }
footer ul li a { font-size: 0.84rem; color: #8fa3b4; text-decoration: none; transition: color 0.2s; }
footer ul li a:hover { color: var(--accent); }
.footer-contact-item { display: flex; gap: 10px; align-items: flex-start; margin-bottom: 12px; font-size: 0.84rem; }
.footer-contact-item i { color: var(--accent); margin-top: 2px; flex-shrink: 0; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.07);
  margin-top: 48px;
  padding: 18px 0;
  font-size: 0.78rem;
}
.payment-icons { display: flex; gap: 8px; align-items: center; }
.payment-icon {
  background: rgba(255,255,255,0.08);
  border-radius: 4px;
  padding: 4px 10px;
  font-size: 0.72rem;
  color: #aec6df;
  font-weight: 600;
  letter-spacing: 0.04em;
}

/* ========== BACK TO TOP ========== */
#backToTop {
  position: fixed;
  bottom: 30px; right: 30px;
  background: var(--accent);
  color: #fff;
  border: none;
  width: 44px; height: 44px;
  border-radius: 50%;
  font-size: 1.1rem;
  cursor: pointer;
  display: none;
  z-index: 999;
  box-shadow: 0 4px 14px rgba(232,160,32,0.4);
  transition: background 0.2s;
}
#backToTop:hover { background: #c8871a; }

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeRight {
  from { opacity: 0; transform: translateX(40px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .hero { min-height: auto; padding: 5rem 0 4rem; }
  .hero-stat-row { gap: 1.5rem; }
  .hero-img-badge { display: none; }
}

/* ── TESTIMONIALS ── */
.testimonials { padding: 80px 0; background: var(--gradient); }
.testi-card {
  background: rgba(255,255,255,.07);
  border: 1.5px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 2rem;
  margin: 0 12px 30px;
  transition: background .3s, transform .3s;
}
.testi-card:hover { background: rgba(255,255,255,.12); }
.testi-stars {
    color: var(--accent);
    font-size: 13px;
    letter-spacing: 4px;
    display: block;
    margin-bottom: 14px;
}
.testi-text { color: #ffffffcc; font-size: .92rem; line-height: 1.75; margin-bottom: 1.4rem; font-style: italic; }
.testi-author { display: flex; align-items: center; gap: .9rem; }
.testi-avatar {
  width: 46px; height: 46px; flex-shrink: 0;
  background: linear-gradient(135deg, var(--accent), #c07010);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; color: var(--dark); font-size: .85rem;
}
.testi-name { color: #fff; font-weight: 700; font-size: .9rem; }
.testi-role { color: #ffffff88; font-size: .78rem; margin-top: .15rem; }

/* ── FAQ ── */
.faq { padding: 90px 0; background: var(--cream); }
.faq-item {
  border-bottom: 1.5px solid #e5ddd0;
  margin-bottom: .5rem;
}
.faq-question {
  width: 100%; text-align: left;
  background: none; border: none; padding: 1.2rem 0;
  font-size: 1rem;
    font-weight: 500;
  color: var(--dark);
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; cursor: pointer;
  transition: color .2s;
}
.faq-question:hover { color: var(--primary); }
.faq-icon { flex-shrink: 0; font-size: 1rem; color: var(--accent); transition: transform .3s; }
.faq-question[aria-expanded="true"] .faq-icon { transform: rotate(180deg); }
.faq-answer { padding: 0 0 1.2rem; color: #555; font-size: .92rem; line-height: 1.75; }


.homeproducts-sec{  padding:90px 0px 80px;  }

.products-col{ text-align: center; background: #fff; margin-bottom: 24px; }
.products-col a{ display: block; }

.item-pic {
    border-radius: 10px;
    overflow: hidden;
}

.item-text { margin-top:10px; margin-bottom: 0px; padding-left: 30px; padding-right: 30px; }
.item-text h3 {
    font-size: 17px;
    margin-bottom: 10px;
    color: #222;
    font-weight: 500;
}

.item-text h4 {
  font-size: 18px;
  margin-bottom:0px;
  color: #02449C;
  font-weight: 600;
}

.item-text h4 *{ font-size: 16px !important; }

.item-text p {
  color: #666;
  font-size: 16px;
  margin-bottom: 5px;
}

.homeproducts-sec .owl-nav .owl-prev {
  position: absolute;
  color: #fff;
  top: 50%;
  left:-30px;
  transform: translateY(-50%);
  text-transform: uppercase;
  font-size: 16px;
}

.homeproducts-sec .owl-nav .owl-next {
  position: absolute;
  color: #fff;
  top: 50%;
  right:-30px;
  transform: translateY(-50%);
  text-transform: uppercase;
  font-size: 16px;
}

.homeproducts-sec .owl-nav span {
  position: relative;
}

.homeproducts-sec .owl-nav i {
  font-size:24px;
  color: #fff;
line-height: 55px;
}

/*--------search---------*/

.top-search-ico{ cursor: pointer; }

.search-box {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: url(../images/grass-bg.png) repeat-x #02449c;
  background-size: 10%;
  background-position: bottom;
  padding: 15px 20px 25px;
  display: none;
  z-index: 99;
}

.search-box h3 {
  color: #fff;
  font-weight: 500;
  font-size: 28px;
}

.search-close {
  position: absolute;
  top:6px;
  cursor: pointer;
  right: 20px;
}
.search-close i {
  font-size: 22px;
  transition: all 0.5s ease;
  color: #fff;
}

.search-box .container{ position: relative; }

.search-box .subs-ico {
    top: 0;
    right: 0;
    border: 0;
    border-radius: 0 4px 4px 0;
    font-size: 15px;
    position: absolute;
    color: #111;
    padding: 0px 15px;
    margin: 0px;
    text-align: center;
    background: var(--accent);
    height: 100%;
    font-weight: 600;
}

.search-box .subs-ico i{ margin-right:4px; }

.search-form .form-control{ font-weight: 500; font-size: 14px; padding: 0.6rem .75rem; }

form.search-form { position: relative; }

.login-ico i{ font-size: 22px; }

.modal-content {
    border-radius: 20px;
    border: none;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}
.login-left {
    height: 100%;
    position: relative;
    min-height: 500px;
}
.login-left img{ width: 100%; height: 100%; object-fit: cover; }
.login-form-wrapper {
    padding: 40px 30px;
}

.field-group {
    margin-bottom: 1.15rem;
}

.field-group label {
    display: block;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #111;
    margin-bottom: 7px;
}

.input-wrap { position: relative; }
.input-icon {
    position: absolute;
    left: 13px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--muted);
    pointer-events: none;
    display: flex;
    align-items: center;
}
.form-control {
    width: 100%;
    padding: 11px 14px 11px 40px;
    font-size: 0.92rem;
    background: #f5f5f5;
    border: 1.5px solid var(--border);
    border-radius: 8px;
    outline: none;
}

.options-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.6rem;
    margin-top: 0.25rem;
}
.remember {
    display: flex;
    align-items: center;
    gap: 7px;
    cursor: pointer;
    font-size: 0.84rem;
    color: var(--muted);
    user-select: none;
}
.forgot-link {
    font-size: 0.84rem;
    font-weight: 600;
    color: var(--primary);
    text-decoration: none;
    transition: color 0.2s;
}

#loginModal .modal-content{ position: relative; }
#loginModal .btn-close{ position: absolute; right: 20px; top: 20px; z-index: 1; }

#forgotModal .modal-content{ position: relative; }
#forgotModal .btn-close{ position: absolute; right: 20px; top: 20px; z-index: 1; }

#signupModal .modal-content{ position: relative; }
#signupModal .btn-close{ position: absolute; right: 20px; top: 20px; z-index: 1; }

.newlogin-link{ text-align: center; font-size: 14px; }
.newlogin-link a{ font-weight: 500; color: var(--accent); }

.modal .title{ font-size: 28px; }

/*------------inner page------------*/

.inner-banner {
  background: #EBF3FF;
  padding: 40px 0px;
  text-align: center;
}

/* ===== TITLE ===== */
.inner-banner h1 {
  font-size: 42px;
  font-weight: 600;
  margin-bottom: 15px;
  color: #222;
}

.inner-banner p{
  font-size: 18px;
  font-weight: 400;
  max-width: 600px;
  width: 100%;
  margin: 0px auto 16px;
  color: #666;
}

/* ===== BREADCRUMB ===== */
.breadcrumb {
    font-size: 14px;
    color: #02449C;
    margin: auto;
    display: flex;
    justify-content: center;
}

.breadcrumb a {
  text-decoration: none;
  color: #6c757d;
  transition: 0.3s;
}

.breadcrumb a:hover {
  color: #000;
}

.breadcrumb span {
  margin: 0 8px;
}

.inner-page{ padding: 50px 0px 70px; }

.btn-cart {
  background:none;
  color: #000;
  border: 1px solid #aaa;
  border-radius: 6px;
  padding: 10px 20px;
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.3px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.3s ease;
  margin-top: 14px;
}

.btn-cart:hover {
  background: #c8871a;
  transform: translateY(-2px);
  border-color: #c8871a;
  color: #fff;
}

.carousel-control-prev-icon, .carousel-control-next-icon {
    background-color: rgb(0 0 0 / 30%);
    border-radius: 50%;
    padding: 20px;
    background-size: 50%;
}

.pro-title { font-size: 34px; font-weight: 500; }

.star-rating {
    color: #f5b342;
    font-size: 1rem;
}

.stock {
  background: #e6f4ea;
  color: #1e7e34;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
}

/* ===== PRICE ===== */
.price {
  font-size: 36px;
  font-weight: 600;
  color: #02449c;
}

/* ===== DESC ===== */
.desc {
  color: #666;
  line-height: 1.7;
  font-size: 15px;
}

/* ===== FEATURES ===== */
.feature-icon {
    width: 42px;
    height: 42px;
    background: #e8f2fe;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: #02449c;
}

/* ===== SIZE SELECT ===== */
.size-select {
  border-radius: 30px;
  padding: 10px 15px;
}

/* ===== QTY ===== */
.qty {
    width: 90px;
    border-radius: 30px;
    text-align: center;
    background-color: #fff;
    border-color: #dee2e6;
    color: #000;
    padding: 0px;
    height: 40px;
    font-weight: 600;
    padding-left: 10px;
    padding-right: 9px;
}

.mainprodt-right {
    position: sticky;
    top: 20px;
    z-index: 9;
}


.mainproduct-middle{ background:#F2F2F2; padding: 50px 0px; }

/* REMOVE DEFAULT BORDER */
.custom-tabs {
  border-bottom: 1px solid #e5e5e5;
  gap: 30px;
}

/* TAB BUTTON */
.custom-tabs .nav-link {
    border: none;
    background: none;
    color: #2f2f2f !important;
    font-size: 15px;
    font-weight: 600;
    padding: 12px 0;
    position: relative;
    transition: 0.3s;
}

/* HOVER */
.custom-tabs .nav-link:hover {
  color: #111;
}

/* ACTIVE TAB */
.custom-tabs .nav-link.active {
  color:var(--accent) !important;
}

/* UNDERLINE */
.custom-tabs .nav-link.active::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 2px;
  background: var(--accent);
}

.stats-row {
    display: flex;
    gap: 2rem;
    margin-top: 0rem;
    text-align: center;
}
.stat-number {
    display: block;
    font-size: 2rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: 0px;
}
.stat-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    color: var(--text-muted);
    letter-spacing: 0.05em;
}

.storytab-text p{ font-size: 15px; line-height: 24px; color: #666; }

.ingredientstab-content .card-title {
  font-size: 18px;
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: var(--primary);
}
.ingredientstab-content .card-text {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.section-heading em{ color: var(--accent);}

/* ===== CARD ===== */
.nutrition-card {
  border: 1px solid #eee;
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}

/* HEADER */
.nutrition-header {
  background: #0b2a66;
  color: #fff;
  padding: 20px;
}

.nutrition-header h4 {
  margin: 0;
  font-weight: 600;
}

.nutrition-header small {
  opacity: 0.8;
}

/* BODY */
.nutrition-body {
  padding: 15px 20px;
}

/* ROW */
.nut-row {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid #eee;
  font-size: 14px;
}

.nut-row.sub {
  padding-left: 15px;
  font-size: 13px;
  color: #666;
}

.nut-row.highlight {
  border-bottom: none;
  font-weight: 600;
  color: #ff6a00;
}

/* RIGHT BOX */
.info-box {
  background: #fff;
  padding: 25px;
  border-radius: 16px;
}

.info-box h2 {
  font-size: 36px;
  font-weight: 600;
  color: #0b2a66;
}

.muted {
  color: #777;
  font-size: 14px;
}

/* ALLERGEN */
.allergen-box {
  background: #eaf5ee;
  border: 1px solid #c8e6c9;
  padding: 20px;
  border-radius: 16px;
}

.allergen-box h6 {
  font-weight: 600;
  margin-bottom: 8px;
  color: #2e7d32;
}

.allergen-box p {
  font-size: 14px;
  color: #444;
}

/* ===== RATING BOX ===== */
.rating-box {
  background: #f7f8fa;
  border-radius: 16px;
  padding: 30px;
}

.rating-number {
  font-size: 48px;
  font-weight: 600;
  color: #0b2a66;
}

.stars {
  color: #f4a100;
  font-size: 18px;
}

/* ===== BARS ===== */
.bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  font-size: 13px;
}

.bar {
  flex: 1;
  height: 6px;
  background: #e5e5e5;
  border-radius: 10px;
}

.fill {
  height: 100%;
  background: #f4a100;
  border-radius: 10px;
}

.fill.small {
  background: #4da3ff;
}

.fill.tiny {
  background: #999;
}

/* ===== REVIEW CARD ===== */
.review-card {
  background: #f7f8fa;
  border-radius: 16px;
  padding: 20px;
  transition: 0.3s;
}

.review-card:hover {
  background: #fff;
  box-shadow: 0 10px 25px rgba(0,0,0,0.05);
}

/* TOP */
.review-top {
  display: flex;
  justify-content: space-between;
  align-items: start;
  margin-bottom: 10px;
}

/* VERIFIED */
.verified {
  background: #e6f4ea;
  color: #2e7d32;
  padding: 2px 6px;
  font-size: 11px;
  border-radius: 6px;
  margin-left: 5px;
}

/* BUTTON */
.btn-clean {
  border: 1px solid #ddd;
  background: transparent;
  padding: 10px 20px;
  border-radius: 8px;
  transition: 0.3s;
  font-size: 14px;
}

.btn-clean:hover {
  border-color: #111;
  color: #111;
}

.faq-search{ max-width: 600px; width: 100%; margin:0px auto 40px; background: #f5f5f5; border-radius: 14px; padding: 20px; }
.faq-search .form-control{ background-color: #fff; }

.hero-bulk {
    background:url(../images/bulk-banner.jpg) no-repeat;
    background-size: cover;
    position: relative;
    overflow: hidden;
    padding:3rem 0;
}
.hero-bulk .badge-accent {
    background: rgb(255 255 255 / 15%);
    backdrop-filter: blur(4px);
    color: #ffc107;
    font-weight: 500;
    letter-spacing: 0.5px;
}
.hero-title { font-size: 3.8rem; }

.bulkpg-middle1 .cat-card {
  background: #f5f5f5;
  border-radius: 16px;
  padding: 25px 15px;
  transition: 0.3s all ease;
  border: 1px solid #e1e1e1;
  cursor: pointer;
}

.bulkpg-middle1 .cat-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.1);
  border: 1px solid #f59e0b; /* Accent color on hover */
}

.bulkpg-middle1 .cat-icon {
  font-size: 2.5rem;
  color: #011E5C; /* Primary Bootstrap color */
  margin-bottom: 12px;
  transition: 0.3s;
}

.bulkpg-middle1 .cat-card:hover .cat-icon {
  transform: scale(1.2);
  color: #f59e0b; /* Accent on hover */
}

.bulkpg-middle1 .cat-title {
  font-weight: 600;
  font-size: 1.1rem;
  color: #0d2149;
  margin-bottom: 5px;
}

.bulkpg-middle1 .cat-desc {
  font-size: 0.85rem;
  color: #6c757d;
}

.para-title{ font-size: 16px; color: #666; }

.quote-card {
    max-width: 1070px;
    width: 100%;
    background: white;
    border-radius: 28px;
    box-shadow: 0 20px 35px -12px rgba(0,0,0,0.1);
    overflow: hidden;
    margin: auto;
}
.quote-card .card-header {
    background: #0a2540;
    color: white;
    padding: 1.8rem 2rem;
}
.quote-card .card-header h2 {
    font-weight: 600;
    margin-bottom: 0.5rem;
    font-size: 1.8rem;
}
.quote-card .card-header p {
    margin-bottom: 0;
    opacity: 0.85;
    font-size: 0.95rem;
}
.card-body {
    padding: 2rem;
}
.form-label {
    font-weight: 600;
    font-size: 0.85rem;
    margin-bottom: 0.4rem;
    color: #1e4663;
}

.quote-card .form-control{ padding-left: 15px; background-color: #fff; border-color: #ccc; }
.quote-card .form-select{  border-color: #ccc; height: 45px; font-size: 14px; }

.contact-card {
    background: white;
    border-radius: 2rem;
    box-shadow: 0 20px 35px -12px rgba(0, 0, 0, 0.1);
    padding: 2rem 1.5rem;
    height: 100%;
    transition: all 0.3s ease;
    border: 1px solid #e1e1e1;
    text-align: center;
}
.contact-icon {
    width: 70px;
    height: 70px;
    background: #e8f2fe;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.2rem;
    transition: 0.2s;
}
.contact-icon i {
    font-size: 2rem;
    color: #02449c;
}
.contact-card h5 {
    font-weight: 700;
    color: #2c3e50;
}
.contact-card p{ font-size: 15px; }

.form-card{
    background:#fff4e0;
    border-radius: 2rem;
    box-shadow: 0 20px 35px -12px rgba(0, 0, 0, 0.1);
    padding: 2rem 1.5rem;
    height: 100%;
    transition: all 0.3s ease;
}


.form-card .form-control {
    padding-left: 15px;
    background-color: #fff;
    border-color: rgb(0 0 0 / 20%);
    color: #fff;
}

.contact-map {
    height: 100%;
}
.contact-map iframe {
    border-radius: 20px;
}

.sidebar {
  position: sticky;
  top: 10px;
  background: #ffffff;
  padding: 20px;
  border-radius: 12px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.05);
  margin-right: 20px;
}

.sidebar-title {
  font-weight: 600;
  font-size: 16px;
  margin-bottom: 15px;
  color: #02449C;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.sidebar a {
    display: block;
    padding: 10px 0px;
    margin-bottom: 6px;
    color: #495057;
    font-size: 14px;
    transition: all 0.25s ease;
    border-bottom: 1px solid #e1e1e1;
}

.sidebar a:hover {
  color: #0d6efd;
  transform: translateX(6px);
  border-color: #0d6efd;
}

.policy-content h3:first-child{ margin-top: 0px; }

.policy-content h3 {
  margin-top: 50px;
  font-weight: 600;
}

.policy-content p {
  margin-top: 12px;
  line-height: 1.9;
  color: #495057;
}

.policy-content ul {
  margin-top: 10px;
  padding-left: 20px;
}

.policy-content li {
  margin-bottom: 8px;
}

.highlight {
  background: #eef4ff;
  border-left: 4px solid #0d6efd;
  padding: 20px;
  border-radius: 8px;
  margin: 20px 0;
  font-style: italic;
}

blockquote {
  border-left: 4px solid #6c757d;
  padding-left: 15px;
  color: #555;
  margin: 20px 0;
}

.about-herobanner{ background: url(../images/about-banner.jpg) no-repeat; padding: 7rem 0px; }

.welcome-text{ padding-left: 30px; }
.welcome-text .title{ border-left: 5px solid #0a58ca; color: var(--primary); padding-left: 1rem; margin-bottom: 24px; line-height: 1; }
.welcome-text p{ font-size: 14px; line-height: 24px; }
.welcome-text ul{ padding-left: 16px; }
.welcome-text ul li{ font-size: 14px; line-height: 26px; color: #000; }

.about-sec2 .row{ background: var(--gradient); padding:60px 40px; border-radius: 24px; margin: 0px; }
.about-sec2 *{ color: #fff; }
.about-sec2 .title{ color: #fff; border-color: #fff; }
.about-sec2 .welcome-text{ padding-left: 0px; padding-right: 50px; }

#productGallery img{ border-radius: 16px; }
.border.rounded.p-3 {
    background: #f5f5f5;
}

/* Cart Card */
.cart-card {
    background: #fff;
    border-radius: 16px;
    padding: 25px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.cart-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 15px 40px rgba(0,0,0,0.12);
}

/* Product Row */
.product-row {
    border-bottom: 1px solid #eee;
    padding: 18px 0;
    transition: background 0.2s ease;
}

.product-row:last-child {
    border-bottom: none;
}

.product-row:hover {
    background: #f9f9f9;
    border-radius: 12px;
}

/* Quantity Input */
.qty-input {
    width: 100px;
    border-radius: 10px;
    text-align: center;
    border: 1px solid #ccc;
    transition: border-color 0.2s;
}

.qty-input:focus {
    border-color: #343a40;
    box-shadow: 0 0 5px rgba(0,0,0,0.1);
    outline: none;
}

/* Remove Button */
.remove-btn {
    cursor: pointer;
    color: #dc3545;
    font-size: 1.2rem;
    transition: color 0.2s;
}

.remove-btn:hover {
    color: #a71d2a;
}

/* Summary Box */
.summary-box {
    background: #fff;
    border-radius: 16px;
    padding: 25px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    position: sticky;
    top: 20px;
}

.summary-box h5 {
    border-bottom: 1px solid #eee;
    padding-bottom: 10px;
    margin-bottom: 20px;
}

.summary-box .btn {
    border-radius: 10px;
    padding: 12px 0;
    font-weight: 500;
    transition: background 0.2s, transform 0.2s;
}

.summary-box .btn:hover {
    transform: translateY(-2px);
}

.summary-box .btn-outline-secondary:hover {
    background: #e9ecef;
}

/* Responsive tweaks */
@media (max-width: 992px) {
    .summary-box {
        position: static;
    }
}

/* Product Card inside cart (optional extra) */
.product-card {
    background: #fafafa;
    padding: 15px;
    border-radius: 12px;
    margin-bottom: 12px;
    transition: box-shadow 0.2s;
}

.product-card:hover {
    box-shadow: 0 5px 15px rgba(0,0,0,0.08);
}


/*--------------media css--------------*/

@media (max-width: 1180px) {
.container{ max-width: 98%; }
.product-card{ padding: 0px; }
.testimonials .container { max-width: 100%; padding: 0px; }
.faq-question{ font-size: 1.5rem; }
footer .col-lg-4 { flex: 0 0 auto; width: 100%; }
footer .col-lg-2 { flex: 0 0 auto; width: 25%; }
.hero-title { font-size: 3rem; }
.hero-content h1{ font-size: 3rem; }
.hero-slide .container{ max-width: 960px; }
.nav-link{ padding: 6px 12px !important; }
.section-title{ font-size: 3rem; }

}

@media (max-width: 1024px) {
.navbar-brand img { height: 60px; }
.nav-link { padding: 6px 6px !important; }
.container-fluid { padding-left: 20px; padding-right: 20px; }
.hero-slide .container { max-width: 77%; }
.inner-banner{ padding: 80px 0px; }
.about-herobanner{ padding: 2rem 0px; }
.about-herobanner .col-lg-8{ width: 90%; }
.lead{ font-size: 1.1rem; }
.newsletter-section .section-title { font-size: 2rem; }

}

@media (max-width: 953px) {
.navbar-toggler{ border: none; color: #fff; }
.navbar-toggler-icon{ filter: invert(1) contrast(10); }
.navbar-toggler:focus{ box-shadow: none; }

.navbar .d-flex.align-items-center{ 
    position: absolute;
    right: 85px;
    top: 20px;
}
.hero-content h1 { font-size: 2.5rem; }
body{ overflow-x: hidden; }
.section-title { font-size: 2.6rem; }
.cat-card{ padding: 20px 10px; }
#why .why-item:last-child{ margin-bottom: 0px; }
.about-herobanner { padding: 4rem 0px; }
.welcome-text { padding-left: 0px; }
.faq-question { font-size: 1.3rem; }
.bulkpg-middle1 .cat-card{ height: auto; margin-bottom: 20px; }
.contact-map{ margin-top: 30px; }
.contact-map iframe{ height: 400px !important; }


}


@media (max-width: 570px) {
.topbar{ display: none; }
.hero-slide{ height: auto; }
.hero-content h1 { font-size: 2rem; }
.hero-slider .owl-nav button.owl-next{ display: none; }
.hero-slider .owl-nav button.owl-prev{ display: none; }
.hero-slide .container { max-width: 90%; }
.products{ padding: 50px 0; }
.section-title { font-size: 2rem; }
.homeproducts-sec{ padding: 50px 0; }
.why{ padding: 50px 0; }
.testimonials{ padding: 60px 0 40px; }
.faq{ padding: 50px 0; }
.newsletter-section{ padding: 50px 0; }
footer .col-lg-4{ padding-bottom: 20px; }
footer .col-lg-2{ width: 100%; margin-top: 0px; border-top: 1px solid #1f3547; padding-top: 20px; }
.footer-title{ font-size: 1rem; margin-bottom: 10px; }
.footer-bottom{ margin-top: 12px; }
.inner-banner h1{ font-size: 32px; }
.inner-banner { padding: 40px 0px; }
.d-flex.gap-3.mb-3{ display:block !important; }
.mainprodt-right .d-flex.gap-3.mb-3 .common-btn{ margin-bottom: 10px; width: 100%; text-align: center; }
.mainprodt-right .d-flex.justify-content-between.small.text-secondary{ flex-direction: column; gap: 6px; }
.hero-title { font-size: 2.4rem; }
.about-herobanner .col-lg-8 {  width: 94%; }
.welcome-text{ margin-top: 20px; }
.aboutsec-3.bulkpg-middle1 .col{ width: 100%; flex: 1 1 auto; }
.about-sec2 .welcome-text {
    padding-left: 0px;
    padding-right: 0px;
    margin-top: 40px;
}
.about-sec2 .row{ padding: 30px 20px; }
.contact-card{ height: auto; margin-bottom: 20px; }
.mainprodt-right{ margin-top: 30px; position: static; }





}







