:root {
  --st-blue-900: #013577;
  --st-blue-800: #043777;
  --st-blue-700: #136bdd;
  --st-blue-600: #246fd6;
  --st-blue-100: #eef6fd;
  --st-text: #1f2124;
  --st-muted: #4b5563;
  --st-black: #000;
  --st-border: #e5e7eb;
  --st-accent: #ff9327;
}

/* =========================
   Shared Base / Home Page Styles
   ========================= */
*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  color: var(--st-text);
  font-family: "Inter", sans-serif;
  font-size: 18px;
  line-height: 24px;
  font-weight: 400;
}
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}
p,
li,
a,
span {
  font-weight: 400;
}
ol,
ul {
  list-style: none;
}
img,
svg,
path,
a,
img:hover,
svg:hover,
a:hover,
button,
button:hover {
  transition: all 0.5s ease-in-out;
}
img {
  max-width: 100%;
  height: auto;
  object-fit: cover;
  vertical-align: middle;
}
.container {
  max-width: 1280px;
  padding: 0;
}
a {
  text-decoration: none;
  color: #013577;
}
.font-italic {
  font-style: italic;
}
.fw_700 {
  font-weight: 700;
}
main#main-content {
  overflow-x: hidden;
}

.topbar {
  min-height: 60px;
  border-bottom: 1px solid #f3f4f6;
  background: #ffffff;
}

.subbar {
  min-height: 60px;
  background: var(--st-blue-800);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.brand-main {
  width: 173px;
}

.brand-sub {
  width: 162px;
}

.navbar .nav-link {
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
  padding: 28px 0 !important;
  color: #1f2937;
}

.subbar .sub-link {
  color: #ffffff;
  position: relative;
}
.subbar .sub-link::after,
.subbar .sub-link.active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: #fff;
  transition: all 0.5s ease-in-out !important;
  -webkit-transition: all 0.5s ease-in-out !important;
  -moz-transition: all 0.5s ease-in-out !important;
  -ms-transition: all 0.5s ease-in-out !important;
  -o-transition: all 0.5s ease-in-out !important;
}
.subbar .sub-link:hover::after,
.subbar .sub-link.active::after {
  width: 100%;
}
.subbar .sub-link.active {
  color: #fff;
}
.sub-link:hover,
.sub-link:focus {
  color: #ffffff;
}

.navbar-toggler {
  border: 0;
}

.navbar-toggler:focus {
  box-shadow: none;
}

.navbar-toggler--light {
  border-color: rgba(255, 255, 255, 0.4);
  background: transparent;
  border: 0;
}

.navbar-toggler--light .navbar-toggler-icon {
  filter: invert(1);
}

.subbar .btn-primary {
  background: var(--st-blue-600);
  border-color: var(--st-blue-600);
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
  min-height: 44px;
  padding: 10px 20px !important;
  border-radius: 999px;
}

.nst-smarttrack-exact-page .subbar {
    position: fixed;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 100;
}

.section-space {
  padding-top: 100px;
  padding-bottom: 100px;
}

.hero {
  min-height: 720px;
  display: flex;
  align-items: center;
  background: linear-gradient(180deg, #f5f7fa 0%, rgba(245, 247, 250, 0) 100%);
  padding: 140px 0 50px;
}

.display-title {
  margin: 0;
  color: var(--st-blue-900);
  font-size: 48px;
  line-height: 60px;
  font-weight: 700;
}

.lead-copy {
  color: var(--st-black);
  font-size: 20px;
  line-height: 28px;
  max-width: 570px;
  margin: 0;
  font-weight: 400;
}

.hero-copy {
  display: flex;
  flex-direction: column;
  gap: 27px;
  margin-bottom: 44px;
  max-width: 584px;
}

.hero-actions,
.need-stack-title-box,
.image_text_block_title_box {
  gap: 16px;
}

.btn-accent {
  background: var(--st-accent);
  color: #ffffff;
  border: 1px solid var(--st-accent);
  min-height: 44px;
  padding: 10px 24px;
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
}

.hero-actions .btn {
  min-height: 44px;
  padding: 10px 24px;
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.hero-actions .btn-light {
  background: #ffffff;
  color: #1f2937;
  border: 1px solid #e5e7eb;
}

.btn-accent:hover {
  background: #f58412;
  border-color: #f58412;
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(245, 132, 18, 0.25);
}

.hero-visual {
  position: relative;
  max-width: 637px;
}

.hero-ring {
  width: 587px;
  height: 587px;
  border: 2px dashed #d1d5dc;
  border-radius: 999px;
  padding: 27px;
  margin: 0 auto;
}

.hero-ring img {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  object-fit: cover;
}

.floating-card {
  position: absolute;
  background: #ffffff;
  border: 1px solid #f3f4f6;
  border-radius: 12px;
  box-shadow:
    0 13px 10px rgba(0, 0, 0, 0.1),
    0 5px 4px rgba(0, 0, 0, 0.1);
  padding: 22px 21px 22px 22px;
  font-size: 15px;
  line-height: 21px;
  font-weight: 400;
}

.floating-card strong {
  display: block;
  color: var(--st-blue-900);
  font-size: 18px;
  line-height: 26px;
  font-weight: 700;
}

.floating-top {
  top: 26px;
  right: 0;
}

.floating-bottom {
  bottom: 24px;
  left: 24px;
}
.floating-bottom span {
  font-size: 15px;
  line-height: 20px;
  color: #1f2124;
}
.section-title {
  color: var(--st-blue-900);
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
  margin: 0;
}

.section-intro {
  color: var(--st-blue-900);
  font-size: 24px;
  line-height: 32px;
  font-weight: 600;
  margin: 0;
}

.quote-panel-area {
  gap: 100px;
}
.quote-panel {
  background-color: var(--st-blue-800);
  background-image: url(../images/SmartTrack_bg_shap_1.png);
  background-size: cover;
  background-repeat: no-repeat;
  width: 100%;
  display: block;
  border: 4px solid #d8e8fe;
  border-radius: 28px;
  padding: 96px 240px;
}

.quote-panel p {
  margin: 0;
  color: #ffffff;
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
}

.SmartTrack_collaboration_area.row,
.Digital_Evidence_info_area {
  gap: 50px;
}

.SmartTrack_collaboration_section .section-title {
  margin: 0;
}

.collab-cards {
  --bs-gutter-x: 12px;
  --bs-gutter-y: 12px;
}

.partner-card {
  border: 1px solid var(--st-border);
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  gap: 40px;
  padding: 32px;
}

.partner-card h3,
.split-content .section-title {
  margin: 0;
  color: var(--st-blue-900);
  font-size: 24px;
  line-height: 32px;
  font-weight: 700;
}

.partner-card h3 {
  max-width: 456px;
}

.partner-logo {
  width: 116px;
}

.partner-wide {
  width: 186px;
}
.partner-card-inner {
  gap: 18px;
}
.btn_blue_arrow {
  background: #2670d5;
  border-color: #2670d5;
  color: #ffffff;
  font-size: 18px;
  line-height: 24px;
  font-weight: 600;
  min-height: 48px;
  padding: 12px 20px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: max-content;
}

.btn_blue_arrow:hover {
  background: #1f67c7;
  border-color: #1f67c7;
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(31, 103, 199, 0.25);
}

.btn_blue_arrow .btn_arrow {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.section-tint {
  background: var(--st-blue-100);
}

.platform-wrapper {
  position: relative;
  width: 100%;
  max-width: 1152px;
  height: 536px;
  margin: 50px auto 0;
}

.platform-ring-outline {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 784px;
  height: 415px;
  border: 3px dashed #bedbff;
  border-radius: 999px;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
}

.platform-center {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 224px;
  height: 224px;
  border-radius: 999px;
  border: 8px solid #ffffff;
  background: var(--st-blue-900);
  color: #ffffff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 24px;
  box-shadow: 0 25px 25px rgba(0, 0, 0, 0.25);
}

.platform-center-icon {
  width: 32px;
  height: 32px;
}

.platform-center span {
  max-width: 158px;
  font-size: 16px;
  line-height: 24px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  text-align: center;
  font-weight: 600;
}

.platform-card {
  position: absolute;
  width: 380px;
  min-height: 120px;
  border: 1px solid var(--st-blue-700);
  border-radius: 16px;
  background: #ffffff;
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow:
    0 1px 1.5px rgba(0, 0, 0, 0.1),
    0 1px 1px rgba(0, 0, 0, 0.1);
}

.platform-card span {
  color: var(--st-blue-900);
  font-size: 20px;
  line-height: 28px;
  font-weight: 700;
}

.platform-icon {
  width: 80px;
  height: 80px;
  border-radius: 999px;
  flex: 0 0 80px;
}

.platform-card p {
  margin: 0;
  color: var(--st-blue-900);
  font-size: 14px;
  line-height: 20px;
  font-weight: 600;
  flex: 1;
  min-width: 0;
  word-break: break-word;
}

.pc-1 {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.pc-2 {
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

.pc-3 {
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
}

.pc-4 {
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
}

.split-panel {
  background: #f9fafb;
  border: 1px solid var(--st-border);
  border-radius: 24px;
  overflow: hidden;
}

.split-content {
  background: #f9fafb;
  border-left: 1px solid #f3f4f6;
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: 50px;
}

.split-content .section-title {
  max-width: 469px;
}
.image_text_block_area .section-title {
  font-size: 24px;
  line-height: 32px;
}
.need-card-pairs-area,
.need-tint-content-area,
.abt-scientific-foundations-area {
  gap: 40px;
}
.feature-list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
}

.feature-list li {
  position: relative;
  font-size: 18px;
  line-height: 24px;
  font-weight: 400;
  color: #1f2124;
  padding: 0 0 0 24px;
}

.feature-list li::before {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #ff6467;
  margin-top: 8px;
  margin-left: -16px;
}
.image_text_block_area {
  padding: 50px;
  gap: 28px;
}
.note {
  margin: 0;
  font-size: 14px;
  line-height: 20px;
  color: #6b7280;
  font-style: italic;
  font-weight: 400;
}

.smarttrack-details .detail-header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 50px;
}

.smarttrack-details .section-title {
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
}

.detail-intro {
  margin: 0;
  color: #1f2124;
  font-size: 20px;
  line-height: 28px;
  font-weight: 400;
}

.detail-grid {
  --bs-gutter-x: 24px;
  --bs-gutter-y: 24px;
}

.detail-card {
  border: 1px solid #f3f4f6;
  border-radius: 16px;
  box-shadow:
    0 1px 1.5px rgba(0, 0, 0, 0.1),
    0 1px 1px rgba(0, 0, 0, 0.1);
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 40px;
}

.detail-card-top {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
  width: 100%;
}

.detail-icon {
  width: 40px;
  height: 40px;
  object-fit: contain;
}

.detail-card h3 {
  color: var(--st-blue-900);
  font-size: 20px;
  line-height: 28px;
  margin: 0;
  font-weight: 700;
}

.detail-card a {
  color: var(--st-blue-700);
  font-size: 14px;
  line-height: 20px;
  font-weight: 700;
  text-decoration: none;
}

.link-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 16px;
}

.case-row {
  --bs-gutter-x: 100px;
  --bs-gutter-y: 24px;
}

.case-copy {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 40px;
}

.case-text {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 28px;
  font-weight: 400;
  max-width: 590px;
}

.case-btn {
  padding: 10px 24px;
}

.link-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: 8px;
  background: #f5f7fa;
  color: var(--st-blue-900);
  padding: 16px 24px;
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
  text-decoration: none;
  gap: 24px;
}

.link-list a span:first-child {
  flex: 1;
}

.list-arrow {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 32px;
}

.promo-wrap {
  border-radius: 20px;
  overflow: hidden;
}

.promo-image-wrap {
  height: 500px;
}

.promo-image {
  height: 100% !important;
  object-fit: cover;
}

.promo-copy {
  background-color: var(--st-blue-900);
  background-image: url(../images/Drug_Development_bg_img.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  padding: 50px 0;
}

.promo-row {
  --bs-gutter-x: 50px;
  --bs-gutter-y: 24px;
  width: 100%;
  max-width: 1160px;
  margin: 0 auto;
}

.promo-copy-left {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.promo-title {
  margin: 0;
  color: #ffffff;
  font-size: 20px;
  line-height: 28px;
  font-weight: 700;
}

.promo-text {
  margin: 0;
  color: #ffffff;
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
}

.promo-quote {
  background: #ffffff;
  color: var(--st-blue-900);
  border-left: 4px solid var(--st-blue-700);
  border-radius: 16px;
  padding: 24px 24px 24px 28px;
  font-size: 18px;
  line-height: 24.75px;
  font-weight: 400;
}

.cta {
  background: linear-gradient(135deg, #4b78c5 0%, #136bdd 100%);
}

.cta-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  padding-left: 10px;
  padding-right: 10px;
}

.cta-title {
  max-width: 1260px;
  width: 100%;
  margin: 0;
  color: #ffffff;
  font-size: 32px;
  line-height: 40px;
  font-weight: 600;
}

.cta-btn {
  min-height: 44px;
  padding: 10px 24px;
  border: 1px solid #e5e7eb;
  background: #ffffff;
  color: #1f2937;
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
}

.cta-btn:hover {
  background: #f8fafc;
  color: #1f2937;
  border-color: #e5e7eb;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.12);
}

.btn-light:hover {
  background: #f8fafc;
  border-color: #dbe3ef;
  color: #1f2937;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.12);
}

.subbar .btn-primary:hover {
  background: #1f67c7;
  border-color: #1f67c7;
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(31, 103, 199, 0.25);
}

.footer-section {
  background: var(--st-blue-900);
  color: #cccccc;
}

.footer-main {
  padding: 100px 0 52px;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.footer-top {
  display: grid;
  grid-template-columns: 410px 210px 210px 210px;
  gap: 40px;
}

.footer-brand {
  width: 410px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.footer-group {
  width: 210px;
}

.footer-logo {
  width: 300px;
}

.footer-title {
  color: #ffffff;
  font-family: 'Georgia', sans-serif;
  font-size: 18px;
  line-height: 28px;
  margin: 0;
  font-weight: 700;
}

.footer-section p,
.footer-section a {
  color: #cccccc;
  text-decoration: none;
  font-size: 18px;
  line-height: 24px;
  font-weight: 400;
}

.footer-links {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
  margin-top: 16px;
}

.footer-contact {
  display: grid;
  gap: 12px;
  margin-top: 16px;
}

.footer-contact p {
  margin: 0;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  padding-top: 33px;
  min-height: 49px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.footer-bottom p {
  margin: 0;
  color: #ffffff;
}

.footer-policy-links {
  display: flex;
  align-items: center;
  gap: 16px;
}

.footer-policy-links a {
  color: #ffffff;
}

/* =========================
   Shared - Subbar Active Link State
   ========================= */
.the-need-page .sub-link.active,
.about-smarttrack-page .sub-link.active,
.how-it-works-page .sub-link.active,
.fdi-fluidda-page .sub-link.active,
.regulatory-strategy-page .sub-link.active,
.case-studies-page .sub-link.active {
  border-bottom: 3px solid #ffffff;
  font-weight: 600;
}

/* =========================
   The Need - Hero Section
   ========================= */
.need-hero {
  min-height: 520px;
  display: flex;
  align-items: flex-start;
  background-image:
    linear-gradient(90deg, #013577 0%, rgba(1, 53, 119, 0.8) 100%),
    url(../images/common_hero_bg_img.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 140px 0 0;
}

.need-hero-copy {
  max-width: 700px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.need-pill {
  width: max-content;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  padding: 8px 20px;
  color: #ffffff;
  font-size: 14px;
  line-height: 20px;
  font-weight: 500;
}

.need-hero h1 {
  margin: 0;
  color: #ffffff;
  font-size: 44px;
  line-height: 60px;
  font-weight: 700;
}

.need-hero p {
  margin: 0;
  color: #d1d5dc;
  font-size: 18px;
  line-height: 24px;
}

/* =========================
   The Need - Challenge Intro
   ========================= */
.need-section {
  padding: 80px 0;
}

.need-stack {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.need-stack-sec,
.Feature_listimage_text_block_sec,
.ast-blue-panel-sec,
.fdi-highlights-sec {
  position: relative;
  width: 100%;
  z-index: 0;
}
.need-stack-sec::after,
.Feature_listimage_text_block_sec::after,
.ast-blue-panel-sec::after,
.fdi-highlights-sec::after {
  content: "";
  background-image: url(../images/dots-shap-2.png);
  background-size: cover;
  background-repeat: no-repeat;
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  z-index: -1;
}
.need-stack h2,
.text-content-block-sec-title h2 {
  margin: 0;
  color: #013577;
  font-size: 44px;
  line-height: 60px;
  font-weight: 700;
}
.text-content-block-sec-title h2 {
  font-size: 36px;
  line-height: 44px;
}
.need-stack p,
.need-two-col-row p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
  font-weight: 400;
}

.need-lead {
  font-size: 20px !important;
  line-height: 28px !important;
  color: #000000 !important;
}

.need-main-image {
  width: 100%;
  /*border-radius: 20px;*/
  /*height: 500px;*/
  border-radius: 20px !important;
  height: 500px !important;
  object-fit: cover;
}

/* =========================
   The Need - Text Content Blocks
   ========================= */
.need-two-col-row {
  --bs-gutter-x: 100px;
  --bs-gutter-y: 24px;
}

/* =========================
   The Need - Highlight Cards (Tint)
   ========================= */
.need-tint-section {
  background: #eef6fd;
  padding: 80px 0;
}

.need-media-card,
.need-split-card {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  overflow: hidden;
  background: #ffffff;
}

.need-media-card .row,
.need-split-card .row {
  width: 100%;
}

.need-media-card img,
.need-split-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 420px;
}

.need-card-content {
  padding: 50px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: 100%;
}

.need-card-content h3 {
  margin: 0;
  color: #013577;
  font-size: 24px;
  line-height: 36px;
  font-weight: 700;
}
.need-card-content-inner-title,
.fdi-collab-inner-info {
  gap: 12px;
}
.need-card-content p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.need-highlight {
  background: rgba(1, 53, 119, 0.07);
  border-left: 3px solid #013577;
  padding: 12px 16px;
}

/* =========================
   The Need - Blue Evidence Panel
   ========================= */
.need-blue-panel-wrap {
  position: relative;
  background-color: #013577;
  color: #ffffff;
  overflow: hidden;
  padding: 0 0 50px;
}

.need-blue-panel-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(../images/abt_blue_panel_bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.1;
  pointer-events: none;
  z-index: 0;
}

.need-blue-panel {
  position: relative;
  padding: 100px 0;
  z-index: 1;
}

.need-blue-row {
  --bs-gutter-x: 50px;
  --bs-gutter-y: 24px;
}

.need-blue-panel h3 {
  margin: 0;
  color: #ffffff;
  font-size: 36px;
  line-height: 44px;
  font-weight: 700;
  max-width: 100%;
}

.need-blue-panel .need-dot-list {
  gap: 40px;
}

.need-dot-list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.need-dot-list li {
  position: relative;
  margin: 0;
  padding-left: 20px;
  color: #ffffff;
  font-size: 18px;
  line-height: 24px;
}

.need-dot-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #ff6467;
}

.need-card-content.alt {
  background: #f9fafb;
  border-left: 1px solid #f3f4f6;
  gap: 28px;
}

.need-dot-list.dark li {
  color: #1f2124;
}

/* =========================
   The Need - Split Detail Cards
   ========================= */
.need-card-pairs {
  padding-top: 80px;
}

/* =========================
   The Need - Final Summary Panel
   ========================= */
.need-final-panel-wrap {
  padding: 0 0 80px;
}

.need-final-panel {
  position: relative;
  background-color: #013577;
  border-radius: 24px;
  overflow: hidden;
  padding: 70px 60px;
  min-height: 402px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

.need-final-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(../images/final_blue_panel_bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.1;
  pointer-events: none;
  z-index: 0;
}

.need-final-row {
  --bs-gutter-x: 100px;
  --bs-gutter-y: 24px;
}

.need-final-panel p {
  margin: 0;
  color: #ffffff;
  font-size: 16px;
  line-height: 24px;
}

.need-final-panel h2 {
  color: #ffffff;
  font-size: 20px;
  line-height: 28px;
  font-weight: 700;
  max-width: 530px;
}

.need-final-copy {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
/* =========================
   About SmartTrack Page
   ========================= */
.ast-section {
  padding: 80px 0;
}

.ast-hero {
  background-image:
    linear-gradient(90deg, #013577 0%, rgba(1, 53, 119, 0.8) 100%),
    url(../images/common_hero_bg_img.jpg);
}

.ast-intro-section {
  background: #eef6fd;
}

.ast-copy-block {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 50px;
}

.ast-copy-block h2,
.ast-final-section h2 {
  margin: 0;
  color: #013577;
  font-size: 44px;
  line-height: 60px;
  font-weight: 700;
}

.ast-copy-block p,
.ast-subheading,
.ast-final-copy p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.ast-overview-card {
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  background: #ffffff;
  padding: 30px 20px 24px;
}

.ast-overview-card h3 {
  margin: 0 0 24px;
  color: #013577;
  font-size: 24px;
  line-height: 32px;
  font-weight: 700;
  text-align: center;
}

.ast-overview-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.ast-overview-item img {
  width: 160px;
  height: 160px;
}

.ast-overview-item p {
  margin: 0;
  color: #013577;
  font-size: 18px;
  line-height: 24px;
  font-weight: 700;
  text-align: center;
  text-transform: capitalize;
}

.ast-overview-row {
  position: relative;
  --bs-gutter-x: 0;
}

.ast-overview-row::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 95px;
  height: 8px;
  width: 90%;
  margin: 0 auto;
  border-radius: 500px;
  background: linear-gradient(
    90deg,
    rgba(75, 120, 197, 0) 0%,
    rgba(5, 97, 255, 0.8) 50%,
    rgba(75, 120, 197, 0) 100%
  );
}
section.abt-Benefits-section {
    z-index: 0;
}
.ast-overview-row > [class*="col-"],
.ast-split-panel {
  position: relative;
  z-index: 1;
}

.ast-split-panel {
  border-radius: 24px;
}

.ast-panel-image {
  min-height: 420px;
  object-fit: cover;
}

.ast-subheading {
  color: #013577;
  font-size: 28px;
  line-height: 36px;
  font-weight: 700;
  margin-bottom: 50px;
}

.ast-benefit-card {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #ffffff;
  padding: 32px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.ast-benefit-icon {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  background: #fff2e5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.ast-benefit-icon img {
  width: 32px;
  height: 32px;
}

.ast-benefit-card h3 {
  margin: 0;
  color: #013577;
  font-size: 28px;
  line-height: 36px;
  font-weight: 700;
}

.ast-benefit-card p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.ast-diagram-wrap {
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  background: #ffffff;
  overflow: hidden;
  margin-bottom: 20px;
}

.ast-diagram-wrap img {
  width: 100%;
}

.ast-copy-card {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #ffffff;
  padding: 32px;
  height: 100%;
}

.ast-copy-card p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}
.ast-copy-card p span {
  color: #013577;
}
.ast-blue-panel {
  margin-top: 40px;
  position: relative;
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 24px;
  overflow: hidden;
  padding: 50px 264px;
  background-color: #013577;
}

.ast-blue-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(../images/abt_blue_panel_bg.jpg);
  background-size: cover;
  background-position: center;
  opacity: 0.1;
  pointer-events: none;
}

.ast-blue-panel p {
  margin: 0;
  position: relative;
  z-index: 1;
  max-width: 1003px;
  color: #ffffff;
  font-size: 28px;
  line-height: 36px;
  font-weight: 700;
  text-align: center;
}

.ast-last-card-section {
  background: #f5f7fa;
}

.ast-final-section {
  background: #ffffff;
}

.ast-final-row {
  --bs-gutter-x: 100px;
  --bs-gutter-y: 24px;
}

.ast-final-copy {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
.Feature_listimage_text_block_sec::after,
.ast-blue-panel-sec::after {
  background-image: url(../images/dots-shap-4.png);
  background-size: auto;
  background-position: bottom;
}

.abt-Benefits-shap {
  position: absolute;
  margin-top: -23%;
  top: 0;
  left: 0;
  width: 100%;
  z-index: -1;
}
.ast-overview-area {
  gap: 80px;
}
.abt-scientific-foundations-title {
  gap: 28px;
}
.ast-benefit-card-info {
  gap: 8px;
}
.ast-last-card-section .split-panel {
  background: #fff;
}

/* =========================
   How it Works Page
   ========================= */
.hiw-section {
  padding: 80px 0;
}

.hiw-hero {
  background-image:
    linear-gradient(90deg, #013577 0%, rgba(1, 53, 119, 0.8) 100%),
    url(../images/common_hero_bg_img.jpg);
}

.hiw-intro-section {
  background: #eef6fd;
}

.hiw-intro-row {
  --bs-gutter-x: 100px;
  --bs-gutter-y: 24px;
}

.hiw-intro-section h2 {
  margin: 0;
  color: #013577;
  font-size: 44px;
  line-height: 60px;
  font-weight: 700;
}

.hiw-intro-copy {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.hiw-intro-copy p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.hiw-intro-copy .hiw-intro-lead {
  color: #000000;
  font-size: 20px;
  line-height: 28px;
}

.hiw-benefit-card {
  background: #ffffff;
  border: 1px solid rgba(1, 53, 119, 0.1);
  border-radius: 12px;
  padding: 17px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.hiw-benefit-card img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.hiw-benefit-card p {
  margin: 0;
  font-size: 14px;
  line-height: 20px;
  font-weight: 500;
}

.hiw-timeline-section {
  background: #ffffff;
}

.hiw-timeline-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.hiw-timeline-wrap::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  transform: translateX(-50%);
  background: linear-gradient(
    180deg,
    rgba(75, 120, 197, 0) 0%,
    rgba(5, 97, 255, 0.8) 50%,
    rgba(75, 120, 197, 0) 100%
  );
  border-radius: 500px;
}

.hiw-step-row {
  position: relative;
  --bs-gutter-x: 20px;
  --bs-gutter-y: 0;
  margin-bottom: 20px;
}

.hiw-step-dot {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 64px;
  height: 64px;
  border-radius: 50%;
  border: 4px solid #ffffff;
  background: #136bdd;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 28px;
  font-weight: 700;
  z-index: 2;
  box-shadow:
    0 1px 1.5px rgba(0, 0, 0, 0.1),
    0 1px 1px rgba(0, 0, 0, 0.1);
}

.hiw-step-card {
  background: #f5f7fa;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.hiw-step-card-info {
  gap: 8px;
}

.hiw-step-icon {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  background: #fff2e5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.hiw-step-icon img {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.hiw-step-card h3 {
  margin: 0;
  color: #013577;
  font-size: 28px;
  line-height: 36px;
  font-weight: 700;
}

.hiw-step-card p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.hiw-step-btn {
  width: max-content;
  min-height: 44px;
  padding: 10px 24px;
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
}

.hiw-advantage-panel {
  position: relative;
  background-color: #013577;
  border-radius: 24px;
  overflow: hidden;
  padding: 50px 80px;
  text-align: center;
}

.hiw-advantage-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(../images/abt_blue_panel_bg.jpg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.1;
  pointer-events: none;
}

.hiw-advantage-panel h2,
.hiw-advantage-panel p {
  position: relative;
  z-index: 1;
  margin: 0;
}

.hiw-advantage-panel h2 {
  color: #ffffff;
  font-size: 28px;
  line-height: 36px;
  font-weight: 700;
}

.hiw-advantage-panel p {
  color: #d1d5dc;
  font-size: 16px;
  line-height: 24px;
}

.hiw-advantage-panel-inner {
  max-width: 860px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin: 0 auto;
}

.hiw-step-card-list,
.fdi-highlight-list-box {
  list-style: disc;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 18px;
  line-height: 24px;
  color: #1f2124;
}
.hiw-step-row > div {
  width: -webkit-fill-available;
  margin-right: 55%;
}
.hiw-step-row > .offset-lg-7 {
  margin-left: 55%;
  margin-right: auto;
  width: -webkit-fill-available;
}

/* =========================
   FDI Fluidda - Page
   ========================= */

.fdi-section-title {
  margin: 0 0 50px;
  color: #013577;
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
}

/* =========================
   FDI Fluidda - Hero
   ========================= */
.fdi-hero {
  background-image:
    linear-gradient(90deg, #013577 0%, rgba(1, 53, 119, 0.8) 100%),
    url(../images/common_hero_bg_img.jpg);
}

.fdi-hero .need-hero-copy {
  max-width: 730px;
}

.fdi-hero .need-hero-copy p {
  color: #d1d5dc;
}

/* =========================
   FDI Fluidda - Intro
   ========================= */
.fdi-intro {
  background: #eef6fd;
}

.fdi-two-col {
  --bs-gutter-x: 100px;
  --bs-gutter-y: 24px;
}

.fdi-two-col .col-lg-6:last-child {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* =========================
   FDI Fluidda - Cards
   ========================= */
.fdi-mini-card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  height: 100%;
}

.fdi-mini-card span {
  color: #999999;
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
}

.fdi-mini-card p {
  font-weight: 600;
}

.fdi-rda-panel {
  background: #013576;
  border-radius: 20px;
  padding: 50px;
  margin-top: 12px;
}

.fdi-rda-panel .row {
  --bs-gutter-x: 100px;
}

.fdi-rda-panel .col-lg-6:last-child {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.fdi-rda-panel .fdi-mini-card {
  height: auto;
}

.fdi-rda-panel h3 {
  margin: 0;
  color: #ffffff;
  font-size: 30px;
  line-height: 40px;
  font-weight: 700;
}

.fdi-statement {
  color: #013577;
  font-size: 24px;
  line-height: 32px;
  font-weight: 600;
}

/* =========================
   FDI Fluidda - Composition
   ========================= */
.fdi-composition .row {
  position: relative;
}

.fdi-composition .row::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 288px;
  height: 2px;
  background: linear-gradient(
    90deg,
    rgba(19, 107, 221, 0) 0%,
    rgba(19, 107, 221, 0.8) 50%,
    rgba(19, 107, 221, 0) 100%
  );
  z-index: 0;
}

.fdi-composition-row > [class*="col-"] {
  padding: 0;
}

.fdi-comp-card {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  min-height: 486px;
  padding: 0 28px;
  position: relative;
  z-index: 1;
}

.fdi-comp-card img {
  width: 100%;
  max-width: 347px;
  height: 250px;
  border-radius: 8px;
  object-fit: contain;
}

.fdi-comp-card span {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #136bdd;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 28px;
  font-weight: 700;
  box-shadow:
    0 4px 3px rgba(0, 0, 0, 0.1),
    0 2px 2px rgba(0, 0, 0, 0.1);
}

.fdi-comp-card h3 {
  margin: 0;
  color: #013577;
  font-size: 28px;
  line-height: 36px;
  font-weight: 700;
}

.fdi-comp-card p {
  max-width: 360px;
}

/* =========================
   FDI Fluidda - Figures and Lists
   ========================= */
.fdi-copy-block {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.fdi-main-figure {
  width: 100%;
  height: 750px;
  border-radius: 20px;
  object-fit: cover;
  margin-top: 28px;
}

.fdi-provide {
  position: relative;
  z-index: 0;
}

.fdi-provide .fdi-section-title {
  margin-bottom: 28px;
}

.fdi-provide .fdi-copy-block {
  gap: 0;
}

.fdi-provide .fdi-copy-block p {
  margin: 0;
}

.fdi-info-card {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.fdi-info-icon-wrap {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  background: #fff2e5;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fdi-info-icon-wrap img {
  width: 32px;
  height: 32px;
}

.fdi-highlight-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.fdi-highlight-item {
  background: #e6f1ff;
  border: 1px solid #cce2ff;
  border-radius: 24px;
  padding: 40px;
  display: flex;
  gap: 28px;
}

.fdi-highlight-icon {
  width: 58px;
  min-width: 58px;
  height: 58px;
  border-radius: 12px;
  border: 1px solid #dbeafe;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fdi-highlight-icon img {
  width: 32px;
  height: 32px;
}

.fdi-highlight-item h3 {
  margin: 0 0 8px;
  color: #013577;
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
}

.fdi-highlight-item p {
  margin: 0;
}

/* =========================
   FDI Fluidda - Collaboration
   ========================= */

.fdi-collab-card {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  overflow: hidden;
}

.fdi-collab-left,
.fdi-collab-right {
  padding: 40px;
  height: 100%;
}

.fdi-collab-left {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.fdi-collab-left h3 {
  margin: 0;
  color: #013577;
  font-size: 24px;
  line-height: 32px;
  font-weight: 700;
}

.fdi-fluidda-logo {
  width: 185px;
  height: 120px;
  object-fit: contain;
}

.fdi-collab-right {
  display: flex;
  flex-direction: column;
  gap: 40px;
  border-radius: 16px;
  background: #013577;
  box-shadow:
    0 20px 25px -5px rgba(0, 0, 0, 0.1),
    0 8px 10px -6px rgba(0, 0, 0, 0.1);
}

.fdi-collab-right p {
  color: #ffffff;
  font-size: 24px;
  line-height: 32px;
  font-weight: 700;
}

.fdi-chip-icon {
  width: 120px;
  height: 120px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
}

.fdi-chip-icon img {
  width: 70px;
  height: 70px;
}
.fdi-highlights-sec::after {
  margin-top: -60px;
}

/* =========================
   Regulatory Strategy Page
   ========================= */
.rs-section {
  padding: 100px 0;
}

.rs-hero {
  background-image:
    linear-gradient(90deg, #013577 0%, rgba(1, 53, 119, 0.8) 100%),
    url(../images/common_hero_bg_img.jpg);
}

.rs-hero-copy {
  max-width: 700px;
}

.rs-intro-section,
.rs-validation-section {
  background: #eef6fd;
}

.rs-two-col {
  --bs-gutter-x: 100px;
  --bs-gutter-y: 24px;
}

.rs-copy-block {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rs-copy-block h2,
.rs-events-title {
  margin: 0;
  color: #013577;
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
}

.rs-copy-block p,
.rs-woe-note,
.rs-event-card h3,
.rs-event-card h3 a {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
  font-weight: 400;
}

.rs-woe-section .rs-woe-sec-area-inner {
  display: flex;
  flex-direction: column;
  gap: 50px;
}

.rs-validation-card {
  border: 1px solid #f3f4f6;
  border-radius: 20px;
  overflow: hidden;
}

.rs-validation-top {
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: 40px;
  background: #ffffff;
}
.rs-woe-title-box {
  gap: 28px;
}
.rs-chip-row {
  display: flex;
  gap: 12px;
}

.rs-chip {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #f3f5f8;
  color: #013577;
  font-size: 16px;
  line-height: 24px;
  font-weight: 700;
  padding: 20px;
}

.rs-validation-panels {
  --bs-gutter-x: 20px;
  /* padding: 0 20px 20px; */
}

.rs-validation-panel {
  border-radius: 20px;
  background: #f5f7fa;
  height: 100%;
  padding: 40px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rs-validation-panel h3,
.rs-engagement-card h3 {
  margin: 0;
  color: #013577;
  font-size: 24px;
  line-height: 32px;
  font-weight: 700;
}

.rs-validation-panel p,
.rs-engagement-card p,
.rs-event-card p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.rs-validation-panel--dark {
  background: #013577;
  box-shadow:
    0 20px 25px -5px rgba(0, 0, 0, 0.1),
    0 8px 10px -6px rgba(0, 0, 0, 0.1);
}

.rs-validation-panel--dark h3 {
  color: #ffffff;
}

.rs-validation-panel--dark p {
  color: #d1d5dc;
}

.rs-engagement-sec {
  background: #013577;
  position: relative;
}

.rs-engagement-sec::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(../images/dots-shap-5.png);
  background-size: cover;
  background-position: bottom;
  pointer-events: none;
}

.rs-engagement-section .rs-engagement-area {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.rs-brand-row {
  display: flex;
  align-items: center;
  gap: 28px;
}

.rs-brand-logo--aptar {
  width: 106px;
}

.rs-brand-logo--nanopharm {
  width: 219px;
}

.rs-brand-separator {
  width: 2px;
  height: 28px;
  background: #fff;
}

.rs-engagement-copy h2,
.rs-engagement-copy p {
  color: #ffffff;
}
.rs-engagement-area-upper {
  display: flex;
  flex-direction: column;
  gap: 28px;
  padding: 20px 0;
}
.rs-engagement-card {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #ffffff;
  height: 100%;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.rs-engagement-card h3 {
  font-size: 28px;
  line-height: 36px;
}

.rs-events-section .rs-events-area {
  display: flex;
  flex-direction: column;
  gap: 50px;
}

.rs-event-card {
  border-right: 1px solid #f3f4f6;
  background: #f9fafb;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rs-event-card h3,
.rs-event-card h3 a {
  color: #013577;
  font-weight: 600;
}

.rs-event-card p {
  opacity: 0.5;
  font-style: italic;
}

/* =========================
   Case Studies Page
   ========================= */

.cs-intro-inner {
  display: flex;
  flex-direction: column;
  gap: 50px;
}

.cs-intro-row {
  --bs-gutter-x: 100px;
  --bs-gutter-y: 24px;
}

.cs-intro-heading {
  margin: 0;
  color: #013577;
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
}

.cs-intro-copy {
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.cs-intro-copy p {
  margin: 0 0 18px;
}

.cs-intro-copy p:last-child {
  margin-bottom: 0;
}

.cs-cards-row {
  --bs-gutter-x: 20px;
  --bs-gutter-y: 20px;
}

.cs-app-card {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #f3f5f8;
  padding: 32px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 24px;
  min-height: 368px;
}

.cs-app-card--tall {
  min-height: 440px;
}

.cs-app-card-icon {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.cs-app-card-icon img {
  width: 32px;
  height: 32px;
  display: block;
}

.cs-app-card-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cs-app-card-body h3 {
  margin: 0;
  color: #013577;
  font-size: 28px;
  line-height: 36px;
  font-weight: 700;
}

.cs-app-card-body p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.cs-studies-section {
  background: #eef6fd;
}

.cs-studies-layout-gap {
  gap: 50px;
}

.cs-studies-intro {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cs-block-title {
  margin: 0;
  color: #013577;
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
}

.cs-studies-lead {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.cs-studies-stack {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.cs-case-card {
  border-radius: 20px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.cs-case-media-wrap {
  width: 100%;
}

.cs-case-media {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 260px;
  background: #ffffff;
}

.cs-case-media img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
  display: block;
}

.cs-case-body {
  border-left: 1px solid rgba(0, 0, 0, 0.05);
  padding: 40px 40px 40px 41px;
  display: flex;
  flex-direction: column;
  gap: 50px;
  justify-content: center;
  height: 100%;
  background: #ffffff;
}

.cs-case-text {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.cs-case-text h3 {
  margin: 0;
  color: #013577;
  font-size: 20px;
  line-height: 28px;
  font-weight: 700;
}

.cs-case-text p {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.cs-case-summary-btn {
  align-self: flex-start;
  border-color: #e5e7eb !important;
}

.cs-pubs-layout-gap {
  gap: 50px;
}

.cs-pubs-intro {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cs-pubs-lead {
  margin: 0;
  color: #1f2124;
  font-size: 18px;
  line-height: 24px;
}

.cs-pubs-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.cs-pub-item {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px 16px;
  border-radius: 8px;
  background: #f5f7fa;
  text-decoration: none;
  color: inherit;
  transition:
    background-color 0.15s ease,
    box-shadow 0.15s ease;
}

.cs-pub-item:hover {
  background: #eef2f7;
}

.cs-pub-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #136bdd;
  flex-shrink: 0;
}

.cs-pub-label {
  flex: 1 1 auto;
  margin: 0;
  color: #013577;
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
}

.cs-pub-icon {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.cs-pub-icon img {
  width: 32px;
  height: 32px;
  display: block;
}

@media (min-width: 992px) {
  .cs-case-media-wrap {
    width: 400px;
    flex: 0 0 400px;
  }

  .cs-case-media {
    min-height: 100%;
  }

  .cs-case-media img {
    min-height: 280px;
  }
}

/* =========================
   Responsive: <= 1399px (All Pages)
   ========================= */
@media (max-width: 1399px) {
  .container {
    padding: 0 24px;
  }
  .platform-wrapper {
    max-width: 1000px;
  }

  .platform-card {
    width: 315px;
  }

  .need-hero h1,
  .need-stack h2,
  .text-content-block-sec-title h2 {
    font-size: 40px;
    line-height: 52px;
  }

  .text-content-block-sec-title h2 {
    font-size: 32px;
    line-height: 40px;
  }

  .need-blue-panel {
    padding: 72px 0;
  }

  .ast-copy-block h2,
  .ast-final-section h2 {
    font-size: 40px;
    line-height: 52px;
  }

  .ast-blue-panel {
    padding: 50px 140px;
  }

  /* How it Works Page */
  .hiw-intro-section h2 {
    font-size: 40px;
    line-height: 52px;
  }

  .hiw-step-card h3 {
    font-size: 24px;
    line-height: 32px;
  }

  /* FDI Fluidda Page */
  .fdi-section {
    padding: 80px 0;
  }

  .fdi-rda-panel h3,
  .fdi-highlight-item h3 {
    font-size: 26px;
    line-height: 34px;
  }

  /* Regulatory Strategy Page */
  .rs-section {
    padding: 80px 0;
  }

  .rs-hero h1 {
    font-size: 40px;
    line-height: 52px;
  }

  .rs-copy-block h2,
  .rs-events-title,
  .cs-intro-heading,
  .cs-block-title {
    font-size: 28px;
    line-height: 36px;
  }

  /* Case Studies Page */
  .cs-section {
    padding: 80px 0;
  }

  .cs-app-card-body h3 {
    font-size: 26px;
    line-height: 34px;
  }
}

/* =========================
   Responsive: <= 1199px (All Pages)
   ========================= */
@media (max-width: 1199px) {
  .navbar .nav-link {
    padding: 0 0 12px !important;
    width: max-content;
  }

 .hero {
    min-height: auto;
    padding-top: 120px !important;
  }
  
  .section-space {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .hero-ring {
    width: 445px;
    height: 420px;
  }

  .quote-panel-area {
    gap: 50px;
  }

  .platform-wrapper {
    height: 500px;
    margin-top: 40px;
  }

  .platform-ring-outline {
    width: 700px;
    height: 375px;
  }

  .platform-card {
    width: 300px;
    min-height: 112px;
    padding: 18px;
  }

  .platform-center {
    width: 210px;
    height: 210px;
    padding: 22px;
  }

  .promo-image-wrap {
    height: 420px;
  }

  .promo-copy {
    padding: 40px 24px;
  }

  .promo-row {
    --bs-gutter-x: 24px;
    max-width: 100%;
  }

  .navbar-collapse {
    padding: 12px;
    border-radius: 12px;
  }

  .topbar .navbar-collapse {
    background: #ffffff;
  }

  .subbar .navbar-collapse {
    background: rgba(255, 255, 255, 0.08);
    margin: 12px 0;
  }

  .subbar .navbar-nav .nav-link {
    color: #ffffff;
  }
  .footer-top {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
  }

  .need-two-col-row {
    --bs-gutter-x: 40px;
  }

  .need-card-content {
    padding: 32px;
  }

  .need-blue-row {
    --bs-gutter-x: 24px;
    --bs-gutter-y: 28px;
  }

  .need-final-panel {
    padding: 32px 24px;
  }

  .ast-section {
    padding: 64px 0;
  }

  .ast-overview-item img {
    width: 132px;
    height: 132px;
  }

  .ast-benefit-card h3 {
    font-size: 24px;
    line-height: 32px;
  }

  .ast-blue-panel {
    padding: 50px 64px;
  }

  .ast-overview-row::before {
    top: 90px;
  }

  /* How it Works Page */
  .hiw-section {
    padding: 64px 0;
  }

  .hiw-intro-row {
    --bs-gutter-x: 40px;
  }

  .hiw-step-card {
    padding: 24px;
  }

  /* FDI Fluidda Page */
  .fdi-two-col {
    --bs-gutter-x: 48px;
  }

  .fdi-comp-card {
    min-height: auto;
    padding: 0 16px;
  }

  .fdi-rda-panel {
    padding: 40px;
  }

  .fdi-rda-panel .row {
    --bs-gutter-x: 40px;
  }

  /* Regulatory Strategy Page */
  .rs-section {
    padding: 64px 0;
  }

  .rs-two-col {
    --bs-gutter-x: 48px;
  }

  .rs-validation-top {
    padding: 32px;
  }

  .rs-validation-panel {
    padding: 28px;
  }

  .rs-engagement-card {
    padding: 24px;
  }

  /* Case Studies Page */
  .cs-section {
    padding: 64px 0;
  }

  .cs-intro-row {
    --bs-gutter-x: 48px;
  }

  .cs-app-card,
  .cs-app-card--tall {
    min-height: 0;
  }

  .cs-case-body {
    padding: 32px;
    gap: 40px;
  }
}

/* =========================
   Responsive: <= 991px (All Pages)
   ========================= */
@media (max-width: 991px) {
  body {
    font-size: 16px;
    line-height: 24px;
  }

  .display-title {
    font-size: 40px;
    line-height: 48px;
  }

  .lead-copy {
    font-size: 18px;
    line-height: 26px;
  }

  .footer-bottom {
    flex-wrap: wrap;
    align-items: flex-start;
  }
  .hero-copy {
    gap: 20px;
    margin-bottom: 28px;
    max-width: 100%;
  }

  .hero-actions .btn {
    padding: 10px 20px;
    font-size: 16px;
    line-height: 24px;
  }

  .hero-ring {
    width: 520px;
    height: 520px;
  }
  .quote-panel {
    padding: 42px 24px;
  }

  .section-intro {
    font-size: 20px;
    line-height: 28px;
  }

  .split-content {
    gap: 20px;
    padding: 24px;
  }

  .collab-cards {
    --bs-gutter-x: 16px;
    --bs-gutter-y: 16px;
  }

  .partner-card {
    gap: 28px;
    padding: 24px;
  }

  .partner-card h3 {
    font-size: 20px;
    line-height: 28px;
  }

  /* .split-panel,
  .split-panel > [class*="col-"] {
    min-height: 0;
  } */

  .platform-ring-outline {
    display: none;
  }

  .platform-card {
    width: 100%;
    max-width: 560px;
    position: relative;
    z-index: 1;
    border-radius: 12px;
    margin: 0 auto;
  }

  .pc-1,
  .pc-2,
  .pc-3,
  .pc-4 {
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    transform: none;
  }

  .platform-center {
    position: relative;
    left: auto;
    top: auto;
    transform: none;
    margin-top: 16px;
    margin-bottom: 16px;
    z-index: 2;
  }

  .pc-1 {
    order: 1;
  }
  .pc-2 {
    order: 2;
  }
  .platform-center {
    order: 3;
  }
  .pc-3 {
    order: 4;
  }
  .pc-4 {
    order: 5;
  }

  .platform-wrapper {
    height: auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
    max-width: 100%;
    margin-top: 36px;
    padding-top: 8px;
    padding-bottom: 8px;
  }

  .platform-center {
    width: 204px;
    height: 204px;
    border-width: 6px;
    box-shadow: 0 16px 22px rgba(0, 0, 0, 0.2);
    margin: 8px auto;
    padding: 18px;
    gap: 6px;
    flex-shrink: 0;
  }

  .platform-center-icon {
    width: 24px;
    height: 24px;
  }

  .platform-center span {
    max-width: 128px;
    font-size: 12px;
    line-height: 16px;
    letter-spacing: 0.4px;
  }

  .platform-card {
    padding: 14px;
    min-height: 96px;
    gap: 10px;
  }

  .platform-icon {
    width: 56px;
    height: 56px;
    flex: 0 0 56px;
  }

  .platform-card span {
    font-size: 18px;
    line-height: 24px;
  }

  .feature-list li,
  .link-list a,
  .footer-section p,
  .footer-section a {
    font-size: 16px;
    line-height: 24px;
  }

  .smarttrack-details .detail-header {
    margin-bottom: 32px;
  }

  .detail-intro {
    font-size: 18px;
    line-height: 26px;
  }

  .detail-grid {
    --bs-gutter-x: 16px;
    --bs-gutter-y: 16px;
  }

  .detail-card h3 {
    font-size: 18px;
    line-height: 24px;
  }

  .case-row {
    --bs-gutter-x: 24px;
  }

  .case-copy {
    margin-bottom: 28px;
  }

  .case-text {
    max-width: 100%;
    font-size: 16px;
    line-height: 24px;
  }

  .promo-image-wrap {
    height: 360px;
  }

  .promo-copy {
    padding: 8px 20px 32px;
  }

  .promo-row {
    width: 100%;
    --bs-gutter-x: 24px;
  }

  .promo-quote {
    font-size: 16px;
    line-height: 24px;
  }

  .cta-title {
    font-size: 28px;
    line-height: 36px;
  }

  .footer-main {
    padding-top: 80px;
    padding-bottom: 80px;
    gap: 32px;
  }

  .footer-brand {
    width: 100%;
    max-width: none;
  }

  .footer-group {
    width: 100%;
    max-width: none;
  }

  .footer-logo {
    width: 260px;
  }

  .need-hero {
    min-height: 455px;
  }

  .need-hero h1,
  .need-stack h2,
  .text-content-block-sec-title h2 {
    font-size: 32px;
    line-height: 42px;
  }

  .text-content-block-sec-title h2 {
    font-size: 28px;
    line-height: 36px;
  }

  .need-two-col-row,
  .need-final-row {
    --bs-gutter-x: 24px;
    --bs-gutter-y: 24px;
  }

  .need-media-card img,
  .need-split-card img {
    min-height: 300px;
  }

  .need-main-image {
    height: auto !important;
  }

  .need-blue-panel {
    padding: 48px 0;
  }

  .need-blue-panel h3 {
    font-size: 30px;
    line-height: 40px;
  }

  .need-blue-panel-wrap {
    padding: 0;
  }
  .section-space,
  .need-section,
  .need-tint-section,
  .ast-section,
  .hiw-section,
  .fdi-section {
    padding: 48px 0;
  }

  .need-final-panel-wrap {
    padding: 0 0 48px;
  }

  .need-final-panel > .row {
    gap: 24px;
  }

  .need-split-card-rgt-img .split-panel {
    flex-direction: column-reverse;
  }

  .ast-copy-block h2,
  .ast-final-section h2 {
    font-size: 32px;
    line-height: 42px;
  }

  .ast-subheading {
    font-size: 24px;
    line-height: 32px;
  }

  .ast-panel-image {
    min-height: 300px;
  }

  .ast-benefit-card,
  .ast-copy-card {
    padding: 24px;
  }

  .ast-overview-area {
    gap: 40px;
  }

  .ast-blue-panel p {
    font-size: 24px;
    line-height: 34px;
  }

  .ast-final-row {
    --bs-gutter-x: 24px;
  }

  .ast-overview-row {
    --bs-gutter-x: 1.5rem;
  }
  .ast-overview-item {
    flex-direction: row;
  }
  .ast-overview-item p {
    text-align: left;
  }
  .ast-overview-row::before {
    width: 8px;
    height: 90%;
    top: 50px;
    margin: 0 auto;
    margin-left: 75px;
  }

  /* How it Works Page */
  .hiw-intro-section h2 {
    font-size: 32px;
    line-height: 42px;
  }

  .hiw-step-card p,
  .hiw-intro-copy p {
    font-size: 16px;
    line-height: 24px;
  }

  .hiw-intro-copy .hiw-intro-lead {
    font-size: 18px;
    line-height: 26px;
  }

  .hiw-step-card h3 {
    font-size: 24px;
    line-height: 32px;
  }

  .hiw-timeline-wrap::before {
    left: 32px;
    transform: none;
  }

  .hiw-step-row {
    margin-left: 0;
    padding-left: 44px;
  }

  .hiw-step-dot {
    left: 32px;
    top: 32px;
    transform: translate(-50%, 0);
    width: 54px;
    height: 54px;
    font-size: 18px;
    line-height: 24px;
  }

  .hiw-step-row > [class*="col-"] {
    width: 100%;
    margin: auto;
  }

  .hiw-step-card {
    width: 95%;
    margin-left: auto;
  }

  /* FDI Fluidda Page */

  .fdi-section-title {
    margin-bottom: 28px;
  }

  .fdi-intro .fdi-section-title {
    margin: 0;
  }

  .fdi-main-figure {
    height: auto;
  }

  .fdi-highlight-item {
    flex-direction: column;
    gap: 16px;
    padding: 28px;
  }

  .fdi-composition-row > [class*="col-"] {
    padding: 0 0 24px;
  }

  .fdi-composition .row::after {
    display: none;
  }

  /* Regulatory Strategy Page */
  .rs-section {
    padding: 48px 0;
  }

  .rs-two-col {
    --bs-gutter-x: 24px;
  }

  .rs-hero h1 {
    font-size: 32px;
    line-height: 42px;
  }

  .rs-copy-block h2,
  .rs-events-title {
    font-size: 26px;
    line-height: 34px;
  }

  .rs-copy-block p,
  .rs-woe-note,
  .rs-validation-panel p,
  .rs-event-card h3,
  .rs-event-card p,
  .rs-engagement-card p {
    font-size: 16px;
    line-height: 24px;
  }

  .rs-validation-panel h3,
  .rs-engagement-card h3 {
    font-size: 22px;
    line-height: 30px;
  }

  .rs-event-card {
    min-height: auto;
  }
  .rs-events-section .rs-events-area {
    gap: 28px;
  }

  /* Case Studies Page */
  .cs-section {
    padding: 48px 0;
  }

  .cs-intro-row {
    --bs-gutter-x: 24px;
  }

  .cs-intro-inner {
    gap: 40px;
  }

  .cs-studies-layout-gap,
  .cs-pubs-layout-gap {
    gap: 40px;
  }

  .cs-intro-heading,
  .cs-block-title {
    font-size: 26px;
    line-height: 34px;
  }

  .cs-intro-copy,
  .cs-studies-lead,
  .cs-pubs-lead,
  .cs-app-card-body p,
  .cs-case-text p {
    font-size: 16px;
    line-height: 24px;
  }

  .cs-app-card-body h3 {
    font-size: 24px;
    line-height: 32px;
  }

  .cs-case-media-wrap {
    width: 100%;
    flex: 1 1 auto;
    max-width: none;
  }

  .cs-case-body {
    border-left: none;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    padding: 28px 24px;
    gap: 28px;
  }

  .cs-case-text h3 {
    font-size: 18px;
    line-height: 26px;
  }

  .cs-case-summary-btn {
    font-size: 16px;
    line-height: 24px;
    min-height: 44px;
  }

  .cs-pub-label {
    font-size: 16px;
    line-height: 24px;
  }
}

/* =========================
   Responsive: <= 767px (All Pages)
   ========================= */
@media (max-width: 767px) {
  .container {
    padding-left: 16px;
    padding-right: 16px;
  }

  .section-space {
    padding-top: 30px;
    padding-bottom: 30px;
  }

  .hero-ring {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
  }

  .floating-top {
    right: 8px;
    top: 10px;
  }

  .floating-bottom {
    left: 8px;
    bottom: 10px;
  }

  .platform-wrapper {
    margin-top: 30px;
    gap: 14px;
    padding-top: 0;
    padding-bottom: 0;
  }

  .platform-card {
    max-width: 100%;
  }

  .platform-center {
    width: 186px;
    height: 186px;
    margin: 10px auto;
    padding: 16px;
  }

  .cta-inner {
    gap: 24px;
  }

  .cta-title {
    font-size: 24px;
    line-height: 32px;
  }

  .footer-main {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .footer-top,
  .footer-brand,
  .footer-group {
    width: 100%;
  }

  .footer-top {
    grid-template-columns: 1fr;
  }

  .need-section,
  .need-tint-section,
  .need-card-pairs,
  .need-final-panel-wrap {
    padding-top: 40px;
    padding-bottom: 40px;
  }

  .need-hero {
    padding: 60px 0 40px;
    align-items: center;
  }

  .need-pill {
    font-size: 12px;
    line-height: 18px;
    padding: 6px 14px;
  }

  .need-hero h1,
  .need-stack h2,
  .text-content-block-sec-title h2 {
    font-size: 26px;
    line-height: 34px;
  }

  .text-content-block-sec-title h2 {
    font-size: 24px;
    line-height: 32px;
  }

  .need-blue-panel h3 {
    font-size: 24px;
    line-height: 36px;
  }

  .need-stack p,
  .need-two-col-row p,
  .need-card-content p,
  .need-dot-list li {
    font-size: 16px;
    line-height: 24px;
  }

  .need-blue-panel .need-dot-list {
    gap: 24px;
  }

  .ast-section {
    padding: 40px 0;
  }

  .ast-copy-block h2,
  .ast-final-section h2 {
    font-size: 26px;
    line-height: 34px;
  }

  .ast-copy-block p,
  .ast-final-copy p,
  .ast-benefit-card p,
  .ast-copy-card p {
    font-size: 16px;
    line-height: 24px;
  }

  .ast-subheading,
  .ast-copy-block {
    margin-bottom: 30px;
  }

  .ast-overview-card h3,
  .ast-benefit-card h3 {
    font-size: 22px;
    line-height: 30px;
  }

  .ast-blue-panel {
    min-height: 240px;
    padding: 36px 24px;
  }

  .ast-blue-panel p {
    font-size: 20px;
    line-height: 30px;
  }

  .ast-final-copy {
    gap: 24px;
  }

  /* How it Works Page */
  .hiw-section {
    padding: 30px 0;
  }

  .hiw-intro-section h2 {
    font-size: 26px;
    line-height: 34px;
  }

  .hiw-step-row {
    margin-left: 0;
    padding-left: 36px;
    margin-bottom: 16px;
  }

  .hiw-step-dot {
    left: 24px;
    width: 48px;
    height: 48px;
    border-width: 3px;
    font-size: 16px;
  }

  .hiw-timeline-wrap::before {
    left: 24px;
  }

  .hiw-step-card {
    padding: 20px;
    gap: 14px;
  }

  .hiw-step-icon {
    width: 54px;
    height: 54px;
  }

  .hiw-step-icon img {
    width: 28px;
    height: 28px;
  }

  .hiw-step-card h3 {
    font-size: 22px;
    line-height: 30px;
  }

  .hiw-step-btn {
    font-size: 16px;
    line-height: 24px;
  }

  .hiw-advantage-panel {
    padding: 36px 20px;
  }

  .hiw-advantage-panel h2 {
    font-size: 24px;
    line-height: 32px;
  }

  /* FDI Fluidda Page */
  .fdi-section {
    padding: 30px 0;
  }

  .fdi-section-title {
    font-size: 24px;
    line-height: 30px;
    margin-bottom: 24px;
  }
  .ast-subheading,
  .fdi-rda-panel h3,
  .fdi-highlight-item h3,
  .fdi-statement,
  .fdi-comp-card h3,
  .fdi-collab-right p {
    font-size: 20px;
    line-height: 30px;
  }

  .fdi-main-figure {
    height: 380px;
  }

  .fdi-provide .fdi-section-title {
    margin-bottom: 24px;
  }

  .fdi-collab-left,
  .fdi-collab-right {
    padding: 32px;
  }

  /* Regulatory Strategy Page */
  .rs-section {
    padding: 40px 0;
  }

  .rs-hero h1 {
    font-size: 26px;
    line-height: 34px;
  }

  .rs-copy-block h2,
  .rs-events-title {
    font-size: 24px;
    line-height: 30px;
  }

  .rs-validation-top {
    padding: 24px;
  }
  .rs-chip-row {
    flex-wrap: wrap;
  }
  .rs-chip {
    font-size: 14px;
    line-height: 20px;
    padding: 14px;
  }

  .rs-validation-panel,
  .rs-engagement-card,
  .rs-event-card {
    padding: 20px;
  }

  .rs-engagement-card h3 {
    font-size: 24px;
    line-height: 30px;
  }

  .rs-brand-row {
    gap: 16px;
  }

  .rs-brand-logo--nanopharm {
    width: 180px;
  }

  /* Case Studies Page */
  .cs-section {
    padding: 40px 0;
  }

  .cs-app-card {
    padding: 24px;
    gap: 20px;
  }

  .cs-studies-layout-gap,
  .cs-pubs-layout-gap {
    gap: 32px;
  }

  .cs-intro-heading,
  .cs-block-title {
    font-size: 24px;
    line-height: 30px;
  }

  .cs-case-body {
    padding: 24px 20px;
  }
}

/* =========================
   Responsive: <= 575px (All Pages)
   ========================= */
@media (max-width: 575px) {
  .hero-actions .btn {
    width: 100%;
  }
  .quote-panel-area,
  .SmartTrack_collaboration_area.row,
  .Digital_Evidence_info_area {
    gap: 30px;
  }
  .quote-panel p {
    font-size: 18px;
    line-height: 30px;
  }
  .section-title {
    font-size: 24px;
    line-height: 30px;
  }
  .image_text_block_area {
    padding: 24px;
    gap: 24px;
  }
  .promo-image {
    object-position: left;
  }
  .cta-title {
    font-size: 20px;
    line-height: 28px;
  }

  .need-section,
  .need-tint-section,
  .need-card-pairs,
  .need-final-panel-wrap,
  .ast-section,
  .rs-section,
  .cs-section {
    padding: 30px 0;
  }

  .need-lead {
    font-size: 18px !important;
  }
  .ast-overview-row::before {
    margin-left: 65px;
  }
  .ast-copy-block h2,
  .ast-final-section h2 {
    font-size: 24px;
    line-height: 30px;
  }
  .image_text_block_area .section-title {
    font-size: 20px;
    line-height: 28px;
  }
  .ast-blue-panel p {
    font-size: 18px;
  }
  .ast-overview-card {
    padding: 24px 16px 20px;
  }

  .ast-overview-item img {
    width: 110px;
    height: 110px;
  }

  .ast-overview-item p,
  .ast-overview-card h3 {
    font-size: 18px;
    line-height: 26px;
  }

  .ast-benefit-card h3 {
    font-size: 20px;
    line-height: 28px;
  }

  .ast-blue-panel {
    padding: 30px 16px;
  }

  .abt-Benefits-shap {
    margin-top: -65%;
  }
  .abt-Benefits-shap img {
    height: 700px;
  }

  /* How it Works Page */
  .hiw-intro-section h2 {
    font-size: 24px;
    line-height: 30px;
  }

  .hiw-benefit-card p {
    font-size: 13px;
    line-height: 18px;
  }

  .hiw-step-card h3 {
    font-size: 20px;
    line-height: 28px;
  }

  .hiw-step-row {
    margin-left: 0;
    padding-left: 28px;
  }

  .hiw-step-dot,
  .hiw-timeline-wrap::before {
    left: 20px;
  }

  /* FDI Fluidda Page */
  .fdi-mini-card,
  .fdi-rda-panel,
  .fdi-highlight-item,
  .fdi-collab-left,
  .fdi-collab-right {
    padding: 20px;
  }

  .fdi-main-figure {
    height: 280px;
  }

  /* Case Studies Page */

  .cs-app-card-body h3 {
    font-size: 20px;
    line-height: 28px;
  }

  .rs-brand-row {
    flex-wrap: wrap;
  }

  .rs-brand-separator {
    display: none;
  }

  .rs-brand-logo--nanopharm {
    width: 150px;
  }
}


/* ============================================================
   SmartTrack Elementor Compatibility Fixes
   Keeps original SmartTrack design while preventing Elementor,
   theme, and page wrapper conflicts.
   ============================================================ */

/* Remove Elementor extra spacing around section-wise SmartTrack widgets */
.elementor-widget[class*="nst_smarttrack_"],
.elementor-widget[class*="nst_smarttrack_"] > .elementor-widget-container,
.nst-smarttrack-exact-page,
.nst-smarttrack-section-widget {
  margin: 0 !important;
  padding: 0 !important;
}

.nst-smarttrack-exact-page {
  width: 100%;
  max-width: 100%;
  overflow-x: clip;
  background: #ffffff;
}

.nst-smarttrack-exact-page * {
  box-sizing: border-box;
}

/* Remove unwanted dotted / decorative pattern backgrounds only */
.nst-smarttrack-exact-page .need-stack-sec::after,
.nst-smarttrack-exact-page .Feature_listimage_text_block_sec::after,
.nst-smarttrack-exact-page .ast-blue-panel-sec::after,
.nst-smarttrack-exact-page .abt-Benefits-shap,
.nst-smarttrack-exact-page .section-shape,
.nst-smarttrack-exact-page .dots-shap,
.nst-smarttrack-exact-page .dots-shape {
  /*display: none !important;*/
  /*content: none !important;*/
  /*background-image: none !important;*/
}

.nst-smarttrack-exact-page .quote-panel {
  /*background-image: none !important;*/
}

/* Restore original button styles and protect them from Elementor/global theme CSS */
.nst-smarttrack-exact-page .btn {
  box-shadow: none;
  text-decoration: none !important;
  transition: all 0.25s ease-in-out !important;
}

.nst-smarttrack-exact-page .btn-accent {
  background: var(--st-accent) !important;
  border: 1px solid var(--st-accent) !important;
  color: #ffffff !important;
  min-height: 44px;
  padding: 10px 24px !important;
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
}

.nst-smarttrack-exact-page .btn-accent:hover,
.nst-smarttrack-exact-page .btn-accent:focus {
  background: #f58412 !important;
  border-color: #f58412 !important;
  color: #ffffff !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(245, 132, 18, 0.25) !important;
}

.nst-smarttrack-exact-page .hero-actions .btn-light,
.nst-smarttrack-exact-page .btn-light {
  background: #ffffff !important;
  color: #1f2937 !important;
  border: 1px solid #e5e7eb !important;
}

.nst-smarttrack-exact-page .hero-actions .btn-light:hover,
.nst-smarttrack-exact-page .btn-light:hover,
.nst-smarttrack-exact-page .btn-light:focus {
  background: #f8fafc !important;
  border-color: #dbe3ef !important;
  color: #1f2937 !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.12) !important;
}

.nst-smarttrack-exact-page .subbar .btn-primary,
.nst-smarttrack-exact-page .subbar a.btn-primary {
  background: var(--st-blue-600) !important;
  border-color: var(--st-blue-600) !important;
  color: #ffffff !important;
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
  min-height: 44px;
  padding: 10px 20px !important;
  border-radius: 999px !important;
}

.nst-smarttrack-exact-page .subbar .btn-primary:hover,
.nst-smarttrack-exact-page .subbar a.btn-primary:hover,
.nst-smarttrack-exact-page .subbar .btn-primary:focus,
.nst-smarttrack-exact-page .subbar a.btn-primary:focus {
  background: #1f67c7 !important;
  border-color: #1f67c7 !important;
  color: #ffffff !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(31, 103, 199, 0.25) !important;
}

.nst-smarttrack-exact-page .btn_blue_arrow {
  background: #2670d5 !important;
  border-color: #2670d5 !important;
  color: #ffffff !important;
  font-size: 18px;
  line-height: 24px;
  font-weight: 600;
  min-height: 48px;
  padding: 12px 20px !important;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: max-content;
}

.nst-smarttrack-exact-page .btn_blue_arrow:hover,
.nst-smarttrack-exact-page .btn_blue_arrow:focus {
  background: #1f67c7 !important;
  border-color: #1f67c7 !important;
  color: #ffffff !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(31, 103, 199, 0.25) !important;
}

.nst-smarttrack-exact-page .case-btn {
  background: var(--st-accent) !important;
  border-color: var(--st-accent) !important;
  color: #ffffff !important;
}

.nst-smarttrack-exact-page .case-btn:hover,
.nst-smarttrack-exact-page .case-btn:focus {
  background: #f58412 !important;
  border-color: #f58412 !important;
  color: #ffffff !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(245, 132, 18, 0.25) !important;
}

.nst-smarttrack-exact-page .cta-btn {
  min-height: 44px;
  padding: 10px 24px !important;
  border: 1px solid #e5e7eb !important;
  background: #ffffff !important;
  color: #1f2937 !important;
  font-size: 16px;
  line-height: 24px;
  font-weight: 500;
}

.nst-smarttrack-exact-page .cta-btn:hover,
.nst-smarttrack-exact-page .cta-btn:focus {
  background: #f8fafc !important;
  color: #1f2937 !important;
  border-color: #e5e7eb !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 16px rgba(15, 23, 42, 0.12) !important;
}

/* Footer full browser width inside Elementor containers */
.nst-smarttrack-exact-page .footer-section {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  background: var(--st-blue-900) !important;
  color: #cccccc !important;
}

.nst-smarttrack-exact-page .footer-section .container {
  max-width: 1320px;
}

/* Avoid horizontal overflow from absolute assets/cards on mobile */
@media (max-width: 991px) {
  .nst-smarttrack-exact-page { overflow-x: hidden; }
  .nst-smarttrack-exact-page img,
  .nst-smarttrack-exact-page svg { max-width: 100%; }
}
