@font-face {
  font-family: "MonumentExtended";
  src: url("../fonts/MonumentExtended-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "MonumentExtended";
  src: url("../fonts/MonumentExtended-Ultrabold.otf") format("opentype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

:root{
  /* extracted from logo */
  --brand2:#092B4F;   /* deep navy */
  --brand:#256288;    /* primary blue */
  --steel:#58748B;    /* steel blue */
  --gray:#99A2A9;     /* light gray */
  --offwhite:#FCFCFD; /* off-white */

  --ink:#0b1f3a;
  --muted:#6b7a90;
  --bg:#FBFEF1;
  --card:#ffffff;
  --stroke:rgba(9, 43, 79, .14);
  --radius:22px;
  --shadow: 0 18px 50px rgba(11, 31, 58, .12);
  --shadow2: 0 10px 26px rgba(11, 31, 58, .10);
  --border: rgba(0, 0, 0, .09);
  --shadow-sm: 0 2px 12px rgba(0, 0, 0, .06);

  --gold:#b88000; --gold-lt:#fffbf0; --gold-mid:#e8d080; --gold-dark:#8a5e00;
  --amber:#d46000; --amber-lt:#fff5ec;
  --volt:#5a9a00; --volt-lt:#f0f7e6;

  --cream:   #F2F2E8;
  --cream2:  #EAEADA;
  --navy:    #1B2A4A;
  --navy2:   #243358;
  --orange:  #E8601C;
  --orange2: #D4551A;
  --teal:    #1E4A5C;
  --teal2:   #163848;
  --white:   #FFFFFF;
  --gray:    #666666;
   --text:    #1B2B4B;
  --text-mid:#4A5568;
    --orange-lt: rgba(232,119,34,0.10);
  --orange-lt2: rgba(232,119,34,0.06);
  --text-lt: #7A8A9A;
  --border1:  rgba(27,42,74,0.12);
  --border2: rgba(27,43,75,0.14);
 --shadow:  0 2px 16px rgba(27,43,75,0.07);
  --shadow-md: 0 6px 32px rgba(27,43,75,0.10);
  --shadow-lg: 0 16px 56px rgba(27,43,75,0.13);
 
    --font-body: "Poppins", sans-serif;
  --font-heading: "MonumentExtended", sans-serif;
}

*{ font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }
body{ background: var(--bg); color: var(--ink);font-family: var(--font-body); }
p,
a,
li,
button,
input,
textarea,
label,
span{
  font-family: var(--font-body);
}

h1,h2,h3,h4,h5,h6{
  font-family: var(--font-heading);
}
.nav-link,
.hero-cert-item,
.btn,
.small-muted,
.footer-link,
.value-text{
  font-family: var(--font-body);
}

.section-title,
.product-heading,
.footer-title,
.value-title,
.brand-name{
  font-family: var(--font-heading);
}

section {
  overflow: hidden;
}
.font-heading{
  font-family: var(--font-heading) !important;
}

.font-body{
  font-family: var(--font-body) !important;
}
.text-ink-78{ color: rgba(11,31,58,.78); }

/* Background lines / soft gradients */
.bg-lines{ position: relative; overflow-x: hidden; }
.bg-lines:before,
.bg-lines:after{
  content:"";
  position:absolute;
  inset:-40%;
  background:
    radial-gradient(circle at 20% 10%, rgba(37,98,136,.12), transparent 45%),
    radial-gradient(circle at 80% 20%, rgba(9,43,79,.10), transparent 45%),
    radial-gradient(circle at 60% 90%, rgba(88,116,139,.09), transparent 45%),
    repeating-linear-gradient(90deg, rgba(11,31,58,.05) 0 1px, transparent 1px 140px);
  transform: rotate(-8deg);
  pointer-events:none;
  z-index:0;
}
.bg-lines > *{ position: relative; z-index:1; }

/* NAVBAR LAYOUT */

.navbar{
  padding: 14px 0;
}

/* center menu */

.nav-center{
  margin: auto;
  gap: 30px;
}

.nav-link{
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: #0d2a44;
}

.nav-link:hover{
  color: #0b4f8f;
}

/* right button */

.nav-right{
  margin-left: 0;
}

/* brochure button */

.btn-pill{
  border-radius: 50px;
  padding: 8px 20px;
  font-size: 14px;
}

.logo-img{
  /*width: 44px;*/
  height: 85px;
  /*object-fit: contain;*/
  /*border-radius: 10px;*/
  /*background: rgba(255,255,255,.65);*/
  /*border: 1px solid var(--stroke);*/
  /*padding: 6px;*/
  /*box-shadow: 0 10px 22px rgba(9,43,79,.10);*/
}

.footer-logo{
  /* width: 48px; */
  height: 90px;
}


.btn-primary{
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  border: 0;
}
.btn-primary:hover{ filter: brightness(1.03); }

.btn-pill{ border-radius: 999px; padding: 10px 16px; font-weight: 900; }

.hero-section{
  position: relative;
  overflow: hidden;
  padding-top: 20px;
  padding-bottom: 44px;
  margin-left: 50px;
  margin-right: 50px;
}
.py-5 {
  padding-top:7rem !important;
  padding-bottom:7rem !important;
}
.pb-0 {
  padding-bottom: 0 !important;
}
.hero-wrap{
  position: relative;
  z-index: 3;
  text-align: center;
}

.hero-marquee{
  position: absolute;
  top: 58px;
  left: 0;
  width: 100%;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
  mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
}

.hero-marquee-track{
  display: flex;
  gap: 110px;
  width: max-content;
  white-space: nowrap;
  animation: heroMarquee 36s linear infinite;
}

.hero-marquee-track span{
  font-size: clamp(5rem, 16vw, 11rem);
  font-weight: 800;
  line-height: .86;
  letter-spacing: -4px;
  text-transform: lowercase;
  color: transparent;
  -webkit-text-stroke: 1px rgba(88, 116, 139, 0.16);
  user-select: none;
}

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

.hero-title {
  position: relative;
  z-index: 3;
  margin: 10px 0 34px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1.1;
  letter-spacing: 1px;
  font-size: clamp(2rem, 5.8vw, 4.5rem);
}

.hero-bg-img {
  background-position:center ;
}
.hero-title span {
  display: inline-block;
  background: linear-gradient(180deg, #0b4f8f 0%, #2d73c7 62%, #93bde900 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 10px 18px rgba(37, 98, 136, 0.10);
  font-family: var(--font-heading);
}

/* Cursor */
#typewriter::after {
  content: "|";
  margin-left: 5px;
  animation: blink 1s infinite;
}

@keyframes blink {
  0%, 50%, 100% { opacity: 1; }
  25%, 75% { opacity: 0; }
}

/* .hero-title{
  position: relative;
  z-index: 3;
  margin: 10px 0 34px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1.1;
  letter-spacing: 1px;
  font-size: clamp(2.5rem, 5.8vw, 5.2rem);
}

.hero-title span{
  display: inline-block;
  background: linear-gradient(180deg, #0b4f8f 0%, #2d73c7 62%, #93bde900 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 10px 18px rgba(37, 98, 136, 0.10);
  font-family: var(--font-heading);
} */

.hero-media {
  position: relative;
  z-index: 3;
  margin-top: 10px;
}

.hero-stack-wrap {
  position: relative;
  width: 100%;
  max-width: 1900px;
  margin: 0 auto;
}

.hero-stack-slider {
  position: relative;
  width: 100%;
  height: 620px;
  overflow: hidden;
  touch-action: pan-y;
  user-select: none;
  cursor: grab;
  perspective: 1200px;
}

.hero-stack-slider.is-dragging {
  cursor: grabbing;
}

.hero-stack-slide {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(64vw, 1160px);
  will-change: transform, opacity, filter;
  backface-visibility: hidden;
  transform-style: preserve-3d;
  transform-origin: center center;
}

.hero-slide-card {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  background: #0c1724;
  border: 2px solid transparent;
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.10);
  backface-visibility: hidden;
  transform: translateZ(0);
}

/* Important: apply same style to video also */
.hero-slide-card img,
.hero-slide-card video,
.hero-video {
  display: block;
  width: 100%;
  height: 540px;
  object-fit: cover;
  border-radius: 24px;
  /* pointer-events: none; */
  backface-visibility: hidden;
  transform: translateZ(0);
}

.hero-stack-slide.is-active {
  z-index: 5;
}

.hero-stack-slide.is-active .hero-slide-card {
  border-color: rgba(75, 85, 99, 0.55);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
}

/* arrows */
.hero-stack-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 54px;
  height: 54px;
  border: none;
  border-radius: 50%;
  background: rgba(9, 43, 79, 0.55);
  color: #fff;
  display: grid;
  place-items: center;
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
  z-index: 20;
  transition: transform .25s ease, background .25s ease, opacity .25s ease;
}

.hero-stack-arrow:hover {
  background: rgba(9, 43, 79, 0.72);
}

.hero-stack-arrow span {
  font-size: 24px;
  line-height: 1;
}

.hero-stack-prev {
  left: 35px;
}

.hero-stack-next {
  right: 35px;
}

/* play button */
.hero-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 72px;
  height: 72px;
  border: none;
  border-radius: 999px;
  background: rgba(9, 43, 79, 0.42);
  backdrop-filter: blur(8px);
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
  display: grid;
  place-items: center;
  transition: transform .25s ease, background .25s ease;
  z-index: 6;
}

.hero-play-btn:hover {
  transform: translate(-50%, -50%) scale(1.06);
  background: rgba(9, 43, 79, 0.56);
}

.hero-play-icon {
  width: 0;
  height: 0;
  margin-left: 4px;
  border-left: 18px solid #fff;
  border-top: 11px solid transparent;
  border-bottom: 11px solid transparent;
}

@media (max-width: 991.98px) {
  .hero-stack-slider {
    height: 430px;
  }

  .hero-stack-slide {
    width: min(82vw, 900px);
  }

  .hero-slide-card,
  .hero-slide-card img,
  .hero-slide-card video,
  .hero-video {
    border-radius: 20px;
  }

  .hero-slide-card img,
  .hero-slide-card video,
  .hero-video {
    height: 360px;
  }

  .hero-stack-prev {
    left: 14px;
  }

  .hero-stack-next {
    right: 14px;
  }
}

@media (max-width: 575.98px) {
  .hero-stack-slider {
    height: 260px;
  }
  .cta-section {
    padding:3rem 15px;
  }
  .gallery-card {
    min-height: 300px !important;
  }
  .strip-num {
    font-size:1.5rem;
  }

  .hero-stack-slide {
    width: 75vw;
  }

  .hero-slide-card,
  .hero-slide-card img,
  .hero-slide-card video,
  .hero-video {
    border-radius: 16px;
  }

  .hero-slide-card img,
  .hero-slide-card video,
  .hero-video {
    height: 240px;
  }

  .hero-play-btn {
    width: 58px;
    height: 58px;
  }

  .hero-play-icon {
    border-left: 14px solid #fff;
    border-top: 9px solid transparent;
    border-bottom: 9px solid transparent;
  }

  .hero-stack-arrow {
    width: 42px;
    height: 42px;
  }

  .hero-stack-arrow span {
    font-size: 18px;
  }

  .hero-stack-prev {
    left: 10px;
  }

  .hero-stack-next {
    right: 10px;
  }
}

.hero-certificates{
  position: relative;
  z-index: 3;
  margin-top: 70px;
  display: flex;
  justify-content: center;
  flex-direction: column;
    align-items: center;
}
.hero-cert-line{
  width: 30%;
  height: 1px;
  background: rgba(16,55,100,.28);
  flex: 0 0 auto;
}
.hero-cert-frame{
  position: relative;
  width: min(620px, 100%);
  padding: 18px 0;
}

.hero-cert-item img{
  max-height: 110px;
  width: auto;
  object-fit: contain;
  display: block;
  opacity: 0.95;
  transition: transform .3s ease, opacity .3s ease;
}

.hero-cert-item img:hover{
  transform: scale(1.05);
  opacity: 1;
}

.hero-cert-frame::before,
.hero-cert-frame::after{
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 250px;
  height: 1px;
  background: rgba(16, 55, 100, .30);
}
.hero-cert-frame::before{
  top: 0;
}

.hero-cert-frame::after{
  bottom: 0;
}

/* CERTIFICATE MARQUEE */

.hero-cert-marquee{
  position: relative;
  overflow: hidden;
  width: 100%;
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 10%,
    black 90%,
    transparent 100%
  );

  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 10%,
    black 90%,
    transparent 100%
  );
  padding: 20px 0;
}

.hero-cert-track{
  display: flex;
  gap: 10px;
  width: max-content;
  animation: certMarquee 18s linear infinite;
}

.hero-cert-item{
  font-size: 16px;
  line-height: 1.2;
  color: #103764;
  text-align: center;
  white-space: nowrap;
  opacity: .85;
}

/* marquee animation */

@keyframes certMarquee{

  from{
    transform: translateX(0);
  }

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

}

.modal{
  z-index: 99999;
}

.modal-backdrop{
  z-index: 99998;
}

.hero-video-modal{
  background: #fff;
}

@media (max-width: 991.98px){
  .navbar-collapse{
    text-align: start;
  }

  .nav-center{
   margin-top:10px;
   margin-bottom: 0;
    gap: 0px;
  }

  .nav-right{
    margin-left: 0;
    margin-top: 10px;
  }
  .hero-marquee{
    top: 70px;
  }

  .hero-marquee-track span{
    font-size: clamp(4rem, 18vw, 8rem);
    letter-spacing: -2px;
  }

  .heroMainSlider .swiper-slide{
    width: 82%;
  }

  .heroMainSlider .swiper-slide-prev{
    transform: translateX(55px) scale(.88);
  }

  .heroMainSlider .swiper-slide-next{
    transform: translateX(-55px) scale(.88);
  }

  .hero-slide-card img{
    height: 250px;
  }

  .hero-cert-frame::before,
  .hero-cert-frame::after{
    width: 180px;
  }

  .hero-cert-line{
    width: 80px;
  }
}

@media (max-width: 767.98px){
  .hero-section{
    padding-bottom: 30px;
  }

  .hero-title{
    margin-bottom: 26px;
  }

  .hero-marquee{
    top: 78px;
  }

  .hero-marquee-track{
    gap: 70px;
  }

  .hero-marquee-track span{
    font-size: clamp(3.6rem, 20vw, 6rem);
  }

  .heroMainSlider .swiper-slide{
    width: 88%;
    filter: brightness(.55) saturate(.7);
  }

  .heroMainSlider .swiper-slide-prev{
    transform: translateX(28px) scale(.92);
  }

  .heroMainSlider .swiper-slide-next{
    transform: translateX(-28px) scale(.92);
  }

  .hero-slide-card img{
    height: 220px;
  }

  .hero-play-btn{
    width: 62px;
    height: 62px;
  }

  .hero-play-icon{
    border-left: 16px solid #fff;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
  }

  .hero-certificates{
    margin-top: 22px;
  }

  .hero-cert-frame{
    padding: 14px 0;
  }

  .hero-cert-frame::before,
  .hero-cert-frame::after{
    width: 120px;
  }

  .hero-cert-item{
    font-size: 13px;
    padding: 0 14px;
  }
}

/* Responsive */
@media (max-width: 991.98px){
  .hero-bg-outline{
    top: 70px;
    font-size: clamp(4rem, 18vw, 8rem);
    letter-spacing: -2px;
  }

  .heroMainSlider .swiper-slide{
    width: 82%;
  }

  .hero-slide-card img{
    height: 250px;
  }

  .hero-cert-line{
    width: 80px;
  }
}

@media (max-width: 767.98px){
  .hero-section{
    padding-bottom: 30px;
  }

  .hero-bg-outline{
    top: 78px;
    font-size: clamp(3.6rem, 20vw, 6rem);
  }

  .hero-title{
    margin-bottom: 26px;
  }

  .heroMainSlider .swiper-slide{
    width: 88%;
    opacity: .55;
    transform: scale(.92);
  }

  .hero-slide-card img{
    height: 220px;
  }

  .hero-play-btn{
    width: 64px;
    height: 64px;
  }

  .hero-play-icon{
    border-left: 16px solid #fff;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
  }

  .hero-certificates{
    margin-top: 24px;
    gap: 8px;
  }

  .hero-cert-line{
    display: none;
  }

  .hero-cert-item{
    font-size: 13px;
    padding: 0 12px;
  }
}


/* Badge row */
.badge-row{
  display:flex;
  gap: 12px;
  align-items:center;
  justify-content:center;
  flex-wrap: wrap;
  padding: 14px 0 10px;
}
.mini-badge{
  background: #fff;
  border: 1px solid var(--stroke);
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 400;
  font-size: 12px;
  color: rgba(9,43,79,.78);
  box-shadow: 0 10px 20px rgba(11,31,58,.06);
}

/* =========================
   VALUE + FEATURE SECTION
========================= */
.value-feature-section{
  position: relative;
  padding: 50px 0 50px;
  overflow: hidden;
}

.value-bg-color{
  position: absolute;
    top: 40%;
    left: -100px;
    width: 20%;
    height: 20%;
    z-index: 0;
    background: linear-gradient(270deg, #0B2F51 0%, #2F79C0 44.23%, #0B2F51 100%);
    filter: blur(150px);
    opacity: 1;
}
.value-bg-shape{
  position: absolute;
  top: 18px;
  right: -20px;
  width: min(360px, 34vw);
  z-index: 1;
  pointer-events: none;
  opacity: .55;
}

.value-bg-shape img{
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  filter: saturate(.85) contrast(.95);
}

.value-feature-section .container{
  position: relative;
  z-index: 2;
}

/* VALUE PROP */
.value-wrap{
  padding: 0 0 34px;
  text-align: center;
}

.value-title{
  /* max-width: 860px; */
  margin: 0 auto;
  font-size: clamp(1.4rem, 2.4vw, 2.1rem);
  line-height: 1.2;
  font-weight: 400;
  color: var(--brand2);
  letter-spacing: 0;
}

.value-text{
  max-width: 760px;
  margin: 16px auto 0;
  color: var(--brand2);
  opacity: .82;
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.55;
  font-weight: 400;
}

/* FEATURE GRID */
.feature-grid{
  padding: 6px 0 0;
}

.feature-item{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

.feature-item:hover,
.feature-item:focus{
  text-decoration: none;
  color: inherit;
}



.feature-item:hover .feature-card img{
  transform: scale(1.06);
}

.feature-item:hover .feature-label{
  transform: translateY(4px);
}
.feature-card{
  width: 100%;
  /* max-width: 170px; */
  height: 230px;
  border-radius: 6px;
  overflow: hidden;
  background: transparent;
  border: 0;
  box-shadow: none;

  transform-origin: center center;

  will-change: transform;
}

.feature-card img{
    transform: scale(1);
    
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 6px;
  transition: transform .35s ease;
}
.feature-label{
  margin: 12px 0 0;
  color: var(--brand2);
  font-size: 15px;
  line-height: 1.05;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0;
  transition: transform .35s ease;
}

.feature-item:hover .feature-label{
  transform: translateY(4px);
}

/* custom 4-column width closer to screenshot */
@media (min-width: 992px){
  .col-lg-custom-5{
    flex: 0 0 auto;
    width: 20%;
  }
}

/* tablet */
@media (max-width: 991.98px){
  .value-feature-section{
    padding: 38px 0 28px;
  }

  .value-bg-shape{
    width: min(280px, 38vw);
    top: 24px;
    right: -40px;
    opacity: .42;
  }

  .value-title{
    max-width: 760px;
    font-size: clamp(1.25rem, 3vw, 1.8rem);
  }

  .value-text{
    max-width: 680px;
    font-size: 13px;
  }

  .feature-card{
    max-width: 160px;
    height: 220px;
  }

  .feature-label{
    font-size: 14px;
  }
}

/* mobile */
@media (max-width: 767.98px){
  .value-feature-section{
    padding: 30px 0 20px;
  }

  .value-bg-shape{
    width: 180px;
    top: 10px;
    right: -50px;
    opacity: .28;
  }

  .value-wrap{
    padding-bottom: 24px;
  }

  .value-title{
    font-size: 1.15rem;
    line-height: 1.28;
    max-width: 100%;
  }

  .value-text{
    font-size: 12px;
    line-height: 1.5;
    max-width: 100%;
    margin-top: 12px;
  }

  .feature-grid .row{
    row-gap: 20px;
  }

  .feature-card{
    max-width: 150px;
    height: 200px;
  }

  .feature-label{
    margin-top: 10px;
    font-size: 13px;
    line-height: 1.05;
  }
}

/* =========================
   ABOUT SECTION
========================= */
.mission-vision-section {
  position: relative;
}

/* ---- Tabs Wrapper ---- */
.mission-tabs {
  display: inline-flex;
  background: #0b4f8f;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 30px;
  padding: 6px;
  gap: 1px;
  flex-wrap: wrap;
}

/* tab button */
.mission-tabs .nav-link {
  position: relative;
  padding: 12px 24px;
  border-radius: 50px;
  border: 1px solid transparent;
  background: transparent !important;
  color: rgba(255,255,255,0.75);
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
  z-index: 1;
}

/* hover */
.mission-tabs .nav-link:hover {
  color: #fff;
  background: rgba(255,255,255,0.10) !important;
  border-color: rgba(255,255,255,0.15);
}

/* active base */
.mission-tabs .nav-link.active {
  color: #fff !important;
}

/* mission active */
.mission-tabs .nav-link#mission-tab.active {
  background: rgba(56,189,248,0.18) !important;
  border: 1px solid rgba(56,189,248,0.35);
}

/* vision active */
.mission-tabs .nav-link#vision-tab.active {
  background: rgba(52,211,153,0.18) !important;
  border: 1px solid rgba(52,211,153,0.35);
}

/* values active */
.mission-tabs .nav-link#values-tab.active {
  background: rgba(251,191,36,0.18) !important;
  border: 1px solid rgba(251,191,36,0.35);
}

/* ---- Content Panel ---- */
.tab-content {
  position: relative;
}

.tab-pane.fade {
  transition: opacity 0.15s ease;
}

.mission-card {
  background: #0b4f8f;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(13, 38, 76, 0.08);
  border: 1px solid #edf2f7;
  min-height: 420px;
}

@media (max-width: 991.98px) {
  .mission-card {
    min-height: auto;
  }
}

.mission-left h3 {
  font-size: clamp(1.8rem, 3vw, 2.5rem);
  font-weight: 700;
  color: white;
}

.mission-left p, .mission-left ul li {
  color: white;
  line-height: 1.8;
  font-size: 18px;
  margin-bottom: 12px;
}

.mission-media {
  overflow: hidden;
  position: relative;
  height: 100%;
}
.mission-card {
    min-height: 500px; /* same height for all tabs */
    display: flex;
    align-items: stretch;
}

.mission-card .row {
    width: 100%;
}

.mission-left,
.mission-media {
    height: 100%;
}
.mission-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.mission-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.mission-media img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
  transform: scale(1);
  opacity: 1;
  transition: transform 0.8s ease, opacity 0.35s ease;
  will-change: transform;
  backface-visibility: hidden;
}

.mission-media:hover img {
  transform: scale(1.03);
}

.mission-media img.img-zoom-animate {
  transform: scale(1.04);
}


/* =========================
   PRODUCTS + STATS SECTION
========================= */
.products-area{
  position: relative;
  padding: 150px 0 100px;
  overflow: hidden;
  background: #FBFEF1;
}

.products-area .container{
  position: relative;
  z-index: 3;
}

/* exact decorative track layer */
.products-bg-track{
  position: absolute;
  left: 0px;
  bottom: -180px;
  width: 1480px;
  height: auto;
  z-index: 1;
  opacity: 0.53;
  pointer-events: none;
}

.products-bg-track img{
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* soft fade so track dissolves into background */
.products-bg-fade{
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(
      ellipse at 20% 78%,
      rgba(251,254,241,0) 0%,
      rgba(251,254,241,0.08) 18%,
      rgba(251,254,241,0.28) 34%,
      rgba(251,254,241,0.62) 52%,
      rgba(251,254,241,0.90) 72%,
      rgba(251,254,241,1) 100%
    );
}

/* faint outline word in top-right */
.products-bg-word{
  position: absolute;
  right: 22px;
  top: 8px;
  z-index: 2;
  font-size: clamp(6rem, 16vw, 11rem);
  line-height: .82;
  color: transparent;
  -webkit-text-stroke: 1px rgba(24,60,95,.07);
  user-select: none;
  pointer-events: none;
}

/* content above bg */
.products-area .container{
  position: relative;
  z-index: 3;
}

/* PRODUCTS */
.product-section{
  padding: 0 0 52px;
}

.product-copy{
  max-width: 370px;
}

.product-heading{
  color: var(--brand2);
  font-weight: 400;
  font-size: clamp(2.1rem, 4vw, 3.1rem);
  line-height: .9;
  margin-bottom: 26px;
}

.product-visual{
  position: relative;
  text-align: center;
  min-height: 370px;
  display: grid;
  place-items: center;
}

.product-visual img{
  width: min(100%, 610px);
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 18px 24px rgba(0,0,0,.12));
}

.product-list-wrap{
  display: flex;
  flex-direction: column;
  gap: 0;
}

.product-item{
  border-bottom: 1px solid rgba(16,55,100,.35);
  padding: 12px 0 10px;
  cursor: pointer;
  outline: none;
  transition: transform .25s ease;
}

.product-item:first-child{
  padding-top: 0;
}

.product-item:hover,
.product-item:focus{
  transform: translateX(3px);
}

.product-link{
  display: inline-block;
  color: var(--brand2);
  font-size: 1rem;
  line-height: 1.1;
  font-weight: 400;
  transition: opacity .25s ease;
}

.product-item:not(.active) .product-link{
  opacity: .92;
}

.product-item.active .product-link,
.product-item:hover .product-link,
.product-item:focus .product-link{
  opacity: 1;
}

/* hidden by default, visible for active tab */
.product-desc-wrap{
  display: none;
  padding-top: 10px;
  max-width: 260px;
}

.product-item.active .product-desc-wrap{
  display: block;
}

.product-desc{
  margin: 0 0 8px;
  color: var(--brand2);
  opacity: .82;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 400;
  font-family: var(--font-body);
}

.product-view-more{
  display: inline-block;
  color: var(--brand2);
  font-size: 12px;
  line-height: 1.2;
  text-decoration: none;
  font-weight: 400;
  transition: opacity .25s ease, transform .25s ease;
}

.product-view-more:hover{
  opacity: .75;
  transform: translateX(2px);
}

.product-visual{
  position: relative;
  text-align: center;
  min-height: 360px;
  display: grid;
  place-items: center;
}

.product-visual img{
  max-width: 100%;
  width: 100%;
  display: block;
  margin: 0 auto;
  object-fit: contain;
  filter: drop-shadow(0 20px 30px rgba(0,0,0,.12));
  transition: opacity .22s ease, transform .22s ease;
}

.product-visual.is-switching img{
  opacity: 1;
  transform: scale(.985);
}

/* STATS */
.stats{
  padding: 18px 0 0;
}

.stat-card{
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(16,55,100,.35);
  border-radius: 4px;
  box-shadow: none;
  padding: 40px;
  min-height: 96px;
  transition: transform .25s ease, background .25s ease;
}

.stat-card:hover{
  transform: translateY(-4px);
  background: rgba(255,255,255,.32);
}

.stat-num{
  font-weight: 400;
  color: var(--brand2);
  font-size: clamp(1.8rem, 3vw, 2.3rem);
  line-height: 1;
  margin-bottom: 5px;
}

.stat-label{
  color: var(--brand2);
  opacity: .9;
  font-weight: 400;
  font-size: 13px;
  margin: 0;
  font-family: var(--font-body);
}

/* RESPONSIVE */
@media (max-width: 1199.98px){
  .product-visual img{
    width: 500px;
  }
   .products-bg-track{
    width: 650px;
    height: 360px;
    left: -190px;
    bottom: 120px;
  }
}

@media (max-width: 991.98px){
  .products-area{
    padding: 80px 0 60px;
  }

  .products-bg-track{
    width: 520px;
    height: 280px;
    left: -180px;
    bottom: 180px;
    opacity: .55;
  }

  .products-bg-word{
    right: 0;
    top: 40px;
    font-size: clamp(5rem, 20vw, 8rem);
  }

  .products-bg-fade{
    background: linear-gradient(90deg,
      rgba(245,244,236,.62) 0%,
      rgba(245,244,236,.82) 30%,
      rgba(245,244,236,.95) 55%,
      rgba(245,244,236,1) 78%);
  }
  .product-copy{
    max-width: 100%;
  }

  .product-visual{
    min-height: 300px;
  }

  .product-visual img{
    width: 460px;
  }

  .product-desc-wrap{
    max-width: 100%;
  }

  .stats{
    padding-top: 8px;
  }
}

@media (max-width: 767.98px){

   .products-bg-track{
    width: 400px;
    height: 220px;
    left: -150px;
    bottom: 220px;
    opacity: .35;
  }

  .products-bg-word{
    display: none;
  }

  .product-heading{
    font-size: 2rem;
    margin-bottom: 18px;
  }

  .product-item{
    padding: 10px 0;
  }

  .product-link{
    font-size: .96rem;
  }

  .product-desc{
    font-size: 11px;
    line-height: 1.45;
  }

  .product-visual{
    min-height: 240px;
  }

  .product-visual img{
    width: 100%;
    max-width: 420px;
  }

  .stat-card{
    min-height: 88px;
    padding: 16px 8px 14px;
  }

  .stat-label{
    font-size: 12px;
  }
}

/* Footer */
footer{
  padding: 60px 0;
  /* border-top: 1px solid var(--stroke); */
  /* background: rgba(255,255,255,.25); */
}
.footer-social .social-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(11, 79, 143, 0.08);
    color: #0b4f8f;
    font-size: 16px;
    transition: all 0.3s ease;
    border: 1px solid rgba(11, 79, 143, 0.1);
}

.footer-social .social-icon:hover {
    background: #0b4f8f;
    color: #fff;
    transform: translateY(-3px);
}

/* Optional brand colors on hover */
.footer-social .social-icon:nth-child(1):hover {
    background: #E1306C; /* Instagram */
}

.footer-social .social-icon:nth-child(2):hover {
    background: #1877F2; /* Facebook */
}

.footer-social .social-icon:nth-child(3):hover {
    background: #0A66C2; /* LinkedIn */
}
.footer-title{ font-weight: 400; color: var(--brand2); margin-bottom: 10px; }
.footer-link{ color: rgba(11,31,58,.76); text-decoration: none; }
.footer-link:hover{ color: var(--brand2); }
.small-muted{ color: rgba(11,31,58,.60); font-weight: 750; font-size: 13px; }
.copyright, .copyright span{ color: rgba(11,31,58,.60); font-weight: 400; font-size: 13px; font-family: var(--font-heading);}

/* Modal */
.modal-video{ border-radius:18px; overflow:hidden; }

/* Smooth anchor */
html{ scroll-behavior: smooth; }

/* AOS smoother */
[data-aos]{ will-change: transform, opacity; }


/* Athletic Track Systems  */
/* ══════════════════════════════════
       SCROLL PROGRESS
    ══════════════════════════════════ */
    #scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 3px; z-index: 2000; }
    #scroll-progress-fill {
      height: 100%; width: 0%;
      background: linear-gradient(90deg, var(--brand), var(--accent-2));
      transition: width .05s linear;
    }

    /* ══════════════════════════════════
       CURSOR GLOW
    ══════════════════════════════════ */
    #cursor-glow {
      position: fixed; width: 280px; height: 280px; border-radius: 50%;
      background: radial-gradient(circle, rgba(0,102,255,.07) 0%, transparent 70%);
      pointer-events: none; z-index: 9999;
      transform: translate(-50%,-50%);
      transition: opacity .3s;
      will-change: left, top;
    }

    /* ══════════════════════════════════
       SECTION DOTS
    ══════════════════════════════════ */
    #section-dots {
      position: fixed; right: 1.5rem; top: 50%; transform: translateY(-50%);
      z-index: 500; display: flex; flex-direction: column; gap: .6rem;
    }
    .s-dot {
      width: 7px; height: 7px; border-radius: 50%;
      border: 1.5px solid rgba(0,102,255,.35);
      background: transparent; cursor: pointer;
      transition: background .3s, transform .3s, box-shadow .3s;
    }
    .s-dot.active {
      background: var(--brand); transform: scale(1.4);
      box-shadow: 0 0 8px rgba(0,102,255,.4);
    }
    @media(max-width:768px){ #section-dots { display:none; } .hero { padding-top: 0!important;height: 100vh!important; } }


    /* ══════════════════════════════════
       HERO
    ══════════════════════════════════ */
    .hero {
      position: relative; height: 90vh; min-height: 550px;
      display: flex; 
      /* align-items: center;  */
      justify-content: center;
      text-align: center;
      overflow: hidden;
      background: var(--bg);
      padding-top: 30px;
    }

    #heroCanvas { position: absolute; inset: 0; width: 100%; height: 100%; }

    .hero::before {
      content: ''; position: absolute; inset: 0;
      background-image:
        linear-gradient(rgba(0,102,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,102,255,.04) 1px, transparent 1px);
      background-size: 60px 60px;
      pointer-events: none; z-index: 1;
    }
    /* .hero::after {
      content: ''; position: absolute; inset: 0;
      background: radial-gradient(ellipse at center, #fbfef100 0%, #fbfef1 88%);
      pointer-events: none; z-index: 1;
    } */

    .hero-content {
      position: relative; z-index: 5;
      text-align: center; padding: 2rem;
      will-change: transform;
      padding-top:3rem;
    }
    .hero-eyebrow {
      font-family: var(--font-mono); font-size: .7rem;
      letter-spacing: .35em; color: var(--brand);
      text-transform: uppercase; margin-bottom: 1.5rem;
      opacity: 0; animation: fadeUp .8s .2s forwards;
    }
    /* .hero-title {
      font-family: var(--font-heading);;
      font-size: clamp(2.5rem, 7vw, 6.5rem);
      font-weight: 900; line-height: 1.02; text-transform: uppercase;
      background: linear-gradient(135deg, #0d1117 20%, var(--brand) 75%);
      -webkit-background-clip: text; -webkit-text-fill-color: transparent;
      background-clip: text;
      opacity: 0; animation: fadeUp .9s .4s forwards;
    } */
   
    .hero-actions {
      display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap;
      opacity: 0; animation: fadeUp .9s .8s forwards;
    }
    .hero-scroll {
      position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
      z-index: 2; text-align: center;
      font-family: var(--font-mono); font-size: .65rem;
      color: var(--text-light); letter-spacing: .2em; text-transform: uppercase;
      opacity: 0; animation: fadeIn 1s 1.5s forwards;
    }
    .scroll-line {
      width: 1px; height: 40px;
      background: linear-gradient(to bottom, var(--brand), transparent);
      margin: .5rem auto 0;
      animation: scrollPulse 2s 1.5s infinite;
    }

    /* ══════════════════════════════════
       BUTTONS
    ══════════════════════════════════ */
    .btn-primary-solid {
      font-family: var(--font-mono); font-size: .78rem;
      letter-spacing: .14em; text-transform: uppercase;
      padding: .9rem 2.2rem;
      background: var(--brand); color: #fff;
      border: 1.5px solid var(--brand);
      text-decoration: none; display: inline-block;
      position: relative; overflow: hidden;
      transition: transform .2s, box-shadow .2s;
      will-change: transform;
      border-radius: 6px;
    }
    .btn-primary-solid:hover {
      color: #fff;
      transform: translateY(-2px);
      box-shadow: 0 10px 28px rgba(0,102,255,.3);
    }

    .btn-outline-dark {
      font-family: var(--font-mono); font-size: .78rem;
      letter-spacing: .14em; text-transform: uppercase;
      padding: .9rem 2.2rem;
      border: 1.5px solid rgba(0,0,0,.18);
      color: var(--text-dim); background: transparent;
      text-decoration: none; display: inline-block;
      transition: border-color .3s, color .3s, transform .2s;
      will-change: transform;
      border-radius: 6px;
    }
    .btn-outline-dark:hover {
      border-color: var(--brand); color: var(--brand);
      transform: translateY(-2px);
    }

    /* ══════════════════════════════════
       SECTION COMMON
    ══════════════════════════════════ */
    /* section { padding: 7rem 0; } */
    .section-label {
      font-family: var(--font-mono); font-size: .68rem;
      letter-spacing: .35em; text-transform: uppercase;
      color: var(--brand); margin-bottom: .75rem;
      display: inline-block; position: relative; overflow: hidden;
    }
    .section-label::after {
      content: ''; position: absolute; bottom: -2px; left: 0;
      height: 1px; width: 100%; background: var(--brand);
      transform: scaleX(0); transform-origin: left;
      transition: transform .6s .3s cubic-bezier(.22,1,.36,1);
    }
    .reveal.visible .section-label::after,
    .reveal-left.visible .section-label::after { transform: scaleX(1); }

    /* .section-title {
      font-family: var(--font-heading);;
      font-size: clamp(1.8rem, 4vw, 3rem);
      font-weight: 700; line-height: 1.1;
      text-transform: uppercase; color: var(--brand2);
    } */
    /* .section-title span { color: var(--brand); } */
    .section-lead {
      font-size: .95rem; color: var(--text-dim);
      line-height: 1.85; max-width: 540px; margin-top: .75rem;
    }

    /* ══════════════════════════════════
       REVEAL ANIMATIONS
    ══════════════════════════════════ */
    .reveal {
      opacity: 0; transform: translateY(32px);
      transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
    }
    .reveal.visible { opacity: 1; transform: translateY(0); }

    .reveal-left {
      opacity: 0; transform: translateX(-50px);
      transition: opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1);
    }
    .reveal-left.visible { opacity: 1; transform: translateX(0); }

    .reveal-right {
      opacity: 0; transform: translateX(50px);
      transition: opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1);
    }
    .reveal-right.visible { opacity: 1; transform: translateX(0); }

    .reveal-scale {
      opacity: 0; transform: scale(.9);
      transition: opacity .75s cubic-bezier(.22,1,.36,1), transform .75s cubic-bezier(.22,1,.36,1);
    }
    .reveal-scale.visible { opacity: 1; transform: scale(1); }

    /* Glitch text */
    .glitch-hover { position: relative; display: inline-block; }
    .glitch-hover::before, .glitch-hover::after {
      content: attr(data-text); position: absolute; top: 0; left: 0;
      width: 100%; height: 100%; pointer-events: none; opacity: 0;
    }
    .glitch-hover:hover::before {
      opacity: .5; color: var(--brand);
      clip-path: polygon(0 0,100% 0,100% 38%,0 38%);
      transform: translateX(-2px);
      animation: glitchTop .35s steps(2) infinite;
    }
    .glitch-hover:hover::after {
      opacity: .4; color: var(--accent-3);
      clip-path: polygon(0 62%,100% 62%,100% 100%,0 100%);
      transform: translateX(2px);
      animation: glitchBot .35s steps(2) infinite;
    }
    @keyframes glitchTop { 0%{transform:translateX(-2px) skewX(0)} 50%{transform:translateX(2px) skewX(-2deg)} 100%{transform:translateX(-2px)} }
    @keyframes glitchBot { 0%{transform:translateX(2px)} 50%{transform:translateX(-2px) skewX(2deg)} 100%{transform:translateX(2px)} }

    @keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
    @keyframes fadeIn { from{opacity:0} to{opacity:1} }
    @keyframes scrollPulse { 0%,100%{opacity:1} 50%{opacity:.2} }
    @keyframes pulseRing { 0%{transform:scale(1);opacity:.6} 100%{transform:scale(1.6);opacity:0} }

    /* ══════════════════════════════════
       SYSTEM STACK — LAYER CARDS
    ══════════════════════════════════ */
    #system-stack {
      background: var(--bg);
      position: relative;
    }
    #system-stack::before {
      content: ''; position: absolute; left: 0; right: 0; top: 0; height: 3px;
      background: linear-gradient(90deg, transparent, var(--brand), transparent);
    }

    /* ─── THE LAYER CARD ─── */
    .layer-card {
      position: relative; overflow: hidden;
      border: 1.5px solid var(--border);
      background: var(--card);
      margin-bottom: 1.25rem;
      cursor: default;
      transition: border-color .35s, box-shadow .35s, transform .35s cubic-bezier(.22,1,.36,1);
      min-height: 140px;
      border-radius: 6px;
    }

    /* Background image layer — hidden by default */
    .layer-card-bg {
      position: absolute; inset: 0;
      background-size: cover; background-position: center;
      opacity: 0;
      transition: opacity .55s cubic-bezier(.22,1,.36,1), transform .55s cubic-bezier(.22,1,.36,1);
      transform: scale(1.06);
    }
    /* Colour tint overlay on top of image */
    .layer-card-bg::after {
      content: ''; position: absolute; inset: 0;
      background: var(--layer-tint, rgba(0,102,255,.82));
      transition: opacity .4s;
    }

    /* Hover: image slides in */
    .layer-card:hover .layer-card-bg,
    .layer-card.active .layer-card-bg {
      opacity: 1; transform: scale(1);
    }

    /* Content sits above the bg */
    .layer-card-body {
      position: relative; z-index: 2;
      padding: 1.5rem 1.75rem;
      transition: color .3s;
    }

    .layer-card:hover,
    .layer-card.active {
      border-color: var(--layer-color, var(--brand));
      box-shadow: 0 12px 40px rgba(0,0,0,.14);
      transform: translateY(-3px);
    }

    /* Left accent bar */
    .layer-card::before {
      content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
      background: var(--layer-color, var(--brand));
      opacity: 0; transition: opacity .3s;
      z-index: 3;
    }
    .layer-card:hover::before,
    .layer-card.active::before { opacity: 1; }

    /* Text colours invert on hover */
    .layer-card:hover .layer-num,
    .layer-card.active .layer-num { color: rgba(255,255,255,.7); }
    .layer-card:hover .layer-name,
    .layer-card.active .layer-name { color: #fff; }
    .layer-card:hover .layer-desc,
    .layer-card.active .layer-desc { color: rgba(255,255,255,.82); }

    .layer-num {
      font-family: var(--font-mono); font-size: .65rem;
      color: var(--layer-color, var(--brand));
      letter-spacing: .15em; margin-bottom: .35rem;
      transition: color .3s;
    }
    .layer-name {
      font-family: var(--font-heading);; font-size: 1rem;
      font-weight: 700; text-transform: uppercase;
      color: var(--brand2); letter-spacing: .05em; margin-bottom: .45rem;
      transition: color .3s;
    }
    .layer-desc {
      font-size: .83rem; color: var(--text-dim); line-height: 1.65;
      transition: color .3s;
    }

    /* Chem chips */
    .chem-chips { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .85rem; }
    .chip {
      font-family: var(--font-mono); font-size: .64rem;
      padding: .25rem .65rem;
      border: 1px solid var(--layer-color, var(--brand));
      color: var(--layer-color, var(--brand));
      letter-spacing: .06em;
      background: rgba(255,255,255,.12);
      backdrop-filter: blur(4px);
      opacity: 0; transform: translateY(4px);
      transition: opacity .3s, transform .3s, color .3s, border-color .3s;
    }
    .layer-card:hover .chip,
    .layer-card.active .chip {
      opacity: 1; transform: translateY(0); color: #fff; border-color: rgba(255,255,255,.4);
    }
    .chip:nth-child(2) { transition-delay:.06s; }
    .chip:nth-child(3) { transition-delay:.12s; }
    .chip:nth-child(4) { transition-delay:.18s; }

    /* Cross-section panel */
    .stack-sticky { position: sticky; top: 120px; }
    .cross-section {
      border: 1.5px solid var(--border);
      background: var(--card);
      overflow: hidden;
      box-shadow: var(--shadow-sm);
      border-radius: 6px;
    }
    .cs-layer {
      display: flex; align-items: center; justify-content: space-between;
      padding: 1.25rem;
      border-bottom: 1px solid var(--border);
      transition: transform .4s cubic-bezier(.25,.8,.25,1), background .3s;
      cursor: pointer; position: relative;
    }
    .cs-layer:last-child { border-bottom: none; }
    .cs-layer-bar {
      position: absolute; left: 0; top: 0; bottom: 0;
      background: var(--layer-color, var(--brand));
      opacity: .08; width: 100%; transition: opacity .3s;
    }
    .cs-layer:hover .cs-layer-bar,
    .cs-layer.active .cs-layer-bar { opacity: .18; }
    .cs-layer-label {
      font-family: var(--font-mono); font-size: .7rem;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--layer-color, var(--text)); position: relative; z-index: 1;
    }
    .cs-layer-thickness {
      font-family: var(--font-mono); font-size: .65rem;
      color: var(--text-light); position: relative; z-index: 1;
    }
    .cross-section.exploded .cs-layer:nth-child(1) { transform: translateY(-24px); }
    .cross-section.exploded .cs-layer:nth-child(2) { transform: translateY(-12px); }
    .cross-section.exploded .cs-layer:nth-child(3) { transform: translateY(0); }
    .cross-section.exploded .cs-layer:nth-child(4) { transform: translateY(12px); }

    /* ══════════════════════════════════
       COMPLIANCE SECTION
    ══════════════════════════════════ */
    #compliance { background: var(--light-bg); }

    .compliance-badge {
      background: var(--card); border: 1.5px solid var(--border);
      padding: 2.25rem 1.75rem; text-align: center;
      position: relative; overflow: hidden;
      transition: transform .25s ease, border-color .3s, box-shadow .3s;
      transform-style: preserve-3d;
      will-change: transform;
      border-radius: 6px;
    }
    .compliance-badge::before {
      content: ''; position: absolute; top: 0; left: -100%;
      width: 60%; height: 100%;
      background: linear-gradient(90deg, transparent, rgba(0,102,255,.05), transparent);
      transition: left .5s ease; pointer-events: none;
    }
    .compliance-badge:hover::before { left: 150%; }
    .compliance-badge:hover {
      border-color: var(--brand);
      box-shadow: 0 12px 40px rgba(0,102,255,.12);
    }
    .badge-icon {
      width: 70px; height: 70px; border-radius: 50%;
      border: 2px solid var(--brand);
      display: flex; align-items: center; justify-content: center;
      margin: 0 auto 1.25rem;
      font-family: var(--font-heading);; font-size: .88rem;
      font-weight: 900; color: var(--brand);
      position: relative;
      transition: transform .5s cubic-bezier(.34,1.56,.64,1), box-shadow .3s;
    }
    .badge-icon::before {
      content: ''; position: absolute; inset: -6px; border-radius: 50%;
      border: 1px solid rgba(0,102,255,.2);
      animation: pulseRing 2.5s ease-out infinite;
    }
    .compliance-badge:hover .badge-icon {
      transform: rotate(10deg) scale(1.08);
      box-shadow: 0 0 24px rgba(0,102,255,.25);
    }
    .badge-title {
      font-family: var(--font-heading);; font-size: .78rem;
      font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
      color: var(--brand2); margin-bottom: .5rem;
    }
    .badge-desc { font-size: .8rem; color: var(--text-dim); line-height: 1.65; }

    /* ══════════════════════════════════
       SPEED METRICS
    ══════════════════════════════════ */
    #speed-metrics {
      background: var(--bg);
      position: relative;
    }
    #speed-metrics::before {
      content: ''; position: absolute; left: 0; right: 0; top: 0; height: 3px;
      background: linear-gradient(90deg, transparent, var(--accent-2), transparent);
    }

    .dial-wrapper { text-align: center; }
    .dial-label {
      font-family: var(--font-heading);; font-size: .65rem;
      letter-spacing: .14em; text-transform: uppercase;
      color: var(--text-dim); margin-top: .75rem;
    }

    .stat-bar-wrap { margin-bottom: 1.5rem; }
    .stat-bar-label {
      display: flex; justify-content: space-between;
      font-family: var(--font-mono); font-size: .72rem;
      color: var(--text-dim); margin-bottom: .45rem;
    }
    .stat-bar-label span:last-child { color: var(--brand2); font-weight: 600; }
    .stat-bar-track {
      height: 4px; background: var(--surface-2);
      position: relative; overflow: hidden; border-radius: 2px;
    }
    .stat-bar-fill {
      position: absolute; left: 0; top: 0; bottom: 0;
      background: var(--bar-color, var(--brand));
      transform: scaleX(0); transform-origin: left;
      transition: transform 1.4s cubic-bezier(.25,.8,.25,1);
      border-radius: 2px;
    }
    .stat-bar-fill.animated { transform: scaleX(1); }
    .stat-bar-fill::after {
      content: ''; position: absolute; inset: 0;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent);
      transform: translateX(-100%);
    }
    .stat-bar-fill.animated::after {
      transform: translateX(100%);
      transition: transform 1.8s .6s ease;
    }
    .stat-bar-glow {
      position: absolute; right: 0; top: -2px; bottom: -2px; width: 8px;
      background: var(--bar-color, var(--brand));
      filter: blur(4px); opacity: .6;
    }

    /* ══════════════════════════════════
       TECH SPECS TABLE
    ══════════════════════════════════ */
    #tech-specs { background: var(--light-bg); }

    .spec-table {
      width: 100%; border-collapse: separate; border-spacing: 0;
      font-size: .83rem; background: var(--card);
    }
    .spec-table thead th {
      font-family: var(--font-mono); font-size: .64rem;
      letter-spacing: .2em; text-transform: uppercase;
      color: var(--brand); padding: .85rem 1.25rem;
      border-bottom: 2px solid rgba(0,102,255,.12);
      background: rgba(0,102,255,.03);
    }
    .spec-table tbody tr {
      border-bottom: 1px solid var(--border);
      transition: background .2s;
      position: relative;
    }
    .spec-table tbody tr::after {
      content: ''; position: absolute; left: 0; right: 0; top: 50%; height: 1px;
      background: var(--brand); opacity: 0; transform: scaleX(0); transform-origin: left;
      transition: opacity .2s, transform .3s cubic-bezier(.22,1,.36,1);
      pointer-events: none;
    }
    .spec-table tbody tr:hover { background: rgba(0,102,255,.03); }
    .spec-table tbody tr:hover::after { opacity: .2; transform: scaleX(1); }
    .spec-table td {
      padding: .9rem 1.25rem; color: var(--text-dim);
      border-bottom: 1px solid var(--border);
    }
    .spec-table td:first-child { color: var(--brand2); font-weight: 500; }
    .spec-pass {
      font-family: var(--font-mono); font-size: .7rem;
      color: var(--accent-2); letter-spacing: .1em;
    }

    /* ══════════════════════════════════
       CTA BAND
    ══════════════════════════════════ */
    .cta-band {
      background: linear-gradient(135deg, #fbfef1 0%, #fbfef1 100%);
      border-top: 1px solid var(--border);
      padding: 3rem 0; text-align: center;
      position: relative; overflow: hidden;
    }
    .cta-band::before {
      content: ''; position: absolute; inset: 0;
      background: radial-gradient(ellipse at 30% 50%, rgba(0,102,255,.06), transparent 60%),
                  radial-gradient(ellipse at 70% 50%, rgba(0,184,148,.06), transparent 60%);
      pointer-events: none;
    }
    .cta-band-title {
      font-family: var(--font-heading);;
      font-size: clamp(1.6rem, 4vw, 3rem);
      font-weight: 900; text-transform: uppercase; color: var(--brand2);
      position: relative;
    }
    .cta-band-sub {
      font-size: .92rem; color: var(--text-dim);
      margin: 1rem auto 2.5rem; max-width: 480px; line-height: 1.75;
    }

    /* Typewriter cursor */
    .typewriter::after { content: '|'; color: var(--brand); animation: cursorBlink .8s step-end infinite; }
    @keyframes cursorBlink { 0%,100%{opacity:1} 50%{opacity:0} }

    @media(max-width:768px){ .nav-links { display:none; } .cross-section { display:none; } .spec-table{font-size: 0.6rem;}}




    /* EPDM Binder */

     /* ─── HERO ────────────────────────────────────────────────── */
    /* .hero {
      position: relative;
      min-height: 90vh;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--bg);
      overflow: hidden;
      text-align: center;
    } */

    /* Canvas particle layer */
    #heroCanvas {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      pointer-events: none;
      z-index: 0;
    }

    /* SVG arc layer */
    .hero-svg-arcs {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      pointer-events: none;
      z-index: 1;
      overflow: visible;
    }
    .arc-path {
      fill: none;
      stroke: rgba(42,107,124,.18);
      stroke-width: 1.5;
      stroke-dasharray: 2000;
      stroke-dashoffset: 2000;
      animation: drawArc 2.4s cubic-bezier(.4,0,.2,1) forwards;
    }
    .arc-path:nth-child(2) {
      stroke: rgba(42,107,124,.10);
      stroke-width: 1;
      animation-delay: .3s;
    }
    .arc-path:nth-child(3) {
      stroke: rgba(42,107,124,.07);
      stroke-width: 1;
      animation-delay: .6s;
    }
    @keyframes drawArc {
      to { stroke-dashoffset: 0; }
    }

    /* Floating EPDM colour swatches */
    .float-swatch {
      position: absolute;
      border-radius: 10px;
      opacity: 0;
      pointer-events: none;
      z-index: 1;
      animation: swatchFloat linear infinite, swatchFadeIn .6s forwards;
      box-shadow: 0 4px 14px rgba(13,31,60,.12);
    }
    @keyframes swatchFadeIn { to { opacity: .55; } }
    @keyframes swatchFloat {
      0%   { transform: translateY(0) rotate(0deg); }
      33%  { transform: translateY(-18px) rotate(4deg); }
      66%  { transform: translateY(-8px) rotate(-3deg); }
      100% { transform: translateY(0) rotate(0deg); }
    }

    /* Colour stripe bar */
    .hero-color-bar {
      position: absolute; top: 0; left: 0; right: 0;
      height: 5px;
      background: linear-gradient(90deg,
        var(--red) 0%,    var(--red)    16.6%,
        var(--orange) 16.6%, var(--orange) 33.3%,
        var(--amber) 33.3%,  var(--amber)  50%,
        var(--green) 50%,    var(--green)  66.6%,
        var(--blue) 66.6%,   var(--blue)   83.3%,
        var(--purple) 83.3%, var(--purple) 100%);
      transform-origin: left;
      animation: stripeExpand .9s cubic-bezier(.4,0,.2,1) forwards;
    }
    @keyframes stripeExpand {
      from { transform: scaleX(0); }
      to   { transform: scaleX(1); }
    }

    /* Hero badge / tag */
    .hero-tag {
      font-family: var(--font-mono);
      font-size: .72rem;
      letter-spacing: .22em;
      color: var(--brand);
      text-transform: uppercase;
      margin-bottom: 1.4rem;
      display: inline-flex; align-items: center; gap: .5rem;
      opacity: 0;
      animation: fadeUp .6s .3s forwards;
    }
    .hero-tag::before {
      content: '';
      display: inline-block;
      width: 28px; height: 2px;
      background: var(--white);
      border-radius: 2px;
    }
    .hero-tag::after {
      content: '';
      display: inline-block;
      width: 28px; height: 2px;
      background: var(--white);
      border-radius: 2px;
    }

    /* Hero headline with word-split reveal */
    /* .hero h1 {
      font-family: var(--font-disp);
      font-size: clamp(3rem, 8.5vw, 7.5rem);
      font-weight: 900;
      line-height: .92;
      text-transform: uppercase;
      color: var(--brand);
    }
    .hero h1 .accent { color: var(--brand); } */
    .word-wrap { display: inline-block; overflow: hidden; }
    .word-inner {
      display: inline-block;
      transform: translateY(110%);
      opacity: 0;
    }
    .word-inner.animate-in {
      animation: wordSlideIn .65s cubic-bezier(.22,1,.36,1) forwards;
    }
    @keyframes wordSlideIn {
      to { transform: translateY(0); opacity: 1; }
    }

    /* Animated underline on accent word */
    .hero-accent-underline {
      position: relative; display: inline-block;
    }
    .hero-accent-underline::after {
      content: '';
      position: absolute;
      bottom: 4px; left: 0;
      height: 4px;
      width: 0;
      background: linear-gradient(90deg, var(--brand), var(--green));
      border-radius: 2px;
      animation: underlineGrow .7s 1.3s cubic-bezier(.4,0,.2,1) forwards;
    }
    @keyframes underlineGrow { to { width: 100%; } }

    .hero-sub {
      font-size: clamp(.9rem, 1.6vw, 1.1rem);
      font-weight: 600;
      color: #000;
      max-width: 600px;
      margin: 1.4rem auto;
      line-height: 1.75;
      opacity: 0;
      animation: fadeUp .7s 1s forwards;
    }

    /* Live stat counters row */
    .hero-stats {
      display: flex; flex-wrap: wrap; gap: 1.5rem;
      justify-content: center;
      margin-top: 1.6rem;
      opacity: 0;
      animation: fadeUp .7s 1.1s forwards;
    }
    .hero-stat-item {
      display: flex; flex-direction: column; align-items: center;
      gap: .1rem;
    }
    .hero-stat-val {
      font-family: var(--font-disp);
      font-size: 2rem;
      font-weight: 900;
      color: var(--brand);
      line-height: 1;
      letter-spacing: -.02em;
    }
    .hero-stat-val .stat-unit {
      font-size: 1.2rem;
      color: var(--brand);
    }
    .hero-stat-lbl {
      font-family: var(--font-mono);
      font-size: .6rem;
      letter-spacing: .14em;
      color: var(--brand2);
      text-transform: uppercase;
    }
    .stat-divider {
      width: 1px; height: 36px;
      background: var(--border-mid);
      align-self: center;
    }

    /* Chips */
    .hero-chips {
      display: flex; flex-wrap: wrap; gap: .5rem;
      justify-content: center;
      margin-top: 1.4rem;
      opacity: 0;
      animation: fadeUp .7s 1.2s forwards;
    }
    .hero-chip {
      font-family: var(--font-body);
      font-size: .75rem;
      font-weight: 500;
      padding: .3rem .85rem;
      border: 1.5px solid var(--border-mid);
      border-radius: 20px;
      color: var(--muted);
      background: rgba(255,255,255,.65);
      transition: border-color .2s, color .2s, background .2s, transform .2s;
    }
    .hero-chip:hover {
      border-color: var(--brand);
      color: var(--brand);
      background: rgba(42,107,124,.06);
      transform: translateY(-2px);
    }

    /* CTA row */
    .hero-cta-row {
      margin-top: 2rem;
      opacity: 0;
      animation: fadeUp .7s 1.35s forwards;
    }

    /* Buttons */
    .btn-primary-atlas {
      font-family: var(--font-disp);
      font-size: .88rem;
      font-weight: 700;
      letter-spacing: .12em;
      text-transform: uppercase;
      background: var(--brand);
      color: #fff;
      border: none;
      padding: .9rem 2.3rem;
      border-radius: 4px;
      transition: all .25s;
      text-decoration: none;
      display: inline-block;
      position: relative;
      overflow: hidden;
    }
    .btn-primary-atlas::after {
      content: '';
      position: absolute; inset: 0;
      background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.18) 50%, transparent 70%);
      transform: translateX(-100%);
      transition: transform .5s;
    }
    .btn-primary-atlas:hover::after { transform: translateX(100%); }
    .btn-primary-atlas:hover {
      background: var(--teal-dark);
      color: #fff;
      transform: translateY(-3px);
      box-shadow: 0 10px 28px rgba(42,107,124,.28);
    }
    .btn-outline-atlas {
      font-family: var(--font-disp);
      font-size: .88rem;
      font-weight: 700;
      letter-spacing: .12em;
      text-transform: uppercase;
      background: transparent;
      color: var(--brand);
      border: 1.5px solid var(--border-mid);
      padding: .9rem 2.3rem;
      border-radius: 4px;
      transition: all .25s;
      text-decoration: none;
      display: inline-block;
    }
    .btn-outline-atlas:hover {
      border-color: var(--brand);
      color: var(--brand);
      transform: translateY(-3px);
    }

    /* Scroll hint */
    .scroll-hint {
         position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    text-align: center;
    font-family: var(--font-mono);
    font-size: .65rem;
    color: var(--text-light);
    letter-spacing: .2em;
    text-transform: uppercase;
    opacity: 0;
    animation: fadeIn 1s 1.5s forwards;
    }
    .scroll-hint span {
      font-family: var(--font-mono);
      font-size: .62rem;
      letter-spacing: .2em;
      color: var(--muted);
      display: block; margin-bottom: .4rem;
    }
    .scroll-arrow-wrap {
      width: 24px; height: 38px;
      margin: 0 auto;
      position: relative;
      display: flex; justify-content: center;
    }
    .scroll-arrow {
      width: 1px; height: 100%;
      background: linear-gradient(to bottom, var(--brand), transparent);
      animation: scrollPulse 1.8s infinite;
    }
    .scroll-dot {
      position: absolute;
      width: 5px; height: 5px;
      border-radius: 50%;
      background: var(--brand);
      top: 0; left: 50%; transform: translateX(-50%);
      animation: dotDrop 1.8s infinite;
    }
    @keyframes scrollPulse { 0%,100%{opacity:1} 50%{opacity:.2} }
    @keyframes dotDrop {
      0%  { top: 0; opacity: 1; }
      80% { top: 100%; opacity: 0; }
      81% { top: 0; opacity: 0; }
      100%{ top: 0; opacity: 1; }
    }
    @keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

    /* ─── SECTION SHARED ──────────────────────────────────────── */
    section { position: relative; }
    .section-label {
      font-family: var(--font-mono);
      font-size: .68rem;
      letter-spacing: .22em;
      color: var(--brand2);
      text-transform: uppercase;
      margin-bottom: .5rem;
    }
    .section-title {
      font-family: var(--font-heading) !important;
      font-size: clamp(1.5rem, 4.5vw, 3.4rem);
      font-weight: 800;
      line-height: 1;
      text-transform: uppercase;
      color: var(--brand2);
    }
    .section-title .dim { color: var(--muted); }
    .divider {
      width: 44px; height: 3px;
      background: var(--brand2);
      border-radius: 2px;
      margin: 1rem 0 1.4rem;
    }
    .section-bg { background: var(--bg); }
    .section-bg-alt { background: var(--bg-alt); }

    /* ─── BOUNCE TEST ─────────────────────────────────────────── */
    #bounce-test { background: var(--bg-alt); }
    .bounce-card {
      background: var(--card);
      border: 1.5px solid var(--border);
      border-radius: 10px;
      overflow: hidden;
      box-shadow: 0 4px 24px rgba(13,31,60,.06);
    }
    .bounce-video-wrap {
      position: relative;
      background: linear-gradient(180deg, #e8f4f7, #d0e9ee);
      height: 300px;
      display: flex; align-items: center; justify-content: center;
      overflow: hidden;
    }
    .ball {
      width: 58px; height: 58px;
      background: radial-gradient(circle at 35% 30%, #c0d8e0, #2a6b7c);
      border-radius: 50%;
      box-shadow: 0 6px 18px rgba(42,107,124,.35);
      position: absolute;
      left: 50%; transform: translateX(-50%);
      top: 20px;
    }
    .surface-line {
      position: absolute; bottom: 48px;
      left: 0; right: 0;
      height: 20px;
      background: linear-gradient(180deg, #b8d8df, #8fbfc8);
      border-top: 2.5px solid var(--brand);
    }
    .impact-ring {
      position: absolute; bottom: 60px;
      left: 50%; transform: translateX(-50%);
      border-radius: 50%;
      border: 2px solid rgba(42,107,124,.45);
      opacity: 0;
    }
    .surf-label {
      position: absolute; bottom: 28px; left: 16px;
      font-family: var(--font-mono); font-size: .58rem;
      letter-spacing: .1em; color: var(--teal-dark);
    }
    #scrubber {
      -webkit-appearance: none; width: 100%; height: 6px;
      background: var(--border); border-radius: 3px; outline: none; cursor: pointer;
      accent-color: var(--brand);
    }
    #scrubber::-webkit-slider-thumb {
      -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%;
      background: var(--brand); cursor: pointer;
      box-shadow: 0 2px 8px rgba(42,107,124,.4);
    }
    .scrub-label {
      font-family: var(--font-mono); font-size: .7rem;
      letter-spacing: .12em; color: var(--muted);
    }
    .bounce-stat-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--border); }
    .bounce-stat { background: var(--card); padding: 1.1rem; text-align: center; }
    .bounce-stat .val { font-family: var(--font-disp); font-size: 1.9rem; font-weight: 800; color: var(--brand); }
    .bounce-stat .lbl { font-family: var(--font-mono); font-size: .6rem; letter-spacing: .1em; color: var(--muted); margin-top: .15rem; }
    .loop-btn {
      font-family: var(--font-mono); font-size: .65rem; letter-spacing: .1em;
      background: transparent; border: 1.5px solid var(--border-mid);
      color: var(--muted); padding: .25rem .75rem; border-radius: 3px; cursor: pointer;
      transition: all .2s; text-transform: uppercase;
    }
    .loop-btn:hover { border-color: var(--brand); color: var(--brand); }

    /* ─── SAFETY ZONE ─────────────────────────────────────────── */
    #safety { background: var(--bg); }
    .cfh-card {
      background: var(--card);
      border: 1.5px solid var(--border);
      border-radius: 10px;
      padding: 2rem 1.6rem;
      transition: border-color .25s, transform .25s, box-shadow .25s;
      position: relative;
      overflow: hidden;
      box-shadow: 0 2px 12px rgba(13,31,60,.05);
    }
    .cfh-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; }
    .cfh-card.red::before   { background: var(--red); }
    .cfh-card.amber::before { background: var(--amber); }
    .cfh-card.green::before { background: var(--green); }
    .cfh-card:hover { border-color: var(--brand); transform: translateY(-4px); box-shadow: 0 10px 32px rgba(42,107,124,.12); }
    .cfh-icon { width: 50px; height: 50px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; margin-bottom: 1rem; }
    .cfh-icon.red    { background: #fdecea; color: var(--red); }
    .cfh-icon.amber  { background: #fdf3dc; color: var(--amber); }
    .cfh-icon.green  { background: #d4edda; color: var(--green); }
    .cfh-number { font-family: var(--font-disp); font-size: 3.2rem; font-weight: 900; line-height: 1; }
    .cfh-number.red   { color: var(--red); }
    .cfh-number.amber { color: var(--amber); }
    .cfh-number.green { color: var(--green); }
    .cfh-card h5 { font-family: var(--font-disp); font-size: 1.1rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; margin: .5rem 0 .6rem; color: var(--brand); }
    .cfh-card p { font-size: .87rem; color: var(--muted); line-height: 1.65; }
    .depth-tag { font-family: var(--font-mono); font-size: .65rem; letter-spacing: .09em; color: var(--muted); margin-top: .8rem; padding: .3rem .7rem; background: var(--bg-card-alt); border: 1px solid var(--border); border-radius: 3px; display: inline-block; }
    .fall-visual {
      background: var(--card);
      border: 1.5px solid var(--border);
      border-radius: 10px;
      padding: 2rem;
      box-shadow: 0 2px 12px rgba(13,31,60,.05);
    }
    .fall-bar-wrap { display: flex; align-items: flex-end; gap: .5rem; height: 200px; }
    .fall-bar { flex: 1; border-radius: 4px 4px 0 0; position: relative; min-width: 36px; }
    .fall-bar-label { font-family: var(--font-mono); font-size: .58rem; letter-spacing: .07em; color: var(--muted); text-align: center; margin-top: .4rem; }
    .fall-bar-val { font-family: var(--font-disp); font-size: .82rem; font-weight: 700; position: absolute; top: -1.5rem; left: 50%; transform: translateX(-50%); white-space: nowrap; }
    .person-icon { font-size: 1.3rem; position: absolute; top: -2.8rem; left: 50%; transform: translateX(-50%); }
    .ground-line { height: 3px; background: linear-gradient(90deg, var(--brand), rgba(42,107,124,.1)); border-radius: 2px; margin-top: .3rem; }
    .compliance-card {
      background: var(--card); border: 1.5px solid var(--border); border-radius: 10px;
      padding: 1.7rem 1.5rem; box-shadow: 0 2px 12px rgba(13,31,60,.05);
    }
    .compliance-card.green-accent { border-left: 4px solid var(--green); }
    .compliance-card.amber-accent { border-left: 4px solid var(--amber); }
    .big-val { font-family: var(--font-disp); font-size: 2.2rem; font-weight: 800; color: var(--brand); }

    /* ─── COLOUR MIXER ────────────────────────────────────────── */
    #color-mixer { background: var(--bg-alt); }
    .palette-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(66px,1fr)); gap: .5rem; }
    .color-chip {
      aspect-ratio: 1; border-radius: 8px; cursor: pointer; position: relative;
      transition: transform .2s, box-shadow .2s; border: 2px solid transparent;
      user-select: none;
    }
    .color-chip:hover { transform: scale(1.1); box-shadow: 0 6px 18px rgba(13,31,60,.18); border-color: rgba(255,255,255,.5); }
    .color-chip:active { transform: scale(.95); }
    .chip-label { position: absolute; bottom: 3px; left: 0; right: 0; text-align: center; font-family: var(--font-mono); font-size: .5rem; letter-spacing: .05em; color: rgba(255,255,255,.9); text-shadow: 0 1px 3px rgba(0,0,0,.5); }
    .mix-canvas {
      background: var(--card); border: 2px dashed var(--border-mid); border-radius: 10px;
      min-height: 300px; position: relative; overflow: hidden; transition: border-color .25s;
      box-shadow: 0 2px 12px rgba(13,31,60,.05);
    }
    .mix-canvas.dragover { border-color: var(--brand); border-style: solid; }
    .mix-canvas-inner { position: absolute; inset: 0; display: flex; }
    .mix-placeholder { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .6rem; pointer-events: none; }
    .mix-placeholder i { font-size: 2.2rem; color: var(--border-mid); }
    .mix-placeholder p { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .12em; color: var(--muted); }
    .mix-legend { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .8rem; }
    .mix-legend-item { display: flex; align-items: center; gap: .3rem; font-family: var(--font-mono); font-size: .63rem; letter-spacing: .07em; color: var(--muted); }
    .mix-legend-dot { width: 12px; height: 12px; border-radius: 3px; flex-shrink: 0; border: 1px solid rgba(0,0,0,.08); }
    .btn-clear-mix { font-family: var(--font-mono); font-size: .65rem; letter-spacing: .1em; color: var(--muted); border: 1.5px solid var(--border-mid); background: transparent; padding: .35rem .85rem; border-radius: 4px; cursor: pointer; transition: all .2s; text-transform: uppercase; }
    .btn-clear-mix:hover { border-color: var(--red); color: var(--red); }
    .mix-seg { flex-shrink: 0; position: relative; height: 100%; transition: flex-basis .5s cubic-bezier(.4,0,.2,1); }
    .mix-pct { font-family: var(--font-mono); font-size: .6rem; color: rgba(255,255,255,.92); text-shadow: 0 1px 3px rgba(0,0,0,.5); position: absolute; top: 8px; left: 50%; transform: translateX(-50%); white-space: nowrap; background: rgba(0,0,0,.22); padding: 2px 5px; border-radius: 3px; }

    /* ─── UV SLIDER ───────────────────────────────────────────── */
    #uv-test { background: var(--bg); }
    .uv-slider-wrap {
      position: relative; border-radius: 10px; overflow: hidden;
      cursor: col-resize; user-select: none; min-height: 340px;
      border: 1.5px solid var(--border);
      box-shadow: 0 4px 24px rgba(13,31,60,.07);
    }
    .uv-panel-base { position: absolute; top: 0; bottom: 0; left: 0; right: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 2.5rem; }
    .uv-left  { background: linear-gradient(135deg, #faf0cc, #f0d890, #e8c840); }
    .uv-right-wrap { position: absolute; inset: 0; overflow: hidden; }
    .uv-right-inner { position: absolute; top: 0; bottom: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 2.5rem; background: linear-gradient(135deg, #e8f4f7, #c8e8ee, #a8dce6); }
    .uv-panel-title { font-family: var(--font-disp); font-size: 1.6rem; font-weight: 800; text-transform: uppercase; margin-bottom: .5rem; }
    .uv-left .uv-panel-title { color: #7a5500; }
    .uv-right-inner .uv-panel-title { color: var(--teal-dark); }
    .uv-swatch { width: 120px; height: 72px; border-radius: 8px; margin: 1rem 0; border: 2px solid rgba(0,0,0,.1); }
    .uv-left .uv-swatch { background: linear-gradient(135deg, #e8c840, #b89000, #e8c840); background-size: 200%; animation: yellowing 3s ease-in-out infinite; }
    @keyframes yellowing { 0%,100%{background-position:0%} 50%{background-position:100%} }
    .uv-right-inner .uv-swatch { background: linear-gradient(135deg, #2e9e4f, #1e7e55, #2e9e4f); background-size: 200%; }
    .uv-tag { font-family: var(--font-mono); font-size: .63rem; letter-spacing: .12em; padding: .22rem .65rem; border-radius: 20px; display: inline-block; }
    .uv-left .uv-tag { background: rgba(184,144,0,.15); color: #7a5500; border: 1px solid rgba(184,144,0,.35); }
    .uv-right-inner .uv-tag { background: rgba(42,107,124,.12); color: var(--teal-dark); border: 1px solid rgba(42,107,124,.3); }
    .uv-stat-text { font-family: var(--font-mono); font-size: .62rem; letter-spacing: .08em; text-align: center; margin-top: .3rem; }
    .uv-left .uv-stat-text { color: #8a6000; }
    .uv-right-inner .uv-stat-text { color: var(--teal-dark); }
    .uv-divider { position: absolute; top: 0; bottom: 0; width: 3px; background: var(--brand); left: 50%; transform: translateX(-50%); z-index: 10; pointer-events: none; }
    .uv-handle { position: absolute; top: 50%; width: 42px; height: 42px; border-radius: 50%; background: var(--brand); display: flex; align-items: center; justify-content: center; color: #fff; font-size: .9rem; box-shadow: 0 4px 14px rgba(13,31,60,.25); z-index: 11; left: 50%; transform: translate(-50%,-50%); cursor: col-resize; }
    .uv-label-overlay { position: absolute; font-family: var(--font-mono); font-size: .6rem; letter-spacing: .12em; top: 12px; padding: .22rem .65rem; background: rgba(255,255,255,.7); border-radius: 3px; z-index: 5; }
    .uv-label-overlay.left  { left: 12px; color: #7a5500; }
    .uv-label-overlay.right { right: 12px; color: var(--teal-dark); z-index: 13; }
    .spec-pill { font-family: var(--font-mono); font-size: .63rem; letter-spacing: .07em; color: var(--muted); padding: .22rem .6rem; border: 1.5px solid var(--border); border-radius: 4px; background: var(--card); }
    .spec-pill span { color: var(--brand); font-weight: 600; }

    /* ─── FEATURES ────────────────────────────────────────────── */
    #features { background: var(--bg-alt); }
    .feat-card {
      background: var(--card); border: 1.5px solid var(--border); border-radius: 10px;
      padding: 1.8rem 1.5rem; height: 100%;
      transition: border-color .25s, transform .25s, box-shadow .25s;
      box-shadow: 0 2px 12px rgba(13,31,60,.04);
    }
    .feat-card:hover { border-color: var(--brand); transform: translateY(-4px); box-shadow: 0 10px 32px rgba(42,107,124,.1); }
    .feat-icon { font-size: 1.8rem; margin-bottom: 1rem; }
    .feat-card h5 { font-family: var(--font-disp); font-size: 1.05rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; margin-bottom: .6rem; color: var(--brand); }
    .feat-card p { font-size: .86rem; color: var(--muted); line-height: 1.65; }

    /* ─── SPECS TABLE ─────────────────────────────────────────── */
    #specs { background: var(--bg); }
    .specs-table { width: 100%; border-collapse: separate; border-spacing: 0; font-family: var(--font-mono); font-size: .78rem; }
    .specs-table thead th { background: var(--bg-alt); border: 1px solid var(--border); padding: .7rem 1rem; letter-spacing: .1em; color: var(--teal-dark); font-weight: 600; text-transform: uppercase; font-size: .67rem; }
    .specs-table tbody td { border: 1px solid var(--border); padding: .65rem 1rem; color: var(--muted); transition: background .2s; }
    .specs-table tbody tr:hover td { background: var(--bg-card-alt); color: var(--brand); }
    .specs-table tbody td:first-child { color: var(--brand); font-weight: 500; }
    .pass-badge { display: inline-block; padding: .12rem .5rem; background: #d4edda; color: var(--green); border: 1px solid #a8d5b5; border-radius: 3px; font-size: .62rem; letter-spacing: .07em; }

    /* ─── CTA BANNER ──────────────────────────────────────────── */
    #cta { padding: 3rem 15px; background: var(--brand); position: relative; overflow: hidden; }
    #cta::before {
      content: '';
      position: absolute; inset: 0;
      background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(42,107,124,.25) 0%, transparent 65%);
    }
    /* Arc decoration on CTA too */
    .cta-arc {
      position: absolute; bottom: -80px; left: 50%; transform: translateX(-50%);
      width: 140%; height: 400px;
      border: 1px solid rgba(255,255,255,.06); border-radius: 50%;
      pointer-events: none;
    }
    .cta-eyebrow { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .22em; color: rgba(255,255,255,.5); text-transform: uppercase; margin-bottom: 1rem; }
    #cta h2 { font-family: var(--font-disp); font-size: clamp(2.4rem, 6vw, 3.4rem); font-weight: 900; text-transform: uppercase; line-height: .95; margin-bottom: 1.4rem; color: #fff; }
    #cta h2 span { color: #6ecbdb; }
    #cta p { font-size: 1rem; color: rgba(255,255,255,.6); max-width: 520px; margin: 0 auto 2rem; line-height: 1.7; }
    .color-dots { display: flex; gap: .5rem; justify-content: center; flex-wrap: wrap; margin-bottom: 2.5rem; }
    .color-dot { width: 26px; height: 26px; border-radius: 50%; border: 2px solid rgba(255,255,255,.2); transition: transform .2s, box-shadow .2s; cursor: pointer; }
    .color-dot:hover { transform: scale(1.28); box-shadow: 0 4px 12px rgba(0,0,0,.3); }
    .btn-cta-light { font-family: var(--font-disp); font-size: .88rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; background: #fff; color: var(--brand); border: none; padding: .85rem 2.2rem; border-radius: 4px; transition: all .25s; text-decoration: none; display: inline-block; }
    .btn-cta-light:hover { background: #e8f4f7; color: var(--teal-dark); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.15); }
    .btn-cta-outline { font-family: var(--font-disp); font-size: .88rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; background: transparent; color: rgba(255,255,255,.8); border: 1.5px solid rgba(255,255,255,.3); padding: .85rem 2.2rem; border-radius: 4px; transition: all .25s; text-decoration: none; display: inline-block; }
    .btn-cta-outline:hover { border-color: rgba(255,255,255,.7); color: #fff; }


    /* Rigid Foam */

    /* HERO */
.hero-rigid{padding-top:70px;min-height:90vh;position:relative;overflow:hidden;display:flex;align-items:flex-end;background:linear-gradient(135deg,#fffbf0 0%,#faf8f3 50%,#f5f0e8 100%);}
.hero-rigid .hero-cell-grid{position:absolute;top:70px;right:0;bottom:0;width:55%;display:grid;grid-template-columns:repeat(14,1fr);gap:4px;padding:1.5rem;opacity:0.65;}
.hero-rigid .foam-cell-hero{border-radius:3px;animation:cellAnim 5s ease-in-out infinite;}
@keyframes cellAnim{0%,100%{transform:scale(0.9);opacity:0.7;}50%{transform:scale(1);opacity:1;}}
.hero-rigid .hero-fade-r{position:absolute;top:70px;right:55%;bottom:0;width:180px;background:linear-gradient(to right,var(--offwhite),transparent);z-index:2;}
.hero-rigid .hero-fade-b{position:absolute;bottom:0;left:0;right:0;height:140px;background:linear-gradient(to bottom,transparent,var(--offwhite));z-index:2;}

.hero-rigid .hero-content{position:relative;z-index:3;padding:5rem 4rem 4rem;max-width:640px;}
.hero-rigid .hero-badge{display:inline-flex;align-items:center;gap:7px;background:var(--gold-lt);border:1px solid var(--gold-mid);color:var(--gold);font-size:0.7rem;letter-spacing:2px;text-transform:uppercase;padding:0.3rem 0.85rem;border-radius:20px;margin-bottom:1.5rem;font-weight:700;}
.hero-rigid .hero-badge::before{content:'';width:6px;height:6px;background:var(--gold);border-radius:50%;animation:blink 2s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.3;}}
.hero-rigid .hero-title{font-family:var(--font-display);font-size:clamp(3rem,6.5vw,6.5rem);line-height:0.92;letter-spacing:2px;margin-bottom:1.5rem;color:var(--text);}
.hero-rigid .hero-title .gold{color:var(--gold);}
.hero-rigid .hero-title .outline{-webkit-text-stroke:2px var(--gold);color:transparent;}


.hero-specs{position:absolute;bottom:0;right:0;z-index:3;display:flex;}
.spec-box{padding:1.2rem 1.8rem;background:var(--white);border-top:1px solid var(--border);border-left:1px solid var(--border);text-align:center;}
.spec-num{font-family:var(--font-display);font-size:1.8rem;color:var(--gold);letter-spacing:2px;}
.spec-label{font-size:0.68rem;color:var(--muted);letter-spacing:1px;text-transform:uppercase;}

    /* EXPANSION */
.expansion-section{background:var(--white);}
.expansion-visual{background:var(--offwhite);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;height:340px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);}
.mold-box{position:absolute;inset:2rem;border:2px dashed var(--border);border-radius:var(--radius);}
.mold-label{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--offwhite);font-size:0.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--subtle);padding:0 0.5rem;}
.foam-fill-div{position:absolute;bottom:2rem;left:2rem;right:2rem;transition:height 0.08s;border-radius:0 0 var(--radius) var(--radius);overflow:hidden;}
.foam-fill-body{position:absolute;inset:0;background:linear-gradient(to top,var(--gold) 0%,var(--amber) 60%,rgba(212,160,0,0.7) 100%);}
.foam-surface-line{position:absolute;top:0;left:0;right:0;height:4px;background:var(--white);opacity:0.6;}
.fill-pct-label{position:absolute;bottom:50%;left:50%;transform:translate(-50%,50%);font-family:var(--font-display);font-size:2.5rem;color:rgba(0,0,0,0.12);letter-spacing:4px;pointer-events:none;z-index:2;}
.exp-cells-container{position:absolute;inset:0;pointer-events:none;}
.exp-bubble{position:absolute;border-radius:50%;background:rgba(212,160,0,0.2);border:1px solid rgba(212,160,0,0.3);animation:bubbleUp 2s ease-out forwards;}
@keyframes bubbleUp{from{transform:scale(0);opacity:0.8;}to{transform:scale(3);opacity:0;}}
.expansion-controls{background:var(--offwhite);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:1.25rem 1.5rem;}
.range-styled{width:100%;accent-color:var(--gold);cursor:pointer;}
.range-label-row{display:flex;justify-content:space-between;font-size:0.7rem;color:var(--muted);margin-top:0.4rem;}

.exp-spec-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem;}
.exp-spec{background:var(--offwhite);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;}
.exp-spec-val{font-family:var(--font-display);font-size:1.5rem;letter-spacing:1px;}
.exp-spec-label{font-size:0.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-top:0.2rem;}

/* THERMAL */
.thermal-section{background:var(--bg);}
.thermal-container{border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;overflow:hidden;display:flex;height:340px;box-shadow:var(--shadow-sm);}
.thermal-outside{width:30%;position:relative;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:0.5rem;transition:background 0.5s;}
.thermal-foam-bar{width:12%;background:linear-gradient(180deg,var(--gold-lt),var(--gold-mid),var(--gold-lt));border-left:2px dashed var(--gold-mid);border-right:2px dashed var(--gold-mid);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:0.5rem;position:relative;}
.thermal-foam-bar::after{content:'ATLAS RF';writing-mode:vertical-rl;font-family:var(--font-display);font-size:0.8rem;letter-spacing:2px;color:var(--gold);opacity:0.5;}
.thermal-inside{flex:1;position:relative;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:0.5rem;transition:background 0.5s;background:rgba(255,100,50,0.07);}
.thermal-temp{font-family:var(--font-display);font-size:2.8rem;letter-spacing:2px;}
.thermal-sub{font-size:0.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
.thermal-controls{background:var(--offwhite);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:1.25rem 1.5rem;}
.delta-box{background:var(--volt-lt);border:1px solid #b8dda0;border-radius:var(--radius);padding:1rem 1.25rem;}

/* DENSITY CALCULATOR */
.calc-section{background:var(--bg);}
.calc-box{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;}
.calc-inputs{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--border);}
.calc-field{background:var(--white);padding:1.5rem;}
.calc-field label{font-size:0.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:0.5rem;font-weight:600;}
.calc-field input{width:100%;background:var(--offwhite);border:1px solid var(--border);color:var(--text);padding:0.7rem 0.9rem;font-size:1rem;font-family:var(--font-body);outline:none;transition:border-color 0.2s;border-radius:var(--radius);}
.calc-field input:focus{border-color:var(--gold);}
.calc-outputs{display:grid;grid-template-columns:repeat(3,1fr);background:var(--border);gap:1px;}
.calc-out{background:var(--offwhite);padding:1.5rem;text-align:center;}
.calc-out-val{font-family:var(--font-display);font-size:2rem;letter-spacing:2px;}
.calc-out-lbl{font-size:0.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-top:0.25rem;}
.calc-footer{padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;background:var(--gold-lt);border-top:1px solid var(--gold-mid);}

/* APPLICATIONS */
.applications-section{background:var(--bg);}
.app-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:1.5rem;}
.app-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow-sm);transition:box-shadow 0.25s,transform 0.25s;position:relative;overflow:hidden;}
.app-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform 0.35s;}
.app-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.app-card:hover::before{transform:scaleX(1);}
.app-num{font-family:var(--font-display);font-size:3.5rem;color:rgba(0,0,0,0.04);position:absolute;top:0;right:1rem;line-height:1;}
.app-line{width:36px;height:3px;background:var(--gold);border-radius:2px;margin-bottom:1rem;}
.app-card h5{font-size:0.95rem;font-weight:700;color:var(--text);margin-bottom:0.4rem;}
.app-card p{font-size:0.83rem;color:var(--muted);line-height:1.7;}
.app-spec-tag{font-size:0.68rem;color:var(--gold);letter-spacing:1px;text-transform:uppercase;font-weight:600;background:var(--gold-lt);padding:0.18rem 0.55rem;border-radius:20px;border:1px solid var(--gold-mid);display:inline-block;margin-top:0.75rem;}

/* SPEC TABLE */
.spec-section{background:var(--white);}
.spec-table{width:100%;border-collapse:collapse;}
.spec-table th{font-size:0.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--muted);padding:1rem 1.25rem;text-align:left;border-bottom:2px solid var(--border);font-weight:700;}
.spec-table td{padding:0.85rem 1.25rem;border-bottom:1px solid var(--light);font-size:0.85rem;color:var(--text);}
.spec-table tr:hover td{background:var(--gold-lt);}
.pass-badge{background:var(--volt-lt);color:var(--volt);font-size:0.68rem;padding:0.18rem 0.5rem;border-radius:20px;border:1px solid #b8dda0;font-weight:700;}
.gold-val{color:var(--gold);font-weight:600;}

/* CTA */
.cta-section{background:var(--gold);padding:5rem 15px;text-align:center;position:relative;overflow:hidden;}
.cta-section::before{content:'FOAM';font-family:var(--font-display);font-size:22vw;color:rgba(255,255,255,0.08);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);letter-spacing:5px;pointer-events:none;}
.cta-section h2{font-family:var(--font-display);font-size:clamp(1.5rem, 4.5vw, 3.4rem);letter-spacing:3px;color:#fff;margin-bottom:0.75rem;position:relative;}
.cta-section p{color:rgba(255,255,255,0.8);margin-bottom:2rem;position:relative;max-width:460px;margin-left:auto;margin-right:auto;}
.btn-cta-dark{background:var(--text);color:var(--gold-lt);padding:1rem 2.5rem;font-size:0.88rem;letter-spacing:2px;text-transform:uppercase;font-weight:700;text-decoration:none;border-radius:var(--radius);display:inline-block;transition:all 0.2s;position:relative;border:2px solid var(--text);}
.btn-cta-dark:hover{background:transparent;border-color:#fff;color:#fff;}

.fade-in{opacity:0;transform:translateY(24px);transition:opacity 0.7s ease,transform 0.7s ease;}
.fade-in.visible{opacity:1;transform:translateY(0);}

@media(max-width:768px){
  .nav-links{display:none;}
  .hero-content{padding:2rem;}
  .hero-cell-grid{opacity:0.2;}
  .hero-specs{position:relative;flex-wrap:wrap;}
  .calc-inputs{grid-template-columns:1fr;}
  .calc-outputs{grid-template-columns:1fr;}
  .app-grid-3{grid-template-columns:1fr;}
  .thermal-container{flex-direction:column;height:auto;}
}

/* Rubber Tile */

.section { padding: 7rem 0 ; }
.section-alt { background: var(--card); }
.section-white { background: var(--white); }
.section-dark { background: var(--text); color: #fff; }

/* Pad selector below xray */
.pad-selector { margin-top: 1.5rem; }
.pad-selector-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.5rem;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius) var(--radius) 0 0;
}
.pad-selector-head h6 {
  font-size: .72rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--c-muted); margin: 0;
}
.pad-density-display {
  font-family: var(--f-display); font-size: 1.6rem; color: var(--brand); letter-spacing: 1px;
}
.pad-options-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  border: 1px solid var(--border); border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  overflow: hidden;
}
.pad-opt {
  padding: 1.4rem 1.25rem;
  border-right: 1px solid var(--border);
  cursor: pointer;
  transition: background var(--t-fast);
  border-top: 3px solid transparent;
  background: var(--c-white);
}
.pad-opt:last-child { border-right: none; }
.pad-opt:hover { background: var(--card); }
.pad-opt.active { border-top-color: var(--brand); background: var(--c-accent-lt); }
.pad-opt-code {
  font-family: var(--f-display); font-size: 1.7rem; letter-spacing: 1px; color: var(--brand);
  margin-bottom: .25rem;
}
.pad-opt.active .pad-opt-code { color: var(--brand); }
.pad-opt-spec { font-size: .82rem; color: var(--c-text-2); margin-bottom: .3rem; font-weight: 500; }
.pad-opt-desc { font-size: .76rem; color: var(--c-muted); line-height: 1.5; }
.pad-opt-fr {
  margin-top: .75rem;
  font-size: .68rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--brand);
  background: var(--c-accent-lt); border: 1px solid var(--c-accent-mid);
  padding: .18rem .55rem; border-radius: 20px; display: inline-block;
}
.pad-opt.active .pad-opt-fr { background: #fff; }

/* ============================================================ 
   SECTION 01 — X-RAY INTERACTIVE SLIDER
   ============================================================ */
.xray-section { background: var(--c-white); }
.xray-label {
  font-size: .68rem; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--brand); margin-bottom: .4rem;
}

.xray-container {
  position: relative; height: 420px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  cursor: col-resize; user-select: none;
  box-shadow: var(--shadow-md);
}

/* Left side: finished gym */
.xray-left {
  position: absolute; top: 0; left: 0; bottom: 0;
  width: 100%;
  background:
    linear-gradient(to bottom, rgba(20,25,40,.5) 0%, rgba(20,25,40,.3) 100%),
    url('https://images.unsplash.com/photo-1534438327276-14e5300c3a48?auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
  display: flex; align-items: flex-end; padding: 1.5rem;
}
.xray-left-label {
  background: rgba(255,255,255,.12); backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  padding: .4rem .8rem; border-radius: var(--r-sm);
  font-size: .68rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: rgba(255,255,255,.8);
}

/* Right side: X-Ray layer view */
.xray-right {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: 50%;
  overflow: hidden; pointer-events: none;
  transition: width 0s;
}
.xray-right-inner {
  position: absolute; top: 0; right: 0; bottom: 0; left: 0;
  display: flex; flex-direction: column;
}
.xray-layer {
  display: flex; align-items: center;
  padding: 0 1.5rem;
  border-bottom: 1px dashed;
  position: relative; overflow: hidden;
}
.xray-layer:last-child { border-bottom: none; }
.xray-layer-name {
  font-size: .68rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  white-space: nowrap; position: relative; z-index: 1;
}
.xray-layer-depth {
  margin-left: auto;
  font-family: var(--f-display); font-size: 1.1rem; letter-spacing: 1px;
  position: relative; z-index: 1;
}
/* Individual layer styles */
.xray-l1 { flex: 1; background: rgba(30,60,160,.8); border-color: rgba(30,60,160,.5); }
.xray-l1 .xray-layer-name { color: #2040a0; } .xray-l1 .xray-layer-depth { color: #2040a0; }
.xray-l2 { flex: .5; background: rgba(224,92,0,.8); border-color: rgba(224,92,0,.5); }
.xray-l2 .xray-layer-name { color: var(--brand); } .xray-l2 .xray-layer-depth { color: var(--brand); }
.xray-l3 { flex: 1.8; background: rgba(74,138,0,.8); border-color: rgba(74,138,0,.25); }
.xray-l3 .xray-layer-name { color: var(--c-volt); } .xray-l3 .xray-layer-depth { color: var(--c-volt); }
.xray-l4 { flex: .5; background: rgba(224,92,0,.8); border-color: rgba(224,92,0,.2); }
.xray-l4 .xray-layer-name { color: var(--brand); opacity:1; } .xray-l4 .xray-layer-depth { color: var(--brand); opacity:1; }
.xray-l5 { flex: .8; background: rgba(0,0,0,.8); }
.xray-l5 .xray-layer-name { color: var(--c-muted); } .xray-l5 .xray-layer-depth { color: var(--c-muted); }

/* Drag handle */
.xray-handle {
  position: absolute; top: 0; bottom: 0; width: 4px;
  background: var(--brand); left: 50%;
  transform: translateX(-50%); z-index: 20;
  cursor: col-resize;
}
.xray-handle-knob {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 42px; height: 42px;
  background: var(--brand); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 1rem; font-weight: 700;
  box-shadow: var(--shadow-md);
  transition: transform var(--t-fast);
}
.xray-handle:hover .xray-handle-knob { transform: translate(-50%, -50%) scale(1.12); }

.xray-scan-hint {
  position: absolute; top: 1rem; left: 50%; transform: translateX(-50%);
  z-index: 15; white-space: nowrap;
  font-size: .68rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  background: rgba(255,255,255,.9); color: var(--brand);
  border: 1px solid var(--c-accent-mid);
  padding: .3rem .9rem; border-radius: 20px;
  animation: hintPulse 2.5s ease-in-out infinite;
  pointer-events: none;
}
@keyframes hintPulse { 0%,100%{opacity:1;} 50%{opacity:.5;} }


/* ============================================================
   SECTION 02 — COMPRESSION ANIMATION
   ============================================================ */
.compression-section { background: var(--card-2); }
.compression-canvas-wrap {
  background: var(--c-white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
#compressionCanvas {
  width: 100%; display: block;
}
.compress-stats-row {
  display: grid; grid-template-columns: repeat(3,1fr);
  border-top: 1px solid var(--border);
}
.compress-stat {
  padding: 1rem 1.5rem; text-align: center;
  border-right: 1px solid var(--border);
}
.compress-stat:last-child { border-right: none; }
.compress-stat-val {
  font-family: var(--f-display); font-size: 1.8rem; letter-spacing: 1px;
}
.compress-stat-lbl {
  font-size: .68rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--c-muted); margin-top: .2rem;
}
.btn-impact {
  background: var(--brand); color: #fff;
  border: none; cursor: pointer;
  padding: .75rem 2rem;
  font-family: var(--f-body); font-size: .82rem; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  border-radius: var(--r-sm);
  transition: background var(--t-fast);
  margin-top: 1.5rem;
}
.btn-impact:hover { background: #c05000; }
.btn-impact:disabled { opacity: .5; cursor: not-allowed; }

/* Energy bar */
.energy-bar-track {
  height: 8px; background: var(--border);
  border-radius: 4px; overflow: hidden; margin-top: .5rem;
}
.energy-bar-fill {
  height: 100%; background: var(--brand);
  border-radius: 4px; width: 0%;
  transition: width .08s linear;
}

/* ============================================================
   SECTION 03 — APPLICATION GALLERY
   ============================================================ */
.gallery-section { background: var(--c-white); }
.gallery-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: auto auto;
  gap: .75rem;
}
.gallery-card {
  position: relative; overflow: hidden;
  border-radius: var(--radius);
  min-height: 220px;
  display: flex; align-items: flex-end;
  cursor: pointer;
}
.gallery-card:first-child { grid-row: span 2; min-height: 460px; }
.gallery-card-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transition: transform .6s ease;
}
.gallery-card:hover .gallery-card-bg { transform: scale(1.04); }
.gallery-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.7) 25%, rgba(0,0,0,.5) 55%, transparent 100%);
  transition: opacity var(--t-med);
}
.gallery-card:hover .gallery-card-overlay { opacity: .85; }
.gallery-card-body {
  position: relative; z-index: 2; padding: 1.5rem;
  transform: translateY(4px); transition: transform var(--t-med);
}
.gallery-card:hover .gallery-card-body { transform: translateY(0); }
.gallery-card-tag {
  font-size: .65rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  background: var(--brand); color: #fff;
  padding: .2rem .6rem; border-radius: 2px;
  display: inline-block; margin-bottom: .5rem;
}
.gallery-card-tag.popular { background: var(--c-red); }
.gallery-card h5 { color: #fff; font-size: .95rem; font-weight: 700; margin-bottom: .25rem; }
.gallery-card p { color: rgba(255,255,255,.7); font-size: .78rem; line-height: 1.5; }

/* ============================================================
   SECTION 04 — INSTALLATION TIMELINE
   ============================================================ */
.timeline-section { background: var(--card-2); }
.timeline-outer { position: relative; padding: 1rem 0 1rem; }


.tl-spine {
  position: absolute; top: 26px; left: 0; right: 0; height: 2px;
  background: var(--border); border-radius: 2px;
}
.tl-spine-fill {
  position: absolute; top: 0; left: 0; height: 100%;
  background: var(--brand); border-radius: 2px;
  width: 0%; transition: width .7s cubic-bezier(.34,1.2,.64,1);
}

.tl-steps {
  display: grid; grid-template-columns: repeat(5,1fr);
  position: relative; z-index: 2;
  gap: 0;
}
.tl-step { text-align: center; padding: 0 .5rem; }
.tl-dot {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid var(--border);
  background: var(--c-white);
  margin: 0 auto .85rem;
  transition: all .3s ease;
  position: relative;
}
.tl-step.done .tl-dot {
  background: var(--brand); border-color: var(--brand);
}
.tl-step.done .tl-dot::after {
  content: '✓'; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: .55rem; color: #fff; font-weight: 700;
}
.tl-step.active .tl-dot {
  background: var(--brand); border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(224,92,0,.2);
}
.tl-time {
  font-family: var(--f-display); font-size: 1.4rem;
  color: var(--brand); letter-spacing: 1px; line-height: 1;
  margin-bottom: .2rem;
}
.tl-step:not(.done):not(.active) .tl-time { color: var(--c-subtle); }
.tl-name { font-size: 1rem; font-weight: 700; color: var(--c-text-2); margin-bottom: .3rem; }
.tl-step:not(.done):not(.active) .tl-name { color: var(--c-subtle); }
.tl-desc { font-size: .72rem; color: var(--c-muted); line-height: 1.5; }

.btn-tl {
  background: transparent; border: 2px solid var(--brand); color: var(--brand);
  padding: .7rem 1.8rem;
  font-family: var(--f-body); font-size: .8rem; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase;
  border-radius: var(--r-sm); cursor: pointer;
  transition: all var(--t-fast);
  margin-top: 2.5rem;
}
.btn-tl:hover { background: var(--brand); color: #fff; }

/* ============================================================
   SECTION 05 — FEATURES / WHY ATLAS
   ============================================================ */
.features-section { background: var(--c-white); }
.features-section .feature-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.75rem;
  height: 100%;
  transition: box-shadow var(--t-fast), transform var(--t-fast), border-color var(--t-fast);
  position: relative; overflow: hidden;
}
.features-section .feature-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--brand);
  transform: scaleX(0); transform-origin: left; transition: transform var(--t-med);
}
.features-section .feature-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: var(--c-accent-mid); }
.features-section .feature-card:hover::before { transform: scaleX(1); }
.features-section .feature-icon {
  font-size: 1.5rem; margin-bottom: 1rem;
  width: 44px; height: 44px;
  background: var(--c-accent-lt); border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
}
.features-section .feature-card h5 { font-size: .92rem; font-weight: 700; margin-bottom: .5rem; color: var(--c-text); }
.features-section .feature-card p { font-size: .82rem; color: var(--c-muted); line-height: 1.65; margin: 0; }

/* ============================================================
   SECTION 06 — SPEC TABLE
   ============================================================ */
.specs-section { background: var(--card-2); }
.spec-table-wrap {
  background: var(--c-white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.spec-table { width: 100%; border-collapse: collapse; }
.spec-table thead tr {
  background: var(--card-2);
  border-bottom: 2px solid var(--border);
}
.spec-table th {
  padding: .9rem 1.25rem;
  font-size: .7rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--c-muted); text-align: left;
}
.spec-table td {
  padding: .8rem 1.25rem;
  font-size: .85rem; color: var(--c-text-2);
  border-bottom: 1px solid var(--border);
}
.spec-table tbody tr:last-child td { border-bottom: none; }
.spec-table tbody tr:hover td { background: var(--card); }
.badge-pass {
  display: inline-block;
  background: var(--c-volt-lt); color: var(--c-volt);
  border: 1px solid #b8d890;
  font-size: .68rem; font-weight: 700; letter-spacing: 1px;
  padding: .18rem .55rem; border-radius: 20px;
}
.spec-accent { color: var(--brand); font-weight: 600; }

/* ============================================================
   SECTION 07 — CTA BANNER
   ============================================================ */
.cta-section {
  background: var(--brand);
  padding: 5.5rem 15px;
  text-align: center;
  position: relative; overflow: hidden;
}
.cta-section::before {
  content: 'STRENGTH';
  font-family: var(--f-display);
  font-size: 20vw;
  color: rgba(255,255,255,.06);
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  letter-spacing: 8px; white-space: nowrap;
  pointer-events: none;
}
.cta-section h2 {
  font-family: var(--f-display);
  font-size: clamp(1.5rem, 4vw, 3.4rem);
  letter-spacing: 3px; color: #fff;
  position: relative; margin-bottom: .75rem;
}
.cta-section p { color: rgba(255,255,255,.8); position: relative; max-width: 480px; margin: 0 auto 2rem; font-size: 1rem; }
.btn-cta-white {
  background: #fff; color: var(--brand);
  padding: .9rem 2.5rem;
  font-size: .85rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  text-decoration: none; border-radius: var(--r-sm); display: inline-block;
  transition: all var(--t-fast); position: relative;
  border: 2px solid #fff;
}
.btn-cta-white:hover { background: transparent; color: #fff; }
.btn-cta-outline-white {
  border: 2px solid rgba(255,255,255,.5); color: rgba(255,255,255,.9);
  padding: .9rem 2.5rem; margin-left: .75rem;
  font-size: .85rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  text-decoration: none; border-radius: var(--r-sm); display: inline-block;
  transition: all var(--t-fast); position: relative;
}
.btn-cta-outline-white:hover { border-color: #fff; color: #fff; background: rgba(255,255,255,.08); }
  .cta-section {
  padding:7rem 15px !important;
} 
/* ============================================================
   STATS STRIP
   ============================================================ */
.stats-strip { background: var(--brand); }
.strip-stat { text-align: center; border-right: 1px solid rgba(255,255,255,.15); padding: .5rem 0; }
.strip-stat:last-child { border-right: none; }
.strip-num {
  font-family: var(--f-display); font-size: 2.4rem; letter-spacing: 2px;
  color: #fff; line-height: 1;
}
.strip-lbl {
  font-size: .68rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
  color: rgba(255,255,255,.65); margin-top: .25rem;
}

/* ============================================================
   CERTIFICATE MARQUEE (like home page)
   ============================================================ */
.cert-marquee { background: var(--card-2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); overflow: hidden; padding: 1rem 0; }
.cert-track { display: flex; gap: 3rem; align-items: center; animation: marquee 20s linear infinite; white-space: nowrap; }
.cert-track:hover { animation-play-state: paused; }
.cert-item { font-size: .72rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--c-subtle); white-space: nowrap; }
.cert-dot { width: 4px; height: 4px; background: var(--brand); border-radius: 50%; flex-shrink: 0; }
@keyframes marquee { from{transform:translateX(0);} to{transform:translateX(-50%);} }


 .layer-card-div {
  display: flex;
  column-gap: 20px;
  flex-wrap: wrap;
 }
 .compliance-badge {
  height: 100%;
 }
  .layer-card-div .layer-card {
    width: 48%;
  }

  @media screen and (max-width:1599px) {
  span#typewriter {
  min-height: 160px;
}
}
  @media screen and (max-width:1199px) {
  span#typewriter {
  min-height: 140px;
}
}
  @media screen and (max-width:992px) {
  span#typewriter {
  min-height: 120px;
}
.navbar {
  background-color: var(--bg);
}
 .section-padding { 
    padding:5rem 0 !important;
   }
.py-5 {
  padding-top:5rem !important;
  padding-bottom:5rem !important;
} 
.pb-0 {
  padding-bottom:0 !important;
}
}

@media screen and (max-width:768px) {
    .layer-card-div .layer-card {
    width: 100%;
  }
  .cta-section {
  padding:5rem 15px !important;
}
}

@media screen and (max-width:580px) {
  .py-5 {
  padding-top:4rem !important;
  padding-bottom:4rem !important;
} 
  .cta-section {
  padding:4rem 15px !important;
}
.pb-0 {
  padding-bottom:0 !important;
}
  .hero-wrap {
    padding:0;
  }
  .hero-section {
    margin-left: 30px;
    margin-right:30px;
  }
      .hero-title {
        margin-bottom: 10px;
    }
}



    .hero {
  position: relative;
  overflow: hidden;
}
.btn-cta-light {
    border:2px solid #fff;
}

/* .hero-bottom-blur {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 30px;
  pointer-events: none;
  z-index: 2;

  background: linear-gradient(
    to top,
    rgba(251, 254, 241, 1),
    rgba(251, 254, 241, 0)
  );

  backdrop-filter: blur(12px);
} */
/* TOP FADE */
/* .hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 60px;
  pointer-events: none;
  z-index: 2;

  background: linear-gradient(
    to bottom,
    rgba(251, 254, 241, 1) 0%,
    rgba(251, 254, 241, 0.9) 40%,
    rgba(251, 254, 241, 0) 100%
  );

  backdrop-filter: blur(8px);
} */


    .chip-label {
    position: absolute;
    bottom: 4px;
    left: 0;
    right: 0;
    text-align: center;
    font-size: 10px;
    color: #fff;
    background: rgba(0, 0, 0, .4);
    border-radius: 4px;
}
    .highlight-value {
  font-size: 64px;
  font-weight: 800;
  color: #0f172a;
  text-shadow: 0 0 10px var(--amber);
}
   .gallery-card h5 {
    letter-spacing:2px;
   }
       .scroll-hint {
         position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    text-align: center;
    font-family: var(--font-mono);
    font-size: .65rem;
    color: var(--text-light);
    letter-spacing: .2em;
    text-transform: uppercase;
    opacity: 0;
    animation: fadeIn 1s 1.5s forwards;
    }
    .margin-top-3 {
        margin-top:3rem;
    }
    
    .ps-60 {
      padding-left:60px;
    }

  @media screen and( max-width:1399px) {
     #hero.rigid-foam-banner {
       height:99vh;
    }
    .logo-img {
        height:100px;
    }
    .hero {
        height:96vh;
    }
  }
    @media screen and (max-width:992px) {
       .ps-60 {
      padding-left:12px;
    }
    .section { padding: 5rem 0; } 
         .hero {
        padding-bottom: 100px;
        height:auto !important;
        padding-top: 0 !important;
       
    }
    .feature-card {
        max-width:100%;
    }

    }
    @media screen and (max-width:768px) {
       .opacity-5 {
        opacity: 0.5;
      }
      .cta-section {
        padding:4rem 15px !important;
      }
      .pad-options-grid {
              grid-template-columns: repeat(1, 1fr);
              border-bottom: 1px solid var(--border);
        }
        
        .gallery-grid {
                grid-template-columns: 1fr;
        }
        .tl-steps {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            position: relative;
            z-index: 2;
            gap: 20px;
        }
        .thermal-foam-bar , .thermal-outside{

            width: 100%;
        }
        .thermal-temp {
            font-size:2rem;
        }
        .thermal-foam-bar::after {

          writing-mode: horizontal-tb;
          font-size: 15px;
          display: flex;
          height: 70px;
          align-items: center;
          justify-content: center;
         }
    }
    @media screen and (max-width:575px) {
      .section { padding: 4rem 0; }
     .hero-sub {
      font-size: 13px !important;
      line-height: 19px !important;
     } 
      .dosage-grid {
        gap: 1rem;
      }
      .cfh-number , .highlight-value {
        font-size:2rem;
      }
      .cure-timeline {
        margin-top:1rem;
      }
        .logo-img {
            height:65px !important;
        }
        .mission-tabs {
          justify-content: center;
        }
        .icon {
          width: 45px !important;
          height: 45px !important;
        }
        .icon i {
          font-size: 15px;
        }
        #specs {
          padding: 4rem 0;
        }
        .pad-options-grid {
              grid-template-columns: repeat(1, 1fr);
        }
    }



/* -------------------------------- about us -------------------------- */
 
  /* ── CANVAS ── */
  .aboutbanner #heroCanvas {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    z-index: 2;
    pointer-events: none;
    opacity: 0.2;
  }
 
    @keyframes heroZoom {
      from { transform: scale(1.05); }
      to   { transform: scale(1.12); }
    }
 .aboutbanner   .hero-ov {
      position: absolute; inset: 0;
      background: radial-gradient(ellipse at center, rgba(27,42,74,0.6) 0%, rgba(27,42,74,0.97) 75%);
    }
    /* subtle grid lines */
 .aboutbanner   .hero-grid {
      position: absolute; inset: 0; pointer-events: none;
      background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
      background-size: 60px 60px;
      animation: gridDrift 30s linear infinite;
    }
    @keyframes gridDrift {
      from { background-position: 0 0; }
      to   { background-position: 60px 60px; }
    }
    /* glowing orange orb top-right */
  .aboutbanner  .hero-glow {
      position: absolute; top: -120px; right: -120px;
      width: 500px; height: 500px; border-radius: 50%;
      background: radial-gradient(circle, rgba(232,96,28,0.18) 0%, transparent 70%);
      pointer-events: none;
      animation: glowPulse 5s ease-in-out infinite;
    }
    @keyframes glowPulse {
      0%,100% { opacity: 0.7; transform: scale(1); }
      50%      { opacity: 1;   transform: scale(1.08); }
    }

    /* Ticker */
   .aboutbanner .hero-ticker {
      position: absolute; top: 0; left: 0; right: 0;
      background: rgba(0,0,0,0.25);
      border-bottom: 1px solid rgba(255,255,255,0.08);
      padding: 0.38rem 0; overflow: hidden;
    }
  .aboutbanner  .ticker-track {
      display: flex; gap: 2.5rem;
      animation: tickerRun 24s linear infinite;
      white-space: nowrap; width: max-content;
    }
 .aboutbanner   .ticker-item {
     
      font-size: 0.63rem; letter-spacing: 0.18em;
      text-transform: uppercase; color: rgba(255,255,255,0.4);
      flex-shrink: 0;
    }
 .aboutbanner   .ticker-item b { color: var(--orange); margin-right: 4px; }
    @keyframes tickerRun { from { transform: translateX(0); } to { transform: translateX(-50%); } }

    /* ── HERO CONTENT — CENTER ── */
   .aboutbanner .hero-inner {
      position: relative; z-index: 2;
      text-align: center;
      padding-top: 4rem; padding-bottom: 10rem;
      width: 100%;
    }
  .aboutbanner  .hero-eye {

      font-size: 0.65rem; letter-spacing: 0.22em;
      text-transform: uppercase; color: var(--orange);
      display: inline-flex; align-items: center; gap: 0.7rem;
      margin-bottom: 1.4rem;
      opacity: 0; animation: fadeInDown 0.7s 0.2s forwards;
    }
   .aboutbanner .hero-eye::before,
   .aboutbanner .hero-eye::after { content: ''; width: 26px; height: 1px; background: var(--orange); display: block; }

   
    .aboutbanner .hero-title .stroke {
      -webkit-text-stroke: 2px rgba(255,255,255,0.25);
      color: transparent;
    }
   .aboutbanner .hero-title .acc { color: var(--orange); }

    .aboutbanner .hero-desc {
      font-size: 1.05rem; line-height: 1.78;
      color: rgba(255,255,255,0.55);
      max-width: 520px; margin: 1.6rem auto 0;
      opacity: 0; animation: fadeInUp 0.8s 0.5s forwards;
    }
  .aboutbanner  .hero-btns {
      display: flex; gap: 0.8rem; margin-top: 2.2rem;
      flex-wrap: wrap; justify-content: center;
      opacity: 0; animation: fadeInUp 0.8s 0.65s forwards;
    }

    /* Decorative divider line */
   .aboutbanner .hero-line {
      width: 60px; height: 2px; background: var(--orange);
      margin: 1.5rem auto 0;
      opacity: 0; animation: expandLine 0.7s 0.45s forwards;
    }
    @keyframes expandLine {
      from { width: 0; opacity: 0; }
      to   { width: 60px; opacity: 1; }
    }

    .btn-org {
      background: var(--orange); color: var(--white);
      
      font-size: 0.82rem; font-weight: 700;
      letter-spacing: 0.12em; text-transform: uppercase;
      border: 2px solid var(--orange); padding: 0.7rem 1.8rem;
      border-radius: 3px; text-decoration: none;
      transition: all 0.25s; display: inline-flex; align-items: center; gap: 0.5rem;
    }
    .btn-org:hover { background: transparent; color: var(--orange); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(232,96,28,0.35); }

    .btn-wh {
      background: transparent; color: var(--white);
    
      font-size: 0.82rem; font-weight: 700;
      letter-spacing: 0.12em; text-transform: uppercase;
      border: 2px solid rgba(255,255,255,0.35); padding: 0.7rem 1.8rem;
      border-radius: 3px; text-decoration: none;
      transition: all 0.25s; display: inline-flex; align-items: center; gap: 0.5rem;
    }
    .btn-wh:hover { border-color: var(--white); background: rgba(255,255,255,0.08); color: var(--white); transform: translateY(-2px); }

    /* Stat bar */
    .stat-bar {
      position: absolute; bottom: 0; left: 0; right: 0; z-index: 3;
      background: rgba(15,24,44,0.92);
      backdrop-filter: blur(12px);
      border-top: 1px solid rgba(255,255,255,0.06);
    }
    .stat-item {
      padding: 1.2rem 1.5rem; text-align: center;
      border-right: 1px solid rgba(255,255,255,0.07);
      transition: background 0.25s;
    }
    .stat-item:last-child { border-right: none; }
    .stat-item:hover { background: rgba(232,96,28,0.08); }
  
    .stat-lbl {
    
      font-size: 0.58rem; letter-spacing: 0.14em;
      text-transform: uppercase; color: rgba(255,255,255,0.3);
      margin-top: 3px; display: block;
    }

    /* ── KEYFRAMES ── */
    @keyframes fadeInDown {
      from { opacity: 0; transform: translateY(-16px); }
      to   { opacity: 1; transform: none; }
    }
    @keyframes fadeInUp {
      from { opacity: 0; transform: translateY(22px); }
      to   { opacity: 1; transform: none; }
    }
    @keyframes fadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }

    /* ── SECTION UTILS ── */
    section { position: relative; }
    .sec-eye {
    
      font-size: 0.63rem; letter-spacing: 0.22em;
      text-transform: uppercase; color: var(--orange); margin-bottom: 0.6rem;
    }
    .sec-ttl {
     
      font-weight: 900; font-size: clamp(2rem, 4.5vw, 3.2rem);
      line-height: 0.95; text-transform: uppercase; color: var(--navy);
    }
    .dvd { width: 44px; height: 3px; background: var(--navy); margin: 1rem 0 1.4rem; }
    .dvd-c { margin-left: auto; margin-right: auto; }
    .body-t { font-size: 0.94rem; line-height: 1.82; color: var(--gray); }
    .text-org { color: var(--orange); }

    /* ── WHO WE ARE ── */
    .who {  background: var(--bg); }
    .who-card {
      background: var(--white); border: 1px solid var(--border1);
      border-radius: 4px; padding: 1.8rem; height: 100%;
      position: relative; overflow: hidden;
      transition: box-shadow 0.3s, transform 0.3s;
    }
    .who-card::after {
      content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
      background: var(--orange);
      transform: scaleX(0); transform-origin: left; transition: transform 0.35s;
    }
    .who-card:hover { box-shadow: 0 8px 30px rgba(27,42,74,0.11); transform: translateY(-4px); }
    .who-card:hover::after { transform: scaleX(1); }
    .wc-icon {
      width: 40px; height: 40px;
      border: 2px solid rgba(232,96,28,0.22);
      border-radius: 3px; display: flex; align-items: center; justify-content: center;
      color: var(--orange); font-size: 0.95rem; margin-bottom: 1rem;
    }
    .wc-title {
     
      font-weight: 700; font-size: 1.02rem; text-transform: uppercase;
      letter-spacing: 0.06em; color: var(--navy); margin-bottom: 0.45rem;
    }
    .chip {
          display: inline-block;
    font-family: 'Roboto Mono', monospace;
    font-size: 0.59rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 0.22rem 0.62rem;
    border: 1px solid rgba(27, 42, 74, 0.2);
    color: var(--navy);
    border-radius: 2px;
    margin-right: 0.35rem;
    margin-bottom: 0.35rem;
    transition: all 0.2s;
    opacity: 1;
    }
    .chip:hover { background: var(--navy); color: var(--white); }

    /* ── METRICS ── */
    .metrics { background: var(--brand); }
    .met-box {
      text-align: center; padding: 2rem 1rem;
      border-right: 1px solid rgba(255,255,255,0.07);
    }
    .met-box:last-child { border-right: none; }
    .met-num {
      
      font-weight: 900; font-size: clamp(2.8rem,5vw,4rem);
      color: #fff; line-height: 1; display: block;
    }
    .met-lbl {

      font-size: 14px; letter-spacing: 0.14em;
      text-transform: uppercase; color: rgba(255,255,255,0.6);
      margin-top: 0.45rem; display: block;
    }

    /* ── EXPANDING HORIZONS ── */
    .expand { background: var(--bg); border-top: 1px solid var(--border1); }
    .exp-feat {
      display: flex; gap: 1.2rem; align-items: flex-start;
      padding: 1.35rem 0; border-bottom: 1px solid var(--border1);
      transition: padding-left 0.22s;
    }
    .exp-feat:last-child { border-bottom: none; padding-bottom:0;}
    .exp-feat:hover { padding-left: 6px; }
    .exp-icon {
      width: 38px; height: 38px;
      border: 2px solid rgba(232,96,28,0.22); border-radius: 3px;
      display: flex; align-items: center; justify-content: center;
      color: var(--orange); font-size: 0.85rem; flex-shrink: 0; margin-top: 2px;
      transition: background 0.2s, color 0.2s;
    }
    .exp-feat:hover .exp-icon { background: var(--orange); color: #fff; }
    .exp-title {
     
      font-weight: 700; font-size: 1rem;
      text-transform: uppercase; letter-spacing: 0.06em;
      color: var(--navy); margin-bottom: 0.2rem;
    }

    /* ── MVV ── */
    .mvv { background: var(--cream); }
    .mvv-tabs-wrap {
      display: flex; border: 2px solid var(--navy); border-radius: 3px;
      overflow: hidden; width: fit-content; margin: 0 auto 2.5rem; flex-wrap: wrap;
    }
    .mvv-btn {
      background: transparent; color: var(--navy);
     
      font-size: 0.88rem; font-weight: 700;
      letter-spacing: 0.1em; text-transform: uppercase;
      border: none; border-right: 2px solid var(--navy);
      padding: 0.6rem 1.8rem; cursor: pointer; transition: all 0.2s;
    }
    .mvv-btn:last-child { border-right: none; }
    .mvv-btn.active, .mvv-btn:hover { background: var(--navy); color: var(--white); }
    .mvv-panel { display: none; }
    .mvv-panel.active { display: block; animation: fadeUp 0.38s ease; }
    .mvv-item {
      display: flex; gap: 1.1rem;
      padding: 1.35rem 0; border-bottom: 1px solid var(--border1);
      align-items: flex-start; transition: padding-left 0.2s;
    }
    .mvv-item:last-child { border-bottom: none; padding-bottom:0;}
    .mvv-item:hover { padding-left: 4px; }
    .mvv-big-n {
      
      font-weight: 900; font-size: 2.2rem;
      color: rgba(27,42,74,0.07); line-height: 1; min-width: 2.4rem;
    }
    .mvv-dot { width: 7px; height: 7px; background: var(--orange); border-radius: 50%; flex-shrink: 0; margin-top: 7px; }
    .mvv-title {
     
      font-weight: 700; font-size: 1.02rem; text-transform: uppercase;
      letter-spacing: 0.05em; color: var(--navy); margin-bottom: 0.28rem;
    }

    /* ── CERTS ── */
    .certs { padding: 3.5rem 0; background: var(--white); border-top: 1px solid var(--border1); border-bottom: 1px solid var(--border1); }
    .cert-scroll { overflow: hidden; }
    .cert-inner {
      display: flex; gap: 3.5rem; width: max-content;
      animation: scrollLeft 18s linear infinite;
    }
    .cert-item {
      height: 42px; flex-shrink: 0;
      display: flex; align-items: center;
      opacity: 0.4; filter: grayscale(1); transition: all 0.3s;
    }
    .cert-item:hover { opacity: 1; filter: none; }
    .cert-item img { height: 100%; width: auto; max-width: 120px; object-fit: contain; }
    @keyframes scrollLeft { from { transform: translateX(0); } to { transform: translateX(-33.33%); } }

    /* ── CTA BAND ── */
   
    .btn-org-lg {
      background: var(--orange); color: var(--white);
   
      font-size: 0.88rem; font-weight: 700; letter-spacing: 0.12em;
      text-transform: uppercase; border: 2px solid var(--orange);
      padding: 0.8rem 2rem; border-radius: 3px; text-decoration: none;
      transition: all 0.25s; display: inline-flex; align-items: center; gap: 0.5rem;
    }
    .btn-org-lg:hover { background: transparent; color: var(--orange); transform: translateY(-2px); }
    .btn-out-wh {
      background: transparent; color: var(--white);
      font-size: 0.88rem; font-weight: 700; letter-spacing: 0.12em;
      text-transform: uppercase; border: 2px solid rgba(255,255,255,0.45);
      padding: 0.8rem 2rem; border-radius: 3px; text-decoration: none;
      transition: all 0.25s; display: inline-flex; align-items: center; gap: 0.5rem;
    }
    .btn-out-wh:hover { border-color: var(--white); background: rgba(255,255,255,0.08); color: var(--white); transform: translateY(-2px); }

   .position-sticky {
    position:sticky;
    top:10px;
   }

    @media (max-width: 768px) {
      .m-nav { display: flex; }
      body { padding-bottom: 30px; }
      .dt-nav { display: none !important; }
      .stat-item { padding: 0.8rem 0.4rem; }
      .stat-num { font-size: 1.5rem; }
      .met-box { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.07); }
      .met-box:last-child { border-bottom: none; }
      .hero-inner { padding-bottom: 9rem; }
     
    }

    /* ── SCROLL REVEAL ── */
    .reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.65s ease, transform 0.65s ease; }
    .reveal-l { opacity: 0; transform: translateX(-26px); transition: opacity 0.65s ease, transform 0.65s ease; }
    .reveal-r { opacity: 0; transform: translateX(26px); transition: opacity 0.65s ease, transform 0.65s ease; }
    .vis { opacity: 1 !important; transform: none !important; }
    .d1 { transition-delay: 0.1s; } .d2 { transition-delay: 0.2s; }
    .d3 { transition-delay: 0.3s; } .d4 { transition-delay: 0.4s; }

    /* ── ATLAS ORB ── */
    .orb {
      position: fixed; bottom: 1.6rem; 
      width: 50px; height: 50px; border-radius: 50%;
      background: radial-gradient(circle at 40% 40%, #3aadcc, var(--teal));
      box-shadow: 0 0 0 0 rgba(58,173,204,0.4);
      animation: orbP 2.8s ease-in-out infinite;
      cursor: pointer; z-index: 100;
      display: flex; align-items: center; justify-content: center;
      border: 1px solid rgba(91,191,214,0.4); transition: transform 0.2s;
    }
    .orb:hover { transform: scale(1.1); }
    .orb i { color: var(--white); font-size: 0.95rem; }
    .orb-lbl {
      position: absolute; right: 58px; white-space: nowrap;
    font-size: 0.59rem;
      letter-spacing: 0.1em; text-transform: uppercase; color: var(--teal);
      background: var(--white); border: 1px solid var(--border1);
      padding: 0.28rem 0.65rem; border-radius: 2px;
      opacity: 0; pointer-events: none; transition: opacity 0.3s;
      box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    }
    .orb:hover .orb-lbl { opacity: 1; }
    @keyframes orbP {
      0%,100% { box-shadow: 0 0 0 0 rgba(58,173,204,0.4); }
      50%      { box-shadow: 0 0 0 10px rgba(58,173,204,0); }
    }

    /* ── FLOATING PARTICLES ── */
    .particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
    .particle {
      position: absolute; border-radius: 50%;
      background: rgba(232,96,28,0.35);
      animation: particleFloat linear infinite;
    }
    @keyframes particleFloat {
      0%   { transform: translateY(100vh) scale(0); opacity: 0; }
      10%  { opacity: 1; }
      90%  { opacity: 1; }
      100% { transform: translateY(-10vh) scale(1); opacity: 0; }
    }

    /* ── SCROLL INDICATOR ── */
    .scroll-hint {
      position: absolute; bottom: 5.5rem; left: 50%; transform: translateX(-50%);
      z-index: 4; text-align: center;
      animation: bobble 2s ease-in-out infinite;
    }
    .scroll-hint span {
      display: block;
    
      letter-spacing: 0.2em; color: rgba(255,255,255,0.3);
      text-transform: uppercase; margin-bottom: 6px;
    }
    .scroll-hint-arrow { display: flex; flex-direction: column; align-items: center; gap: 3px; }
    .scroll-hint-arrow i { color: rgba(255,255,255,0.25); font-size: 0.75rem; }
    @keyframes bobble {
      0%,100% { transform: translateX(-50%) translateY(0); }
      50%      { transform: translateX(-50%) translateY(5px); }
    }
    .section-padding {
        padding:7rem 0;
    }
    @media screen and (max-width:575px) {
        .mvv-btn {
            width: 100%;
            border-right:none;
        }
          .products-area{
    padding: 64px 0 60px;
  }

        .bounce-stat .val {
          font-size: 1.5rem;
        }
        .big-val {
          font-size: 1.2rem;
        }
        .section-padding {
            padding:4rem 0 !important;
        }
            .hero-content {
        padding: 1rem;
    }
    }


      .hero {
  position: relative;
  overflow: hidden;
}

.hero-top-blur {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 120px;
  pointer-events: none;
  z-index: 2;

  background: linear-gradient(
    to bottom,
    #FBFEF1 0%,
    rgba(251, 254, 241, 0.6) 40%,
    rgba(251, 254, 241, 0) 100%
  );
}

.hero-bottom-blur {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 140px;
  pointer-events: none;
  z-index: 2;

  background: linear-gradient(
    to top,
    #FBFEF1 0%,
    rgba(251, 254, 241, 0.7) 40%,
    rgba(251, 254, 241, 0) 100%
  );
}


/* ─── TIMELINE ─── */
.timeline-wrap {
  position: relative;
  padding-left: 0;
  margin-top: 1rem;
}
.timeline-wrap::before {
  content: '';
  position: absolute;
  left: 89px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--border1);
}
.tl-item {
  display: flex;
  gap: 1.5rem;
  align-items: flex-start;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--border1);
  position: relative;
}
.tl-item:last-child { border-bottom: none; }
.tl-year {
  font-family: var(--font-heading, sans-serif);
  font-weight: 900;
  font-size: 1rem;
  color: var(--orange);
  min-width: 60px;
  text-align: right;
  padding-top: 3px;
  flex-shrink: 0;
}
.tl-dot {
  width: 16px;
  height: 16px;
  background: var(--orange);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 5px;
  position: relative;
  z-index: 1;
  box-shadow: 0 0 0 3px rgba(232,96,28,0.18);
}
.tl-content { flex: 1; }
.tl-title {
  font-weight: 700;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--navy);
  margin-bottom: 0.25rem;
}
@media (max-width: 575px) {
  .hero-title , .hero-stat-val {
    font-size:1.5rem;
  }.hero-sub {
    margin-top: 15px;
    margin-bottom:0;
  }
.hero-cta-row {
  margin-top:1.2rem;
}
  .timeline-wrap::before { left: 65px; }
  .tl-year { font-size: 0.82rem; min-width: 44px; }
  .tl-item { gap: 1rem; }
}




/* ═══════════════════════════════════════════════════════════════
   NEOSOL F-1360 — FULL RESPONSIVE CSS
   Drop this entire block inside your <style> tag,
   replacing the existing styles completely.
═══════════════════════════════════════════════════════════════ */


/* ── SHARED ── */
.rf-section { padding: clamp(2.5rem, 7vw, 6rem) 0; }


/* ══════════════════════════════════════════════════════════════
   01 — FOAM MATRIX PENETRATION DEMO
══════════════════════════════════════════════════════════════ */
.pen-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.5rem;
  align-items: center;
}

.pen-panel {
  background: var(--navy); border-radius: 12px; padding: 2rem;
  box-shadow: 0 20px 60px rgba(11,29,42,.18);
  position: relative; overflow: hidden;
}
.pen-panel-label {
  font-size: .55rem; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(255,255,255,.35); font-weight: 800; margin-bottom: 1.25rem;
  display: flex; align-items: center; gap: .75rem;
}
.pen-panel-label::after { content: ''; flex: 1; height: 1px; background: rgba(255,255,255,.08); }

#foamCanvas {
  display: block; width: 100%; height: 240px;
  border-radius: 8px; margin-bottom: 1.25rem; cursor: pointer;
}

.pen-controls {
  display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem;
}
.pen-controls label {
  font-size: .6rem; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.4); font-weight: 700; flex-shrink: 0;
}
.pen-controls input[type=range] {
  flex: 1; -webkit-appearance: none; height: 5px; border-radius: 3px;
  background: rgba(255,255,255,.12); outline: none; cursor: pointer;
}
.pen-controls input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%;
  background: #fff; border: 3px solid var(--orange); box-shadow: 0 2px 8px rgba(0,0,0,.3);
}

.pen-metrics {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 1px; background: rgba(255,255,255,.07);
  border-radius: 6px; overflow: hidden;
}
.pen-metric { background: rgba(255,255,255,.04); padding: .9rem; text-align: center; }
.pen-metric-v {
  font-family: var(--display); font-size: 1.5rem;
  font-weight: 900; color: var(--white); line-height: 1;
}
.pen-metric-l {
  font-size: .52rem; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(255,255,255,.38); margin-top: .2rem;
}
.pen-footer {
  font-size: .54rem; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(255,255,255,.2); text-align: center;
  margin-top: 1rem; padding-top: .75rem;
  border-top: 1px solid rgba(255,255,255,.06);
}

.data-box {
  background: var(--cream); border: 1px solid var(--border);
  border-radius: 8px; padding: 1.5rem; margin-top: 1.5rem;
}
.data-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: .55rem 0; border-bottom: 1px solid var(--border);
  font-size: .82rem;
}
.data-row:last-child { border-bottom: none; padding-bottom: 0; }
.data-row span   { color: var(--muted); }
.data-row strong { font-family: var(--display); font-size: 1rem; font-weight: 900; color: var(--navy); }
.data-row strong.ok { color: var(--green); }
.data-row strong.hi { color: var(--brand); }


/* ══════════════════════════════════════════════════════════════
   02 — CURE TIMELINE  (TRUE LEFT–RIGHT ALTERNATING)
══════════════════════════════════════════════════════════════ */
.cure-section { background: var(--cream); }

.cure-timeline {
  position: relative;
  margin-top: 3rem;
}

/* Centre vertical line */
.cure-timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--brand), rgba(232,119,34,.1));
  transform: translateX(-50%);
}

/* 3-column grid: [left content] [dot] [right content] */
.cure-step {
  display: grid;
  grid-template-columns: 1fr 80px 1fr;
  gap: 0 1.5rem;
  align-items: center;
  margin-bottom: 2.5rem;
  position: relative;
}

/* ── ODD steps: content LEFT · dot CENTRE · empty RIGHT ── */
.cure-step:nth-child(odd) .cure-content { grid-column: 1; text-align: right; order: 1; }
.cure-step:nth-child(odd) .cure-dot     { grid-column: 2; order: 2; }
.cure-step:nth-child(odd) .cure-empty   { grid-column: 3; order: 3; display: block; }

/* ── EVEN steps: empty LEFT · dot CENTRE · content RIGHT ── */
.cure-step:nth-child(even) .cure-empty   { grid-column: 1; order: 1; display: block; }
.cure-step:nth-child(even) .cure-dot     { grid-column: 2; order: 2; }
.cure-step:nth-child(even) .cure-content { grid-column: 3; order: 3; text-align: left; }

/* Progress bar: mirror direction for left-side content */
.cure-step:nth-child(odd) .cure-bar-wrap { direction: rtl; }
.cure-step:nth-child(odd) .cure-bar      { direction: ltr; }

.cure-dot {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--navy);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-size: 1rem; font-weight: 900; color: #fff;
  flex-shrink: 0; z-index: 1;
  justify-self: center;
  box-shadow: 0 0 0 6px var(--cream2), 0 0 0 8px rgba(232,119,34,.2);
  transition: transform .3s, background .3s;
  cursor: pointer;
}
.cure-dot.active {
  background: var(--orange);
  box-shadow: 0 0 0 6px var(--cream2), 0 0 0 10px rgba(232,119,34,.3);
  transform: scale(1.15);
}
.cure-dot.passed { background: var(--brand); }

.cure-content  { padding: .25rem 0; }
.cure-time     { font-family: var(--display); font-size: 1.5rem; font-weight: 900; color: var(--brand); line-height: 1; }
.cure-title    { font-family: var(--display); font-size: 1.1rem; font-weight: 800; text-transform: uppercase; color: var(--navy); margin: .2rem 0 .4rem; }
.cure-desc     { font-size: .79rem; color: var(--muted); line-height: 1.75; }
.cure-bar-wrap { background: rgba(232,119,34,.12); border-radius: 4px; height: 6px; margin-top: .75rem; overflow: hidden; }
.cure-bar      { height: 100%; border-radius: 4px; background: var(--brand); width: 0; transition: width 1.2s ease; }

.cure-sim-btn {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--orange); color: #fff; border: none; border-radius: 4px;
  padding: .75rem 1.6rem; font-size: .68rem; letter-spacing: .14em;
  text-transform: uppercase; font-weight: 800; cursor: pointer; transition: background .2s;
  margin-top: 2.5rem;
}
.cure-sim-btn:hover { background: #c9611a; }


/* ══════════════════════════════════════════════════════════════
   03 — DOSAGE CALCULATOR
══════════════════════════════════════════════════════════════ */
.dosage-section { background: var(--white); }

.dosage-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 3.5rem;
  align-items: start;
}

.foam-types {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  margin-bottom: 1.75rem;
}
.foam-type-btn {
  padding: 1.1rem 1rem; border: 1.5px solid var(--border); border-radius: 8px;
  background: var(--cream2); cursor: pointer; transition: all .22s; text-align: left;
}
.foam-type-btn.active  { border-color: var(--orange); background: rgba(232,119,34,.05); }
.foam-type-btn:hover   { border-color: rgba(232,119,34,.4); }
.ftb-icon   { font-size: 1.5rem; margin-bottom: .4rem; }
.ftb-name   { font-family: var(--display); font-size: .95rem; font-weight: 800; text-transform: uppercase; color: var(--navy); }
.ftb-dosage { font-size: .68rem; color: var(--orange); font-weight: 700; }

.dosage-card        { background: var(--navy); border-radius: 12px; overflow: hidden; box-shadow: 0 12px 48px rgba(0,0,0,.16); }
.dosage-card-head   { background: var(--brand); padding: 1.6rem 1.9rem; }
.dosage-card-title  { font-family: var(--display); font-size: 1.6rem; font-weight: 900; text-transform: uppercase; color: #fff; }
.dosage-card-sub    { font-size: .72rem; color: rgba(255,255,255,.85); margin-top: .2rem; }
.dosage-card-body   { padding: 1.9rem; }

.dosage-field       { margin-bottom: 1.25rem; }
.dosage-field label {
  display: block; font-size: .54rem; letter-spacing: .16em;
  text-transform: uppercase; color: rgba(255,255,255,.4);
  font-weight: 700; margin-bottom: .4rem;
}
.dosage-field input,
.dosage-field select {
  width: 100%; background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12); border-radius: 5px;
  padding: .65rem .9rem; color: #fff; font-size: .95rem;
  font-family: var(--display); font-weight: 700;
  outline: none; transition: border-color .2s; appearance: none; box-sizing: border-box;
}
.dosage-field input:focus,
.dosage-field select:focus { border-color: var(--orange); }
.dosage-field select option { background: var(--navy); }

.dosage-fields-row  { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

.dosage-res-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 1px; background: rgba(255,255,255,.07);
  border-radius: 6px; overflow: hidden; margin-top: 1.25rem;
}
.dosage-res    { background: rgba(255,255,255,.03); padding: 1.1rem .9rem; text-align: center; }
.dosage-res-v  { font-family: var(--display); font-size: 1.8rem; font-weight: 900; color: var(--white); line-height: 1; }
.dosage-res-u  { font-size: .5rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.3); margin: .15rem 0; }
.dosage-res-l  { font-size: .65rem; color: rgba(255,255,255,.4); }
.dosage-note   { font-size: .62rem; color: rgba(255,255,255,.22); text-align: center; margin-top: .85rem; }


/* ══════════════════════════════════════════════════════════════
   04 — APPLICATION STEPS
══════════════════════════════════════════════════════════════ */
.steps-section { background: var(--cream); }

.steps-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}

.step-list { display: flex; flex-direction: column; gap: 1rem; }

.step-item {
  display: flex; gap: 1.25rem; padding: 1.25rem 1.4rem;
  border: 1.5px solid var(--border); border-radius: 8px; background: #fff;
  cursor: pointer; transition: all .22s; align-items: flex-start;
}
.step-item.active  { border-color: var(--brand); background: rgba(232,119,34,.04); }
.step-item:hover   { border-color: rgba(37,98,136,.4); }

.step-n {
  min-width: 40px; height: 40px; border-radius: 50%; background: var(--navy);
  color: #fff; display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-size: 1.1rem; font-weight: 900; flex-shrink: 0;
  transition: background .22s;
}
.step-item.active .step-n { background: var(--brand); }

.step-label      { font-family: var(--display); font-size: .95rem; font-weight: 800; text-transform: uppercase; color: var(--navy); margin-bottom: .3rem; }
.step-desc-short { font-size: .78rem; color: var(--muted); line-height: 1.7; }

.step-detail-panel {
  background: var(--navy); border-radius: 12px; padding: 2.5rem;
  position: sticky; top: 90px; min-height: 360px;
  box-shadow: 0 12px 48px rgba(11,29,42,.18);
}
.sdp-eyebrow { font-size: .54rem; letter-spacing: .2em; text-transform: uppercase; color: var(--orange); font-weight: 800; margin-bottom: .5rem; }
.sdp-title   { font-family: var(--display); font-size: 2rem; font-weight: 900; text-transform: uppercase; color: #fff; line-height: .95; margin-bottom: 1rem; }
.sdp-body    { font-size: .84rem; color: rgba(255,255,255,.6); line-height: 1.82; margin-bottom: 1.5rem; }
.sdp-tip     {
  background: rgba(232,119,34,.12); border: 1px solid rgba(232,119,34,.25);
  border-radius: 6px; padding: 1rem 1.1rem;
  font-size: .78rem; color: rgba(255,255,255,.75); line-height: 1.7;
}
.sdp-tip strong { color: var(--orange); }
.sdp-step-num {
  position: absolute; bottom: 2rem; right: 2rem;
  font-family: var(--display); font-size: 5rem; font-weight: 900;
  color: rgba(255,255,255,.05); line-height: 1; user-select: none;
}

.shelf-box {
  background: var(--navy); border-radius: 10px; padding: 2rem;
  text-align: center; margin-top: 1.5rem;
  box-shadow: 0 8px 32px rgba(11,29,42,.12);
}
.shelf-val { font-family: var(--display); font-size: 3.5rem; font-weight: 900; color: var(--orange); line-height: 1; }
.shelf-lbl { font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.4); margin-top: .4rem; }


/* ══════════════════════════════════════════════════════════════
   05 — FEATURES
══════════════════════════════════════════════════════════════ */
.feat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 1rem;
}
.feat-card {
  background: var(--cream); border: 1px solid var(--border);
  border-radius: 8px; padding: 1.75rem 1.5rem;
  position: relative; overflow: hidden;
  transition: all .25s; box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.feat-card::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--brand); transform: scaleX(0); transform-origin: left; transition: transform .3s;
}
.feat-card:hover { transform: translateY(-3px); box-shadow: 0 10px 32px rgba(0,0,0,.1); }
.feat-card:hover::after { transform: scaleX(1); }

.feat-icon-box {
  width: 50px; height: 50px; background: rgba(232,119,34,.1);
  border-radius: 8px; display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; margin-bottom: .85rem;
}
.feat-title { font-family: var(--display); font-size: 1rem; font-weight: 800; text-transform: uppercase; color: var(--navy); margin-bottom: .4rem; }
.feat-desc  { font-size: .78rem; color: var(--muted); line-height: 1.76; }


/* ══════════════════════════════════════════════════════════════
   06 — APPLICATIONS
══════════════════════════════════════════════════════════════ */
.apps-section { background: var(--cream); }

.apps-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 1.25rem; 
}
.app-card {
  background: #fff; border: 1px solid var(--border);
  border-radius: 10px; padding: 2rem 1.75rem;
  position: relative; overflow: hidden;
  transition: all .25s; box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.app-card::before {
  content: ''; position: absolute; top: 0; left: 0; bottom: 0;
  width: 4px; background: var(--orange);
  transform: scaleY(0); transform-origin: bottom; transition: transform .3s;
}
.app-card:hover { box-shadow: 0 10px 36px rgba(0,0,0,.1); transform: translateY(-2px); }
.app-card:hover::before { transform: scaleY(1); }

.app-num        { font-family: var(--display); font-size: 3.5rem; font-weight: 900; color: rgba(11,29,42,.08); line-height: 1; margin-bottom: .5rem; }
.app-card-title { font-family: var(--display); font-size: 1.2rem; font-weight: 800; text-transform: uppercase; color: var(--navy); margin-bottom: .6rem; }
.app-card-desc  { font-size: .8rem; color: var(--muted); line-height: 1.78; }
.app-card-tag   {
  display: inline-block; margin-top: .85rem;
  font-size: .66rem; letter-spacing: .12em; text-transform: uppercase;
  font-weight: 700; color: var(--brand);
  background: rgba(232,119,34,.1); padding: .28rem .75rem; border-radius: 2px;
}


/* ══════════════════════════════════════════════════════════════
   07 — SPEC TABLE
══════════════════════════════════════════════════════════════ */
.specs-section { background: var(--cream); }



/* ══════════════════════════════════════════════════════════════
   08 — SAFETY
══════════════════════════════════════════════════════════════ */
.safety-section { background: var(--white); }

.safety-box {
  background: var(--brand2); border-radius: 12px; padding: 3.5rem;
  box-shadow: 0 12px 48px rgba(42,107,124,.2);
}
.safety-box p { color: rgba(255,255,255,.78); line-height: 1.82; font-size: .88rem; margin-bottom: 1.5rem; }


/* ══════════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
══════════════════════════════════════════════════════════════ */

/* ── Tablet landscape: 1024px ── */
@media (max-width: 1024px) {
  .pen-grid       { gap: 2rem; }
  .dosage-grid    { gap: 2rem; }
  .steps-layout   { gap: 2.5rem; }
}

/* ── Tablet portrait: 900px ── */
@media (max-width: 900px) {
  .pen-grid       { grid-template-columns: 1fr; }
  .dosage-grid    { grid-template-columns: 1fr; }
  .steps-layout   { grid-template-columns: 1fr; }
  .step-detail-panel { position: static; min-height: auto; }
  .feat-grid      { grid-template-columns: 1fr 1fr; }
  .dosage-card-body { padding: 1.4rem; }
}

/* ── Mobile large: 768px — CURE TIMELINE collapses to single column ── */
@media (max-width: 768px) {
  .rf-section { padding: 4rem 0; }
  .cure-step:last-child {
    margin-bottom:0 !important ;
  }
  
  /* Cure timeline: single left-aligned column */
  .cure-timeline::before {
    left: 26px;
    transform: none;
  }

  .cure-step {
    grid-template-columns: 52px 1fr !important;
    grid-template-rows: auto;
    gap: 0 1rem;
  }

  /* Reset ALL column/order overrides for both odd and even */
  .cure-step:nth-child(odd)  .cure-dot,
  .cure-step:nth-child(even) .cure-dot {
    grid-column: 1 !important;
    grid-row: 1;
    order: 1 !important;
    justify-self: start;
    width: 52px; height: 52px;
  }

  .cure-step:nth-child(odd)  .cure-content,
  .cure-step:nth-child(even) .cure-content {
    grid-column: 2 !important;
    grid-row: 1;
    order: 2 !important;
    text-align: left !important;
  }

  .cure-step:nth-child(odd)  .cure-empty,
  .cure-step:nth-child(even) .cure-empty {
    display: none !important;
  }

  /* Reset progress bar direction */
  .cure-step:nth-child(odd) .cure-bar-wrap { direction: ltr; }
  .cure-step:nth-child(odd) .cure-bar      { direction: ltr; }

  /* dot ring adjusts for cream background change */
  .cure-dot { box-shadow: 0 0 0 5px var(--cream2), 0 0 0 7px rgba(232,119,34,.2); }

  /* Safety box padding */
  .safety-box { padding: 2rem 1.5rem; }

  /* Steps detail */
  .step-detail-panel { padding: 1.75rem; }
  .sdp-title { font-size: 1.5rem; }

  /* Spec table already has overflow-x:auto */
  .spec-table td { padding: .65rem .85rem; font-size: .76rem; }

  /* Dosage fields */
  .dosage-fields-row { grid-template-columns: 1fr; }
  .dosage-res-v      { font-size: 1.5rem; }
}

/* ── Mobile medium: 600px ── */
@media (max-width: 600px) {
  .apps-grid  { grid-template-columns: 1fr; }

  .pen-metrics { grid-template-columns: repeat(3,1fr); }

  .rf-title { font-size: clamp(1.8rem, 7vw, 2.8rem); }

  .dosage-card-head { padding: 1.2rem 1.4rem; }
  .dosage-card-body { padding: 1.2rem; }
  .dosage-res-v     { font-size: 1.3rem; }

  .shelf-val { font-size: 2.8rem; }
}

/* ── Mobile small: 480px ── */
@media (max-width: 480px) {
  .feat-grid  { grid-template-columns: 1fr; }

  .foam-types { grid-template-columns: 1fr 1fr; }

  .cure-timeline::before { display: none; }
.pad-density-display {
  font-size:15px;
}
  .cure-dot { width: 44px !important; height: 44px !important; font-size: .85rem; }

  .cure-time  { font-size: 1.2rem; }
  .cure-title { font-size: .95rem; }
  .cure-desc  { font-size: .74rem; }

  .hero-stats { flex-wrap: wrap; gap: .5rem; }

  .data-row { flex-direction: column; align-items: flex-start; gap: .2rem; }

  .pen-metric-v { font-size: 1.2rem; }

  .step-item { padding: 1rem 1rem; gap: 1rem; }
  .step-n    { min-width: 34px; height: 34px; font-size: .95rem; }

  .app-card  { padding: 1.5rem 1.25rem; }
  .app-num   { font-size: 2.5rem; }

  .sdp-step-num { font-size: 3.5rem; bottom: 1.25rem; right: 1.25rem; }
  .sdp-title    { font-size: 1.3rem; }
  .step-detail-panel { padding: 1.5rem; }
}


    /* Video */
.hero-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 20px;
}

/* Progress bar container */
.progress-bar {
  position: absolute;
  bottom: 10px;
  left: 10%;
  width: 80%;
  height: 4px;
  background: rgba(255,255,255,0.3);
  border-radius: 10px;
  overflow: hidden;
}

/* Progress fill */
.progress-bar::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 0%;
  background: #fff;
  transition: width linear;
}

  .cert-badge {
    background: #092B4F99;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border: 1px solid #092B4F99;
    color: #fff;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.6);
    padding: 8px 24px;
    letter-spacing: 0.14em;
    border-radius:5px;
}



/* -------------- our product ---------------- */
    /* ════════════════════════════════
       SEARCH BAR
    ════════════════════════════════ */
    .search-wrap {
      max-width: 1200px; margin: 0 auto;
      padding: 36px 52px 0;
      display: flex; align-items: center; justify-content: space-between;
      gap: 16px; flex-wrap: wrap;
    }
    .search-box {
      display: flex; align-items: center; gap: 0;
      background: var(--white);
      border: 1px solid var(--border);
      flex: 1; max-width: 360px;
    }
    .search-box input {
      flex: 1; padding: 11px 16px;
      border: none; outline: none;
      font-family: var(--fb); font-size: 14px;
      color: var(--navy); background: transparent;
    }
    .search-box input::placeholder { color: var(--muted); }
    .search-box button {
      padding: 11px 16px;
      background: var(--navy); border: none; cursor: pointer;
      color: var(--white); font-size: 15px;
      transition: background 0.2s;
    }
    .search-box button:hover { background: var(--brand); }

    .result-count {
      font-family: var(--fm); font-size: 11px;
      letter-spacing: 0.12em; text-transform: uppercase;
      color: var(--muted);
    }
    .result-count span { color: var(--navy); font-weight: 700; }

    /* ════════════════════════════════
       GRID
    ════════════════════════════════ */
    .grid-wrap {
      max-width: 1200px; margin: 0 auto;
      padding: 36px 52px 80px;
    }

    .product-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }

    /* ════════════════════════════════
       PRODUCT CARD
    ════════════════════════════════ */
  .product-grid  .card {
      background: var(--white);
      border: 1px solid var(--border);
      display: flex; flex-direction: column;
      position: relative;
      overflow: hidden;
      cursor: pointer;
      transition: transform 0.28s cubic-bezier(0.34,1.56,0.64,1),
                  box-shadow 0.28s ease,
                  border-color 0.22s;
      animation: cardIn 0.5s ease both;
    }
  .product-grid   .card:hover {
      transform: translateY(-8px);
      border-color: var(--navy);
      box-shadow: 0 20px 50px rgba(28,28,46,0.13);
    }

    /* top accent line slides in on hover */
   .product-grid  .card::before {
      content: '';
      position: absolute; top: 0; left: 0; right: 0; height: 3px;
      background: linear-gradient(90deg, var(--brand), var(--red));
      transform: scaleX(0); transform-origin: left;
      transition: transform 0.32s ease;
      z-index: 2;
    }
  .product-grid   .card:hover::before { transform: scaleX(1); }

    /* stagger */
  .product-grid   .card:nth-child(1) { animation-delay: 0.05s; }
  .product-grid   .card:nth-child(2) { animation-delay: 0.12s; }
 .product-grid    .card:nth-child(3) { animation-delay: 0.19s; }
  .product-grid   .card:nth-child(4) { animation-delay: 0.26s; }
  .product-grid   .card:nth-child(5) { animation-delay: 0.33s; }
  .product-grid   .card:nth-child(6) { animation-delay: 0.40s; }

    /* IMAGE */
  .product-grid   .card-img {
      position: relative;
      width: 100%; height: 220px;
      overflow: hidden;
      background: var(--cream-d);
    }
  .product-grid   .card-img img {
      width: 100%; height: 100%;
      object-fit: cover;
      transition: transform 0.5s ease, filter 0.3s ease;
      display: block;
    }
  .product-grid   .card:hover .card-img img {
      transform: scale(1.07);
    }

    /* category badge */
  .product-grid   .card-badge {
      position: absolute; top: 14px; left: 14px; z-index: 3;
      padding: 5px 11px;
      background: var(--navy);
      font-family: var(--fm); font-size: 9px;
      letter-spacing: 0.14em; text-transform: uppercase;
      color: var(--white);
    }


    /* BODY */
  .product-grid   .card-body {
      padding: 22px 24px 14px;
      flex: 1; display: flex; flex-direction: column; gap: 10px;
    }

 .product-grid    .card-num {
      font-family: var(--fm); font-size: 10px;
      letter-spacing: 0.16em; color: var(--muted);
    }

  .product-grid   .card-title {
      font-family: var(--fh);
      font-size: 22px; font-weight: 800;
      text-transform: uppercase; letter-spacing: 0.04em;
      color: var(--navy); line-height: 1.1;
    }

   .product-grid  .card-desc {
      font-size: 13px; line-height: 1.65;
      color: var(--muted); flex: 1;
    }

    /* FOOTER */
 .product-grid    .card-foot {
      padding: 0 24px 22px;
    }
   .product-grid  .card-link {
      display: flex; align-items: center; justify-content: space-between;
      padding: 12px 18px;
      background: var(--cream);
      border: 1px solid var(--border);
      text-decoration: none;
      transition: background 0.22s, border-color 0.22s;
    }
  .product-grid   .card-link:hover { background: var(--navy); border-color: var(--navy); }
  .product-grid   .card-link:hover .cl-text { color: var(--white); }
  .product-grid   .card-link:hover .cl-arrow { color: var(--white); background: var(--brand); }

    .cl-text {
      font-family: var(--fh); font-size: 13px; font-weight: 700;
      letter-spacing: 0.1em; text-transform: uppercase;
      color: var(--navy);
      transition: color 0.22s;
    }
    .cl-arrow {
      width: 28px; height: 28px;
      display: flex; align-items: center; justify-content: center;
      background: var(--navy); color: var(--white);
      font-size: 14px;
      transition: background 0.22s, color 0.22s;
      flex-shrink: 0;
    }

    /* ════════════════════════════════
       EMPTY STATE
    ════════════════════════════════ */
    .empty {
      grid-column: 1/-1;
      text-align: center;
      padding: 80px 20px;
      display: none;
    }
    .empty-num {
      font-family: var(--fh); font-size: 80px; font-weight: 900;
      color: var(--border); line-height: 1;
    }
    .empty-txt {
      font-size: 16px; color: var(--muted); margin-top: 12px;
    }


    /* ════════════════════════════════
       ANIMATIONS
    ════════════════════════════════ */
    @keyframes cardIn {
      from { opacity: 0; transform: translateY(32px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* ════════════════════════════════
       RESPONSIVE
    ════════════════════════════════ */
    @media (max-width: 1024px) {
      .product-grid { grid-template-columns: repeat(2, 1fr); }
    }
    @media (max-width: 720px) {

      .search-wrap, .grid-wrap { padding-left: 20px; padding-right: 20px; }
      .product-grid { grid-template-columns: 1fr; }
}




 

 

    /* ── PANELS ── */
    .directors-panel,
    .industries-panel {
      background: var(--white);
      border-radius: 20px;
      padding: 38px 34px;
      border: 1px solid var(--border);
      box-shadow: 0 4px 32px rgba(26,46,90,.07);
      height: 100%;
    }

    /* ── DIRECTOR CARDS ── */
    .dir-card {
      background: var(--white);
      border-radius: 14px;
      height:100%;
      padding: 22px 20px;
      border: 1px solid var(--border);
      border-left: 4px solid var(--brand);
      margin-bottom: 16px;
      transition: transform .3s, box-shadow .3s, border-left-color .3s;
    }
    .dir-card:last-child { margin-bottom: 0; }
    .dir-card:hover {
      transform: translateX(5px);
      box-shadow: 0 8px 28px rgba(26,46,90,.1);
      border-left-color: var(--navy);
    }

    .dir-av {
      width: 50px; height: 50px; border-radius: 50%; flex-shrink: 0;
      background: linear-gradient(180deg, #0b4f8f 0%, #2d73c7 62%, #93bde900 100%);
      display: flex; align-items: center; justify-content: center;
    
      font-size: 1.1rem; color: var(--white); font-weight: 700;
    }
    .dir-av.alt { background: linear-gradient(180deg, #0b4f8f 0%, #2d73c7 62%, #93bde900 100%); }

    .dir-role {
      font-size: .65rem; font-weight: 700;
      letter-spacing: .14em; text-transform: uppercase;
      color: var(--brand); margin-bottom: 2px;
    }
    .dir-name {
    
      font-size: 1.05rem; color: var(--navy); font-weight: 700;
    }
    .dir-bio {
      font-size: .85rem; color: var(--gray);
      line-height: 1.7; margin-top: 10px;
    }
    .dir-yrs {
      display: inline-flex; align-items: center; gap: 6px;
      margin-top: 12px;
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: 50px;
      padding: 4px 14px;
      font-size: .76rem; font-weight: 600; color: var(--navy);
    }
    .dir-yrs-dot {
      width: 7px; height: 7px; border-radius: 50%;
      background: var(--brand); flex-shrink: 0;
    }

    @media (max-width: 991px) {
      .directors-panel { margin-bottom: 24px; }
    }


    .ind-card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 22px 18px;
      transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease, background .28s ease;
      cursor: default;
      height:100%;
    }
    .ind-card:hover {
      transform: translateY(-5px);
      box-shadow: 0 12px 36px rgba(26,46,90,.12);
      border-color: var(--brand2);
      background: var(--white);
    }

    /* ── ICON BOX ── */
    .ind-icon-box {
      width: 52px; height: 52px;
      border-radius: 12px;
      background: var(--cream);
      border: 1px solid var(--border);
      display: flex; align-items: center; justify-content: center;
      font-size: 1.4rem;
      margin-bottom: 16px;
      transition: background .28s, border-color .28s;
    }
    .ind-card:hover .ind-icon-box {
      background: rgba(196,154,42,.12);
      border-color: var(--brand2);
    }

    /* ── CARD TEXT ── */
    .ind-name {
      font-size: 16px; font-weight: 700;
      text-transform: uppercase; letter-spacing: .08em;
      color: var(--navy); margin-bottom: 12px;
      position: relative; display: inline-block;
    }
    .ind-card li {
      font-size:16px;
    }
    .ind-name::after {
      content: '';
      display: block;
      width: 100%; height: 2px;
      background: linear-gradient(90deg, var(--brand2), transparent);
      border-radius: 1px; margin-top: 4px;
      transition: width .3s ease;
    }
    .ind-card:hover .ind-name::after { width: 110%; }

    .ind-app {
      font-size: .8rem;
      color: var(--gray);
      line-height: 1.6;
      margin-top: 4px;
    }


    
/* ── Active card highlight ── */
.feature-item {
  display: block;
  text-decoration: none;
  cursor: pointer;
  transition: transform .22s ease;
}
.feature-item:hover  { transform: translateY(-4px); }
.feature-item.active .feature-card {
  outline: 3px solid var(--brand2);
  outline-offset: 3px;
  border-radius: 14px;
}
.feature-item.active .feature-label {
  color: var(--apu-navy) !important;
}

/* ── Drawer wrapper ── */
.feature-drawer-wrap {
  overflow: hidden;
  max-height: 0;
  height:0;
  transition: max-height .45s cubic-bezier(.4,0,.2,1), opacity .35s ease;
  opacity: 0;
}
.feature-drawer-wrap.open {
  max-height: 100%;
  height:100%;
  opacity: 1;
}

/* ── Drawer card itself ── */
.feature-drawer {
  background: #fff;
  border: 1.5px solid var(--apu-navy);
  border-radius: 16px;
  overflow: hidden;
  margin-top: 24px;
}

/* ── Drawer header band ── */
.drawer-header {
  background: var(--brand2);
  padding: 20px 28px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.drawer-tag {
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--white);
  opacity: .85;
  margin: 0 0 8px;
  font-weight: 600;
}
.drawer-headline {

 
  color: #fff;
  margin: 0 0 3px;
 
}
.drawer-sub {
  font-size: .85rem;
  color: rgba(255,255,255,.65);
  margin: 0;
}
.drawer-close {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
  width: 32px;
  height: 32px;
  min-width: 32px;
  border-radius: 50%;
  font-size: 17px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, transform .2s;
  margin-top: 2px;
}
.drawer-close:hover {
  background: rgba(255,255,255,.26);
  transform: scale(1.1) rotate(90deg);
}

/* ── Stat items grid ── */
.drawer-body {
  padding: 22px 28px 26px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 767px) {
  .drawer-body     { grid-template-columns: repeat(2, 1fr); padding: 16px 18px 20px; }
  .drawer-header   { padding: 16px 18px; }
  .drawer-headline { font-size: 1.2rem; }
}
@media (max-width: 480px) {
  .drawer-body { grid-template-columns: 1fr; }
}

/* ── Single stat item ── */
.drawer-item {
  background: var(--cream);
  border-radius: 10px;
  padding: 14px 16px;
  border-left: 3px solid var(--brand);
  transition: background .2s, transform .2s;
}
.drawer-item:hover {
  background: #edecea;
  transform: translateX(3px);
}
.drawer-num {

  font-size: 1.6rem;
  font-weight: 700;
  color: var(--apu-navy);
  line-height: 1;
  margin-bottom: 5px;
}
.drawer-point-title {
  font-size: .98rem;
  font-weight: 700;
  color: var(--apu-navy);
  margin: 0 0 4px;
  line-height: 1.2;
}
.drawer-point-desc {
  font-size: .82rem;
  color: #4a4f6a;
  line-height: 1.55;
  margin: 0;
}

/* ── Chevron indicator on card ── */
.drawer-chevron {
  display: block;
  font-size: 11px;
  color: var(--apu-gold);
  margin-top: 4px;
  transition: transform .25s ease, opacity .2s;
  opacity: 0;
}
.feature-item:hover  .drawer-chevron,
.feature-item.active .drawer-chevron { opacity: 1; }
.feature-item.active .drawer-chevron { transform: rotate(180deg); }
       /* Navbar scroll behavior */
.navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.navbar.navbar--hidden {
    transform: translateY(-100%);
}

.navbar.navbar--scrolled {
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.12);
    background:var(--bg);
}
body {
    padding-top: 125px; /* adjust to match your navbar height */
}

@media screen and (max-width:575px) {
  
body {
    padding-top: 95px;
}
    span#typewriter {
        min-height: 80px;
    }
}

.rf-section.steps-section , .about-sticky{
  overflow: visible !important;
}

.navbar.navbar--scrolled .logo-img {
  height: 55px !important;
 
}

.navbar.navbar--scrolled {
  padding:6px 0 !important;
    
}

@media screen and (max-width:992px) {
 .navbar.navbar--scrolled {
  padding-bottom:15px !important;
    
} 
}
.navbar, .logo-img{
transition:all 0.3s ease-in-out ;
}


   .hero-top-blur {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 120px;
  pointer-events: none;
  z-index: 2;

  background: linear-gradient(
    to bottom,
    #FBFEF1 0%,
    rgba(251, 254, 241, 0.6) 40%,
    rgba(251, 254, 241, 0) 100%
  );
}

.hero-bottom-blur {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 140px;
  pointer-events: none;
  z-index: 2;

  background: linear-gradient(
    to top,
    #FBFEF1 0%,
    rgba(251, 254, 241, 0.7) 40%,
    rgba(251, 254, 241, 0) 100%
  );
}
   .social-sidebar {
  position: fixed;
  bottom:90px;
 right: 20px;
 z-index: 5;

}

/* Icons */
.icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 55px;
  height: 55px;
  margin: 10px 0;
  border-radius: 50%;
  color: #fff;
  font-size: 22px;
  text-decoration: none;
  transition: 0.3s;
}

/* Colors */
.instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366); }
.facebook { background: #1877f2; }
.twitter { background: #1da1f2; }
.youtube { background: #ff0000; }
.phone { background: var(--brand2); }
.whatsapp { background: #25d366; }
.social-sidebar-div {
  
  background: var(--brand);
  padding: 6px;
  border-radius: 40px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}
/* Hover effect */
.icon:hover {
  transform: scale(1.1);
}
 .mobile-sidebar-outer {
        display:none;
    }
  @media screen and (max-width:768px) {
    .social-sidebar {
        display:none;
    }
    .mobile-sidebar-outer {
 display:block;
    }
    .mobile-sidebar {
       
        position:fixed;
        bottom:0;
        width: 100%;
        background:#ffffff;
        z-index: 5;
        box-shadow: rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px;
    }
  }     


  .btn-pill{
    border-radius: 50px;
    padding: 12px 28px;
    font-weight: 600;
    text-decoration: none;
    display: inline-block;
    position: relative;
    overflow: hidden;
}

/* Pulse Animation */
.pulse-btn{
    background: #1f4571;
    color: #fff;
    animation: pulse 1.8s infinite;
    transition: 0.3s ease;
}

.pulse-btn:hover{
    transform: scale(1.05);
}

@keyframes pulse {
    0%{
        box-shadow: 0 0 0 0 rgba(31, 69, 113, 0.7);
    }
    70%{
        box-shadow: 0 0 0 18px rgba(31, 69, 113, 0);
    }
    100%{
        box-shadow: 0 0 0 0 rgba(31, 69, 113, 0);
    }
}

/* ----------- contact page -------------------------- */


/* PAGE */
.page-wrapper{min-height:100vh;display:flex;flex-direction:column;}

/* HERO ORB */
.hero-orb-section{padding:5rem 0 2rem;text-align:center;position:relative;}
.orb-wrap{display:inline-block;position:relative;margin-bottom:2rem;}
.orb{width:130px;height:130px;border-radius:50%;    background:var(--brand2);margin:0 auto;position:relative;animation:orbPulse 3s ease-in-out infinite;transition:background 0.7s ease;box-shadow:0 0 0 0 rgba(225,112,85,0.3);}
@keyframes orbPulse{0%,100%{box-shadow:0 0 0 0 rgba(225,112,85,0.2),0 4px 24px rgba(225,112,85,0.15);}50%{box-shadow:0 0 0 18px rgba(225,112,85,0.05),0 4px 32px rgba(225,112,85,0.2);}}
.orb-inner{position:absolute;inset:18%;border-radius:50%;background:rgba(255,255,255,0.25);animation:orbInner 3s ease-in-out infinite 0.5s;}
@keyframes orbInner{0%,100%{transform:scale(0.88);opacity:0.5;}50%{transform:scale(1.08);opacity:1;}}
.orb-ring{position:absolute;border-radius:50%;border:1px solid;pointer-events:none;}
.orb-ring-1{inset:-18px;border-color:rgba(225,112,85,0.25);animation:ringPulse 3s ease-in-out infinite;}
.orb-ring-2{inset:-36px;border-color:rgba(225,112,85,0.12);animation:ringPulse 3s ease-in-out infinite 0.8s;}
.orb-ring-3{inset:-54px;border-color:rgba(225,112,85,0.06);animation:ringPulse 3s ease-in-out infinite 1.6s;}
@keyframes ringPulse{0%,100%{transform:scale(1);opacity:0.7;}50%{transform:scale(1.04);opacity:0.3;}}
.orb-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:0.9rem;letter-spacing:3px;color:#fff;}

.hero-headline{font-size:clamp(3.5rem,9vw,7rem);letter-spacing:3px;line-height:0.92;color:var(--text);margin-bottom:0.75rem;}


/* CHAT */
.chat-section{padding:1.5rem 0 5rem;}
.chat-wrap{max-width:760px;margin:0 auto;}
.chat-window{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;min-height:400px;max-height:520px;overflow-y:auto;padding:1.75rem;display:flex;flex-direction:column;gap:1.1rem;box-shadow:var(--shadow-sm);}
.chat-window::-webkit-scrollbar{width:4px;}
.chat-window::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}

.msg{display:flex;gap:0.9rem;align-items:flex-start;animation:msgIn 0.35s cubic-bezier(.34,1.56,.64,1);}
@keyframes msgIn{from{opacity:0;transform:translateY(8px) scale(0.97);}to{opacity:1;transform:translateY(0) scale(1);}}
.msg-atlas{flex-direction:row;}
.msg-user{flex-direction:row-reverse;}
.msg-avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:0.8rem;letter-spacing:1px;}
.msg-atlas .msg-avatar{background:var(--red);color:#fff;}
.msg-user .msg-avatar{background:var(--light);color:var(--muted);font-size:0.65rem;font-weight:700;}
.msg-bubble{max-width:78%;padding:0.85rem 1.1rem;border-radius:var(--radius);font-size:0.88rem;line-height:1.65;}
.msg-atlas .msg-bubble{background:var(--offwhite);border:1px solid var(--border);color:var(--text);}
.msg-user .msg-bubble{background:var(--red);color:#fff;border:none;}
.msg-bubble p{margin:0;}
.msg-options{display:flex;gap:0.5rem;flex-wrap:wrap;margin-top:0.75rem;}
.opt-btn{background:#fff;border:1.5px solid var(--border);color:var(--text);padding:0.45rem 0.9rem;font-size:0.78rem;letter-spacing:0.5px;font-weight:600;border-radius:var(--radius);cursor:pointer;transition:all 0.2s;}
.opt-btn:hover,.opt-btn.selected{background:var(--red , #092B4F);color:#fff;border-color:var(--red , #092B4F);}

.typing-wrap{display:flex;gap:4px;align-items:center;padding:0.6rem 0;}
.typing-dot{width:5px;height:5px;background:var(--subtle);border-radius:50%;animation:typeBounce 1.2s ease-in-out infinite;}
.typing-dot:nth-child(2){animation-delay:0.2s;}
.typing-dot:nth-child(3){animation-delay:0.4s;}
@keyframes typeBounce{0%,80%,100%{transform:scale(0.8);opacity:0.5;}40%{transform:scale(1.2);opacity:1;}}

.chat-input-bar{background:var(--brand);color:#fff;border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:0.9rem 1.25rem;display:flex;gap:0.75rem;align-items:center;}
.chat-input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:0.9rem;}
.chat-input::placeholder{color:var(--subtle);}
.chat-send{background:var(--red);color:#fff;border:none;width:38px;height:38px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;flex-shrink:0;transition:background 0.2s;}
.chat-send:hover{background:#b81a1a;}
.chat-meta{display:flex;align-items:center;justify-content:space-between;padding:0.6rem 0.25rem;}
.btn-reset{background:transparent;border:1px solid var(--border);color:var(--muted);padding:0.35rem 0.75rem;font-size:0.7rem;letter-spacing:1px;text-transform:uppercase;border-radius:var(--radius);cursor:pointer;transition:all 0.2s;}
.btn-reset:hover{border-color:var(--text);color:var(--text);}

/* CONTACT SECTION */
.contact-section{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:5rem 0;}
.section-eyebrow{font-size:0.7rem;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:0.6rem;display:block;font-weight:700;}
.section-title{font-size:clamp(2rem,4vw,3rem);letter-spacing:2px;line-height:1.05;color:var(--text);}
.divider{width:50px;height:3px;margin:1.25rem 0 1.5rem;border-radius:2px;}

.contact-method{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:0.75rem;text-decoration:none;color:var(--text);transition:all 0.2s;box-shadow:var(--shadow-sm);}
.contact-method:hover{border-color:var(--red);box-shadow:var(--shadow);color:var(--text);}
.contact-method:hover .cmethod-arrow{color:var(--red);}
.cmethod-icon{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0;}
.cmethod-label{font-size:14px;letter-spacing:1px;text-transform:uppercase;color:var(--brand2);font-weight:600;margin-bottom:0.15rem;}
.cmethod-val{font-size:0.92rem;color:var(--text);font-weight:500;text-decoration:none;}
.cmethod-arrow{margin-left:auto;color:var(--subtle);font-size:1rem;transition:color 0.2s;}

.address-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-top:1rem;}
.address-card h6{font-size:14px;letter-spacing:2px;text-transform:uppercase;color:var(--brand2);margin-bottom:0.5rem;font-weight:700;}
.address-card p{font-size:0.85rem;color:var(--text);line-height:1.7;margin-bottom:1rem;}
.address-card p:last-child{margin-bottom:0;}

/* MAP */
.map-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;box-shadow:var(--shadow-sm);}
.map-card h5{font-size:1.2rem;letter-spacing:2px;color:var(--muted);margin-bottom:1.5rem;}
.hub-ring-anim{animation:hubRingAnim 2.5s ease-out infinite;}
@keyframes hubRingAnim{0%{transform:scale(1);opacity:0.6;}100%{transform:scale(2.8);opacity:0;}}
.hub-dot{animation:hubDotBlink 2s ease-in-out infinite;}
@keyframes hubDotBlink{0%,100%{opacity:1;}50%{opacity:0.4;}}

.shipping-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;margin-top:1rem;}
.shipping-stat{background:var(--card);padding:1rem;text-align:center;}
.shipping-stat-num{font-size:1.6rem;color:var(--red);letter-spacing:1px;}
.shipping-stat-label{font-size:0.68rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}

.msg-atlas .msg-avatar {
  background: var(--red, #092B4F); /* fallback */
}

@media screen and (max-width:992px) {
  .chat-section {
    padding: 5rem 0 5rem;
} 
 .contact-section {
  padding-bottom:4rem;
 }
}
@media screen and (max-width:575px) {
  .contact-section {
  
    padding-top:40px;
  }
  .hero-orb-section {
    padding-bottom:0;
    padding-top:50px;
  }
  .chat-section {
    padding:4rem 0;
  }
  .divider {
    margin:5px 0;
  }
  .shipping-stat-num {
    font-size:20px;
  }
}


/* ----------------- about us ----------------------- */
 .binder-list .o4-head { text-align: center; margin-bottom: 52px; }
.binder-list .o4-head .eyebrow {
  font-size: 11px; font-weight: 600; letter-spacing: 3.5px;
  text-transform: uppercase; color: #c9a84c;
  display: block; margin-bottom: 10px;
}
.binder-list .o4-head h2 {

  font-size: clamp(1.9rem, 4vw, 2.9rem);
  font-weight: 800; color: #1d2c6b;
  letter-spacing: 1px; text-transform: uppercase;
}
.binder-list .o4-head h2 span { color: #c9a84c; }
.binder-list .o4-head .gold-line {
  width: 56px; height: 3px;
  background: #c9a84c; border-radius: 4px;
  margin: 14px auto 0;
}

.binder-list .o4-strip {
  display: grid;
  grid-template-columns: 72px 1fr auto;
  align-items: center;
  gap: 22px;
  padding: 40px 30px;
  border-bottom: 1px solid rgba(29,44,107,0.2);
  transition: background 0.2s;
  position: relative;
}
.binder-list .o4-strip:first-child { border-top:1px solid rgba(29,44,107,0.2); }
.binder-list .o4-strip:hover { background: rgba(29,44,107,0.025); }
.binder-list .o4-strip::before {
  content: '';
  position: absolute;
  left: 0; top: 0%; height: 100%;
  width: 3px;
  background: transparent;
  border-radius: 0 4px 4px 0;
  transition: background 0.2s;
}
.binder-list .o4-strip:hover::before { background: var(--brand); }

.binder-list .o4-icon-col {
  display: flex; flex-direction: column;
  align-items: center; gap: 5px;
}
.binder-list .o4-strip-num {

  font-size: 14px; font-weight: 800;
  letter-spacing: 2px; color: var(--brand);
}
.binder-list .o4-icon-box {
  width: 50px; height: 50px;
  border-radius: 13px;
  background: #1d2c6b;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: var(--white);
  flex-shrink: 0;
  transition: background 0.22s;
}
.binder-list .o4-strip:hover .o4-icon-box { background: #2b3990; }

.binder-list .o4-body h3 {
 
  font-size: 1.02rem; font-weight: 800;
  color: #1d2c6b; text-transform: uppercase;
  letter-spacing: 1.2px; margin-bottom: 6px;
}
.binder-list .o4-body p {
 line-height: 1.68; margin: 0;
}
.binder-list .o4-body p strong { color: #1d2c6b; font-weight: 600; }

.binder-list .o4-badge {
  font-size: 10px; font-weight: 700;
  letter-spacing: 1.8px; text-transform: uppercase;
  color: var(--brand2);
  background: var(--white);
  padding: 5px 12px;
  border-radius: 40px;
  border: 1px solid var(--brand2);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 767px) {

  /* opt4 */
 .binder-list .o4-strip { grid-template-columns: 58px 1fr; gap: 14px; padding: 18px 20px; }
 .binder-list .o4-badge { display: none; }
}

@media (max-width: 480px) {

 .binder-list .o4-strip { padding: 16px 18px; }
}

.industrial-image-div {
  width: 100%;
  border-radius:12px;
  overflow:hidden;
}
.industrial-image-div img {
  width: 100%;
}

  .our-project-galley .project-gallery-image {
    border-radius:10px;
    overflow:hidden;
    width:100%;
  }
  .our-project-galley .project-gallery-image img {
    width:100%;
    scale:1;
    transition:all 0.3s ease-in-out;
  }
    .our-project-galley .project-gallery-image:hover img {
      scale:1.08;
    }