/* ==========================================================================
   Social Influence — Main Stylesheet
   Dark tech-forward SaaS agency theme for a Montreal digital marketing agency
   Mobile-first: base styles target 375px viewport
   Responsive breakpoints live in responsive.css
   ========================================================================== */


/* ============================================================
   1. RESET & BASE
   ============================================================ */

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

html {
  font-size: 100%;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  hanging-punctuation: first last;
}

body {
  font-family: var(--si-font-body);
  font-size: var(--si-text-base);
  font-weight: var(--si-weight-normal);
  line-height: var(--si-leading-normal);
  color: var(--si-text-light);
  background-color: var(--si-bg-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Remove list styles on ul/ol with a list role */
ul[role='list'],
ol[role='list'] {
  list-style: none;
}

/* Improve media defaults */
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

/* Remove built-in form typography styles */
input,
button,
textarea,
select {
  font: inherit;
}

/* Avoid text overflows */
p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

/* Improve table defaults */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Remove default button styles */
button {
  background: none;
  border: none;
  cursor: pointer;
}

/* Anchor no default color */
a {
  color: inherit;
  text-decoration: none;
}

/* hr */
hr {
  border: none;
  border-top: 1px solid var(--si-border-dark);
  margin: var(--si-space-8) 0;
}

/* Focus visible — keyboard navigation */
:focus-visible {
  outline: 2px solid var(--si-accent-primary);
  outline-offset: 3px;
  border-radius: var(--si-radius-sm);
}

/* Selection colour */
::selection {
  background-color: var(--si-accent-primary);
  color: var(--si-text-white);
}


/* ============================================================
   2. TYPOGRAPHY
   ============================================================ */

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--si-font-heading);
  font-weight: var(--si-weight-bold);
  line-height: var(--si-leading-tight);
  letter-spacing: var(--si-tracking-tight);
  color: var(--si-text-white);
}

h1 {
  font-size: var(--si-text-5xl);
  font-weight: var(--si-weight-extrabold);
  margin-bottom: var(--si-space-6);
}

h2 {
  font-size: var(--si-text-4xl);
  font-weight: var(--si-weight-bold);
  margin-bottom: var(--si-space-5);
}

h3 {
  font-size: var(--si-text-3xl);
  font-weight: var(--si-weight-semibold);
  margin-bottom: var(--si-space-4);
}

h4 {
  font-size: var(--si-text-2xl);
  font-weight: var(--si-weight-semibold);
  margin-bottom: var(--si-space-4);
}

h5 {
  font-size: var(--si-text-xl);
  font-weight: var(--si-weight-medium);
  margin-bottom: var(--si-space-3);
}

h6 {
  font-size: var(--si-text-lg);
  font-weight: var(--si-weight-medium);
  margin-bottom: var(--si-space-3);
}

p {
  font-size: var(--si-text-base);
  line-height: var(--si-leading-relaxed);
  color: var(--si-text-muted);
  margin-bottom: var(--si-space-4);
}

p:last-child {
  margin-bottom: 0;
}

strong,
b {
  font-weight: var(--si-weight-semibold);
  color: var(--si-text-light);
}

em,
i {
  font-style: italic;
}

small {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
}

/* Inline anchors */
.si-link,
.wp-block-paragraph a,
.entry-content a {
  color: var(--si-accent-light);
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 3px;
  transition: color var(--si-transition-fast),
              text-decoration-color var(--si-transition-fast);
}

.si-link:hover,
.wp-block-paragraph a:hover,
.entry-content a:hover {
  color: var(--si-accent-primary);
}

/* Read-more link inside cards */
.si-read-more {
  display: inline-flex;
  align-items: center;
  gap: var(--si-space-2);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-semibold);
  color: var(--si-accent-light);
  text-decoration: none;
  transition: color var(--si-transition-fast), gap var(--si-transition-fast);
}

.si-read-more:hover {
  color: var(--si-accent-primary);
  gap: var(--si-space-3);
  text-decoration-color: var(--si-accent-primary);
}

/* Section labels / overlines */
.si-overline {
  font-family: var(--si-font-body);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-widest);
  text-transform: uppercase;
  color: var(--si-accent-light);
  display: block;
  margin-bottom: var(--si-space-3);
}

/* Gradient text utility */
.si-text-gradient {
  background: var(--si-gradient-text);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* Lead paragraph */
.si-lead {
  font-size: var(--si-text-lg);
  line-height: var(--si-leading-relaxed);
  color: var(--si-text-light);
}

/* Blockquote */
blockquote {
  border-left: 3px solid var(--si-accent-primary);
  padding-left: var(--si-space-6);
  margin: var(--si-space-8) 0;
  font-style: italic;
  color: var(--si-text-muted);
}

/* Code */
code {
  font-family: var(--si-font-mono);
  font-size: var(--si-text-sm);
  background: var(--si-bg-card);
  color: var(--si-accent-light);
  padding: 0.15em 0.45em;
  border-radius: var(--si-radius-sm);
  border: 1px solid var(--si-border-dark);
}

pre {
  font-family: var(--si-font-mono);
  font-size: var(--si-text-sm);
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-md);
  padding: var(--si-space-6);
  overflow-x: auto;
  line-height: var(--si-leading-relaxed);
}

pre code {
  background: none;
  border: none;
  padding: 0;
}

/* Light section typography overrides */
.si-section-light h1,
.si-section-light h2,
.si-section-light h3,
.si-section-light h4,
.si-section-light h5,
.si-section-light h6 {
  color: var(--si-text-heading);
}

.si-section-light p {
  color: var(--si-text-body);
}

.si-section-light strong {
  color: var(--si-text-dark);
}

.si-section-light .si-overline {
  color: var(--si-accent-primary);
}


/* ============================================================
   3. LAYOUT
   ============================================================ */

/* Primary container */
.si-container {
  width: 100%;
  max-width: var(--si-container-max);
  margin-inline: auto;
  padding-inline: var(--si-container-padding);
}

/* Wide container — for full-bleed layouts with inner constraint */
.si-container-wide {
  width: 100%;
  max-width: var(--si-container-wide);
  margin-inline: auto;
  padding-inline: var(--si-container-padding);
}

/* Narrow container — for focused content (blog, forms, faqs) */
.si-container-narrow {
  width: 100%;
  max-width: var(--si-container-narrow);
  margin-inline: auto;
  padding-inline: var(--si-container-padding);
}

/* Generic section wrapper */
.si-section {
  padding-block: var(--si-section-py);
  padding-inline: var(--si-section-px);
}

/* Dark section — deep navy */
.si-section-dark {
  background-color: var(--si-bg-secondary);
  color: var(--si-text-light);
}

.si-section-dark h1,
.si-section-dark h2,
.si-section-dark h3,
.si-section-dark h4,
.si-section-dark h5,
.si-section-dark h6 {
  color: var(--si-text-white);
}

.si-section-dark p {
  color: var(--si-text-muted);
}

/* Darkest section variant */
.si-section-darkest {
  background-color: var(--si-bg-primary);
  color: var(--si-text-light);
}

.si-section-darkest h1,
.si-section-darkest h2,
.si-section-darkest h3,
.si-section-darkest h4,
.si-section-darkest h5,
.si-section-darkest h6 {
  color: var(--si-text-white);
}

.si-section-darkest p {
  color: var(--si-text-muted);
}

/* Light section — clean white/off-white */
.si-section-light {
  background-color: var(--si-surface-light);
  color: var(--si-text-body);
}

/* Pure white section */
.si-section-white {
  background-color: var(--si-surface-white);
  color: var(--si-text-body);
}

.si-section-white h1,
.si-section-white h2,
.si-section-white h3,
.si-section-white h4,
.si-section-white h5,
.si-section-white h6 {
  color: var(--si-text-heading);
}

.si-section-white p {
  color: var(--si-text-body);
}

/* Gradient section accent */
.si-section-gradient {
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
}

.si-section-gradient h1,
.si-section-gradient h2,
.si-section-gradient h3,
.si-section-gradient h4,
.si-section-gradient h5,
.si-section-gradient h6,
.si-section-gradient p {
  color: var(--si-text-white);
}

/* Smooth section transitions */
.si-section,
.si-section-dark,
.si-section-darkest,
.si-section-light,
.si-section-white,
.si-section-gradient {
  transition: background-color var(--si-transition-slow);
}


/* ============================================================
   4. GRID SYSTEM
   ============================================================ */

/* Base grid */
.si-grid {
  display: grid;
  gap: var(--si-space-8);
  grid-template-columns: 1fr;
}

/* 2-column grid */
.si-grid-2 {
  display: grid;
  gap: var(--si-space-8);
  grid-template-columns: 1fr;
}

/* 3-column grid */
.si-grid-3 {
  display: grid;
  gap: var(--si-space-8);
  grid-template-columns: 1fr;
}

/* 4-column grid */
.si-grid-4 {
  display: grid;
  gap: var(--si-space-6);
  grid-template-columns: 1fr;
}

/* Auto-fit grid — wraps naturally */
.si-grid-auto {
  display: grid;
  gap: var(--si-space-8);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.si-grid-auto-sm {
  display: grid;
  gap: var(--si-space-6);
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* Flex utilities */
.si-flex {
  display: flex;
  gap: var(--si-space-4);
}

.si-flex-col {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-4);
}

.si-flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--si-space-4);
}

.si-flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--si-space-4);
}

.si-flex-start {
  display: flex;
  align-items: flex-start;
  gap: var(--si-space-4);
}

.si-flex-end {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--si-space-4);
}

.si-flex-wrap {
  flex-wrap: wrap;
}

/* Gap modifiers */
.si-gap-2 { gap: var(--si-space-2); }
.si-gap-4 { gap: var(--si-space-4); }
.si-gap-6 { gap: var(--si-space-6); }
.si-gap-8 { gap: var(--si-space-8); }
.si-gap-12 { gap: var(--si-space-12); }

/* Grid alignment */
.si-grid-align-center {
  align-items: center;
}

.si-grid-align-start {
  align-items: flex-start;
}

/* Asymmetric grids */
.si-grid-2-1 {
  display: grid;
  gap: var(--si-space-8);
  grid-template-columns: 1fr;
}


/* ============================================================
   5. BUTTONS
   ============================================================ */

/* Base button — all buttons inherit from this */
.si-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--si-space-2);
  min-height: 44px;
  min-width: 44px;
  padding: var(--si-space-3) var(--si-space-6);
  font-family: var(--si-font-body);
  font-size: var(--si-text-base);
  font-weight: var(--si-weight-semibold);
  line-height: 1;
  letter-spacing: var(--si-tracking-wide);
  border-radius: var(--si-radius-md);
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition:
    background-color var(--si-transition-base),
    border-color var(--si-transition-base),
    color var(--si-transition-base),
    box-shadow var(--si-transition-base),
    transform var(--si-transition-fast);
  position: relative;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
}

.si-btn:active {
  transform: scale(0.97);
}

/* Primary button — gradient fill */
.si-btn-primary {
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
  border-color: transparent;
  box-shadow: 0 4px 15px var(--si-accent-glow);
}

.si-btn-primary:hover,
.si-btn-primary:focus-visible {
  background: var(--si-gradient-cta);
  box-shadow: 0 8px 25px rgba(158, 0, 93, 0.45);
  transform: translateY(-1px);
  color: var(--si-text-white);
}

/* Shimmer effect on primary */
.si-btn-primary::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 40%,
    rgba(255, 255, 255, 0.15) 50%,
    transparent 60%
  );
  transform: translateX(-100%);
  transition: transform 0.6s ease;
}

.si-btn-primary:hover::after {
  transform: translateX(100%);
}

/* Secondary button — outlined */
.si-btn-secondary {
  background: transparent;
  color: var(--si-accent-light);
  border-color: var(--si-accent-primary);
  box-shadow: none;
}

.si-btn-secondary:hover,
.si-btn-secondary:focus-visible {
  background: var(--si-accent-subtle);
  border-color: var(--si-accent-light);
  color: var(--si-text-white);
  box-shadow: 0 0 0 3px var(--si-accent-glow);
}

/* Secondary button on colored CTA sections — make it pop */
.si-cta-section .si-btn-secondary {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(4px);
}
.si-cta-section .si-btn-secondary:hover,
.si-cta-section .si-btn-secondary:focus-visible {
  background: rgba(255, 255, 255, 0.3);
  border-color: #fff;
  color: #fff;
}

/* Ghost button — subtle */
.si-btn-ghost {
  background: transparent;
  color: var(--si-text-muted);
  border-color: var(--si-border-dark);
}

.si-btn-ghost:hover,
.si-btn-ghost:focus-visible {
  background: var(--si-glass-bg);
  color: var(--si-text-light);
  border-color: var(--si-border-accent);
}

/* WhatsApp button */
.si-btn-whatsapp {
  background: var(--si-whatsapp);
  color: var(--si-text-white);
  border-color: transparent;
  box-shadow: 0 4px 15px var(--si-whatsapp-glow);
}

.si-btn-whatsapp:hover,
.si-btn-whatsapp:focus-visible {
  background: var(--si-whatsapp-hover);
  box-shadow: 0 8px 25px rgba(37, 211, 102, 0.45);
  transform: translateY(-1px);
  color: var(--si-text-white);
}

/* CTA / Green button */
.si-btn-cta {
  background: var(--si-cta-primary);
  color: var(--si-text-white);
  border-color: transparent;
  box-shadow: 0 4px 15px var(--si-cta-glow);
}

.si-btn-cta:hover,
.si-btn-cta:focus-visible {
  background: var(--si-cta-hover);
  box-shadow: 0 8px 25px rgba(16, 185, 129, 0.45);
  transform: translateY(-1px);
  color: var(--si-text-white);
}

/* Dark bg variant — for light section use */
.si-btn-dark {
  background: var(--si-bg-primary);
  color: var(--si-text-white);
  border-color: var(--si-border-dark);
}

.si-btn-dark:hover,
.si-btn-dark:focus-visible {
  background: var(--si-bg-secondary);
  border-color: var(--si-accent-primary);
  color: var(--si-text-white);
}

/* Size modifiers */
.si-btn-sm {
  min-height: 44px;
  padding: var(--si-space-2) var(--si-space-4);
  font-size: var(--si-text-sm);
  border-radius: var(--si-radius-sm);
}

.si-btn-lg {
  min-height: 56px;
  padding: var(--si-space-4) var(--si-space-10);
  font-size: var(--si-text-lg);
  border-radius: var(--si-radius-lg);
}

.si-btn-xl {
  min-height: 64px;
  padding: var(--si-space-5) var(--si-space-12);
  font-size: var(--si-text-xl);
  border-radius: var(--si-radius-lg);
}

/* Full-width button */
.si-btn-full {
  width: 100%;
}

/* Icon-only button */
.si-btn-icon {
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: var(--si-radius-md);
}

.si-btn-icon-lg {
  width: 56px;
  height: 56px;
  padding: 0;
  border-radius: var(--si-radius-lg);
}

/* Rounded pill buttons */
.si-btn-rounded {
  border-radius: var(--si-radius-full);
}

/* Disabled state */
.si-btn:disabled,
.si-btn[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}


/* ============================================================
   6. CARDS
   ============================================================ */

/* Base card */
.si-card {
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-lg);
  padding: var(--si-space-8);
  transition:
    transform var(--si-transition-base),
    box-shadow var(--si-transition-base),
    border-color var(--si-transition-base);
  position: relative;
  overflow: hidden;
}

.si-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--si-shadow-dark-lg);
  border-color: var(--si-border-accent);
}

/* Card with subtle gradient top border */
.si-card-accent {
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-lg);
  padding: var(--si-space-8);
  transition:
    transform var(--si-transition-base),
    box-shadow var(--si-transition-base);
  position: relative;
  overflow: hidden;
}

.si-card-accent::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--si-gradient-primary);
  opacity: 0;
  transition: opacity var(--si-transition-base);
}

.si-card-accent:hover::before {
  opacity: 1;
}

.si-card-accent:hover {
  transform: translateY(-4px);
  box-shadow: var(--si-shadow-dark-lg);
}

/* Dark card — deeper background */
.si-card-dark {
  background: var(--si-bg-secondary);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-lg);
  padding: var(--si-space-8);
  transition:
    transform var(--si-transition-base),
    box-shadow var(--si-transition-base),
    border-color var(--si-transition-base);
}

.si-card-dark:hover {
  transform: translateY(-4px);
  box-shadow:
    var(--si-shadow-dark-lg),
    var(--si-shadow-glow);
  border-color: var(--si-border-accent);
}

/* Glassmorphism card */
.si-card-glass {
  background: var(--si-glass-bg);
  border: 1px solid var(--si-glass-border);
  border-radius: var(--si-radius-lg);
  padding: var(--si-space-8);
  backdrop-filter: var(--si-glass-blur);
  -webkit-backdrop-filter: var(--si-glass-blur);
  transition:
    transform var(--si-transition-base),
    box-shadow var(--si-transition-base),
    background var(--si-transition-base);
}

.si-card-glass:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: var(--si-shadow-dark-lg);
}

/* Light card — for light sections */
.si-card-light {
  background: var(--si-surface-white);
  border: 1px solid var(--si-border-light);
  border-radius: var(--si-radius-lg);
  padding: var(--si-space-8);
  box-shadow: var(--si-shadow-card);
  transition:
    transform var(--si-transition-base),
    box-shadow var(--si-transition-base);
}

.si-card-light:hover {
  transform: translateY(-4px);
  box-shadow: var(--si-shadow-card-hover);
}

.si-card-light .si-card-title {
  color: var(--si-text-heading);
}

.si-card-light p {
  color: var(--si-text-body);
}

.si-card-light li {
  color: var(--si-text-body);
}

/* Checklist */
.si-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-3);
}

.si-checklist li {
  display: flex;
  align-items: flex-start;
  gap: var(--si-space-3);
  font-size: var(--si-text-base);
  line-height: var(--si-leading-relaxed);
}

.si-checklist li::before {
  content: '✓';
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: var(--si-radius-full);
  background: var(--si-accent-subtle);
  color: var(--si-accent-light);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-bold);
  margin-top: 2px;
}

.si-checklist-light li {
  color: var(--si-text-light);
}

/* Service card */
.si-service-card {
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-lg);
  padding: var(--si-space-8);
  text-align: center;
  transition:
    transform var(--si-transition-base),
    box-shadow var(--si-transition-base),
    border-color var(--si-transition-base),
    background var(--si-transition-base);
  position: relative;
  overflow: hidden;
}

.si-service-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--si-gradient-card);
  opacity: 0;
  transition: opacity var(--si-transition-base);
  z-index: 0;
}

.si-service-card > * {
  position: relative;
  z-index: 1;
}

.si-service-card:hover {
  transform: translateY(-6px);
  border-color: var(--si-accent-primary);
  box-shadow:
    var(--si-shadow-dark-lg),
    0 0 30px var(--si-accent-glow);
}

.si-service-card:hover::before {
  opacity: 1;
}

/* Service card icon */
.si-service-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: var(--si-accent-subtle);
  border-radius: var(--si-radius-md);
  margin-bottom: var(--si-space-5);
  color: var(--si-accent-light);
  font-size: var(--si-text-2xl);
  transition: background var(--si-transition-base), color var(--si-transition-base);
}

.si-service-card:hover .si-service-card-icon {
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
}

/* Card header / footer separators */
.si-card-header {
  padding-bottom: var(--si-space-5);
  border-bottom: 1px solid var(--si-border-dark);
  margin-bottom: var(--si-space-5);
}

.si-card-footer {
  padding-top: var(--si-space-5);
  border-top: 1px solid var(--si-border-dark);
  margin-top: var(--si-space-5);
}


/* ============================================================
   7. NAVIGATION
   ============================================================ */

/* Sticky header */
.si-header {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--si-z-nav);
  background: rgba(10, 10, 26, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--si-border-dark);
  transition: background var(--si-transition-base), box-shadow var(--si-transition-base);
}

.si-header.scrolled {
  background: rgba(10, 10, 26, 0.97);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

.si-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: var(--si-space-4);
  padding-inline: var(--si-container-padding);
  max-width: var(--si-container-max);
  margin-inline: auto;
  min-height: 70px;
}

/* Logo */
.si-logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
}

.si-logo img {
  max-height: 40px;
  width: auto;
  display: block;
}

.si-logo-text {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-xl);
  font-weight: var(--si-weight-bold);
  color: var(--si-text-white);
  letter-spacing: var(--si-tracking-tight);
}

/* Primary navigation */
.si-nav {
  display: flex;
  align-items: center;
  gap: var(--si-space-2);
}

/* Nav links list */
.si-nav-links {
  display: none; /* hidden on mobile — shown via responsive.css */
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;
  gap: var(--si-space-1);
}

/* Individual nav link */
.si-nav-link {
  display: inline-flex;
  align-items: center;
  gap: var(--si-space-1);
  padding: var(--si-space-2) var(--si-space-3);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-medium);
  color: var(--si-text-light);
  text-decoration: none;
  border-radius: var(--si-radius-sm);
  position: relative;
  transition: color var(--si-transition-fast);
  min-height: 44px;
}

/* Animated underline on hover */
.si-nav-link::after {
  content: '';
  position: absolute;
  bottom: 4px;
  left: var(--si-space-3);
  right: var(--si-space-3);
  height: 2px;
  background: var(--si-gradient-primary);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--si-transition-base);
  border-radius: var(--si-radius-full);
}

.si-nav-link:hover,
.si-nav-link:focus-visible,
.si-nav-link[aria-current="page"] {
  color: var(--si-text-white);
}

.si-nav-link:hover::after,
.si-nav-link:focus-visible::after,
.si-nav-link[aria-current="page"]::after {
  transform: scaleX(1);
}

/* Nav CTA button area */
.si-nav-cta {
  display: none; /* shown in responsive.css */
  align-items: center;
  gap: var(--si-space-3);
  margin-left: var(--si-space-4);
}

/* Hamburger — visible on mobile */
.si-hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  gap: 5px;
  cursor: pointer;
  border-radius: var(--si-radius-sm);
  background: transparent;
  border: 1px solid var(--si-border-dark);
  transition: border-color var(--si-transition-fast), background var(--si-transition-fast);
  -webkit-tap-highlight-color: transparent;
}

.si-hamburger:hover {
  border-color: var(--si-accent-primary);
  background: var(--si-accent-subtle);
}

.si-hamburger-line {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--si-text-light);
  border-radius: var(--si-radius-full);
  transition: transform var(--si-transition-base), opacity var(--si-transition-base);
  transform-origin: center;
}

/* Hamburger open state */
.si-hamburger[aria-expanded="true"] .si-hamburger-line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.si-hamburger[aria-expanded="true"] .si-hamburger-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.si-hamburger[aria-expanded="true"] .si-hamburger-line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile menu overlay */
.si-mobile-menu {
  position: fixed;
  inset: 0;
  z-index: var(--si-z-overlay);
  background: var(--si-bg-primary);
  display: flex;
  flex-direction: column;
  padding: var(--si-space-6) var(--si-container-padding);
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform var(--si-transition-slow);
}

.si-mobile-menu[aria-hidden="false"] {
  transform: translateX(0);
}

.si-mobile-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--si-space-10);
  padding-bottom: var(--si-space-6);
  border-bottom: 1px solid var(--si-border-dark);
}

.si-mobile-menu-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-sm);
  color: var(--si-text-muted);
  cursor: pointer;
  transition: color var(--si-transition-fast), border-color var(--si-transition-fast);
}

.si-mobile-menu-close:hover {
  color: var(--si-text-white);
  border-color: var(--si-accent-primary);
}

.si-mobile-nav-links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-2);
  flex: 1;
}

.si-mobile-nav-link {
  display: flex;
  align-items: center;
  padding: var(--si-space-4);
  font-size: var(--si-text-lg);
  font-weight: var(--si-weight-medium);
  color: var(--si-text-muted);
  text-decoration: none;
  border-radius: var(--si-radius-md);
  border: 1px solid transparent;
  transition:
    color var(--si-transition-fast),
    background var(--si-transition-fast),
    border-color var(--si-transition-fast);
  min-height: 56px;
}

.si-mobile-nav-link:hover,
.si-mobile-nav-link[aria-current="page"] {
  color: var(--si-text-white);
  background: var(--si-accent-subtle);
  border-color: var(--si-border-accent);
}

/* Mobile sub-menu accordion */
.si-mobile-nav-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--si-space-4);
  font-size: var(--si-text-lg);
  font-weight: var(--si-weight-medium);
  color: var(--si-text-muted);
  background: none;
  border: none;
  border-radius: var(--si-radius-md);
  cursor: pointer;
  min-height: 56px;
  transition: color var(--si-transition-fast), background var(--si-transition-fast);
}

.si-mobile-nav-toggle:hover {
  color: var(--si-text-white);
  background: var(--si-accent-subtle);
}

.si-mobile-nav-toggle svg {
  transition: transform var(--si-transition-base);
}

.si-mobile-nav-parent.is-open .si-mobile-nav-toggle svg {
  transform: rotate(180deg);
}

.si-mobile-nav-sub {
  display: none;
  flex-direction: column;
  padding-left: var(--si-space-4);
  gap: var(--si-space-1);
}

.si-mobile-nav-parent.is-open .si-mobile-nav-sub {
  display: flex;
}

.si-mobile-nav-sub a {
  display: block;
  padding: var(--si-space-3) var(--si-space-4);
  font-size: var(--si-text-base);
  color: var(--si-text-muted);
  text-decoration: none;
  border-radius: var(--si-radius-sm);
  transition: color var(--si-transition-fast), background var(--si-transition-fast);
}

.si-mobile-nav-sub a:hover {
  color: var(--si-text-white);
  background: var(--si-accent-subtle);
}

/* Mobile menu panel & footer */
.si-mobile-menu-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.si-mobile-menu-footer {
  margin-top: auto;
  padding-top: var(--si-space-6);
  border-top: 1px solid var(--si-border-dark);
}

.si-mobile-menu-contact {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-3);
}

.si-mobile-menu-contact a {
  display: flex;
  align-items: center;
  gap: var(--si-space-2);
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  text-decoration: none;
  transition: color var(--si-transition-fast);
}

.si-mobile-menu-contact a:hover {
  color: var(--si-text-white);
}

.si-mobile-menu-cta {
  padding-top: var(--si-space-8);
  border-top: 1px solid var(--si-border-dark);
  display: flex;
  flex-direction: column;
  gap: var(--si-space-3);
}

/* Dropdown nav */
.si-nav-item--has-dropdown {
  position: relative;
}

.si-nav-dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 240px;
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-md);
  box-shadow: var(--si-shadow-dark-lg);
  padding: var(--si-space-2);
  padding-top: calc(var(--si-space-2) + 8px);
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition:
    opacity var(--si-transition-base),
    transform var(--si-transition-base),
    visibility var(--si-transition-base);
  z-index: var(--si-z-dropdown);
}

/* Bridge element to prevent hover gap */
.si-nav-item--has-dropdown::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: 12px;
  pointer-events: none;
}

.si-nav-item--has-dropdown:hover::after {
  pointer-events: auto;
}

.si-nav-item--has-dropdown:hover .si-nav-dropdown,
.si-nav-item--has-dropdown:focus-within .si-nav-dropdown,
.si-nav-item--has-dropdown.is-focused .si-nav-dropdown {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.si-nav-dropdown li a {
  display: block;
  padding: var(--si-space-3) var(--si-space-4);
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  border-radius: var(--si-radius-sm);
  text-decoration: none;
  transition: color var(--si-transition-fast), background var(--si-transition-fast);
}

.si-nav-dropdown li a:hover {
  color: var(--si-text-white);
  background: var(--si-accent-subtle);
}

/* Mega dropdown (multi-column for Industries) */
.si-nav-dropdown--mega {
  min-width: 420px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}


/* ============================================================
   8. HERO
   ============================================================ */

.si-hero {
  min-height: 85vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-block: var(--si-space-20);
  padding-inline: var(--si-container-padding);
  background: var(--si-gradient-hero);
  position: relative;
  overflow: hidden;
}

/* Subtle noise/grid overlay */
.si-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 50%, rgba(158, 0, 93, 0.12) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(251, 191, 36, 0.1) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}

/* Hero glow orb */
.si-hero::after {
  content: '';
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(158, 0, 93, 0.08) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.si-hero > * {
  position: relative;
  z-index: 1;
}

.si-hero-inner {
  width: 100%;
  max-width: var(--si-container-narrow);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--si-space-6);
}

/* Small badge above the title */
.si-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--si-space-2);
  padding: var(--si-space-2) var(--si-space-4);
  background: var(--si-accent-subtle);
  border: 1px solid var(--si-border-accent);
  border-radius: var(--si-radius-full);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-widest);
  text-transform: uppercase;
  color: var(--si-accent-light);
}

.si-hero-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: var(--si-radius-full);
  background: var(--si-accent-light);
  animation: pulse-dot 2s infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.75); }
}

/* Hero title */
.si-hero-title {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-hero);
  font-weight: var(--si-weight-extrabold);
  line-height: var(--si-leading-tight);
  letter-spacing: var(--si-tracking-tight);
  color: var(--si-text-white);
  margin: 0;
}

/* Hero subtitle */
.si-hero-subtitle {
  font-size: var(--si-text-lg);
  line-height: var(--si-leading-relaxed);
  color: var(--si-text-light);
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}

/* Hero CTA group */
.si-hero-cta-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--si-space-3);
  width: 100%;
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
}

.si-hero-cta-group .si-btn {
  width: 100%;
}

/* Hero social proof / trust indicators */
.si-hero-trust {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--si-space-2);
  font-size: var(--si-text-sm);
  color: var(--si-text-light);
  margin-top: var(--si-space-2);
}

.si-hero-trust-faces {
  display: flex;
  align-items: center;
}

.si-hero-trust-face {
  width: 32px;
  height: 32px;
  border-radius: var(--si-radius-full);
  border: 2px solid var(--si-bg-primary);
  object-fit: cover;
  margin-left: -8px;
}

.si-hero-trust-face:first-child {
  margin-left: 0;
}

/* ── Service Page Hero ─────────────────────────────────────────────── */
.si-hero-service {
  padding-block: var(--si-space-16) var(--si-space-12);
}

.si-hero-content {
  max-width: 820px;
  margin-inline: auto;
  text-align: center;
}

.si-hero-content .si-hero-title {
  margin-bottom: var(--si-space-5);
}

.si-hero-content .si-hero-subtitle {
  max-width: 680px;
  margin-inline: auto;
  margin-bottom: var(--si-space-3);
}

.si-hero-content .si-hero-cta-group {
  margin-top: var(--si-space-6);
  max-width: none;
  justify-content: center;
}

/* Service keyword tags below CTA */
.si-service-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--si-space-2);
  margin-top: var(--si-space-6);
}

/* ── Inner Page Hero (about, contact, pricing, etc.) ──────────────── */
.si-hero-inner-content {
  max-width: 800px;
  margin-inline: auto;
}


/* ============================================================
   9. FOOTER
   ============================================================ */

.si-footer {
  background: var(--si-bg-primary);
  border-top: 1px solid var(--si-border-dark);
  padding-top: var(--si-space-20);
  border-radius: 0;
}

.si-footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--si-space-10);
  padding-bottom: var(--si-space-12);
}

/* Footer brand column */
.si-footer-brand {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-5);
}

.si-footer-logo img {
  max-height: 36px;
  width: auto;
}

.si-footer-tagline,
.si-footer-description {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  line-height: var(--si-leading-relaxed);
  max-width: 300px;
  margin: 0;
}

/* Footer column alias (HTML uses .si-footer-about for brand col) */
.si-footer-about {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-5);
}

/* Footer navigation columns */
.si-footer-nav-title,
.si-footer-heading {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-widest);
  text-transform: uppercase;
  color: var(--si-text-white);
  margin-bottom: var(--si-space-5);
}

.si-footer-nav-list,
.si-footer-nav,
.si-footer-contact {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-3);
}

.si-footer-nav-link,
.si-footer-nav a,
.si-footer-contact a,
.si-footer-contact li {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  text-decoration: none;
  transition: color var(--si-transition-fast);
  display: inline-flex;
  align-items: center;
  gap: var(--si-space-2);
  min-height: 44px;
  padding-block: var(--si-space-1);
}

.si-footer-nav-link:hover,
.si-footer-nav a:hover,
.si-footer-contact a:hover {
  color: var(--si-text-white);
}

/* Social icons in footer */
.si-footer-social,
.si-social-links {
  display: flex;
  gap: var(--si-space-3);
  flex-wrap: wrap;
}

.si-footer-social-link,
.si-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-md);
  color: var(--si-text-muted);
  font-size: var(--si-text-base);
  text-decoration: none;
  transition:
    color var(--si-transition-fast),
    background var(--si-transition-fast),
    border-color var(--si-transition-fast);
}

.si-footer-social-link:hover,
.si-social-link:hover {
  color: var(--si-text-white);
  background: var(--si-accent-subtle);
  border-color: var(--si-accent-primary);
}

/* Footer bottom bar */
.si-footer-bottom {
  border-top: 1px solid var(--si-border-dark);
  padding-block: var(--si-space-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--si-space-3);
  text-align: center;
}

.si-footer-copyright {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  margin: 0;
}

.si-footer-legal {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--si-space-4);
  list-style: none;
  margin: 0;
  padding: 0;
}

.si-footer-legal-link,
.si-footer-legal a {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  text-decoration: none;
  transition: color var(--si-transition-fast);
}

.si-footer-legal-link:hover,
.si-footer-legal a:hover {
  color: var(--si-text-light);
}


/* ============================================================
   10. STATS / COUNTER
   ============================================================ */

.si-stats-section {
  padding-block: var(--si-section-py);
  padding-inline: var(--si-container-padding);
}

.si-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--si-space-6);
}

.si-stat-card {
  text-align: center;
  padding: var(--si-space-8) var(--si-space-4);
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-lg);
  transition: transform var(--si-transition-base), border-color var(--si-transition-base);
}

.si-stat-card:hover {
  transform: translateY(-2px);
  border-color: var(--si-border-accent);
}

.si-stat-number {
  display: inline-block;
  font-family: var(--si-font-mono);
  font-size: var(--si-text-4xl);
  font-weight: var(--si-weight-extrabold);
  color: var(--si-accent-light);
  line-height: 1;
  letter-spacing: var(--si-tracking-tight);
}

.si-stat-suffix {
  display: inline;
  font-family: var(--si-font-mono);
  font-size: var(--si-text-2xl);
  font-weight: var(--si-weight-bold);
  color: var(--si-accent-light);
}

.si-stat-label {
  display: block;
  margin-top: var(--si-space-2);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-medium);
  letter-spacing: var(--si-tracking-wider);
  text-transform: uppercase;
  color: var(--si-text-light);
}

.si-stat-detail {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  line-height: var(--si-leading-relaxed);
  margin-top: var(--si-space-3);
  text-align: justify;
}

.si-stat-highlight {
  text-align: center;
  padding: var(--si-space-6);
  background: var(--si-accent-subtle);
  border-radius: var(--si-radius-lg);
  border: 1px solid var(--si-border-accent);
}

/* Divider variant — horizontal rule between stats */
.si-stats-inline {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.si-stats-inline .si-stat-card {
  background: transparent;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid var(--si-border-dark);
  padding: var(--si-space-6) 0;
}

.si-stats-inline .si-stat-card:last-child {
  border-bottom: none;
}


/* ============================================================
   11. TESTIMONIALS
   ============================================================ */

.si-testimonials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--si-space-6);
}

.si-testimonial-card {
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-lg);
  padding: var(--si-space-8);
  position: relative;
  transition: transform var(--si-transition-base), border-color var(--si-transition-base);
}

.si-testimonial-card:hover {
  transform: translateY(-3px);
  border-color: var(--si-border-accent);
}

/* Large decorative quote mark */
.si-testimonial-card::before {
  content: '\201C';
  position: absolute;
  top: var(--si-space-5);
  right: var(--si-space-6);
  font-family: var(--si-font-heading);
  font-size: 5rem;
  line-height: 1;
  color: var(--si-accent-primary);
  opacity: 0.15;
  pointer-events: none;
  user-select: none;
}

/* Star rating */
.si-testimonial-stars {
  display: flex;
  gap: var(--si-space-1);
  margin-bottom: var(--si-space-4);
  color: var(--si-warning);
  font-size: var(--si-text-sm);
}

/* Quote text */
.si-testimonial-text {
  font-size: var(--si-text-base);
  font-style: italic;
  line-height: var(--si-leading-relaxed);
  color: var(--si-text-light);
  margin-bottom: var(--si-space-6);
  position: relative;
  z-index: 1;
}

/* Author block */
.si-testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--si-space-3);
  border-top: 1px solid var(--si-border-dark);
  padding-top: var(--si-space-5);
}

.si-testimonial-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--si-radius-full);
  object-fit: cover;
  border: 2px solid var(--si-border-accent);
  flex-shrink: 0;
}

.si-testimonial-avatar-placeholder {
  width: 48px;
  height: 48px;
  border-radius: var(--si-radius-full);
  background: var(--si-gradient-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--si-font-heading);
  font-weight: var(--si-weight-bold);
  color: var(--si-text-white);
  font-size: var(--si-text-base);
  flex-shrink: 0;
}

.si-testimonial-author-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.si-testimonial-name {
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-semibold);
  color: var(--si-text-white);
  margin: 0;
  line-height: 1.3;
}

.si-testimonial-role {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  margin: 0;
  line-height: 1.3;
}

.si-testimonial-company {
  font-size: var(--si-text-xs);
  color: var(--si-accent-light);
  margin: 0;
  line-height: 1.3;
}


/* ============================================================
   12. FAQ
   ============================================================ */

.si-faq-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.si-faq-item {
  border-bottom: 1px solid var(--si-border-dark);
}

.si-faq-item:first-child {
  border-top: 1px solid var(--si-border-dark);
}

/* Clickable question row */
.si-faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--si-space-4);
  padding: var(--si-space-5) 0;
  cursor: pointer;
  font-family: var(--si-font-heading);
  font-size: var(--si-text-base);
  font-weight: var(--si-weight-semibold);
  color: var(--si-text-white);
  background: none;
  border: none;
  text-align: left;
  width: 100%;
  min-height: 56px;
  transition: color var(--si-transition-fast);
}

.si-faq-question:hover {
  color: var(--si-accent-light);
}

.si-faq-question-text {
  flex: 1;
}

/* Rotating icon */
.si-faq-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  color: var(--si-accent-primary);
  transition: transform var(--si-transition-base);
}

.si-faq-item[open] .si-faq-icon,
.si-faq-item.is-open .si-faq-icon {
  transform: rotate(45deg);
}

/* Answer — hidden by default, revealed via JS toggle of .is-open */
.si-faq-answer {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.4s ease, opacity 0.3s ease;
}

.si-faq-item.is-open .si-faq-answer {
  max-height: 600px;
  opacity: 1;
}

.si-faq-answer-inner {
  padding-bottom: var(--si-space-5);
  font-size: var(--si-text-base);
  color: var(--si-text-light);
  line-height: var(--si-leading-relaxed);
}

/* FAQ answer paragraphs when no inner wrapper is used */
.si-faq-answer > p {
  padding-bottom: var(--si-space-5);
  font-size: var(--si-text-base);
  color: var(--si-text-light);
  line-height: var(--si-leading-relaxed);
  text-align: justify;
}

/* Native details/summary variant */
details.si-faq-item > summary {
  list-style: none;
  cursor: pointer;
}

details.si-faq-item > summary::-webkit-details-marker {
  display: none;
}

details.si-faq-item[open] .si-faq-icon {
  transform: rotate(45deg);
}


/* ============================================================
   13. FORMS
   ============================================================ */

.si-form {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-5);
}

.si-form-group {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-2);
  margin-bottom: var(--si-space-5);
}

.si-form-group:last-child {
  margin-bottom: 0;
}

/* Label */
.si-label,
.si-form-label {
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-medium);
  color: var(--si-text-light);
  letter-spacing: var(--si-tracking-wide);
}

.si-label-required::after {
  content: ' *';
  color: var(--si-error);
}

.si-required {
  color: var(--si-error);
}

/* Link accent */
.si-link-accent {
  color: var(--si-accent-light);
  text-decoration: underline;
  text-decoration-color: var(--si-accent-primary);
  text-underline-offset: 3px;
  transition: color var(--si-transition-fast);
}

.si-link-accent:hover {
  color: var(--si-accent-primary);
}

/* Trust list (sidebar) */
.si-trust-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-4);
}

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

.si-trust-item svg {
  flex-shrink: 0;
  color: var(--si-success);
  margin-top: 2px;
}

/* Steps list (sidebar) */
.si-steps-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: step;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-5);
}

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

.si-step-number {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: var(--si-radius-full);
  background: var(--si-accent-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: var(--si-text-sm);
}

/* Hours table */
.si-hours-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--si-text-sm);
}

.si-hours-table td {
  padding: var(--si-space-2) var(--si-space-3);
  border-bottom: 1px solid var(--si-border-dark);
  color: var(--si-text-muted);
}

.si-hours-table td:first-child {
  font-weight: 600;
  color: var(--si-text-light);
}

/* Negative list (about page) */
.si-list-negative {
  list-style: none;
  padding: 0;
}

.si-list-negative li {
  position: relative;
  padding-left: var(--si-space-6);
  margin-bottom: var(--si-space-2);
  color: var(--si-text-muted);
}

.si-list-negative li::before {
  content: '✕';
  position: absolute;
  left: 0;
  color: var(--si-error);
  font-weight: 700;
}

/* Blog single */
.si-blog-single-header {
  margin-bottom: var(--si-space-8);
}

.si-blog-single-title {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-4xl);
  font-weight: var(--si-weight-bold);
  line-height: var(--si-leading-tight);
  color: var(--si-text-white);
  margin-bottom: var(--si-space-4);
}

.si-blog-single-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--si-space-3);
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
}

.si-meta-separator {
  color: var(--si-border-dark);
}

.si-blog-single-cover {
  margin-top: var(--si-space-8);
  margin-bottom: var(--si-space-8);
  border-radius: var(--si-radius-xl);
  overflow: hidden;
}

.si-blog-single-cover img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.si-blog-single-content {
  font-size: var(--si-text-base);
  line-height: var(--si-leading-relaxed);
  color: var(--si-text-light);
}

.si-blog-single-content h2 {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-2xl);
  font-weight: var(--si-weight-bold);
  color: var(--si-text-white);
  margin-top: var(--si-space-10);
  margin-bottom: var(--si-space-4);
}

.si-blog-single-content h3 {
  font-size: var(--si-text-xl);
  font-weight: var(--si-weight-semibold);
  color: var(--si-text-white);
  margin-top: var(--si-space-8);
  margin-bottom: var(--si-space-3);
}

.si-blog-single-content p {
  margin-bottom: var(--si-space-4);
}

.si-blog-single-content ul,
.si-blog-single-content ol {
  padding-left: var(--si-space-6);
  margin-bottom: var(--si-space-4);
}

.si-blog-single-content li {
  margin-bottom: var(--si-space-2);
}

.si-blog-single-content a {
  color: var(--si-accent-light);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.si-blog-single-content a:hover {
  color: var(--si-accent-primary);
}

.si-blog-single-content blockquote {
  border-left: 3px solid var(--si-accent-primary);
  padding-left: var(--si-space-5);
  margin: var(--si-space-6) 0;
  font-style: italic;
  color: var(--si-text-light);
}

/* Form row layout */
.si-form-row {
  display: flex;
  gap: var(--si-space-4);
  flex-wrap: wrap;
}

.si-form-row-2 > .si-form-group {
  flex: 1 1 calc(50% - var(--si-space-2));
  min-width: 200px;
}

/* Base input / textarea / select */
.si-input,
.si-form-input,
.si-textarea,
.si-form-textarea,
.si-select,
.si-form-select {
  width: 100%;
  padding: var(--si-space-3) var(--si-space-4);
  min-height: 48px;
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-md);
  font-family: var(--si-font-body);
  font-size: var(--si-text-base);
  color: var(--si-text-white);
  transition:
    border-color var(--si-transition-fast),
    box-shadow var(--si-transition-fast),
    background var(--si-transition-fast);
  appearance: none;
  -webkit-appearance: none;
}

.si-input::placeholder,
.si-form-input::placeholder,
.si-textarea::placeholder,
.si-form-textarea::placeholder {
  color: var(--si-text-muted);
  opacity: 1;
}

/* Focus state */
.si-input:focus,
.si-form-input:focus,
.si-textarea:focus,
.si-form-textarea:focus,
.si-select:focus,
.si-form-select:focus {
  outline: none;
  border-color: var(--si-accent-primary);
  box-shadow: 0 0 0 3px var(--si-accent-glow);
  background: var(--si-bg-card-hover);
}

/* Hover state */
.si-input:hover:not(:focus),
.si-form-input:hover:not(:focus),
.si-textarea:hover:not(:focus),
.si-form-textarea:hover:not(:focus),
.si-select:hover:not(:focus),
.si-form-select:hover:not(:focus) {
  border-color: rgba(255, 255, 255, 0.15);
}

/* Error state */
.si-input.has-error,
.si-form-input.has-error,
.si-textarea.has-error,
.si-form-textarea.has-error,
.si-select.has-error,
.si-form-select.has-error {
  border-color: var(--si-error);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15);
}

/* Success state */
.si-input.is-valid,
.si-form-input.is-valid,
.si-textarea.is-valid,
.si-form-textarea.is-valid,
.si-select.is-valid,
.si-form-select.is-valid {
  border-color: var(--si-success);
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.15);
}

/* Textarea */
.si-textarea {
  min-height: 140px;
  resize: vertical;
  line-height: var(--si-leading-relaxed);
}

/* Select */
.si-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--si-space-4) center;
  background-size: 16px;
  padding-right: var(--si-space-10);
  cursor: pointer;
}

.si-select option {
  background: var(--si-bg-secondary);
  color: var(--si-text-white);
}

/* Light form variant — for use on light sections */
.si-input-light,
.si-textarea-light,
.si-select-light {
  background: var(--si-surface-white);
  border-color: var(--si-border-light);
  color: var(--si-text-dark);
}

.si-input-light::placeholder,
.si-textarea-light::placeholder {
  color: #9CA3AF;
}

.si-input-light:focus,
.si-textarea-light:focus,
.si-select-light:focus {
  background: var(--si-surface-white);
  border-color: var(--si-accent-primary);
  box-shadow: 0 0 0 3px var(--si-accent-glow);
}

/* Form feedback text */
.si-form-hint {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  margin-top: var(--si-space-1);
}

.si-form-error {
  font-size: var(--si-text-xs);
  color: var(--si-error);
  margin-top: var(--si-space-1);
  display: flex;
  align-items: center;
  gap: var(--si-space-1);
}

.si-form-success {
  font-size: var(--si-text-xs);
  color: var(--si-success);
  margin-top: var(--si-space-1);
}

/* Checkbox / radio */
.si-checkbox,
.si-radio {
  display: flex;
  align-items: flex-start;
  gap: var(--si-space-3);
  cursor: pointer;
  min-height: 44px;
  padding-block: var(--si-space-1);
}

.si-checkbox input[type="checkbox"],
.si-radio input[type="radio"] {
  width: 18px;
  height: 18px;
  min-width: 18px;
  accent-color: var(--si-accent-primary);
  cursor: pointer;
  margin-top: 2px;
}

.si-checkbox-label,
.si-radio-label {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  line-height: var(--si-leading-relaxed);
}


/* ============================================================
   14. BADGES / PILLS
   ============================================================ */

/* Base badge */
.si-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--si-space-1);
  padding: var(--si-space-1) var(--si-space-3);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-widest);
  text-transform: uppercase;
  border-radius: var(--si-radius-full);
  line-height: 1;
  white-space: nowrap;
}

/* Default accent badge */
.si-badge {
  background: var(--si-accent-subtle);
  color: var(--si-accent-light);
  border: 1px solid var(--si-border-accent);
}

/* Colour variants */
.si-badge-new {
  background: rgba(16, 185, 129, 0.1);
  color: var(--si-success);
  border: 1px solid rgba(16, 185, 129, 0.2);
}

.si-badge-exclusive {
  background: rgba(251, 191, 36, 0.1);
  color: #A78BFA;
  border: 1px solid rgba(251, 191, 36, 0.2);
}

.si-badge-hot {
  background: rgba(239, 68, 68, 0.1);
  color: var(--si-error);
  border: 1px solid rgba(239, 68, 68, 0.2);
}

.si-badge-warning {
  background: rgba(245, 158, 11, 0.1);
  color: var(--si-warning);
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.si-badge-dark {
  background: var(--si-bg-card);
  color: var(--si-text-muted);
  border: 1px solid var(--si-border-dark);
}

.si-badge-gradient {
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
  border: none;
}

.si-badge-outline {
  background: transparent;
  border: 1px solid var(--si-accent-primary);
  color: var(--si-accent-light);
}

/* Card badge — positioned at top-right of a card */
.si-card-badge {
  position: absolute;
  top: var(--si-space-3);
  right: var(--si-space-3);
  padding: var(--si-space-1) var(--si-space-3);
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-wider);
  text-transform: uppercase;
  border-radius: var(--si-radius-full);
  z-index: 1;
}

/* Pill — rounder, used for service/category tags */
.si-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--si-space-2);
  padding: var(--si-space-2) var(--si-space-4);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-medium);
  border-radius: var(--si-radius-full);
  background: var(--si-bg-secondary);
  color: var(--si-text-light);
  border: 1px solid var(--si-border-dark);
  white-space: nowrap;
  transition: color var(--si-transition-fast), border-color var(--si-transition-fast), background var(--si-transition-fast);
}

.si-pill:hover,
.si-pill.is-active {
  color: var(--si-accent-light);
  border-color: var(--si-border-accent);
  background: var(--si-accent-subtle);
}

/* Pill list — horizontal scrollable row */
.si-pill-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--si-space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}


/* ============================================================
   15. BREADCRUMBS
   ============================================================ */

.si-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--si-space-2);
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
}

.si-breadcrumb-item {
  display: inline-flex;
  align-items: center;
  gap: var(--si-space-2);
}

/* Separator between items */
.si-breadcrumb-item:not(:last-child)::after {
  content: '/';
  color: var(--si-text-muted);
  opacity: 0.5;
  font-size: var(--si-text-xs);
}

.si-breadcrumb-link {
  color: var(--si-text-muted);
  text-decoration: none;
  transition: color var(--si-transition-fast);
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.si-breadcrumb-link:hover {
  color: var(--si-accent-light);
}

/* Current page — not a link */
.si-breadcrumb-item[aria-current="page"] {
  color: var(--si-text-light);
  font-weight: var(--si-weight-medium);
}

/* Light section breadcrumb override */
.si-section-light .si-breadcrumb,
.si-section-white .si-breadcrumb {
  color: var(--si-text-body);
}

.si-section-light .si-breadcrumb-link,
.si-section-white .si-breadcrumb-link {
  color: var(--si-text-body);
}

.si-section-light .si-breadcrumb-link:hover,
.si-section-white .si-breadcrumb-link:hover {
  color: var(--si-accent-primary);
}

.si-section-light .si-breadcrumb-item[aria-current="page"],
.si-section-white .si-breadcrumb-item[aria-current="page"] {
  color: var(--si-text-dark);
}


/* ============================================================
   16. WHATSAPP FLOAT
   ============================================================ */

.si-whatsapp-float {
  position: fixed;
  bottom: var(--si-space-6);
  right: var(--si-space-5);
  z-index: var(--si-z-whatsapp);
  width: 60px;
  height: 60px;
  min-width: 60px;
  min-height: 60px;
  border-radius: var(--si-radius-full);
  background: var(--si-whatsapp);
  color: var(--si-text-white);
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  box-shadow:
    0 4px 20px var(--si-whatsapp-glow),
    0 2px 8px rgba(0, 0, 0, 0.25);
  transition:
    background var(--si-transition-base),
    transform var(--si-transition-base),
    box-shadow var(--si-transition-base);
  animation: whatsapp-pulse 3s ease-in-out infinite;
}

.si-whatsapp-float:hover,
.si-whatsapp-float:focus-visible {
  background: var(--si-whatsapp-hover);
  transform: scale(1.1);
  box-shadow:
    0 8px 30px rgba(37, 211, 102, 0.5),
    0 4px 12px rgba(0, 0, 0, 0.3);
  animation: none;
}

.si-whatsapp-float svg,
.si-whatsapp-float img {
  width: 28px;
  height: 28px;
  pointer-events: none;
}

/* Pulse animation */
@keyframes whatsapp-pulse {
  0%  { box-shadow: 0 4px 20px var(--si-whatsapp-glow), 0 0 0 0 rgba(37, 211, 102, 0.5); }
  70% { box-shadow: 0 4px 20px var(--si-whatsapp-glow), 0 0 0 12px rgba(37, 211, 102, 0); }
  100%{ box-shadow: 0 4px 20px var(--si-whatsapp-glow), 0 0 0 0 rgba(37, 211, 102, 0); }
}

/* Tooltip label on hover */
.si-whatsapp-float-tooltip {
  position: absolute;
  right: calc(100% + var(--si-space-3));
  top: 50%;
  transform: translateY(-50%);
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-md);
  padding: var(--si-space-2) var(--si-space-3);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-medium);
  color: var(--si-text-white);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--si-transition-fast);
}

.si-whatsapp-float:hover .si-whatsapp-float-tooltip {
  opacity: 1;
}


/* ============================================================
   17. CTA SECTIONS
   ============================================================ */

.si-cta-section {
  padding-block: var(--si-section-py);
  padding-inline: var(--si-container-padding);
  background: var(--si-gradient-cta);
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Decorative bokeh glow behind CTA */
.si-cta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 50%, rgba(255, 255, 255, 0.06) 0%, transparent 60%),
    radial-gradient(circle at 80% 50%, rgba(255, 255, 255, 0.04) 0%, transparent 60%);
  pointer-events: none;
}

.si-cta-section > * {
  position: relative;
  z-index: 1;
}

.si-cta-section h2,
.si-cta-section h3 {
  color: var(--si-text-white);
  margin-bottom: var(--si-space-4);
}

.si-cta-section p,
.si-section-dark.si-cta-section p {
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: var(--si-space-8);
}

.si-cta-section-inner {
  max-width: 700px;
  margin-inline: auto;
}

.si-cta-button-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--si-space-3);
}

/* CTA section dark variant — deep bg with gradient text */
.si-cta-section-dark {
  padding-block: var(--si-section-py);
  padding-inline: var(--si-container-padding);
  background: var(--si-bg-secondary);
  text-align: center;
  border-top: 1px solid var(--si-border-dark);
  border-bottom: 1px solid var(--si-border-dark);
  position: relative;
  overflow: hidden;
}

.si-cta-section-dark::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 800px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(158, 0, 93, 0.08) 0%, transparent 70%);
  pointer-events: none;
}

.si-cta-section-dark > * {
  position: relative;
  z-index: 1;
}

/* ═══════════ CTA FOOTER — Primary/Navy ═══════════ */
.si-cta-footer {
    background: linear-gradient(135deg, #0F172A 0%, #1E293B 100%);
    text-align: center;
    padding: 80px 40px;
}
.si-cta-footer .si-trust-bar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 40px;
    max-width: 800px;
    margin: 0 auto 48px;
}
.si-cta-footer .si-trust-item {
    font-size: 1rem;
    color: #D1D5DB;
    line-height: 1.4;
}
.si-cta-footer .si-trust-item strong {
    color: #9e005d;
    font-size: 1.75rem;
    font-weight: 800;
    display: block;
    margin-bottom: 4px;
    font-family: var(--si-font-heading, 'DM Sans', sans-serif);
}
.si-cta-heading {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    color: #F9FAFB;
    margin-bottom: 16px;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
    font-weight: 700;
}
.si-cta-subtext {
    font-size: 1.125rem;
    color: #D1D5DB;
    margin-bottom: 32px;
}
.si-btn-cta-primary {
    display: inline-block;
    padding: 16px 40px;
    background: #9e005d;
    color: #FFFFFF;
    font-size: 1.125rem;
    font-weight: 700;
    border-radius: 8px;
    text-decoration: none;
    box-shadow: 0 4px 12px rgba(158, 0, 93, 0.3);
    transition: all 0.3s ease;
}
.si-btn-cta-primary:hover {
    background: #7d004a;
    box-shadow: 0 8px 20px rgba(158, 0, 93, 0.4);
    transform: translateY(-2px);
    color: #FFFFFF;
    text-decoration: none;
}

@media (max-width: 767px) {
    .si-cta-footer {
        padding: 60px 20px;
    }
    .si-cta-footer .si-trust-bar {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
        margin-bottom: 36px;
    }
    .si-btn-cta-primary {
        padding: 14px 32px;
        font-size: 1rem;
    }
}


/* ============================================================
   18. PRICING
   ============================================================ */

.si-pricing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--si-space-6);
  align-items: stretch;
}

/* Base pricing card */
.si-pricing-card {
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-xl);
  padding: var(--si-space-8);
  display: flex;
  flex-direction: column;
  gap: var(--si-space-6);
  transition: transform var(--si-transition-base), border-color var(--si-transition-base);
  position: relative;
}

.si-pricing-card:hover {
  transform: translateY(-4px);
  border-color: var(--si-border-accent);
}

/* Featured / highlighted card */
.si-pricing-featured {
  background: var(--si-bg-card);
  border: 2px solid var(--si-accent-primary);
  border-radius: var(--si-radius-xl);
  padding: var(--si-space-8);
  display: flex;
  flex-direction: column;
  gap: var(--si-space-6);
  position: relative;
  box-shadow: 0 0 40px var(--si-accent-glow);
}

/* "Most Popular" badge on featured card */
.si-pricing-popular-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-widest);
  text-transform: uppercase;
  padding: var(--si-space-1) var(--si-space-5);
  border-radius: var(--si-radius-full);
  white-space: nowrap;
}

/* Pricing card header */
.si-pricing-name {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-xl);
  font-weight: var(--si-weight-semibold);
  color: var(--si-text-white);
  margin: 0;
}

.si-pricing-description {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  margin: var(--si-space-2) 0 0;
  line-height: var(--si-leading-relaxed);
}

/* Price display */
.si-pricing-price {
  display: flex;
  align-items: flex-end;
  gap: var(--si-space-1);
  line-height: 1;
}

.si-pricing-currency {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-xl);
  font-weight: var(--si-weight-semibold);
  color: var(--si-text-muted);
  align-self: flex-start;
  margin-top: var(--si-space-2);
}

.si-pricing-amount {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-5xl);
  font-weight: var(--si-weight-extrabold);
  color: var(--si-text-white);
  line-height: 1;
}

.si-pricing-period {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  align-self: flex-end;
  margin-bottom: var(--si-space-1);
}

/* Features list */
.si-pricing-features {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-3);
  border-top: 1px solid var(--si-border-dark);
  padding-top: var(--si-space-6);
}

.si-pricing-feature {
  display: flex;
  align-items: flex-start;
  gap: var(--si-space-3);
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  line-height: var(--si-leading-relaxed);
}

/* Check icon */
.si-pricing-feature-icon {
  width: 18px;
  height: 18px;
  min-width: 18px;
  color: var(--si-success);
  margin-top: 1px;
}

/* Unavailable feature */
.si-pricing-feature.is-unavailable {
  opacity: 0.4;
}

.si-pricing-feature.is-unavailable .si-pricing-feature-icon {
  color: var(--si-text-muted);
}

.si-pricing-cta {
  margin-top: auto;
}

/* ── Pricing Page Overrides ── */

/* Featured card: elevation + magenta glow */
.si-pricing-page .si-pricing-featured {
  border: 2px solid #9e005d;
  box-shadow: 0 0 40px rgba(158, 0, 93, 0.2), 0 20px 60px rgba(0, 0, 0, 0.1);
}
.si-pricing-page .si-pricing-card:hover {
  border-color: rgba(158, 0, 93, 0.3);
}

/* "Le plus populaire" badge — green */
.si-pricing-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: #10B981;
  color: #FFFFFF;
  font-size: var(--si-text-xs, 0.8125rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 6px 20px;
  border-radius: 100px;
  white-space: nowrap;
  z-index: 3;
}

/* Primary CTA button full-width variant */
.si-btn-cta-primary.si-btn-full {
  display: block;
  width: 100%;
  text-align: center;
}

/* Pricing page featured card light section override */
.si-section-light .si-pricing-page .si-pricing-featured,
.si-pricing-page.si-section-light .si-pricing-featured {
  background: var(--si-surface-white, #FFFFFF);
  border-color: #9e005d;
  box-shadow: 0 0 40px rgba(158, 0, 93, 0.15), 0 20px 60px rgba(0, 0, 0, 0.08);
}

/* Light section pricing hover — magenta accent */
.si-pricing-page.si-section-light .si-pricing-card:hover {
  box-shadow: var(--si-shadow-card-hover, 0 10px 30px rgba(0,0,0,0.1));
  border-color: rgba(158, 0, 93, 0.3);
}

/* Featured card responsive: remove scale on mobile */
@media (max-width: 767px) {
  .si-pricing-page .si-pricing-featured {
    transform: scale(1) !important;
    margin-top: 0 !important;
  }
}

/* ── "Pourquoi nos prix sont si accessibles?" Section ── */
.si-pricing-why-accessible {
  background: #0F172A;
}

.si-why-accessible-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
}

.si-why-accessible-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  padding: 32px 24px;
  text-align: center;
  transition: border-color 0.3s ease, transform 0.3s ease;
}

.si-why-accessible-card:hover {
  border-color: rgba(158, 0, 93, 0.2);
  transform: translateY(-4px);
}

.si-why-accessible-icon {
  font-size: 2.5rem;
  margin-bottom: 16px;
  line-height: 1;
}

.si-why-accessible-card h3 {
  font-family: var(--si-font-heading, 'Space Grotesk', sans-serif);
  font-size: 1.125rem;
  font-weight: 700;
  color: #F9FAFB;
  margin-bottom: 12px;
  line-height: 1.3;
}

.si-why-accessible-card p {
  font-size: 0.9375rem;
  color: #D1D5DB;
  line-height: 1.6;
  margin: 0;
}

@media (max-width: 1024px) {
  .si-why-accessible-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .si-why-accessible-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .si-why-accessible-card {
    padding: 24px 20px;
  }
}

/* ── Pricing FAQ contrast fix ── */
.si-pricing-faq .si-faq-question {
  color: #F9FAFB;
}
.si-pricing-faq .si-faq-question:hover {
  color: #9e005d;
}
.si-pricing-faq .si-faq-question-text {
  color: inherit;
}
.si-pricing-faq .si-faq-icon {
  color: #D1D5DB;
}
.si-pricing-faq .si-faq-answer-inner,
.si-pricing-faq .si-faq-answer-inner p {
  color: #D1D5DB;
}


/* ============================================================
   18b. WHY US — Trust Pillars
   ============================================================ */

.si-why-us-icon {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  background: linear-gradient(135deg, #9e005d, #FBBF24);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  margin: 0 auto 16px;
  flex-shrink: 0;
}

.si-why-us-card {
  background: var(--si-bg-tertiary, #1F2937);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  padding: 32px 24px;
  text-align: center;
  transition: border-color 0.3s ease, transform 0.3s ease;
}

.si-why-us-card:hover {
  border-color: rgba(158, 0, 93, 0.3);
  transform: translateY(-2px);
}

.si-why-us-card h3 {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--si-text-primary, #F1F5F9);
  margin-bottom: 8px;
}

.si-why-us-card p {
  font-size: 0.95rem;
  color: var(--si-text-secondary, #CBD5E1);
  line-height: 1.6;
  margin: 0;
}



/* ============================================================
   19. CASE STUDIES — MakeItBloom-inspired design
   ============================================================ */

.si-case-study-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--si-space-6);
}

/* Card — clean container with hover lift */
.si-case-study-card {
  background: var(--si-bg-card);
  border-radius: 16px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  border: none;
}

.si-case-study-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

/* Image area — tall, full-bleed with gradient and large centered logo */
.si-case-study-image-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--si-bg-secondary);
}

.si-case-study-image-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.35) 100%);
  pointer-events: none;
  z-index: 1;
}

/* Cover image variant — full background cover */
.si-case-study-image-wrap--cover {
  background-size: cover;
  background-position: 8% center;
  background-repeat: no-repeat;
}

.si-case-study-image-wrap--cover::after {
  background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.25) 100%);
}

.si-case-study-card:hover .si-case-study-image-wrap--cover {
  transform: scale(1.03);
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Brand name overlay on cover images */

/* Logo inside image area — large, white, centered */
.si-case-study-image-wrap .si-cs-logo {
  position: relative;
  z-index: 2;
  width: 140px;
  height: 140px;
  object-fit: contain;
  filter: drop-shadow(0 4px 20px rgba(0, 0, 0, 0.2));
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.si-case-study-card:hover .si-cs-logo {
  transform: scale(1.08);
}

/* Monogram fallback — large, clean, centered */
.si-cs-monogram {
  position: relative;
  z-index: 2;
  font-family: var(--si-font-heading);
  font-size: 4.5rem;
  font-weight: var(--si-weight-extrabold);
  color: #fff;
  line-height: 1;
  letter-spacing: -0.03em;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.si-case-study-card:hover .si-cs-monogram {
  transform: scale(1.08);
}

/* Brand name watermark below logo */
.si-cs-brand-name {
  position: absolute;
  bottom: var(--si-space-4);
  left: 0;
  right: 0;
  z-index: 2;
  text-align: left;
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-semibold);
  color: rgba(255, 255, 255, 0.85);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.4);
  padding-left: var(--si-space-6);
  padding-right: var(--si-space-6);
}

/* Metric badge — now inside content area, not overlapping image */
.si-case-study-metric-badge {
  position: absolute;
  top: var(--si-space-4);
  right: var(--si-space-4);
  z-index: 3;
  background: rgba(0, 0, 0, 0.75);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--si-radius-full);
  padding: var(--si-space-2) var(--si-space-4);
  text-align: center;
}

.si-case-study-metric-value {
  display: block;
  font-family: var(--si-font-mono);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-bold);
  color: var(--si-text-white);
  line-height: 1;
  white-space: nowrap;
}

.si-case-study-metric-label {
  display: none;
}

/* Client logo overlay — legacy, kept for backwards compat */
.si-case-study-logo {
  display: none;
}

.si-case-study-logo img {
  display: none;
}

/* Card content — clean, minimal like makeitbloom */
.si-case-study-content {
  padding: var(--si-space-5) var(--si-space-5) var(--si-space-5);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 6px;
}

.si-case-study-category {
  font-size: 0.68rem;
  font-weight: var(--si-weight-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--si-accent-light);
  display: block;
}

.si-case-study-title {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-lg);
  font-weight: var(--si-weight-bold);
  color: var(--si-text-white);
  margin: 0;
  line-height: 1.3;
}

.si-case-study-excerpt {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Results metrics row */
.si-result-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: var(--si-space-4);
  padding: var(--si-space-4) 0;
  border-top: 1px solid var(--si-border-dark);
}

.si-result-metric {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.si-result-metric-value {
  font-family: var(--si-font-mono);
  font-size: var(--si-text-xl);
  font-weight: var(--si-weight-extrabold);
  color: var(--si-accent-light);
  line-height: 1;
}

.si-result-metric-label {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--si-tracking-wider);
}


/* ============================================================
   20. BLOG
   ============================================================ */

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

/* Blog card */
.si-blog-card {
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--si-transition-base), border-color var(--si-transition-base);
}

.si-blog-card:hover {
  transform: translateY(-4px);
  border-color: var(--si-border-accent);
}

/* Blog card image */
.si-blog-card-image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: var(--si-bg-secondary);
  flex-shrink: 0;
}

.si-blog-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--si-transition-slow);
}

.si-blog-card:hover .si-blog-card-image img {
  transform: scale(1.04);
}

/* Blog card content */
.si-blog-card-content {
  padding: var(--si-space-6);
  display: flex;
  flex-direction: column;
  gap: var(--si-space-3);
  flex: 1;
}

/* Blog meta (date + category) */
.si-blog-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--si-space-3);
}

.si-blog-date {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  display: flex;
  align-items: center;
  gap: var(--si-space-1);
}

.si-blog-category {
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-wider);
  text-transform: uppercase;
  color: var(--si-accent-light);
  text-decoration: none;
  transition: color var(--si-transition-fast);
}

.si-blog-category:hover {
  color: var(--si-text-white);
}

/* Blog title */
.si-blog-title {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-xl);
  font-weight: var(--si-weight-semibold);
  color: var(--si-text-white);
  line-height: var(--si-leading-snug);
  margin: 0;
  transition: color var(--si-transition-fast);
}

.si-blog-card:hover .si-blog-title {
  color: var(--si-accent-light);
}

/* Blog excerpt */
.si-blog-excerpt {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  line-height: var(--si-leading-relaxed);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Blog card footer */
.si-blog-card-footer {
  margin-top: auto;
  padding-top: var(--si-space-4);
  border-top: 1px solid var(--si-border-dark);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Author mini info */
.si-blog-author {
  display: flex;
  align-items: center;
  gap: var(--si-space-2);
}

.si-blog-author-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--si-radius-full);
  object-fit: cover;
}

.si-blog-author-name {
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-medium);
  color: var(--si-text-muted);
}

/* Read time */
.si-blog-read-time {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
}

/* Featured post — larger */
.si-blog-card-featured {
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--si-transition-base), border-color var(--si-transition-base);
}

.si-blog-card-featured:hover {
  transform: translateY(-4px);
  border-color: var(--si-border-accent);
}

.si-blog-card-featured .si-blog-card-image {
  aspect-ratio: 16 / 8;
}

.si-blog-card-featured .si-blog-title {
  font-size: var(--si-text-2xl);
}


/* ============================================================
   21. UTILITIES
   ============================================================ */

/* Text alignment */
.si-text-center { text-align: center; }
.si-text-left   { text-align: left; }
.si-text-right  { text-align: right; }

/* Text color utilities */
.si-text-white  { color: var(--si-text-white) !important; }
.si-text-light  { color: var(--si-text-light) !important; }
.si-text-muted  { color: var(--si-text-muted) !important; }
.si-text-dark   { color: var(--si-text-dark) !important; }
.si-text-accent { color: var(--si-accent-light) !important; }

/* Font size utilities */
.si-text-xs   { font-size: var(--si-text-xs); }
.si-text-sm   { font-size: var(--si-text-sm); }
.si-text-base { font-size: var(--si-text-base); }
.si-text-lg   { font-size: var(--si-text-lg); }
.si-text-xl   { font-size: var(--si-text-xl); }
.si-text-2xl  { font-size: var(--si-text-2xl); }
.si-text-3xl  { font-size: var(--si-text-3xl); }
.si-text-4xl  { font-size: var(--si-text-4xl); }
.si-text-5xl  { font-size: var(--si-text-5xl); }

/* Font weight utilities */
.si-font-normal   { font-weight: var(--si-weight-normal); }
.si-font-medium   { font-weight: var(--si-weight-medium); }
.si-font-semibold { font-weight: var(--si-weight-semibold); }
.si-font-bold     { font-weight: var(--si-weight-bold); }

/* Screen reader only */
.si-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Visibility */
.si-hidden { display: none !important; }
.si-invisible { visibility: hidden; }

/* Display */
.si-block        { display: block; }
.si-inline-block { display: inline-block; }
.si-inline-flex  { display: inline-flex; }

/* Overflow */
.si-overflow-hidden { overflow: hidden; }

/* Border radius */
.si-rounded-sm   { border-radius: var(--si-radius-sm); }
.si-rounded-md   { border-radius: var(--si-radius-md); }
.si-rounded-lg   { border-radius: var(--si-radius-lg); }
.si-rounded-xl   { border-radius: var(--si-radius-xl); }
.si-rounded-full { border-radius: var(--si-radius-full); }

/* Margin bottom */
.si-mb-1  { margin-bottom: var(--si-space-1); }
.si-mb-2  { margin-bottom: var(--si-space-2); }
.si-mb-3  { margin-bottom: var(--si-space-3); }
.si-mb-4  { margin-bottom: var(--si-space-4); }
.si-mb-5  { margin-bottom: var(--si-space-5); }
.si-mb-6  { margin-bottom: var(--si-space-6); }
.si-mb-8  { margin-bottom: var(--si-space-8); }
.si-mb-10 { margin-bottom: var(--si-space-10); }
.si-mb-12 { margin-bottom: var(--si-space-12); }
.si-mb-16 { margin-bottom: var(--si-space-16); }
.si-mb-0  { margin-bottom: 0; }

/* Margin top */
.si-mt-1  { margin-top: var(--si-space-1); }
.si-mt-2  { margin-top: var(--si-space-2); }
.si-mt-3  { margin-top: var(--si-space-3); }
.si-mt-4  { margin-top: var(--si-space-4); }
.si-mt-5  { margin-top: var(--si-space-5); }
.si-mt-6  { margin-top: var(--si-space-6); }
.si-mt-8  { margin-top: var(--si-space-8); }
.si-mt-10 { margin-top: var(--si-space-10); }
.si-mt-12 { margin-top: var(--si-space-12); }
.si-mt-16 { margin-top: var(--si-space-16); }
.si-mt-0  { margin-top: 0; }

/* Margin inline (horizontal) */
.si-mx-auto { margin-inline: auto; }

/* Padding vertical */
.si-py-1  { padding-block: var(--si-space-1); }
.si-py-2  { padding-block: var(--si-space-2); }
.si-py-3  { padding-block: var(--si-space-3); }
.si-py-4  { padding-block: var(--si-space-4); }
.si-py-5  { padding-block: var(--si-space-5); }
.si-py-6  { padding-block: var(--si-space-6); }
.si-py-8  { padding-block: var(--si-space-8); }
.si-py-10 { padding-block: var(--si-space-10); }
.si-py-12 { padding-block: var(--si-space-12); }
.si-py-16 { padding-block: var(--si-space-16); }

/* Padding horizontal */
.si-px-4  { padding-inline: var(--si-space-4); }
.si-px-6  { padding-inline: var(--si-space-6); }
.si-px-8  { padding-inline: var(--si-space-8); }

/* Max width */
.si-max-w-narrow { max-width: var(--si-container-narrow); }
.si-max-w-container { max-width: var(--si-container-max); }
.si-max-w-wide  { max-width: var(--si-container-wide); }
.si-max-w-full  { max-width: 100%; }

/* Width */
.si-w-full { width: 100%; }

/* Relative / absolute helpers */
.si-relative { position: relative; }
.si-absolute { position: absolute; }

/* Z-index */
.si-z-base    { z-index: var(--si-z-base); }
.si-z-sticky  { z-index: var(--si-z-sticky); }

/* Aspect ratio */
.si-aspect-video  { aspect-ratio: 16 / 9; }
.si-aspect-square { aspect-ratio: 1 / 1; }
.si-aspect-3-2    { aspect-ratio: 3 / 2; }

/* Opacity */
.si-opacity-75 { opacity: 0.75; }
.si-opacity-50 { opacity: 0.5; }

/* Truncate text */
.si-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Line clamp */
.si-line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.si-line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Visually hidden but focusable (skip links) */
.si-skip-link {
  position: absolute;
  top: -100%;
  left: var(--si-space-4);
  z-index: 9999;
  background: var(--si-accent-primary);
  color: var(--si-text-white);
  padding: var(--si-space-3) var(--si-space-6);
  border-radius: var(--si-radius-md);
  font-weight: var(--si-weight-semibold);
  text-decoration: none;
  transition: top var(--si-transition-fast);
}

.si-skip-link:focus {
  top: var(--si-space-4);
}

/* Divider */
.si-divider {
  height: 1px;
  background: var(--si-border-dark);
  border: none;
  margin: var(--si-space-8) 0;
}

.si-divider-light {
  height: 1px;
  background: var(--si-border-light);
  border: none;
  margin: var(--si-space-8) 0;
}

/* Dot separator */
.si-dot-separator::before {
  content: '·';
  margin-inline: var(--si-space-2);
  color: var(--si-text-muted);
  opacity: 0.5;
}


/* ============================================================
   22. DARK / LIGHT SECTION ALTERNATING PATTERN
   ============================================================ */

/*
   Pattern guide:
   - Dark sections: --si-bg-primary / --si-bg-secondary backgrounds
     All text uses white/light/muted variants from the design system
   - Light sections: --si-surface-light / --si-surface-white backgrounds
     All text uses dark/body variants from the design system
   - Both section types support the same structural components
     (cards, buttons, badges) with adapted colour overrides below.
*/

/* Light section — card overrides */
.si-section-light .si-card,
.si-section-white .si-card {
  background: var(--si-surface-white);
  border-color: var(--si-border-light);
  box-shadow: var(--si-shadow-card);
}

.si-section-light .si-card:hover,
.si-section-white .si-card:hover {
  box-shadow: var(--si-shadow-card-hover);
  border-color: rgba(158, 0, 93, 0.15);
}

/* Light section — heading / text colour resets */
.si-section-light h1,
.si-section-light h2,
.si-section-light h3,
.si-section-light h4,
.si-section-light h5,
.si-section-light h6,
.si-section-white h1,
.si-section-white h2,
.si-section-white h3,
.si-section-white h4,
.si-section-white h5,
.si-section-white h6 {
  color: var(--si-text-heading);
}

.si-section-light p,
.si-section-white p {
  color: var(--si-text-body);
}

/* Light section — badge overrides */
.si-section-light .si-badge,
.si-section-white .si-badge {
  background: rgba(158, 0, 93, 0.08);
  border-color: rgba(158, 0, 93, 0.15);
  color: var(--si-accent-primary);
}

/* Light section — input overrides */
.si-section-light .si-input,
.si-section-light .si-textarea,
.si-section-light .si-select,
.si-section-white .si-input,
.si-section-white .si-textarea,
.si-section-white .si-select {
  background: var(--si-surface-white);
  border-color: rgba(0, 0, 0, 0.1);
  color: var(--si-text-dark);
}

.si-section-light .si-input:focus,
.si-section-light .si-textarea:focus,
.si-section-light .si-select:focus,
.si-section-white .si-input:focus,
.si-section-white .si-textarea:focus,
.si-section-white .si-select:focus {
  border-color: var(--si-accent-primary);
  box-shadow: 0 0 0 3px var(--si-accent-glow);
}

/* Light section — label overrides */
.si-section-light .si-label,
.si-section-white .si-label {
  color: var(--si-text-dark);
}

/* Light section — overline */
.si-section-light .si-overline,
.si-section-white .si-overline {
  color: var(--si-accent-primary);
}

/* Dark section — explicit text colours for nested light-text elements */
.si-section-dark .si-badge,
.si-section-darkest .si-badge {
  background: var(--si-accent-subtle);
  border-color: var(--si-border-accent);
  color: var(--si-accent-light);
}

/* Transition between sections */
.si-section + .si-section,
.si-section-dark + .si-section-light,
.si-section-light + .si-section-dark,
.si-section-dark + .si-section-white,
.si-section-white + .si-section-dark {
  /* Rely on background-color transitions set above. */
}


/* ============================================================
   ADDITIONAL COMPONENT PATTERNS
   ============================================================ */

/* Process / Steps list */
.si-steps {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-8);
  position: relative;
}

.si-step {
  display: flex;
  gap: var(--si-space-5);
  align-items: flex-start;
}

.si-step-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: var(--si-radius-full);
  background: var(--si-accent-subtle);
  border: 2px solid var(--si-border-accent);
  font-family: var(--si-font-mono);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-bold);
  color: var(--si-accent-light);
}

.si-step-content {
  flex: 1;
  padding-top: var(--si-space-2);
}

.si-step-title {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-lg);
  font-weight: var(--si-weight-semibold);
  color: var(--si-text-white);
  margin: 0 0 var(--si-space-2);
}

.si-step-description {
  font-size: var(--si-text-sm);
  color: var(--si-text-light);
  line-height: var(--si-leading-relaxed);
  margin: 0;
}

/* Icon list */
.si-icon-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-3);
}

.si-icon-list-item {
  display: flex;
  align-items: flex-start;
  gap: var(--si-space-3);
  font-size: var(--si-text-sm);
  color: var(--si-text-light);
  line-height: var(--si-leading-relaxed);
}

.si-icon-list-icon {
  width: 20px;
  height: 20px;
  min-width: 20px;
  color: var(--si-success);
  margin-top: 1px;
}

/* Separator with label */
.si-separator-label {
  display: flex;
  align-items: center;
  gap: var(--si-space-4);
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--si-tracking-widest);
  font-weight: var(--si-weight-medium);
}

.si-separator-label::before,
.si-separator-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--si-border-dark);
}

/* Logo cloud / partner logos */
.si-logo-cloud {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--si-space-8);
  filter: grayscale(100%);
  opacity: 0.5;
  transition: opacity var(--si-transition-base);
}

.si-logo-cloud:hover {
  opacity: 0.7;
}

.si-logo-cloud img {
  max-height: 32px;
  width: auto;
}

/* Alert / notification bar */
.si-alert {
  padding: var(--si-space-4) var(--si-space-5);
  border-radius: var(--si-radius-md);
  display: flex;
  align-items: flex-start;
  gap: var(--si-space-3);
  font-size: var(--si-text-sm);
  line-height: var(--si-leading-relaxed);
}

.si-alert-info {
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid rgba(59, 130, 246, 0.2);
  color: #93C5FD;
}

.si-alert-success {
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.2);
  color: #6EE7B7;
}

.si-alert-warning {
  background: rgba(245, 158, 11, 0.1);
  border: 1px solid rgba(245, 158, 11, 0.2);
  color: #FCD34D;
}

.si-alert-error {
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
  color: #FCA5A5;
}

/* Notification / top bar */
.si-topbar {
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
  text-align: center;
  padding: var(--si-space-2) var(--si-container-padding);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-medium);
  letter-spacing: var(--si-tracking-wide);
}

.si-topbar a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Loading spinner */
@keyframes si-spin {
  to { transform: rotate(360deg); }
}

.si-spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--si-border-dark);
  border-top-color: var(--si-accent-primary);
  border-radius: var(--si-radius-full);
  animation: si-spin 0.7s linear infinite;
}

.si-spinner-lg {
  width: 40px;
  height: 40px;
  border-width: 3px;
}

/* Skeleton loader */
@keyframes si-skeleton {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}

.si-skeleton {
  background: var(--si-bg-card);
  border-radius: var(--si-radius-sm);
  animation: si-skeleton 1.8s ease-in-out infinite;
}

/* Tag cloud */
.si-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: var(--si-space-2);
  list-style: none;
  margin: 0;
  padding: 0;
}

.si-tag {
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-medium);
  color: var(--si-text-muted);
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-sm);
  padding: var(--si-space-1) var(--si-space-3);
  text-decoration: none;
  transition:
    color var(--si-transition-fast),
    border-color var(--si-transition-fast),
    background var(--si-transition-fast);
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.si-tag:hover {
  color: var(--si-accent-light);
  border-color: var(--si-border-accent);
  background: var(--si-accent-subtle);
}

/* Pagination */
.si-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--si-space-2);
  flex-wrap: wrap;
}

.si-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--si-radius-md);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-medium);
  color: var(--si-text-muted);
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  text-decoration: none;
  transition:
    color var(--si-transition-fast),
    background var(--si-transition-fast),
    border-color var(--si-transition-fast);
}

.si-page-btn:hover {
  color: var(--si-text-white);
  border-color: var(--si-border-accent);
  background: var(--si-accent-subtle);
}

.si-page-btn.is-active {
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
  border-color: transparent;
}

.si-page-btn:disabled,
.si-page-btn[aria-disabled="true"] {
  opacity: 0.3;
  pointer-events: none;
}

/* Table */
.si-table-wrap {
  overflow-x: auto;
  border-radius: var(--si-radius-md);
  border: 1px solid var(--si-border-dark);
}

.si-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--si-text-sm);
}

.si-table th {
  padding: var(--si-space-3) var(--si-space-5);
  text-align: left;
  font-weight: var(--si-weight-semibold);
  font-size: var(--si-text-xs);
  letter-spacing: var(--si-tracking-wider);
  text-transform: uppercase;
  color: var(--si-text-muted);
  background: var(--si-bg-secondary);
  border-bottom: 1px solid var(--si-border-dark);
  white-space: nowrap;
}

.si-table td {
  padding: var(--si-space-4) var(--si-space-5);
  color: var(--si-text-light);
  border-bottom: 1px solid var(--si-border-dark);
  vertical-align: middle;
}

.si-table tr:last-child td {
  border-bottom: none;
}

.si-table tr:hover td {
  background: var(--si-accent-subtle);
}

/* Image with caption */
.si-figure {
  margin: var(--si-space-8) 0;
}

.si-figure img {
  width: 100%;
  border-radius: var(--si-radius-lg);
  border: 1px solid var(--si-border-dark);
}

.si-figcaption {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  text-align: center;
  margin-top: var(--si-space-3);
  font-style: italic;
}

/* Tooltip base */
[data-tooltip] {
  position: relative;
  cursor: help;
}

[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  color: var(--si-text-light);
  font-size: var(--si-text-xs);
  padding: var(--si-space-2) var(--si-space-3);
  border-radius: var(--si-radius-sm);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--si-transition-fast);
  z-index: var(--si-z-dropdown);
  box-shadow: var(--si-shadow-dark-md);
}

[data-tooltip]:hover::after {
  opacity: 1;
}

/* ============================================================
   SECTION HEADER — base rules for section titles
   ============================================================ */

.si-section-header {
  text-align: center;
  max-width: 720px;
  margin-inline: auto;
  margin-bottom: var(--si-space-12);
}

.si-section-title {
  font-family: var(--si-font-heading);
  font-weight: var(--si-weight-bold);
  color: var(--si-text-white);
  margin-bottom: var(--si-space-4);
}

.si-section-subtitle {
  font-size: var(--si-text-lg);
  line-height: var(--si-leading-relaxed);
  color: var(--si-text-light);
  margin: 0 auto;
  text-align: center;
  max-width: 700px;
}

.si-section-light .si-section-title {
  color: var(--si-text-heading);
}

.si-section-light .si-section-subtitle {
  color: var(--si-text-body);
}


/* ============================================================
   LIGHT-SECTION OVERRIDES — cards, FAQ, pricing, stats
   Prevents dark cards on light backgrounds (unreadable text)
   ============================================================ */

/* --- Service Cards --- */
.si-section-light .si-service-card {
  background: var(--si-surface-white);
  border-color: var(--si-border-light);
  box-shadow: var(--si-shadow-card);
}

.si-section-light .si-service-card:hover {
  box-shadow: var(--si-shadow-card-hover);
  border-color: rgba(158, 0, 93, 0.2);
}

.si-section-light .si-service-card h3 {
  color: var(--si-text-heading);
}

.si-section-light .si-service-card p {
  color: var(--si-text-body);
}

.si-section-light .si-service-card .si-link,
.si-section-light .si-service-card .si-read-more {
  color: var(--si-accent-primary);
}

.si-section-light .si-service-card-icon {
  background: rgba(158, 0, 93, 0.08);
  color: var(--si-accent-primary);
}

.si-section-light .si-service-card:hover .si-service-card-icon {
  background: var(--si-gradient-primary);
  color: var(--si-text-white);
}

/* --- Stat Cards --- */
.si-section-light .si-stat-card {
  background: var(--si-surface-white);
  border-color: var(--si-border-light);
  box-shadow: var(--si-shadow-card);
}

.si-section-light .si-stat-card:hover {
  box-shadow: var(--si-shadow-card-hover);
  border-color: rgba(158, 0, 93, 0.2);
}

.si-section-light .si-stat-number {
  color: var(--si-accent-primary);
}

.si-section-light .si-stat-label {
  color: var(--si-text-body);
}

.si-section-light .si-stat-detail {
  color: var(--si-text-body);
}

/* --- Pricing Cards --- */
.si-section-light .si-pricing-card {
  background: var(--si-surface-white);
  border-color: var(--si-border-light);
  box-shadow: var(--si-shadow-card);
}

.si-section-light .si-pricing-card:hover {
  box-shadow: var(--si-shadow-card-hover);
  border-color: rgba(158, 0, 93, 0.2);
}

.si-section-light .si-pricing-featured {
  background: var(--si-surface-white);
  border-color: var(--si-accent-primary);
  box-shadow: 0 0 40px rgba(158, 0, 93, 0.15);
}

.si-section-light .si-pricing-name {
  color: var(--si-text-heading);
}

.si-section-light .si-pricing-description {
  color: var(--si-text-body);
}

.si-section-light .si-pricing-amount {
  color: var(--si-text-heading);
}

.si-section-light .si-pricing-currency,
.si-section-light .si-pricing-period {
  color: var(--si-text-body);
}

.si-section-light .si-pricing-features {
  border-top-color: var(--si-border-light);
}

.si-section-light .si-pricing-feature {
  color: var(--si-text-body);
}

.si-section-light .si-pricing-feature-icon {
  color: var(--si-success);
}

/* --- FAQ --- */
.si-section-light .si-faq-item {
  border-color: var(--si-border-light);
}

.si-section-light .si-faq-question {
  color: var(--si-text-heading);
}

.si-section-light .si-faq-question:hover {
  color: var(--si-accent-primary);
}

.si-section-light .si-faq-answer-inner,
.si-section-light .si-faq-answer > p {
  color: var(--si-text-body);
}

.si-section-light .si-faq-icon {
  color: var(--si-accent-primary);
}

/* --- Testimonial Cards --- */
.si-section-light .si-testimonial-card {
  background: var(--si-surface-white);
  border-color: var(--si-border-light);
  box-shadow: var(--si-shadow-card);
}

.si-section-light .si-testimonial-card:hover {
  box-shadow: var(--si-shadow-card-hover);
  border-color: rgba(158, 0, 93, 0.15);
}

.si-section-light .si-testimonial-text {
  color: var(--si-text-body);
}

.si-section-light .si-testimonial-author {
  border-top-color: var(--si-border-light);
}

.si-section-light .si-testimonial-name {
  color: var(--si-text-heading);
}

.si-section-light .si-testimonial-role {
  color: var(--si-text-body);
}

/* --- Dark cards inside light sections: preserve text colours --- */
/* Case study cards keep dark backgrounds so they need light text */
.si-section-light .si-case-study-card h3 {
  color: var(--si-text-white);
}

.si-section-light .si-case-study-card p {
  color: var(--si-text-light);
}

/* NOTE: .si-card-dark in light sections no longer forces light text
   because service cards use si-card-dark but their background is
   overridden to white by .si-section-light .si-service-card.
   Text is handled by the utility class overrides above. */

.si-section-light .si-case-study-category {
  color: var(--si-accent-light);
}

.si-section-light .si-case-study-card .si-link {
  color: var(--si-accent-light);
}

/* --- Positioning / general card in light --- */
.si-section-light .si-pill {
  background: rgba(158, 0, 93, 0.08);
  border-color: rgba(158, 0, 93, 0.15);
  color: var(--si-accent-primary);
}

/* ============================================================
   CRITICAL FIX: !important utility class overrides in light sections
   The utility classes (.si-text-white, .si-text-light, .si-text-muted)
   use !important which prevents light-section component overrides from
   working. These rules use !important with higher specificity to ensure
   proper contrast on light backgrounds.
   ============================================================ */

/* General light-section text utility overrides */
.si-section-light .si-text-white  { color: var(--si-text-heading) !important; }
.si-section-light .si-text-light  { color: var(--si-text-body) !important; }
.si-section-light .si-text-muted  { color: var(--si-text-body) !important; }

/* Headings in light sections — must be dark */
.si-section-light h1.si-text-white,
.si-section-light h2.si-text-white,
.si-section-light h3.si-text-white,
.si-section-light h4.si-text-white { color: var(--si-text-heading) !important; }

/* Service cards in light sections — force dark text on white cards */
.si-section-light .si-service-card .si-text-white,
.si-section-light .si-service-card .si-card-title { color: var(--si-text-heading) !important; }
.si-section-light .si-service-card .si-text-light { color: var(--si-text-body) !important; }
.si-section-light .si-service-card .si-text-muted { color: var(--si-text-body) !important; }

/* Pricing cards in light sections — force dark text on white cards */
.si-section-light .si-pricing-card .si-text-white { color: var(--si-text-heading) !important; }
.si-section-light .si-pricing-card .si-text-light { color: var(--si-text-body) !important; }

/* Stat cards in light sections */
.si-section-light .si-stat-card .si-text-white { color: var(--si-text-heading) !important; }
.si-section-light .si-stat-card .si-text-light { color: var(--si-text-body) !important; }

/* EXCEPTIONS: Intentionally dark elements inside light sections keep light text */
.si-section-light .si-case-study-card .si-text-white  { color: var(--si-text-white) !important; }
.si-section-light .si-case-study-card .si-text-light   { color: var(--si-text-light) !important; }
.si-section-light .si-case-study-card .si-case-study-title { color: var(--si-text-white) !important; }

/* FAQ items in light sections */
.si-section-light .si-faq-question .si-text-white { color: var(--si-text-heading) !important; }
.si-section-light .si-faq-answer .si-text-light { color: var(--si-text-body) !important; }

/* ============================================================
   Dark cards inside light sections — preserve dark appearance
   .si-card-dark cards keep their dark bg/text EXCEPT service cards
   which intentionally get white treatment in light sections.
   ============================================================ */
.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) {
  background: var(--si-bg-secondary) !important;
  border-color: var(--si-border-dark) !important;
}

.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card):hover {
  border-color: var(--si-border-accent) !important;
  box-shadow: var(--si-shadow-dark-lg), var(--si-shadow-glow) !important;
}

/* Text inside preserved dark cards stays light */
.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) h1,
.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) h2,
.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) h3,
.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) h4 {
  color: var(--si-text-white) !important;
}

.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) p,
.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) li {
  color: var(--si-text-light) !important;
}

.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) .si-text-white {
  color: var(--si-text-white) !important;
}

.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) .si-text-light {
  color: var(--si-text-light) !important;
}

.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) .si-text-muted {
  color: var(--si-text-muted) !important;
}

.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) .si-stat-number {
  color: var(--si-accent-primary) !important;
}

.si-section-light .si-card-dark:not(.si-service-card):not(.si-case-study-card) .si-stat-label {
  color: var(--si-text-white) !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--si-weight-semibold);
}


/* ============================================================
   FOOTER HTML CLASS ALIASES
   Maps HTML classes used in footer.php to styled rules
   ============================================================ */

/* Footer columns */
.si-footer-col {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-2);
}

.si-footer-about {
  gap: var(--si-space-5);
}

/* Footer description text */
.si-footer-description {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  line-height: var(--si-leading-relaxed);
  max-width: 300px;
  margin: 0;
}

/* Footer column headings */
.si-footer-heading {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-widest);
  text-transform: uppercase;
  color: var(--si-text-white);
  margin-bottom: var(--si-space-3);
}

/* Footer navigation lists */
.si-footer-nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-1);
}

.si-footer-nav li a {
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  text-decoration: none;
  transition: color var(--si-transition-fast);
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding-block: var(--si-space-1);
}

.si-footer-nav li a:hover {
  color: var(--si-text-white);
}

/* Footer contact list */
.si-footer-contact {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--si-space-3);
}

.si-footer-contact li {
  display: flex;
  align-items: center;
  gap: var(--si-space-3);
  font-size: var(--si-text-sm);
  color: var(--si-text-muted);
  line-height: var(--si-leading-relaxed);
}

.si-footer-contact li svg {
  flex-shrink: 0;
  color: var(--si-accent-light);
}

.si-footer-contact li a {
  color: var(--si-text-muted);
  text-decoration: none;
  transition: color var(--si-transition-fast);
}

.si-footer-contact li a:hover {
  color: var(--si-text-white);
}

/* Footer sub-heading (Zones desservies) */
.si-footer-subheading {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-xs);
  font-weight: var(--si-weight-semibold);
  letter-spacing: var(--si-tracking-widest);
  text-transform: uppercase;
  color: var(--si-text-white);
  margin-top: var(--si-space-5);
  margin-bottom: var(--si-space-3);
}

/* Footer location links */
.si-footer-locations {
  display: flex;
  flex-wrap: wrap;
  gap: var(--si-space-2);
}

.si-footer-locations a {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  text-decoration: none;
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-sm);
  padding: var(--si-space-1) var(--si-space-3);
  transition: color var(--si-transition-fast), border-color var(--si-transition-fast);
}

.si-footer-locations a:hover {
  color: var(--si-text-white);
  border-color: var(--si-border-accent);
}

/* Social links container */
.si-social-links {
  display: flex;
  gap: var(--si-space-3);
  flex-wrap: wrap;
}

/* Social link icons */
.si-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--si-bg-card);
  border: 1px solid var(--si-border-dark);
  border-radius: var(--si-radius-md);
  color: var(--si-text-muted);
  text-decoration: none;
  transition:
    color var(--si-transition-fast),
    background var(--si-transition-fast),
    border-color var(--si-transition-fast);
}

.si-social-link:hover {
  color: var(--si-text-white);
  background: var(--si-accent-subtle);
  border-color: var(--si-accent-primary);
}

.si-social-link svg {
  width: 18px;
  height: 18px;
}

/* Footer legal links (bottom bar) */
.si-footer-legal a {
  font-size: var(--si-text-xs);
  color: var(--si-text-muted);
  text-decoration: none;
  transition: color var(--si-transition-fast);
}

.si-footer-legal a:hover {
  color: var(--si-text-light);
}


/* ============================================================
   MOBILE MENU OVERLAY
   ============================================================ */

.si-mobile-menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 1;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--si-transition-base);
}

.si-mobile-menu.is-open .si-mobile-menu-overlay {
  opacity: 1;
  pointer-events: auto;
}


/* ============================================================
   DECORATIVE ORB ELEMENTS
   ============================================================ */

.si-orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(80px);
}

.si-orb-accent {
  background: rgba(158, 0, 93, 0.15);
}

.si-orb-gold {
  background: rgba(251, 191, 36, 0.12);
}

.si-dot-pattern {
  position: absolute;
  pointer-events: none;
  opacity: 0.04;
  background-image: radial-gradient(circle, var(--si-text-white) 1px, transparent 1px);
  background-size: 20px 20px;
}


/* ==========================================================================
   GLOSSARY PAGE
   ========================================================================== */

.si-glossary-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--si-space-2);
  justify-content: center;
}

.si-glossary-nav-letter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--si-radius-md);
  font-family: var(--si-font-mono);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-bold);
  text-decoration: none;
  transition: background 0.2s, color 0.2s, transform 0.2s;
}

.si-glossary-nav-active {
  background: var(--si-bg-card);
  color: var(--si-accent-primary);
  border: 1px solid var(--si-border-subtle);
}

.si-glossary-nav-active:hover {
  background: var(--si-accent-primary);
  color: #fff;
  transform: translateY(-2px);
}

.si-glossary-nav-disabled {
  color: var(--si-text-muted);
  opacity: 0.35;
  cursor: default;
}

.si-glossary-group {
  margin-bottom: var(--si-space-10);
  scroll-margin-top: 100px;
}

.si-glossary-letter-header {
  position: sticky;
  top: 80px;
  z-index: 5;
  padding: var(--si-space-3) 0;
  margin-bottom: var(--si-space-4);
  border-bottom: 2px solid var(--si-accent-primary);
  background: var(--si-bg-light);
}

.si-glossary-letter {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-3xl);
  font-weight: var(--si-weight-extrabold);
  color: var(--si-accent-primary);
  line-height: 1;
}

.si-glossary-terms {
  display: flex;
  flex-direction: column;
  gap: var(--si-space-4);
}

.si-glossary-term {
  padding: var(--si-space-6);
  background: #fff;
  border-radius: var(--si-radius-lg);
  border: 1px solid var(--si-border-subtle);
  transition: box-shadow 0.3s, border-color 0.3s;
  scroll-margin-top: 100px;
}

.si-glossary-term:hover {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
  border-color: var(--si-accent-primary);
}

.si-glossary-term:target {
  border-color: var(--si-accent-primary);
  box-shadow: 0 0 0 3px rgba(158, 0, 93, 0.15);
}

.si-glossary-term-name {
  font-family: var(--si-font-heading);
  font-size: var(--si-text-lg);
  font-weight: var(--si-weight-bold);
  color: var(--si-text-primary);
  margin: 0 0 var(--si-space-2) 0;
  line-height: 1.3;
}

.si-glossary-term-definition {
  font-size: var(--si-text-base);
  color: var(--si-text-secondary);
  line-height: 1.7;
  margin: 0;
}

.si-glossary-term-link {
  display: inline-flex;
  align-items: center;
  gap: var(--si-space-1);
  margin-top: var(--si-space-3);
  font-size: var(--si-text-sm);
  font-weight: var(--si-weight-semibold);
  color: var(--si-accent-primary);
  text-decoration: none;
  transition: color 0.2s, gap 0.2s;
}

.si-glossary-term-link:hover {
  color: var(--si-accent-light);
  gap: var(--si-space-2);
}


/* === Case Study Card Components === */
.si-card-case-study {
    background: var(--si-bg-secondary, #111128);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 12px;
    padding: 24px;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
}
.si-card-case-study:hover {
    border-color: rgba(158, 0, 93, 0.3);
    transform: translateY(-2px);
}

.si-card-text {
    font-size: 0.95rem;
    color: var(--si-text-secondary, #CBD5E1);
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-align: justify;
}

.si-card-metric {
    display: inline-block;
    background: linear-gradient(135deg, rgba(158, 0, 93, 0.15), rgba(251, 191, 36, 0.15));
    color: var(--si-accent-primary, #9e005d);
    font-weight: 700;
    font-size: 1.5rem;
    padding: 8px 16px;
    border-radius: 8px;
    margin-bottom: 12px;
}

.si-card-industry {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--si-text-muted, #94A3B8);
    background: rgba(255, 255, 255, 0.06);
    padding: 4px 12px;
    border-radius: 4px;
    margin-bottom: 12px;
}

.si-card-link {
    color: var(--si-accent-primary, #9e005d);
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: auto;
    transition: color 0.2s ease;
}
.si-card-link:hover {
    color: #818CF8;
}

/* Challenge/Solution card text truncation */
.si-challenges-grid .si-card-text,
.si-solutions-grid .si-card-text {
    -webkit-line-clamp: 4;
}


/* Industry link cards — cross-linking sections on service pages */
.si-industry-link-card {
    background: var(--si-bg-tertiary, #1F2937);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 12px;
    padding: 20px 16px;
    text-align: center;
    text-decoration: none;
    color: var(--si-text-primary, #F1F5F9);
    transition: border-color 0.3s ease, transform 0.3s ease;
    display: block;
}
.si-industry-link-card:hover {
    border-color: rgba(158, 0, 93, 0.3);
    transform: translateY(-2px);
    color: var(--si-text-primary, #F1F5F9);
    text-decoration: none;
}
.si-industry-link-card h4 {
    font-family: 'DM Sans', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 4px;
}
.si-industry-link-card span {
    font-size: 0.8rem;
    color: var(--si-text-muted, #94A3B8);
}


/* Print styles — hide interactive chrome */
@media print {
  .si-header,
  .si-hamburger,
  .si-mobile-menu,
  .si-whatsapp-float,
  .si-btn {
    display: none !important;
  }

  body {
    background: #fff;
    color: #000;
    font-size: 12pt;
  }
}


/* ═══════════ INDUSTRY PAGE COMPONENTS ═══════════ */

/* Challenge Cards (RED theme) */
.si-challenge-card {
    background: #fff;
    border-left: 4px solid #ef4444;
    border-radius: var(--si-radius-md);
    padding: var(--si-space-6);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: transform var(--si-transition-base), box-shadow var(--si-transition-base);
}

.si-challenge-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.si-challenge-icon {
    color: #ef4444;
    margin-bottom: var(--si-space-3);
}

.si-challenge-card h3 {
    font-size: var(--si-text-lg);
    font-weight: 700;
    margin-bottom: var(--si-space-2);
    color: var(--si-text-dark);
}

.si-challenge-card p {
    font-size: var(--si-text-sm);
    color: var(--si-text-body);
    line-height: 1.6;
}

/* Solution Cards (GREEN theme) */
.si-solution-card {
    background: #fff;
    border-left: 4px solid #10b981;
    border-radius: var(--si-radius-md);
    padding: var(--si-space-6);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    transition: transform var(--si-transition-base), box-shadow var(--si-transition-base);
}

.si-solution-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.si-solution-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(16, 185, 129, 0.1);
    color: #10b981;
    font-weight: 700;
    font-size: var(--si-text-sm);
    margin-bottom: var(--si-space-3);
}

.si-solution-card h3 {
    font-size: var(--si-text-lg);
    font-weight: 700;
    margin-bottom: var(--si-space-2);
    color: var(--si-text-dark);
}

.si-solution-card p {
    font-size: var(--si-text-sm);
    color: var(--si-text-body);
    line-height: 1.6;
    margin-bottom: var(--si-space-3);
}

.si-solution-link {
    font-size: var(--si-text-sm);
    font-weight: 600;
    color: #10b981;
    text-decoration: none;
    transition: color var(--si-transition-fast);
}

.si-solution-link:hover {
    color: #059669;
}

/* Trust Badges Bar */
.si-trust-bar {
    display: flex;
    justify-content: center;
    gap: var(--si-space-8);
    flex-wrap: wrap;
    padding: var(--si-space-6) 0;
}

.si-trust-badge {
    display: flex;
    align-items: center;
    gap: var(--si-space-2);
    font-size: var(--si-text-sm);
    font-weight: 600;
    color: var(--si-text-body);
}

.si-trust-badge svg {
    color: var(--si-accent-primary);
    flex-shrink: 0;
}

/* Stats Row (Hero) */
.si-hero-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--si-space-6);
    margin-top: var(--si-space-8);
    padding-top: var(--si-space-6);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.si-hero-stat-number {
    font-size: var(--si-text-2xl);
    font-weight: 800;
    color: var(--si-accent-primary);
    display: block;
}

.si-hero-stat-label {
    font-size: var(--si-text-xs);
    color: var(--si-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Timeline */
.si-timeline {
    position: relative;
    max-width: 800px;
    margin: 0 auto;
}

.si-timeline::before {
    content: '';
    position: absolute;
    left: 24px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--si-accent-primary);
    opacity: 0.3;
}

.si-timeline-step {
    display: flex;
    gap: var(--si-space-6);
    margin-bottom: var(--si-space-8);
    position: relative;
}

.si-timeline-dot {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--si-accent-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 700;
    font-size: var(--si-text-sm);
    z-index: 1;
}

.si-timeline-period {
    font-size: var(--si-text-xs);
    font-weight: 700;
    color: var(--si-accent-primary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--si-space-1);
}

.si-timeline-content h3 {
    font-size: var(--si-text-lg);
    font-weight: 700;
    margin-bottom: var(--si-space-2);
}

.si-timeline-content p {
    font-size: var(--si-text-sm);
    color: var(--si-text-muted);
    line-height: 1.6;
}

/* Comparison Table */
.si-comparison-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--si-text-sm);
}

.si-comparison-table thead th {
    padding: var(--si-space-4);
    text-align: left;
    font-weight: 700;
    border-bottom: 2px solid var(--si-border-dark);
    color: var(--si-text-dark);
}

.si-comparison-table thead th:first-child {
    width: 40%;
}

.si-comparison-table thead th.si-highlight {
    background: rgba(158, 0, 93, 0.05);
    color: var(--si-accent-primary);
}

.si-comparison-table tbody td {
    padding: var(--si-space-3) var(--si-space-4);
    border-bottom: 1px solid var(--si-border-light);
    vertical-align: middle;
}

.si-comparison-table tbody td.si-highlight {
    background: rgba(158, 0, 93, 0.03);
    font-weight: 600;
}

.si-comparison-check {
    color: #10b981;
}

.si-comparison-x {
    color: #ef4444;
}

.si-comparison-partial {
    color: #f59e0b;
}

/* Process Steps */
.si-process-step {
    display: flex;
    align-items: flex-start;
    gap: var(--si-space-4);
    margin-bottom: var(--si-space-6);
}

.si-process-number {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: var(--si-radius-md);
    background: var(--si-accent-primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: var(--si-text-sm);
}

.si-process-content h3 {
    font-size: var(--si-text-base);
    font-weight: 700;
    margin-bottom: var(--si-space-1);
}

.si-process-content p {
    font-size: var(--si-text-sm);
    color: var(--si-text-muted);
    line-height: 1.5;
}

/* Related Industries */
.si-related-industry-link {
    display: block;
    padding: var(--si-space-4) var(--si-space-5);
    background: var(--si-bg-card);
    border: 1px solid var(--si-border-light);
    border-radius: var(--si-radius-md);
    text-decoration: none;
    color: var(--si-text-dark);
    font-weight: 600;
    transition: border-color var(--si-transition-fast), transform var(--si-transition-fast);
}

.si-related-industry-link:hover {
    border-color: var(--si-accent-primary);
    transform: translateY(-2px);
}

/* Guarantee Section */
.si-guarantee-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--si-space-6);
}

.si-guarantee-item {
    text-align: center;
}

.si-guarantee-icon {
    color: var(--si-accent-primary);
    margin-bottom: var(--si-space-3);
}

/* Geographic Coverage */
.si-geo-regions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--si-space-4);
    margin-top: var(--si-space-6);
}

.si-geo-region h4 {
    font-size: var(--si-text-base);
    font-weight: 700;
    color: var(--si-text-white);
    margin-bottom: var(--si-space-2);
}

.si-geo-region ul {
    list-style: none;
    padding: 0;
}

.si-geo-region li {
    font-size: var(--si-text-sm);
    color: var(--si-text-muted);
    padding: var(--si-space-1) 0;
}

/* Responsive: Industry components */
@media (max-width: 767px) {
    .si-hero-stats {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--si-space-4);
    }

    .si-trust-bar {
        flex-direction: column;
        align-items: center;
        gap: var(--si-space-4);
    }

    .si-guarantee-grid {
        grid-template-columns: 1fr;
    }

    .si-geo-regions {
        grid-template-columns: 1fr;
    }

    .si-comparison-table {
        font-size: var(--si-text-xs);
    }

    .si-comparison-table thead th,
    .si-comparison-table tbody td {
        padding: var(--si-space-2);
    }
}

/* ═══════════ FOUNDER CARD ═══════════ */
.si-founder-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 48px 32px;
    background: linear-gradient(135deg, #1E293B, #0F172A);
    border-radius: 16px;
    border: 1px solid #374151;
    max-width: 300px;
    margin: 0 auto;
}
.si-founder-card--photo {
    max-width: 360px;
    padding: 0;
    overflow: hidden;
}
.si-founder-card--photo .si-founder-info {
    padding: var(--si-space-5) var(--si-space-6);
}
.si-founder-photo {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    aspect-ratio: 1 / 1;
}
.si-founder-initials {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: linear-gradient(135deg, #9e005d, #FBBF24);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
    font-weight: 800;
    color: #FFFFFF;
    margin-bottom: 24px;
    font-family: 'DM Sans', sans-serif;
}
.si-founder-info h3 {
    color: #F9FAFB;
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 8px;
}
.si-founder-info p {
    color: #D1D5DB;
    font-size: 0.9rem;
}

/* ═══════════ MERCI PAGE + GLOBAL FIXES (v1.4.3) ═══════════ */

/* Fix 1: Center hero success checkmark icon (SVG is display:block globally) */
.si-success-icon {
  display: flex;
  justify-content: center;
}

/* Fix 2: Center card icons in text-center cards */
.si-card-icon {
  width: 100%;
  width: 100%;
  display: flex;
  justify-content: center;
  margin-bottom: var(--si-space-4);
}

/* Fix 3: Ensure CTA section subtitle text is centered */
.si-cta-section .si-section-subtitle,
.si-cta-section p {
  text-align: center;
  margin-inline: auto;
}

/* Fix 4: Footer contact icons — align to top of first text line */
.si-footer-contact li {
  align-items: flex-start;
}
.si-footer-contact li svg {
  margin-top: 3px;
}

/* ═══════════ Fix industry page challenge/solution card text truncation ═══════════ */
.si-challenges-grid .si-card-text,
.si-solutions-grid .si-card-text {
    -webkit-line-clamp: unset !important;
    line-clamp: unset !important;
    display: block !important;
    overflow: visible !important;
    max-height: none !important;
    text-overflow: unset !important;
    -webkit-box-orient: unset !important;
}
