/*
 * Nexren AI
 * Complete CSS Design System
 * Converted from Elementor Template Kit v1.0.0
 *
 * Fonts  : DM Sans (headings + body/UI)
 * Colors : Primary #0F0B27 · Accent #4C37C4 · Secondary #9482FB · Yellow #FFAE00
 * ─────────────────────────────────────────────────────────────────────────────
 */

/* ══════════════════════════════════════════
   GOOGLE FONTS
   ══════════════════════════════════════════ */
/* @import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,700;1,400&display=swap'); */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap');
/* ══════════════════════════════════════════
   CSS CUSTOM PROPERTIES
   ══════════════════════════════════════════ */
:root {
  /* Brand Colors */
  --c-primary:    #0F0B27;
  --c-secondary:  #9482FB;
  --c-accent:     #4C37C4;
  --c-yellow:     #FFAE00;

  /* Text / Neutral */
  --c-text:       #37344B;
  --c-text-muted: rgba(55, 52, 75, 0.65);
  --c-white:      #FFFFFF;
  --c-white-70:   rgba(255, 255, 255, 0.70);
  --c-white-30:   rgba(255, 255, 255, 0.22);  /* #FFFFFF38 */
  --c-border:     #EFEFF1;
  --c-bg:         #FAFAFA;

  /* Typography */
  --f-heading: 'DM Sans', sans-serif;
  --f-body:    'DM Sans', sans-serif;

  /* Sizing */
  --max-w:           1320px;
  --container-px:    50px;
  --container-px-md: 30px;
  --container-px-sm: 20px;

  /* Section Padding */
  --sp: 120px;
  --sp-md: 60px;
  --sp-sm: 40px;

  /* Border Radius */
  --r-btn:  99px;
  --r-card: 20px;
  --r-sm:   10px;

  /* Shadows */
  --shadow-card:  0 4px 40px rgba(15, 11, 39, 0.08);
  --shadow-hover: 0 12px 48px rgba(76, 55, 196, 0.18);

  /* Transition */
  --t: 0.3s ease;
}

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

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--c-text);
  background: var(--c-white);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img, video { display: block; max-width: 100%; height: auto; }
a { text-decoration: none; color: inherit; }
ul, ol { list-style: none; }
button, input, select, textarea { font-family: inherit; }
button { cursor: pointer; background: none; border: none; }

/* ══════════════════════════════════════════
   TYPOGRAPHY SCALE
   ══════════════════════════════════════════ */
h1, h2, h3, h4, h5, h6 {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 600;
  line-height: 1.2;
  color: var(--c-primary);
}

h1 { font-size: 4rem; }
h2 { font-size: 3rem; }
h3 { font-size: 2.5rem; }
h4 { font-size: 2.25rem; }
h5 { font-size: 1.5rem; }
h6 { font-size: 1.25rem; }

.display-text {
  font-family: var(--f-heading);
  font-size: 12.5rem;
  font-weight: 600;
  line-height: 1.2;
  text-transform: uppercase;
}

p {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.6;
  color: var(--c-text-muted);
}

/* ══════════════════════════════════════════
   LAYOUT — Container
   ══════════════════════════════════════════ */
.container {
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--container-px);
}

/* ══════════════════════════════════════════
   SECTION BASE
   ══════════════════════════════════════════ */
.section {
  padding-block: var(--sp);
}

.section--dark {
  background: var(--c-primary);
}
.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4,
.section--dark h5,
.section--dark h6 { color: var(--c-white); }
.section--dark p { color: var(--c-white-70); }

.section--bg {
  background: var(--c-bg);
}

/* ══════════════════════════════════════════
   SECTION TAG / LABEL
   ══════════════════════════════════════════ */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--f-body);
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-accent);
  margin-bottom: 14px;
}

.tag::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  flex-shrink: 0;
}

.section--dark .tag { color: var(--c-yellow); }

/* Section heading block utility */
.section-head {
  margin-bottom: 60px;
}

.section-head--center {
  text-align: center;
  max-width: 720px;
  margin-inline: auto;
  margin-bottom: 60px;
}

.section-head h2 { margin-bottom: 16px; }
.section-head p  { max-width: 600px; }
.section-head--center p { margin-inline: auto; }

/* ══════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: var(--r-btn);
  font-family: var(--f-body);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.01em;
  white-space: nowrap;
  border: 1.5px solid transparent;
  transition: var(--t);
  cursor: pointer;
}

.btn--sm{
  background: black;
  color: white;
  border-color: black;
  padding: 14px 28px;
}
.btn--sm:hover {
  background: black;
  border-color: black;
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(76, 55, 196, 0.38);
}

.btn--primary {
  background: var(--c-accent);
  color: var(--c-white);
  border-color: var(--c-accent);
}
.btn--primary:hover {
  background: #3a2aa0;
  border-color: #3a2aa0;
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(76, 55, 196, 0.38);
}

.btn--secondary {
  background: transparent;
  color: var(--c-white);
  border-color: rgba(255, 255, 255, 0.35);
}
.btn--secondary:hover {
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(255, 255, 255, 0.70);
}

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

.btn--outline-whiteblack{
  color: black;
  border-color: rgb(156, 155, 155);
  padding: 14px 28px;
}
.btn--outline-whiteblack:hover {
  background: black;
  color: white;
  border-color: white;
}

.btn--white {
  background: var(--c-white);
  color: var(--c-primary);
  border-color: var(--c-white);
}
.btn--white:hover {
  background: var(--c-bg);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(255, 255, 255, 0.2);
}

.btn svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════
   NAVIGATION / HEADER
   ══════════════════════════════════════════ */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
  background: var(--c-primary);
  transition: box-shadow 0.3s;
}

.site-header.scrolled {
  box-shadow: 0 4px 30px rgba(15, 11, 39, 0.5);
}

.header__inner {
  max-width: var(--max-w);
  margin-inline: auto;
  padding: 22px var(--container-px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}

/* Logo */
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.logo__img {
  height: 36px;
  width: auto;
}

.logo__text {
  font-family: var(--f-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--c-white);
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 1;
}

/* Nav menu */
.nav {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
  justify-content: center;
}

.nav__item {
  position: relative;
}

.nav__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-family: var(--f-body);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.2;
  color: var(--c-white-30);
  border-radius: 6px;
  transition: var(--t);
}

.nav__link:hover,
.nav__link--active {
  color: var(--c-white);
}

/* New badge */
.nav__badge {
  display: inline-block;
  padding: 2px 6px;
  background: var(--c-yellow);
  color: var(--c-primary);
  font-size: 0.6rem;
  font-weight: 700;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.5;
}

/* Nav CTA */
.header__cta { flex-shrink: 0; }

/* Hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  padding: 4px;
  flex-shrink: 0;
  cursor: pointer;
}

.hamburger__line {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--c-white);
  border-radius: 2px;
  transition: var(--t);
  transform-origin: center;
}

.hamburger.is-active .hamburger__line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.is-active .hamburger__line:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.is-active .hamburger__line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav overlay + drawer */
.mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(15, 11, 39, 0.75);
  z-index: 998;
}

.mobile-overlay.is-open { display: block; }

.mobile-nav {
  position: fixed;
  top: 0;
  right: -100%;
  width: min(320px, 88vw);
  height: 100dvh;
  background: var(--c-primary);
  border-left: 1px solid rgba(255, 255, 255, 0.08);
  z-index: 999;
  padding: 100px 28px 40px;
  display: flex;
  flex-direction: column;
  gap: 0;
  transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}

.mobile-nav.is-open { right: 0; }

.mobile-nav__link {
  display: block;
  padding: 14px 0;
  font-family: var(--f-body);
  font-size: 1rem;
  font-weight: 500;
  color: var(--c-white-30);
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  transition: color 0.2s;
}

.mobile-nav__link:hover { color: var(--c-white); }

.mobile-nav__cta {
  margin-top: 28px;
  width: 100%;
  display: flex;
  justify-content: center;
}

/* ══════════════════════════════════════════
   PAGE HERO (Inner Pages)
   ══════════════════════════════════════════ */
.page-hero {
  background: url('https://tolkio.tokotema.xyz/wp-content/uploads/2025/04/image-13.png') center/cover no-repeat;
  padding-top: 240px;
  padding-bottom: var(--sp);
  text-align: center;
  color: var(--c-white);
  position: relative;
}

.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
}

.page-hero > .container { position: relative; z-index: 1; }

.page-hero h1 {
  font-size: 4rem;
  color: var(--c-white);
  margin-bottom: 20px;
}

/* Breadcrumb */
.breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-body);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--c-white-70);
}

.breadcrumb a { color: var(--c-white-70); transition: color 0.2s; }
.breadcrumb a:hover { color: var(--c-white); }

.breadcrumb__sep {
  color: var(--c-white-30);
  font-size: 0.75rem;
}

.breadcrumb span:last-child { color: var(--c-yellow); }

/* ══════════════════════════════════════════
   HOME HERO SECTION
   ══════════════════════════════════════════ */
.hero {
  background: var(--c-primary) url('https://tolkio.tokotema.xyz/wp-content/uploads/2025/04/image-7.jpg') center/cover no-repeat;
  padding-top: 245px;
  padding-bottom: 120px;
  position: relative;
  overflow: hidden;
  color: var(--c-white);
}

.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(15,11,39,0.90) 0%, rgba(15,11,39,0.60) 100%);
  z-index: 0;
}

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

.hero__grid {
  display: grid;
  grid-template-columns: 41.22fr 58.78fr;
  gap: 60px;
  align-items: center;
}

.hero__content { display: flex; flex-direction: column; align-items: flex-start; }

.hero__content .tag { margin-bottom: 20px; }

.hero__heading {
  font-family: var(--f-heading);
  font-size: 4rem;
  font-weight: 600;
  line-height: 1.15;
  color: var(--c-white);
  margin-bottom: 20px;
}

.hero__sub {
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--c-white-70);
  margin-bottom: 16px;
  line-height: 1.5;
}

.hero__desc {
  font-size: 1rem;
  color: var(--c-white-30);
  margin-bottom: 40px;
  max-width: 480px;
  line-height: 1.7;
}

.hero__actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.hero__image {
  display: flex;
  justify-content: center;
  align-items: center;
}

.hero__img {
  width: 100%;
  max-width: 660px;
  border-radius: 20px;
  object-fit: contain;
  /* Glow effect */
  filter: drop-shadow(0 0 60px rgba(76, 55, 196, 0.40));
}

/* Decorative orb */
.hero__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  z-index: 0;
  pointer-events: none;
}
.hero__orb--1 {
  width: 600px; height: 600px;
  background: rgba(76, 55, 196, 0.25);
  top: -200px; right: -100px;
}
.hero__orb--2 {
  width: 400px; height: 400px;
  background: rgba(148, 130, 251, 0.15);
  bottom: -100px; left: 30%;
}

/* ══════════════════════════════════════════
   HOW IT WORKS / STATS
   ══════════════════════════════════════════ */
.stats {
  background: var(--c-white);
  padding-block: var(--sp);
  border-bottom: 1px solid var(--c-border);
}

.stats__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  text-align: center;
}

.stat-item {}

.stat-item__num {
  font-family: var(--f-heading);
  font-size: 3.5rem;
  font-weight: 700;
  color: var(--c-accent);
  line-height: 1;
  margin-bottom: 10px;
}

.stat-item__label {
  font-family: var(--f-body);
  font-size: 1rem;
  font-weight: 500;
  color: var(--c-text-muted);
}

.stats__divider {
  width: 1px;
  background: var(--c-border);
  align-self: stretch;
}

/* How It Works steps */
.how-works__steps {
  margin-top: 60px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  position: relative;
}

.how-works__steps::before {
  content: '';
  position: absolute;
  top: 30px;
  left: calc(16.67% + 30px);
  right: calc(16.67% + 30px);
  height: 1px;
  background: var(--c-border);
  z-index: 0;
}

.step-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
}

.step-item__num {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--c-accent);
  color: var(--c-white);
  font-family: var(--f-heading);
  font-size: 1.25rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  flex-shrink: 0;
  box-shadow: 0 4px 20px rgba(76, 55, 196, 0.30);
}

.step-item__title {
  font-family: var(--f-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 10px;
}

.step-item__desc {
  font-size: 0.925rem;
  color: var(--c-text-muted);
  line-height: 1.65;
}

/* ══════════════════════════════════════════
   FEATURES SECTION
   ══════════════════════════════════════════ */
.features { background: var(--c-bg); }

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

.feature-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  padding: 36px 28px;
  transition: var(--t);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.feature-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
  border-color: rgba(76, 55, 196, 0.20);
}

.feature-card__icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: rgba(76, 55, 196, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
  flex-shrink: 0;
}

.feature-card__icon svg { width: 28px; height: 28px; }

.feature-card__img {
  width: 56px;
  height: 56px;
  object-fit: contain;
}

.feature-card__title {
  font-family: var(--f-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 0;
}

.feature-card__desc {
  font-size: 0.925rem;
  color: var(--c-text-muted);
  line-height: 1.65;
}

.feature-card__divider {
  height: 1px;
  background: var(--c-border);
  margin: 4px 0;
}

.feature-card__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-body);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--c-accent);
  margin-top: auto;
  transition: gap 0.2s;
}

.feature-card__link:hover { gap: 10px; }

.feature-card__link svg { width: 14px; height: 14px; }

/* ══════════════════════════════════════════
   MOBILE APP SECTION
   ══════════════════════════════════════════ */
.mobile-app {
  background: var(--c-primary);
  position: relative;
  overflow: hidden;
}

.mobile-app__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.mobile-app__content {}
.mobile-app__content h2 { color: var(--c-white); margin-bottom: 20px; }
.mobile-app__content p  { color: var(--c-white-70); margin-bottom: 36px; }

.mobile-app__badges {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.badge-img {
  height: 52px;
  width: auto;
  border-radius: 10px;
  transition: transform 0.2s, opacity 0.2s;
}

.badge-img:hover { transform: translateY(-2px); opacity: 0.90; }

/* Placeholder badge (if images missing) */
.badge-placeholder {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  border: 1.5px solid rgba(255,255,255,0.30);
  border-radius: 10px;
  color: var(--c-white);
  font-family: var(--f-body);
  font-size: 0.8rem;
  font-weight: 500;
  cursor: pointer;
  transition: var(--t);
}
.badge-placeholder:hover { background: rgba(255,255,255,0.06); }

.badge-placeholder__icon { font-size: 1.6rem; }
.badge-placeholder__text small { display: block; font-size: 0.65rem; opacity: 0.7; text-transform: uppercase; letter-spacing: 0.05em; }
.badge-placeholder__text strong { font-size: 0.95rem; font-weight: 600; font-family: var(--f-heading); }

.mobile-app__image {
  display: flex;
  justify-content: center;
  position: relative;
}

.mobile-app__img {
  max-width: 100%;
  border-radius: 20px;
  filter: drop-shadow(0 0 50px rgba(148, 130, 251, 0.35));
}

/* ══════════════════════════════════════════
   WHO WE ARE / ABOUT PREVIEW
   ══════════════════════════════════════════ */
.about-preview {
  background: var(--c-white);
}

.about-preview__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.about-preview__img {
  width: 100%;
  border-radius: var(--r-card);
  object-fit: cover;
  box-shadow: var(--shadow-card);
}

.about-preview__content h2 { margin-bottom: 20px; }
.about-preview__content p  { margin-bottom: 32px; }

/* ══════════════════════════════════════════
   FEATURE CARDS (3-card strip)
   ══════════════════════════════════════════ */
.feature-strip { background: var(--c-bg); }

.feature-strip__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.strip-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  padding: 36px 28px;
  transition: var(--t);
}

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

.strip-card__icon {
  margin-bottom: 24px;
}

.strip-card__icon img {
  width: 56px;
  height: 56px;
  object-fit: contain;
}

.strip-card__icon-box {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: rgba(76,55,196,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
}

.strip-card__icon-box svg { width: 28px; height: 28px; }

.strip-card__title {
  font-family: var(--f-heading);
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 16px;
}

.strip-card__divider {
  height: 1px;
  background: var(--c-border);
  margin: 20px 0;
}

.strip-card__desc {
  font-size: 0.925rem;
  color: var(--c-text-muted);
  line-height: 1.65;
}

/* ══════════════════════════════════════════
   PARTNERS SECTION
   ══════════════════════════════════════════ */
.partners { background: var(--c-white); }

.partners__grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
  flex-wrap: wrap;
}

.partner-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  filter: grayscale(1);
  opacity: 0.5;
  transition: var(--t);
}

.partner-logo:hover { filter: grayscale(0); opacity: 1; }

.partner-logo img { height: 100%; width: auto; object-fit: contain; }

/* Placeholder partner boxes */
.partner-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 60px;
  border: 1px solid var(--c-border);
  border-radius: 10px;
  background: var(--c-bg);
  font-family: var(--f-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--c-text-muted);
  transition: var(--t);
}

.partner-placeholder:hover {
  border-color: var(--c-accent);
  color: var(--c-accent);
}

/* ══════════════════════════════════════════
   SERVICES SECTION
   ══════════════════════════════════════════ */
.services { background: var(--c-bg); }

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

.service-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: var(--t);
  position: relative;
  overflow: hidden;
}

.service-card:hover {
  border-color: rgba(76,55,196,0.25);
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

.service-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-accent), var(--c-secondary));
  opacity: 0;
  transition: opacity 0.3s;
}

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

.service-card__icon {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  background: rgba(76,55,196,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
  flex-shrink: 0;
}

.service-card__icon svg { width: 32px; height: 32px; }
.service-card__icon img { width: 36px; height: 36px; object-fit: contain; }

.service-card__title {
  font-family: var(--f-heading);
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--c-primary);
}

.service-card__desc {
  font-size: 0.925rem;
  color: var(--c-text-muted);
  line-height: 1.7;
  flex: 1;
}

.service-card__footer {
  margin-top: auto;
}

/* ══════════════════════════════════════════
   WHY CHOOSE SECTION
   ══════════════════════════════════════════ */
.why-choose {
  background: var(--c-primary);
  position: relative;
  overflow: hidden;
}

.why-choose::before {
  content: '';
  position: absolute;
  top: -300px; right: -200px;
  width: 700px; height: 700px;
  border-radius: 50%;
  background: rgba(76, 55, 196, 0.15);
  filter: blur(120px);
  pointer-events: none;
}

.why-choose__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
  z-index: 1;
}

.why-choose__content {}
.why-choose__content h2 { color: var(--c-white); margin-bottom: 20px; }
.why-choose__content > p { color: var(--c-white-70); margin-bottom: 36px; }

.why-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 40px;
}

.why-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.why-item__icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: rgba(76, 55, 196, 0.30);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-secondary);
  flex-shrink: 0;
}

.why-item__icon svg { width: 22px; height: 22px; }

.why-item__body {}

.why-item__title {
  font-family: var(--f-heading);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--c-white);
  margin-bottom: 6px;
}

.why-item__desc {
  font-size: 0.9rem;
  color: var(--c-white-70);
  line-height: 1.6;
}

.why-choose__image {
  display: flex;
  justify-content: center;
  align-items: center;
}

.why-choose__img {
  width: 100%;
  max-width: 500px;
  border-radius: 20px;
  filter: drop-shadow(0 0 60px rgba(148, 130, 251, 0.30));
}

/* ══════════════════════════════════════════
   TESTIMONIALS
   ══════════════════════════════════════════ */
.testimonials { background: var(--c-bg); }

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

.testimonial-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: var(--t);
}

.testimonial-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
  border-color: rgba(76,55,196,0.20);
}

.testimonial-card__stars {
  display: flex;
  gap: 4px;
  color: var(--c-yellow);
  font-size: 1.125rem;
}

.testimonial-card__quote {
  font-size: 1rem;
  color: var(--c-text);
  line-height: 1.7;
  font-style: italic;
  flex: 1;
}

.testimonial-card__divider {
  height: 1px;
  background: var(--c-border);
}

.testimonial-card__author {
  display: flex;
  align-items: center;
  gap: 14px;
}

.testimonial-card__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--c-border);
  flex-shrink: 0;
}

/* Placeholder avatar */
.testimonial-card__avatar--placeholder {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--c-accent), var(--c-secondary));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-white);
  font-family: var(--f-heading);
  font-size: 1rem;
  font-weight: 700;
  flex-shrink: 0;
}

.testimonial-card__name {
  font-family: var(--f-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 2px;
}

.testimonial-card__role {
  font-size: 0.825rem;
  color: var(--c-text-muted);
}

/* ══════════════════════════════════════════
   CTA BANNER
   ══════════════════════════════════════════ */
/* ══════════════════════════════════════════
   RESPONSIVE CTA BANNER FIX
   ══════════════════════════════════════════ */
.cta-banner {
  background: var(--c-primary) url("https://tolkio.tokotema.xyz/wp-content/uploads/2025/04/image-7.jpg") center/cover no-repeat;
  position: relative;
  overflow: hidden;
  text-align: center;
  padding-block: var(--sp); /* Uses your design system's padding */
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Remove the fixed 1000px width/height that breaks mobile */
.cta-banner .container {
  max-width: var(--max-w);
  width: 100%;
  height: auto; /* Allow height to expand based on text */
  background: none; /* Remove duplicate background image */
  position: relative;
  z-index: 2;
}

/* Updated Overlay for better text legibility */
.cta-banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(15, 11, 39, 0.7); /* Dark overlay to make text pop */
  z-index: 1;
}

.cta-banner__inner {
  position: relative;
  z-index: 3;
  max-width: 800px;
  margin-inline: auto;
}

/* Make font sizes fluid */
.cta-banner h2 {
  font-size: clamp(2rem, 5vw, 4rem); /* Responsive size between 2rem and 4rem */
  color: var(--c-white);
  margin-bottom: 20px;
}

.cta-banner p {
  font-size: clamp(1rem, 2vw, 1.125rem);
  color: var(--c-white-70);
  margin-bottom: 40px;
  line-height: 1.7;
}

.cta-banner__actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

/* Decorative Glow (Responsive) */
.cta-banner::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60%; 
  height: 60%;
  background: rgba(76, 55, 196, 0.3);
  filter: blur(100px);
  z-index: 1;
  pointer-events: none;
}

/* Mobile Adjustments */
@media (max-width: 768px) {
  .cta-banner {
    padding-block: var(--sp-md);
  }
  
  .cta-banner__actions {
    flex-direction: column;
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
  }
  
  .cta-banner__actions .btn {
    width: 100%;
  }
}

/* ══════════════════════════════════════════
   PRICING CARDS
   ══════════════════════════════════════════ */
.pricing-section { background: var(--c-border); }

.pricing__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  align-items: stretch;
}

.pricing-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  transition: var(--t);
}

.pricing-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-6px);
}

.pricing-card--featured {
  background: var(--c-primary);
  border-color: var(--c-accent);
  box-shadow: 0 8px 40px rgba(76,55,196,0.30);
}

.pricing-card--featured h3,
.pricing-card--featured .pricing-card__price,
.pricing-card--featured .pricing-card__title { color: var(--c-white); }
.pricing-card--featured p { color: var(--c-white-70); }

.pricing-card__badge {
  display: inline-block;
  padding: 4px 12px;
  background: var(--c-yellow);
  color: var(--c-primary);
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: var(--r-btn);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  width: fit-content;
}

.pricing-card__icon {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  background: rgba(76,55,196,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
}

.pricing-card--featured .pricing-card__icon { background: rgba(255,255,255,0.10); color: var(--c-secondary); }

.pricing-card__icon svg { width: 32px; height: 32px; }
.pricing-card__icon img { width: 36px; height: 36px; object-fit: contain; }

.pricing-card__title {
  font-family: var(--f-heading);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--c-primary);
}

.pricing-card__price {
  font-family: var(--f-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--c-accent);
  line-height: 1;
}

.pricing-card--featured .pricing-card__price { color: var(--c-secondary); }

.pricing-card__price span {
  font-size: 1rem;
  font-weight: 400;
  font-family: var(--f-body);
  color: var(--c-text-muted);
}

.pricing-card--featured .pricing-card__price span { color: var(--c-white-30); }

.pricing-card__desc {
  font-size: 0.925rem;
  color: var(--c-text-muted);
  line-height: 1.65;
}

.pricing-card__divider {
  height: 1px;
  background: var(--c-border);
}
.pricing-card--featured .pricing-card__divider { background: rgba(255,255,255,0.10); }

.pricing-card__features {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}

.pricing-card__feature {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.925rem;
  color: var(--c-text);
  font-weight: 500;
}

.pricing-card--featured .pricing-card__feature { color: var(--c-white-70); }

.pricing-card__check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(76,55,196,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
  flex-shrink: 0;
}

.pricing-card--featured .pricing-card__check { background: rgba(255,255,255,0.12); color: var(--c-secondary); }

.pricing-card__check svg { width: 12px; height: 12px; }

.pricing-card__cta { margin-top: auto; }

/* ══════════════════════════════════════════
   ABOUT PAGE — STORY TIMELINE
   ══════════════════════════════════════════ */
.about-story { background: var(--c-bg); }

.timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  max-width: 800px;
  margin-inline: auto;
}

.timeline::before {
  content: '';
  position: absolute;
  left: 30px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--c-border);
}

.timeline-item {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 28px;
  padding-bottom: 40px;
  position: relative;
}

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

.timeline-item__dot {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--c-accent);
  color: var(--c-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--f-heading);
  font-size: 0.875rem;
  font-weight: 700;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  box-shadow: 0 0 0 4px var(--c-bg), 0 4px 16px rgba(76,55,196,0.25);
}

.timeline-item__content { padding-top: 12px; }

.timeline-item__year {
  font-family: var(--f-heading);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--c-accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}

.timeline-item__title {
  font-family: var(--f-heading);
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 10px;
}

.timeline-item__desc {
  font-size: 0.925rem;
  color: var(--c-text-muted);
  line-height: 1.65;
}

/* Values cards */
.values__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.value-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  padding: 36px 28px;
  text-align: center;
  transition: var(--t);
  
}

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

.value-card__icon {
  width: 72px;
  height: 72px;
  border-radius: 20px;
  background: rgba(76,55,196,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
  margin: 0 auto 20px;
}

.value-card__icon svg { width: 36px; height: 36px; }

.value-card__title {
  font-family: var(--f-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 12px;
}

.value-card__desc {
  font-size: 0.9rem;
  color: var(--c-text-muted);
  line-height: 1.65;
}

/* Vision / Quote block */
.vision-block {
  background: var(--c-primary);
  border-radius: var(--r-card);
  padding: 60px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.vision-block::before {
  content: '"';
  position: absolute;
  top: -20px; left: 30px;
  font-family: var(--f-heading);
  font-size: 12rem;
  color: rgba(76,55,196,0.15);
  line-height: 1;
  pointer-events: none;
}

.vision-block__quote {
  font-family: var(--f-heading);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--c-white);
  line-height: 1.5;
  margin-bottom: 24px;
  max-width: 700px;
  margin-inline: auto;
}

.vision-block__author {
  font-size: 0.925rem;
  color: var(--c-white-70);
  font-weight: 500;
}

.vision-block__author strong {
  color: var(--c-secondary);
  font-family: var(--f-heading);
  font-weight: 600;
}

/* ══════════════════════════════════════════
   TEAM SECTION
   ══════════════════════════════════════════ */
.team-section { background: var(--c-white); }

.team__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.team-card {
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  overflow: hidden;
  transition: var(--t);
}

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

.team-card__img-wrap {
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--c-border);
}

.team-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.team-card:hover .team-card__img { transform: scale(1.05); }

/* Placeholder team avatar */
.team-card__img-placeholder {
  width: 100%;
  aspect-ratio: 1;
  background: linear-gradient(135deg, var(--c-accent), var(--c-secondary));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-white);
  font-family: var(--f-heading);
  font-size: 3rem;
  font-weight: 700;
}

.team-card__info {
  padding: 24px 20px;
}

.team-card__name {
  font-family: var(--f-heading);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 4px;
}

.team-card__role {
  font-size: 0.825rem;
  color: var(--c-accent);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 12px;
}

.team-card__desc {
  font-size: 0.875rem;
  color: var(--c-text-muted);
  line-height: 1.6;
}

/* ══════════════════════════════════════════
   CONTACT PAGE
   ══════════════════════════════════════════ */
.contact-section { background: var(--c-bg); }

.contact-info__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-bottom: 60px;
}

.contact-card {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  padding: 40px 28px;
  text-align: center;
  transition: var(--t);
}

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

.contact-card__icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(76,55,196,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
  margin: 0 auto 20px;
}

.contact-card__icon svg { width: 30px; height: 30px; }

.contact-card__title {
  font-family: var(--f-heading);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 12px;
}

.contact-card__detail {
  font-size: 0.925rem;
  color: var(--c-text-muted);
  line-height: 1.8;
}

.contact-card__detail a { color: var(--c-accent); transition: opacity 0.2s; }
.contact-card__detail a:hover { opacity: 0.75; }

/* Map */
.map-wrap {
  border-radius: var(--r-card);
  overflow: hidden;
  border: 1px solid var(--c-border);
  margin-bottom: 60px;
}

.map-wrap iframe {
  display: block;
  width: 100%;
  height: 450px;
  border: none;
}

/* Contact form */
.contact-form-wrap {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  border-radius: var(--r-card);
  padding: 60px;
}

.contact-form-wrap h3 {
  font-family: var(--f-heading);
  font-size: 2rem;
  font-weight: 600;
  color: var(--c-primary);
  margin-bottom: 8px;
}

.contact-form-wrap > p {
  font-size: 1rem;
  color: var(--c-text-muted);
  margin-bottom: 36px;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

.form-grid--2 {
  grid-template-columns: 1fr 1fr;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.form-group--full { grid-column: 1 / -1; }

.form-group label {
  font-family: var(--f-body);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--c-text);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 18px 24px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  background: var(--c-white);
  font-family: var(--f-body);
  font-size: 0.925rem;
  color: var(--c-text);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  resize: vertical;
}

.form-group input::placeholder,
.form-group textarea::placeholder { color: rgba(55,52,75,0.4); }

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--c-accent);
  box-shadow: 0 0 0 3px rgba(76,55,196,0.10);
}

.form-group textarea { min-height: 140px; }

.form-submit {
  margin-top: 8px;
}

/* ══════════════════════════════════════════
   FAQ / ACCORDION
   ══════════════════════════════════════════ */
.faq-section { background: var(--c-white); }

.accordion {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 860px;
  margin-inline: auto;
}

.accordion-item {
  border-bottom: 1px solid var(--c-border);
}

.accordion-item:first-child { border-top: 1px solid var(--c-border); }

.accordion-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 24px 0;
  text-align: left;
  cursor: pointer;
  transition: color 0.2s;
  background: none;
  border: none;
}

.accordion-trigger:hover { color: var(--c-accent); }

.accordion-trigger__text {
  font-family: var(--f-heading);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--c-primary);
  transition: color 0.2s;
}

.accordion-item.is-open .accordion-trigger__text { color: var(--c-accent); }

.accordion-trigger__icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--c-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-text-muted);
  flex-shrink: 0;
  transition: var(--t);
}

.accordion-item.is-open .accordion-trigger__icon {
  background: var(--c-accent);
  border-color: var(--c-accent);
  color: var(--c-white);
  transform: rotate(45deg);
}

.accordion-trigger__icon svg { width: 18px; height: 18px; }

.accordion-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}

.accordion-panel__inner {
  padding-bottom: 24px;
}

.accordion-panel__inner p {
  font-size: 1rem;
  color: var(--c-text-muted);
  line-height: 1.7;
}

/* ══════════════════════════════════════════
   HELP CENTER
   ══════════════════════════════════════════ */
.help-center { background: var(--c-bg); }

/* ══════════════════════════════════════════
   SERVICES DETAIL PAGE
   ══════════════════════════════════════════ */
.service-detail { background: var(--c-white); }

.service-detail__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.service-detail__content h2 { margin-bottom: 20px; }
.service-detail__content p { margin-bottom: 24px; }

.benefits-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 36px;
}

.benefit-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 0.95rem;
  color: var(--c-text);
  font-weight: 500;
}

.benefit-item::before {
  content: '';
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(76,55,196,0.10);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 10l4 4 8-8' stroke='%234C37C4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: 12px;
  background-position: center;
  background-repeat: no-repeat;
  flex-shrink: 0;
  margin-top: 2px;
}

/* ══════════════════════════════════════════
   404 PAGE
   ══════════════════════════════════════════ */
.error-page {
  min-height: 100vh;
  background: var(--c-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-block: var(--sp);
  position: relative;
  overflow: hidden;
}

.error-page::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 700px; height: 700px;
  border-radius: 50%;
  background: rgba(76,55,196,0.20);
  filter: blur(120px);
  pointer-events: none;
}

.error-page__inner {
  position: relative;
  z-index: 1;
}

.error-page__num {
  font-family: var(--f-heading);
  font-size: 12.5rem;
  font-weight: 600;
  line-height: 1;
  text-transform: uppercase;
  color: transparent;
  -webkit-text-stroke: 2px rgba(76,55,196,0.6);
  margin-bottom: 20px;
}

.error-page__title {
  font-family: var(--f-heading);
  font-size: 2.5rem;
  font-weight: 600;
  color: var(--c-accent);
  margin-bottom: 16px;
}

.error-page__desc {
  font-size: 1.125rem;
  color: var(--c-white-70);
  max-width: 500px;
  margin: 0 auto 40px;
  line-height: 1.7;
}

/* ══════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════ */
.site-footer {
  background: var(--c-primary);
  padding-top: 100px;
  padding-bottom: 60px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.footer__grid {
  display: grid;
  grid-template-columns: 27fr 16fr 16fr 16fr;
  gap: 80px;
  padding-bottom: 60px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  margin-bottom: 40px;
}

/* Brand column */
.footer__brand {}

.footer__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
}

.footer__logo-img { height: 36px; width: auto; }

.footer__logo-text {
  font-family: var(--f-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--c-white);
  text-transform: uppercase;
  letter-spacing: -0.02em;
}

.footer__desc {
  font-size: 0.925rem;
  color: var(--c-white-30);
  line-height: 1.7;
  margin-bottom: 28px;
}

.footer__social {
  display: flex;
  gap: 12px;
  margin-bottom: 28px;
}

.social-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-white-70);
  transition: var(--t);
}

.social-icon:hover {
  background: var(--c-accent);
  border-color: var(--c-accent);
  color: var(--c-white);
}

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

.footer__contact {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer__contact-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.875rem;
  color: var(--c-white-30);
}

.footer__contact-item svg { width: 16px; height: 16px; color: var(--c-accent); flex-shrink: 0; }

.footer__contact-item a { color: var(--c-white-30); transition: color 0.2s; }
.footer__contact-item a:hover { color: var(--c-white); }

/* Link columns */
.footer__col-title {
  font-family: var(--f-heading);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--c-white);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 24px;
}

.footer__links {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.footer__links a {
  font-size: 0.9rem;
  color: var(--c-white-30);
  transition: color 0.2s;
  font-weight: 400;
}

.footer__links a:hover { color: var(--c-white); }

/* Bottom bar */
.footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.footer__copy {
  font-size: 0.875rem;
  color: var(--c-white-30);
}

.footer__copy a { color: var(--c-secondary); }

.footer__legal {
  display: flex;
  align-items: center;
  gap: 24px;
}

.footer__legal a {
  font-size: 0.875rem;
  color: var(--c-white-30);
  transition: color 0.2s;
}

.footer__legal a:hover { color: var(--c-white); }

/* ══════════════════════════════════════════
   ANIMATION UTILITIES
   ══════════════════════════════════════════ */
.fade-up {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

.fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.fade-in {
  opacity: 0;
  transition: opacity 0.65s ease;
}

.fade-in.is-visible { opacity: 1; }

.fade-left {
  opacity: 0;
  transform: translateX(-32px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

.fade-left.is-visible { opacity: 1; transform: translateX(0); }

.fade-right {
  opacity: 0;
  transform: translateX(32px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

.fade-right.is-visible { opacity: 1; transform: translateX(0); }

/* Stagger delay helpers */
.delay-1 { transition-delay: 0.1s !important; }
.delay-2 { transition-delay: 0.2s !important; }
.delay-3 { transition-delay: 0.3s !important; }
.delay-4 { transition-delay: 0.4s !important; }
.delay-5 { transition-delay: 0.5s !important; }
.delay-6 { transition-delay: 0.6s !important; }

/* ══════════════════════════════════════════
   BRIDGE ALIASES — HTML shorthand class names
   ══════════════════════════════════════════ */

/* Header / Nav */
.header-inner { max-width:var(--max-w); margin-inline:auto; padding:22px var(--container-px); display:flex; align-items:center; justify-content:space-between; gap:40px; }
.site-logo { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.site-logo img { height:36px; width:auto; }
.site-nav { display:flex; align-items:center; gap:4px; flex:1; justify-content:center; }
.nav-link { display:inline-flex; align-items:center; gap:6px; padding:8px 14px; font-size:0.875rem; font-weight:500; color:var(--c-white-30); border-radius:6px; transition:var(--t); }
.nav-link:hover, .nav-link.active { color:var(--c-white); }
.header-actions { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.hamburger { display:none; flex-direction:column; justify-content:center; gap:5px; width:36px; height:36px; padding:4px; flex-shrink:0; }
.hamburger span { display:block; width:100%; height:2px; background:var(--c-white); border-radius:2px; transition:var(--t); transform-origin:center; }
.hamburger.is-active span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.is-active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.is-active span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.mobile-drawer { position:fixed; top:0; right:-100%; width:min(320px,88vw); height:100dvh; background:var(--c-primary); border-left:1px solid rgba(255,255,255,0.08); z-index:999; padding:100px 28px 40px; display:flex; flex-direction:column; gap:0; transition:right 0.35s cubic-bezier(0.4,0,0.2,1); overflow-y:auto; }
.mobile-drawer.is-open { right:0; }
.mobile-drawer a { display:block; padding:14px 0; font-size:1rem; font-weight:500; color:var(--c-white-30); border-bottom:1px solid rgba(255,255,255,0.07); transition:color 0.2s; }
.mobile-drawer a:hover { color:var(--c-white); }

/* Button extras */
.btn--sm { padding:10px 20px; font-size:0.8rem; }
.btn--outline-white { background:transparent; color:rgba(255,255,255,0.80); border:1.5px solid rgba(255,255,255,0.35); }
.btn--outline-white:hover { background:rgba(255,255,255,0.10); color:var(--c-white); border-color:rgba(255,255,255,0.65); }

/* Badge */
.badge { display:inline-flex; align-items:center; gap:6px; font-size:0.75rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:white; background:linear-gradient(90deg, #0d1761, #5d489e); border:1px solid rgba(76,55,196,0.22); padding:5px 14px; border-radius:99px; margin-bottom:16px; }
.badge--light { background:rgba(255,255,255,0.10); color:rgba(255,255,255,0.80); border-color:rgba(255,255,255,0.20); }

/* Section header block */
.section-header { text-align:center; max-width:720px; margin-inline:auto; margin-bottom:56px; }
.section-header h2 { margin-bottom:16px; }
.section-header p { margin-inline:auto; }

/* Page hero content */
.page-hero__content { max-width:800px; margin-inline:auto; }
.page-hero__content h1 { font-size:4rem; color:black; margin-bottom:20px; }
.page-hero p { font-size:1.125rem; color:black; max-width:600px; margin-inline:auto; }

/* Home hero */
.hero-home { background:var(--c-primary) url('https://tolkio.tokotema.xyz/wp-content/uploads/2025/04/image-7.jpg') center/cover no-repeat; padding-top:150px; padding-bottom:120px; position:relative; overflow:hidden; color:var(--c-white); }
.hero-home::after { content:''; position:absolute; inset:0;  z-index:0; }
.hero-home > .container { position:relative; z-index:1; }
.hero-home__grid { display:grid; grid-template-columns:41.22fr 58.78fr; gap:60px; align-items:center; }
.hero-home__content { display:flex; flex-direction:column; align-items:flex-start; }
.hero-home__content h1 { font-size:4rem; color:black; margin-bottom:20px; }
.hero-home__content p { color:black; margin-bottom:36px; max-width:480px; }
.hero-home__actions { display:flex; align-items:center; gap:16px; flex-wrap:wrap;color:black }
.hero-home__visual { display:flex; justify-content:center; align-items:center; }
.hero-home__visual img { width:100%; border-radius:20px; filter:drop-shadow(0 0 60px rgba(76,55,196,0.40)); }

/* Stats strip */
.stats-strip { background:var(--c-white); padding-block:60px; border-bottom:1px solid var(--c-border); }
.stats-strip__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; text-align:center; }
.stat-item strong { display:block; font-family:var(--f-heading); font-size:3.5rem; font-weight:700; color:black; line-height:1; margin-bottom:8px; }
.stat-item span { font-size:1rem; font-weight:500; color:var(--c-text-muted); }

/* Features grid (HTML alias) */
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.feature-card h3 { font-family:var(--f-heading); font-size:1.25rem; font-weight:600; color:var(--c-primary); margin-bottom:0; }
.feature-card p { font-size:0.925rem; color:var(--c-text-muted); line-height:1.65; margin:0; }

/* How It Works */
.how-it-works { background:var(--c-bg); }
.steps-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:32px; margin-top:0; }
.step { display:flex; flex-direction:column; align-items:center; text-align:center; gap:16px; }
.step__num { width:60px; height:60px; border-radius:50%; background:var(--c-accent); color:var(--c-white); font-family:var(--f-heading); font-size:1.25rem; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0; box-shadow:0 4px 20px rgba(76,55,196,0.30); }
.step h3 { font-family:var(--f-heading); font-size:1.125rem; font-weight:600; color:var(--c-primary); margin-bottom:0; }
.step p { font-size:0.9rem; color:var(--c-text-muted); line-height:1.65; margin:0; }

/* Mobile app section */
.mobile-app-section { background:var(--c-primary); overflow:hidden; }
.mobile-app__visual { display:flex; justify-content:center; }
.mobile-app__visual img { max-width:100%; border-radius:20px; filter:drop-shadow(0 0 50px rgba(148,130,251,0.35)); }
.mobile-app__content h2 { color:var(--c-white); margin-bottom:20px; }
.mobile-app__content p { color:var(--c-white-70); margin-bottom:24px; }
.check-list { list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:32px; }
.check-list li { display:flex; align-items:center; gap:12px; font-size:0.95rem; font-weight:500; color:black; }
.check-list li::before { content:''; width:20px; height:20px; border-radius:50%; background:rgba(76,55,196,0.30) url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 10l4 4 8-8' stroke='%239482FB' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/12px no-repeat; flex-shrink:0; }
.mobile-app-section .check-list li { color:var(--c-white-70); }
.about-preview .check-list li { color:var(--c-text-muted); }
.about-preview .check-list li::before { background:rgba(76,55,196,0.10) url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 10l4 4 8-8' stroke='%234C37C4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/12px no-repeat; }
.service-detail-content .check-list li { color:var(--c-text-muted); }
.service-detail-content .check-list li::before { background:rgba(76,55,196,0.10) url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 10l4 4 8-8' stroke='%234C37C4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/12px no-repeat; }
.app-badges { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.app-badge { display:inline-flex; align-items:center; gap:10px; padding:10px 20px; border:1.5px solid rgba(255,255,255,0.30); border-radius:10px; color:var(--c-white); font-size:0.875rem; font-weight:500; transition:var(--t); }
.app-badge:hover { background:rgba(255,255,255,0.06); border-color:rgba(255,255,255,0.55); }

/* About preview visual */
.about-preview__visual img { width:100%; border-radius:var(--r-card); object-fit:cover; box-shadow:var(--shadow-card); }

/* Why choose (dark section with grid) */
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; position:relative; z-index:1; }
.why-item { padding:28px; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:var(--r-card); transition:var(--t); }
.why-item:hover { background:rgba(76,55,196,0.15); border-color:rgba(76,55,196,0.30); }
.why-item__num { font-family:var(--f-heading); font-size:0.75rem; font-weight:700; letter-spacing:0.12em; color:var(--c-secondary); text-transform:uppercase; margin-bottom:12px; }
.why-item h3 { font-family:var(--f-heading); font-size:1.125rem; font-weight:600; color:var(--c-white); margin-bottom:10px; }
.why-item p { font-size:0.9rem; color:var(--c-white-70); line-height:1.65; margin:0; }

/* Services grid */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.services-grid--full { grid-template-columns:repeat(3,1fr); }
.service-card h3 { font-family:var(--f-heading); font-size:1.375rem; font-weight:600; color:var(--c-primary); }
.service-card p { font-size:0.925rem; color:var(--c-text-muted); line-height:1.7; margin:0; }
.service-card__list { list-style:none; display:flex; flex-direction:column; gap:8px; margin:0; }
.service-card__list li { font-size:0.875rem; color:var(--c-text-muted); padding-left:18px; position:relative; }
.service-card__list li::before { content:'·'; position:absolute; left:0; color:var(--c-accent); font-weight:700; }
.card-link { display:inline-flex; align-items:center; gap:6px; font-size:0.875rem; font-weight:600; color:var(--c-accent); margin-top:auto; transition:gap 0.2s; }
.card-link:hover { gap:10px; }

/* Partners */
.partners-section { background:var(--c-bg); padding-block:60px; border-top:1px solid var(--c-border); border-bottom:1px solid var(--c-border); }
.partners-label { text-align:center; font-size:0.8rem; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--c-text-muted); margin-bottom:28px; }
.partners-logos { display:flex; align-items:center; justify-content:center; gap:48px; flex-wrap:wrap; }
.partners-logos span { font-family:var(--f-heading); font-size:1.25rem; font-weight:700; color:var(--c-text-muted); opacity:0.55; letter-spacing:-0.02em; transition:var(--t); }
.partners-logos span:hover { opacity:1; color:var(--c-accent); }

/* Testimonials */
.testimonials-section { background:var(--c-white); }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.testimonial-card p { font-size:1rem; color:var(--c-text); line-height:1.7; font-style:italic; flex:1; margin:0; }
.author-avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--c-accent),var(--c-secondary)); display:flex; align-items:center; justify-content:center; color:var(--c-white); font-family:var(--f-heading); font-size:1rem; font-weight:700; flex-shrink:0; }
.testimonial-card__author div strong { display:block; font-family:var(--f-heading); font-size:0.95rem; font-weight:600; color:var(--c-primary); }
.testimonial-card__author div span { font-size:0.8rem; color:var(--c-text-muted); }

/* CTA banner paragraph */
.cta-banner p { font-size:1.125rem; color:var(--c-white-70); margin-bottom:36px; line-height:1.7; }

/* Footer bridge */
.footer-grid { display:grid; grid-template-columns:27fr 16fr 16fr 16fr; gap:80px; padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,0.08); margin-bottom:40px; }
.footer-brand p { font-size:0.925rem; color:var(--c-white-30); line-height:1.7; margin-bottom:24px; }
.footer-col h4 { font-family:var(--f-heading); font-size:0.875rem; font-weight:700; color:var(--c-white); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:22px; }
.footer-col ul { display:flex; flex-direction:column; gap:14px; }
.footer-col ul li a { font-size:0.9rem; color:rgb(216, 213, 213); transition:color 0.2s; }
.footer-col ul li a:hover { color:var(--c-white); }
.footer-contact-items { display:flex; flex-direction:column; gap:12px; }
.footer-contact-item { display:flex; align-items:center; gap:10px; font-size:0.875rem; color:var(--c-white-30); }
.footer-contact-item svg { color:var(--c-accent); flex-shrink:0; }
.footer-contact-item a { color:var(--c-white-30); transition:color 0.2s; }
.footer-contact-item a:hover { color:var(--c-white); }
.social-links { display:flex; gap:12px; margin-bottom:28px; }
.social-links a { width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,0.12); display:flex; align-items:center; justify-content:center; color:var(--c-white-70); transition:var(--t); }
.social-links a:hover { background:var(--c-accent); border-color:var(--c-accent); color:var(--c-white); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer-bottom p { font-size:0.875rem; color:var(--c-white-30); margin:0; }
.footer-legal { display:flex; align-items:center; gap:24px; }
.footer-legal a { font-size:0.875rem; color:var(--c-white-30); transition:color 0.2s; }
.footer-legal a:hover { color:var(--c-white); }

/* About page extras */
.about-stats { display:flex; gap:40px; flex-wrap:nowrap; margin-top:32px; }
.about-stat strong { display:block; font-family:var(--f-heading); font-size:2.5rem; font-weight:700; color:var(--c-accent); line-height:1; margin-bottom:4px; }
.about-stat span { font-size:0.875rem; color:var(--c-text-muted); font-weight:500; }
.values-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.value-card { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-card); padding:36px 28px; text-align:center; transition:var(--t); }
.value-card:hover { box-shadow:var(--shadow-hover); transform:translateY(-4px); }
.value-card__icon { font-size:2.5rem; margin-bottom:20px; display:block; }
.value-card h3 { font-family:var(--f-heading); font-size:1.25rem; font-weight:600; color:var(--c-primary); margin-bottom:12px; }
.value-card p { font-size:0.9rem; color:var(--c-text-muted); line-height:1.65; margin:0; }
.vision-section { background:var(--c-primary); padding-block:var(--sp); }
.vision-quote { max-width:820px; margin-inline:auto; text-align:center; position:relative; }
.vision-quote blockquote { font-family:var(--f-heading); font-size:1.5rem; font-weight:600; color:var(--c-white); line-height:1.5; margin-bottom:24px; font-style:normal; }
.vision-quote cite { font-size:0.925rem; color:var(--c-white-70); font-style:normal; }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.team-grid--leaders { grid-template-columns:repeat(4,1fr); }
.team-card { background:var(--c-bg); border:1px solid var(--c-border); border-radius:var(--r-card); padding:28px 24px; text-align:center; transition:var(--t); display:flex; flex-direction:column; align-items:center; gap:10px; }
.team-card:hover { box-shadow:var(--shadow-hover); transform:translateY(-4px); }
.team-card__avatar { width:72px; height:72px; border-radius:50%; background:linear-gradient(135deg,var(--c-accent),var(--c-secondary)); display:flex; align-items:center; justify-content:center; color:var(--c-white); font-family:var(--f-heading); font-size:1.5rem; font-weight:700; margin-bottom:8px; flex-shrink:0; }
.team-card h3 { font-family:var(--f-heading); font-size:1.125rem; font-weight:600; color:var(--c-primary); margin-bottom:0; }
.team-card span { font-size:0.8rem; font-weight:600; color:var(--c-accent); text-transform:uppercase; letter-spacing:0.06em; }
.team-card p { font-size:0.875rem; color:var(--c-text-muted); line-height:1.6; margin:0; }
.team-card__links { display:flex; justify-content:center; gap:10px; margin-top:8px; }
.team-card__links a { width:32px; height:32px; border-radius:50%; border:1px solid var(--c-border); display:flex; align-items:center; justify-content:center; color:var(--c-text-muted); transition:var(--t); }
.team-card__links a:hover { background:var(--c-accent); border-color:var(--c-accent); color:var(--c-white); }

/* Pricing page */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; align-items:start; }
.pricing-card__header h3 { font-family:var(--f-heading); font-size:1.5rem; font-weight:600; color:var(--c-primary); margin-bottom:8px; }
.pricing-card--featured .pricing-card__header h3 { color:var(--c-white); }
.pricing-card__header p { font-size:0.9rem; color:var(--c-text-muted); margin:0; }
.pricing-card--featured .pricing-card__header p { color:var(--c-white-70); }
.pricing-card__price { display:flex; align-items:baseline; gap:4px; }
.pricing-card__price strong { font-family:var(--f-heading); font-size:2.5rem; font-weight:700; color:var(--c-accent); line-height:1; }
.pricing-card--featured .pricing-card__price strong { color:var(--c-secondary); }
.pricing-card__price span { font-size:0.95rem; color:var(--c-text-muted); }
.pricing-card--featured .pricing-card__price span { color:var(--c-white-30); }
.pricing-card__features { display:flex; flex-direction:column; gap:12px; list-style:none; }
.pricing-card__features li { display:flex; align-items:center; gap:10px; font-size:0.9rem; font-weight:500; color:var(--c-text); }
.pricing-card--featured .pricing-card__features li { color:var(--c-white-70); }
.pricing-card__features li svg { color:var(--c-accent); flex-shrink:0; }
.pricing-card--featured .pricing-card__features li svg { color:var(--c-secondary); }
.pricing-card__features li.disabled { opacity:0.45; }
.pricing-card__features li.disabled svg { color:var(--c-text-muted); }
.pricing-card--featured .pricing-card__features li.disabled svg { color:var(--c-white-30); }

/* Contact page */
.contact-cards-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.contact-info-card { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-card); padding:28px 20px; text-align:center; transition:var(--t); }
.contact-info-card:hover { box-shadow:var(--shadow-hover); transform:translateY(-4px); }
.contact-info-card__icon { width:64px; height:64px; border-radius:50%; background:rgba(76,55,196,0.08); display:flex; align-items:center; justify-content:center; color:var(--c-accent); margin:0 auto 20px; }
.contact-info-card__icon svg { width:30px; height:30px; }
.contact-info-card h3 { font-family:var(--f-heading); font-size:1.25rem; font-weight:600; color:var(--c-primary); margin-bottom:10px; }
.contact-info-card p { font-size:0.9rem; color:var(--c-text-muted); margin-bottom:12px; }
.contact-info-card a, .contact-info-card span { font-size:0.95rem; font-weight:600; color:var(--c-accent); display:block; }
.contact-form-layout { display:grid; grid-template-columns:1fr 1.5fr; gap:60px; align-items:start; }
.contact-form-info h2 { margin-bottom:16px; }
.contact-form-info p { color:var(--c-text-muted); margin-bottom:0; }
.contact-form-card { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-card); padding:40px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { display:flex; flex-direction:column; gap:8px; margin-bottom:20px; }
.form-group label { font-size:0.875rem; font-weight:500; color:var(--c-text); }
.required { color:var(--c-accent); }
.form-status { padding:14px 18px; border-radius:var(--r-sm); font-size:0.875rem; font-weight:500; margin-top:16px; }
.form-status.success { background:#F0FDF4; color:#15803D; border:1px solid #86EFAC; }
.form-status.error { background:#FFF1F2; color:#BE123C; border:1px solid #FDA4AF; }
.map-container { border:1px solid var(--c-border); border-radius:var(--r-card); overflow:hidden; }
.map-container iframe { display:block; width:100%; height:400px; border:none; }
.map-overlay { display:flex; align-items:center; justify-content:space-between; padding:14px 20px; background:var(--c-primary); flex-wrap:wrap; gap:12px; }
.map-address { display:flex; align-items:center; gap:8px; font-size:0.875rem; color:rgba(255,255,255,0.65); }
.map-link { color:var(--c-secondary); font-weight:600; font-size:0.85rem; transition:color 0.2s; white-space:nowrap; }
.map-link:hover { color:var(--c-white); }

/* Accordion (bridge — existing uses different class structure) */
.accordion-trigger { font-family:var(--f-heading); font-size:1.05rem; font-weight:600; color:var(--c-primary); }
.accordion-trigger svg { flex-shrink:0; color:var(--c-text-muted); transition:transform 0.3s; }
.accordion-item.is-open .accordion-trigger svg { transform:rotate(180deg); }
.accordion-body { max-height:0; overflow:hidden; opacity:0; transition:max-height 0.4s ease, opacity 0.3s ease; }
.accordion-body p { font-size:0.95rem; color:var(--c-text-muted); line-height:1.7; padding-bottom:20px; margin:0; }

/* Service detail */
.service-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.service-detail-content h2 { margin-bottom:20px; }
.service-detail-content p { margin-bottom:20px; color:var(--c-text-muted); }
.service-detail-visual img { width:100%; border-radius:var(--r-card); box-shadow:var(--shadow-card); }
.benefits-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.benefit-card { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-card); padding:32px 24px; text-align:center; transition:var(--t); }
.benefit-card:hover { box-shadow:var(--shadow-hover); transform:translateY(-4px); }
.benefit-card strong { display:block; font-family:var(--f-heading); font-size:2.5rem; font-weight:700; color:var(--c-accent); line-height:1; margin-bottom:12px; }
.benefit-card h3 { font-family:var(--f-heading); font-size:1.1rem; font-weight:600; color:var(--c-primary); margin-bottom:10px; }
.benefit-card p { font-size:0.875rem; color:var(--c-text-muted); line-height:1.65; margin:0; }

/* Help center categories */
.help-categories { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.help-category { background:var(--c-white); border:1px solid var(--c-border); border-radius:var(--r-card); padding:36px 28px; text-align:center; transition:var(--t); display:flex; flex-direction:column; align-items:center; gap:12px; }
.help-category:hover { box-shadow:var(--shadow-hover); transform:translateY(-4px); border-color:rgba(76,55,196,0.25); }
.help-category__icon { font-size:2.5rem; }
.help-category h3 { font-family:var(--f-heading); font-size:1.125rem; font-weight:600; color:var(--c-primary); }
.help-category p { font-size:0.875rem; color:var(--c-text-muted); line-height:1.6; margin:0; }
.c-bg-alt { background:var(--c-bg); }

/* 404 page */
.error-page__number { font-family:var(--f-heading); font-size:12.5rem; font-weight:600; line-height:1; color:transparent; -webkit-text-stroke:2px rgba(76,55,196,0.6); margin-bottom:20px; }
.error-page h1 { font-family:var(--f-heading); font-size:2.5rem; font-weight:600; color:var(--c-white); margin-bottom:16px; }
.error-page p { font-size:1.125rem; color:var(--c-white-70); max-width:500px; margin:0 auto 40px; line-height:1.7; }
.error-page__actions { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; margin-bottom:48px; }
.error-page__links { text-align:center; }
.error-page__links > p { font-size:0.875rem; color:var(--c-white-30); margin-bottom:20px; }
.error-page__link-grid { display:flex; align-items:center; justify-content:center; gap:12px; flex-wrap:wrap; }
.error-page__link-grid a { padding:8px 20px; border:1px solid rgba(255,255,255,0.15); border-radius:99px; font-size:0.875rem; font-weight:500; color:var(--c-white-70); transition:var(--t); }
.error-page__link-grid a:hover { background:rgba(76,55,196,0.25); border-color:var(--c-accent); color:var(--c-white); }

/* ── Responsive bridges ── */
@media (max-width:1025px) {
  .hero-home__grid { grid-template-columns:1fr; gap:48px; }
  .hero-home__visual { display:none; }
  .hero-home__content { align-items:center; text-align:center; }
  .features-grid { grid-template-columns:repeat(2,1fr); }
  .steps-grid { grid-template-columns:repeat(2,1fr); }
  .services-grid, .services-grid--full { grid-template-columns:1fr 1fr; }
  .why-grid { grid-template-columns:repeat(2,1fr); }
  .testimonials-grid { grid-template-columns:1fr 1fr; }
  .pricing-grid { grid-template-columns:1fr; max-width:480px; margin-inline:auto; }
  .team-grid, .team-grid--leaders { grid-template-columns:repeat(2,1fr); }
  .contact-cards-grid { grid-template-columns:2fr 1fr; }
  .contact-form-layout { grid-template-columns:1fr; gap:40px; }
  .service-detail-grid { grid-template-columns:1fr; gap:48px; }
  .benefits-grid { grid-template-columns:repeat(2,1fr); }
  .values-grid { grid-template-columns:repeat(2,1fr); }
  .help-categories { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:50px; }
  .stats-strip__grid { gap:20px; }
}

@media (max-width:768px) {
  .site-nav { display:none; }
  .header-actions .btn--primary { display:none; }
  .hamburger { display:flex; }
  .hero-home { padding-top:160px; padding-bottom:80px; }
  .hero-home__content h1 { font-size:2.75rem; }
  .features-grid { grid-template-columns:1fr; }
  .steps-grid { grid-template-columns:1fr 1fr; }
  .services-grid, .services-grid--full { grid-template-columns:1fr; }
  .why-grid { grid-template-columns:1fr 1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .team-grid, .team-grid--leaders { grid-template-columns:1fr 1fr; }
  .contact-cards-grid { grid-template-columns:1fr; }
  .benefits-grid { grid-template-columns:1fr 1fr; }
  .values-grid { grid-template-columns:1fr 1fr; }
  .help-categories { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:36px; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .footer-legal { flex-direction:column; gap:12px; }
  .error-page__number { font-size:7rem; }
  .form-row { grid-template-columns:1fr; }
  .stats-strip__grid { grid-template-columns:1fr; gap:28px; text-align:center; }
}

@media (max-width:480px) {
  .hamburger { display:flex; }
  .hero-home__content h1 { font-size:2.25rem; }
  .hero-home__actions { flex-direction:column; width:100%; }
  .hero-home__actions .btn { width:100%; justify-content:center; }
  .steps-grid { grid-template-columns:1fr; }
  .why-grid { grid-template-columns:1fr; }
  .team-grid, .team-grid--leaders { grid-template-columns:1fr; }
  .benefits-grid { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr; }
  .error-page__number { font-size:5rem; }
  .error-page__actions { flex-direction:column; align-items:center; }
  .error-page__actions .btn { width:100%; justify-content:center; }
  .cta-banner__actions { flex-direction:column; }
  .cta-banner__actions .btn { width:100%; justify-content:center; }
  .about-stats { gap:24px; }
}

/* ══════════════════════════════════════════
   UTILITIES
   ══════════════════════════════════════════ */
.text-center { text-align: center; }
.text-white  { color: var(--c-white); }
.text-accent { color: var(--c-accent); }

.mt-8  { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mt-32 { margin-top: 32px; }
.mt-40 { margin-top: 40px; }
.mt-60 { margin-top: 60px; }

.mb-8  { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.mb-32 { margin-bottom: 32px; }
.mb-40 { margin-bottom: 40px; }
.mb-60 { margin-bottom: 60px; }

/* ══════════════════════════════════════════
   RESPONSIVE — Large (≤ 1024px)
   ══════════════════════════════════════════ */
@media (max-width: 1025px) {
  :root {
    --container-px: var(--container-px-md);
    --sp: var(--sp-md);
  }

  h1 { font-size: 3.5rem; }
  h2 { font-size: 2.75rem; }
  h3 { font-size: 2.25rem; }
  h4 { font-size: 2rem; }
  h5 { font-size: 1.25rem; }

  .hero { padding-top: 180px; }
  .hero__grid { grid-template-columns: 1fr; gap: 48px; }
  .hero__heading { font-size: 3.5rem; }
  .hero__content { align-items: center; text-align: center; }
  .hero__image { display: none; }

  .stats__grid { gap: 20px; }
  .how-works__steps::before { display: none; }

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

  .mobile-app__grid { grid-template-columns: 1fr; gap: 48px; text-align: center; }
  .mobile-app__badges { justify-content: center; }
  .mobile-app__image { display: none; }

  .about-preview__grid { grid-template-columns: 1fr; gap: 48px; }

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

  .services__grid { grid-template-columns: 1fr 1fr; }

  .why-choose__grid { grid-template-columns: 1fr; gap: 48px; }
  .why-choose__image { display: none; }

  .testimonials__grid { grid-template-columns: 1fr 1fr; }

  .pricing__grid { grid-template-columns: 1fr; gap: 20px; max-width: 480px; margin-inline: auto; }

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

  .contact-info__grid { grid-template-columns: 1fr; }

  .footer__grid { grid-template-columns: 1fr 1fr; gap: 50px; }

  .values__grid { grid-template-columns: 1fr 1fr; }

  .service-detail__grid { grid-template-columns: 1fr; gap: 48px; }

  .form-grid { grid-template-columns: 1fr 1fr; }

  .contact-form-wrap { padding: 40px; }
}

/* ══════════════════════════════════════════
   RESPONSIVE — Tablet (≤ 768px)
   ══════════════════════════════════════════ */
@media (max-width: 768px) {
  :root {
    --container-px: var(--container-px-sm);
    --sp: var(--sp-sm);
  }

  h1 { font-size: 2.5rem; }
  h2 { font-size: 2rem; }
  h3 { font-size: 1.75rem; }
  h4 { font-size: 1.5rem; }
  h5 { font-size: 1.125rem; }
  h6 { font-size: 1rem; }

  p { font-size: 1rem; }

  .display-text { font-size: 8rem; }

  .nav { display: none; }
  .header__cta { display: none; }
  .hamburger { display: flex; }

  .hero { padding-top: 160px; padding-bottom: 80px; }
  .hero__heading { font-size: 2.75rem; }
  .hero__actions { justify-content: center; }

  .stats__grid { grid-template-columns: 1fr; gap: 30px; text-align: center; }
  .stats__divider { display: none; }
  .stat-item__num { font-size: 3rem; }

  .how-works__steps { grid-template-columns: 1fr; gap: 32px; }

  .features__grid { grid-template-columns: 1fr; gap: 20px; }
  .section-head { margin-bottom: 36px; }

  .feature-strip__grid { grid-template-columns: 1fr; gap: 20px; }

  .services__grid { grid-template-columns: 1fr; }

  .testimonials__grid { grid-template-columns: 1fr; gap: 20px; }

  .pricing__grid { max-width: 100%; }

  .team__grid { grid-template-columns: 1fr 1fr; }

  .footer__grid { grid-template-columns: 1fr; gap: 36px; }
  .site-footer { padding-top: 60px; }

  .values__grid { grid-template-columns: 1fr; }

  .contact-info__grid { grid-template-columns: 1fr; }

  .form-grid { grid-template-columns: 1fr; }
  .contact-form-wrap { padding: 28px 20px; }

  .map-wrap iframe { height: 300px; }

  .page-hero h1 { font-size: 2.5rem; }

  .error-page__num { font-size: 7rem; }
  .error-page__title { font-size: 2rem; }

  .cta-banner h2 { font-size: 2rem; }

  .partners__grid { gap: 28px; }

  .vision-block { padding: 40px 28px; }
  .vision-block__quote { font-size: 1.25rem; }

  .timeline::before { left: 20px; }
  .timeline-item { grid-template-columns: 40px 1fr; gap: 20px; }
  .timeline-item__dot { width: 40px; height: 40px; font-size: 0.75rem; }

  .footer__bottom { flex-direction: column; text-align: center; }
}

/* ══════════════════════════════════════════
   RESPONSIVE — Mobile (≤ 480px)
   ══════════════════════════════════════════ */
@media (max-width: 480px) {
  h1 { font-size: 2rem; }
  h2 { font-size: 1.75rem; }
  h3 { font-size: 1.5rem; }

  .hero { padding-top: 140px; }
  .hero__heading { font-size: 2.25rem; }
  .hero__actions { flex-direction: column; width: 100%; }
  .hero__actions .btn { width: 100%; justify-content: center; }

  .team__grid { grid-template-columns: 1fr; }

  .error-page__num { font-size: 5rem; }

  .header__inner { padding: 16px var(--container-px-sm); }

  .cta-banner__actions { flex-direction: column; }
  .cta-banner__actions .btn { width: 100%; justify-content: center; }

  .footer__legal { flex-direction: column; gap: 12px; }
}

/* ── Mega Menu ── */
.nav-dropdown { position:relative; }
.nav-dropdown__menu { display:none; position:absolute; top:calc(100% + 12px); left:50%; transform:translateX(-50%); background:#1a1630; border:1px solid rgba(255,255,255,0.08); border-radius:14px; overflow:hidden; z-index:999; min-width:540px; box-shadow:0 20px 60px rgba(0,0,0,0.4); }
.nav-dropdown:hover .nav-dropdown__menu { display:grid; grid-template-columns:1fr 1fr; }
.nav-mega__col { padding:1.25rem 1rem; }
.nav-mega__col:first-child { border-right:1px solid rgba(255,255,255,0.08); }
.nav-mega__label { font-size:0.7rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.35); margin:0 0 0.75rem 0.5rem; padding:0; }
.nav-mega__item { display:flex; align-items:center; gap:0.75rem; padding:0.625rem 0.5rem; border-radius:8px; color:rgba(255,255,255,0.75); transition:background 0.2s,color 0.2s; text-decoration:none; }
.nav-mega__item:hover { background:rgba(76,55,196,0.25); color:#fff; }
.nav-mega__icon { width:34px; height:34px; border-radius:8px; background:rgba(76,55,196,0.22); display:flex; align-items:center; justify-content:center; color:var(--c-secondary); flex-shrink:0; }
.nav-mega__icon svg { width:17px; height:17px; }
.nav-mega__body { display:flex; flex-direction:column; gap:2px; }
.nav-mega__body strong { font-size:0.875rem; font-weight:600; color:#fff; line-height:1.2; font-family:var(--f-heading); }
.nav-mega__body span { font-size:0.75rem; color:rgba(255,255,255,0.40); line-height:1.3; }
.nav-mega .dropdown-divider { height:1px; background:rgba(255,255,255,0.06); margin:0.15rem 0.5rem; }
.nav-dropdown__chevron { width:14px; height:14px; display:inline-block; vertical-align:middle; margin-left:4px; transition:transform 0.2s; }
.nav-dropdown:hover .nav-dropdown__chevron { transform:rotate(180deg); }


