/* ============================================================
   IdentiGate — main.css
   Hand-crafted stylesheet. Tailwind-free.

   This file is the long-term target for the Tailwind migration.
   styles.css (compiled Tailwind) stays active while pages are
   migrated component by component. When a component moves here
   its utility classes are removed from the HTML and it no longer
   needs to be in the Tailwind build.

   Migration phases:
     Phase 1  ✓  Design tokens + base + blog prose
     Phase 2  ✓  All custom components (.banner, .nav, .ig-dot, .product-card,
                  .why-section, .timeline, .foundations, .expandable,
                  .section-title, .feature-list, .icon-grid)
     Phase 3      Replace per-page utility classes with semantic classes
     Phase 4      Drop Tailwind entirely
   ============================================================ */


/* ============================================================
   DESIGN TOKENS
   ============================================================ */

:root {

  /* --- Brand Colors --- */
  --color-brand-green:        #013C39;
  --color-brand-green-light:  #0F6457;
  --color-brand-dark:         #002E2B;
  --color-brand-orange:       #F97316;

  /* --- Extended Palette (component-specific, distinct from brand tokens) --- */
  --color-orange-400:      #fb923c;           /* Tailwind orange-400 — product card badges/checks    */
  --color-green-500:       #22c55e;           /* Tailwind green-500  — product card badges/checks    */
  --color-green-600:       #16a34a;           /* Tailwind green-600  — timeline numbers, foundation  */
  --color-orange-tint-35:  rgba(249,115,22,0.35); /* Semi-transparent orange — card borders, dividers */
  --color-orange-tint-65:  rgba(249,115,22,0.65); /* More opaque orange — vertical rule accents       */

  /* --- Neutral Palette (matches Tailwind gray-* used on site) --- */
  --color-white:    #ffffff;
  --color-gray-50:  #f9fafb;
  --color-gray-100: #f3f4f6;
  --color-gray-200: #e5e7eb;
  --color-gray-300: #d1d5db;
  --color-gray-500: #6b7280;
  --color-gray-600: #4b5563;
  --color-gray-700: #374151;
  --color-gray-800: #1f2937;
  --color-gray-900: #111827;

  /* --- Typography Scale --- */
  --text-xs:   0.75rem;   /*  12px */
  --text-sm:   0.875rem;  /*  14px */
  --text-base: 1rem;      /*  16px */
  --text-lg:   1.125rem;  /*  18px */
  --text-xl:   1.25rem;   /*  20px */
  --text-2xl:  1.5rem;    /*  24px */
  --text-3xl:  1.875rem;  /*  30px */
  --text-4xl:  2.25rem;   /*  36px */
  --text-5xl:  3rem;      /*  48px */

  /* --- Font Weights --- */
  --weight-normal:   400;
  --weight-medium:   500;
  --weight-semibold: 600;
  --weight-bold:     700;

  /* --- Line Heights --- */
  --leading-tight:   1.25;
  --leading-snug:    1.375;
  --leading-normal:  1.5;
  --leading-relaxed: 1.625;

  /* --- Spacing (base-4 rhythm, aligned to Tailwind scale) --- */
  --space-1:  0.25rem;  /*  4px */
  --space-2:  0.5rem;   /*  8px */
  --space-3:  0.75rem;  /* 12px */
  --space-4:  1rem;     /* 16px */
  --space-6:  1.5rem;   /* 24px */
  --space-8:  2rem;     /* 32px */
  --space-10: 2.5rem;   /* 40px */
  --space-12: 3rem;     /* 48px */
  --space-16: 4rem;     /* 64px */
  --space-20: 5rem;     /* 80px */
  --space-24: 6rem;     /* 96px */

  /* --- Border Radius --- */
  --radius-sm:   0.25rem;  /*  4px */
  --radius-md:   0.375rem; /*  6px */
  --radius-lg:   0.5rem;   /*  8px */
  --radius-xl:   0.75rem;  /* 12px */
  --radius-2xl:  1rem;     /* 16px */
  --radius-full: 9999px;

  /* --- Shadows --- */
  --shadow-sm:  0 1px 2px 0 rgba(0,0,0,0.05);
  --shadow:     0 1px 3px 0 rgba(0,0,0,0.1), 0 1px 2px -1px rgba(0,0,0,0.1);
  --shadow-md:  0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -2px rgba(0,0,0,0.1);
  --shadow-lg:  0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -4px rgba(0,0,0,0.1);
  --shadow-xl:  0 20px 25px -5px rgba(0,0,0,0.1), 0 8px 10px -6px rgba(0,0,0,0.1);
  --shadow-2xl: 0 25px 50px -12px rgba(0,0,0,0.25);

  /* --- Layout --- */
  --content-max-width: 80rem;   /* 1280px — Tailwind max-w-7xl */
  --content-padding-x: 1.5rem;  /*   24px — Tailwind px-6      */

  /* --- Header --- */
  --header-height: 68px;

  /* --- Transitions --- */
  --transition-fast: all 0.15s ease;
  --transition-base: all 0.2s ease;
  --transition-slow: all 0.3s ease;

  /* ═══════════════════════════════════════════════════════════
     BANNER SYSTEM TOKENS
     Mirrors the banner variables compiled into styles.css so
     banner components can be migrated with no visual change.
  ═══════════════════════════════════════════════════════════ */

  --banner-bg:              #096a5f;
  --banner-text:            #ffffff;
  --banner-text-muted:      rgba(255,255,255,0.9);

  --banner-btn-bg:          #ffffff;
  --banner-btn-text:        #2A9D8F;
  --banner-btn-hover-bg:    #f3f4f6;

  --banner-heading-size:    clamp(1.875rem, 4vw, 2.25rem);
  --banner-heading-weight:  700;
  --banner-subtitle-size:   clamp(1.25rem, 2.5vw, 1.5rem);
  --banner-subtitle-weight: 600;
  --banner-btn-size:        1.125rem;
  --banner-btn-weight:      600;

  --banner-padding-y:       3.5rem;
  --banner-padding-y-cta:   5rem;
  --banner-padding-x:       1.5rem;
  --banner-max-width:       80rem;
  --banner-subtitle-gap:    1rem;
  --banner-btn-gap:         2.5rem;
  --banner-btn-spacing:     1.5rem;

  --banner-btn-padding-x:   2rem;
  --banner-btn-padding-y:   0.75rem;
  --banner-btn-radius:      0.5rem;
  --banner-btn-shadow:      0 1px 3px rgba(0,0,0,0.1);

  --banner-transition:      all 0.2s ease;

  /* ═══════════════════════════════════════════════════════════
     V2 DESIGN TOKENS  (short names — DM Sans / beige palette)
     Reference: identigate_website_v2-44.html
  ═══════════════════════════════════════════════════════════ */

  --f:   #1B3A2D;   /* forest green        — primary brand  */
  --fl:  #2A5A43;   /* forest green light  — hover / accents */
  --fd:  #122A1F;   /* forest green dark   */
  --b:   #F5F0EB;   /* beige               — page background */
  --bd:  #E8E0D8;   /* beige dark          — borders        */
  --o:   #E8811A;   /* orange              — accent / CTA   */
  --ol:  #F09A3E;   /* orange light        — hover          */
  --w:   #FFFFFF;   /* white               */
  --td:  #1A1A1A;   /* text dark           */
  --tm:  #4A4A4A;   /* text medium         */
  --tl:  #7A7A7A;   /* text light / muted  */
  --red: #E84B4B;   /* red                 — error / warning */
}


/* ============================================================
   BASE
   ============================================================ */

html {
  scroll-behavior: smooth;
}

/* Fixed header — dynamically loaded into #header-placeholder */
#header-placeholder {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: rgba(245,240,235,0.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(27,58,45,0.06);
  min-height: var(--header-height);
}

/* Push body content below the fixed header */
body {
  padding-top: var(--header-height);
  font-family: 'DM Sans', sans-serif;
  background: var(--b);
  color: var(--td);
  -webkit-font-smoothing: antialiased;
}

/* First content section after nav: reduce top padding (body already has 68px) */
#header-placeholder + section:not(.hero) {
  padding-top: 3rem !important;
}

/* Anchor targets scroll into view clear of the fixed header */
[id] {
  scroll-margin-top: var(--header-height);
}


/* ============================================================
   LAYOUT PRIMITIVES
   Reusable semantic classes replacing the most common Tailwind
   utility combinations. These cover ~80% of repeated patterns.
   ============================================================ */

/* --- Section wrappers --- */
.section {
  width: 100%;
  padding-top: var(--space-20);
  padding-bottom: var(--space-20);
  background-color: var(--color-white);
}

.section--light {
  background-color: var(--color-gray-50);
}

.section--muted {
  background-color: var(--color-gray-100);
}

.section--hero {
  width: 100%;
  /* Pull section up to fill the white body padding-top gap beneath the fixed header */
  margin-top: calc(-1 * var(--header-height));
  padding-top: calc(var(--space-16) + var(--header-height));
  padding-bottom: var(--space-16);
  background-color: var(--color-gray-50);
}

.section--pale {
  background-color: var(--color-gray-200);
}

/* --- Inner containers --- */
.container {
  max-width: var(--content-max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--content-padding-x);
  padding-right: var(--content-padding-x);
}

.container--narrow {
  max-width: 64rem; /* 1024px — max-w-5xl */
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--content-padding-x);
  padding-right: var(--content-padding-x);
}

/* --- Heading hierarchy --- */
.heading-hero {
  font-size: var(--text-4xl);
  font-weight: var(--weight-bold);
  color: var(--color-gray-900);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-6);
}

@media (min-width: 768px) {
  .heading-hero {
    font-size: var(--text-5xl);
  }
}

.heading-section {
  font-size: var(--text-3xl);
  font-weight: var(--weight-bold);
  color: var(--color-gray-900);
  line-height: var(--leading-tight);
}

@media (min-width: 768px) {
  .heading-section {
    font-size: var(--text-4xl);
  }
}

.heading-sub {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--color-brand-dark);
  line-height: var(--leading-snug);
}

@media (min-width: 768px) {
  .heading-sub {
    font-size: var(--text-3xl);
  }
}

.heading-card {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-gray-900);
  line-height: var(--leading-snug);
}

/* --- Body text --- */
.body-text {
  color: var(--color-gray-700);
  line-height: var(--leading-relaxed);
}

/* --- Cards --- */
.card {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
}

.card--hover {
  transition: var(--transition-slow);
}

.card--hover:hover {
  box-shadow: var(--shadow-lg);
}

/* --- Buttons --- */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 2.5rem;
  border-radius: var(--radius-md);
  background-color: var(--color-brand-green-light);
  color: var(--color-white);
  font-weight: var(--weight-semibold);
  font-size: var(--text-base);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  transition: var(--transition-base);
  cursor: pointer;
  border: none;
}

.btn-primary:hover {
  background-color: var(--color-brand-green);
}

.btn-primary--sm {
  padding: 0.5rem 1rem;
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
}

.btn-primary--lg {
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-lg);
  font-size: var(--text-lg);
}

/* --- Grid layouts --- */
.col-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
}

@media (min-width: 768px) {
  .col-2 {
    grid-template-columns: 1fr 1fr;
  }
}

.col-3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 768px) {
  .col-3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* col-2 variant: narrower gap (gap-6) — used in hero sections */
.col-2--hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: center;
}

@media (min-width: 768px) {
  .col-2--hero {
    grid-template-columns: 1fr 1fr;
  }
}

/* col-2 variant: wider gap (gap-16) — used in use case / wide layouts */
.col-2--wide {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-16);
  align-items: center;
}

@media (min-width: 768px) {
  .col-2--wide {
    grid-template-columns: 1fr 1fr;
  }
}

/* col-2 variant: align items to start instead of center */
.col-2--start {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: start;
}

@media (min-width: 768px) {
  .col-2--start {
    grid-template-columns: 1fr 1fr;
  }
}

/* col-2 variant: breaks at lg (1024px) instead of md — product pages */
.col-2--lg {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
}

@media (min-width: 1024px) {
  .col-2--lg {
    grid-template-columns: 1fr 1fr;
  }
}

/* --- Feature card (lighter than .card — rounded-lg, hover shadow) --- */
.feature-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-base);
}

.feature-card:hover {
  box-shadow: var(--shadow-md);
}

/* --- Section note (bottom-of-section blockquote accent) --- */
/* Usage: <div class="section-note"><div class="section-note__inner">
           <div class="section-note__bar"></div>
           <p class="section-note__text">...</p></div></div> */
.section-note {
  margin-top: var(--space-20);
  display: flex;
  justify-content: center;
  padding-left: var(--space-8);
  padding-right: var(--space-8);
}

.section-note__inner {
  max-width: 42rem;
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.section-note__bar {
  flex-shrink: 0;
  width: 0.25rem;
  background-color: var(--color-orange-tint-65);
  border-radius: var(--radius-full);
  align-self: stretch;
}

.section-note__text {
  font-style: italic;
  color: var(--color-gray-700);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

/* --- Hero subtitle text --- */
.text-intro {
  font-size: var(--text-xl);
  color: var(--color-gray-700);
  line-height: var(--leading-relaxed);
}

@media (min-width: 768px) {
  .text-intro {
    font-size: var(--text-2xl);
  }
}

/* --- Responsive image base --- */
/* Keep max-w-* alongside as needed: <img class="img-fluid max-w-lg"> */
.img-fluid {
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* --- Semi-transparent white backgrounds (replace Tailwind slash opacity) --- */
/* Replaces bg-white/80 */
.bg-white-80 {
  background-color: rgba(255, 255, 255, 0.8);
}

/* Replaces bg-white/90 */
.bg-white-90 {
  background-color: rgba(255, 255, 255, 0.9);
}

/* --- Orange tint helpers (replace Tailwind arbitrary values) --- */
/* Replaces border-[rgb(249,115,22,0.35)] */
.border-orange-tint {
  border-color: var(--color-orange-tint-35);
}

/* Replaces bg-[rgb(249,115,22,0.65)] */
.bg-orange-accent {
  background-color: var(--color-orange-tint-65);
}


/* ============================================================
   ANIMATIONS
   ============================================================ */

@keyframes scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ============================================================
   INDUSTRY SCROLLER
   Migrated from src/input.css. Used in: industries.html
   ============================================================ */

.scroller:hover {
  animation-play-state: paused;
}

.fade-left {
  position: absolute;
  left: 0;
  width: 80px;
  top: 0;
  bottom: 0;
  background: linear-gradient(to right, #f3f4f6, transparent);
}

.fade-right {
  position: absolute;
  right: 0;
  width: 80px;
  top: 0;
  bottom: 0;
  background: linear-gradient(to left, #f3f4f6, transparent);
}


/* ============================================================
   BLOG PROSE
   Migrated from the inline <style> block in blog-layout.njk.
   Once this file is linked, that block can be removed.
   ============================================================ */

.blog-prose h2 {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--color-gray-800);
  margin-top: 2.5rem;
  margin-bottom: 1rem;
}

.blog-prose h3 {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-gray-800);
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}

.blog-prose p {
  color: var(--color-gray-700);
  line-height: 1.75;
  margin-bottom: 1.25rem;
}

.blog-prose ul,
.blog-prose ol {
  color: var(--color-gray-700);
  line-height: 1.75;
  margin-bottom: 1.25rem;
  padding-left: 1.5rem;
}

.blog-prose ul { list-style-type: disc; }
.blog-prose ol { list-style-type: decimal; }

.blog-prose li {
  margin-bottom: 0.5rem;
}

.blog-prose a {
  color: var(--color-brand-green-light);
  text-decoration: underline;
}

.blog-prose a:hover {
  color: var(--color-brand-orange);
}

.blog-prose blockquote {
  border-left: 4px solid var(--color-brand-orange);
  padding-left: 1.25rem;
  margin: 1.5rem 0;
  color: var(--color-gray-600);
  font-style: italic;
}

.blog-prose code {
  background-color: var(--color-gray-100);
  padding: 0.15rem 0.4rem;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}

.blog-prose pre {
  background-color: var(--color-gray-800);
  color: var(--color-gray-200);
  padding: 1.25rem;
  border-radius: var(--radius-lg);
  overflow-x: auto;
  margin-bottom: 1.5rem;
}

.blog-prose pre code {
  background: none;
  padding: 0;
  color: inherit;
}

.blog-prose img {
  border-radius: var(--radius-lg);
  margin: 1.5rem 0;
}


/* ============================================================
   BANNER COMPONENT SYSTEM
   Migrated from src/input.css (@apply → plain CSS).
   Tokens are defined in :root above — change once, updates all.

   Usage:
     <section class="banner">          standard banner
     <section class="banner banner--cta">   extra vertical padding
   ============================================================ */

.banner {
  width: 100%;
  background-color: var(--banner-bg);
  padding-top: var(--banner-padding-y);
  padding-bottom: var(--banner-padding-y);
}

.banner--cta {
  padding-top: var(--banner-padding-y-cta);
  padding-bottom: var(--banner-padding-y-cta);
}

.banner__container {
  max-width: var(--banner-max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--banner-padding-x);
  padding-right: var(--banner-padding-x);
  text-align: center;
}

.banner__heading {
  color: var(--banner-text);
  font-size: var(--banner-heading-size);
  font-weight: var(--banner-heading-weight);
  line-height: var(--leading-tight);
  margin: 0;
  white-space: pre-line;
}

.banner__subtitle {
  color: var(--banner-text-muted);
  font-size: var(--banner-subtitle-size);
  font-weight: var(--banner-subtitle-weight);
  line-height: var(--leading-snug);
  margin-top: var(--banner-subtitle-gap);
}

.banner__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--banner-btn-spacing);
  margin-top: var(--banner-btn-gap);
}

@media (min-width: 640px) {
  .banner__actions {
    flex-direction: row;
  }
}

.banner__btn {
  display: inline-block;
  text-decoration: none;
  cursor: pointer;
  border: none;
  background-color: var(--banner-btn-bg);
  color: var(--banner-btn-text);
  font-size: var(--banner-btn-size);
  font-weight: var(--banner-btn-weight);
  padding: var(--banner-btn-padding-y) var(--banner-btn-padding-x);
  border-radius: var(--banner-btn-radius);
  box-shadow: var(--banner-btn-shadow);
  transition: var(--banner-transition);
}

.banner__btn:hover {
  background-color: var(--banner-btn-hover-bg);
}

/* Outline variant — not yet used in templates, kept for completeness */
.banner__btn--outline {
  background-color: transparent;
  border: 2px solid var(--banner-text);
  color: var(--banner-text);
  box-shadow: none;
}

.banner__btn--outline:hover {
  background-color: var(--banner-text);
  color: var(--banner-bg);
}


/* ============================================================
   IG-DOT BULLET LIST
   Migrated from src/input.css.
   ============================================================ */

.ig-dot-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.ig-dot-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.ig-dot {
  width: 0.5rem;
  height: 0.5rem;
  background-color: var(--color-brand-orange);
  border-radius: var(--radius-full);
  margin-top: 0.60em;
  flex-shrink: 0;
}

.ig-dot-lg {
  width: 0.8rem;
  height: 0.8rem;
  background-color: var(--color-brand-orange);
  border-radius: var(--radius-full);
  margin-top: 0.67em;
  flex-shrink: 0;
}

.ig-dot-text {
  color: var(--color-gray-700);
  line-height: var(--leading-relaxed);
}


/* ============================================================
   NAVIGATION
   Migrated from src/input.css. No @apply was used — this is a
   straight move out of @layer components into main.css.
   ============================================================ */

.nav-link {
  display: inline-flex;
  align-items: center;
  color: var(--color-gray-700);
  transition: var(--transition-base);
  padding: 0.5rem 0;
}

.nav-link:hover {
  color: var(--color-brand-green-light);
}

.nav-link.is-active {
  color: var(--color-brand-orange);
  font-weight: var(--weight-medium);
}

/* Always reserve padding/dimensions so active state doesn't shift layout */
.nav-text {
  position: relative;
  padding: 0.25rem 0.75rem;
  display: inline-block;
  flex-shrink: 0;
  min-width: 1px;
  white-space: nowrap;
}

.nav-link.is-active .nav-text::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-brand-orange);
  pointer-events: none;
}

/* Dropdown */

.nav-dropdown {
  position: relative;
}

.nav-dropdown__trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.nav-dropdown__arrow {
  transition: transform 0.2s ease;
}

.nav-dropdown:hover .nav-dropdown__arrow {
  transform: rotate(180deg);
}

.nav-dropdown__menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  min-width: 200px;
  background-color: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  padding: 0.5rem 0;
  margin-top: 0.5rem;
  z-index: 100;
}

.nav-dropdown:hover .nav-dropdown__menu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.nav-dropdown__item {
  display: block;
  padding: 0.625rem 1.25rem;
  color: var(--color-gray-700);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  transition: background-color 0.15s ease, color 0.15s ease;
  white-space: nowrap;
}

.nav-dropdown__item:hover {
  background-color: var(--color-gray-50);
  color: var(--color-brand-orange);
}


/* ============================================================
   PRODUCT CARD SYSTEM
   Migrated from src/input.css (@apply → plain CSS).
   Used in: private-label/components/branded-identity.html
   ============================================================ */

.products-section {
  width: 100%;
  padding-top: var(--space-20);
  padding-bottom: var(--space-20);
  padding-left: var(--space-6);
  padding-right: var(--space-6);
}

.products-section__title {
  text-align: center;
  margin-bottom: var(--space-16);
  margin-left: auto;
  margin-right: auto;
  color: var(--color-gray-800);
  max-width: 72rem;
  font-family: Arial, sans-serif;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 400;
  letter-spacing: -0.02em;
}

.products-section__cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--space-8);
  padding-top: var(--space-6);
  max-width: 72rem;
  margin-left: auto;
  margin-right: auto;
}

.product-card {
  position: relative;
  background-color: var(--color-white);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-lg);
  transition: all 0.3s ease;
  padding: 50px 36px 40px;
}

.product-card:hover {
  box-shadow: var(--shadow-2xl);
  transform: translateY(-4px);
}

.product-card__badge {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  padding: 0.75rem 1.75rem;
  border-radius: var(--radius-full);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--color-white);
  white-space: nowrap;
}

.product-card__badge--orange { background-color: var(--color-orange-400); }
.product-card__badge--green  { background-color: var(--color-green-500); }

.product-card__description {
  color: var(--color-gray-600);
  margin-bottom: 1.75rem;
  line-height: var(--leading-relaxed);
  font-size: 1.05rem;
}

.product-card__features {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  list-style: none;
  padding: 0;
  margin: 0;
}

.product-card__feature {
  display: flex;
  align-items: flex-start;
  gap: 0.875rem;
  color: var(--color-gray-800);
}

.product-card__check {
  flex-shrink: 0;
  margin-top: 0.125rem;
  width: 22px;
  height: 22px;
}

.product-card__check--orange { color: var(--color-orange-400); }
.product-card__check--green  { color: var(--color-green-500); }

.product-card__divider {
  width: 100%;
  height: 1px;
  margin-top: var(--space-6);
  margin-bottom: var(--space-4);
}

.product-card__divider--orange { background-color: var(--color-orange-400); }
.product-card__divider--green  { background-color: var(--color-green-500); }

.product-card__footer {
  color: var(--color-gray-600);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  font-style: italic;
}


/* ============================================================
   WHY SECTION
   Migrated from src/input.css (@apply → plain CSS).
   Used in: private-label/components/private-label.html
   ============================================================ */

.why-section {
  width: 100%;
  padding-top: var(--space-20);
  padding-bottom: var(--space-20);
  padding-left: var(--space-6);
  padding-right: var(--space-6);
}

.why-section__title {
  text-align: center;
  margin-bottom: var(--space-16);
  margin-left: auto;
  margin-right: auto;
  color: var(--color-gray-800);
  max-width: 72rem;
  font-family: Arial, sans-serif;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 400;
  letter-spacing: -0.02em;
}

.why-section__card {
  max-width: 64rem;
  margin-left: auto;
  margin-right: auto;
  background-color: var(--color-white);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-lg);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-8);
  padding: 2.5rem;
}

@media (min-width: 1024px) {
  .why-section__card {
    gap: 0;
    padding: var(--space-12);
  }
}

.why-section__column {
  text-align: center;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

@media (min-width: 1024px) {
  .why-section__column {
    padding-left: var(--space-8);
    padding-right: var(--space-8);
  }

  .why-section__column:not(:last-child) {
    border-right: 1px solid var(--color-gray-100);
  }
}

.why-section__label {
  text-transform: uppercase;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.05em;
  display: inline-block;
  margin-bottom: var(--space-2);
}

.why-section__label--orange { color: var(--color-brand-orange); }
.why-section__label--green  { color: var(--color-green-600); }
.why-section__label--olive  { color: #8b7355; }

.why-section__label-underline {
  width: 4rem;
  height: 2px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.25rem;
}

.why-section__label-underline--orange { background-color: var(--color-orange-400); }
.why-section__label-underline--green  { background-color: var(--color-green-500); }
.why-section__label-underline--olive  { background-color: #8b7355; }

.why-section__heading {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-gray-800);
  margin-bottom: var(--space-3);
}

@media (min-width: 1024px) {
  .why-section__heading {
    font-size: var(--text-2xl);
  }
}

.why-section__text {
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
}


/* ============================================================
   TIMELINE SECTION
   Migrated from src/input.css (@apply → plain CSS).
   Used in: private-label/components/how-it-works.html
   ============================================================ */

.timeline-section {
  width: 100%;
  padding-top: var(--space-20);
  padding-bottom: var(--space-20);
  padding-left: var(--space-6);
  padding-right: var(--space-6);
}

.timeline-section__title {
  text-align: center;
  margin-bottom: var(--space-16);
  margin-left: auto;
  margin-right: auto;
  color: var(--color-gray-800);
  max-width: 72rem;
  font-family: Arial, sans-serif;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 400;
  letter-spacing: -0.02em;
}

.timeline-section__steps {
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
}

.timeline-step {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  padding-bottom: var(--space-12);
  padding-left: 20px;
}

.timeline-step:last-child {
  padding-bottom: 0;
}

.timeline-step__line {
  position: absolute;
  width: 2px;
  left: 4px;
  top: 18px;
  bottom: -18px;
}

.timeline-step:last-child .timeline-step__line {
  display: none;
}

.timeline-step__line--green  { background-color: var(--color-green-500); }
.timeline-step__line--orange { background-color: var(--color-orange-400); }

.timeline-step__dot {
  position: absolute;
  width: 0.75rem;
  height: 0.75rem;
  border-radius: var(--radius-full);
  z-index: 10;
  left: -1px;
  top: 18px;
}

.timeline-step__dot--green  { background-color: var(--color-green-500); }
.timeline-step__dot--orange { background-color: var(--color-orange-400); }

.timeline-step__number {
  width: 3rem;
  height: 3rem;
  border-radius: var(--radius-full);
  border: 2px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-lg);
  font-weight: var(--weight-medium);
  flex-shrink: 0;
}

.timeline-step__number--green  { border-color: var(--color-green-500); color: var(--color-green-600); }
.timeline-step__number--orange { border-color: var(--color-orange-400); color: var(--color-brand-orange); }

.timeline-step__content {
  padding-top: var(--space-2);
}

.timeline-step__heading {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-gray-800);
  margin-bottom: var(--space-2);
}

.timeline-step__text {
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
}


/* ============================================================
   FOUNDATIONS SECTION
   Migrated from src/input.css (@apply → plain CSS).
   Used in: private-label/components/platform-capabilities.html,
            signing-portal/components/extended.html
   ============================================================ */

.foundations-section {
  width: 100%;
  padding-top: var(--space-20);
  padding-bottom: var(--space-20);
  padding-left: var(--space-6);
  padding-right: var(--space-6);
}

.foundations-section__title {
  text-align: center;
  margin-bottom: var(--space-16);
  margin-left: auto;
  margin-right: auto;
  color: var(--color-gray-800);
  max-width: 72rem;
  font-family: Arial, sans-serif;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 400;
  letter-spacing: -0.02em;
}

.foundations-section__grid {
  max-width: 64rem;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}

@media (max-width: 768px) {
  .foundations-section__grid {
    grid-template-columns: 1fr;
  }
}

.foundation-card {
  background-color: var(--color-white);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-md);
  padding: var(--space-8);
}

.foundation-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.foundation-card__icon {
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
}

.foundation-card__icon svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke-width: 1.5;
}

.foundation-card__icon--green svg  { stroke: var(--color-green-600); }
.foundation-card__icon--orange svg { stroke: var(--color-brand-orange); }

.foundation-card__title {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
}

.foundation-card__title--green  { color: var(--color-green-600); }
.foundation-card__title--orange { color: var(--color-brand-orange); }

.foundation-card__text {
  color: var(--color-gray-600);
  line-height: var(--leading-relaxed);
}


/* ============================================================
   EXPANDABLE / READ MORE
   Migrated from src/input.css (@apply → plain CSS).
   Used in: solutions/components/product-identity.html,
            solutions/components/product-signature.html,
            solutions/components/product-fragmentation.html
   ============================================================ */

.expandable-section {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.4s ease-out, opacity 0.3s ease-out;
}

.expandable-section.expanded {
  max-height: 600px;
  opacity: 1;
  transition: max-height 0.5s ease-in, opacity 0.3s ease-in;
}

.read-more-btn {
  display: inline-flex;
  align-items: center;
  color: var(--color-brand-orange);
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  cursor: pointer;
  border: none;
  background: transparent;
  padding: 0;
  gap: 6px;
  margin-top: var(--space-6);
  transition: color 0.2s ease, gap 0.2s ease;
}

.read-more-btn:hover {
  color: #ea580c;  /* orange-600 */
  gap: 10px;
}

.read-more-btn svg {
  transition: transform 0.3s ease;
}

.read-more-btn.expanded svg {
  transform: rotate(180deg);
}


/* ============================================================
   SECTION TITLE & INTRO TEXT
   Migrated from src/input.css (@apply → plain CSS).
   Used in: blog/index.njk,
            private-label/components/customized-solution.html,
            private-label/components/who-uses.html
   ============================================================ */

.section-title {
  font-size: var(--text-3xl);
  font-weight: var(--weight-bold);
  color: var(--color-gray-800);
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-4);
  border-bottom: 4px solid var(--color-brand-orange);
}

@media (min-width: 1024px) {
  .section-title {
    font-size: var(--text-4xl);
  }
}

.intro-text {
  font-size: var(--text-lg);
  color: var(--color-gray-600);
  margin-bottom: var(--space-8);
  line-height: var(--leading-relaxed);
}


/* ============================================================
   FEATURE LIST (checkmark items)
   Migrated from src/input.css (@apply → plain CSS).
   Used in: private-label/components/customized-solution.html
   ============================================================ */

.feature-list {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-bottom: 2.5rem;
}

.feature-item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  color: var(--color-gray-800);
}

.feature-icon {
  width: 1.75rem;
  height: 1.75rem;
  background-color: var(--color-green-500);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.feature-icon svg {
  width: 1rem;
  height: 1rem;
  stroke: white;
  fill: none;
  stroke-width: 3;
}

.feature-text {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
}


/* ============================================================
   ICON GRID
   Migrated from src/input.css (@apply → plain CSS).
   Used in: private-label/components/customized-solution.html
   ============================================================ */

.icon-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  margin-top: var(--space-6);
}

@media (min-width: 640px) {
  .icon-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1024px) {
  .icon-grid {
    gap: var(--space-8);
  }
}

.icon-item {
  text-align: center;
}

.icon-circle {
  width: 5rem;
  height: 5rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: var(--space-4);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #f5f7fa 0%, #e8ecf1 100%);
  transition: transform 0.3s ease;
}

.icon-circle:hover {
  transform: translateY(-4px);
}

.icon-circle svg {
  width: 2.5rem;
  height: 2.5rem;
  stroke: var(--color-gray-600);
  stroke-width: 2;
  fill: none;
}

.icon-label {
  font-size: var(--text-sm);
  color: var(--color-gray-600);
  font-weight: var(--weight-medium);
}


/* ============================================================
   V2 COMPONENTS
   Extracted from identigate_website_v2-44.html.
   Uses short CSS variable names (--f, --o, --b, etc.) defined
   in the V2 DESIGN TOKENS block of :root above.
   ============================================================ */

/* --- V2 NAV --- */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 2rem;height:68px;display:flex;justify-content:space-between;align-items:center;background:rgba(245,240,235,0.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--bd)}
.site-nav-logo{font-size:1.25rem;font-weight:700;color:var(--f);text-decoration:none;letter-spacing:-0.02em;flex-shrink:0}
.site-nav-logo span{color:var(--o)}
.nm{display:flex;gap:1.5rem;align-items:center}
.nm a{font-size:0.78rem;font-weight:500;color:var(--tm);text-decoration:none;letter-spacing:0.04em;text-transform:uppercase;transition:color 0.2s;padding:0.3rem 0}
.nm a:hover{color:var(--f);font-weight:600}
.nm a.act{color:var(--o);font-weight:700;border-bottom:2px solid var(--o);padding-bottom:0.15rem}
.nav-dd{position:relative}
.nav-dd::after{content:'';position:absolute;top:100%;left:-16px;right:-16px;height:0.8rem}
.nav-dd-menu{visibility:hidden;opacity:0;transition:opacity 0.12s,visibility 0.12s;transition-delay:0.18s;position:absolute;top:calc(100% + 0.6rem);left:50%;transform:translateX(-50%);background:var(--w);border:1px solid var(--bd);border-radius:10px;padding:0.8rem 0;min-width:220px;box-shadow:0 12px 32px rgba(27,58,45,0.12);z-index:200}
.nav-dd:hover .nav-dd-menu{visibility:visible;opacity:1;transition-delay:0s}
.nav-dd-menu::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);width:10px;height:10px;background:var(--w);border-left:1px solid var(--bd);border-top:1px solid var(--bd)}
.nav-dd-label{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--o);font-weight:700;padding:0.3rem 1.2rem;margin-bottom:0.2rem}
.nav-dd-menu a{display:block;font-size:0.78rem;font-weight:400;color:var(--tm)!important;text-transform:none!important;letter-spacing:0!important;padding:0.35rem 1.2rem!important;transition:background 0.15s,color 0.15s}
.nav-dd-menu a:hover{background:var(--b);color:var(--f)!important;font-weight:500!important}
.nc{background:var(--o)!important;color:var(--w)!important;padding:0.5rem 1.1rem!important;border-radius:5px;transition:all 0.2s!important;letter-spacing:0.02em!important}
.nc:hover{background:var(--ol)!important;transform:translateY(-1px)}
.mob-btn{display:none;background:none;border:none;cursor:pointer;color:var(--f);font-size:1.4rem;padding:0.3rem}

/* --- V2 LAYOUT --- */
.mx{max-width:1140px;margin:0 auto;width:100%;padding:0}
.sec{padding:5rem 2rem}
.sl{font-size:0.68rem;text-transform:uppercase;letter-spacing:0.16em;font-weight:700;margin-bottom:0.7rem}
.sl-l{color:rgba(255,255,255,0.35)}
.sl-d{color:var(--o)}
.sl-badge{display:inline-block;background:var(--o);color:var(--w);font-size:0.68rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:0.3rem 0.8rem;border-radius:4px;margin-bottom:0.7rem}
.st{font-family:'DM Serif Display',serif;font-size:2.2rem;line-height:1.15;color:var(--f);letter-spacing:-0.01em}
.ss{font-size:0.95rem;color:var(--tl);line-height:1.65;margin-top:0.6rem;max-width:540px}

/* --- V2 BUTTONS --- */
.bp{display:inline-flex;align-items:center;gap:0.5rem;background:var(--o);color:var(--w);padding:0.8rem 1.6rem;border-radius:6px;font-weight:600;font-size:0.9rem;text-decoration:none;transition:all 0.2s;border:none;cursor:pointer}
.bp:hover{background:var(--ol);transform:translateY(-1px)}
.bp-dark{background:var(--f)}
.bp-dark:hover{background:var(--fl)}
.bs{display:inline-flex;align-items:center;gap:0.5rem;color:var(--f);padding:0.8rem 1.6rem;border-radius:6px;font-weight:600;font-size:0.9rem;text-decoration:none;border:2px solid rgba(27,58,45,0.2);cursor:pointer;transition:all 0.2s}
.bs:hover{border-color:var(--f);background:rgba(27,58,45,0.03)}
.bw{display:inline-flex;align-items:center;background:var(--w);color:var(--f);padding:0.8rem 1.6rem;border-radius:6px;font-weight:600;font-size:0.9rem;text-decoration:none;cursor:pointer;transition:transform 0.15s}
.bw:hover{transform:translateY(-1px)}

/* --- V2 GRIDS --- */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}

/* --- V2 CARD (overrides v1) --- */
.card{background:var(--w);border-radius:14px;padding:2rem;box-shadow:0 1px 12px rgba(27,58,45,0.04);transition:transform 0.2s,box-shadow 0.2s}
.card:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(27,58,45,0.08)}
.card h3{font-size:0.95rem;font-weight:600;color:var(--f);margin-bottom:0.4rem}
.card p{font-size:0.85rem;color:var(--tm);line-height:1.55}
.card-icon{font-size:2rem;margin-bottom:0.8rem;display:block}

/* --- V2 HERO --- */
.hero{min-height:100vh;display:flex;align-items:center;padding:1rem 2rem 4rem;background:var(--b);position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;top:0;right:0;width:45%;height:100%;background:linear-gradient(135deg,transparent 30%,rgba(232,129,26,0.03) 100%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:3rem;align-items:center}
.hero-badge{display:inline-block;background:var(--f);color:var(--w);font-size:0.68rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:0.35rem 0.85rem;border-radius:4px;margin-bottom:1.2rem}
.hero h1{font-family:'DM Serif Display',serif;font-size:3rem;line-height:1.08;color:var(--f);letter-spacing:-0.02em;margin-bottom:1rem}
.hero h1 em{font-style:normal;color:var(--o)}
.hero-p{font-size:1.05rem;line-height:1.65;color:var(--tm);margin-bottom:1.8rem;max-width:480px}
.hero-ctas{display:flex;gap:0.8rem;flex-wrap:wrap;margin-bottom:2rem}
.hero-proof{display:flex;gap:2.5rem;margin-top:0.5rem;flex-wrap:wrap}
.hero-proof-item{text-align:left}
.hero-proof-n{font-family:'DM Serif Display',serif;font-size:1.8rem;color:var(--f)}
.hero-proof-l{font-size:0.72rem;color:var(--tl);font-weight:500}
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.hero-phone{width:260px;height:480px;background:var(--w);border-radius:28px;box-shadow:0 20px 60px rgba(27,58,45,0.12);border:3px solid var(--bd);position:relative;overflow:hidden;display:flex;flex-direction:column}
.hero-phone-status{background:var(--f);color:var(--w);text-align:center;padding:1.2rem 1rem 0.8rem;font-size:0.65rem;font-weight:600;letter-spacing:0.05em;text-transform:uppercase}
.hero-phone-content{flex:1;padding:1.2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:0.8rem}
.hero-phone-icon{font-size:3rem}
.hero-phone-text{font-size:0.8rem;color:var(--tm);line-height:1.4}
.hero-phone-text strong{color:var(--f)}
.hero-phone-btn{background:var(--o);color:var(--w);border:none;padding:0.6rem 1.4rem;border-radius:6px;font-weight:600;font-size:0.78rem;width:100%;cursor:default}
.hero-phone-steps{display:flex;gap:0.3rem;margin-top:0.3rem}
.hero-phone-step{width:8px;height:8px;border-radius:50%;background:var(--bd)}
.hero-phone-step.active{background:var(--o)}

/* --- V2 WHAT YOU CAN DO --- */
.wyd{background:var(--w);padding:4.5rem 2rem}
.wyd-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.wyd-card{padding:2rem;border-radius:14px;border:1px solid var(--bd);text-align:center;transition:all 0.2s}
.wyd-card:hover{border-color:var(--o);box-shadow:0 4px 16px rgba(232,129,26,0.08)}
.wyd-card-num{font-family:'DM Serif Display',serif;font-size:2.5rem;color:var(--o);margin-bottom:0.5rem}
.wyd-card h3{font-size:1rem;font-weight:700;color:var(--f);margin-bottom:0.4rem}
.wyd-card p{font-size:0.85rem;color:var(--tm);line-height:1.5}

/* --- V2 HOW IT WORKS --- */
.hiw{background:var(--f);color:var(--w);padding:5rem 2rem}
.hiw-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2.5rem}
.hiw-step{position:relative;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);border-radius:14px;padding:2rem;text-align:center}
.hiw-step-num{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--o);color:var(--w);font-family:'DM Serif Display',serif;font-size:1.3rem;margin-bottom:1rem}
.hiw-step h3{font-size:1.05rem;font-weight:600;margin-bottom:0.5rem}
.hiw-step p{font-size:0.85rem;color:rgba(255,255,255,0.6);line-height:1.5}
.hiw-step .hiw-time{display:inline-block;margin-top:0.8rem;background:rgba(232,129,26,0.15);color:var(--o);padding:0.2rem 0.7rem;border-radius:4px;font-size:0.72rem;font-weight:700;letter-spacing:0.04em}
.hiw-note{text-align:center;margin-top:2rem;font-size:0.88rem;color:rgba(255,255,255,0.5)}
.hiw-note strong{color:var(--o)}

/* --- V2 SPLIT KEY --- */
.splitkey{background:var(--b);padding:5rem 2rem}
.sk-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin-top:2rem}
.sk-visual{display:flex;flex-direction:column;gap:0.8rem}
.sk-half{display:flex;align-items:center;gap:1rem;background:var(--w);border-radius:12px;padding:1.5rem;box-shadow:0 2px 12px rgba(27,58,45,0.04)}
.sk-half-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}
.sk-half-icon.user{background:var(--o);color:var(--w)}
.sk-half-icon.server{background:var(--f);color:var(--w)}
.sk-half h4{font-size:0.9rem;font-weight:600;color:var(--f);margin-bottom:0.2rem}
.sk-half p{font-size:0.82rem;color:var(--tm);line-height:1.4}
.sk-divider{text-align:center;font-size:0.72rem;text-transform:uppercase;letter-spacing:0.15em;color:var(--tl);font-weight:700;padding:0.5rem 0;position:relative}
.sk-divider::before,.sk-divider::after{content:'';position:absolute;top:50%;width:30%;height:1px;background:var(--bd)}
.sk-divider::before{left:5%}
.sk-divider::after{right:5%}
.sk-result{background:var(--f);color:var(--w);border-radius:12px;padding:1.2rem;text-align:center;font-size:0.85rem}
.sk-result strong{color:var(--o)}
.sk-text h2{margin-bottom:1rem}
.sk-text p{font-size:0.92rem;color:var(--tm);line-height:1.65;margin-bottom:0.8rem}
.sk-text .sk-benefits{list-style:none;margin-top:1.2rem}
.sk-text .sk-benefits li{font-size:0.88rem;color:var(--tm);padding:0.5rem 0;padding-left:1.5rem;position:relative;border-bottom:1px solid var(--bd)}
.sk-text .sk-benefits li:last-child{border:none}
.sk-text .sk-benefits li::before{content:'✓';position:absolute;left:0;color:var(--o);font-weight:700}

/* --- V2 COVERAGE --- */
.coverage{background:var(--w);padding:5rem 2rem}
.cov-bars{display:flex;flex-direction:column;gap:1.2rem;max-width:600px;margin:2rem auto 0}
.cov-bar{display:grid;grid-template-columns:140px 1fr 50px;align-items:center;gap:1rem}
.cov-bar-label{font-size:0.82rem;font-weight:500;color:var(--tm);text-align:right}
.cov-bar-track{height:32px;background:var(--b);border-radius:6px;overflow:hidden;position:relative}
.cov-bar-fill{height:100%;border-radius:6px;display:flex;align-items:center;justify-content:flex-end;padding-right:0.8rem;font-size:0.72rem;font-weight:700;color:var(--w);transition:width 1.5s cubic-bezier(0.25,0.46,0.45,0.94);width:0}
.cov-bar-fill.eudi{background:var(--bd);color:var(--tm)}
.cov-bar-fill.ecmr{background:var(--fl)}
.cov-bar-fill.ig{background:var(--o)}
.cov-bar-num{font-family:'DM Serif Display',serif;font-size:1.3rem;color:var(--f)}
.cov-note{text-align:center;margin-top:1.5rem;font-size:0.82rem;color:var(--tl);max-width:500px;margin-left:auto;margin-right:auto;line-height:1.5}

/* --- V2 PRODUCTS PREVIEW --- */
.prod-prev{background:var(--b);padding:5rem 2rem}
.pp-pillars{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem}
.pp-pillar{background:var(--w);border-radius:16px;padding:2.2rem;box-shadow:0 2px 16px rgba(27,58,45,0.04)}
.pp-pillar-badge{display:inline-block;font-size:0.68rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:0.3rem 0.7rem;border-radius:4px;margin-bottom:1rem}
.pp-pillar-badge.id{background:var(--o);color:var(--w)}
.pp-pillar-badge.sig{background:var(--f);color:var(--w)}
.pp-pillar h3{font-family:'DM Serif Display',serif;font-size:1.3rem;color:var(--f);margin-bottom:0.5rem}
.pp-pillar-desc{font-size:0.88rem;color:var(--tm);line-height:1.5;margin-bottom:1.2rem}
.pp-list{list-style:none;display:flex;flex-direction:column;gap:0.3rem}
.pp-list li{font-size:0.84rem;color:var(--tm);padding:0.45rem 0.8rem;border-radius:6px;cursor:pointer;transition:all 0.15s;display:flex;justify-content:space-between;align-items:center}
.pp-list li:hover{background:var(--b);color:var(--f);font-weight:500}
.pp-list li::after{content:'→';font-size:0.75rem;color:var(--tl);transition:color 0.15s}
.pp-list li:hover::after{color:var(--o)}
.pp-list a{color:var(--tm);text-decoration:none;flex:1}
.pp-list li:hover a{color:var(--f)}

/* --- V2 INDUSTRIES --- */
.industries{background:var(--w);padding:5rem 2rem}
.ind-featured{background:linear-gradient(135deg,var(--f) 0%,var(--fl) 100%);border-radius:16px;padding:2.5rem;color:var(--w);display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;margin-top:2rem;margin-bottom:1.5rem}
.ind-featured h3{font-family:'DM Serif Display',serif;font-size:1.6rem;margin-bottom:0.6rem}
.ind-featured p{font-size:0.92rem;color:rgba(255,255,255,0.7);line-height:1.6;margin-bottom:1.2rem}
.ind-featured-stats{display:flex;gap:1.5rem}
.ind-featured-stat{text-align:center}
.ind-featured-stat-n{font-family:'DM Serif Display',serif;font-size:1.5rem;color:var(--o)}
.ind-featured-stat-l{font-size:0.7rem;color:rgba(255,255,255,0.5)}
.ind-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}
.ind-card{background:var(--b);border-radius:12px;padding:1.5rem;text-align:center;transition:all 0.2s;cursor:default}
.ind-card:hover{background:var(--w);box-shadow:0 4px 16px rgba(27,58,45,0.06)}
.ind-card-icon{font-size:1.8rem;margin-bottom:0.5rem}
.ind-card h4{font-size:0.82rem;font-weight:600;color:var(--f)}

/* --- V2 TRACTION --- */
.traction{background:var(--f);color:var(--w);padding:4rem 2rem}
.traction-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2rem}
.traction-item{text-align:center;padding:1.5rem;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);border-radius:12px}
.traction-item-icon{font-size:1.5rem;margin-bottom:0.5rem}
.traction-item h4{font-size:0.88rem;font-weight:600;margin-bottom:0.3rem}
.traction-item p{font-size:0.78rem;color:rgba(255,255,255,0.5);line-height:1.4}

/* --- V2 DIFF TABLE --- */
.diff{background:var(--b);padding:5rem 2rem}
.diff-table{width:100%;border-collapse:collapse;margin-top:2rem;background:var(--w);border-radius:14px;overflow:hidden;box-shadow:0 2px 12px rgba(27,58,45,0.04)}
.diff-table th{text-align:left;font-size:0.7rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--tl);padding:1rem;border-bottom:2px solid var(--b);font-weight:600}
.diff-table th:first-child{width:30%}
.diff-table td{padding:0.8rem 1rem;font-size:0.84rem;border-bottom:1px solid var(--b);color:var(--tm)}
.diff-table .chk{color:var(--o);font-weight:700;font-size:1rem}
.diff-table .nope{color:var(--bd);font-size:1rem}
.diff-table .hl{background:rgba(232,129,26,0.04)}
.diff-table .hl td{color:var(--f);font-weight:500}

/* --- V2 CTA SECTION --- */
.cta-sec{background:var(--f);padding:5rem 2rem;text-align:center;color:var(--w)}
.cta-sec h2{font-family:'DM Serif Display',serif;font-size:2.2rem;margin-bottom:0.8rem}
.cta-sec p{font-size:0.95rem;color:rgba(255,255,255,0.6);max-width:480px;margin:0 auto 2rem;line-height:1.6}
.cta-btns{display:flex;gap:0.8rem;justify-content:center;flex-wrap:wrap}

/* --- V2 COMPLIANCE --- */
.compliance{background:var(--w);padding:3rem 2rem;text-align:center}
.comp-badges{display:flex;justify-content:center;gap:3rem;margin-top:1rem;flex-wrap:wrap}
.comp-badge-name{font-size:0.85rem;font-weight:700;color:var(--f)}
.comp-badge-status{font-size:0.72rem;color:var(--tl)}

/* --- V2 FOOTER --- */
.footer{background:var(--w);padding:3rem 2rem;border-top:1px solid var(--bd)}
.foot-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:2rem}
.foot-brand p{font-size:0.8rem;color:var(--tl);line-height:1.6;margin-top:0.5rem;max-width:240px}
.foot-col h4{font-size:0.68rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--tl);margin-bottom:0.7rem;font-weight:700}
.foot-col a{display:block;font-size:0.8rem;color:var(--tm);text-decoration:none;margin-bottom:0.35rem;transition:color 0.15s}
.foot-col a:hover{color:var(--f)}
.foot-bot{text-align:center;padding-top:1.5rem;margin-top:1.5rem;border-top:1px solid var(--bd)}
.foot-bot p{font-size:0.72rem;color:var(--tl)}

/* --- V2 FADE-IN ANIMATION --- */
.fi{opacity:0;transform:translateY(18px);transition:opacity 0.6s ease,transform 0.6s ease}
.fi.vis{opacity:1;transform:translateY(0)}

/* --- V2 BREADCRUMB --- */
.bread{padding:0.6rem 2rem 0.5rem;font-size:0.75rem;color:var(--tl)}
.bread a{color:var(--tl);text-decoration:none}
.bread a:hover{color:var(--f)}
.bread span{margin:0 0.3rem;opacity:0.5}

/* --- V2 PRODUCT PAGE HERO --- */
.phero{padding:6rem 2rem 3rem;text-align:center}
.phero-badge{display:inline-block;font-size:0.68rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:0.3rem 0.85rem;border-radius:4px;margin-bottom:1rem}
.phero-badge-id{background:var(--o);color:var(--w)}
.phero-badge-sig{background:var(--f);color:var(--w)}
.phero h1{font-family:'DM Serif Display',serif;font-size:2.5rem;color:var(--f);max-width:650px;margin:0 auto 0.6rem;line-height:1.12}
.phero-aud{font-size:0.78rem;color:var(--tl);margin-bottom:0.8rem}
.phero-sub{font-size:1rem;color:var(--tm);max-width:540px;margin:0 auto 1.5rem;line-height:1.6}

/* --- V2 PROCESS FLOW --- */
.proc{background:var(--f);color:var(--w);padding:5rem 2rem}
.proc-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2rem}
.proc-step{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:14px;padding:1.8rem 1.5rem;text-align:center;position:relative}
.proc-step-num{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--o);color:var(--w);font-weight:700;font-size:0.85rem;margin-bottom:0.8rem}
.proc-step h4{font-size:0.9rem;font-weight:600;margin-bottom:0.4rem}
.proc-step p{font-size:0.8rem;color:rgba(255,255,255,0.55);line-height:1.45}
.proc-step .proc-arrow{position:absolute;right:-0.9rem;top:50%;color:var(--o);font-size:1.1rem;font-weight:700;z-index:1}

/* --- V2 FEATURE ROWS --- */
.feat{padding:5rem 2rem}
.feat-row{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin-bottom:4rem}
.feat-row:last-child{margin-bottom:0}
.feat-row.rev{direction:rtl}
.feat-row.rev>*{direction:ltr}
.feat-text h3{font-family:'DM Serif Display',serif;font-size:1.5rem;color:var(--f);margin-bottom:0.7rem;line-height:1.2}
.feat-text p{font-size:0.9rem;color:var(--tm);line-height:1.65;margin-bottom:0.5rem}
.feat-text .feat-highlight{background:rgba(232,129,26,0.08);border-left:3px solid var(--o);padding:0.8rem 1rem;border-radius:0 8px 8px 0;margin-top:1rem;font-size:0.85rem;color:var(--f);line-height:1.5}
.feat-vis{background:var(--b);border-radius:16px;padding:3rem;display:flex;align-items:center;justify-content:center;min-height:240px;font-size:4rem;text-align:center}
.feat-vis-dark{background:var(--f);color:var(--w)}

/* --- V2 RELATED PRODUCTS NAV --- */
.related{background:var(--b);padding:4rem 2rem}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.5rem}
.related-card{background:var(--w);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all 0.2s;text-decoration:none;display:block}
.related-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(27,58,45,0.08)}
.related-card h4{font-size:0.9rem;font-weight:600;color:var(--f);margin-bottom:0.3rem}
.related-card p{font-size:0.78rem;color:var(--tl);line-height:1.4}
.related-card-arrow{display:inline-block;margin-top:0.5rem;font-size:0.78rem;font-weight:600;color:var(--o)}

/* --- V2 PRODUCT OVERVIEW CARDS --- */
.prod-card{cursor:pointer;border-top:3px solid var(--o);padding:1.8rem;transition:all 0.25s;position:relative}
.prod-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(27,58,45,0.12);border-color:var(--o)}
.prod-card .prod-arrow{position:absolute;top:1.5rem;right:1.5rem;width:32px;height:32px;border-radius:50%;background:var(--b);display:flex;align-items:center;justify-content:center;font-size:0.8rem;color:var(--o);transition:all 0.25s}
.prod-card:hover .prod-arrow{background:var(--o);color:var(--w)}
.prod-card-g{border-top-color:var(--f)}
.prod-card-g:hover{border-color:var(--f)}
.prod-card-g .prod-arrow{color:var(--f)}
.prod-card-g:hover .prod-arrow{background:var(--f);color:var(--w)}

/* --- V2 ARTICLE BODY --- */
.art-body{max-width:720px;margin:0 auto;font-size:0.95rem;line-height:1.8;color:var(--td)}
.art-body h2{font-family:'DM Serif Display',serif;font-size:1.4rem;color:var(--f);margin:2.5rem 0 1rem;line-height:1.25}
.art-body h3{font-size:1.1rem;color:var(--f);font-weight:600;margin:2rem 0 0.8rem}
.art-body p{margin-bottom:1.2rem}
.art-body strong{color:var(--f);font-weight:600}
.art-body a{color:var(--o);text-decoration:underline;text-decoration-color:rgba(232,129,26,0.3)}
.art-body a:hover{text-decoration-color:var(--o)}
.art-body blockquote{border-left:3px solid var(--o);padding:0.8rem 1.2rem;margin:1.5rem 0;background:var(--b);border-radius:0 8px 8px 0;font-style:italic;color:var(--tm)}
.art-body hr{border:none;border-top:1px solid var(--bd);margin:2.5rem 0}
.art-body ul,.art-body ol{margin-bottom:1.2rem;padding-left:1.5rem;color:var(--td);line-height:1.8}
.art-body ul{list-style-type:disc}
.art-body ol{list-style-type:decimal}
.art-body li{margin-bottom:0.5rem}
.art-body code{background:var(--b);border:1px solid var(--bd);padding:0.15rem 0.4rem;border-radius:4px;font-size:0.88rem}
.art-body pre{background:var(--f);color:var(--w);padding:1.25rem;border-radius:10px;overflow-x:auto;margin-bottom:1.5rem}
.art-body pre code{background:none;border:none;padding:0;color:inherit}
.art-body img{border-radius:10px;margin:1.5rem 0}

/* --- V2 ARTICLE HIGHLIGHT BOX --- */
.art-hl{background:rgba(232,129,26,0.06);border-left:4px solid var(--o);padding:1.2rem 1.5rem;border-radius:0 10px 10px 0;margin:1.8rem 0;font-size:0.92rem;line-height:1.7;color:var(--f)}
.art-hl strong{color:var(--o)}

/* --- V2 ARTICLE KEY STAT --- */
.art-stat{display:flex;gap:1.5rem;align-items:center;background:var(--w);border:1px solid var(--bd);border-radius:12px;padding:1.5rem;margin:1.8rem 0}
.art-stat-n{font-family:'DM Serif Display',serif;font-size:2rem;color:var(--f);white-space:nowrap}
.art-stat-l{font-size:0.85rem;color:var(--tm);line-height:1.45}

/* --- BLOG CARD --- */
.blog-card{display:flex;flex-direction:row;text-decoration:none;color:inherit}
.blog-card-img{width:180px;min-width:180px;flex-shrink:0;display:flex;overflow:hidden;border-radius:14px 0 0 14px}
.blog-card-img img{width:100%;object-fit:cover;display:block;min-height:200px}
.blog-card-body{padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between;flex:1}
.blog-post-title{font-family:'DM Serif Display',serif;font-size:2.2rem;color:var(--f);line-height:1.2;margin-bottom:1rem}
.blog-post-cover{width:100%;object-fit:contain;border-radius:10px;margin-bottom:2rem;display:block}

/* --- V2 RESPONSIVE --- */
@media(max-width:900px){
  .hero-grid,.g2,.sk-grid,.feat-row,.feat-row.rev,.pp-pillars,.ind-featured,.foot-grid{grid-template-columns:1fr!important;direction:ltr!important}
  .hero h1{font-size:2.2rem}
  .hero-visual{display:none}
  .g3,.g4,.hiw-steps,.proc-flow,.wyd-grid,.traction-grid,.ind-grid,.related-grid{grid-template-columns:1fr!important}
  .proc-step .proc-arrow{display:none}
  .nm{display:none;position:fixed;top:68px;left:0;right:0;z-index:99;background:var(--b);flex-direction:column;padding:1.5rem 2rem;gap:1rem;border-bottom:1px solid var(--bd);box-shadow:0 8px 20px rgba(0,0,0,0.08)}
  .nm.open{display:flex}
  .mob-btn{display:block}
  .nav-dd-menu{position:static!important;transform:none!important;box-shadow:none!important;border:none!important;margin-top:0.5rem!important;padding:0!important;background:transparent!important;visibility:visible!important;opacity:1!important;transition:none!important}
  .nav-dd-menu::before{display:none!important}
  .nav-dd-menu a{padding:0.25rem 0 0.25rem 1rem!important;font-size:0.75rem!important}
  .cov-bar{grid-template-columns:100px 1fr 40px}
  .diff-table{font-size:0.75rem}
  .diff-table th,.diff-table td{padding:0.6rem 0.5rem}
  .blog-card{flex-direction:column}
  .blog-card-img{width:100%;min-width:0;height:200px}
  .blog-card-body{padding:1.2rem}
  .blog-post-title{font-size:1.6rem}
}

/* --- LOGISTICS --- */

/* HERO */
.lhero{min-height:85vh;display:flex;align-items:center;padding:7rem 2rem 4rem;position:relative}
.lhero::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(160deg,var(--b) 55%,rgba(232,129,26,0.05) 100%);pointer-events:none}
.lhero .mx{position:relative;z-index:1}
.lhero-g{display:grid;grid-template-columns:1.2fr 0.8fr;gap:3rem;align-items:center}
.lhero-badge{display:inline-block;background:var(--f);color:var(--w);font-size:0.65rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:0.35rem 0.85rem;border-radius:4px;margin-bottom:1.2rem}
.lhero h1{font-family:'DM Serif Display',serif;font-size:2.8rem;line-height:1.1;color:var(--f);margin-bottom:1rem}
.lhero h1 em{font-style:normal;color:var(--o)}
.lhero-p{font-size:1rem;line-height:1.65;color:var(--tm);margin-bottom:1.8rem;max-width:520px}
.lhero-ctas{display:flex;gap:0.8rem;flex-wrap:wrap;margin-bottom:2rem}
.lhero-stats{display:flex;gap:2.5rem;flex-wrap:wrap}
.lhero-sn{font-family:'DM Serif Display',serif;font-size:1.6rem;color:var(--f)}
.lhero-sl{font-size:0.7rem;color:var(--tl);font-weight:500}

/* MODE CARDS */
.mcards{display:grid;grid-template-columns:1fr 1fr;gap:0.8rem}
.mcard{background:var(--w);border-radius:12px;padding:1.3rem;box-shadow:0 2px 16px rgba(27,58,45,0.05);position:relative;overflow:hidden;transition:all 0.2s;text-decoration:none;color:inherit;display:block}
.mcard:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(27,58,45,0.1)}
.mcard-bar{position:absolute;top:0;left:0;width:100%;height:3px}
.mcard-ico{font-size:1.5rem;margin-bottom:0.4rem;display:block}
.mcard h3{font-size:0.85rem;font-weight:700;color:var(--f);margin-bottom:0.15rem}
.mcard p{font-size:0.68rem;color:var(--tl);line-height:1.4}

/* URGENCY */
.urg{background:var(--o);padding:1rem 2rem;text-align:center}
.urg p{color:var(--w);font-size:0.85rem;font-weight:600}
.urg strong{font-size:1rem}

/* GAP */
.gap{background:var(--fd);padding:5rem 2rem;text-align:center;position:relative;overflow:hidden}
.gap::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;background:radial-gradient(circle,rgba(232,129,26,0.06),transparent 70%);transform:translate(-50%,-50%);pointer-events:none}
.gap-row{display:flex;justify-content:center;align-items:center;gap:2rem;margin:2rem 0}
.gap-n{font-family:'DM Serif Display',serif;font-size:5rem;line-height:1}
.gap-n.a{color:var(--w)}.gap-n.b{color:var(--o)}
.gap-lb{font-size:0.85rem;color:rgba(255,255,255,0.5);margin-top:0.3rem}
.gap-lb.b{color:var(--o)}
.gap-dv{width:3px;height:100px;background:var(--o);border-radius:2px}
.gap-desc{color:rgba(255,255,255,0.5);font-size:0.85rem;line-height:1.6;max-width:600px;margin:1.5rem auto 0}
.gap-desc strong{color:var(--w)}

/* OVERVIEW CARDS */
.ovcards{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.ovcard{background:var(--w);border-radius:14px;padding:1.8rem;box-shadow:0 1px 12px rgba(27,58,45,0.04);position:relative;overflow:hidden;transition:all 0.25s;text-decoration:none;color:inherit;display:block}
.ovcard:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(27,58,45,0.08)}
.ovcard-bar{position:absolute;top:0;left:0;width:100%;height:3px}
.ovcard-ph{position:absolute;top:1rem;right:1rem;font-size:0.58rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:0.2rem 0.5rem;border-radius:3px}
.ovcard-ph.live{background:rgba(232,129,26,0.1);color:var(--o)}
.ovcard-ph.exp{background:rgba(27,58,45,0.06);color:var(--fl)}
.ovcard-ico{font-size:2rem;margin-bottom:0.8rem;display:block}
.ovcard h3{font-family:'DM Serif Display',serif;font-size:1.1rem;color:var(--f);margin-bottom:0.3rem}
.ovcard-sub{font-size:0.72rem;color:var(--o);font-weight:600;margin-bottom:0.6rem}
.ovcard p{font-size:0.82rem;color:var(--tm);line-height:1.55;margin-bottom:0.8rem}
.ovcard-link{font-size:0.78rem;font-weight:600;color:var(--o)}

/* HOW IT WORKS */
.how{padding:5rem 2rem;background:var(--w)}
.how-center{text-align:center;margin-bottom:3rem}
.how-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative}
.how-steps::before{content:'';position:absolute;top:1.5rem;left:12%;width:76%;height:2px;background:var(--bd)}
.how-step{text-align:center;position:relative}
.how-num{width:44px;height:44px;border-radius:50%;background:var(--o);color:var(--w);font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;position:relative;z-index:1}
.how-step h4{font-size:0.9rem;font-weight:700;color:var(--f);margin-bottom:0.3rem}
.how-step p{font-size:0.78rem;color:var(--tl);line-height:1.5}

/* SUB-PAGE HERO */
.sub-hero{padding:7rem 2rem 3rem;position:relative}
.sub-hero-back{font-size:0.78rem;color:var(--o);text-decoration:none;font-weight:600;display:inline-flex;align-items:center;gap:0.3rem;margin-bottom:1.5rem}
.sub-hero-back:hover{color:var(--ol)}
.sub-hero h1{font-family:'DM Serif Display',serif;font-size:2.4rem;line-height:1.12;color:var(--f);margin-bottom:0.5rem}
.sub-hero-sub{font-size:0.9rem;color:var(--o);font-weight:600;margin-bottom:1rem}
.sub-hero p{font-size:0.95rem;color:var(--tm);line-height:1.65;max-width:700px;margin-bottom:1.5rem}
.sub-stats{display:flex;gap:2rem;flex-wrap:wrap;margin-top:1.5rem}
.sub-sn{font-family:'DM Serif Display',serif;font-size:1.8rem;color:var(--o)}
.sub-sl{font-size:0.7rem;color:var(--tl);font-weight:500}

/* CONTENT SECTIONS */
.csec{padding:4rem 2rem}
.csec-alt{background:var(--w)}
.csec-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.csec h2{font-family:'DM Serif Display',serif;font-size:1.6rem;color:var(--f);margin-bottom:0.5rem;line-height:1.2}
.csec p{font-size:0.88rem;color:var(--tm);line-height:1.65;margin-bottom:1rem}

/* PAIN CARDS */
.pain{background:var(--b);border-radius:10px;padding:1.3rem;margin-bottom:0.8rem}
.pain h4{font-size:0.85rem;font-weight:700;color:var(--f);margin-bottom:0.3rem}
.pain p{font-size:0.8rem;color:var(--tm);line-height:1.5;margin:0}
.csec-alt .pain{background:var(--b)}

/* SOLUTION HIGHLIGHT */
.solh{border-left:3px solid var(--o);padding:1rem 1rem 1rem 1.2rem;margin:1.5rem 0;background:rgba(232,129,26,0.04);border-radius:0 8px 8px 0}
.solh h4{font-size:0.9rem;font-weight:700;color:var(--o);margin-bottom:0.3rem}
.solh p{font-size:0.85rem;color:var(--tm);line-height:1.55;margin:0}

/* RAIL HERO — split background via gradient (more reliable than abs divs with height:100%) */
.rail-hero{background:var(--b)}
.rail-hero .mx{background:linear-gradient(90deg,var(--f) 50%,var(--b) 50%);padding-bottom:2rem}

/* REG TAG */
.rtag{display:inline-block;background:rgba(232,129,26,0.1);color:var(--o);font-size:0.68rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:0.25rem 0.6rem;border-radius:3px;margin-bottom:1rem}

/* CTA DARK */
.cta-dark{background:var(--f);padding:4rem 2rem;text-align:center}
.cta-dark h2{font-family:'DM Serif Display',serif;font-size:2rem;color:var(--w);margin-bottom:0.6rem}
.cta-dark p{color:rgba(255,255,255,0.6);font-size:0.95rem;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}

/* BLOG LINKS */
.blog-links{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.blog-link{display:block;background:var(--w);padding:1rem;border-radius:8px;text-decoration:none;transition:all 0.2s;border:1px solid var(--bd)}
.blog-link:hover{border-color:var(--o);transform:translateY(-1px)}
.blog-link h5{font-size:0.82rem;color:var(--f);font-weight:600;margin-bottom:0.2rem}
.blog-link p{font-size:0.7rem;color:var(--tl);margin:0}
.csec-alt .blog-link{background:var(--b)}

/* logistics responsive */
@media(max-width:900px){
  .rail-hero{background:var(--f)}
  .rail-hero .mx{background:var(--f)}
  .rail-hero [style*="1fr 1fr"]{grid-template-columns:1fr!important}
  .rail-smgs-h{color:var(--w)!important}
  .rail-smgs-p{color:rgba(255,255,255,0.7)!important}
  .lhero-g,.csec-grid{grid-template-columns:1fr}
  .ovcards{grid-template-columns:1fr 1fr}
  .how-steps{grid-template-columns:1fr 1fr}
  .how-steps::before{display:none}
  .gap-row{flex-direction:column;gap:1rem}
  .gap-dv{width:60px;height:3px}
  .gap-n{font-size:3.5rem}
  .blog-links{grid-template-columns:1fr}
  .cta-dark [style*="repeat(3"]{grid-template-columns:1fr!important}
}
@media(max-width:600px){
  .mcards,.ovcards{grid-template-columns:1fr}
  .how-steps{grid-template-columns:1fr}
  .lhero h1{font-size:2rem}
  .sub-hero h1{font-size:1.8rem}
  .sub-stats{gap:1.5rem}
}
/* end logistics responsive */
