@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&display=swap');

/* styles.css (UPDATED: Omega-style header + video hero) */
:root{
  --bg: #05070d;
  --bg2:#0b111a;

  --panel: rgba(255,255,255,0.05);
  --stroke: rgba(255,255,255,0.10);

  /* Industrial accents: warn amber + steel blue */
  --brass: #d9a43d;   /* safety amber */
  --brass2:#6ea3c9;   /* steel blue */
  --ink:#f0f2f6;
  --muted: rgba(240,242,246,0.70);

  --shadow: 0 18px 55px rgba(0,0,0,0.70);
  --radius2: 28px;
  --max: 1160px;

  /* Header scroll-state: solid charcoal */
  --navSolidBg: rgba(15,18,26,0.96);
  --navSolidText: rgba(240,242,246,0.96);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--ink);
  /* Premium solid charcoal to avoid banding/intersections */
  background: #0a0c12;
  overflow-x:hidden;
}

html{
  scroll-behavior: smooth;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }

.bg{ position:fixed; inset:0; pointer-events:none; z-index:-2; }
.bg__grid{
  position:absolute; inset:-2px;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 68px 68px;
  opacity:0.25;
  mask-image: radial-gradient(circle at 30% 10%, #000 45%, transparent 70%);
}
.bg__glow{
  position:absolute; width:680px; height:680px; border-radius:50%;
  filter: blur(60px);
  opacity:0.30;
}
.bg__glow--a{ left:-120px; top:-160px; background: rgba(217,164,61,0.40); }
.bg__glow--b{ right:-160px; top:-80px; background: rgba(110,163,201,0.28); }
.bg__noise{
  position:absolute; inset:0;
  background-image: url("https://grainy-gradients.vercel.app/noise.svg");
  opacity:0.08;
  mix-blend-mode: overlay;
}

.motifs{ position:fixed; inset:0; pointer-events:none; z-index:-1; }
.motif{
  position:absolute;
  width:68px; height:68px;
  border-radius: 18px;
  display:grid; place-items:center;
  background: rgba(0,0,0,0.22);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 16px 50px rgba(0,0,0,0.55);
  backdrop-filter: blur(10px);
}
.motif img{
  width: 56px;
  height: auto;
  object-fit: contain;
  opacity: 0.94;
}
.motif--logoA{ left:8%; top:22%; transform: rotate(-6deg); }
.motif--logoB{ right:8%; top:18%; transform: rotate(8deg); }

/* ===== OMEGA-STYLE HEADER (NEW) ===== */
.luxHeader{
  position: fixed;
  top: 33px; left: 0; right: 0;
  z-index: 1001;
  padding: 14px 18px;
  transition: background .22s ease, border-color .22s ease, color .22s ease, backdrop-filter .22s ease;
  background: transparent;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.luxHeader__inner{
  width: min(var(--max), 100%);
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
}
.luxBrand{
  display:flex; align-items:center; gap:12px;
  font-weight:600;
  font-size: 12px;
  letter-spacing: 0.18em;
  min-height: 52px;
}
.luxBrand__logo{
  height: 48px;
  width: auto;
  display:block;
  filter: drop-shadow(0 10px 28px rgba(0,0,0,0.45));
}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.luxBrand__text{ opacity:0.92; }

/* ===== STAR EXPORT HOUSE TOP BAR ===== */
.topBar{
  width: 100%;
  background: #0d0f14;
  border-bottom: 1px solid rgba(201,168,76,0.18);
  padding: 6px 20px;
  text-align: center;
  z-index: 1002;
  position: fixed;
  top: 0; left: 0; right: 0;
}
.topBar__inner{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.45);
  font-family: 'Inter', sans-serif;
}
.topBar__inner strong{
  color: #c9a84c;
  font-weight: 600;
}
.topBar__inner i{
  font-size: 8px;
  color: #c9a84c;
}
@media(max-width:600px){
  .topBar{ padding: 5px 12px; }
  .topBar__inner{ font-size: 9.5px; letter-spacing:0.03em; }
  .luxHeader{ top: 31px; }
}

.luxHeader{ --navLinkBg: rgba(255,255,255,0.08); --navLinkStroke: rgba(255,255,255,0.20); --navLinkGlow: rgba(200,162,74,0.85); }

.luxNav{
  display:flex; gap: 18px; align-items:center;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.luxNav a{
  position: relative;
  isolation: isolate;
  display:inline-flex;
  align-items:center;
  gap:6px;
  opacity:0.88;
  padding: 10px 12px;
  border-radius: 14px;
  overflow:hidden;
  transition: opacity .25s var(--easeOut2), transform .35s var(--easeOut2), letter-spacing .3s var(--easeOut2);
  backdrop-filter: blur(6px);
}

/* Glassy halo behind nav items */
.luxNav a::before{
  content:"";
  position:absolute;
  inset:-4px;
  border-radius: 16px;
  background: radial-gradient(140% 120% at 20% 20%, rgba(255,255,255,0.16), transparent 55%),
              linear-gradient(120deg, transparent, var(--navLinkGlow), rgba(255,255,255,0.28), transparent);
  background-size: 160% 160%;
  opacity: 0;
  transform: translateY(6px) scale(0.9);
  filter: blur(10px);
  transition: opacity .38s var(--easeOut2), transform .5s var(--easeOut2);
  z-index: -1;
}

.luxNav a::after{
  content:"";
  position:absolute;
  left: 16px; right: 16px; bottom: 6px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--navLinkGlow), transparent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .45s var(--easeOut2);
  opacity: .95;
  box-shadow: 0 0 22px rgba(200,162,74,0.45);
}

.luxNav a:hover{
  opacity:1;
  transform: translateY(-2px) scale(1.02);
  letter-spacing: 0.24em;
  text-shadow: 0 6px 24px rgba(0,0,0,0.32), 0 0 18px rgba(200,162,74,0.55);
}
.luxNav a:hover::before{
  opacity: 0.9;
  transform: translateY(0) scale(1);
  animation: navShine 1.8s linear infinite;
}
.luxNav a:hover::after{
  transform: scaleX(1);
}

/* ── NAV DROPDOWN ─────────────────────────────────────────── */
.luxNav__drop { position: relative; }

.luxNav__caret {
  font-size: 7px;
  margin-left: 2px;
  opacity: 0.50;
  vertical-align: middle;
  transition: transform 0.22s, opacity 0.22s;
}
.luxNav__drop:hover .luxNav__caret,
.luxNav__drop:focus-within .luxNav__caret {
  transform: rotate(180deg);
  opacity: 0.90;
}

.luxNav__menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 188px;
  background: rgba(5, 8, 16, 0.97);
  border: 1px solid rgba(201,168,76,0.22);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  box-shadow: 0 18px 48px rgba(0,0,0,0.60), 0 0 0 1px rgba(255,255,255,0.04);
  padding: 6px 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.20s, transform 0.20s;
  z-index: 300;
}
.luxNav__drop:hover .luxNav__menu,
.luxNav__drop:focus-within .luxNav__menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.luxNav__menu a {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 12px 20px !important;
  font-size: 10px !important;
  letter-spacing: 0.15em !important;
  color: rgba(230,234,240,0.65) !important;
  border-radius: 0 !important;
  background: transparent !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
  transition: color 0.18s, background 0.18s !important;
  white-space: nowrap;
  overflow: hidden;
}
.luxNav__menu a:last-child { border-bottom: none !important; }
.luxNav__menu a:hover {
  color: var(--brass2) !important;
  background: rgba(201,168,76,0.07) !important;
  opacity: 1 !important;
  transform: none !important;
  letter-spacing: 0.19em !important;
  text-shadow: none !important;
}
.luxNav__menu a::before,
.luxNav__menu a::after { display: none !important; }
.luxNav__menu a i {
  font-size: 12px;
  color: var(--brass2);
  opacity: 0.70;
  width: 16px;
  text-align: center;
  flex-shrink: 0;
}

/* Mobile sub-links under Submersible */
.luxMobile__subLink {
  padding-left: 32px !important;
  font-size: 11px !important;
  opacity: 0.80;
  background: rgba(255,255,255,0.03) !important;
  display: flex;
  align-items: center;
  gap: 8px;
}
.luxMobile__subLink i {
  font-size: 11px;
  color: var(--brass2);
  opacity: 0.70;
  width: 14px;
  text-align: center;
}

.luxQuoteBtn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 11px 18px;
  border-radius: 8px;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight:800;
  border: 1px solid rgba(255,255,255,0.20);
  background: rgba(10,14,22,0.22);
  backdrop-filter: blur(10px);
  transition: background .25s ease, border-color .25s ease, color .25s ease, transform .25s ease;
}
.luxQuoteBtn i{ color: var(--brass2); }
/* ── Arabic RTL ── */
.lang-ar{
  direction: rtl;
  font-family: 'Noto Sans Arabic', Inter, system-ui, sans-serif;
}
.lang-ar .section__head,
.lang-ar .videoHero__content,
.lang-ar .factoryCine__inner,
.lang-ar .upkargpt__cta,
.lang-ar .cta__left{
  text-align: right;
}
.lang-ar .luxNav{ flex-direction: row-reverse; }
.lang-ar .luxHeader__inner{ flex-direction: row-reverse; }
.lang-ar .luxNav a::after{ left: 8px; right: 8px; }

/* ── Japanese ── */
.lang-ja{
  font-family: 'Noto Sans JP', Inter, system-ui, sans-serif;
}
.lang-ja .section__title,
.lang-ja .showCard__name,
.lang-ja .statItem__number,
.lang-ja .cta__title{
  font-family: 'Noto Sans JP', sans-serif;
  letter-spacing: 0.02em;
}
.lang-ja .section__eyebrow{
  letter-spacing: 0.12em;
}
.lang-ja .section__head,
.lang-ja .videoHero__content,
.lang-ja .factoryCine__inner,
.lang-ja .upkargpt__cta,
.lang-ja .cta__left{
  text-align: left;
}

.luxBurger{
  display:none;
  width:44px; height:40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.22);
  background: rgba(10,14,22,0.20);
  color: var(--ink);
  backdrop-filter: blur(10px);
}
.luxBurger span{
  display:block; width:18px; height:2px; margin:6px auto;
  background: rgba(234,239,247,0.88);
  border-radius:10px;
}

.luxMobile{
  width: min(var(--max), 100%);
  margin: 10px auto 0;
  display:none;
  flex-direction:column;
  gap: 8px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(10,14,22,0.72);
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(14px);
}
.luxMobile a{
  padding: 12px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,0.06);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 12px;
}
.luxMobile__cta{
  background: rgba(200,162,74,0.12) !important;
  border: 1px solid rgba(200,162,74,0.18);
}

/* scrolled state: solid + black text */
.luxHeader.is-scrolled{
  background: var(--navSolidBg);
  border-bottom-color: rgba(255,255,255,0.04);
  backdrop-filter: blur(10px);
  --navLinkGlow: rgba(217,164,61,0.75);
}
.luxHeader.is-scrolled .luxBrand__text,
.luxHeader.is-scrolled .luxNav,
.luxHeader.is-scrolled .luxNav a,
.luxHeader.is-scrolled .luxQuoteBtn{
  color: var(--navSolidText);
}
.luxHeader.is-scrolled .luxBrand__logo{
  filter: drop-shadow(0 10px 22px rgba(0,0,0,0.35));
}
.luxHeader.is-scrolled .luxNav a:hover{
  background: rgba(0,0,0,0.06);
}
.luxHeader.is-scrolled .luxQuoteBtn{
  background: rgba(217,164,61,0.92);
  border-color: rgba(217,164,61,0.95);
  color: #05070d;
}
.luxHeader.is-scrolled .luxQuoteBtn i{
  color: #05070d;
}
.luxHeader.is-scrolled .luxQuoteBtn:hover{
  background: rgba(217,164,61,1.0);
  border-color: rgba(217,164,61,1.0);
  transform: translateY(-1px);
}
.luxHeader.is-scrolled .luxBurger{
  background: rgba(255,255,255,0.55);
  border-color: rgba(0,0,0,0.10);
}
.luxHeader.is-scrolled .luxBurger span{
  background: rgba(10,12,16,0.70);
}

/* ===== VIDEO HERO (NEW) ===== */
.videoHero{
  position: relative;
  height: 100vh;
  min-height: 640px;
  overflow: hidden;
}
.videoHero__video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover;
  transform: scale(1.02);
  filter: contrast(1.05) saturate(1.02);
}
.videoHero__overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.55), rgba(0,0,0,0.25) 50%, rgba(0,0,0,0.70));
}
.videoHero__content{
  position: relative;
  height: 100%;
  width: min(var(--max), 100%);
  margin: 0 auto;
  padding: 0 18px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  gap: 12px;
}
.videoHero__eyebrow{
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  opacity: 0.88;
}
.videoHero__title{
  margin: 0;
  font-family: Oswald, Inter, sans-serif;
  font-size: clamp(46px, 6vw, 92px);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 0.95;
  background: linear-gradient(90deg, rgba(255,255,255,0.95), rgba(200,162,74,0.95));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}
.videoHero__sub{
  margin: 0;
  font-size: 15px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(234,239,247,0.82);
}
.typingLine{
  font-size: 15px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: 0.92;
}
.typingLine #exportingText{ color: var(--brass); }
.typingCursor{
  display:inline-block;
  width: 10px;
  margin-left: 4px;
  animation: blink 1s steps(1) infinite;
}
@keyframes blink{
  0%,50%{ opacity:1; }
  50.01%,100%{ opacity:0; }
}
.videoHero__actions{
  margin-top: 28px;
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content:center;
}
.videoHero__scroll{
  position:absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
}
.scrollPill{
  display:inline-flex; align-items:center; gap:10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(10,14,22,0.22);
  backdrop-filter: blur(10px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 11px;
  opacity: 0.9;
}

/* ===== existing styles (kept) ===== */
.page{ width:min(var(--max), 100%); margin:0 auto; padding: 24px 28px 0; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border-radius: 10px;
  padding: 13px 22px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  border: 1px solid rgba(255,255,255,0.10);
  transition: transform .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease;
  will-change: transform;
  text-transform: uppercase;
}
.btn--primary{
  background: linear-gradient(135deg, rgba(217,164,61,1.0) 0%, rgba(201,155,52,0.97) 55%, rgba(110,163,201,0.90) 100%);
  border-color: rgba(217,164,61,0.45);
  color: rgba(9,11,15,0.96);
  box-shadow: 0 8px 28px rgba(217,164,61,0.28), 0 2px 8px rgba(0,0,0,0.24);
}
.btn--primary:hover{ transform: translateY(-2px); box-shadow: 0 14px 38px rgba(217,164,61,0.36), 0 4px 12px rgba(0,0,0,0.28); }
.btn--ghost{
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
}
.btn--ghost:hover{ transform: translateY(-2px); background: rgba(255,255,255,0.10); border-color: rgba(255,255,255,0.18); }

.marquee{
  margin: 36px 0 48px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  overflow:hidden;
}
.marquee__track{ white-space: nowrap; overflow:hidden; }
.marquee__text{
  display:inline-block;
  padding: 16px 0;
  font-family: Oswald, Inter, sans-serif;
  font-size: clamp(20px, 2.4vw, 34px);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: transparent;
  -webkit-text-stroke: 1px rgba(246,248,251,0.32);
  text-stroke: 1px rgba(246,248,251,0.32);
  opacity:0.95;
}

.section{ padding: 72px 0; }
.section, .factoryCine, #hero, #catalog, #upkargpt, #quote{
  scroll-margin-top: 110px;
}
.section--alt{
  border-radius: var(--radius2);
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  padding: 64px 40px;
}
#powerFinder {
  margin-top: 72px;
}
#quality.section--alt{
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  border-radius: 0;
  padding: 72px 32px 80px;
}
.section__head{ margin-bottom: 48px; }
.section__eyebrow{
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--brass);
  opacity: 0.80;
  margin-bottom: 14px;
}
.section__title{
  font-family: Oswald, Inter, sans-serif;
  font-size: clamp(34px, 4vw, 54px);
  letter-spacing: -0.01em;
  font-weight: 600;
  margin: 0;
  line-height: 1.05;
}
.section__desc{
  margin: 14px 0 0;
  color: rgba(240,242,246,0.62);
  max-width: 60ch;
  line-height: 1.85;
  font-size: 15px;
  letter-spacing: 0.01em;
}

.cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.card{
  border-radius: var(--radius2);
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.10);
  padding: 16px;
  box-shadow: 0 18px 55px rgba(0,0,0,0.35);
  transform-style: preserve-3d;
}
.card__top{ display:flex; gap:8px; align-items:center; }
.tag{
  display:inline-flex; align-items:center; gap:8px;
  font-size: 11px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: rgba(234,239,247,0.75);
  letter-spacing: 0.04em;
}
.tag--muted{ background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.10); opacity:0.85; }
.card h3{ font-family: Oswald, Inter, sans-serif; margin: 12px 0 6px; font-size: 26px; }
.card p{ margin:0; color: var(--muted); line-height:1.7; font-size: 14px; }
.card__img{ margin-top: 14px; border-radius: 22px; overflow:hidden; border: 1px solid rgba(255,255,255,0.10); }
.card__img img{ height: 220px; width:100%; object-fit: cover; transform: scale(1.02); transition: transform .5s ease; }
.card:hover .card__img img{ transform: scale(1.06); }
.card__link{ display:inline-flex; align-items:center; gap:10px; margin-top: 12px; font-weight:600; opacity:0.90; }
.card__link i{ color: var(--brass); }

.qualityGrid{ display:grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 14px; }
.panel{
  border-radius: var(--radius2);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  padding: 18px;
  box-shadow: 0 18px 55px rgba(0,0,0,0.25);
}
.panel__icon{
  width:44px; height:44px; border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--brass2);
}
.panel h3{ font-family: Oswald, Inter, sans-serif; margin: 12px 0 6px; font-size: 24px; }
.panel p{ margin:0; color: var(--muted); line-height:1.7; font-size:14px; }
.certRow{ display:flex; gap:10px; margin-top: 14px; }
.cert{
  flex:1; height: 58px; border-radius: 18px;
  border: 1px dashed rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.03);
  display:grid; place-items:center;
  color: rgba(234,239,247,0.75);
  font-weight:700;
  letter-spacing:0.12em;
}

/* Certificates full-width slider */
.certSlider{
  position: relative;
  width: 100%;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(10,12,18,0.65);
  box-shadow: 0 18px 50px rgba(0,0,0,0.42);
  padding: 12px 64px;
  overflow:hidden;
  margin-top: 10px;
}
.certSlider__viewport{
  overflow: hidden;
  touch-action: pan-y;
}
.certSlider__track{
  display: flex;
  gap: 10px;
  transition: transform .45s var(--easeOut2);
  will-change: transform;
}
.certSlide{
  min-width: 100%;
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.4);
  box-shadow: 0 10px 28px rgba(0,0,0,0.32);
}
.certSlider--sliding .certSlide img{
  filter: blur(3px);
  transition: filter .25s ease;
}
.certSlide img{
  width:100%;
  height: 360px;
  object-fit: contain;
  display:block;
  background: #0d1118;
}
.certSlider__arrow{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.08);
  color: var(--ink);
  display:grid; place-items:center;
  cursor:pointer;
  transition: transform .2s var(--easeOut2), background .2s var(--easeOut2);
  z-index: 3;
}
.certSlider__arrow:hover{ transform: translateY(-50%) scale(1.04); background: rgba(255,255,255,0.14); }
.certSlider__arrow--prev{ left: 10px; }
.certSlider__arrow--next{ right: 10px; }
.certSlider__pause{
  position:absolute;
  top: 12px; right: 18px;
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.10);
  color: var(--ink);
  display:grid; place-items:center;
  cursor:pointer;
  transition: transform .2s var(--easeOut2), background .2s var(--easeOut2);
  z-index:2;
}
.certSlider__pause:hover{ transform: scale(1.06); background: rgba(255,255,255,0.16); }

.factoryCine{
  position: relative;
  margin: 0;
  width: 100vw;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  border-radius: 0;
  overflow: hidden;
  min-height: 100vh;
  border: none;
  box-shadow: none;
  display:flex;
  align-items:center;
  justify-content:center;
}
.factoryCine__video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover;
  filter: contrast(1.05) saturate(1.05);
  transform: scale(1.02);
}
.factoryCine__overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.62), rgba(0,0,0,0.18) 45%, rgba(0,0,0,0.78)),
    radial-gradient(120% 90% at 20% 20%, rgba(217,164,61,0.22), transparent 60%),
    radial-gradient(140% 110% at 82% 12%, rgba(110,163,201,0.18), transparent 58%);
}
.factoryCine__inner{
  position: relative;
  height: 100%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap: 14px;
  width: min(var(--max), 100%);
  margin: 0 auto;
  padding: 96px 40px 100px;
  text-align: center;
}
.factoryCine__eyebrow{
  font-size: 12px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  opacity: 0.9;
}
.factoryCine__title{
  margin:0;
  font-family: Oswald, Inter, sans-serif;
  font-size: clamp(40px, 5vw, 82px);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: linear-gradient(90deg, rgba(255,255,255,0.95), rgba(200,162,74,0.95));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}
.factoryCine__desc{
  margin: 6px 0 0;
  max-width: 62ch;
  color: rgba(234,239,247,0.82);
  line-height:1.8;
}
.factoryCine__actions{
  display:flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 28px;
  justify-content:center;
}

.upkargpt{
  display:grid;
  grid-template-columns: 1.2fr 0.9fr;
  gap: 14px;
  align-items: stretch;
}
.upkargpt__card, .upkargpt__panel{
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,0.10);
  background: linear-gradient(160deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
  box-shadow: 0 18px 55px rgba(0,0,0,0.35);
  padding: 18px;
}
.upkargpt__badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(217,164,61,0.12);
  border: 1px solid rgba(217,164,61,0.22);
  font-size: 12px;
  letter-spacing:0.04em;
  text-transform: uppercase;
}
.upkargpt__card h3{
  margin: 12px 0 8px;
  font-family: Oswald, Inter, sans-serif;
  font-size: 26px;
}
.upkargpt__card ul{
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.7;
  display:grid;
  gap: 6px;
}
.upkargpt__panel{
  position: relative;
  overflow:hidden;
  background: radial-gradient(480px 280px at 80% 0%, rgba(110,163,201,0.18), transparent 60%),
              linear-gradient(180deg, rgba(15,18,26,0.82), rgba(10,12,18,0.92));
  border-color: rgba(110,163,201,0.22);
}
.upkargpt__panel::after{
  content:\"\"; position:absolute; inset:-20%; background: radial-gradient(520px 320px at 20% 20%, rgba(217,164,61,0.22), transparent 60%); pointer-events:none; filter: blur(4px);
}
.upkargpt__cta{
  position: relative;
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.upkargpt__eyebrow{
  margin:0;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(240,242,246,0.82);
}
.upkargpt__cta h3{
  margin: 0;
  font-family: Oswald, Inter, sans-serif;
  font-size: 30px;
}
.upkargpt__cta p{
  margin:0;
  color: var(--muted);
  line-height:1.7;
}
.upkargpt__actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
}

/* FAQ Preview (replaces UpkarGPT section on index) */
.faqPreview{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
  margin-bottom: 32px;
}
.faqPreview__item{
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 20px;
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(160deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  transition: border-color 0.2s, background 0.2s;
}
.faqPreview__item:hover{
  border-color: rgba(255,107,0,0.28);
  background: linear-gradient(160deg, rgba(255,107,0,0.06), rgba(255,255,255,0.02));
}
.faqPreview__icon{
  flex-shrink: 0;
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 8px;
  background: rgba(255,107,0,0.12);
  border: 1px solid rgba(255,107,0,0.20);
  color: var(--accent);
  font-size: 15px;
}
.faqPreview__body{ flex: 1; }
.faqPreview__q{
  margin: 0 0 6px;
  font-family: Oswald, Inter, sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: rgba(240,242,246,0.92);
  line-height: 1.35;
}
.faqPreview__a{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--muted);
}
.faqPreview__footer{
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.faqPreview__count{
  margin: 0;
  font-size: 12.5px;
  color: var(--muted);
  letter-spacing: 0.02em;
}

.input{
  width:100%;
  padding: 13px 16px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.05);
  color: var(--ink);
  outline:none;
  font-size: 14px;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.input:focus{
  border-color: rgba(201,168,76,0.48);
  box-shadow: 0 0 0 3px rgba(201,168,76,0.09);
}
.input::placeholder{ color: rgba(234,239,247,0.38); }

/* ============================================================
   CONTACT / QUOTE SECTION — PREMIUM REDESIGN
   ============================================================ */
.cta{
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0;
  align-items: stretch;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 32px 80px rgba(0,0,0,0.45);
}

/* ── Left info panel ── */
.cta__left{
  padding: 48px 44px;
  background: linear-gradient(145deg, rgba(18,22,34,0.98), rgba(10,13,20,0.99));
  border-right: 1px solid rgba(255,255,255,0.06);
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  overflow: hidden;
}
.cta__left::before{
  content: "";
  position: absolute;
  top: -60px; left: -60px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,168,76,0.08), transparent 70%);
  pointer-events: none;
}
.cta__title{
  font-family: Oswald, Inter, sans-serif;
  font-size: clamp(36px, 4vw, 52px);
  letter-spacing: 0.02em;
  margin: 0 0 12px;
  text-transform: uppercase;
  line-height: 1.05;
  color: var(--ink);
}
.cta__title span{ color: #c9a84c; }
.cta__desc{
  margin: 0 0 36px;
  color: rgba(240,242,246,0.58);
  line-height: 1.80;
  font-size: 14px;
  max-width: 38ch;
}

/* Contact methods */
.contactInfo{ display: flex; flex-direction: column; gap: 10px; margin-bottom: 36px; }
.contactInfo__method{
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  text-decoration: none;
  color: var(--ink);
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.contactInfo__method:hover{
  background: rgba(201,168,76,0.07);
  border-color: rgba(201,168,76,0.22);
  transform: translateX(3px);
}
.contactInfo__icon{
  width: 38px; height: 38px;
  border-radius: 10px;
  background: rgba(201,168,76,0.10);
  border: 1px solid rgba(201,168,76,0.18);
  display: grid; place-items: center;
  flex-shrink: 0;
  font-size: 14px;
  color: #c9a84c;
}
.contactInfo__detail{ display: flex; flex-direction: column; gap: 2px; }
.contactInfo__label{
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(240,242,246,0.38);
}
.contactInfo__value{
  font-size: 13px;
  font-weight: 500;
  color: rgba(240,242,246,0.85);
}

/* Address block */
.contactInfo__address{
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  color: var(--ink);
}

/* Trust badges */
.contactTrust{
  margin-top: auto;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.07);
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
}
.contactTrust__badge{
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(240,242,246,0.40);
}
.contactTrust__badge i{ color: rgba(201,168,76,0.55); font-size: 11px; }

/* ── Right form panel ── */
.cta__form{
  padding: 48px 44px;
  background: rgba(255,255,255,0.025);
  position: relative;
  overflow: hidden;
}
.cta__form::before{
  content: "";
  position: absolute;
  bottom: -80px; right: -80px;
  width: 360px; height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(110,163,201,0.06), transparent 70%);
  pointer-events: none;
}
.cta__form__title{
  font-family: Oswald, Inter, sans-serif;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(240,242,246,0.70);
  margin: 0 0 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.grid{ display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.field{
  display: flex;
  flex-direction: column;
  gap: 7px;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(240,242,246,0.50);
}
.field--full{ grid-column: 1 / -1; }
.cta__form .input{ margin: 0; font-size: 14px; letter-spacing: 0; text-transform: none; font-weight: 400; }
.cta__form textarea{ resize: none; min-height: 110px; }
.cta__footer{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 24px;
  flex-wrap: wrap;
}
.cta__form .btn--submit{
  padding: 15px 36px;
  font-size: 12px;
  letter-spacing: 0.14em;
  background: linear-gradient(135deg, rgba(217,164,61,1.0) 0%, rgba(201,155,52,0.97) 55%, rgba(110,163,201,0.90) 100%);
  border-color: rgba(217,164,61,0.45);
  color: #05070d;
  font-weight: 700;
}
.cta__form .btn--submit:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 38px rgba(217,164,61,0.36);
}
.fineprint{
  font-size: 11.5px;
  color: rgba(240,242,246,0.38);
  line-height: 1.6;
  display: flex;
  align-items: center;
  gap: 6px;
}
.fineprint i{ color: rgba(201,168,76,0.55); font-size: 12px; }

/* Legacy .chip kept for any non-contact usage */
.chip{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.10);
  font-size: 13px;
  color: var(--ink);
  transition: transform .25s var(--easeOut2), border-color .25s var(--easeOut2), background .25s var(--easeOut2);
}
.chip i{ color: rgba(240,242,246,0.45); }
.chip:hover{ transform: translateY(-1px); border-color: rgba(217,164,61,0.28); }

.footer{
  margin: 36px 0 0;
  position: relative;
  left: 50%;
  right: 50%;
  width: 100vw;
  margin-left: -50vw;
  margin-right: -50vw;
  background: #0b0d12;
  border-top: 1px solid rgba(201,168,76,0.20);
  padding: 28px 32px 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  border-radius: 0;
  box-shadow: none;
}
.footer__left{
  display:flex;
  align-items:center;
  gap: 12px;
}
.footer__logo{
  height: 60px;
  width:auto;
  display:block;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,0.45));
}
.footer__copy{
  margin: 0;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #f2f4f6;
}
.footer p{
  margin:4px 0 0;
  color: rgba(240,242,246,0.64);
}
.footer__right a{
  opacity:0.85;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid #b12222;
  background: rgba(177,34,34,0.12);
  color: var(--ink);
  transition: transform .2s var(--easeOut2), opacity .2s var(--easeOut2), border-color .2s var(--easeOut2);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 44px;
  font-size: 16px;
}
.footer__right a:hover{
  opacity:1;
  transform: translateY(-1px);
  border-color: #e33939;
}

.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal.is-visible{
  opacity: 1;
  transform: none;
}

/* Responsive */
@media (max-width: 980px){
  .luxNav, .luxQuoteBtn{ display:none; }
  .luxBurger{ display:block; }

  .cards{ grid-template-columns: 1fr; }
  .qualityGrid{ grid-template-columns: 1fr; }
  .upkargpt{ grid-template-columns: 1fr; }
  .cta{ grid-template-columns: 1fr; border-radius: 16px; }
  .cta__left{ padding: 36px 28px; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.06); }
  .cta__form{ padding: 36px 28px; }
  .grid{ grid-template-columns: 1fr; }
  .pumpsGrid{ grid-template-columns: 1fr; }
  .certSlider{
    padding: 12px 46px;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
  .certSlide img{ height: 280px; }
  .mediaStrip{ grid-template-columns: 1fr; }
  .videoHero{ min-height: 620px; }
  .factoryCine{
    margin: 0;
    border-radius: 0;
    min-height: 80vh;
    left: 0;
    right: 0;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    align-items: center;
  }
  .factoryCine__inner{
    padding: 40px 18px 44px;
    align-items: center;
  }
  .footer{
    flex-direction: column;
    align-items: flex-start;
    padding: 20px 18px;
    left: 50%;
    right: 50%;
    width: 100vw;
    margin-left: -50vw;
    margin-right: -50vw;
  }
  #quality.section--alt{
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    padding: 28px 18px 30px;
  }
}

/* Mid screens */
@media (max-width: 720px){
  .luxHeader{ padding: 12px 14px; }
  .luxHeader__inner{ padding: 0 2px; }
  .videoHero__title{ font-size: clamp(36px, 9vw, 62px); }
  .videoHero__sub{ font-size: 13px; letter-spacing: 0.10em; }
  .videoHero__actions{ gap: 10px; }
  .videoHero__actions .btn{ width: 100%; justify-content: center; }
  .section{ padding: 28px 0; }
  .page{ padding: 14px 14px 32px; }
  .factoryCine__inner{ padding: 28px 16px 32px; }
  .upkargpt__card ul{ grid-template-columns: 1fr; }
  .upkargpt__panel{ padding: 16px; }
  .cta__form{ padding: 16px; }
}

/* Small screens */
@media (max-width: 540px){
  .luxHeader__inner{ gap: 10px; }
  .luxBrand__logo{ height: 40px; }
  .luxBurger{ width:40px; height:38px; }
  .videoHero{ min-height: 520px; }
  .factoryCine{ min-height: 70vh; }
  .certSlider{
    padding: 10px 40px;
  }
  .certSlide img{ height: 220px; }
  .footer{ padding: 18px 14px; }
}
/* ===== PREMIUM HOVER UPGRADE ===== */
:root{
  --easeOut: cubic-bezier(.2,.8,.2,1);
  --easeOut2: cubic-bezier(.16,1,.3,1);
}

/* Smooth hardware hints */
.card, .btn, .luxQuoteBtn, .luxNav a{
  will-change: transform, filter;
}

/* --- Card: luxury tilt + lift + sheen --- */
.card{
  position: relative;
  overflow: hidden;
  transition: transform .55s var(--easeOut2), filter .55s var(--easeOut2), border-color .55s var(--easeOut2);
}

.card::before{
  /* moving highlight */
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(420px 260px at var(--mx,50%) var(--my,50%),
    rgba(255,255,255,0.22),
    rgba(200,162,74,0.10) 35%,
    transparent 70%);
  opacity: 0;
  transition: opacity .45s var(--easeOut2);
  pointer-events:none;
  mix-blend-mode: screen;
}

.card::after{
  /* subtle top sheen bar */
  content:"";
  position:absolute; left:-40%; top:-30%;
  width: 160%; height: 60%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  transform: rotate(8deg) translateY(0);
  opacity: 0;
  transition: opacity .6s var(--easeOut2), transform .6s var(--easeOut2);
  pointer-events:none;
}

.card:hover{
  border-color: rgba(200,162,74,0.24);
  filter: brightness(1.06) saturate(1.02);
}

.card:hover::before{ opacity: 1; }
.card:hover::after{
  opacity: .85;
  transform: rotate(8deg) translateY(18px);
}

/* Image gets richer + slight parallax */
.card__img img{
  transition: transform .9s var(--easeOut2), filter .9s var(--easeOut2);
}
.card:hover .card__img img{
  filter: contrast(1.06) saturate(1.06);
}

/* --- Buttons: shine sweep + press --- */
.btn, .luxQuoteBtn{
  position: relative;
  overflow: hidden;
  transition: transform .35s var(--easeOut2), box-shadow .45s var(--easeOut2);
}

.btn::after, .luxQuoteBtn::after{
  content:"";
  position:absolute;
  top:-60%; left:-60%;
  width: 70%; height: 220%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.26), transparent);
  transform: rotate(18deg) translateX(-60%);
  opacity: 0.0;
  transition: transform .8s var(--easeOut2), opacity .25s var(--easeOut2);
  pointer-events:none;
}

.btn:hover::after, .luxQuoteBtn:hover::after{
  opacity: 0.9;
  transform: rotate(18deg) translateX(260%);
}

.btn:active, .luxQuoteBtn:active{
  transform: translateY(1px) scale(0.99);
}

/* --- Nav links: luxury underline reveal --- */
.luxNav a{
  position: relative;
  transition: opacity .25s var(--easeOut2), transform .35s var(--easeOut2);
}

.luxNav a::after{
  content:"";
  position:absolute;
  left: 8px; right: 8px; bottom: 6px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,162,74,0.9), transparent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .45s var(--easeOut2);
  opacity: .9;
}
.luxNav a:hover{
  transform: translateY(-1px);
}
.luxNav a:hover::after{
  transform: scaleX(1);
}

@keyframes navShine{
  0%   { background-position: 0% 0%; }
  50%  { background-position: 100% 100%; }
  100% { background-position: 0% 0%; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .card, .btn, .luxQuoteBtn, .luxNav a,
  .card::before, .card::after, .btn::after, .luxQuoteBtn::after{
    transition: none !important;
    animation: none !important;
  }
}
.specTable{
  width:100%;
  border-collapse: collapse;
  margin: 8px 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 16px;
  overflow:hidden;
}
.specTable th, .specTable td{
  padding: 10px 12px;
  font-size: 13px;
  text-align:left;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.specTable th{
  font-weight:700;
  color: var(--ink);
  background: rgba(255,255,255,0.08);
}
.specTable tr:last-child td{ border-bottom: none; }
.specTable tbody tr:nth-child(odd){
  background: rgba(255,255,255,0.02);
}
.specTable tbody tr:hover{
  background: rgba(217,164,61,0.08);
}
.specNote{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(234,239,247,0.68);
}
.specTables{
  display:grid;
  gap: 16px;
  margin-top: 10px;
}
.specTableWrapper{
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 18px;
  padding: 14px;
  background: rgba(12,14,20,0.65);
  box-shadow: 0 18px 40px rgba(0,0,0,0.38);
  overflow-x: auto;
}
.specTableWrapper h3{
  margin: 0 0 6px;
  font-family: Oswald, Inter, sans-serif;
}
.pumpsGrid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}
.pumpCard{
  border-radius: 18px;
  padding: 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 14px 36px rgba(0,0,0,0.30);
}
.pumpCard h3{ margin: 0 0 8px; font-family: Oswald, Inter, sans-serif; }
.pumpCard ul{ margin: 0; padding-left: 18px; color: var(--muted); line-height:1.6; font-size: 13px; display:grid; gap:4px; }

.mediaStrip{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 12px;
}
.mediaStrip--wide{ grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
.mediaCard{
  position: relative;
  overflow:hidden;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.03);
  box-shadow: 0 16px 40px rgba(0,0,0,0.38);
  isolation:isolate;
}
.mediaCard img{
  width:100%;
  height: 180px;
  object-fit: cover;
  object-position: center;
  padding: 0;
  background: transparent;
  display:block;
  filter: saturate(1.05) contrast(1.05);
  transition: transform .5s var(--easeOut2), filter .5s var(--easeOut2);
}
.mediaCard::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.45));
}
.mediaCard figcaption{
  position:absolute; left:14px; bottom:12px;
  font-weight:700;
  letter-spacing:0.04em;
  text-transform: uppercase;
  color: var(--ink);
  z-index:1;
}
.mediaCard:hover img{
  transform: scale(1.05);
  filter: saturate(1.12) contrast(1.08);
}

/* Engine media: show full engine, darker frame, higher contrast caption */
.mediaCard--engine img{
  height: 200px;
  object-fit: contain;
  padding: 12px;
  background: rgba(10,12,18,0.78);
}
.mediaCard--engine figcaption{
  color: #0b0d12;
  background: rgba(255,255,255,0.78);
  padding: 6px 10px;
  border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.28);
}
.mediaCard--engine::after{
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.30));
}

/* =========================
   UPKARGPT CHATBOT WIDGET
   ========================= */
/* ── Floating Language Picker ── */
.langFab{
  position:fixed;
  bottom:96px; right:28px;
  width:46px; height:46px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(15,18,26,0.92);
  backdrop-filter:blur(12px);
  color:rgba(240,242,246,0.70);
  font-size:18px;
  display:grid; place-items:center;
  cursor:pointer;
  z-index:9000;
  transition:background .2s ease, color .2s ease, transform .2s ease, border-color .2s ease;
  box-shadow:0 4px 18px rgba(0,0,0,0.40);
}
.langFab:hover{
  background:rgba(201,168,76,0.15);
  border-color:rgba(201,168,76,0.38);
  color:#c9a84c;
  transform:translateY(-2px);
}
.langFloatPanel{
  position:fixed;
  bottom:152px; right:28px;
  width:200px;
  background:rgba(12,15,22,0.96);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:16px;
  box-shadow:0 16px 48px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.04);
  backdrop-filter:blur(20px);
  z-index:9001;
  overflow:hidden;
  transform:translateY(10px) scale(0.96);
  opacity:0;
  pointer-events:none;
  transition:transform .28s cubic-bezier(0.34,1.56,0.64,1), opacity .22s ease;
}
.langFloatPanel.open{
  transform:translateY(0) scale(1);
  opacity:1;
  pointer-events:all;
}
.langFloatPanel__header{
  display:flex;
  align-items:center;
  gap:8px;
  padding:12px 16px 10px;
  border-bottom:1px solid rgba(255,255,255,0.07);
  font-size:11px;
  font-weight:700;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:rgba(240,242,246,0.45);
}
.langFloatPanel__header i{
  font-size:12px;
  color:rgba(201,168,76,0.65);
}
.langFloatPanel__options{
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.langFloatOption{
  display:flex;
  align-items:center;
  gap:12px;
  width:100%;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid transparent;
  background:transparent;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease;
  text-align:left;
}
.langFloatOption:hover{
  background:rgba(255,255,255,0.06);
  border-color:rgba(255,255,255,0.08);
}
.langFloatOption--active{
  background:rgba(201,168,76,0.10);
  border-color:rgba(201,168,76,0.22);
}
.langFloatOption__code{
  font-size:13px;
  font-weight:700;
  color:rgba(240,242,246,0.85);
  min-width:36px;
}
.langFloatOption--active .langFloatOption__code{
  color:#c9a84c;
}
.langFloatOption__name{
  font-size:12px;
  color:rgba(240,242,246,0.45);
}

.chatLauncher{
  position:fixed;
  bottom:28px; right:28px;
  width:56px; height:56px;
  border-radius:50%;
  border:none;
  background: linear-gradient(135deg, var(--brass), #b57f1f);
  color:#0a0c12;
  font-size:22px;
  display:grid; place-items:center;
  cursor:pointer;
  z-index:150;
  box-shadow: 0 8px 28px rgba(217,164,61,.35);
  transition: transform .35s var(--easeOut2), box-shadow .35s var(--easeOut2);
  animation: chatPulse 2.5s ease-in-out infinite;
}
.chatLauncher:hover{
  transform: scale(1.08);
  box-shadow: 0 12px 36px rgba(217,164,61,.45);
}
.chatLauncher.hidden{ display:none }
@keyframes chatPulse{
  0%,100%{ box-shadow: 0 8px 28px rgba(217,164,61,.35); }
  50%{ box-shadow: 0 8px 28px rgba(217,164,61,.55), 0 0 0 8px rgba(217,164,61,.10); }
}
.chatPanel{
  position:fixed;
  bottom:28px; right:28px;
  width:380px; height:520px;
  background:rgba(15,17,22,.95);
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  box-shadow: 0 24px 64px rgba(0,0,0,.55);
  z-index:160;
  display:none;
  flex-direction:column;
  overflow:hidden;
  transform: translateY(20px) scale(.97);
  opacity:0;
  transition: transform .42s var(--easeOut2), opacity .42s var(--easeOut2);
}
.chatPanel.open{
  display:flex;
  transform: translateY(0) scale(1);
  opacity:1;
}
.chatPanel__header{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid rgba(217,164,61,.18);
  flex-shrink:0;
}
.chatPanel__brand{
  display:flex; align-items:center; gap:10px;
}
.chatPanel__brand h3{
  margin:0;
  font-family: Oswald, Inter, sans-serif;
  font-size:16px;
  letter-spacing:.6px;
}
.chatPanel__dot{
  width:8px; height:8px;
  border-radius:50%;
  background:#34d399;
  box-shadow: 0 0 6px rgba(52,211,153,.5);
}
.chatPanel__close{
  width:32px; height:32px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:var(--ink);
  cursor:pointer;
  display:grid; place-items:center;
  font-size:14px;
  transition: background .25s ease;
}
.chatPanel__close:hover{ background:rgba(255,255,255,.08) }
.chatPanel__messages{
  flex:1;
  overflow-y:auto;
  padding:14px 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.chatPanel__messages::-webkit-scrollbar{ width:4px }
.chatPanel__messages::-webkit-scrollbar-track{ background:transparent }
.chatPanel__messages::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.12); border-radius:4px }
.chatMsg{
  max-width:85%;
  padding:10px 14px;
  border-radius:14px;
  font-size:13px;
  line-height:1.55;
  word-wrap:break-word;
}
.chatMsg--bot{
  align-self:flex-start;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}
.chatMsg--user{
  align-self:flex-end;
  background:rgba(217,164,61,.12);
  border:1px solid rgba(217,164,61,.18);
}
.chatTyping{
  display:flex; gap:4px; align-items:center;
  padding:10px 14px;
  align-self:flex-start;
}
.chatTyping span{
  width:6px; height:6px;
  border-radius:50%;
  background:rgba(255,255,255,.3);
  animation: typingDot 1.2s ease-in-out infinite;
}
.chatTyping span:nth-child(2){ animation-delay:.15s }
.chatTyping span:nth-child(3){ animation-delay:.3s }
@keyframes typingDot{
  0%,60%,100%{ opacity:.3; transform:translateY(0) }
  30%{ opacity:1; transform:translateY(-4px) }
}
.chatChips{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  padding:0 16px 10px;
  flex-shrink:0;
}
.chatChip{
  padding:7px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  color:var(--muted);
  font-size:12px;
  cursor:pointer;
  transition: background .25s ease, color .25s ease;
}
.chatChip:hover{
  background:rgba(255,255,255,.08);
  color:var(--ink);
}
.chatPanel__input{
  display:flex;
  gap:8px;
  padding:10px 16px 14px;
  border-top:1px solid rgba(255,255,255,.08);
  flex-shrink:0;
}
.chatPanel__input input{
  flex:1;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  color:var(--ink);
  padding:0 12px;
  height:40px;
  font-size:13px;
  outline:none;
  transition: border-color .25s ease;
}
.chatPanel__input input::placeholder{ color:rgba(169,176,189,.75) }
.chatPanel__input input:focus{ border-color:rgba(255,255,255,.26) }
.chatPanel__input button{
  width:40px; height:40px;
  border-radius:12px;
  border:none;
  background: linear-gradient(135deg, var(--brass), #b57f1f);
  color:#0a0c12;
  font-size:15px;
  cursor:pointer;
  display:grid; place-items:center;
  flex-shrink:0;
  transition: transform .25s var(--easeOut2);
}
.chatPanel__input button:hover{ transform:scale(1.06) }
@media (max-width: 540px){
  .chatPanel{
    width:100%;
    bottom:0; right:0;
    border-radius:22px 22px 0 0;
    height:70vh;
  }
  .chatLauncher{
    bottom:16px; right:16px;
  }
}

/* ==========================================================================
   AQUAFORCE SUBMERSIBLE PUMPS — 2026 INDUSTRIAL
   ========================================================================== */

/* --- HERO BANNER --- */
.subHero{
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  padding: 64px 28px;
  margin-bottom: 18px;
  background: linear-gradient(160deg, #080b14 0%, #0d1420 40%, #111a2c 100%);
  border: 1px solid rgba(110,163,201,0.18);
  box-shadow:
    0 0 80px rgba(110,163,201,0.08),
    0 32px 72px rgba(0,0,0,0.55);
}
.subHero__bg{
  position: absolute; inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.subHero__gridOverlay{
  position: absolute; inset: -2px;
  background-image:
    linear-gradient(to right, rgba(110,163,201,0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(110,163,201,0.06) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 80%);
  opacity: 0.6;
}
.subHero__glowA{
  position: absolute;
  width: 500px; height: 500px;
  left: -10%; top: -30%;
  border-radius: 50%;
  background: rgba(110,163,201,0.18);
  filter: blur(100px);
}
.subHero__glowB{
  position: absolute;
  width: 400px; height: 400px;
  right: -8%; bottom: -20%;
  border-radius: 50%;
  background: rgba(217,164,61,0.12);
  filter: blur(80px);
}
.subHero__inner{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 16px;
}
.subHero__badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(110,163,201,0.12);
  border: 1px solid rgba(110,163,201,0.28);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--brass2);
}
.subHero__title{
  margin: 0;
  font-family: Oswald, Inter, sans-serif;
  font-size: clamp(38px, 5.5vw, 72px);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 0.95;
  background: linear-gradient(90deg, #f0f2f6 20%, var(--brass2) 60%, var(--brass) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.subHero__tm{
  font-size: 0.4em;
  vertical-align: super;
  opacity: 0.6;
}
.subHero__tagline{
  margin: 0;
  font-size: 15px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(234,239,247,0.72);
  max-width: 50ch;
}
.subHero__pills{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 8px;
}
.subHero__pill{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: rgba(240,242,246,0.88);
  backdrop-filter: blur(6px);
  transition: border-color .3s var(--easeOut2), background .3s var(--easeOut2), transform .3s var(--easeOut2);
}
.subHero__pill:hover{
  border-color: rgba(110,163,201,0.32);
  background: rgba(110,163,201,0.08);
  transform: translateY(-2px);
}
.subHero__pill i{
  color: var(--brass2);
  font-size: 13px;
}

/* --- FILTER CHIPS --- */
.subFilter{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}
.subFilter__chip{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: rgba(240,242,246,0.78);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all .28s var(--easeOut2);
}
.subFilter__chip:hover{
  background: rgba(110,163,201,0.10);
  border-color: rgba(110,163,201,0.28);
  color: var(--ink);
  transform: translateY(-1px);
}
.subFilter__chip--active{
  background: linear-gradient(135deg, rgba(110,163,201,0.22), rgba(217,164,61,0.14));
  border-color: rgba(110,163,201,0.35);
  color: var(--ink);
  box-shadow: 0 4px 18px rgba(110,163,201,0.15);
}

/* --- PRODUCT CARDS GRID --- */
.subGrid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}
.subCard{
  position: relative;
  border-radius: 22px;
  background: linear-gradient(170deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 20px 50px rgba(0,0,0,0.35);
  overflow: hidden;
  transition: transform .45s var(--easeOut2), border-color .45s var(--easeOut2), box-shadow .45s var(--easeOut2);
}
.subCard:hover{
  transform: translateY(-4px);
  border-color: rgba(110,163,201,0.28);
  box-shadow: 0 28px 64px rgba(0,0,0,0.45), 0 0 32px rgba(110,163,201,0.08);
}

/* Placeholder image area */
.subCard__img{
  position: relative;
  height: 200px;
  background:
    radial-gradient(ellipse 60% 50% at 50% 45%, rgba(110,163,201,0.08), transparent 70%),
    linear-gradient(180deg, rgba(15,20,32,0.95), rgba(10,14,22,0.98));
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.subCard__imgIcon{
  font-size: 52px;
  color: rgba(110,163,201,0.18);
  transition: color .4s var(--easeOut2), transform .4s var(--easeOut2);
}
.subCard:hover .subCard__imgIcon{
  color: rgba(110,163,201,0.32);
  transform: scale(1.08);
}
/* Animated scan line on hover */
.subCard__img::after{
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(110,163,201,0.50), transparent);
  top: -1px;
  opacity: 0;
  transition: opacity .3s ease;
}
.subCard:hover .subCard__img::after{
  opacity: 1;
  animation: scanLine 2s linear infinite;
}
@keyframes scanLine{
  0%  { top: -1px; }
  100%{ top: 100%; }
}

/* Class badge */
.subCard__classBadge{
  position: absolute;
  top: 14px; right: 14px;
  padding: 6px 12px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(10px);
}
.subCard__classBadge--DW{
  background: rgba(251,191,36,0.12);
  border-color: rgba(251,191,36,0.28);
  color: #fbbf24;
}
.subCard__classBadge--IB{
  background: rgba(96,165,250,0.12);
  border-color: rgba(96,165,250,0.28);
  color: #60a5fa;
}
.subCard__classBadge--SW{
  background: rgba(248,113,113,0.12);
  border-color: rgba(248,113,113,0.28);
  color: #f87171;
}

.subCard__body{
  padding: 18px;
}
.subCard__model{
  margin: 0 0 2px;
  font-family: 'Courier New', monospace;
  font-size: 12px;
  letter-spacing: 0.10em;
  color: var(--brass2);
  text-transform: uppercase;
}
.subCard__name{
  margin: 0 0 12px;
  font-family: Oswald, Inter, sans-serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* Spec rows */
.subCard__specs{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 14px;
}
.subCard__spec{
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
}
.subCard__specLabel{
  display: block;
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(240,242,246,0.50);
  margin-bottom: 2px;
}
.subCard__specVal{
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}

/* Application tags */
.subCard__apps{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.subCard__appTag{
  padding: 5px 10px;
  border-radius: 8px;
  font-size: 11px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(240,242,246,0.72);
}

/* Hide filtered-out cards with animation */
.subCard[data-hidden="true"]{
  display: none;
}

/* --- PERFORMANCE BANDS --- */
.perfBands{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
}
.perfBand{
  position: relative;
  border-radius: 20px;
  padding: 22px;
  background: linear-gradient(170deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 16px 44px rgba(0,0,0,0.30);
  overflow: hidden;
  transition: border-color .35s var(--easeOut2);
}
.perfBand:hover{
  border-color: rgba(110,163,201,0.24);
}
.perfBand::before{
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brass2), var(--brass));
  opacity: 0.6;
}
.perfBand__hp{
  font-family: Oswald, Inter, sans-serif;
  font-size: 28px;
  font-weight: 600;
  margin: 0 0 4px;
  background: linear-gradient(90deg, #f0f2f6, var(--brass2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.perfBand__use{
  font-size: 12px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--brass2);
  margin: 0 0 14px;
}
.perfBand__row{
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  font-size: 13px;
}
.perfBand__row:last-child{ border-bottom: none; }
.perfBand__label{ color: rgba(240,242,246,0.60); }
.perfBand__val{ font-weight: 600; color: var(--ink); }

/* Visual bar behind head/discharge */
.perfBand__bar{
  position: relative;
  height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.06);
  margin-top: 12px;
  overflow: hidden;
}
.perfBand__barFill{
  position: absolute;
  top: 0; left: 0; bottom: 0;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--brass2), var(--brass));
  transition: width 1.2s var(--easeOut2);
}

/* --- MATERIAL GRID --- */
.matGrid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
}
.matCard{
  padding: 18px;
  border-radius: 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 12px 32px rgba(0,0,0,0.25);
  transition: border-color .35s var(--easeOut2), transform .35s var(--easeOut2);
}
.matCard:hover{
  border-color: rgba(110,163,201,0.22);
  transform: translateY(-2px);
}
.matCard__icon{
  width: 42px; height: 42px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(110,163,201,0.10);
  border: 1px solid rgba(110,163,201,0.22);
  color: var(--brass2);
  font-size: 16px;
  margin-bottom: 10px;
}
.matCard h4{
  margin: 0 0 4px;
  font-family: Oswald, Inter, sans-serif;
  font-size: 16px;
  font-weight: 600;
}
.matCard p{
  margin: 0;
  color: rgba(240,242,246,0.65);
  font-size: 13px;
  line-height: 1.6;
}

/* --- FEATURE GRID --- */
.featGrid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}
.featCard{
  position: relative;
  padding: 22px;
  border-radius: 20px;
  background: linear-gradient(170deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 14px 38px rgba(0,0,0,0.28);
  overflow: hidden;
  transition: border-color .35s var(--easeOut2), transform .35s var(--easeOut2);
}
.featCard:hover{
  border-color: rgba(217,164,61,0.22);
  transform: translateY(-2px);
}
.featCard__num{
  font-family: Oswald, Inter, sans-serif;
  font-size: 40px;
  font-weight: 600;
  line-height: 1;
  background: linear-gradient(180deg, rgba(110,163,201,0.30), rgba(110,163,201,0.06));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-bottom: 8px;
}
.featCard h4{
  margin: 0 0 6px;
  font-family: Oswald, Inter, sans-serif;
  font-size: 18px;
  font-weight: 600;
}
.featCard p{
  margin: 0;
  color: rgba(240,242,246,0.65);
  font-size: 13px;
  line-height: 1.65;
}

/* --- INSTALLATION GRID --- */
.installGrid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 18px;
}
.installCol{
  padding: 20px;
  border-radius: 18px;
  background: rgba(52,211,153,0.04);
  border: 1px solid rgba(52,211,153,0.16);
}
.installCol h4{
  margin: 0 0 10px;
  font-family: Oswald, Inter, sans-serif;
  font-size: 18px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: #34d399;
}
.installCol--dont{
  background: rgba(248,113,113,0.04);
  border-color: rgba(248,113,113,0.16);
}
.installCol--dont h4{ color: #f87171; }
.installCol ul{
  margin: 0;
  padding-left: 18px;
  color: rgba(240,242,246,0.72);
  line-height: 1.7;
  font-size: 13px;
  display: grid;
  gap: 4px;
}

.subCaution{
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 20px;
  border-radius: 14px;
  background: rgba(251,191,36,0.06);
  border: 1px solid rgba(251,191,36,0.18);
}
.subCaution i{
  color: #fbbf24;
  font-size: 18px;
  margin-top: 2px;
  flex-shrink: 0;
}
.subCaution p{
  margin: 0;
  color: rgba(240,242,246,0.78);
  font-size: 13px;
  line-height: 1.65;
}

/* --- RESPONSIVE --- */
@media (max-width: 980px){
  .subGrid{ grid-template-columns: 1fr; }
  .perfBands{ grid-template-columns: 1fr; }
  .matGrid{ grid-template-columns: repeat(2, 1fr); }
  .featGrid{ grid-template-columns: 1fr; }
  .installGrid{ grid-template-columns: 1fr; }
}
@media (max-width: 540px){
  .subHero{ padding: 40px 16px; border-radius: 18px; }
  .subHero__pills{ gap: 8px; }
  .subHero__pill{ padding: 8px 12px; font-size: 11px; }
  .matGrid{ grid-template-columns: 1fr; }
  .subCard__specs{ grid-template-columns: 1fr; }
}

/* --- PERFORMANCE CHARTS --- */
.perfChartGrid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 18px;
}
.perfChart{
  position: relative;
  border-radius: 20px;
  padding: 20px;
  background: linear-gradient(170deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 16px 44px rgba(0,0,0,0.30);
  overflow: hidden;
  transition: border-color .35s var(--easeOut2);
}
.perfChart:hover{
  border-color: rgba(110,163,201,0.24);
}
.perfChart::before{
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brass2), var(--brass));
  opacity: 0.6;
}
.perfChart__header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.perfChart__title{
  margin: 0;
  font-family: Oswald, Inter, sans-serif;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.perfChart__badge{
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: rgba(110,163,201,0.12);
  border: 1px solid rgba(110,163,201,0.24);
  color: var(--brass2);
}
.perfChart__svg{
  width: 100%;
  height: auto;
  display: block;
}
.perfChart__grid line{
  stroke: rgba(255,255,255,0.06);
  stroke-width: 1;
}
.perfChart__axis text{
  font-family: 'Courier New', monospace;
  font-size: 10px;
  fill: rgba(240,242,246,0.50);
}
.perfChart__axisLabel{
  font-family: 'Courier New', monospace;
  font-size: 11px;
  fill: rgba(240,242,246,0.65);
  letter-spacing: 0.06em;
}
.perfChart__curve{
  fill: none;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 0 6px rgba(110,163,201,0.35));
  transition: d 0.6s ease;
}
.perfChart__curve--primary{
  stroke: var(--brass2);
}
.perfChart__curve--secondary{
  stroke: var(--brass);
}
.perfChart__area{
  opacity: 0.08;
  transition: d 0.6s ease;
}
.perfChart__area--primary{
  fill: var(--brass2);
}
.perfChart__area--secondary{
  fill: var(--brass);
}
.perfChart__dot{
  fill: var(--brass2);
  stroke: rgba(10,14,22,0.90);
  stroke-width: 2;
  cursor: pointer;
  transition: r 0.2s ease, fill 0.2s ease;
}
.perfChart__dot:hover{
  fill: var(--brass);
}
.perfChart__tooltip{
  position: absolute;
  padding: 8px 12px;
  border-radius: 10px;
  background: rgba(10,14,22,0.92);
  border: 1px solid rgba(110,163,201,0.28);
  box-shadow: 0 8px 24px rgba(0,0,0,0.45);
  font-family: 'Courier New', monospace;
  font-size: 12px;
  color: var(--ink);
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 10;
  white-space: nowrap;
}
.perfChart__tooltip.visible{
  opacity: 1;
  transform: translateY(0);
}

/* Model selector */
.perfSelector{
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 14px;
}
.perfSelector__label{
  font-size: 12px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(240,242,246,0.65);
}
.perfSelector__select{
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.05);
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
  outline: none;
  cursor: pointer;
  transition: border-color 0.25s ease;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236ea3c9' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 34px;
}
.perfSelector__select:focus{
  border-color: rgba(110,163,201,0.35);
}

/* Trust badges */
.trustBadges{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 20px;
}
.trustBadge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: rgba(240,242,246,0.82);
  transition: border-color .3s var(--easeOut2), transform .3s var(--easeOut2);
}
.trustBadge:hover{
  border-color: rgba(217,164,61,0.24);
  transform: translateY(-1px);
}
.trustBadge i{
  color: var(--brass);
  font-size: 14px;
}

/* PDF download button */
.perfDownload{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 16px;
  padding: 12px 20px;
  border-radius: 14px;
  background: rgba(217,164,61,0.10);
  border: 1px solid rgba(217,164,61,0.22);
  color: var(--brass);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-decoration: none;
  transition: background .25s ease, border-color .25s ease, transform .25s ease;
}
.perfDownload:hover{
  background: rgba(217,164,61,0.16);
  border-color: rgba(217,164,61,0.35);
  transform: translateY(-1px);
}
.perfDownload i{
  font-size: 15px;
}

/* Responsive: stack charts on mobile */
@media (max-width: 980px){
  .perfChartGrid{ grid-template-columns: 1fr; }
}
@media (max-width: 540px){
  .perfChart{ padding: 16px; }
  .trustBadges{ gap: 8px; }
  .trustBadge{ padding: 8px 12px; font-size: 11px; }
}

/* --- GENSET POWER GRAPH — LEGEND & TOLERANCE LINE --- */
.pgLegend{
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  margin-top: 10px;
}
.pgLegendItem{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Courier New', monospace;
  font-size: 11px;
  color: rgba(240,242,246,0.70);
  letter-spacing: 0.04em;
}
.pgLegendDot{
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 6px currentColor;
}
.pgTolLine{
  stroke: rgba(217,164,61,0.38);
  stroke-width: 1;
  stroke-dasharray: 5 3;
}

/* --- FULL-PAGE HERO VARIANT (standalone page) --- */
.subHero--full{
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  margin-bottom: 0;
  border: none;
  padding: 100px 28px 64px;
}
.subHero--full .subHero__inner{
  gap: 18px;
}
.subHero__sub{
  margin: 0;
  font-size: 14px;
  color: rgba(234,239,247,0.60);
  max-width: 56ch;
  line-height: 1.7;
}
.subHero__actions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 8px;
}

/* Floating particles */
.subHero__particles{
  position: absolute; inset: 0;
  overflow: hidden;
  pointer-events: none;
}
.subHero__particle{
  position: absolute;
  width: 3px; height: 3px;
  border-radius: 50%;
  background: rgba(110,163,201,0.35);
  box-shadow: 0 0 6px rgba(110,163,201,0.20);
  animation: particleFloat linear infinite;
}
@keyframes particleFloat{
  0%  { transform: translateY(0) scale(1);   opacity: 0; }
  10% { opacity: 0.8; }
  90% { opacity: 0.8; }
  100%{ transform: translateY(-120px) scale(0.4); opacity: 0; }
}
@media (max-width: 540px){
  .subHero--full{ min-height: 90vh; padding: 80px 16px 40px; }
}

/* ==========================================================================
   NEXT-LEVEL UPGRADES — 2026 INDUSTRIAL
   ========================================================================== */

/* --- LENIS SMOOTH SCROLL --- */
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto; }
.lenis.lenis-smooth [data-lenis-prevent]{ overscroll-behavior:contain; }
.lenis.lenis-stopped{ overflow:hidden; }

/* --- PRELOADER --- */
.preloader{
  position:fixed; inset:0;
  z-index:9999;
  background:#05070d;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:28px;
  transition: opacity .6s ease, visibility .6s ease;
}
.preloader.done{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
.preloader__logo{
  width:80px; height:80px;
  border-radius:20px;
  overflow:hidden;
  box-shadow: 0 0 60px rgba(217,164,61,0.25);
  animation: preloaderPulse 1.8s ease-in-out infinite;
}
.preloader__logo img{
  width:100%; height:100%;
  object-fit:contain;
}
@keyframes preloaderPulse{
  0%,100%{ transform:scale(1); box-shadow: 0 0 60px rgba(217,164,61,0.25); }
  50%{ transform:scale(1.06); box-shadow: 0 0 80px rgba(217,164,61,0.45); }
}
.preloader__bar{
  width:180px; height:3px;
  border-radius:2px;
  background:rgba(255,255,255,0.08);
  overflow:hidden;
}
.preloader__fill{
  height:100%;
  border-radius:2px;
  background:linear-gradient(90deg, var(--brass), var(--brass2));
  width:0%;
  transition: width .3s ease;
}
.preloader__text{
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(240,242,246,0.45);
}

/* --- CUSTOM CURSOR --- */
.cursor{
  position:fixed;
  top:0; left:0;
  width:40px; height:40px;
  border-radius:50%;
  border:1px solid rgba(217,164,61,0.45);
  pointer-events:none;
  z-index:10000;
  transform:translate(-50%,-50%);
  transition: width .3s var(--easeOut2), height .3s var(--easeOut2), border-color .3s var(--easeOut2), background .3s var(--easeOut2);
  mix-blend-mode:difference;
}
.cursor__dot{
  position:fixed;
  top:0; left:0;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--brass);
  pointer-events:none;
  z-index:10001;
  transform:translate(-50%,-50%);
}
.cursor.hover{
  width:64px; height:64px;
  border-color:rgba(217,164,61,0.70);
  background:rgba(217,164,61,0.06);
}
.cursor.click{
  transform:translate(-50%,-50%) scale(0.85);
}
@media (pointer:coarse),
       (max-width:980px){
  .cursor,.cursor__dot{ display:none !important; }
}

/* --- PRODUCT SHOWCASE --- */
.showcase{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:22px;
}
.showCard{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,0.10);
  background:linear-gradient(170deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  box-shadow:0 8px 24px rgba(0,0,0,0.28), 0 24px 64px rgba(0,0,0,0.24);
  transform-style:preserve-3d;
  transition: transform .55s var(--easeOut2), border-color .55s var(--easeOut2), box-shadow .55s var(--easeOut2);
  cursor:pointer;
  text-decoration:none;
  color:var(--ink);
  display:block;
}
.showCard:hover{
  border-color:rgba(217,164,61,0.26);
  box-shadow:0 12px 32px rgba(0,0,0,0.32), 0 32px 80px rgba(0,0,0,0.38), 0 0 40px rgba(217,164,61,0.07);
}
.showCard__img{
  position:relative;
  height:280px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(15,20,32,0.96), rgba(10,14,22,0.99));
  display:flex;
  align-items:center;
  justify-content:center;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.showCard__img::before{
  content:"";
  position:absolute;
  top:0; left:15%; right:15%;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(201,168,76,0.38), transparent);
  z-index:2;
}
.showCard__img img{
  max-height:220px;
  width:auto;
  max-width:88%;
  object-fit:contain;
  filter:drop-shadow(0 16px 40px rgba(0,0,0,0.50));
  transition: transform .65s var(--easeOut2), filter .65s var(--easeOut2);
}
.showCard:hover .showCard__img img{
  transform:scale(1.06) translateY(-4px);
  filter:drop-shadow(0 24px 56px rgba(0,0,0,0.60));
}
/* Glow on hover */
.showCard__img::after{
  content:"";
  position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 80% at var(--gx,50%) var(--gy,60%), rgba(217,164,61,0.12), transparent 70%);
  opacity:0;
  transition: opacity .45s var(--easeOut2);
  pointer-events:none;
}
.showCard:hover .showCard__img::after{ opacity:1; }

.showCard__body{
  padding:28px 30px 32px;
}
.showCard__badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 12px;
  border-radius:999px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  font-size:10px;
  font-weight:700;
  letter-spacing:0.20em;
  text-transform:uppercase;
  color:rgba(240,242,246,0.60);
  margin-bottom:18px;
}
.showCard__name{
  margin:0 0 10px;
  font-family:Oswald, Inter, sans-serif;
  font-size:clamp(24px, 3vw, 34px);
  font-weight:600;
  letter-spacing:0.01em;
  line-height:1.1;
}
.showCard__desc{
  margin:0 0 20px;
  color:rgba(240,242,246,0.62);
  font-size:14px;
  line-height:1.80;
  letter-spacing:0.008em;
}
.showCard__link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:700;
  letter-spacing:0.10em;
  text-transform:uppercase;
  color:rgba(217,164,61,0.78);
  transition: gap .3s var(--easeOut2), color .3s;
}
.showCard:hover .showCard__link{ gap:14px; color:rgba(217,164,61,1); }

/* --- STATS COUNTERS --- */
.statsSection{
  position:relative;
  padding:88px 0;
  overflow:hidden;
}
.statsSection::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 20% 50%, rgba(217,164,61,0.06), transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 50%, rgba(110,163,201,0.05), transparent 55%);
  pointer-events:none;
}
.statsGrid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
}
.statItem{
  position:relative;
  text-align:center;
  padding:44px 20px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.04);
  box-shadow:0 8px 24px rgba(0,0,0,0.22), 0 24px 48px rgba(0,0,0,0.18);
  transition: border-color .4s var(--easeOut2), transform .4s var(--easeOut2);
  overflow:hidden;
}
.statItem::before{
  content:"";
  position:absolute;
  top:0; left:20%; right:20%;
  height:2px;
  border-radius:0 0 2px 2px;
  background:linear-gradient(90deg, transparent, rgba(201,168,76,0.55), transparent);
}
.statItem:hover{
  border-color:rgba(217,164,61,0.18);
  transform:translateY(-4px);
}
.statItem__number{
  font-family:Oswald, Inter, sans-serif;
  font-size:clamp(40px, 5vw, 64px);
  font-weight:700;
  line-height:1;
  background:linear-gradient(135deg, #f0f2f6, var(--brass));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.statItem__suffix{
  font-size:0.5em;
  opacity:0.7;
}
.statItem__label{
  margin-top:8px;
  font-size:11px;
  letter-spacing:0.20em;
  text-transform:uppercase;
  color:rgba(240,242,246,0.55);
  font-weight:500;
}
.statItem__bar{
  width:40px; height:3px;
  margin:14px auto 0;
  border-radius:2px;
  background:linear-gradient(90deg, var(--brass), var(--brass2));
  opacity:0.5;
}

/* --- SPLIT TEXT --- */
.splitChar{
  display:inline-block;
  transform-origin:bottom center;
}
.splitWord{
  display:inline-block;
  white-space:pre;
}

/* --- ENHANCED SECTION DIVIDER --- */
.sectionDivider{
  width:100%;
  height:1px;
  margin:64px 0;
  background:linear-gradient(90deg, transparent 0%, rgba(201,168,76,0.18) 25%, rgba(255,255,255,0.08) 50%, rgba(201,168,76,0.18) 75%, transparent 100%);
}

/* --- RESPONSIVE FOR NEW SECTIONS --- */
@media (max-width:980px){
  .showcase{ grid-template-columns:1fr; }
  .statsGrid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:540px){
  .statsGrid{ grid-template-columns:1fr 1fr; gap:12px; }
  .statItem{ padding:22px 12px; }
  .showCard__img{ height:200px; }
}

/* ============================================================
   INDUSTRIAL ENGINES SECTION — 2030 Heavy Duty
   ============================================================ */

.indEng__eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(177,34,34,0.12);
  border: 1px solid rgba(177,34,34,0.26);
  color: #e86060;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.indEng__layout{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: center;
  margin-top: 20px;
}

/* --- Specs column --- */
.indEng__specs{
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.indEng__tableWrap{
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(217,164,61,0.18);
  background: linear-gradient(170deg, rgba(18,20,28,0.92), rgba(10,12,18,0.98));
  box-shadow:
    0 24px 60px rgba(0,0,0,0.52),
    inset 0 1px 0 rgba(255,255,255,0.06);
}

.indEng__tableHeader{
  padding: 14px 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.03);
}

.indEng__tableBadge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--brass);
}

.indEng__tableScroll{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.indEng__table{
  margin: 0;
  border: none;
  border-radius: 0;
}

.indEng__table thead tr{
  background: rgba(217,164,61,0.08);
}

.indEng__table th{
  white-space: nowrap;
  color: var(--brass);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  border-bottom: 1px solid rgba(217,164,61,0.16);
}

.indEng__table td{
  font-size: 14px;
  font-weight: 500;
}

.indEng__table tbody tr{
  transition: background .2s ease;
}

.indEng__table tbody tr:hover{
  background: rgba(217,164,61,0.10) !important;
}

.indEng__kva{
  font-family: Oswald, Inter, sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
}

.indEng__tableWrap .specNote{
  padding: 10px 16px 14px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* Stat pills */
.indEng__pills{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

.indEng__pill{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 10px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  text-align: center;
  transition: border-color .3s var(--easeOut2), transform .3s var(--easeOut2);
}

.indEng__pill:hover{
  border-color: rgba(217,164,61,0.22);
  transform: translateY(-2px);
}

.indEng__pillVal{
  font-family: Oswald, Inter, sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--brass);
  line-height: 1;
}

.indEng__pillLabel{
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--muted);
}

/* --- Image column --- */
.indEng__visual{
  display: flex;
  align-items: stretch;
  justify-content: center;
}

.indEng__imgWrap{
  position: relative;
  width: 100%;
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(217,164,61,0.16);
  background: linear-gradient(160deg, rgba(14,17,26,0.96), rgba(8,10,16,0.99));
  box-shadow:
    0 32px 80px rgba(0,0,0,0.60),
    0 0 0 1px rgba(255,255,255,0.04),
    inset 0 1px 0 rgba(255,255,255,0.06);
  padding: 36px 24px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 20px;
  isolation: isolate;
  min-height: 340px;
}

/* Ambient glow behind image */
.indEng__imgGlow{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 55% at 50% 10%, rgba(217,164,61,0.10), transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(110,163,201,0.07), transparent 55%);
  pointer-events: none;
  z-index: 0;
  transition: opacity .5s ease;
}

.indEng__imgWrap:hover .indEng__imgGlow{
  opacity: 1.3;
}

.indEng__imgWrap img{
  position: relative;
  z-index: 1;
  max-width: 88%;
  max-height: 280px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 24px 52px rgba(0,0,0,0.65));
  transition: transform .65s var(--easeOut2), filter .65s var(--easeOut2);
}

.indEng__imgWrap:hover img{
  transform: scale(1.04) translateY(-5px);
  filter: drop-shadow(0 32px 68px rgba(0,0,0,0.72));
}

/* Corner badge */
.indEng__imgBadge{
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(217,164,61,0.12);
  border: 1px solid rgba(217,164,61,0.24);
  color: var(--brass);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
  z-index: 2;
  backdrop-filter: blur(8px);
}

/* --- Responsive --- */
@media (max-width: 860px){
  .indEng__layout{
    grid-template-columns: 1fr;
  }
  .indEng__visual{
    order: 2;
  }
  .indEng__specs{
    order: 1;
  }
  .indEng__imgWrap{
    min-height: 260px;
  }
}

@media (max-width: 540px){
  .indEng__pills{
    grid-template-columns: repeat(2, 1fr);
  }
  .indEng__table th,
  .indEng__table td{
    padding: 8px 10px;
    font-size: 12px;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .indEng__imgWrap img,
  .indEng__pill{
    transition: none !important;
  }
}

/* ===== 4-STROKE DIESEL CYCLE SECTION ===== */
.strokeSection {
  width: 100%;
  background: #060d18;
  position: relative;
}
.strokePin {
  width: 100%;
  height: 100vh;
  min-height: 560px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 48px;
  padding: 24px 40px;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
}
.strokePin::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,107,0,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,107,0,0.03) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
}
.strokePin::after {
  content: "";
  position: absolute;
  left: 20%;
  top: 50%;
  transform: translate(-50%,-50%);
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,107,0,0.06) 0%, transparent 70%);
  pointer-events: none;
}
.stroke__brand {
  position: absolute;
  top: 22px;
  left: 32px;
  font-family: "Oswald", sans-serif;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 0.28em;
  color: #FF6B00;
  z-index: 10;
}
.stroke__engineWrap {
  flex: 0 0 auto;
  width: min(300px, 38vw);
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 0 48px rgba(255,107,0,0.10));
}
.stroke__engineWrap svg { width: 100%; height: auto; display: block; }
.stroke__info {
  flex: 1;
  max-width: 440px;
  position: relative;
  z-index: 2;
}
.stroke__eyebrow {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}
.stroke__num {
  font-family: "Oswald", sans-serif;
  font-size: 13px;
  letter-spacing: 0.22em;
  color: #FF6B00;
}
.stroke__cycle {
  font-size: 11px;
  letter-spacing: 0.18em;
  color: rgba(255,255,255,0.35);
  text-transform: uppercase;
}
.stroke__name {
  font-family: "Oswald", sans-serif;
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #fff;
  line-height: 0.95;
  margin: 0 0 6px;
}
.stroke__nameSub {
  font-family: "Oswald", sans-serif;
  font-size: clamp(20px, 3vw, 32px);
  font-weight: 400;
  letter-spacing: 0.12em;
  color: #FF6B00;
  display: block;
  margin-bottom: 18px;
}
.stroke__divider {
  width: 48px;
  height: 3px;
  background: #FF6B00;
  margin-bottom: 18px;
  border-radius: 2px;
}
.stroke__caption {
  font-size: 15px;
  color: rgba(200,220,255,0.72);
  line-height: 1.7;
  max-width: 380px;
  margin: 0 0 28px;
}
.stroke__dotsWrap { display: flex; flex-direction: column; gap: 8px; }
.stroke__dots { display: flex; gap: 8px; }
.stroke__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,0.18);
  border: none;
  padding: 0;
  transition: background 0.35s, transform 0.35s;
}
.stroke__dot--active { background: #FF6B00; transform: scale(1.35); }
.stroke__dotLabels { display: flex; gap: 0; }
.stroke__dotLabel {
  font-size: 9px;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.25);
  text-transform: uppercase;
  width: 18px;
  text-align: center;
  transition: color 0.35s;
  white-space: nowrap;
  overflow: visible;
}
.stroke__dotLabel--active { color: #FF6B00; }
.stroke__progressWrap {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: rgba(255,255,255,0.06);
  z-index: 10;
}
.stroke__progressBar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #FF6B00, #ffa040);
}
.stroke__scrollHint {
  position: absolute;
  bottom: 20px;
  right: 32px;
  font-size: 11px;
  letter-spacing: 0.15em;
  color: rgba(255,255,255,0.25);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 10;
}
.stroke__scrollHint i { font-size: 9px; animation: bounceY 1.8s ease-in-out infinite; }
@keyframes bounceY { 0%,100%{transform:translateY(0)} 50%{transform:translateY(4px)} }
@media (max-width: 800px) {
  .strokePin {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding: 64px 20px 40px;
    justify-content: center;
  }
  .stroke__engineWrap { width: min(210px, 55vw); }
  .stroke__info { max-width: 100%; text-align: center; }
  .stroke__dots { justify-content: center; }
  .stroke__dotLabels { justify-content: center; }
  .stroke__divider { margin: 0 auto 18px; }
  .stroke__caption { max-width: 100%; }
  .stroke__name { font-size: 38px; }
}

/* ===== HP TABLE MODAL ===== */
.hpModal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9000;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.hpModal--open {
  display: flex;
}
.hpModal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.72);
  backdrop-filter: blur(6px);
}
.hpModal__panel {
  position: relative;
  z-index: 1;
  background: #0e1117;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  width: 100%;
  max-width: 860px;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 80px rgba(0,0,0,0.7);
  animation: modalPop 0.25s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes modalPop {
  from { opacity:0; transform: scale(0.92) translateY(16px); }
  to   { opacity:1; transform: scale(1) translateY(0); }
}
.hpModal__close {
  position: absolute;
  top: 14px; right: 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  width: 36px; height: 36px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 15px;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.2s;
}
.hpModal__close:hover { background: rgba(255,255,255,0.14); }
.hpModal__header {
  padding: 28px 28px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
}
.hpModal__code {
  font-family: 'Courier New', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--brass2, #c9a84c);
  margin: 0 0 4px;
  text-transform: uppercase;
}
.hpModal__title {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 600;
  color: #fff;
  margin: 0;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.hpModal__note {
  margin: 8px 0 0;
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  font-style: italic;
}
.hpModal__body {
  overflow-y: auto;
  flex: 1;
  padding: 0;
}
.hpModal__tableWrap {
  overflow-x: auto;
  padding: 20px 24px 28px;
}
.hpTable {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.hpTable thead tr {
  background: rgba(255,255,255,0.04);
}
.hpTable th {
  padding: 10px 14px;
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  border-bottom: 1px solid rgba(255,255,255,0.10);
  white-space: nowrap;
}
.hpTable td {
  padding: 10px 14px;
  color: rgba(255,255,255,0.80);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  white-space: nowrap;
}
.hpTable tbody tr:hover td { background: rgba(255,255,255,0.04); }
.hpTable__td--hp {
  font-weight: 700;
  color: var(--brass2, #c9a84c);
  font-size: 14px;
}

/* Card HP hint */
.subCard__hpHint {
  margin-top: 14px;
  padding: 8px 12px;
  background: rgba(201,168,76,0.07);
  border: 1px solid rgba(201,168,76,0.20);
  border-radius: 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--brass2, #c9a84c);
  text-align: center;
  transition: background 0.2s, border-color 0.2s;
}
.subCard:hover .subCard__hpHint {
  background: rgba(201,168,76,0.14);
  border-color: rgba(201,168,76,0.40);
}

@media (max-width: 600px) {
  .hpModal__panel { max-height: 94vh; border-radius: 12px; }
  .hpModal__header { padding: 20px 18px 14px; }
  .hpModal__title { font-size: 17px; }
  .hpModal__tableWrap { padding: 14px 12px 20px; }
  .hpTable th, .hpTable td { padding: 8px 10px; font-size: 12px; }
}

/* ===== CREDENTIALS STRIP ===== */
.credStrip {
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(90deg, rgba(201,168,76,0.04) 0%, rgba(255,255,255,0.02) 50%, rgba(201,168,76,0.04) 100%);
  padding: 22px 32px;
  overflow-x: auto;
}
.credStrip__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  width: min(1200px, 100%);
  margin: 0 auto;
}
.credBadge {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 22px;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  white-space: nowrap;
  transition: color 0.2s;
}
.credBadge:hover { color: #c9a84c; }
.credBadge i { font-size: 12px; color: rgba(240,242,246,0.40); }
.credDivider {
  width: 1px;
  height: 20px;
  background: rgba(255,255,255,0.10);
  flex-shrink: 0;
}
@media(max-width:768px){
  .credBadge { padding: 6px 14px; font-size: 10.5px; }
}

/* ===== WORLD MAP — PRESENCE OF UPKAR ===== */
.worldMapWrap {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.09);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.05), 0 24px 64px rgba(0,0,0,0.45), 0 0 60px rgba(201,168,76,0.07);
}
.worldMap {
  display: block;
  width: 100%;
  height: auto;
}
.mktRegions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 22px;
}
.mktRegion {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 16px;
  background: rgba(201,168,76,0.07);
  border: 1px solid rgba(201,168,76,0.18);
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.mktRegion i { color: rgba(240,242,246,0.35); font-size: 10px; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(201,168,76,0.22); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(201,168,76,0.42); }

/* ── D3 map country paths ── */
.country {
  fill: #141c2e;
  stroke: rgba(255,255,255,0.055);
  stroke-width: 0.4px;
  transition: fill 0.25s;
}
.country--export {
  fill: rgba(201,168,76,0.16);
  stroke: rgba(201,168,76,0.45);
  stroke-width: 0.7px;
}
.country--export:hover {
  fill: rgba(201,168,76,0.30);
  cursor: default;
}
/* India — more prominent highlight */
.country--india {
  fill: rgba(201,168,76,0.28) !important;
  stroke: rgba(201,168,76,0.7) !important;
  stroke-width: 1px !important;
}
.mapDot {
  filter: drop-shadow(0 0 5px rgba(201,168,76,0.85));
}

/* ===== POWER FINDER ===== */
.pf {
  max-width: 820px;
  margin: 0 auto;
}
.pf__steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 40px;
}
.pf__step {
  display: flex;
  align-items: center;
  gap: 10px;
  opacity: 0.35;
  transition: opacity 0.3s;
}
.pf__step--active,
.pf__step--done { opacity: 1; }
.pf__stepNum {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid rgba(201,168,76,0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: rgba(240,242,246,0.5);
  transition: all 0.3s;
}
.pf__step--active .pf__stepNum {
  border-color: #c9a84c;
  background: rgba(201,168,76,0.12);
  color: #c9a84c;
}
.pf__step--done .pf__stepNum {
  border-color: #c9a84c;
  background: #c9a84c;
  color: #05070d;
}
.pf__stepLabel {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--muted);
}
.pf__step--active .pf__stepLabel { color: var(--ink); }
.pf__stepLine {
  flex: 1;
  min-width: 40px;
  height: 1px;
  background: rgba(255,255,255,0.1);
  margin: 0 12px;
}

.pf__panel {
  display: none;
}
.pf__panel--active {
  display: block;
  animation: pfFadeIn 0.3s ease;
}
@keyframes pfFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.pf__question {
  text-align: center;
  font-size: clamp(16px, 2.5vw, 22px);
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 28px;
}
.pf__choices {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px;
}
.pf__choice {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 22px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: 14px;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, transform 0.15s;
  color: var(--muted);
  font-size: 13px;
  font-weight: 500;
  text-align: center;
  font-family: inherit;
}
.pf__choice i {
  font-size: 24px;
  color: rgba(201,168,76,0.65);
  transition: color 0.2s;
}
.pf__choice:hover {
  border-color: rgba(201,168,76,0.5);
  background: rgba(201,168,76,0.07);
  color: var(--ink);
  transform: translateY(-2px);
}
.pf__choice:hover i { color: #c9a84c; }
.pf__choice--selected {
  border-color: #c9a84c;
  background: rgba(201,168,76,0.12);
  color: var(--ink);
}
.pf__choice--selected i { color: #c9a84c; }

/* Result panel */
.pf__resultInner {
  text-align: center;
  padding: 40px 24px;
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 18px;
  background: rgba(201,168,76,0.05);
}
.pf__resultIcon {
  font-size: 48px;
  color: #c9a84c;
  margin-bottom: 16px;
}
.pf__resultTitle {
  font-size: clamp(18px, 3vw, 26px);
  font-weight: 700;
  margin: 0 0 12px;
  color: var(--ink);
}
.pf__resultDesc {
  color: var(--muted);
  font-size: 15px;
  max-width: 560px;
  margin: 0 auto 28px;
  line-height: 1.6;
}
.pf__resultActions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════════════════════════
   UPKAR LUXURY BRAND UPGRADE
   Cormorant Garamond · Deep Onyx · Warm Gold · Architectural Lines
   ═══════════════════════════════════════════════════════════════════ */

/* ── 1. Luxury tokens ──────────────────────────────────────────── */
:root {
  --fDisplay:   'Cormorant Garamond', 'Times New Roman', Georgia, serif;
  --gold:        #c9a84c;
  --gold-hi:     #dbbf6a;
  --gold-dim:    rgba(201,168,76,0.12);
  --onyx:        #02030a;
  --ink-prem:    #ebe7e0;
  --muted-prem:  rgba(235,231,224,0.48);
}

/* ── 2. Deeper base ────────────────────────────────────────────── */
body { background: var(--onyx); }

.bg__grid   { opacity: 0.14; }
.bg__noise  { opacity: 0.032; }
.bg__glow--a{ opacity: 0.14; }
.bg__glow--b{ opacity: 0.10; }

/* ── 3. Top bar ─────────────────────────────────────────────────── */
.topBar {
  background: #020308;
  border-bottom: 1px solid rgba(201,168,76,0.10);
}

/* ── 4. Preloader ───────────────────────────────────────────────── */
.preloader {
  background: var(--onyx);
}
.preloader__logo {
  width: 72px; height: 72px;
  border-radius: 6px;
  box-shadow: 0 0 48px rgba(201,168,76,0.18);
}
@keyframes preloaderPulse {
  0%,100%{ transform: scale(1);    box-shadow: 0 0 36px rgba(201,168,76,0.14); }
  50%    { transform: scale(1.04); box-shadow: 0 0 64px rgba(201,168,76,0.30); }
}
.preloader__bar {
  width: 120px;
  height: 1px;
  background: rgba(255,255,255,0.06);
}
.preloader__fill { background: linear-gradient(90deg, var(--gold), var(--gold-hi)); }
.preloader__text {
  font-size: 9px;
  letter-spacing: 0.36em;
  color: rgba(201,168,76,0.40);
  font-family: var(--fDisplay);
  font-style: italic;
}

/* ── 5. Header ──────────────────────────────────────────────────── */
.luxHeader { border-bottom-color: rgba(201,168,76,0.07); }
.luxNav { font-size: 10.5px; letter-spacing: 0.22em; }

.luxQuoteBtn {
  border-radius: 2px;
  border: 1px solid rgba(201,168,76,0.30);
  background: rgba(201,168,76,0.04);
  color: rgba(201,168,76,0.85);
  letter-spacing: 0.22em;
  font-size: 10px;
  padding: 10px 18px;
  transition: all .3s var(--easeOut2);
}
.luxQuoteBtn i { color: var(--gold); }
.luxQuoteBtn:hover {
  border-color: rgba(201,168,76,0.55);
  background: rgba(201,168,76,0.09);
  transform: none;
}
.luxHeader.is-scrolled .luxQuoteBtn {
  background: var(--gold);
  border-color: var(--gold);
  color: #020308;
}
.luxHeader.is-scrolled .luxQuoteBtn i { color: #020308; }

/* ── 6. Hero title ──────────────────────────────────────────────── */
.videoHero__title {
  font-family: var(--fDisplay);
  font-size: clamp(58px, 8vw, 130px);
  font-weight: 300;
  letter-spacing: 0.04em;
  line-height: 0.90;
  background: linear-gradient(160deg, #ffffff 0%, var(--gold-hi) 60%, rgba(201,168,76,0.70) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.videoHero__eyebrow {
  font-family: var(--fDisplay);
  font-style: italic;
  font-size: 15px;
  letter-spacing: 0.18em;
  color: rgba(201,168,76,0.75);
  opacity: 1;
}
.videoHero__sub {
  letter-spacing: 0.20em;
  color: rgba(235,231,224,0.65);
  font-size: 12px;
}

/* ── 7. Factory cine title ──────────────────────────────────────── */
.factoryCine__title {
  font-family: var(--fDisplay);
  font-weight: 300;
  font-size: clamp(50px, 6.5vw, 108px);
  letter-spacing: 0.04em;
  line-height: 0.90;
  background: linear-gradient(160deg, #ffffff 0%, var(--gold-hi) 60%, rgba(201,168,76,0.65) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.factoryCine__eyebrow {
  font-family: var(--fDisplay);
  font-style: italic;
  font-size: 14px;
  letter-spacing: 0.18em;
  color: rgba(201,168,76,0.72);
  opacity: 1;
}

/* ── 8. Section headings ────────────────────────────────────────── */
.section__title {
  font-family: var(--fDisplay);
  font-size: clamp(36px, 4.5vw, 66px);
  font-weight: 300;
  letter-spacing: 0.02em;
  line-height: 1.05;
}
.section__eyebrow {
  font-size: 9.5px;
  letter-spacing: 0.34em;
  color: var(--gold);
  opacity: 1;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.section__eyebrow::before,
.section__eyebrow::after {
  content: '';
  display: inline-block;
  width: 22px;
  height: 1px;
  background: var(--gold);
  opacity: 0.38;
}

/* ── 9. Showcard — luxury architectural ────────────────────────── */
.showCard {
  border-radius: 4px;
  border: 1px solid rgba(201,168,76,0.10);
  background: #06080e;
  box-shadow:
    0 1px 0 rgba(201,168,76,0.05) inset,
    0 24px 56px rgba(0,0,0,0.48);
  transition:
    border-color .55s var(--easeOut2),
    box-shadow   .55s var(--easeOut2),
    transform    .55s var(--easeOut2);
}
/* Thin gold top accent that sweeps in on hover */
.showCard::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(201,168,76,0.0) 10%,
    rgba(201,168,76,0.75) 50%,
    rgba(201,168,76,0.0) 90%,
    transparent 100%);
  opacity: 0;
  transition: opacity .55s var(--easeOut2);
  z-index: 3;
}
.showCard:hover { border-color: rgba(201,168,76,0.26); transform: translateY(-6px); }
.showCard:hover::before { opacity: 1; }
.showCard:hover { box-shadow: 0 2px 0 rgba(201,168,76,0.14) inset, 0 36px 80px rgba(0,0,0,0.55), 0 0 50px rgba(201,168,76,0.05); }

.showCard__img {
  height: 300px;
  background: radial-gradient(ellipse 70% 60% at 50% 80%, rgba(12,14,22,0.0), rgba(6,8,14,0.0)),
              linear-gradient(170deg, #0c0f1c 0%, #06080e 100%);
  border-bottom: 1px solid rgba(201,168,76,0.07);
}
/* Remove old gradient rule */
.showCard__img::before { display: none; }

.showCard__body {
  padding: 34px 36px 40px;
  position: relative;
}
/* Thin rule between image and body */
.showCard__body::before {
  content: '';
  position: absolute;
  top: 0; left: 36px; right: 36px;
  height: 1px;
  background: linear-gradient(90deg,
    rgba(201,168,76,0.24) 0%,
    rgba(201,168,76,0.08) 60%,
    transparent 100%);
}

.showCard__badge {
  border-radius: 2px;
  padding: 4px 10px;
  font-size: 9px;
  letter-spacing: 0.30em;
  font-weight: 700;
  color: var(--gold);
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.20);
  margin-bottom: 20px;
}

.showCard__name {
  font-family: var(--fDisplay);
  font-size: clamp(30px, 3.2vw, 44px);
  font-weight: 300;
  letter-spacing: 0.02em;
  line-height: 1.0;
  margin: 0 0 14px;
  color: var(--ink-prem);
}

.showCard__desc {
  font-size: 13.5px;
  line-height: 1.85;
  letter-spacing: 0.01em;
  color: var(--muted-prem);
  margin-bottom: 22px;
}

.showCard__link {
  font-size: 10.5px;
  letter-spacing: 0.18em;
  color: rgba(201,168,76,0.60);
  gap: 8px;
}
.showCard:hover .showCard__link {
  color: var(--gold);
  gap: 14px;
}

/* ── 10. Stats counters ─────────────────────────────────────────── */
.statItem {
  border-radius: 4px;
  border-color: rgba(201,168,76,0.08);
  background: rgba(201,168,76,0.02);
}
.statItem::before {
  height: 1px;
  left: 25%; right: 25%;
  background: linear-gradient(90deg, transparent, rgba(201,168,76,0.50), transparent);
  border-radius: 0;
}
.statItem__number {
  font-family: var(--fDisplay);
  font-size: clamp(44px, 5.5vw, 72px);
  font-weight: 400;
  background: linear-gradient(135deg, var(--ink-prem), var(--gold));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.statItem__label {
  letter-spacing: 0.26em;
  font-size: 10px;
  color: var(--muted-prem);
}
.statItem__bar {
  background: linear-gradient(90deg, var(--gold), rgba(201,168,76,0.30));
  height: 1px;
  border-radius: 0;
  opacity: 0.55;
  width: 32px;
}

/* ── 11. Marquee ────────────────────────────────────────────────── */
.marquee {
  border-radius: 0;
  border-left: none;
  border-right: none;
  border-color: rgba(201,168,76,0.07);
  background: rgba(0,0,0,0.16);
}
.marquee__text {
  -webkit-text-stroke: 1px rgba(201,168,76,0.14);
  text-stroke: 1px rgba(201,168,76,0.14);
  letter-spacing: 0.14em;
}

/* ── 12. Buttons ────────────────────────────────────────────────── */
.btn {
  border-radius: 2px;
  letter-spacing: 0.16em;
  font-size: 11px;
}
.btn--primary {
  background: linear-gradient(135deg, var(--gold) 0%, #a8892e 100%);
  border-color: rgba(201,168,76,0.40);
  color: #020308;
  box-shadow: 0 4px 20px rgba(201,168,76,0.20);
}
.btn--primary:hover {
  background: linear-gradient(135deg, var(--gold-hi) 0%, #b8992e 100%);
  box-shadow: 0 8px 32px rgba(201,168,76,0.34);
}
.btn--ghost { border-radius: 2px; border-color: rgba(255,255,255,0.08); }

/* ── 13. CTA section ────────────────────────────────────────────── */
.cta { border-radius: 4px; border-color: rgba(201,168,76,0.08); }
.cta__title {
  font-family: var(--fDisplay);
  font-size: clamp(38px, 4vw, 58px);
  font-weight: 300;
  letter-spacing: 0.02em;
  line-height: 1.05;
}
.cta__form .btn--submit {
  border-radius: 2px;
  letter-spacing: 0.22em;
  background: var(--gold);
  border-color: var(--gold);
  color: #020308;
  font-weight: 700;
  box-shadow: 0 4px 20px rgba(201,168,76,0.22);
}
.cta__form .btn--submit:hover {
  background: var(--gold-hi);
  box-shadow: 0 8px 32px rgba(201,168,76,0.36);
  transform: translateY(-2px);
}

/* ── 14. Section divider ────────────────────────────────────────── */
.sectionDivider {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(201,168,76,0.08) 20%,
    rgba(201,168,76,0.20) 50%,
    rgba(201,168,76,0.08) 80%,
    transparent 100%);
  height: 1px;
  margin: 72px 0;
}

/* ── 15. Section --alt panels ───────────────────────────────────── */
.section--alt {
  border-radius: 4px;
  border-color: rgba(201,168,76,0.06);
  background: rgba(201,168,76,0.015);
}

/* ── 16. Card component ─────────────────────────────────────────── */
.card {
  border-radius: 4px;
  border-color: rgba(201,168,76,0.08);
  background: linear-gradient(170deg, rgba(201,168,76,0.03), rgba(0,0,0,0.06));
}
.card h3 { font-family: var(--fDisplay); font-weight: 400; }

/* ── 17. Panel component ────────────────────────────────────────── */
.panel { border-radius: 4px; border-color: rgba(201,168,76,0.07); }
.panel h3 { font-family: var(--fDisplay); font-weight: 400; }

/* ── 18. Footer ─────────────────────────────────────────────────── */
.footer {
  background: #020308;
  border-top: 1px solid rgba(201,168,76,0.14);
}

/* ── 19. Scroll pill ────────────────────────────────────────────── */
.scrollPill {
  border-radius: 1px;
  border-color: rgba(201,168,76,0.20);
  background: rgba(201,168,76,0.04);
  color: rgba(201,168,76,0.65);
  letter-spacing: 0.22em;
  font-size: 10px;
}

/* ── 20. UpkarGPT panel ─────────────────────────────────────────── */
.upkargpt__card h3,
.upkargpt__cta h3 {
  font-family: var(--fDisplay);
  font-size: 32px;
  font-weight: 400;
}
.upkargpt__badge {
  border-radius: 2px;
  background: rgba(201,168,76,0.07);
  border-color: rgba(201,168,76,0.18);
}
.upkargpt__card, .upkargpt__panel {
  border-radius: 4px;
  border-color: rgba(201,168,76,0.07);
}

/* ── 21. Input fields ───────────────────────────────────────────── */
.input {
  border-radius: 2px;
  border-color: rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.03);
  color: var(--ink-prem);
}
.input:focus { border-color: rgba(201,168,76,0.42); box-shadow: 0 0 0 3px rgba(201,168,76,0.07); }

/* ── 22. certRow / cert badge ───────────────────────────────────── */
.cert {
  border-radius: 2px;
  border-color: rgba(201,168,76,0.14);
  background: rgba(201,168,76,0.03);
  color: rgba(201,168,76,0.75);
}

/* ── 23. Cursor refinement ──────────────────────────────────────── */
.cursor { border-color: rgba(201,168,76,0.35); }
.cursor__dot { background: var(--gold); }
.cursor.hover { border-color: rgba(201,168,76,0.60); background: rgba(201,168,76,0.04); }

/* ── 24. Luxury title utility class ─────────────────────────────── */
.luxTitle {
  font-family: var(--fDisplay);
  font-weight: 300;
  letter-spacing: 0.03em;
}

/* ── 25. Hero → about & product page page-level title blocks ────── */
.videoHero__content .btn--primary { color: #020308; }

/* ── 26. Indeng table ───────────────────────────────────────────── */
.indEng__tableWrap {
  border-color: rgba(201,168,76,0.12);
  border-radius: 4px;
}

/* ── 27. Mobile menu ────────────────────────────────────────────── */
.luxMobile {
  border-radius: 4px;
  border-color: rgba(201,168,76,0.10);
  background: rgba(2,3,8,0.88);
}
.luxMobile__cta {
  background: rgba(201,168,76,0.09) !important;
  border: 1px solid rgba(201,168,76,0.22);
}
