@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Cormorant+Garamond:wght@500;600;700&display=swap');

:root {
  --navy: #0D1B3E;
  --navy-light: #1A2F5E;
  --navy-deep: #06102A;
  --yellow: #FFD600;
  --yellow-light: #FFE566;
  --yellow-deep: #F9A825;
  --white: #ffffff;
  --shadow: 0 26px 65px rgba(0, 0, 0, .18);
  --soft-shadow: 0 18px 48px rgba(60, 65, 75, .08);
  --radius: 24px;
}

* {
  box-sizing: border-box
}

html {
  scroll-behavior: smooth
}

body {
  margin: 0;
  font-family: "Inter", sans-serif;
  color: #12151a;
  background: #fff;
  line-height: 1.72;
}

a {
  text-decoration: none
}

img {
  max-width: 100%
}

.section-padding {
  padding: 35px 0
}

.section-sm {
  padding: 70px 0
}

.display-serif {
  font-family: "Cormorant Garamond", serif;
  letter-spacing: -.02em;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: #0D1B3E;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2.1px;
}

.eyebrow::before {
  content: "";
  width: 42px;
  height: 1px;
  background: linear-gradient(90deg, #0D1B3E, transparent);
}

.section-title {
  font-size: clamp(34px, 4vw, 62px);
  line-height: 1.02;
  font-weight: 700;
  margin: 18px 0 18px;
}

.section-subtitle {
  max-width: 740px;
  color: #5c6674;
  font-size: 14px;
}

.text-gold {
  color: #FFD600
}

.text-ruby {
  color: #FFD600
}

.bg-luxe-soft {
  background: linear-gradient(180deg, #eef2ff, #e8edf8)
}

/* ── Topbar ── */
.topbar {
  background: #0D1B3E;
  color: #fff;
  padding: 9px 0;
  font-size: 13px;
  letter-spacing: .2px;
}

.topbar a {
  color: #FFD600
}

/* Mobile View */
@media (max-width: 768px) {
    .topbar {
        padding: 0px 0;
    }
}

@media (max-width: 768px) {
    .section-title {
      font-size: 28px !important;
    }
}
/* ── Navbar ── */
.navbar {
  background: rgba(13, 27, 62, .97) !important;
  backdrop-filter: blur(14px);
  border-bottom: 2px solid #FFD600;
}

.navbar-brand {
  color: #fff !important;
  font-size: 32px;
  font-weight: 900;
  letter-spacing: .4px;
}

/* Mobile View */
@media (max-width: 768px) {
    .navbar-brand {
        font-size: 28px;
    }
}

.navbar-brand span {
  color: #FFD600;
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
}

.nav-link {
  color: #fff !important;
  font-weight: 700;
  margin: 0 8px;
  position: relative;
}

.nav-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 100%;
  bottom: -7px;
  height: 2px;
  background: #FFD600;
  transition: .35s ease;
}

.nav-link:hover::after,
.nav-link.active::after {
  right: 0
}

.nav-link:hover,
.nav-link.active {
  color: #FFD600 !important;
  opacity: 1
}

/* ── Buttons ── */
.btn-luxe {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 24px;
  border: none;
  border-radius: 999px;
  font-weight: 800;
  color: #0D1B3E;
  background: #FFD600;
  box-shadow: 0 14px 35px rgba(255, 214, 0, .40);
  transition: .3s ease;
}

.btn-luxe:hover {
  transform: translateY(-2px);
  background: #F9A825;
  color: #0D1B3E
}

.btn-luxe-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 13px 22px;
  border-radius: 999px;
  border: 2px solid #FFD600;
  color: #FFD600;
  font-weight: 800;
  transition: .3s ease;
}

.btn-luxe-outline:hover {
  background: #FFD600;
  color: #0D1B3E;
}

.btn-ruby-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: 999px;
  border: 2px solid #FFD600;
  color: #FFD600;
  font-weight: 800;
  transition: .3s ease;
}

.btn-ruby-outline:hover {
  background: #FFD600;
  color: #0D1B3E;
}

/* ── Hero ── */
.hero {
  min-height: 100vh;
  color: #fff;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  background:
    radial-gradient(circle at 16% 22%, rgba(255, 255, 255, .14), transparent 18%),
    radial-gradient(circle at 84% 20%, rgba(255, 214, 0, .20), transparent 18%),
    linear-gradient(120deg, #0D1B3E 0%, #1A2F5E 40%, #0D1B3E 100%);
}

.hero::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 42%;
  height: 100%;
  background: linear-gradient(180deg, #FFD600, #F9A825);
  clip-path: polygon(24% 0, 100% 0, 100% 100%, 0 100%);
  z-index: 0;
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255, 255, 255, .06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .06) 1px, transparent 1px);
  background-size: 78px 78px;
  opacity: .35;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, .7), transparent);
  z-index: 0;
}

.hero .container {
  position: relative;
  z-index: 2
  top: 0px !important;
}

.hero-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 1px solid rgba(255, 255, 255, .40);
  background: rgba(255, 255, 255, .18);
  color: #fff;
  border-radius: 999px;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.7px;
}

/* Mobile View */
@media (max-width: 768px) {
    .hero-chip  {
        font-size: 8px !important;
    }
}

/* Mobile View */
@media (max-width: 768px) {
    .hero h1  {
        font-size: clamp(44px, 6vw, 88px) !important;
    }
}

.hero h1 {
  font-size: clamp(48px, 6vw, 88px);
  line-height: .93;
  margin: 20px 0 18px;
  max-width: 760px;
  font-weight: 700;
}

.hero p {
  max-width: 640px;
  color: rgba(255, 255, 255, .88);
  font-size: 18px;
  margin-bottom: 30px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px
}

.hero-aside {
  position: relative;
  min-height: 620px
}

.hero-frame {
  position: absolute;
  right: 0;
  top: 70px;
  width: 420px;
  border-radius: 32px;
  overflow: hidden;
  background: rgba(255, 255, 255, .15);
  border: 1px solid rgba(255, 255, 255, .35);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}

.hero-frame .visual {
  min-height: 310px;
  position: relative;
  background:
    radial-gradient(circle at 78% 24%, rgba(255, 214, 0, .50), transparent 26%),
    linear-gradient(140deg, #1A2F5E, #0D1B3E);
}

.hero-frame .visual::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(249, 221, 39, 0.35);
  border-radius: 24px;
}

.hero-frame .visual::after {
  content: "BESPOKE\A STEEL\A SOLUTIONS";
  white-space: pre;
  position: absolute;
  left: 26px;
  bottom: 24px;
  color: #FFD600;
  font-family: "Cormorant Garamond", serif;
  font-size: 48px;
  line-height: .86;
  font-weight: 700;
}

.hero-frame .content {
  padding: 26px
}

.hero-frame .content h5 {
  font-weight: 800;
  margin-bottom: 10px;
  color: #fff
}

.hero-frame .content p {
  margin: 0;
  font-size: 15px;
  color: rgba(255, 255, 255, .80)
}

.floating-badge {
  position: absolute;
  background: #fff;
  color: #11151b;
  border-radius: 20px;
  padding: 18px 20px;
  box-shadow: var(--shadow);
}

.floating-badge h4 {
  margin: 0 0 4px;
  color: #0D1B3E;
  font-size: 30px;
  font-weight: 900;
}

.floating-badge p {
  margin: 0;
  color: #5e6773;
  font-size: 14px;
  line-height: 1.45
}

.floating-badge.one {
  left: -10px;
  bottom: 150px;
  width: 240px
}

.floating-badge.two {
  right: 24px;
  bottom: 20px;
  width: 220px
}

/* ── After hero panel ── */
.after-hero {
  margin-top: -46px;
  position: relative;
  z-index: 5
}

.luxe-panel {
  background: #fff;
  border-radius: 30px;
  box-shadow: var(--soft-shadow);
  padding: 28px 30px;
  border-top: 3px solid #0D1B3E;
}

.trust-item {
  display: flex;
  align-items: center;
  gap: 14px
}

.trust-icon {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, rgba(13, 27, 62, .18), rgba(255, 214, 0, .10));
  color: #0D1B3E;
  font-size: 26px;
}

.trust-item h6 {
  margin: 0;
  font-weight: 900
}

.trust-item p {
  margin: 0;
  color: #6b7480;
  font-size: 14px
}

/* ── Cards ── */
.card-luxe {
  height: 100%;
  background: #fff;
  border: 1px solid #edf1f5;
  border-radius: 26px;
  padding: 30px;
  box-shadow: var(--soft-shadow);
  position: relative;
  overflow: hidden;
  transition: .35s ease;
}

.card-luxe:hover {
  transform: translateY(-6px);
  border-color: rgba(13, 27, 62, .35)
}

.card-luxe::after {
  content: "";
  position: absolute;
  right: -40px;
  top: -40px;
  width: 130px;
  height: 130px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(13, 27, 62, .10), transparent 62%);
}

.icon-luxe {
  width: 64px;
  height: 64px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, rgba(13, 27, 62, .18), rgba(255, 214, 0, .12));
  color: #0D1B3E;
  font-size: 30px;
  margin-bottom: 18px;
}

.card-luxe h5 {
  font-weight: 900
}

.card-luxe p {
  color: #5f6875;
  margin-bottom: 0
}

/* ── Split luxury panel ── */
.split-luxury {
  border-radius: 34px;
  overflow: hidden;
  background: #0D1B3E;
  color: #fff;
  box-shadow: var(--shadow);
}

.split-left {
  padding: 50px
}

.split-right {
  min-height: 100%;
  position: relative;
  padding: 46px;
  background:
    radial-gradient(circle at 78% 20%, rgba(255, 214, 0, .18), transparent 20%),
    linear-gradient(145deg, #FFD600, #F9A825);
}

.split-right::before {
  content: "";
  position: absolute;
  inset: 22px;
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 24px;
}

.stat-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.stat-box {
  background: rgba(13, 27, 62, .15);
  border: 1px solid rgba(13, 27, 62, .20);
  border-radius: 22px;
  padding: 22px;
}

.stat-box h3 {
  font-size: 38px;
  font-weight: 900;
  margin: 0 0 6px;
  color: #0D1B3E;
}

.stat-box p {
  margin: 0;
  color: rgba(13, 27, 62, .85)
}

/* ── Showcase ── */
.showcase {
  border-radius: 34px;
  overflow: hidden;
  background: #0D1B3E;
  color: #fff;
  box-shadow: var(--shadow);
}

.showcase-head {
  padding: 40px 40px 8px
}

.showcase-grid {
  padding: 28px 28px 36px
}

.product-card {
  height: 100%;
  background: rgba(255, 255, 255, .10);
  border: 1px solid rgba(255, 255, 255, .20);
  border-radius: 24px;
  overflow: hidden;
  transition: .35s ease;
  box-shadow: 0 16px 32px rgba(0, 0, 0, .12);
}

.product-card:hover {
  transform: translateY(-6px);
  border-color: rgba(255, 214, 0, .50)
}

.product-visual {
  height: 230px;
  position: relative;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
}

.product-visual::before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 18px;
}

.product-visual::after {
  content: attr(data-title);
  position: absolute;
  left: 22px;
  bottom: 18px;
  color: #FFD600;
  font-family: "Cormorant Garamond", serif;
  font-size: 36px;
  line-height: .9;
  font-weight: 700;
}

.product-body {
  padding: 24px
}

.product-tag {
  display: inline-block;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #0D1B3E;
  background: #FFD600;
  padding: 4px 10px;
  border-radius: 999px;
}

.product-body h5 {
  font-weight: 900;
  margin-top: 12px
}

.product-body p {
  color: rgba(255, 255, 255, .82)
}

/* ── Industry wrap ── */
.industry-wrap {
  background: #fff;
  border-radius: 28px;
  border: 1px solid #edf1f5;
  box-shadow: var(--soft-shadow);
  padding: 36px;
}

.industry-pill {
  background: #eef2ff;
  border: 1px solid rgba(13, 27, 62, .28);
  border-radius: 999px;
  padding: 14px 18px;
  font-weight: 800;
  color: #28303a;
  text-align: center;
  transition: .3s ease;
}

.industry-pill:hover {
  background: #0D1B3E;
  color: #FFD600;
  border-color: #0D1B3E
}

/* ── CTA ── */
.cta-luxe {
  border-radius: 34px;
  overflow: hidden;
  padding: 52px;
  color: #fff;
  box-shadow: var(--shadow);
  background:
    radial-gradient(circle at 14% 20%, rgba(255, 255, 255, .14), transparent 22%),
    radial-gradient(circle at 88% 18%, rgba(255, 214, 0, .20), transparent 18%),
    linear-gradient(130deg, #0D1B3E 0%, #1A2F5E 50%, #06102A 100%);
}

.cta-luxe h2 {
  font-size: clamp(34px, 4vw, 62px);
  line-height: .98;
  margin: 16px 0 14px;
  font-weight: 700;
}

.cta-luxe p {
  color: rgba(255, 255, 255, .88);
  max-width: 760px
}

/* ── Page hero ── */
.page-hero {
  position: relative;
  padding: 200px 0 25px;
  overflow: hidden;
  color: #fff;
  background:
    radial-gradient(circle at 18% 20%, rgba(255, 255, 255, .14), transparent 18%),
    radial-gradient(circle at 84% 18%, rgba(255, 214, 0, .20), transparent 18%),
    linear-gradient(125deg, #0D1B3E 0%, #1A2F5E 52%, #06102A 100%);
}

.page-hero::after {
  content: "";
  position: absolute;
  right: -70px;
  top: -50px;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .10);
}

.page-hero h1 {
  font-size: clamp(44px, 5vw, 74px);
  font-weight: 700;
  margin: -100px 0 10px;
}

.page-hero p {
  max-width: 700px;
  color: rgba(255, 255, 255, .88)
}

.breadcrumb a {
  color: #FFD600
}

.breadcrumb-item.active {
  color: #fff;
  opacity: .75
}

.breadcrumb-item + .breadcrumb-item::before {
    color: #fff !important;
}

/* ── Panel ── */
.panel {
  background: #fff;
  border: 1px solid #edf1f5;
  border-radius: 28px;
  box-shadow: var(--soft-shadow);
  overflow: hidden;
  height: 100%;
}

.panel-pad {
  padding: 30px
}

.timeline {
  position: relative;
  padding-left: 28px
}

.timeline::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 0;
  bottom: 0;
  width: 1.5px;
  background: linear-gradient(180deg, #0D1B3E, #FFD600);
}

.timeline-item {
  position: relative;
  margin-bottom: 24px
}

.timeline-item::before {
  content: "";
  position: absolute;
  left: -28px;
  top: 7px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #0D1B3E;
  box-shadow: 0 0 0 6px rgba(13, 27, 62, .18);
}

.timeline-item h6 {
  font-weight: 900;
  margin-bottom: 6px
}

.timeline-item p {
  margin: 0;
  color: #5f6875
}

/* ── Filter box ── */
.filter-box {
  position: sticky;
  top: 96px
}

.filter-card {
  background: #fff;
  border: 1px solid #edf1f5;
  border-radius: 28px;
  box-shadow: var(--soft-shadow);
  padding: 24px;
}

.filter-card h5 {
  font-weight: 900
}

.form-control,
.form-select {
  border-radius: 16px;
  border: 1px solid #dce3eb;
  padding: 13px 14px;
}

.form-control:focus,
.form-select:focus {
  border-color: #0D1B3E;
  box-shadow: 0 0 0 .18rem rgba(13, 27, 62, .18);
}

.listing-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

/* ── List card ── */
.list-card {
  height: 100%;
  background: #fff;
  border: 1px solid #edf1f5;
  border-radius: 26px;
  overflow: hidden;
  box-shadow: var(--soft-shadow);
  transition: .35s ease;
}

.list-card:hover {
  transform: translateY(-6px);
  border-color: rgba(13, 27, 62, .35)
}

.list-visual {
  height: 240px;
  position: relative;
  background:
    radial-gradient(circle at 78% 20%, rgba(255, 214, 0, .30), transparent 22%),
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, .12), transparent 18%),
    linear-gradient(140deg, #1A2F5E, #0D1B3E);
}

.list-visual::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255, 255, 255, .38);
  border-radius: 18px;
}

.list-visual::after {
  content: attr(data-title);
  position: absolute;
  left: 22px;
  bottom: 18px;
  color: #FFD600;
  font-family: "Cormorant Garamond", serif;
  font-size: 38px;
  font-weight: 700;
  line-height: .92;
}

.ribbon {
  position: absolute;
  top: 16px;
  right: 16px;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  background: #FFD600;
  color: #0D1B3E;
}

.list-body {
  padding: 24px
}

.list-body h5 {
  font-weight: 900
}

.list-body p {
  color: #5c6674
}

/* ── Detail card ── */
.detail-card {
  background: #fff;
  border: 1px solid #edf1f5;
  border-radius: 30px;
  box-shadow: var(--soft-shadow);
  overflow: hidden;
}

.detail-visual {
  min-height: 560px;
  position: relative;
  background:
    radial-gradient(circle at 80% 18%, rgba(255, 214, 0, .35), transparent 22%),
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, .12), transparent 18%),
    linear-gradient(140deg, #1A2F5E, #0D1B3E);
}

.detail-visual::before {
  content: "";
  position: absolute;
  inset: 24px;
  border: 1px solid rgba(255, 255, 255, .38);
  border-radius: 24px;
}

.detail-visual::after {
  content: attr(data-title);
  position: absolute;
  left: 34px;
  bottom: 28px;
  right: 34px;
  color: #FFD600;
  font-family: "Cormorant Garamond", serif;
  font-size: 62px;
  line-height: .88;
  font-weight: 700;
}

.detail-content {
  padding: 34px
}

.detail-content h2 {
  font-weight: 900;
  margin-top: 16px
}

/* ── Mini box / spec ── */
.mini-box {
  background: #fff;
  border: 1px solid #edf1f5;
  border-radius: 22px;
  box-shadow: var(--soft-shadow);
  padding: 22px;
  height: 100%;
}

.mini-box h5 {
  font-weight: 900
}

.mini-box p {
  margin: 0;
  color: #5f6875
}

.spec-wrap {
  border: 1px solid #edf1f5;
  border-radius: 24px;
  overflow: hidden
}

.spec-wrap td {
  padding: 15px 16px
}

.spec-wrap tr:nth-child(odd) {
  background: #eef2ff
}

/* ── Contact ── */
.contact-card {
  background: #fff;
  border: 1px solid #edf1f5;
  border-radius: 26px;
  box-shadow: var(--soft-shadow);
  padding: 28px;
  height: 100%;
}

.contact-card h5 {
  font-weight: 900
}

.map-box {
  min-height: 100%;
  border-radius: 30px;
  padding: 34px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-shadow: var(--shadow);
  background:
    radial-gradient(circle at 20% 18%, rgba(255, 255, 255, .14), transparent 18%),
    radial-gradient(circle at 86% 20%, rgba(255, 214, 0, .20), transparent 18%),
    linear-gradient(130deg, #0D1B3E 0%, #1A2F5E 55%, #06102A 100%);
}

/* ── Footer ── */
.footer {
  margin-top: 80px;
  padding: 82px 0 28px;
  background: #0D1B3E;
  color: rgba(255, 255, 255, .88);
  border-top: 4px solid #FFD600;
}

.footer .brand {
  color: #FFD600;
  font-size: 34px;
  font-weight: 900
}

.footer .brand span {
  color: #fff;
  font-family: "Cormorant Garamond", serif;
  font-weight: 700
}

.footer h5 {
  color: #FFD600;
  font-weight: 900;
  margin-bottom: 18px
}

.footer a {
  display: block;
  color: rgba(255, 255, 255, .80);
  margin-bottom: 10px
}

.footer a:hover {
  color: #FFD600
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, .22);
  padding-top: 22px;
  margin-top: 32px;
  font-size: 14px;
  color: rgba(255, 255, 255, .65);
}

/* ── WhatsApp float ── */
.whatsapp-float {
  position: fixed;
  right: 22px;
  bottom: 22px;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0D1B3E;
  background: #FFD600;
  box-shadow: 0 14px 34px rgba(255, 214, 0, .45);
  z-index: 999;
  transition: .3s ease;
}

.whatsapp-float:hover {
  color: #0D1B3E;
  transform: scale(1.06);
  background: #F9A825
}

/* ── Responsive ── */
@media(max-width:1199px) {
  .hero-frame {
    width: 370px
  }
}

@media(max-width:991px) {
  .hero {
    min-height: auto;
    padding: 130px 0 88px
  }

  .hero::before {
    width: 100%;
    height: 35%;
    right: 0;
    top: auto;
    bottom: 0;
    clip-path: polygon(0 20%, 100% 0, 100% 100%, 0 100%);
  }

  .hero-aside {
    min-height: 520px
  }

  .hero-frame {
    left: 0;
    right: auto;
    max-width: 420px;
    width: 100%
  }

  .floating-badge.one {
    left: 0
  }

  .floating-badge.two {
    right: 0
  }

  .after-hero {
    margin-top: 0;
    padding-top: 26px
  }

  .filter-box {
    position: static
  }
}

@media(max-width:767px) {
  .hero-aside {
    min-height: auto
  }

  .hero-frame {
    position: relative;
    top: 0
  }

  .floating-badge {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: 100% !important;
    margin-top: 18px
  }

  .split-left,
  .split-right,
  .cta-luxe {
    padding: 10px
  }

  .page-hero {
    padding: 190px 0 25px
  }

  .detail-visual {
    min-height: 360px
  }

  .detail-visual::after {
    font-size: 46px
  }
}

/* ── Hero Background Carousel ── */
.hero-text-wrap {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  padding: 100px 44px !important;
  min-height: 480px;
  display: flex;
  align-items: center;
}

.hero-bg-carousel {
  position: absolute;
  inset: 0;
  z-index: 0
}

.hero-bg-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1.2s ease;
  transform: scale(1.04);
}

.hero-bg-slide.active {
  opacity: 1;
  animation: zoomSlide 6s ease forwards;
}

@keyframes zoomSlide {
  from {
    transform: scale(1.04)
  }

  to {
    transform: scale(1.00)
  }
}

.hero-bg-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: inherit;
  background: linear-gradient(120deg,
      rgba(13, 27, 62, .50) 0%,
      rgba(13, 27, 62, .30) 60%,
      rgba(255, 214, 0, .12) 100%);
}

.hero-text-content {
  position: relative;
  z-index: 2;
  width: 100%
}

.hero-text-content h1,
.hero-text-content p,
.hero-text-content .hero-chip {
  text-shadow: 0 2px 18px rgba(0, 0, 0, .45), 0 1px 4px rgba(0, 0, 0, .30);
}

.hero-carousel-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-top: -20px;
  width: 100%;
}

.hero-carousel-dots .dot {
  width: 28px;
  height: 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .35);
  cursor: pointer;
  transition: background .3s ease, width .3s ease;
}

.hero-carousel-dots .dot.active {
  background: #FFD600;
  width: 44px;
}

@media(max-width:767px) {
  .hero-text-wrap {
    padding: 36px 24px;
    min-height: 400px;
    border-radius: 20px
  }
}

/* ── Product Carousel (Dark bg version) ── */
.sp-section {
  position: relative;
  overflow: hidden;
}

.sp-img {
  width: 100%;
  height: 100%;
  object-fit: fill;
  transition: transform .4s ease;
}

.sp-track {
  overflow: hidden;
}

.sp-row {
  display: flex;
  gap: 20px;
  transition: transform 0.46s cubic-bezier(.4, 0, .2, 1);
  will-change: transform;
}

.sp-card {
  flex: 0 0 calc(33.333% - 14px);
  background: rgba(255, 255, 255, .10);
  border: 1px solid rgba(255, 255, 255, .20);
  border-radius: 24px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .32s ease, border-color .32s ease, box-shadow .32s ease;
  box-shadow: 0 16px 36px rgba(0, 0, 0, .14);
}

.sp-card:hover {
  transform: translateY(-7px);
  border-color: rgba(255, 214, 0, .55);
  box-shadow: 0 28px 56px rgba(0, 0, 0, .22);
}

.sp-visual {
  height: 148px;
  position: relative;
  background: linear-gradient(145deg, rgba(255, 214, 0, .40), rgba(249, 168, 37, .55));
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.sp-visual::before {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 14px;
}

.sp-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255, 255, 255, .05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .05) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity: .5;
}

.sp-visual-icon {
  font-size: 46px;
  color: rgba(13, 27, 62, .88);
  position: relative;
  z-index: 2;
  transition: transform .3s ease;
}

.sp-card:hover .sp-visual-icon {
  transform: scale(1.12);
}

.sp-body {
  padding: 20px 22px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.sp-body .product-tag {
  margin-bottom: 10px;
}

.sp-card-name {
  font-family: "Cormorant Garamond", serif;
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  line-height: 1.18;
  margin-bottom: 8px;
  letter-spacing: -.01em;
}

.sp-card-desc {
  font-size: 13.5px;
  color: rgba(255, 255, 255, .78);
  line-height: 1.58;
  margin-bottom: 14px;
  flex: 1;
}

.sp-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 16px;
}

.sp-pill {
  font-size: 10.5px;
  font-weight: 700;
  background: rgba(255, 255, 255, .14);
  border: 1px solid rgba(255, 255, 255, .26);
  border-radius: 999px;
  color: rgba(255, 255, 255, .92);
  padding: 4px 11px;
  letter-spacing: .3px;
}

.sp-pill.sp-pill-hi {
  background: rgba(255, 214, 0, .26);
  border-color: rgba(255, 214, 0, .50);
  color: #FFD600;
}

.sp-actions {
  display: flex;
  gap: 8px;
  margin-top: auto;
}

.sp-btn-quote {
  flex: 1;
  padding: 9px 14px;
  background: #FFD600;
  color: #0D1B3E;
  border: none;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 800;
  cursor: pointer;
  font-family: "Inter", sans-serif;
  letter-spacing: .3px;
  box-shadow: 0 8px 22px rgba(255, 214, 0, .42);
  transition: background .22s ease, transform .2s ease, box-shadow .22s ease;
  text-align: center;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.sp-btn-quote:hover {
  background: #F9A825;
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(249, 168, 37, .45);
  color: #0D1B3E;
}

.sp-btn-detail {
  flex: 1;
  padding: 9px 14px;
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255, 255, 255, .45);
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 800;
  cursor: pointer;
  font-family: "Inter", sans-serif;
  transition: background .22s ease, border-color .22s ease;
  text-align: center;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.sp-btn-detail:hover {
  background: rgba(255, 255, 255, .18);
  border-color: rgba(255, 255, 255, .80);
  color: #fff;
}

.sp-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  margin-top: 32px;
}

.sp-arrow {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, .40);
  background: rgba(255, 255, 255, .14);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 18px;
  transition: background .22s ease, border-color .22s ease, transform .2s ease;
  line-height: 1;
}

.sp-arrow:hover {
  background: rgba(255, 255, 255, .28);
  border-color: #FFD600;
  transform: scale(1.08);
}

.sp-arrow:disabled {
  opacity: .28;
  cursor: default;
  pointer-events: none;
  transform: none;
}

.sp-dots {
  display: flex;
  align-items: center;
  gap: 7px;
}

.sp-dot {
  height: 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .32);
  cursor: pointer;
  transition: width .32s ease, background .32s ease;
  width: 22px;
}

.sp-dot.active {
  background: #FFD600;
  width: 42px;
}

.sp-count {
  font-size: 13px;
  color: rgba(255, 255, 255, .65);
  font-weight: 700;
  min-width: 42px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

@media(max-width:991px) {
  .sp-card {
    flex: 0 0 calc(50% - 10px)
  }
}

@media(max-width:575px) {
  .sp-card {
    flex: 0 0 100%
  }

  .sp-nav {
    gap: 12px
  }

  .sp-arrow {
    width: 38px;
    height: 38px;
    font-size: 16px
  }
}

/* ── Product Carousel (Light/White bg version) ── */
.sp-section.light .sp-card {
  background: #fff;
  border: 1px solid #edf1f5;
  box-shadow: 0 8px 28px rgba(60, 65, 75, .07);
}

.sp-section.light .sp-card:hover {
  border-color: rgba(13, 27, 62, .28);
  box-shadow: 0 20px 48px rgba(60, 65, 75, .13);
}

.sp-section.light .sp-visual {
  height: 220px;
  min-height: 220px;
  max-height: 220px;
  overflow: hidden;
}

.sp-section.light .sp-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #0D1B3E;
  background: rgba(13, 27, 62, .08);
  border: 1px solid rgba(13, 27, 62, .18);
  padding: 4px 11px;
  border-radius: 999px;
  margin-bottom: 10px;
}

.sp-section.light .sp-name {
  font-family: "Cormorant Garamond", serif;
  font-size: 21px;
  font-weight: 700;
  color: #12151a;
  line-height: 1.18;
  margin-bottom: 8px;
}

.sp-section.light .sp-desc {
  font-size: 13.5px;
  color: #5c6674;
  line-height: 1.58;
  margin-bottom: 14px;
  flex: 1;
}

.sp-section.light .sp-pill {
  background: #eef2ff;
  border: 1px solid rgba(13, 27, 62, .20);
  border-radius: 999px;
  color: #28303a;
  padding: 4px 11px;
}

.sp-section.light .sp-pill.sp-hi {
  background: rgba(255, 214, 0, .12);
  border-color: rgba(255, 214, 0, .40);
  color: #7a5f00;
}

.sp-section.light .sp-btn-q {
  flex: 1;
  padding: 9px 14px;
  background: #0D1B3E;
  color: #FFD600;
  border: none;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 800;
  cursor: pointer;
  font-family: "Inter", sans-serif;
  box-shadow: 0 8px 22px rgba(13, 27, 62, .28);
  transition: background .22s ease, transform .2s ease, box-shadow .22s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-decoration: none;
}

.sp-section.light .sp-btn-q:hover {
  background: #06102A;
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(6, 16, 42, .34);
  color: #FFD600;
}

.sp-section.light .sp-btn-d {
  flex: 1;
  padding: 9px 14px;
  background: transparent;
  color: #0D1B3E;
  border: 2px solid #0D1B3E;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 800;
  cursor: pointer;
  font-family: "Inter", sans-serif;
  transition: background .22s ease, color .22s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-decoration: none;
}

.sp-section.light .sp-btn-d:hover {
  background: #0D1B3E;
  color: #FFD600;
}

.sp-section.light .sp-arrow {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 2px solid #0D1B3E;
  background: #fff;
  color: #0D1B3E;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 18px;
  transition: background .22s ease, color .22s ease, transform .2s ease;
  box-shadow: 0 4px 14px rgba(13, 27, 62, .18);
}

.sp-section.light .sp-arrow:hover {
  background: #0D1B3E;
  color: #FFD600;
  transform: scale(1.08);
}

.sp-section.light .sp-dot {
  background: rgba(13, 27, 62, .20);
}

.sp-section.light .sp-dot.active {
  background: #FFD600;
}

.sp-section.light .sp-count {
  color: #5c6674;
}

/* Side-arrow layout */
.sp-outer-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
}

.sp-outer-wrap .sp-track {
  flex: 1;
  overflow: hidden;
}

.sp-arrow-side {
  flex-shrink: 0;
  position: static;
  top: auto;
  transform: none;
}

#spPrev {
  left: auto;
}

#spNext {
  right: auto;
}

.sp-full-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 20px;
  width: 100%;
}

.sp-full-wrap .sp-track {
  flex: 1;
  overflow: hidden;
}

.sp-arrow-side {
  flex-shrink: 0;
}

.sp-section.light .sp-card {
  flex: 0 0 calc(33.333% - 14px);
}

@media(max-width:991px) {
  .sp-section.light .sp-card {
    flex: 0 0 calc(50% - 10px);
  }
}

@media(max-width:575px) {
  .sp-section.light .sp-card {
    flex: 0 0 100%;
  }

  .sp-full-wrap {
    padding: 0 12px;
  }
}

/* ── Quote strip ── */

.quote-strip {
  overflow: hidden;
  background: #0D1B3E;
  padding: 12px 0;
  width: 100%;
}

.quote-scroll {
  display: flex;
  width: max-content;
  animation: scrollLeft 35s linear infinite;
}

.quote-scroll:hover {
  animation-play-state: paused;
}

@keyframes scrollLeft {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

.product-card {
  position: relative;
  width: 200px;
  /* ↑ wider for clearer image */
  height: 130px;
  /* ↑ taller */
  margin: 0 10px;
  border-radius: 10px;
  overflow: hidden;
  flex-shrink: 0;
  cursor: pointer;
}

.product-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  filter: brightness(0.99);
  /* ↑ was 0.42 — much clearer now */
  transition: filter 0.3s ease;
}

.product-card:hover img {
  filter: brightness(0.99);
  /* darkens slightly on hover */
}

/* Dark gradient overlay — image stays visible, text stays readable */
.product-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,
      rgba(0, 0, 0, 0.65) 0%,
      rgba(0, 0, 0, 0.15) 50%,
      rgba(0, 0, 0, 0) 100%);
  border-radius: 10px;
  pointer-events: none;
}

.product-card .label {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  /* text sits at bottom */
  padding: 10px 8px;
  z-index: 1;
}

.product-card .label span {
  font-size: 12.5px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.35;
  text-align: center;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.95);
  letter-spacing: 0.3px;
}

.fp-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #e8e8e8;
    transition: box-shadow 0.25s, transform 0.25s;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.fp-card:hover {
    box-shadow: 0 8px 32px rgba(13,27,62,0.13);
    transform: translateY(-4px);
}
.fp-card-img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    display: block;
}
.fp-card-body {
    padding: 18px 20px 20px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.fp-card-tag {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #FFD600;
    background: #0D1B3E;
    display: inline-block;
    padding: 3px 10px;
    border-radius: 3px;
    margin-bottom: 10px;
}
.fp-card-name {
    font-size: 15px;
    font-weight: 700;
    color: #0D1B3E;
    margin-bottom: 8px;
}
.fp-card-desc {
    font-size: 0.85rem;
    color: #666;
    flex: 1;
    margin-bottom: 14px;
}
.fp-card-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 16px;
}
.fp-pill {
    font-size: 9px;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 20px;
    background: #f0f2f7;
    color: #0D1B3E;
}
.fp-pill-hi {
    background: #fff8d6;
    color: #b8860b;
}
.fp-store-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 20px;
    background: #0D1B3E;
    color: #FFD600;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-decoration: none;
    border-radius: 5px;
    transition: background 0.2s, color 0.2s;
    align-self: flex-start;
}
.fp-store-btn:hover {
    background: #FFD600;
    color: #0D1B3E;
}

.featured-scroll-wrap{
    overflow:hidden;
    width:100%;
    position:relative;
}

.featured-scroll{
    display:flex;
    gap:24px;
    width:max-content;
    animation:featuredScroll 50s linear infinite;
}

.featured-scroll:hover{
    animation-play-state:paused;
}

@keyframes featuredScroll{
    from{
        transform:translateX(0);
    }
    to{
        transform:translateX(-50%);
    }
}

.featured-item{
    width:300px;
    flex-shrink:0;
}

