/* Premium homepage styles - overrides and additions */
:root{
  --primary: #0f1724; /* deep navy */
  --accent: #b8860b; /* gold */
  --muted: #6c757d;
  --card-bg: #ffffff;
  --glass: rgba(15,23,36,0.6);
}
body{
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background-color: #fff;
  color: #0f1724;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.lead.text-muted{ color: var(--muted) !important; }
.container { max-width: 1200px; }
.header-premium { background: linear-gradient(180deg,#fff,#fbfbfb); }
.navbar-brand { font-weight: 700; letter-spacing: 0.3px; color: var(--primary); }
.nav-link { color: #24303a !important; padding: .5rem 0.75rem; }
.nav-link:hover { color: var(--accent) !important; text-decoration:none; }
.hero { position:relative; overflow:hidden; min-height:60vh; display:flex; align-items:center; }
.hero__bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:contrast(1) saturate(.9); transform:scale(1.02); }
.hero__overlay { position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,17,36,0.45), rgba(15,17,36,0.6)); }
.hero__content{ position:relative; z-index:2; padding-top:4rem; padding-bottom:4rem; }
.btn-cta { background: linear-gradient(90deg,var(--accent), #e0a400); border: none; color:#fff; box-shadow: 0 8px 30px rgba(184,134,11,0.12); border-radius:10px; padding:.8rem 1.25rem; font-weight:600; }
.btn-cta-outline { border:1px solid rgba(255,255,255,0.25); color:#fff; background:transparent; border-radius:10px; padding:.7rem 1.1rem; }
.card-stats { border-radius:12px; box-shadow: 0 10px 30px rgba(15,23,36,0.04); transition:transform .18s ease, box-shadow .18s ease; background:var(--card-bg); }
.card-stats:hover { transform:translateY(-8px); box-shadow: 0 20px 40px rgba(15,23,36,0.06); }
.card-stats .display-6 { font-size:2rem; color:var(--primary); }
.service-card { border:1px solid #eef1f4; border-radius:12px; background:var(--card-bg); transition: transform .18s ease, box-shadow .18s ease; }
.service-card:hover { transform:translateY(-6px); box-shadow:0 18px 30px rgba(12,16,22,0.06); }
.service-card .icon { font-size:28px; }
.feature-card { border-radius:10px; background:linear-gradient(180deg,#fff,#fbfbfb); box-shadow:0 8px 24px rgba(15,23,36,0.03); }
.card { border-radius: 12px; transition: transform .18s ease, box-shadow .18s ease; overflow:hidden; }
.card:hover { transform: translateY(-8px); box-shadow: 0 20px 40px rgba(12,16,22,0.06); }
.card .card-title { font-size: 1rem; font-weight:700; }
.card-img-top { object-fit:cover; height:220px; width:100%; display:block; transition:transform .35s ease; }
.product-card { display:flex; flex-direction:column; }
.product-card .card-body { padding:1rem; }
.product-card .price { color:var(--accent); font-weight:700; }
.product-card:hover img { transform: scale(1.06); }
.partners .partner-logo { max-height:56px; opacity:.65; filter:grayscale(1) contrast(.9); transition:filter .25s ease, opacity .25s ease, transform .25s ease; }
.partners .partner-logo:hover { filter:none; opacity:1; transform:translateY(-4px); }
.contact-form { background:#fff; box-shadow:0 10px 30px rgba(15,23,36,0.04); border-radius:12px; }
.footer-premium { background:#0f1724; color:#cbd5e1; }
.footer-premium a { color:#e6b75b; text-decoration:none; }
.socials a { font-size:18px; opacity:.9; }
.fade-in-up { opacity:0; transform: translateY(10px); animation:fadeUp .6s forwards; animation-delay: var(--delay, 40ms); }
@keyframes fadeUp { to { opacity:1; transform: translateY(0); } }
.btn { border-radius:10px; padding:.55rem .95rem; }
.btn-outline-primary { border-radius:10px; border:1px solid rgba(15,23,36,0.06); background:transparent; color:var(--primary); }
@media (max-width: 768px) {
  .card .display-6 { font-size: 1.25rem; }
  .navbar-brand { font-size:1rem; }
  .hero__content { padding-top:3rem; padding-bottom:3rem; }
  .card-img-top { height:160px; }
}

/* Shop page specific */
.shop-hero { min-height:36vh; }
.shop-hero .hero__overlay { background: linear-gradient(180deg, rgba(15,17,36,0.45), rgba(15,17,36,0.6)); }
.shop-main { padding-top:48px; padding-bottom:48px; }
.filters-card { border-radius:12px; background:var(--card-bg); box-shadow:0 10px 30px rgba(15,23,36,0.04); padding:18px; }
.filter-toggle { display:none; }
.product-grid { gap:1.25rem; }
.product-card-ui { position:relative; border-radius:12px; overflow:hidden; transition:transform .22s ease, box-shadow .22s ease; box-shadow:0 8px 24px rgba(12,16,22,0.04); background:var(--card-bg); }
.product-card-ui:hover { transform:translateY(-8px); box-shadow:0 20px 40px rgba(12,16,22,0.06); }
.product-card-ui .card-img-top { background:#fff; padding:18px; height:220px; object-fit:contain; transition:transform .35s ease; }
.product-card-ui:hover .card-img-top { transform:scale(1.06); }
.product-meta { padding:1rem; }
.product-title { font-weight:700; font-size:1rem; color:var(--primary); margin-bottom:.25rem; }
.product-price { color:var(--accent); font-weight:700; }
.product-actions { display:flex; gap:.5rem; }
.wishlist-btn { position:absolute; top:10px; right:10px; background:rgba(255,255,255,0.9); border-radius:8px; width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center; box-shadow:0 6px 18px rgba(12,16,22,0.06); border:none; transition:transform .18s ease, background .18s ease; }
.wishlist-btn:hover { transform:translateY(-3px); background:#fff; }
.pagination-modern { display:flex; gap:.5rem; justify-content:center; align-items:center; padding:18px 0; }
.pagination-modern .page-item .page-link { border-radius:10px; padding:.5rem .75rem; border:1px solid rgba(15,23,36,0.06); color:var(--primary); }
.pagination-modern .page-item.active .page-link { background:linear-gradient(90deg,var(--accent), #e0a400); color:#fff; border-color:transparent; }
.topbar { display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:12px 0; border-bottom:1px solid #eef2f5; margin-bottom:18px; }
.sort-select { max-width:220px; }

@media (max-width: 992px) {
  .filter-toggle { display:block; }
  .filters-card { display:none; }
}

@media (max-width: 576px) {
  .product-card-ui .card-img-top { height:180px; padding:12px; }
  .product-actions .btn { width:100%; }
}

/* About page specific */
.about-hero-sub { color: rgba(255,255,255,0.92); font-weight:500; margin-top:6px; }
.about-highlight { background: linear-gradient(90deg, rgba(184,134,11,0.08), rgba(184,134,11,0.04)); border-left:4px solid var(--accent); padding:18px; border-radius:10px; box-shadow:0 8px 24px rgba(15,23,36,0.03); }
.about-section { padding-top:80px; padding-bottom:80px; }
.icon-grid .service-item { transition: transform .18s ease, box-shadow .18s ease; border-radius:12px; padding:18px; background:var(--card-bg); border:1px solid #eef2f5; display:flex; gap:12px; align-items:flex-start; }
.icon-grid .service-item:hover { transform:translateY(-6px); box-shadow: 0 14px 36px rgba(12,16,22,0.06); }
.icon-grid .service-item .icon { width:56px; height:56px; border-radius:10px; display:inline-flex; align-items:center; justify-content:center; background:linear-gradient(180deg,#fff,#fbfbfb); color:var(--accent); font-size:22px; box-shadow:0 6px 18px rgba(12,16,22,0.04); }
.testimonial-card { border-radius:12px; box-shadow:0 12px 36px rgba(15,23,36,0.06); padding:20px; background:var(--card-bg); }
.testimonial-carousel .carousel-item { padding:12px 0; }
.gallery-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:12px; }
.gallery-grid img { width:100%; height:160px; object-fit:cover; border-radius:8px; transition: transform .35s ease; }
.gallery-grid img:hover { transform: scale(1.04); }
.clients-columns { column-count:3; column-gap:24px; }
.clients-columns .client-item { display:block; break-inside:avoid; padding:6px 0; color:var(--primary); }
.fade-delay-1 { --delay:40ms; }
.fade-delay-2 { --delay:120ms; }
.fade-delay-3 { --delay:220ms; }

@media (max-width: 992px) {
  .gallery-grid { grid-template-columns: repeat(2,1fr); }
  .clients-columns { column-count:2; }
}
@media (max-width: 576px) {
  .gallery-grid { grid-template-columns: 1fr; }
  .clients-columns { column-count:1; }
}

/* Contact page specifics */
.contact-card { border-radius:10px; transition:transform .18s ease, box-shadow .18s ease; background:var(--card-bg); border:1px solid #eef2f5; }
.contact-card:hover { transform:translateY(-6px); box-shadow:0 18px 36px rgba(12,16,22,0.06); }
.contact-form .form-control { border-radius:10px; padding:.75rem; border:1px solid #e6e9ee; transition:box-shadow .18s ease, border-color .18s ease; }
.contact-form .form-control:focus { box-shadow:0 6px 24px rgba(15,23,36,0.06); border-color: var(--accent); outline: none; }
.contact-form .btn-cta { padding:.7rem 1.1rem; }
.contact-form .btn-cta:active { transform: translateY(1px); }
.contact-form .spinner-border { vertical-align:middle; }
.contact-form[aria-busy="true"] { opacity:0.9; pointer-events:none; }
.map-embed { border-radius:10px; overflow:hidden; }
.product-card-ui { border-radius:10px; overflow:hidden; transition: transform .22s ease, box-shadow .22s ease; background:var(--card-bg); }
.product-card-ui img { height:140px; object-fit:cover; width:100%; display:block; }
.product-card-ui:hover { transform:translateY(-6px); box-shadow:0 18px 36px rgba(12,16,22,0.06); }
.feature-card { border-radius:10px; background:linear-gradient(180deg,#fff,#fbfbfb); padding:12px; }


