/* ==========================================================================
   EMEDLOGIX — Premium Responsive Stylesheet  v5.0
   Mobile-First | AngularJS-Driven | Impactful Healthcare Brand
   ========================================================================== */

/* ── Google Fonts ─────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Poppins:wght@400;500;600;700;800&display=swap');

/* ── Design Tokens ─────────────────────────────────────────────────────────── */
:root {
  /* ── New Logo Brand Palette ── */
  --primary:          #0A1A3E;   /* Deep navy (logo text) */
  --primary-dark:     #060E24;   /* Darkest navy */
  --secondary:        #E8A800;   /* Gold (logo 'e') */
  --secondary-light:  #F5C000;   /* Bright gold */
  --accent:           #FFF4D6;   /* Warm gold tint background */
  --accent-2:         #F97316;   /* Orange (logo gradient) */

  --dark:             #0A1A3E;   /* Same as primary for headings */
  --text-main:        #1A2540;   /* Very dark navy — high contrast */
  --text-muted:       #4A5568;   /* Softer but still readable */
  --white:            #FFFFFF;
  --bg-color:         #FAFBFF;
  --bg-light:         #F5F0E8;   /* Warm cream tint */

  --font-heading: 'Poppins', sans-serif;
  --font-body:    'Inter',   sans-serif;

  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 5rem;

  --radius:    10px;
  --radius-lg: 18px;
  --radius-xl: 28px;

  --shadow-sm:    0 2px 8px  rgba(10,26,62,.08);
  --shadow-md:    0 8px 28px rgba(10,26,62,.14);
  --shadow-hover: 0 16px 48px rgba(232,168,0,.22);

  --trans-fast:   .18s ease;
  --trans-smooth: .3s cubic-bezier(.25,.8,.25,1);

  --header-h: 92px;
}

/* ── Reset ─────────────────────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

/* ═══════════════════════════════════════════════════════════════
   PAGE LOADER — Astronaut splash screen (shown on every page load)
   ═══════════════════════════════════════════════════════════════ */
#page-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: linear-gradient(135deg, #060E24 0%, #0A1A3E 50%, #1A3575 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  transition: opacity 0.65s ease, visibility 0.65s ease;
}
#page-loader.hide {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
#page-loader img {
  width: min(200px, 42vw);
  animation: loaderFloat 2s ease-in-out infinite;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,0.35));
}
#page-loader .loader-brand {
  font-family: 'Poppins', sans-serif;
  font-size: 1.55rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.04em;
}
#page-loader .loader-brand span { color: #F5C000; }
#page-loader .loader-dots {
  display: flex;
  gap: 0.5rem;
}
#page-loader .loader-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,0.6);
  animation: loaderDot 1.2s ease-in-out infinite;
}
#page-loader .loader-dots span:nth-child(2) { animation-delay: 0.2s; }
#page-loader .loader-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes loaderFloat {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-18px); }
}
@keyframes loaderDot {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
  40%           { transform: scale(1.0); opacity: 1.0; }
}

html { scroll-behavior:smooth; font-size:16px; }

body {
  font-family: var(--font-body);
  color: var(--text-main);
  background: var(--bg-color);
  line-height: 1.65;
  overflow-x: hidden;
}

h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-heading);
  color: var(--dark);
  font-weight: 700;
  line-height: 1.2;
}

a { text-decoration:none; color:var(--secondary); transition:var(--trans-smooth); }
ul { list-style:none; }
img { max-width:100%; display:block; }

/* ── Layout Helpers ────────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.25rem;
}

.section-pad { padding: var(--space-xl) 0; }

/* ── Universal Section Spacing (catches bare <section> tags) ── */
section { padding: 4rem 0; }
section.section-pad { padding: var(--space-xl) 0; }
section.page-hero { padding: 0; } /* hero has its own controlled padding */

/* ── Typography spacing ─────────────────────────────────────── */
p { margin-bottom: 0.85rem; line-height: 1.75; }
h2 { margin-bottom: 1rem; }
h3 { margin-bottom: 0.75rem; }

.bg-light  { background: var(--bg-light); }
.bg-dark   { background: var(--dark); }
.text-center { text-align:center; }
.mt-2 { margin-top:1rem; }
.mt-4 { margin-top:2rem; }

/* ── Grid ──────────────────────────────────────────────────────────────────── */
.grid        { display:grid; gap:var(--space-lg); }
.grid-2      { grid-template-columns:repeat(2,1fr); }
.grid-3      { grid-template-columns:repeat(3,1fr); }
.grid-4      { grid-template-columns:repeat(4,1fr); }
.col-span-2  { grid-column:span 2; }
.equal-grid  { display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:stretch; }

/* ── Page Animation Keyframes ─────────────────────────────────────────────── */
@keyframes float-y {
  0%,100% { transform: translateY(0px); }
  50%      { transform: translateY(-14px); }
}
@keyframes float-y-slow {
  0%,100% { transform: translateY(0px); }
  50%      { transform: translateY(-8px); }
}
@keyframes pulse-glow {
  0%,100% { box-shadow: 0 0 0 0 rgba(0,98,255,0); }
  50%      { box-shadow: 0 0 30px 10px rgba(0,98,255,0.18); }
}
@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes spin-ccw {
  from { transform: rotate(0deg); }
  to   { transform: rotate(-360deg); }
}
@keyframes data-pulse {
  0%   { opacity:1; transform:scale(1); }
  50%  { opacity:.4; transform:scale(.9); }
  100% { opacity:1; transform:scale(1); }
}
@keyframes slide-up-fade {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes heartbeat {
  0%,100% { transform:scale(1); }
  14%      { transform:scale(1.18); }
  28%      { transform:scale(1); }
  42%      { transform:scale(1.1); }
  70%      { transform:scale(1); }
}
@keyframes blink-cursor {
  0%,100% { opacity:1; } 50% { opacity:0; }
}
@keyframes orbit {
  from { transform: rotate(0deg) translateX(55px) rotate(0deg); }
  to   { transform: rotate(360deg) translateX(55px) rotate(-360deg); }
}
@keyframes orbit2 {
  from { transform: rotate(120deg) translateX(55px) rotate(-120deg); }
  to   { transform: rotate(480deg) translateX(55px) rotate(-480deg); }
}
@keyframes orbit3 {
  from { transform: rotate(240deg) translateX(55px) rotate(-240deg); }
  to   { transform: rotate(600deg) translateX(55px) rotate(-600deg); }
}
@keyframes code-scroll {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}
@keyframes wave-pulse {
  0%,100% { transform:scaleY(0.5); opacity:0.5; }
  50%      { transform:scaleY(1.3); opacity:1; }
}
@keyframes ring-expand {
  0%   { transform:scale(0.8); opacity:.7; }
  100% { transform:scale(2); opacity:0; }
}

/* ── Reusable Animated Visual Containers ──────────────────────────────────── */
.anim-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  flex-shrink: 0;
}
/* Floating card visual */
.float-card {
  animation: float-y 4s ease-in-out infinite;
}
.float-card-slow {
  animation: float-y-slow 6s ease-in-out infinite;
}
/* Heartbeat icon */
.heartbeat-icon {
  animation: heartbeat 1.6s ease-in-out infinite;
  display: inline-block;
}
/* Spinning ring */
.spin-ring {
  animation: spin-slow 8s linear infinite;
}
.spin-ring-ccw {
  animation: spin-ccw 12s linear infinite;
}
/* Generic pulsing dot */
.pulse-dot {
  animation: data-pulse 2s ease-in-out infinite;
}

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1.5rem;
  border-radius: var(--radius);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: .95rem;
  cursor: pointer;
  border: 2px solid transparent;
  transition: var(--trans-smooth);
  white-space: nowrap;
}

.btn-large { padding:1rem 2rem; font-size:1.05rem; }

.btn-primary {
  background: var(--primary);
  color: var(--white);
  border-color: var(--primary);
}
.btn-primary:hover {
  background: var(--secondary);
  border-color: var(--secondary);
  color: var(--white);
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.btn-outline-white {
  background: transparent;
  color: var(--white);
  border-color: rgba(255,255,255,.45);
}
.btn-outline-white:hover {
  background: var(--white);
  color: var(--primary);
}

.btn-outline-primary {
  background: transparent;
  color: var(--primary);
  border-color: var(--primary);
}
.btn-outline-primary:hover {
  background: var(--primary);
  color: var(--white);
}

.btn-secondary {
  background: var(--accent);
  color: var(--primary);
  border-color: rgba(0,98,255,.25);
}
.btn-secondary:hover {
  background: var(--secondary);
  color: var(--white);
  transform: translateY(-2px);
}

/* ── Badge ─────────────────────────────────────────────────────────────────── */
.badge {
  display:inline-block;
  padding:.35rem 1rem;
  background:var(--accent);
  color:var(--secondary);
  border-radius:50px;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  margin-bottom:1rem;
}
.badge-light {
  background:rgba(255,255,255,.15);
  color:var(--dark);
  border:1px solid rgba(255,255,255,.3);
}

/* ── Section Headers ───────────────────────────────────────────────────────── */
.section-header { margin-bottom:3rem; }
.section-header h2 { font-size:2.2rem; margin-bottom:.75rem; }
.section-header p  { color:var(--text-muted); font-size:1.05rem; max-width:600px; }
.text-center .section-header p { margin:0 auto; }

/* ═══════════════════════════════════════════════════════════════
   HEADER & NAVIGATION
   ═══════════════════════════════════════════════════════════════ */
.header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--bg-light); /* Matches logo background */
  box-shadow: 0 1px 0 rgba(0,0,0,.08), var(--shadow-sm);
  height: var(--header-h);
}

.header-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-h);
  gap: 1rem;
}

/* Logo */
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  text-decoration: none;
}
.logo-icon     { height:52px; width:auto; object-fit:contain; }
.logo-text     { height:52px; width:auto; object-fit:contain; }
.logo-combined {
  height: 68px;
  width: auto;
  object-fit: contain;
  transition: transform 0.3s ease, filter 0.3s ease;
  filter: drop-shadow(0 2px 6px rgba(232,168,0,0.0));
}
.logo-combined:hover {
  transform: scale(1.06);
  filter: drop-shadow(0 4px 18px rgba(232,168,0,0.45));
}
@media (max-width: 768px) { .logo-combined { height:54px; max-width:220px; } }
@media (max-width: 480px) { .logo-combined { height:46px; max-width:180px; } }

/* Nav list */
.nav { flex:1; display:flex; justify-content:center; overflow:visible; }

.nav-list {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.nav-link {
  display: flex;
  align-items: center;
  gap: .25rem;
  padding: .45rem .62rem;
  color: var(--dark);
  font-weight: 500;
  font-size: .82rem;
  border-radius: var(--radius);
  transition: color var(--trans-fast);
  cursor: pointer;
  white-space: nowrap;
  position: relative;
  z-index: 1;
}
.nav-link::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius);
  background: var(--secondary);
  z-index: -1;
  transform: scale(0.4) translateY(12px);
  opacity: 0;
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.nav-link:hover::before,
.nav-item.has-dropdown:hover > a.nav-link::before {
  transform: scale(1) translateY(0);
  opacity: 1;
}
.nav-link:hover,
.nav-item.has-dropdown:hover > a.nav-link {
  color: var(--white);
}

.blink-dot {
  width: 10px;
  height: 10px;
  background-color: #ef4444;
  border-radius: 50%;
  display: inline-block;
  margin-left: 8px;
  animation: blinkAnim 1s ease-in-out infinite alternate;
  box-shadow: 0 0 12px rgba(239, 68, 68, 1);
}
@keyframes blinkAnim {
  0% { opacity: 1; transform: scale(1.6); box-shadow: 0 0 18px rgba(239, 68, 68, 1); }
  100% { opacity: 0.1; transform: scale(0.5); box-shadow: 0 0 2px rgba(239, 68, 68, 0); }
}

.drop-icon { font-size:.7rem; transition:transform .25s ease; }
.sub-icon  { font-size:.65rem; color:var(--text-muted); }

/* Rotate chevron when dropdown open (desktop hover) */
.nav-item.has-dropdown:hover > a .drop-icon { transform:rotate(180deg); }

/* ── Dropdown (Desktop) ──────────────────────────── */
.dropdown, .submenu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 220px;
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  border-top: 3px solid var(--secondary);
  padding: .5rem 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(15px);
  transition: opacity .3s cubic-bezier(0.34, 1.56, 0.64, 1), transform .3s cubic-bezier(0.34, 1.56, 0.64, 1), visibility .3s;
  z-index: 200;
  pointer-events: none;
}
@keyframes float-dropdown {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

.submenu {
  top: -.5rem;
  left: 100%;
  border-top: none;
  border-left: 3px solid var(--secondary);
  margin-left: 4px;
}

.nav-item.has-dropdown { position: relative; }
.dropdown-item.has-submenu { position: relative; }

/* Desktop: show on hover */
@media (min-width: 769px) {
  .nav-item.has-dropdown:hover > .dropdown,
  .dropdown-item.has-submenu:hover > .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
    animation: float-dropdown 4s ease-in-out infinite 0.3s;
  }
  .dropdown:hover { opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto; animation: float-dropdown 4s ease-in-out infinite 0.3s; }
}

.dropdown a, .submenu a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .7rem 1.25rem;
  color: var(--text-main);
  font-size: .9rem;
  font-weight: 500;
  transition: var(--trans-fast);
}
.dropdown a:hover, .submenu a:hover {
  background: var(--bg-light);
  color: var(--secondary);
  padding-left: 1.6rem;
}

/* ── Header Right (CTA + Hamburger) ─────────────── */
.header-right {
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-shrink: 0;
}

.header-demo-btn { display:inline-flex; }

.mobile-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 1.55rem;
  color: var(--primary);
  cursor: pointer;
  padding: .25rem .5rem;
  border-radius: var(--radius);
  transition: var(--trans-fast);
  line-height: 1;
}
.mobile-toggle:hover { background:var(--accent); }

/* Mobile CTA inside nav — hidden on desktop */
.mobile-cta-item { display:none; }

/* ═══════════════════════════════════════════════════════════════
   HERO SECTION
   ═══════════════════════════════════════════════════════════════ */
.hero-section {
  padding: 5rem 0 3rem;
  background: linear-gradient(150deg, #ffffff 0%, #FFF8E6 60%, #FFF0CC 100%);
  position: relative;
  overflow: hidden;
}

/* Subtle animated background circles */
.hero-section::before {
  content:'';
  position:absolute;
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(232,168,0,.1) 0%, transparent 70%);
  top:-150px; right:-100px;
  border-radius:50%;
  pointer-events:none;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 3rem;
}

.hero-title {
  font-size: clamp(2rem, 4vw, 3.4rem);
  margin-bottom: 1.25rem;
  letter-spacing: -.5px;
  color: var(--dark);
  line-height: 1.18;
}
.hero-title .highlight { color: #EA580C; }

.hero-subtitle {
  font-size: 1.1rem;
  color: var(--text-muted);
  margin-bottom: 2rem;
  line-height: 1.75;
  max-width: 520px;
}

.hero-cta {
  display: flex;
  gap: .85rem;
  flex-wrap: wrap;
}

.hero-image { position:relative; }

.glow-box {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,98,255,.18);
  transform: perspective(1000px) rotateY(-4deg);
  transition: var(--trans-smooth);
}
.glow-box:hover {
  transform: perspective(1000px) rotateY(0) translateY(-8px);
  box-shadow: 0 36px 80px rgba(0,98,255,.26);
}
.glow-box img { width:100%; height:auto; }

/* Compliance Bar */
.compliance-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
  margin-top: 3.5rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(0,0,0,.06);
}
.compliance-bar span {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .8rem;
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: .5px;
  text-transform: uppercase;
}
.compliance-bar i { color:var(--primary); font-size:1.15rem; }

/* ═══════════════════════════════════════════════════════════════
   FEATURES SECTION
   ═══════════════════════════════════════════════════════════════ */
.features-section { padding: var(--space-xl) 0; }

/* Cards */
.card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 2.25rem;
  box-shadow: var(--shadow-sm);
  transition: var(--trans-smooth);
  overflow: hidden;
  position: relative;
}
.card:hover { 
  box-shadow: 0 25px 60px rgba(0, 98, 255, 0.22); 
  transform: translateY(-10px) scale(1.02); 
}

.card-subtitle {
  display: inline-block;
  color: #92600A;
  background: rgba(232,168,0,0.12);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: .85rem;
  padding: 0.25rem 0.75rem;
  border-radius: 50px;
  border: 1px solid rgba(232,168,0, 0.35);
}
.card h3 { font-size:1.6rem; margin-bottom:.75rem; }
.card p  { color:var(--text-muted); }

.card-image-bottom {
  width: calc(100% + 4.5rem);
  margin: 1.5rem -2.25rem -2.25rem;
}

.card-dark { background: var(--white); border: 2px solid var(--secondary); color: var(--dark); }
.card-dark h3 { color: var(--primary); }
.card-dark h3, .card-dark p { opacity: 1; }
.card-dark p { opacity: 1; }

.feature-icon {
  font-size: 2.2rem;
  color: var(--secondary-light);
  margin-bottom: 1.25rem;
}

.metric { margin-top:1.75rem; padding-top:1.75rem; border-top:1px solid rgba(255,255,255,.12); }
.metric-value {
  display:block;
  font-size:2.6rem;
  font-weight:700;
  font-family:var(--font-heading);
  color:var(--dark);
  line-height:1;
}
.metric-label { font-size:.82rem; opacity:.7; color:var(--dark); }

.cloud-icons { display:flex; gap:1rem; margin-top:1rem; }
.cloud-icons i {
  background:rgba(255,255,255,.12);
  padding:.55rem .65rem;
  border-radius:6px;
  font-size:1.4rem;
  color:var(--secondary-light);
}

.flex-row { display:flex; align-items:center; gap:1.25rem; }

.icon-box {
  background: var(--accent);
  color: var(--secondary);
  min-width: 56px; height:56px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem;
  flex-shrink:0;
}

.justify-between { justify-content:space-between; }
.compliance-badges { display:flex; gap:.75rem; font-size:1.8rem; color:var(--primary); flex-shrink:0; }

/* ═══════════════════════════════════════════════════════════════
   LAYER / DARK SECTION
   ═══════════════════════════════════════════════════════════════ */
.layer-section { padding: var(--space-xl) 0; background-color: var(--white); color: var(--dark); }

.flex-box {
  display: flex;
  align-items: center;
  gap: 3.5rem;
}

.layer-content { flex:1; }
.layer-content h2 { color: var(--primary); font-size: 2.5rem; margin-bottom: 2rem; }

.feature-list { display:flex; flex-direction:column; gap:1.75rem; }

.feature-item { display:flex; gap:1.25rem; }
.feature-item .icon {
  background:rgba(255,255,255,.09);
  color:var(--secondary-light);
  width:42px; height:42px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.feature-item h4 { color: var(--dark); margin-bottom: 0.5rem; }
.feature-item p { color: var(--text-muted); font-size: 0.95rem; }

.layer-image { flex:1; }
.layer-image img {
  border-radius:var(--radius-lg);
  width:100%;
  box-shadow:0 24px 60px rgba(0,0,0,.45);
}

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIAL
   ═══════════════════════════════════════════════════════════════ */
.testimonial-section { padding:var(--space-xl) 0; }

.testimonial-card {
  max-width: 820px;
  margin: 2rem auto 0;
  background: var(--white);
  padding: 3rem;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  position: relative;
}
.testimonial-card::before {
  content: '\201C';
  position:absolute; top:-18px; left:28px;
  font-size:7rem; font-family:Georgia,serif;
  color:var(--accent); line-height:1; z-index:0;
}
.quote {
  font-size:1.08rem; font-style:italic;
  position:relative; z-index:1;
  margin-bottom:1.75rem; line-height:1.85;
}
.author h4 { color:var(--primary); margin-bottom:.15rem; }
.author p  { font-size:.88rem; color:var(--text-muted); }

/* ═══════════════════════════════════════════════════════════════
   CTA SECTION
   ═══════════════════════════════════════════════════════════════ */
.cta-section {
  padding: 5.5rem 0;
  background: linear-gradient(135deg, #FFF9EC 0%, #FFF4D6 60%, #FFE8A0 100%);
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(232,168,0,0.2);
  border-bottom: 1px solid rgba(232,168,0,0.2);
}
.cta-section::before {
  content:'';
  position:absolute;
  width:500px; height:500px;
  border-radius:50%;
  background:rgba(249,115,22,.06);
  top:-200px; right:-100px;
  pointer-events:none;
}

.cta-container h2 { color:var(--primary); font-size:clamp(1.8rem,3vw,2.8rem); margin-bottom:1rem; }
.cta-container p  { font-size:1.1rem; opacity:.88; max-width:680px; margin:0 auto 2.5rem; color:var(--text-muted); }

.cta-actions {
  display:flex;
  justify-content:center;
  gap:1rem;
  flex-wrap:wrap;
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.footer { background:var(--white); padding:4.5rem 0 0; }

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 2.5rem;
}

.footer-logo {
  height: 80px;
  max-width: 100%;
  margin-bottom: 1rem;
  object-fit: contain;
  mix-blend-mode: multiply;
  filter: drop-shadow(0 2px 8px rgba(232,168,0,0.2));
  transition: transform 0.3s ease, filter 0.3s ease;
}
.footer-logo:hover {
  transform: scale(1.04);
  filter: drop-shadow(0 4px 16px rgba(232,168,0,0.4));
}

/* ── Global Continuous Animations ── */
.anim-float {
  animation: continuous-float 5s ease-in-out infinite;
}
@keyframes continuous-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-15px); }
}

.anim-glow {
  animation: continuous-glow 3s ease-in-out infinite alternate;
}
@keyframes continuous-glow {
  0% { box-shadow: 0 0 10px rgba(0, 98, 255, 0.4); transform: scale(1); }
  100% { box-shadow: 0 0 30px rgba(0, 98, 255, 0.9), 0 0 10px rgba(232, 168, 0, 0.6); transform: scale(1.03); }
}

.anim-pulse-badge {
  animation: pulse-badge 2.5s ease-in-out infinite alternate;
}
@keyframes pulse-badge {
  0% { transform: scale(1); box-shadow: 0 4px 10px rgba(0, 98, 255, 0.1); }
  100% { transform: scale(1.06); box-shadow: 0 12px 25px rgba(0, 98, 255, 0.3); border-color: rgba(0, 98, 255, 0.4); }
}

.anim-bounce-icon {
  animation: continuous-bounce 2s ease-in-out infinite;
  display: inline-block;
}
@keyframes continuous-bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px) scale(1.1); color: var(--secondary); }
}

.footer-col h4 {
  font-size:1rem;
  font-weight:700;
  color:var(--dark);
  margin-bottom:1.25rem;
  padding-bottom:.5rem;
  border-bottom:2px solid var(--accent);
  display:inline-block;
}

.footer-col p { color:var(--text-muted); font-size:.92rem; line-height:1.7; }

.footer-col ul li { margin-bottom:.7rem; }
.footer-col ul a  { color:var(--text-muted); font-size:.92rem; }
.footer-col ul a:hover { color:var(--secondary); padding-left:5px; }

.duns-badge { margin:1.25rem 0; }

.social-links { display:flex; gap:.75rem; margin-top:1rem; }
.social-links a {
  display:flex; align-items:center; justify-content:center;
  width:38px; height:38px;
  background:var(--bg-light);
  color:var(--primary);
  border-radius:50%;
  font-size:1rem;
  transition:var(--trans-smooth);
}
.social-links a:hover { background:var(--secondary); color:var(--dark); transform:translateY(-3px); }

.location h5 { font-size:.9rem; font-weight:700; color:var(--dark); margin-bottom:.4rem; }
.location p  { font-size:.86rem; color:var(--text-muted); margin-bottom:.25rem; }
.location i  { margin-right:.4rem; color:var(--secondary); }

.footer-bottom {
  margin-top: 3.5rem;
  border-top: 1px solid rgba(0,0,0,.06);
  padding: 1.5rem 0;
}
.footer-bottom-inner {
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:1rem;
}
.footer-bottom-inner p { color:var(--text-muted); font-size:.87rem; }

.footer-links a {
  color:var(--text-muted);
  font-size:.87rem;
  margin-left:1.25rem;
}
.footer-links a:hover { color:var(--secondary); }

/* ═══════════════════════════════════════════════════════════════
   PAGE-SPECIFIC (Hero on inner pages)
   ═══════════════════════════════════════════════════════════════ */
.page-hero {
  padding: 5.5rem 0 4.5rem;
  background: linear-gradient(135deg, #f0f4ff 0%, #e8f0fe 60%, #dce8ff 100%);
  text-align: center;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid #d4e2ff;
}
.page-hero h1 { 
  color: var(--primary); 
  font-size: clamp(2.2rem, 5vw, 3.4rem); 
  margin-bottom: 1.25rem; 
  font-weight: 800;
}
.page-hero p  { 
  color: var(--text-muted); 
  font-size: 1.15rem; 
  max-width: 720px; 
  margin: 0 auto 2.5rem; 
  line-height: 1.75;
}

.kw-chips {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 2rem;
}
.kw-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 1rem;
  background: var(--white);
  color: var(--primary);
  border: 1px solid rgba(10,61,145,0.25);
  border-radius: 50px;
  font-size: 0.85rem;
  font-weight: 600;
  box-shadow: var(--shadow-sm);
  transition: var(--trans-fast);
}
.kw-chip:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--secondary);
  background: var(--accent);
}
.kw-chip i { color: var(--secondary); font-size: 0.6rem; }

.breadcrumb { 
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-size: 0.9rem; 
  font-weight: 500;
  margin-bottom: 1.25rem; 
}
.breadcrumb a { color: var(--secondary); opacity: 0.8; }
.breadcrumb a:hover { opacity: 1; text-decoration: underline; }
.breadcrumb span { color: var(--primary); font-weight: 600; }

/* Stats bar */
.stats-bar { background:var(--primary); padding:3rem 0; }
.stats-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
  text-align:center;
}
.stat-item h3 { font-size:2.8rem; color:var(--secondary-light); margin-bottom:.4rem; font-weight:800; }
.stat-item p  { color:rgba(255,255,255,.72); font-size:.9rem; }

/* Workflow cards */
.workflow-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.75rem;
}
.wf-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding:2rem;
  border-left:4px solid var(--secondary);
  box-shadow:var(--shadow-sm);
  transition:var(--trans-smooth);
}
.wf-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-hover); }
.step-num {
  background:var(--accent);
  color:var(--secondary);
  width:40px; height:40px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:1rem;
  margin-bottom:1rem;
}
.wf-card h3 { font-size:1.15rem; margin-bottom:.5rem; }
.wf-card p  { color:var(--text-muted); font-size:.92rem; }

/* RIPE grid */
.ripe-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.75rem; }
.ripe-card {
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;
  padding:2.25rem;
  border-radius:var(--radius-lg);
}
.ripe-card h3 { color:#fff; margin-bottom:.85rem; }
.ripe-card p  { color:rgba(255,255,255,.85); font-size:.93rem; }
.ripe-card i  { font-size:2.25rem; color:rgba(255,255,255,.7); margin-bottom:1.25rem; display:block; }

/* CTA Strip */
.cta-strip {
  background: linear-gradient(135deg, #f0f4ff 0%, #e8f0fe 60%, #dce8ff 100%);
  color: var(--dark);
  padding: 5rem 0;
  text-align: center;
  border-top: 1px solid rgba(0,98,255,0.08);
  border-bottom: 1px solid rgba(0,98,255,0.08);
}
.cta-strip h2 { color:var(--primary); font-size:clamp(1.8rem,3vw,2.5rem); margin-bottom:1.25rem; }
.cta-strip p  { color:var(--text-muted); margin-bottom:2rem; font-size:1.05rem; max-width:700px; margin-left:auto; margin-right:auto; }
.cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* About page */
.about-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:3.5rem; align-items:center;
}
.about-content h2 { font-size:2.2rem; margin-bottom:1.25rem; }
.about-content p  { color:var(--text-muted); font-size:1rem; margin-bottom:1.1rem; line-height:1.85; }
.about-visual {
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  border-radius:var(--radius-xl);
  padding:2.75rem;
  color:#fff;
}
.about-stats { display:grid; grid-template-columns:1fr 1fr; gap:1.75rem; }
.about-stat h3 { color:#fff; font-size:2.3rem; margin-bottom:.25rem; }
.about-stat p  { color:rgba(255,255,255,.8); font-size:.88rem; }

.team-values {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.75rem;
}
.value-card {
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:2.25rem;
  box-shadow:var(--shadow-sm);
  text-align:center;
  transition:var(--trans-smooth);
}
.value-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-hover); }
.value-icon {
  width:68px; height:68px;
  border-radius:18px;
  background:var(--accent);
  color:var(--secondary);
  display:flex; align-items:center; justify-content:center;
  font-size:1.75rem;
  margin:0 auto 1.25rem;
}
.value-card h3 { margin-bottom:.7rem; font-size:1.1rem; }
.value-card p  { color:var(--text-muted); font-size:.92rem; }

.locations { display:grid; grid-template-columns:1fr 1fr; gap:1.75rem; }
.location-card {
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:2.25rem;
  box-shadow:var(--shadow-sm);
  border-left:4px solid var(--secondary);
}
.location-card h3 { margin-bottom:1rem; }
.location-card .flag { font-size:2rem; margin-bottom:.5rem; }
.location-card p {
  color:var(--text-muted);
  font-size:.9rem;
  margin-bottom:.5rem;
  display:flex;
  align-items:flex-start;
  gap:.6rem;
}
.location-card p i { color:var(--secondary); margin-top:.1rem; font-size:.82rem; flex-shrink:0; }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — TABLET  (max-width: 1024px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .grid-3 { grid-template-columns:1fr; }
  .col-span-2 { grid-column:span 1; }

  .hero-grid { grid-template-columns:1fr; text-align:center; gap:2.5rem; }
  .hero-subtitle { max-width:100%; margin-left:auto; margin-right:auto; }
  .hero-cta { justify-content:center; }
  .glow-box { transform:none; }
  .glow-box:hover { transform:translateY(-6px); }

  .flex-box { flex-direction:column; gap:2.5rem; }
  .layer-image { width:100%; }

  .footer-grid { grid-template-columns:repeat(2,1fr); }

  .about-grid    { grid-template-columns:1fr; }
  .team-values   { grid-template-columns:repeat(2,1fr); }
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE  (max-width: 768px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ── Nav ── */
  .header-demo-btn, .header-login-btn { display:none; }
  .mobile-toggle   { display:block; }
  .mobile-cta-item { display:block; padding:.75rem 1.25rem; }
  .mobile-cta-btn  { width:100%; justify-content:center; }

  .nav { position:static; }

  .nav-list {
    display: none;
    flex-direction: column;
    align-items: stretch;
    position: absolute;
    top: var(--header-h);
    left: 0;
    width: 100%;
    background: var(--white);
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    padding: .5rem 0 1.5rem;
    gap: 0;
    max-height: calc(100vh - var(--header-h));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .nav-list.mobile-open { display:flex; }

  .nav-item > .nav-link {
    padding: .9rem 1.25rem;
    border-radius: 0;
    justify-content: space-between;
    border-bottom: 1px solid rgba(0,0,0,.05);
    width: 100%;
    font-size: 1rem;
  }

  /* ── Mobile Dropdowns (AngularJS ng-class driven) ── */
  .dropdown, .submenu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    border-radius: 0;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s ease;
    pointer-events: auto;
    background: var(--bg-light);
  }

  /* When AngularJS adds .drop-open, expand the dropdown */
  .nav-item.has-dropdown.drop-open > .dropdown,
  .dropdown-item.has-submenu.sub-open > .submenu {
    max-height: 400px;
  }

  .dropdown a, .submenu a {
    padding: .75rem 1.75rem;
    border-bottom: 1px solid rgba(0,0,0,.04);
    font-size: .9rem;
  }
  .dropdown a:hover, .submenu a:hover { padding-left:2.1rem; }

  .submenu { background:#f0f5fc; padding-left:.5rem; }

  /* Rotate chevron when mobile drop is open */
  .nav-item.has-dropdown.drop-open > .nav-link .drop-icon { transform:rotate(180deg); }

  /* ── Layout ── */
  .grid-2, .grid-4, .equal-grid { grid-template-columns:1fr; }
  .flex-row { flex-direction:column; text-align:center; }
  .justify-between { justify-content:center; }

  .compliance-bar { display:none; }

  .cta-actions, .cta-btns { flex-direction:column; align-items:center; }
  .cta-actions .btn, .cta-btns .btn { width:100%; max-width:320px; justify-content:center; }

  .stats-grid { grid-template-columns:repeat(2,1fr); }

  .ripe-grid     { grid-template-columns:1fr; }
  .team-values   { grid-template-columns:1fr; }
  .locations     { grid-template-columns:1fr; }
  .about-stats   { grid-template-columns:repeat(2,1fr); }
  .footer-grid   { grid-template-columns:1fr; }

  .footer-bottom-inner { flex-direction:column; text-align:center; }
  .footer-links a { margin-left:.75rem; margin-right:.75rem; }

  .section-header h2   { font-size:1.75rem; }
  .testimonial-card    { padding:2rem 1.5rem; }
  .page-hero           { padding:3.5rem 0 3rem; }
  .card                { padding:1.75rem; }
  .wf-card             { padding:1.5rem; }
  .ripe-card           { padding:1.75rem; }
  .about-visual        { padding:2rem; }
  .value-card          { padding:1.75rem; }
  .location-card       { padding:1.75rem; }

  .hero-section { padding:3.5rem 0 2.5rem; }
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — SMALL  (max-width: 480px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
  .logo-text { display:none; }
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:1.25rem; }
  .stat-item h3 { font-size:2.2rem; }
  .btn-large { padding:.85rem 1.5rem; font-size:1rem; }
  .page-hero h1 { font-size:2rem; }
  .section-header h2 { font-size:1.5rem; }
  .hero-badge { font-size:.75rem; padding:.35rem .8rem; }
  .cta-strip h2 { font-size:1.5rem; }
  .kw-chips { gap:.4rem; }
  .kw-chip { font-size:.78rem; padding:.35rem .7rem; }
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — ADDITIONAL PAGE-SPECIFIC RULES
   Covers page layouts not in the generic grid system
   ═══════════════════════════════════════════════════════════════ */

/* Tablet: 768–1024px — page-specific two-column grids */
@media (max-width: 1024px) {
  /* Workflow page */
  .wf-step { grid-template-columns: 70px 1fr; gap:1.5rem; }

  /* Chase page */
  .chase-hero-grid  { grid-template-columns:1fr; gap:2rem; }
  .interop-cards    { grid-template-columns:repeat(2,1fr); }

  /* Legal page */
  .legal-grid { grid-template-columns:1fr; }
  .legal-nav  { display:none; }

  /* Login */
  .login-grid { grid-template-columns:1fr; }
  .login-promo { display:none; }

  /* Hero with image side-by-side */
  .hero-image { max-width:360px; margin:0 auto; }

  /* Section pad reduced on tablet */
  section.section-pad { padding: 3.5rem 0; }
  section { padding: 3rem 0; }
}

/* Mobile: up to 768px — page-specific */
@media (max-width: 768px) {
  /* Workflow */
  .wf-step { grid-template-columns:1fr; }
  .step-features { grid-template-columns:1fr; }
  .step-num-big { width:54px; height:54px; font-size:1.4rem; }

  /* Chase page */
  .interop-cards { grid-template-columns:1fr; }
  .timeline-item { padding:1.25rem 1rem 1.25rem 1.5rem; }

  /* Terms / Legal */
  .legal-cards { gap:1.25rem; }
  .legal-card  { padding:1.75rem 1.25rem; }
  .legal-card h2 { font-size:1.25rem; }

  /* About page */
  .about-grid  { grid-template-columns:1fr; }
  .about-stats { grid-template-columns:repeat(2,1fr); }

  /* Contact page */
  .contact-grid { grid-template-columns:1fr; }

  /* Blogs */
  .blog-grid   { grid-template-columns:1fr; }

  /* RIPE page */
  .ripe-features { grid-template-columns:1fr; }

  /* HCC page */
  .hcc-cards  { grid-template-columns:1fr; }

  /* NLP / OCR feature sections */
  .feat-grid  { grid-template-columns:1fr; }

  /* Hero layout stacking */
  .page-hero { padding:3rem 0 2.5rem; text-align:center; }
  .page-hero .container { grid-template-columns:1fr !important; }
  .page-hero .hero-image { display:none; }
  .page-hero .cta-btns, .page-hero .cta-actions { justify-content:center; }

  /* Section padding */
  section.section-pad { padding: 3rem 0; }
  section { padding: 2.5rem 0; }

  /* Typography */
  h1 { font-size: clamp(1.8rem, 5vw, 2.5rem); }
  h2 { font-size: clamp(1.4rem, 4vw, 2rem); }
  h3 { font-size: clamp(1.1rem, 3vw, 1.4rem); }

  /* Breadcrumb */
  .breadcrumb { font-size:.8rem; flex-wrap:wrap; }

  /* ICD Search iframe */
  .iframe-container { height:70vh; }
}

/* ═══════════════════════════════════════════════════════════════
   AOS ANIMATION OVERRIDES
   ═══════════════════════════════════════════════════════════════ */
[data-aos] { backface-visibility:hidden; }
/* From Uiverse.io by Praashoo7 */ 
.main {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  height: 300px;
  transform: scale(0.8);
}

.loaders,
.loadersB {
  display: flex;
  align-items: center;
  justify-content: center;
}

.loader {
  position: absolute;
  width: 1.15em;
  height: 13em;
  border-radius: 50px;
  background: #e0e0e0;
}
.loader:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 1.15em;
  height: 5em;
  background: #e0e0e0;
  border-radius: 50px;
  border: 1px solid #e2e2e2;
  box-shadow:
    inset 5px 5px 15px #d3d2d2ab,
    inset -5px -5px 15px #e9e9e9ab;
  mask-image: linear-gradient(
    to bottom,
    black calc(100% - 48px),
    transparent 100%
  );
}
.loader::before {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 1.15em;
  height: 4.5em;
  background: #e0e0e0;
  border-radius: 50px;
  border: 1px solid #e2e2e2;
  box-shadow:
    inset 5px 5px 15px #d3d2d2ab,
    inset -5px -5px 15px #e9e9e9ab;
  mask-image: linear-gradient(
    to top,
    black calc(100% - 48px),
    transparent 100%
  );
}
.loaderA {
  position: absolute;
  width: 1.15em;
  height: 13em;
  border-radius: 50px;
  background: transparent;
}
.ball0,
.ball1,
.ball2,
.ball3,
.ball4,
.ball5,
.ball6,
.ball7,
.ball8,
.ball9 {
  width: 1.15em;
  height: 1.15em;
  box-shadow:
    rgba(0, 0, 0, 0.17) 0px -10px 10px 0px inset,
    rgba(0, 0, 0, 0.15) 0px -15px 15px 0px inset,
    rgba(0, 0, 0, 0.1) 0px -40px 20px 0px inset,
    rgba(0, 0, 0, 0.06) 0px 2px 1px,
    rgba(0, 0, 0, 0.09) 0px 4px 2px,
    rgba(0, 0, 0, 0.09) 0px 8px 4px,
    rgba(0, 0, 0, 0.09) 0px 16px 8px,
    rgba(0, 0, 0, 0.09) 0px 32px 16px,
    0px -1px 15px -8px rgba(0, 0, 0, 0.09);
  border-radius: 50%;
  transition: transform 800ms cubic-bezier(1, -0.4, 0, 1.4);
  background-color: rgb(232, 232, 232, 1);
  animation: 3.63s move ease-in-out infinite;
}
.loader:nth-child(2) {
  transform: rotate(20deg);
}
.loader:nth-child(3) {
  transform: rotate(40deg);
}
.loader:nth-child(4) {
  transform: rotate(60deg);
}
.loader:nth-child(5) {
  transform: rotate(80deg);
}
.loader:nth-child(6) {
  transform: rotate(100deg);
}
.loader:nth-child(7) {
  transform: rotate(120deg);
}
.loader:nth-child(8) {
  transform: rotate(140deg);
}
.loader:nth-child(9) {
  transform: rotate(160deg);
}

.loaderA:nth-child(2) {
  transform: rotate(20deg);
}
.loaderA:nth-child(3) {
  transform: rotate(40deg);
}
.loaderA:nth-child(4) {
  transform: rotate(60deg);
}
.loaderA:nth-child(5) {
  transform: rotate(80deg);
}
.loaderA:nth-child(6) {
  transform: rotate(100deg);
}
.loaderA:nth-child(7) {
  transform: rotate(120deg);
}
.loaderA:nth-child(8) {
  transform: rotate(140deg);
}
.loaderA:nth-child(9) {
  transform: rotate(160deg);
}

.ball1 {
  animation-delay: 0.2s;
}
.ball2 {
  animation-delay: 0.4s;
}
.ball3 {
  animation-delay: 0.6s;
}
.ball4 {
  animation-delay: 0.8s;
}
.ball5 {
  animation-delay: 1s;
}
.ball6 {
  animation-delay: 1.2s;
}
.ball7 {
  animation-delay: 1.4s;
}
.ball8 {
  animation-delay: 1.6s;
}
.ball9 {
  animation-delay: 1.8s;
}

@keyframes move {
  0% {
    transform: translateY(0em);
  }
  50% {
    transform: translateY(12em);
  }
  100% {
    transform: translateY(0em);
  }
}


/* ═══════════════════════════════════════════════════════
   PAGE PRELOADER — UIverse Astronaut (by JkHuger)
═══════════════════════════════════════════════════════ */
#page-preloader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: linear-gradient(135deg, #0d1b4b 0%, #1a3a6b 50%, #0d1b4b 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  transition: opacity 0.7s ease, visibility 0.7s ease;
}
#page-preloader.preloader-hidden {
  opacity: 0;
  visibility: hidden;
}
.preloader-text {
  position: absolute;
  bottom: 12%;
  color: rgba(255,255,255,0.7);
  font-family: 'Inter', sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  animation: pulse-text 2s ease-in-out infinite;
}
@keyframes pulse-text {
  0%, 100% { opacity: 0.5; }
  50%       { opacity: 1; }
}

@keyframes snow {
  0%   { opacity: 0; transform: translateY(0px); }
  20%  { opacity: 1; }
  100% { opacity: 1; transform: translateY(650px); }
}
@keyframes astronaut {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
.box-of-star1, .box-of-star2, .box-of-star3, .box-of-star4 {
  width: 100%; position: absolute; z-index: 10; left: 0; top: 0;
  transform: translateY(0px); height: 700px;
}
.box-of-star1 { animation: snow 5s linear infinite; }
.box-of-star2 { animation: snow 5s -1.64s linear infinite; }
.box-of-star3 { animation: snow 5s -2.30s linear infinite; }
.box-of-star4 { animation: snow 5s -3.30s linear infinite; }
.star {
  width: 3px; height: 3px; border-radius: 50%;
  background-color: #FFF; position: absolute; z-index: 10; opacity: 0.7;
}
.star:before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background-color: #FFF; position: absolute; z-index: 10;
  top: 80px; left: 70px; opacity: .7;
}
.star:after {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background-color: #FFF; position: absolute; z-index: 10;
  top: 8px; left: 170px; opacity: .9;
}
.star-position1 { top: 30px;  left: 20px; }
.star-position2 { top: 110px; left: 250px; }
.star-position3 { top: 60px;  left: 570px; }
.star-position4 { top: 120px; left: 900px; }
.star-position5 { top: 20px;  left: 1120px; }
.star-position6 { top: 90px;  left: 1280px; }
.star-position7 { top: 30px;  left: 1480px; }
.astronaut {
  width: 250px; height: 300px; position: absolute; z-index: 11;
  top: calc(50% - 150px); left: calc(50% - 125px);
  animation: astronaut 5s linear infinite;
}
.schoolbag {
  width: 100px; height: 150px; position: absolute; z-index: 1;
  top: calc(50% - 75px); left: calc(50% - 50px);
  background-color: #94b7ca; border-radius: 50px 50px 0 0 / 30px 30px 0 0;
}
.head {
  width: 97px; height: 80px; position: absolute; z-index: 3;
  background: -webkit-linear-gradient(left, #e3e8eb 0%, #e3e8eb 50%, #fbfdfa 50%, #fbfdfa 100%);
  border-radius: 50%; top: 34px; left: calc(50% - 47.5px);
}
.head:after {
  content: ""; width: 60px; height: 50px; position: absolute;
  top: calc(50% - 25px); left: calc(50% - 30px);
  background: -webkit-linear-gradient(top, #15aece 0%, #15aece 50%, #0391bf 50%, #0391bf 100%);
  border-radius: 15px;
}
.head:before {
  content: ""; width: 12px; height: 25px; position: absolute;
  top: calc(50% - 12.5px); left: -4px;
  background-color: #618095; border-radius: 5px; box-shadow: 92px 0px 0px #618095;
}
.body {
  width: 85px; height: 100px; position: absolute; z-index: 2;
  border-radius: 40px / 20px; top: 105px; left: calc(50% - 41px);
  background: -webkit-linear-gradient(left, #e3e8eb 0%, #e3e8eb 50%, #fbfdfa 50%, #fbfdfa 100%);
}
.panel {
  width: 60px; height: 40px; position: absolute;
  top: 20px; left: calc(50% - 30px); background-color: #b7cceb;
}
.panel:before {
  content: ""; width: 30px; height: 5px; position: absolute;
  top: 9px; left: 7px; background-color: #fbfdfa;
  box-shadow: 0px 9px 0px #fbfdfa, 0px 18px 0px #fbfdfa;
}
.panel:after {
  content: ""; width: 8px; height: 8px; position: absolute;
  top: 9px; right: 7px; background-color: #fbfdfa;
  border-radius: 50%; box-shadow: 0px 14px 0px 2px #fbfdfa;
}
.arm { width: 80px; height: 30px; position: absolute; top: 121px; z-index: 2; }
.arm-left  { left: 30px;  background-color: #e3e8eb; border-radius: 0 0 0 39px; }
.arm-right { right: 30px; background-color: #fbfdfa; border-radius: 0 0 39px 0; }
.arm-left:before, .arm-right:before {
  content: ""; width: 30px; height: 70px; position: absolute; top: -40px;
}
.arm-left:before  { border-radius: 50px 50px 0px 120px / 50px 50px 0 110px; left: 0;  background-color: #e3e8eb; }
.arm-right:before { border-radius: 50px 50px 120px 0 / 50px 50px 110px 0;   right: 0; background-color: #fbfdfa; }
.arm-left:after, .arm-right:after {
  content: ""; width: 30px; height: 10px; position: absolute; top: -24px;
}
.arm-left:after  { background-color: #6e91a4; left: 0; }
.arm-right:after { right: 0; background-color: #b6d2e0; }
.leg { width: 30px; height: 40px; position: absolute; z-index: 2; bottom: 70px; }
.leg-left  { left: 76px;  background-color: #e3e8eb; transform: rotate(20deg); }
.leg-right { right: 73px; background-color: #fbfdfa; transform: rotate(-20deg); }
.leg-left:before, .leg-right:before {
  content: ""; width: 50px; height: 25px; position: absolute; bottom: -26px;
}
.leg-left:before  { left: -20px;  background-color: #e3e8eb; border-radius: 30px 0 0 0; border-bottom: 10px solid #6d96ac; }
.leg-right:before { right: -20px; background-color: #fbfdfa; border-radius: 0 30px 0 0; border-bottom: 10px solid #b0cfe4; }

/* ═══ RAPID DEPLOYMENT — TIMELINE CARD ═══════════════════ */
.card-highlight {
  background: #ffffff;
  border: 2px solid #e8f0fe;
  border-radius: var(--radius-lg);
  padding: 2.25rem;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.deploy-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 1.5rem;
  position: relative;
}
.deploy-timeline::before {
  content: '';
  position: absolute;
  left: 18px;
  top: 24px;
  bottom: 24px;
  width: 2px;
  background: linear-gradient(to bottom, var(--secondary), var(--primary));
  z-index: 0;
}
.deploy-step {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.65rem 0;
  position: relative;
  z-index: 1;
}
.deploy-dot {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #e8f0fe;
  border: 2px solid var(--secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.8rem;
  color: var(--secondary);
  transition: all 0.3s ease;
}
.deploy-dot.active {
  background: var(--secondary);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(0,98,255,0.15);
}
.deploy-info {
  display: flex;
  flex-direction: column;
  line-height: 1.3;
}
.deploy-info strong {
  font-size: 0.85rem;
  color: var(--primary);
  font-weight: 700;
}
.deploy-info span {
  font-size: 0.82rem;
  color: var(--text-muted);
}

.ops-badge {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  background: linear-gradient(135deg, #f0f4ff, #e8f0fe);
  border-radius: 8px;
  padding: 0.75rem 1rem;
  font-size: 0.85rem;
  color: var(--primary);
  margin-top: auto;
}
.ops-divider { font-weight: 900; color: var(--secondary); }
.ops-tag {
  margin-left: auto;
  background: var(--secondary);
  color: #fff;
  border-radius: 20px;
  padding: 0.2rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}

/* ═══ MOBILE RESPONSIVENESS OVERHAUL ══════════════════════
   Real fixes that actually work on real phones
══════════════════════════════════════════════════════════ */

/* Tablets and below */
@media (max-width: 1024px) {
  .grid-3 { grid-template-columns: 1fr !important; }
  .col-span-2 { grid-column: span 1 !important; }
  .grid-2 { grid-template-columns: 1fr 1fr !important; }
  .hero-grid { gap: 2rem; }
}

/* Mobile - 768px and below */
@media (max-width: 768px) {
  html { font-size: 15px; }

  .container { padding: 0 1rem; }

  /* Hero */
  .hero-section { padding: 5rem 0 3rem; }
  .hero-grid { grid-template-columns: 1fr !important; text-align: center; gap: 2rem; }
  .hero-title { font-size: clamp(1.8rem, 6vw, 2.8rem); }
  .hero-subtitle { font-size: 1rem; margin: 0 auto; }
  .hero-cta { flex-direction: column; align-items: center; gap: 0.75rem; }
  .hero-image { display: flex; justify-content: center; }
  .hero-image img { max-width: 280px; }
  .glow-box { transform: none !important; }

  /* Grids */
  .grid-2,
  .grid-3,
  .grid-4 { grid-template-columns: 1fr !important; }
  .col-span-2 { grid-column: span 1 !important; }

  /* Cards */
  .card { padding: 1.5rem; }
  .card-highlight { height: auto; }
  .flex-row { flex-direction: column !important; text-align: center !important; }

  /* Architecture section */
  .flex-box { flex-direction: column !important; gap: 2rem; }
  .layer-image { width: 100% !important; }
  .layer-image img { max-height: 260px; object-fit: cover; }

  /* Deploy timeline */
  .ops-tag { margin-left: 0; }

  /* Footer */
  .footer-grid,
  .grid.grid-4 { grid-template-columns: 1fr 1fr !important; }

  /* Stats */
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 1rem; }

  /* Buttons - touch-friendly */
  .btn { min-height: 48px; font-size: 1rem; padding: 0.75rem 1.5rem; }
  .btn-large { min-height: 52px; }

  /* Section padding */
  .section-pad,
  .features-section,
  .layer-section,
  .testimonial-section,
  .cta-section { padding: 3rem 0; }
}

/* Small phones — 480px and below */
@media (max-width: 480px) {
  html { font-size: 14px; }
  .hero-title { font-size: clamp(1.6rem, 7vw, 2.2rem); }
  .hero-image img { max-width: 220px; }

  .footer-grid,
  .grid.grid-4 { grid-template-columns: 1fr !important; }
  .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .section-header h2 { font-size: clamp(1.4rem, 6vw, 2rem); }
  .compliance-bar { display: none; }
}

/* ═══ RAPID DEPLOYMENT — RING METRIC ═══════════════ */
.deploy-metric-ring {
  width: 130px; height: 130px;
  border-radius: 50%;
  background: conic-gradient(var(--secondary) 0% 100%);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1.25rem;
  box-shadow: 0 0 0 6px #e8f0fe, 0 8px 30px rgba(0,98,255,0.2);
  animation: ring-pulse 3s ease-in-out infinite;
}
@keyframes ring-pulse {
  0%, 100% { box-shadow: 0 0 0 6px #e8f0fe, 0 8px 30px rgba(0,98,255,0.2); }
  50%       { box-shadow: 0 0 0 10px #dce8ff, 0 8px 40px rgba(0,98,255,0.35); }
}
.ring-inner {
  width: 100px; height: 100px; border-radius: 50%;
  background: #fff; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
}
.ring-value { font-size: 2.8rem; font-weight: 900; color: var(--secondary); line-height: 1; }
.ring-unit  { font-size: 0.75rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }

.perf-chips {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 0.5rem; margin-bottom: 1.25rem;
}
.perf-chip {
  display: flex; align-items: center; gap: 0.5rem;
  background: #f0f9f0; border-radius: 8px;
  padding: 0.5rem 0.75rem; font-size: 0.8rem; color: #1a5c2a;
}
.perf-chip i { color: #22a84a; font-size: 0.85rem; flex-shrink: 0; }

/* ═══ ABOUT PAGE — BRIGHT LAYOUT ═══════════════════ */
.about-visual-bright {
  display: flex; flex-direction: column; gap: 1rem;
}
.about-img-wrap { border-radius: 16px; overflow: hidden; }
.about-stat-chips {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem;
}
.stat-chip {
  background: linear-gradient(135deg, #f0f4ff, #e8f0fe);
  border-radius: 12px; padding: 1rem;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  border: 1px solid #d4e2ff;
}
.chip-val {
  font-size: 1.6rem; font-weight: 900; color: var(--secondary);
  line-height: 1; margin-bottom: 0.25rem;
}
.chip-lbl { font-size: 0.75rem; color: var(--text-muted); font-weight: 500; }

@media (max-width: 768px) {
  .about-visual-bright { margin-top: 1.5rem; }
  .perf-chips { flex-direction: column; align-items: stretch; }
  .deploy-metric-ring { width: 100px; height: 100px; }
  .ring-inner { width: 76px; height: 76px; }
  .ring-value { font-size: 2rem; }
}

/* ═══ PAGE HERO — BRIGHT VERSION (overrides dark for product pages) ════════ */
.page-hero {
  padding: 5.5rem 0 4.5rem !important;
  background: linear-gradient(135deg, #f0f4ff 0%, #e8f0fe 60%, #dce8ff 100%) !important;
  color: var(--primary) !important;
  border-bottom: 1px solid #d4e2ff;
}
.page-hero h1 { color: var(--primary) !important; font-weight: 800 !important; }
.page-hero p  { color: var(--text-muted) !important; font-size: 1.15rem !important; }
.page-hero .breadcrumb a    { color: var(--secondary) !important; font-weight: 500 !important; }
.page-hero .breadcrumb span { color: var(--primary) !important; font-weight: 600 !important; }

/* btn-outline-white on light bg → use border with primary colour */
/* btn-outline-white on light bg → use border with primary colour */
.page-hero .btn-outline-white,
.page-hero .btn-outline-primary {
  border-color: var(--primary) !important;
  color: var(--primary) !important;
  background: transparent !important;
}
.page-hero .btn-outline-white:hover,
.page-hero .btn-outline-primary:hover {
  background: var(--primary) !important;
  color: var(--white) !important;
}

/* stats-bar stays dark/vibrant — reinforce */
.stats-bar {
  background: linear-gradient(135deg, #2C3590, #0062ff) !important;
  color: #fff !important;
}
.stats-bar .stat-item h3 { color: #F5A300 !important; }
.stats-bar .stat-item p  { color: rgba(255,255,255,0.8) !important; }

/* Chase visual bright card text fix */
.chase-visual h3, .chase-visual h4 { color: var(--primary) !important; }
.chase-visual .ehr-logo { color: var(--dark) !important; font-weight: 700; }

/* OCR visual bright card */
.ocr-visual h3 { color: var(--primary) !important; }
.ocr-step p    { color: rgba(255,255,255,0.88) !important; }
.ocr-step-num  { background: var(--secondary) !important; color: #fff !important; }

/* Mobile: stack page-hero content neatly */
@media (max-width: 768px) {
  .page-hero { padding: 3.5rem 0 2.5rem !important; text-align: center; }
  .page-hero .cta-btns { justify-content: center !important; }
  .stats-bar .stats-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media (max-width: 480px) {
  .stats-bar .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .page-hero h1 { font-size: clamp(1.8rem,7vw,2.5rem) !important; }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE RESPONSIVENESS — COMPREHENSIVE FINAL RULES
   These rules fire at every breakpoint, ensuring all pages
   work correctly on phones, tablets, and desktops.
═══════════════════════════════════════════════════════════════ */

/* ── Auto-fit helper classes (added by script to inline grids) ── */
.mobile-grid-2 { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.5rem; }
.mobile-grid-3 { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.5rem; }
.mobile-grid-4 { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1.25rem; }

/* ── Base: all images are fluid ── */
img { max-width:100%; height:auto; display:block; }

/* ── Base: all containers are fluid ── */
.container { width:100%; max-width:1200px; margin:0 auto; padding:0 1.5rem; box-sizing:border-box; }

/* ── Tables scroll on mobile ── */
table { width:100%; overflow-x:auto; display:block; }

/* ══ BREAKPOINT: Tablet (max 1024px) ═══════════════════════════ */
@media (max-width:1024px) {
  .grid-3, .grid-4 { grid-template-columns:repeat(2,1fr) !important; }
  .col-span-2 { grid-column:span 1 !important; }
  .about-grid { grid-template-columns:1fr !important; }
  .team-values { grid-template-columns:repeat(2,1fr) !important; }
  .hero-grid { grid-template-columns:1fr !important; text-align:center; }
  .hero-cta { justify-content:center !important; }
  .flex-box { flex-direction:column !important; }
  .ocr-section { flex-direction:column !important; }
  .chase-hero-grid { grid-template-columns:1fr !important; }
  .interop-cards { grid-template-columns:1fr 1fr !important; }
  .nlp-modules { grid-template-columns:1fr !important; }
  .icd-hero-grid { grid-template-columns:1fr !important; }
  .workflow-cards { grid-template-columns:1fr !important; }
  .locations { grid-template-columns:1fr !important; }
}

/* ══ BREAKPOINT: Mobile (max 768px) ════════════════════════════ */
@media (max-width:768px) {
  html { font-size:15px; }
  body { overflow-x:hidden; }

  /* Layout */
  .container { padding:0 1rem; }
  .grid-2, .grid-3, .grid-4,
  .mobile-grid-2, .mobile-grid-3, .mobile-grid-4 {
    grid-template-columns:1fr !important;
  }
  .col-span-2 { grid-column:span 1 !important; }
  .flex-row { flex-direction:column !important; align-items:flex-start !important; }
  .flex-box { flex-direction:column !important; gap:2rem !important; }
  .justify-between { justify-content:flex-start !important; }

  /* Sections */
  section, .section-pad { padding:3rem 0 !important; }
  .hero-section { padding:4.5rem 0 2.5rem !important; }
  .page-hero { padding:3rem 0 2rem !important; text-align:center !important; }

  /* Hero */
  .hero-grid { grid-template-columns:1fr !important; gap:2rem !important; text-align:center !important; }
  .hero-title { font-size:clamp(1.8rem,6vw,2.6rem) !important; }
  .hero-cta { flex-direction:column !important; align-items:center !important; gap:0.75rem !important; }
  .hero-image { display:flex; justify-content:center; }
  .hero-image img { max-width:260px !important; }

  /* Nav */
  .header-demo-btn { display:none !important; }

  /* Cards */
  .card { padding:1.25rem !important; }
  .card-highlight { height:auto !important; }
  .about-grid { grid-template-columns:1fr !important; }
  .team-values { grid-template-columns:1fr 1fr !important; }

  /* Stats bar */
  .stats-grid { grid-template-columns:repeat(2,1fr) !important; gap:1rem !important; }
  .stat-item h3 { font-size:2rem !important; }

  /* Specific product page grids */
  .chase-hero-grid { grid-template-columns:1fr !important; }
  .interop-cards { grid-template-columns:1fr !important; }
  .locations { grid-template-columns:1fr !important; }
  .nlp-modules { grid-template-columns:1fr !important; }
  .ocr-section { flex-direction:column !important; gap:2rem !important; }
  .icd-hero-grid { grid-template-columns:1fr !important; }
  .steps-grid { grid-template-columns:1fr 1fr !important; }
  .feat-grid { grid-template-columns:1fr !important; }
  .workflow-cards { grid-template-columns:1fr !important; }
  .ripe-grid { grid-template-columns:1fr !important; }
  .cta-btns { flex-direction:column !important; align-items:center !important; gap:0.75rem !important; }

  /* Footer */
  .footer-grid, .grid.grid-4 { grid-template-columns:1fr 1fr !important; }
  .footer-bottom-inner { flex-direction:column !important; text-align:center !important; gap:0.5rem !important; }

  /* Touch-friendly buttons */
  .btn, .btn-icd-primary, .btn-icd-outline {
    min-height:48px; padding:0.75rem 1.25rem; font-size:0.97rem;
    display:inline-flex; align-items:center; justify-content:center;
  }
  .btn-large { min-height:52px; width:100%; max-width:320px; }

  /* Deploy ring */
  .deploy-metric-ring { width:100px; height:100px; }
  .ring-inner { width:76px; height:76px; }
  .ring-value { font-size:2rem; }

  /* About visual */
  .about-visual-bright { margin-top:1.5rem; }
  .about-stat-chips { grid-template-columns:1fr 1fr !important; }

  /* Text */
  .section-header h2 { font-size:clamp(1.5rem,5vw,2rem) !important; }
}

/* ══ BREAKPOINT: Small phones (max 480px) ══════════════════════ */
@media (max-width:480px) {
  html { font-size:14px; }

  .logo-text { display:none; }
  .hero-title { font-size:clamp(1.5rem,7vw,2rem) !important; }
  .hero-image img { max-width:200px !important; }
  .compliance-bar { display:none !important; }

  .stats-grid { grid-template-columns:1fr 1fr !important; }
  .stat-item h3 { font-size:1.8rem !important; }

  .team-values { grid-template-columns:1fr !important; }
  .footer-grid, .grid.grid-4 { grid-template-columns:1fr !important; }
  .steps-grid { grid-template-columns:1fr !important; }
  .about-stat-chips { grid-template-columns:1fr 1fr !important; }

  /* Specific product page fixes */
  .doc-types, .icd-feature-grid, .specialty-list { grid-template-columns:1fr !important; }

  .btn-large { font-size:0.95rem; padding:0.7rem 1rem; }
  h1 { font-size:clamp(1.6rem,7vw,2.2rem) !important; }
  h2 { font-size:clamp(1.3rem,5.5vw,1.8rem) !important; }
}

/* ═══ COMPLIANCE BADGES — REDESIGNED & FULLY RESPONSIVE ════════════ */
.compliance-section {
  background: #fff;
  border-top: 1px solid #e8f0fe;
  border-bottom: 1px solid #e8f0fe;
  padding: 2rem 1.5rem;
  text-align: center;
  margin-top: 2.5rem;
}
.compliance-title {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 1.25rem;
}
.compliance-cards {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  gap: 0.75rem;
  max-width: 900px;
  margin: 0 auto;
}
.comp-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  background: #f8faff;
  border: 1px solid #d4e2ff;
  border-radius: 12px;
  padding: 0.9rem 1.25rem;
  min-width: 120px;
  flex: 1 1 120px;
  max-width: 160px;
  transition: box-shadow 0.2s, transform 0.2s;
}
.comp-badge:hover {
  box-shadow: 0 6px 20px rgba(0,98,255,0.1);
  transform: translateY(-2px);
}
.comp-badge i {
  font-size: 1.5rem;
  color: var(--secondary);
  margin-bottom: 0.2rem;
}
.comp-name {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--primary);
  white-space: nowrap;
}
.comp-desc {
  font-size: 0.7rem;
  color: var(--text-muted);
  white-space: nowrap;
}

/* ── Remove old compliance-bar display:none at mobile — new section shows always ── */
@media (max-width: 768px) {
  .compliance-section { padding: 1.5rem 1rem; margin-top: 1.5rem; }
  .compliance-cards { gap: 0.5rem; }
  .comp-badge { min-width: 90px; max-width: 140px; padding: 0.75rem 0.8rem; flex: 1 1 90px; }
  .comp-badge i { font-size: 1.2rem; }
  .comp-name { font-size: 0.75rem; }
  .comp-desc { display: none; }
}
@media (max-width: 480px) {
  .compliance-cards { gap: 0.4rem; }
  .comp-badge { min-width: 80px; flex: 1 1 80px; padding: 0.6rem; }
  .comp-badge i { font-size: 1.1rem; }
  .comp-name { font-size: 0.7rem; }
}

/* ════════════════════════════════════════════════════════════════
   EMEDLOGIX — PREMIUM DESIGN SYSTEM UPGRADE
   Professional, trending, high-impact styles
════════════════════════════════════════════════════════════════ */

/* ── Ultra-wide monitor support (1400px+) ── */
@media (min-width: 1400px) {
  .container { max-width: 1320px; }
  .hero-title { font-size: 3.8rem; }
  .hero-grid  { gap: 5rem; }
}
@media (min-width: 1600px) {
  .container { max-width: 1480px; }
}

/* ── Fluid heading scale — scoped, does NOT override .hero-title ── */
.section-header h2 { font-size: clamp(1.6rem, 3vw, 2.5rem); line-height: 1.2; }
.page-hero h1      { font-size: clamp(2rem, 4vw, 3.2rem);   line-height: 1.15; }

/* ════════════ PREMIUM BUTTON SYSTEM ════════════ */

/* 1. Shimmer CTA — primary gradient with animated sheen */
.btn-shimmer {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 0.85rem 2rem; border-radius: 50px;
  background: linear-gradient(135deg, #2C3590 0%, #0062ff 50%, #2C3590 100%);
  background-size: 200% auto;
  color: #fff; font-weight: 700; font-size: 0.97rem;
  font-family: 'Poppins', sans-serif;
  text-decoration: none; border: none; cursor: pointer;
  transition: background-position 0.5s ease, transform 0.2s, box-shadow 0.2s;
  box-shadow: 0 6px 24px rgba(0,98,255,0.35);
  position: relative; overflow: hidden;
  white-space: nowrap;
}
.btn-shimmer::before {
  content: '';
  position: absolute; top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transition: left 0.5s ease;
}
.btn-shimmer:hover { background-position: right center; transform: translateY(-2px); box-shadow: 0 10px 32px rgba(0,98,255,0.45); }
.btn-shimmer:hover::before { left: 160%; }

/* 2. Glow Outline — transparent with animated glow border */
.btn-glow {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 0.82rem 2rem; border-radius: 50px;
  background: transparent;
  border: 2px solid var(--secondary);
  color: var(--secondary); font-weight: 700; font-size: 0.97rem;
  font-family: 'Poppins', sans-serif;
  text-decoration: none; cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 0 0 rgba(0,98,255,0);
  white-space: nowrap;
}
.btn-glow:hover {
  background: var(--secondary); color: #fff;
  box-shadow: 0 0 20px rgba(0,98,255,0.4), 0 4px 16px rgba(0,98,255,0.25);
  transform: translateY(-2px);
}

/* 3. Pill Chip button — smaller, tag-style */
.btn-pill {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.45rem 1rem; border-radius: 50px;
  background: #e8f0fe; color: var(--secondary);
  font-size: 0.8rem; font-weight: 700; letter-spacing: 0.04em;
  text-decoration: none; cursor: pointer; border: 1px solid #d4e2ff;
  transition: all 0.2s; white-space: nowrap;
}
.btn-pill:hover { background: var(--secondary); color: #fff; border-color: var(--secondary); }

/* 4. Icon-pulse — solid with bouncing arrow icon */
.btn-icon-pulse {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.7rem;
  padding: 0.85rem 2rem; border-radius: 12px;
  background: var(--secondary); color: #fff;
  font-weight: 700; font-size: 0.97rem; font-family: 'Poppins', sans-serif;
  text-decoration: none; cursor: pointer; border: none;
  transition: transform 0.2s, box-shadow 0.2s;
  box-shadow: 0 4px 18px rgba(0,98,255,0.3);
  white-space: nowrap;
}
.btn-icon-pulse i { animation: pulse-arrow 1.4s ease infinite; }
@keyframes pulse-arrow {
  0%, 100% { transform: translateX(0); }
  50%       { transform: translateX(4px); }
}
.btn-icon-pulse:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,98,255,0.4); }

/* 5. Golden accent — for DUNS/compliance highlight CTAs */
.btn-gold {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 0.82rem 2rem; border-radius: 50px;
  background: linear-gradient(135deg, #F5A300, #e08c00);
  color: #fff; font-weight: 700; font-size: 0.97rem;
  font-family: 'Poppins', sans-serif;
  text-decoration: none; cursor: pointer; border: none;
  box-shadow: 0 6px 20px rgba(245,163,0,0.35);
  transition: transform 0.2s, box-shadow 0.2s;
  white-space: nowrap;
}
.btn-gold:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(245,163,0,0.5); }

/* ════════ KEYWORD / TAG CHIP SYSTEM ════════ */
.kw-chips {
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  margin: 1.2rem 0;
}
.kw-chip {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 1.1rem; border-radius: 50px;
  background: var(--white); border: 1px solid rgba(0,98,255,0.25);
  color: var(--primary); font-size: 0.82rem; font-weight: 700;
  box-shadow: var(--shadow-sm);
  transition: var(--trans-smooth);
}
.kw-chip:hover {
    background: var(--accent);
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
}
.kw-chip i { font-size: 0.65rem; color: var(--secondary); }

/* ════════ GLASSMORPHISM CARD ════════ */
.card-glass {
  background: rgba(255,255,255,0.65);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid rgba(255,255,255,0.45);
  border-radius: var(--radius-lg);
  padding: 2.25rem;
  box-shadow: 0 8px 32px rgba(31,38,135,0.08);
  transition: transform 0.3s, box-shadow 0.3s;
}
.card-glass:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(0,98,255,0.12); }

/* ════════ TRUST BADGE ROW ════════ */
.trust-row {
  display: grid; grid-template-columns: max-content max-content; align-items: center;
  justify-content: flex-start; gap: 0.8rem 1.5rem;
  padding: 1.5rem 0; margin-top: 1rem;
}
.trust-item {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.82rem; font-weight: 600; color: var(--text-muted);
}
.trust-item i { color: var(--secondary); font-size: 1rem; }

/* ════════ SECTION — KEY TERM HIGHLIGHT ════════ */
.highlight-box {
  background: linear-gradient(135deg, #f0f4ff, #e8f0fe);
  border-left: 4px solid var(--secondary);
  border-radius: 0 12px 12px 0;
  padding: 1.25rem 1.5rem; margin: 1.5rem 0;
  font-size: 1rem; line-height: 1.7; color: var(--dark);
}
.highlight-box strong { color: var(--secondary); }

/* ════════ SECTION WAVE DIVIDER ════════ */
.wave-divider { width: 100%; overflow: hidden; line-height: 0; }
.wave-divider svg { display: block; width: 100%; }

/* ════════ ANIMATED COUNTER ════════ */
.stat-counter { font-variant-numeric: tabular-nums; }

/* ════════ BUTTON MOBILE FIXES ════════ */
@media (max-width: 768px) {
  .btn-shimmer, .btn-glow, .btn-icon-pulse, .btn-gold {
    padding: 0.8rem 1.5rem; font-size: 0.92rem; width: 100%; max-width: 320px;
    justify-content: center;
  }
  .kw-chips { gap: 0.35rem; justify-content: center; }
  .kw-chip  { font-size: 0.72rem; padding: 0.25rem 0.65rem; }
  .trust-row { gap: 1rem; justify-content: center; grid-template-columns: max-content max-content; }
  .trust-item { font-size: 0.76rem; }
}
@media (max-width: 480px) {
  .btn-shimmer, .btn-glow, .btn-icon-pulse { font-size: 0.88rem; padding: 0.75rem 1.2rem; }
  .trust-row { grid-template-columns: 1fr; justify-content: center; gap: 0.75rem; }
  .trust-item { justify-content: center; }
}

/* -------- PROACTIVE GLOBAL CARD ALIGNMENT FIX -------- */
.card, .feat-card, .testimonial-card, .wf-card, .value-card, .ripe-card, .price-card {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    height: 100% !important;
}

/* Ensure buttons, images, or specific bottom elements get pushed to the bottom cleanly */
.card > img.card-image-bottom, 
.feat-card > img, 
.wf-card > .wf-image, 
.card > .ops-badge, 
.card > .perf-chips,
.card-highlight > img,
.card-highlight > .perf-chips,
.btn-container,
.mt-auto {
    margin-top: auto !important;
}

/* ══ FLOATING SCROLL BUTTON ═════════════════════════════════════════ */
.scroll-arrow-btn {
  position: fixed;
  bottom: 2rem;
  left: 2rem;
  width: 50px;
  height: 50px;
  background: var(--secondary);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  box-shadow: 0 4px 15px rgba(245, 166, 35, 0.5);
  cursor: pointer;
  z-index: 10000;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: all 0.3s ease;
  animation: bounceScroller 2s infinite ease-in-out;
}
.scroll-arrow-btn.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.scroll-arrow-btn:hover {
  background: var(--primary);
  transform: translateY(-5px) scale(1.05);
  box-shadow: 0 8px 25px rgba(37, 99, 235, 0.5);
  animation-play-state: paused;
}
@keyframes bounceScroller {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}
@media (max-width: 768px) {
  .scroll-arrow-btn {
    bottom: 1.5rem;
    left: 1.5rem;
    width: 45px;
    height: 45px;
    font-size: 1.2rem;
  }
}

/* ═══════════════════════════════════════════════════════════════
   FINAL MOBILE-FIRST POLISH — v5.1
   Ensures every page, every element, every breakpoint is clean
═══════════════════════════════════════════════════════════════ */

/* ── Header Login Button (visible on desktop, hidden on mobile) ── */
.header-login-btn {
  border-color: var(--primary) !important;
  color: var(--primary) !important;
  background: transparent !important;
}
.header-login-btn:hover {
  background: var(--primary) !important;
  color: var(--white) !important;
}

/* ── Specialty hero cards (CPT page) ── */
@media (max-width: 768px) {
  .specialty-hero {
    flex-direction: column !important;
    min-height: auto !important;
  }
  .specialty-visual {
    width: 100% !important;
    height: 120px !important;
    font-size: 4rem !important;
  }
  .specialty-info {
    padding: 2rem 1.5rem !important;
  }
  .cpt-grid { grid-template-columns: 1fr !important; }
  .cpt-dash-inner { grid-template-columns: 1fr !important; }
  .donut-grid { grid-template-columns: 1fr 1fr !important; }
}

/* ── ICD page grids ── */
@media (max-width: 768px) {
  .icd-hero-grid { grid-template-columns: 1fr !important; }
  .icd-feature-grid { grid-template-columns: 1fr !important; }
  .specialty-list { grid-template-columns: 1fr !important; }
  .doc-types { grid-template-columns: 1fr 1fr !important; }
}

/* ── HCC dashboard (3-col → 1-col) ── */
@media (max-width: 900px) {
  .hcc-dash-grid { grid-template-columns: 1fr !important; }
}
@media (max-width: 768px) {
  .hcc-grid { grid-template-columns: 1fr !important; }
  .impact-grid { grid-template-columns: 1fr 1fr !important; }
  .bar-label { min-width: 80px !important; font-size: .78rem !important; }
}

/* ── OCR page visual stacking ── */
@media (max-width: 768px) {
  .ocr-section { flex-direction: column !important; gap: 1.5rem !important; }
  .ocr-visual { padding: 1.5rem !important; }
}

/* ── Chase/RIPE page ── */
@media (max-width: 768px) {
  .chase-hero-grid { grid-template-columns: 1fr !important; }
  .interop-cards { grid-template-columns: 1fr !important; }
  .ripe-grid { grid-template-columns: 1fr !important; }
  .feat-grid { grid-template-columns: 1fr !important; }
}

/* ── Contact form full-width on small screens ── */
@media (max-width: 768px) {
  .contact-layout { grid-template-columns: 1fr !important; }
  .form-grid { grid-template-columns: 1fr !important; }
  .form-group.full { grid-column: span 1 !important; }
  .contact-form-panel { padding: 1.75rem 1rem !important; }
}

/* ── About page improvements ── */
@media (max-width: 768px) {
  .about-grid { grid-template-columns: 1fr !important; }
  .locations { grid-template-columns: 1fr !important; }
  .team-values { grid-template-columns: 1fr 1fr !important; }
}

/* ── Workflow page ── */
@media (max-width: 768px) {
  .workflow-cards { grid-template-columns: 1fr !important; }
  .wf-step { grid-template-columns: 1fr !important; }
  .step-features { grid-template-columns: 1fr !important; }
}

/* ── Login page ── */
@media (max-width: 768px) {
  .login-grid { grid-template-columns: 1fr !important; }
  .login-promo { display: none !important; }
}

/* ── Global touch targets — all interactive elements min 44px ── */
a, button, .btn, input, select, textarea, .nav-link, .kw-chip {
  -webkit-tap-highlight-color: rgba(0,98,255,0.1);
}
input, select, textarea {
  font-size: 16px !important; /* Prevent iOS zoom on focus */
}

/* ── Safe area support (iPhone notch/home indicator) ── */
@supports (padding: env(safe-area-inset-bottom)) {
  .footer { padding-bottom: calc(2rem + env(safe-area-inset-bottom)); }
  .scroll-arrow-btn { bottom: calc(1.5rem + env(safe-area-inset-bottom)); }
  #emli-toggle { bottom: calc(1.5rem + env(safe-area-inset-bottom)); }
}

/* ── Prevent horizontal scroll on all devices ── */
html, body { max-width: 100%; overflow-x: hidden; }

/* ── Smooth image scaling on retina ── */
img { image-rendering: -webkit-optimize-contrast; }

/* ── Print styles — basic clean print ── */
@media print {
  .header, .footer, .scroll-arrow-btn, #emli-toggle, #emli-window { display: none !important; }
  body { color: #000 !important; background: #fff !important; }
  a { color: #000 !important; text-decoration: underline !important; }
}
