/* =============================================
   OpsMonsters - Pixel-perfect clone of nikolaradeski.com
   ============================================= */

/* --- @font-face: exact fonts from reference site --- */
@font-face {
  font-family: "General Sans";
  src: url("../fonts/GeneralSans-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "General Sans";
  src: url("../fonts/GeneralSans-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "General Sans";
  src: url("../fonts/GeneralSans-Semibold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "General Sans";
  src: url("../fonts/GeneralSans-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Clash Display";
  src: url("../fonts/ClashDisplay-Medium-2.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Clash Display";
  src: url("../fonts/ClashDisplay-Semibold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Clash Display";
  src: url("../fonts/ClashDisplay-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gloria Hallelujah";
  src: url("../fonts/GloriaHallelujah-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg: #eaeaea;
  --dark: #141617;
  --text: #333;
  --gray: #6d6d6d;
  --muted: #8e8e8e;
  --border: #dbdbdb;
  --accent: #e27500;
  --green: #00512f;
  --blue: #2d60ce;
  --white: #fff;

  /* Font stacks - exact match to reference */
  --font: "General Sans", Arial, Helvetica, sans-serif;
  --font-medium: "General Sans", Arial, Helvetica, sans-serif;
  --font-display: "Clash Display", "General Sans", sans-serif;
  --font-hand: "Gloria Hallelujah", Arial, Helvetica, sans-serif;

  --site-w: 1100px;
  --px: 40px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; overflow-x: hidden; }
body {
  font-family: var(--font);
  font-weight: 400;
  color: var(--text);
  background: var(--bg);
  line-height: 1.4;
  letter-spacing: -0.5px;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; height: auto; display: block; }
button { border: none; background: none; cursor: pointer; font-family: inherit; }
input, textarea { font-family: inherit; }
ul { list-style: none; }

/* =============================================
   FLOATING BOTTOM NAV (reference has pill nav at bottom)
   ============================================= */
.bottom-nav {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1000;
  background: var(--dark);
  border-radius: 50px;
  padding: 10px 8px;
  display: flex;
  align-items: center;
  gap: 4px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
}
.bottom-nav a {
  padding: 10px 20px;
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,0.7);
  border-radius: 40px;
  transition: all 0.3s;
  white-space: nowrap;
}
.bottom-nav a:hover, .bottom-nav a.active {
  color: #fff;
}

/* Service nav auto-rotation active state */
.bottom-nav .nav-service.auto-active,
.bottom-nav .nav-service.page-active {
  color: #fff;
  background: rgba(255,255,255,0.08);
  border-radius: 40px;
}

.bottom-nav .nav-home {
  width: 40px;
  height: 40px;
  background: var(--dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.bottom-nav .nav-home svg { width: 18px; height: 18px; fill: #fff; }
.bottom-nav .nav-cta {
  background: var(--accent);
  color: #fff !important;
  font-weight: 600;
  padding: 10px 22px;
}
.bottom-nav .nav-cta:hover { background: #c96800; }

/* Mobile menu toggle button - hidden on desktop */
.nav-menu-btn {
  display: none;
  padding: 10px 18px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,0.7);
  border-radius: 40px;
  background: none;
  border: none;
  cursor: pointer;
  transition: color 0.3s;
  white-space: nowrap;
  letter-spacing: -0.2px;
}
.nav-menu-btn:hover { color: #fff; }
.nav-menu-btn.is-open { color: #fff; }

/* Mobile slide-up panel - hidden by default */
.nav-mobile-panel {
  display: none;
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  background: var(--dark);
  border-radius: 20px;
  padding: 8px;
  min-width: 200px;
  flex-direction: column;
  box-shadow: 0 -4px 40px rgba(0,0,0,0.35), 0 0 0 1px rgba(255,255,255,0.05);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease, visibility 0.22s ease, transform 0.22s cubic-bezier(0.16,1,0.3,1);
}
.nav-mobile-panel.open {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.nav-mobile-panel a {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 500;
  color: rgba(255,255,255,0.65);
  padding: 12px 20px;
  border-radius: 12px;
  display: block;
  white-space: nowrap;
  transition: background 0.18s, color 0.18s;
  letter-spacing: -0.2px;
}
.nav-mobile-panel a:hover { background: rgba(255,255,255,0.07); color: #fff; }

/* side-badge removed */

/* =============================================
   SCROLL TO TOP
   ============================================= */
.scroll-top {
  position: fixed;
  bottom: 32px;
  right: 28px;
  z-index: 900;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--dark);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
  opacity: 0;
  transition: opacity 0.3s;
  cursor: pointer;
}
.scroll-top.visible { opacity: 1; }

/* =============================================
   SECTION HELPERS
   ============================================= */
.container { max-width: var(--site-w); margin: 0 auto; padding: 0 var(--px); }
.section { padding: 100px 0; }
/* Section tag - Gloria Hallelujah (h5 in reference: 18px) */
.section-tag {
  font-family: var(--font-hand);
  font-size: 16px;
  font-weight: 400;
  color: var(--muted);
  margin-bottom: 12px;
  display: block;
  letter-spacing: 0;
}
/* Section title - General Sans Semibold (h1/h2 in reference: 4rem, -3px spacing, line-height 1) */
.section-title {
  font-family: var(--font);
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--dark);
}
.section-title .accent { color: var(--accent); }

/* =============================================
   HERO SECTION
   ============================================= */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding: 60px 0 120px;
}
/* Hero background video - fills section, blends seamlessly into page bg */
.hero-video-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  /* Soft fade on all edges so video blends into #eaeaea background */
  -webkit-mask-image: radial-gradient(ellipse 85% 80% at 50% 45%, black 40%, transparent 100%);
  mask-image: radial-gradient(ellipse 85% 80% at 50% 45%, black 40%, transparent 100%);
}
.hero-video-bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.4;
}
.hero .container {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 100%;
  padding: 0 var(--px);
}
.hero-center {
  text-align: center;
  width: 100%;
}
.hero-name {
  font-family: var(--font);
  font-size: clamp(4rem, 12vw, 10rem);
  font-weight: 600;
  line-height: 1;
  color: var(--dark);
  letter-spacing: -0.03em;
  margin-bottom: 20px;
}
.hero-badge {
  font-size: 13px;
  color: var(--muted);
  letter-spacing: 0.02em;
  margin-bottom: 16px;
  display: block;
}
.hero-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 700px;
  margin: 0 auto;
}
.hero-sub {
  font-size: 14px;
  color: var(--gray);
  letter-spacing: -0.3px;
}
.hero-meta {
  font-size: 13px;
  color: var(--muted);
}

/* (hero card removed) */

/* =============================================
   SERVICES SECTION
   Sticky stacking cards left, phone mockup sticky right
   ============================================= */
.services { padding-bottom: 60px; }
.services-header.released,
.services-header--static { position: relative; top: auto; z-index: auto; }
.services-header {
  margin-bottom: 40px;
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--bg);
  padding-bottom: 8px;
}
.services-header .section-desc {
  font-size: 14px;
  color: var(--gray);
  max-width: 500px;
  line-height: 1.7;
  margin-top: 12px;
}
.services-layout {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  position: relative;
  z-index: 1;
}
.services-cards {
  flex: 1;
  max-width: 580px;
}
.service-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 32px 36px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.07);
  position: sticky;
  top: 180px;
  margin-bottom: 30px;
  transition: box-shadow 0.3s, transform 0.3s;
  will-change: transform;
}
/* Latest card on TOP - ascending z-index */
.service-card:nth-child(1) { z-index: 1; }
.service-card:nth-child(2) { z-index: 2; }
.service-card:nth-child(3) { z-index: 3; }
.service-card:nth-child(4) { z-index: 4; }
.service-card:nth-child(5) { z-index: 5; }
.service-card:nth-child(6) { z-index: 6; }
.service-card:nth-child(7) { z-index: 7; }
.service-card:nth-child(8) { z-index: 8; }
.service-card:nth-child(9) { z-index: 9; }
.service-card:hover { box-shadow: 0 12px 40px rgba(0,0,0,0.12); }
.service-learn-more {
  display: inline-block;
  margin-top: 20px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  text-decoration: none;
  letter-spacing: 0.2px;
  transition: opacity 0.2s;
}
.service-learn-more:hover { opacity: 0.7; }
.service-badge {
  font-family: var(--font-hand);
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 10px;
  display: block;
}
/* Service title - General Sans Semibold (h3 in reference: 36px, -2.5px) */
.service-title {
  font-family: var(--font);
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
  font-weight: 600;
  color: var(--dark);
  margin-bottom: 14px;
  letter-spacing: -1.5px;
  line-height: 1.1;
}
.service-desc {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 400;
  color: var(--gray);
  line-height: 1.6;
  margin-bottom: 16px;
  letter-spacing: -0.3px;
}
.service-tools {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.service-tools li {
  font-size: 12px;
  color: var(--muted);
  padding-left: 14px;
  position: relative;
}
.service-tools li::before {
  content: '\2022';
  position: absolute;
  left: 0;
  color: var(--muted);
}

/* Phone mockup on right side */
.services-mockup {
  width: 320px;
  flex-shrink: 0;
  position: sticky;
  top: 180px;
}
.mockup-device {
  background: var(--dark);
  border-radius: 28px;
  padding: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.2);
  transform: rotate(3deg);
  overflow: hidden;
  /* Ensure child corners are clipped */
  isolation: isolate;
}
.mockup-screen {
  background: #0a0a0a;
  border-radius: 18px;
  aspect-ratio: 9/16;
  position: relative;
  overflow: hidden;
  /* Force GPU layer for proper corner clipping */
  -webkit-mask-image: -webkit-radial-gradient(white, black);
  mask-image: radial-gradient(white, black);
}
/* Scrolling portfolio thumbnails inside mockup */
.mockup-slideshow {
  display: flex;
  flex-direction: column;
  animation: mockup-scroll 25s linear infinite;
}
.mockup-slide {
  width: 100%;
  flex-shrink: 0;
  display: block;
}
@keyframes mockup-scroll {
  0% { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}
/* Dark blurred overlay on top of slideshow */
.mockup-dark-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  color: #fff;
  text-align: center;
}
.mockup-screen .mockup-name {
  font-family: var(--font);
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.5px;
}
.mockup-screen .mockup-role {
  font-size: 12px;
  opacity: 0.7;
}

/* =============================================
   ABOUT SECTION
   ============================================= */
.about { position: relative; padding-top: 80px; }
.about-top { display: flex; gap: 40px; align-items: flex-start; margin-bottom: 40px; }
.about-text { flex: 1; }
.about-text .about-headline {
  font-family: var(--font);
  font-size: 15px;
  font-weight: 500;
  color: var(--gray);
  margin-bottom: 16px;
  letter-spacing: -0.3px;
}
.about-text .about-desc {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 400;
  color: var(--gray);
  line-height: 1.7;
  margin-bottom: 12px;
  max-width: 520px;
  letter-spacing: -0.3px;
}
.about-text .about-impact {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 500;
  color: var(--dark);
  margin-bottom: 24px;
}

/* CTA Buttons row */
.about-ctas {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  border-radius: 10px;
  transition: all 0.3s;
  cursor: pointer;
  letter-spacing: -0.3px;
}
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { background: #c96800; }
.btn-outline { background: transparent; border: 1.5px solid var(--border); color: var(--dark); }
.btn-outline:hover { border-color: var(--dark); }

/* About right column */
.about-right-col {
  width: 360px;
  flex-shrink: 0;
}
.about-highlights {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.highlight-card {
  background: var(--white);
  border-radius: 16px;
  padding: 24px 20px;
  text-align: center;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: all 0.3s;
}
.highlight-card:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  transform: translateY(-2px);
}
.highlight-number {
  display: block;
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: -1px;
  line-height: 1;
  margin-bottom: 6px;
}
.highlight-label {
  display: block;
  font-family: var(--font);
  font-size: 12px;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: -0.2px;
}

/* Rating row */
.rating-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}
.rating-stars { display: flex; gap: 2px; }
.rating-stars .star { color: var(--accent); font-size: 16px; }
.rating-label { font-size: 13px; color: var(--muted); }

/* Social icons */
.social-row {
  display: flex;
  gap: 10px;
  margin-bottom: 24px;
}
.social-icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--gray);
  transition: all 0.3s;
}
.social-icon:hover { border-color: var(--dark); color: var(--dark); }

/* Marquee ticker */
.marquee-wrap {
  overflow: hidden;
  padding: 16px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin-bottom: 40px;
}
.marquee-track {
  display: flex;
  white-space: nowrap;
  animation: marquee 30s linear infinite;
  will-change: transform;
  transform: translateZ(0);
}
.marquee-text {
  font-size: 13px;
  color: var(--muted);
  flex-shrink: 0;
  padding-right: 20px;
}
@keyframes marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* About closing - General Sans Medium, large (reference: clamp 1.5-2rem) */
.about-closing {
  font-family: var(--font);
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 500;
  color: var(--dark);
  line-height: 1.35;
  letter-spacing: -1.5px;
  max-width: 800px;
}

/* =============================================
   TEAM SECTION
   ============================================= */
.team-title { margin-bottom: 8px; }
.team-desc {
  font-size: 14px;
  color: var(--gray);
  max-width: 480px;
  line-height: 1.7;
  margin-bottom: 52px;
}
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.team-card {
  border-radius: 20px;
  overflow: hidden;
  background: var(--white);
  box-shadow: 0 4px 24px rgba(0,0,0,0.07);
  transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94), box-shadow 0.45s;
  will-change: transform;
  cursor: default;
}
.team-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 64px rgba(0,0,0,0.13);
}
.team-card-photo {
  aspect-ratio: 3/4;
  position: relative;
  overflow: hidden;
  background: #ddd;
}
.team-card-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
  display: block;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.team-card:hover .team-card-photo img { transform: scale(1.07); }
.team-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(20,22,23,0.90) 0%, rgba(20,22,23,0.25) 45%, transparent 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 22px 18px;
  opacity: 0;
  transition: opacity 0.4s ease;
}
.team-card:hover .team-overlay { opacity: 1; }
.team-overlay-name {
  font-family: var(--font);
  font-size: 17px;
  font-weight: 600;
  color: #fff;
  letter-spacing: -0.4px;
  line-height: 1.2;
}
.team-overlay-role {
  font-size: 12px;
  color: var(--accent);
  font-weight: 500;
  margin-top: 5px;
  letter-spacing: 0.01em;
}
.team-card-info {
  padding: 16px 18px 20px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 3px;
  position: relative;
}
.team-card-info::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--accent);
  transition: width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  border-radius: 0 0 20px 20px;
}
.team-card:hover .team-card-info::before { width: 100%; }
.team-name {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 600;
  color: var(--dark);
  letter-spacing: -0.3px;
}
.team-role {
  font-size: 12px;
  color: var(--accent);
  font-weight: 500;
}

/* =============================================
   PORTFOLIO SECTION
   ============================================= */
.portfolio-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.portfolio-card {
  display: block;
  border-radius: 20px;
  overflow: hidden;
  background: var(--white);
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: all 0.4s;
}
.portfolio-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.1);
}
.portfolio-card-image {
  aspect-ratio: 16/10;
  position: relative;
  overflow: hidden;
  background: #ddd;
}
.portfolio-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
  display: block;
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.portfolio-card:hover .portfolio-card-image img {
  transform: scale(1.05);
}
/* Dark overlay on hover with title + CTA */
.portfolio-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  opacity: 0;
  transition: opacity 0.35s ease;
}
.portfolio-card:hover .portfolio-overlay { opacity: 1; }
.portfolio-overlay-title {
  font-family: var(--font);
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  letter-spacing: -0.5px;
}
.portfolio-overlay-cta {
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,0.7);
}


/* Branding portfolio - 3-col grid for logo/identity thumbnails */
.br-behance-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) {
  .br-behance-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .br-behance-grid { grid-template-columns: 1fr; }
}

/* =============================================
   REVIEWS SECTION
   ============================================= */
.reviews-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.review-card {
  background: var(--white);
  border-radius: 20px;
  padding: 32px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: all 0.3s;
}
.review-card:hover { box-shadow: 0 8px 30px rgba(0,0,0,0.08); }
.review-text {
  font-size: 14px;
  color: var(--gray);
  line-height: 1.8;
  margin-bottom: 20px;
}
.review-author { display: flex; justify-content: space-between; align-items: center; }
.review-byline { font-size: 13px; font-weight: 600; color: var(--dark); }
.review-type { font-size: 12px; color: var(--muted); }
.review-name {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 600;
  color: var(--dark);
  letter-spacing: -0.3px;
}
.review-role { font-size: 12px; color: var(--muted); margin-top: 2px; }
.review-date { font-size: 12px; color: var(--muted); }

/* =============================================
   CONTACT SECTION
   ============================================= */
.contact-section { background: var(--bg); }
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}
.contact-desc {
  font-size: 14px;
  color: var(--gray);
  line-height: 1.7;
  margin-top: 16px;
  margin-bottom: 24px;
}
.contact-email {
  font-size: 16px;
  color: var(--accent);
  font-weight: 600;
  display: block;
  margin-bottom: 20px;
  cursor: pointer;
  text-decoration: none;
  transition: text-decoration 0.1s;
}
.contact-email:hover { text-decoration: underline; }
.contact-form { display: flex; flex-direction: column; gap: 14px; }
.contact-form input,
.contact-form textarea,
.contact-form select {
  width: 100%;
  padding: 14px 16px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  font-size: 14px;
  color: var(--dark);
  outline: none;
  transition: border-color 0.3s;
}
.contact-form select {
  appearance: none;
  -webkit-appearance: none;
  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='%23999' 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 14px center;
  padding-right: 42px;
  cursor: pointer;
}
.contact-form select:invalid,
.contact-form select option[value=""] { color: var(--muted); }
.contact-form select option:not([value=""]) { color: var(--dark); }
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus { border-color: var(--accent); }
.contact-form textarea { resize: vertical; min-height: 120px; }
.contact-form .btn-submit {
  background: var(--accent);
  color: #fff;
  padding: 14px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: background 0.3s;
}
.contact-form .btn-submit:hover { background: #c96800; }

/* =============================================
   FOOTER
   ============================================= */
.site-footer {
  border-top: 1px solid var(--border);
  padding: 60px 0 30px;
  background: var(--bg);
}
.footer-top {
  display: flex;
  justify-content: space-between;
  gap: 40px;
  margin-bottom: 40px;
}
.footer-brand { flex: 1; }
.footer-logo {
  font-family: var(--font);
  font-size: 20px;
  font-weight: 600;
  color: var(--dark);
  display: block;
  margin-bottom: 6px;
  letter-spacing: -0.5px;
}
.footer-tagline { font-size: 14px; color: var(--muted); margin-bottom: 10px; }
.footer-brand-desc {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.7;
  max-width: 260px;
  margin-top: 10px;
}
.footer-cols { display: flex; gap: 48px; }
.footer-col-sub {
  font-size: 13px;
  color: rgba(107,114,128,0.55);
  padding-left: 10px;
  position: relative;
}
.footer-col { display: flex; flex-direction: column; gap: 8px; }
.footer-col h4 {
  font-family: var(--font);
  font-size: 14px;
  font-weight: 600;
  color: var(--dark);
  margin-bottom: 6px;
  letter-spacing: -0.3px;
}
.footer-col a { font-size: 14px; color: var(--muted); transition: color 0.3s; }
.footer-col a:hover { color: var(--accent); }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  font-size: 13px;
  color: var(--muted);
}
.footer-bottom a { color: var(--muted); transition: color 0.3s; }
.footer-bottom a:hover { color: var(--dark); }

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 1000px) {
  .hero-bottom { flex-direction: column; gap: 8px; text-align: center; }
  .services-layout { flex-direction: column; }
  .services-mockup { display: none; }
  /* Release services header sticky on tablet/mobile - avoid overlap issues */
  .services-header { position: relative; top: auto; }
  /* Disable sticky card stacking on mobile - cards just flow normally */
  .service-card { position: relative; top: 0; margin-bottom: 16px; }
  .about-top { flex-direction: column; }
  .about-right-col { width: 100%; max-width: 100%; }
  .contact-layout { grid-template-columns: 1fr; gap: 40px; }
  .team-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .bottom-nav { bottom: 16px; padding: 8px 6px; }
  .bottom-nav a { padding: 8px 10px; font-size: 11px; }
  .bottom-nav .nav-cta { padding: 8px 14px; }
  /* Collapse links into menu button on tablet/mobile */
  .bottom-nav .nav-link { display: none; }
  .nav-menu-btn { display: inline-flex; align-items: center; padding: 8px 16px; }
  .nav-mobile-panel { display: flex; }
}
@media (max-width: 640px) {
  :root { --px: 16px; }
  .section { padding: 60px 0; }
  .section-tag { font-size: clamp(12px, 3vw, 15px); }
  /* Hero name: clamp min was 4rem (64px) - too large for sub-640px viewports */
  .hero-name { font-size: clamp(2.5rem, 10vw, 4rem); letter-spacing: -0.02em; }
  .hero { padding: 40px 0 80px; }
  /* section-title letter-spacing is now em-based and auto-scales — no override needed */
  .portfolio-grid { grid-template-columns: 1fr; gap: 14px; }
  .team-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .portfolio-card-image { aspect-ratio: 4/3; }
  .about-highlights { grid-template-columns: 1fr 1fr; }
  .reviews-grid { grid-template-columns: 1fr; }
  .review-card { padding: 20px; }
  .footer-top { flex-direction: column; gap: 24px; }
  .footer-cols { flex-direction: column; gap: 20px; }
  .footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
  .contact-form input,
  .contact-form textarea { min-width: 0; }
  .hero-bottom { max-width: 100%; }
  /* Bottom nav: compact pill on small screens */
  .bottom-nav { max-width: calc(100vw - 32px); }
}
@media (max-width: 380px) {
  /* Very small screens: stat cards drop to single column */
  .about-highlights { grid-template-columns: 1fr; }
  /* Nav items: reduce further to prevent overflow */
  .bottom-nav a { padding: 6px 7px; font-size: 10px; }
  .bottom-nav .nav-cta { padding: 6px 10px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .marquee-track { animation: none; }
}

/* Toast notification - positioned near triggering element */
.toast {
  position: fixed;
  background: var(--dark);
  color: #fff;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  padding: 10px 20px;
  border-radius: 10px;
  box-shadow: 0 6px 24px rgba(0,0,0,0.2);
  opacity: 0;
  transition: opacity 0.3s, transform 0.3s;
  z-index: 9999;
  pointer-events: none;
  white-space: nowrap;
}
.toast-show {
  opacity: 1;
  transform: translateY(0) !important;
}
.toast-error {
  background: #d32f2f;
}

/* Form inline errors */
.form-error {
  display: block;
  font-family: var(--font);
  font-size: 12px;
  color: #d32f2f;
  margin-top: 4px;
  letter-spacing: -0.2px;
}

/* =============================================
   Glass Modal (success, error, privacy, terms)
   ============================================= */
.glass-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}
.glass-modal-open {
  opacity: 1;
  visibility: visible;
}
.glass-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 22, 23, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.glass-modal-card {
  position: relative;
  background: #fff;
  border-radius: 28px;
  padding: 48px 44px 40px;
  max-width: 440px;
  width: 90%;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 0 32px 100px rgba(0,0,0,0.18), 0 0 0 1px rgba(0,0,0,0.04);
  transform: translateY(24px) scale(0.96);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
  text-align: center;
}
/* For legal content - wider */
.glass-modal-card.modal-wide {
  max-width: 600px;
  text-align: left;
}
.glass-modal-open .glass-modal-card {
  transform: translateY(0) scale(1);
}
.glass-modal-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-size: 28px;
  line-height: 1;
}
.glass-modal-icon.icon-success {
  background: rgba(45, 138, 26, 0.1);
  color: #2d8a1a;
}
.glass-modal-icon.icon-error {
  background: rgba(211, 47, 47, 0.1);
  color: #d32f2f;
}
.glass-modal-icon.icon-info {
  background: rgba(226, 117, 0, 0.1);
  color: var(--accent);
}
.glass-modal-title {
  font-family: var(--font);
  font-size: 20px;
  font-weight: 600;
  color: var(--dark);
  letter-spacing: -0.5px;
  margin-bottom: 8px;
}
.glass-modal-subtitle {
  font-family: var(--font);
  font-size: 14px;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 4px;
}
.glass-modal-body {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.7;
  letter-spacing: -0.2px;
}
.glass-modal-body h4 {
  font-size: 15px;
  font-weight: 600;
  color: var(--dark);
  margin: 20px 0 6px;
  letter-spacing: -0.3px;
}
.glass-modal-body ul {
  padding-left: 18px;
  margin: 6px 0;
}
.glass-modal-body li {
  margin-bottom: 4px;
  list-style: disc;
}
.glass-modal-body p {
  margin-bottom: 8px;
}
.glass-modal-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 28px;
}
.glass-modal-close {
  padding: 12px 36px;
  font-family: var(--font);
  font-size: 14px;
  font-weight: 500;
  color: #fff;
  background: var(--accent);
  border: none;
  border-radius: 14px;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
  letter-spacing: -0.2px;
}
.glass-modal-close:hover {
  background: #c96800;
  transform: translateY(-1px);
}
.glass-modal-card::-webkit-scrollbar { width: 4px; }
.glass-modal-card::-webkit-scrollbar-track { background: transparent; }
.glass-modal-card::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.1); border-radius: 4px; }

/* =============================================
   COOKIE CONSENT BANNER
   ============================================= */
.cookie-banner {
  position: fixed;
  bottom: 96px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  z-index: 998;
  width: calc(100% - 32px);
  max-width: 740px;
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  padding: 22px 24px;
  box-shadow: 0 12px 48px rgba(0,0,0,0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.38s ease, transform 0.38s cubic-bezier(0.16,1,0.3,1);
}
.cookie-banner.cookie-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: all;
}
.cookie-banner-inner {
  display: flex;
  align-items: center;
  gap: 24px;
}
.cookie-banner-text {
  flex: 1;
  min-width: 0;
}
.cookie-banner-text strong {
  display: block;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 4px;
  letter-spacing: -0.2px;
}
.cookie-banner-text p {
  color: rgba(255,255,255,0.6);
  font-size: 12.5px;
  line-height: 1.6;
  margin: 0;
}
.cookie-banner-text a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.cookie-banner-text a:hover { color: #e08020; }
.cookie-banner-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.cookie-btn {
  padding: 9px 18px;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.2s, color 0.2s, transform 0.2s;
  letter-spacing: -0.1px;
}
.cookie-btn:hover { transform: translateY(-1px); }
.cookie-btn-reject {
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.75);
}
.cookie-btn-reject:hover { background: rgba(255,255,255,0.14); color: #fff; }
.cookie-btn-manage {
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.75);
}
.cookie-btn-manage:hover { background: rgba(255,255,255,0.14); color: #fff; }
.cookie-btn-accept {
  background: var(--accent);
  color: #fff;
}
.cookie-btn-accept:hover { background: #c96800; }

/* Manage preferences modal overlay */
.cookie-pref-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 1100;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.25s;
  pointer-events: none;
}
.cookie-pref-overlay.cookie-pref-open {
  opacity: 1;
  pointer-events: all;
}
.cookie-pref-card {
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  padding: 32px;
  width: calc(100% - 32px);
  max-width: 480px;
  box-shadow: 0 20px 64px rgba(0,0,0,0.5);
  transform: translateY(16px);
  transition: transform 0.28s cubic-bezier(0.16,1,0.3,1);
}
.cookie-pref-overlay.cookie-pref-open .cookie-pref-card {
  transform: translateY(0);
}
.cookie-pref-card h3 {
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 6px;
  letter-spacing: -0.4px;
}
.cookie-pref-card > p {
  color: rgba(255,255,255,0.55);
  font-size: 13px;
  line-height: 1.6;
  margin-bottom: 24px;
}
.cookie-pref-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 0;
  border-top: 1px solid rgba(255,255,255,0.07);
}
.cookie-pref-info strong {
  display: block;
  color: #fff;
  font-size: 13.5px;
  font-weight: 600;
  margin-bottom: 2px;
}
.cookie-pref-info span {
  color: rgba(255,255,255,0.5);
  font-size: 12px;
  line-height: 1.5;
}
/* Toggle switch */
.cookie-toggle {
  position: relative;
  flex-shrink: 0;
  width: 44px;
  height: 24px;
}
.cookie-toggle input { opacity: 0; width: 0; height: 0; }
.cookie-toggle-slider {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.12);
  border-radius: 24px;
  cursor: pointer;
  transition: background 0.25s;
}
.cookie-toggle-slider::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  top: 3px;
  background: rgba(255,255,255,0.6);
  border-radius: 50%;
  transition: transform 0.25s, background 0.25s;
}
.cookie-toggle input:checked + .cookie-toggle-slider { background: var(--accent); }
.cookie-toggle input:checked + .cookie-toggle-slider::before {
  transform: translateX(20px);
  background: #fff;
}
.cookie-toggle input:disabled + .cookie-toggle-slider { opacity: 0.5; cursor: not-allowed; }
.cookie-pref-actions {
  display: flex;
  gap: 10px;
  margin-top: 24px;
  justify-content: flex-end;
}

@media (max-width: 600px) {
  .cookie-banner-inner { flex-direction: column; align-items: flex-start; gap: 16px; }
  .cookie-banner-actions { width: 100%; justify-content: flex-end; }
  .cookie-btn { padding: 8px 14px; font-size: 12px; }
}

/* =============================================
   Hero - CTA row (AI page + others)
   ============================================= */
.hero-cta-row {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 40px;
  opacity: 0;
}
.btn-cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--accent);
  color: var(--white);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 600;
  padding: 14px 30px;
  border-radius: 40px;
  letter-spacing: -0.2px;
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
  will-change: transform;
}
.btn-cta-primary:hover {
  background: #c96800;
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(226,117,0,0.4);
}
.btn-cta-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(0,0,0,0.06);
  color: var(--dark);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 500;
  padding: 14px 30px;
  border-radius: 40px;
  border: 1px solid rgba(0,0,0,0.12);
  letter-spacing: -0.2px;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.btn-cta-ghost:hover {
  background: rgba(0,0,0,0.1);
  color: var(--dark);
  border-color: rgba(0,0,0,0.2);
}

/* =============================================
   AI Page - Services
   ============================================= */
.ai-services { padding: 100px 0; background: var(--bg); }
.ai-section-header { margin-bottom: 56px; }

.ai-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.ai-service-card {
  background: var(--white);
  border-radius: 20px;
  padding: 36px 30px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
  border: 1px solid transparent;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.35s, border-color 0.35s;
  will-change: transform;
}
.ai-service-card:hover {
  box-shadow: 0 16px 56px rgba(0,0,0,0.11);
  border-color: rgba(226,117,0,0.25);
}
.ai-service-card--featured {
  border-color: rgba(226,117,0,0.25);
  background: #fffcf8;
}

.ai-service-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
}
.ai-service-number {
  font-family: var(--font);
  font-size: 12px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.5px;
}
.ai-service-badge {
  font-family: var(--font);
  font-size: 11px;
  font-weight: 500;
  color: var(--muted);
  background: #f2f2f2;
  border: 1px solid var(--border);
  padding: 3px 10px;
  border-radius: 20px;
  letter-spacing: 0;
}

.ai-service-title {
  font-family: var(--font);
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 600;
  color: var(--dark);
  letter-spacing: -1.2px;
  line-height: 1.1;
  margin-bottom: 14px;
}
.ai-service-desc {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.7;
  margin-bottom: 24px;
  flex: 1;
}

.ai-service-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 28px;
}
.ai-service-tools li {
  font-family: var(--font);
  font-size: 11px;
  font-weight: 500;
  color: var(--gray);
  background: #f2f2f2;
  border: 1px solid var(--border);
  padding: 4px 10px;
  border-radius: 20px;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
  cursor: default;
}
.ai-service-tools li:hover {
  background: rgba(226,117,0,0.08);
  color: var(--accent);
  border-color: rgba(226,117,0,0.2);
}

.ai-service-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--border);
  padding-top: 20px;
  margin-top: auto;
}
.ai-service-price {
  font-family: var(--font);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
}
.ai-service-arrow {
  font-size: 18px;
  color: var(--border);
  transition: color 0.2s, transform 0.2s;
  display: inline-block;
}
.ai-service-card:hover .ai-service-arrow {
  color: var(--accent);
  transform: translateX(5px);
}

/* =============================================
   AI Page - Process
   ============================================= */
.ai-process { padding: 100px 0; background: var(--white); }

.ai-process-steps {
  display: flex;
  flex-direction: column;
  max-width: 680px;
}

.ai-process-step {
  display: flex;
  gap: 28px;
  align-items: flex-start;
}

.ai-step-node {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
}

.ai-step-dot {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: var(--bg);
  border: 2px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 700;
  color: var(--dark);
  flex-shrink: 0;
  transition: background 0.3s, border-color 0.3s, color 0.3s, transform 0.3s;
}
.ai-process-step:hover .ai-step-dot {
  background: var(--dark);
  border-color: var(--dark);
  color: var(--white);
  transform: scale(1.1);
}

.ai-step-line {
  width: 2px;
  flex: 1;
  min-height: 36px;
  background: var(--border);
  margin: 4px 0;
}

.ai-step-body {
  padding-bottom: 44px;
  flex: 1;
}
.ai-process-step:last-child .ai-step-body { padding-bottom: 0; }

.ai-step-tag {
  font-family: var(--font-hand);
  font-size: 13px;
  color: var(--accent);
  display: block;
  margin-top: 10px;
  margin-bottom: 5px;
}
.ai-step-title {
  font-family: var(--font);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--dark);
  letter-spacing: -0.4px;
  margin-bottom: 7px;
}
.ai-step-desc {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.7;
  max-width: 480px;
}

/* =============================================
   AI Page - Use Cases
   ============================================= */
.ai-usecases { padding: 100px 0; background: var(--bg); }

.ai-filter-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.ai-filter-btn {
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--gray);
  background: var(--white);
  border: 1px solid var(--border);
  padding: 8px 20px;
  border-radius: 40px;
  cursor: pointer;
  letter-spacing: -0.2px;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.ai-filter-btn:hover { color: var(--dark); border-color: #aaa; }
.ai-filter-btn.active {
  background: var(--dark);
  color: var(--white);
  border-color: var(--dark);
}

.ai-usecases-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.ai-usecase-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 28px;
  transition: box-shadow 0.25s, border-color 0.25s;
  will-change: transform, opacity;
}
.ai-usecase-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.08);
  border-color: #ccc;
}

.ai-usecase-cat {
  font-family: var(--font);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 20px;
  margin-bottom: 14px;
  display: inline-block;
}
.cat-automation { background: rgba(226,117,0,0.1);  color: var(--accent); }
.cat-agents     { background: rgba(45,96,206,0.1);  color: var(--blue);   }
.cat-aiops      { background: rgba(0,81,47,0.1);    color: var(--green);  }

.ai-usecase-title {
  font-family: var(--font);
  font-size: 1rem;
  font-weight: 600;
  color: var(--dark);
  letter-spacing: -0.4px;
  margin-bottom: 10px;
  line-height: 1.3;
}
.ai-usecase-outcome {
  font-family: var(--font);
  font-size: 13px;
  color: var(--gray);
  line-height: 1.7;
}

/* =============================================
   AI Page - CTA Strip
   ============================================= */
.ai-cta-strip { background: var(--dark); padding: 100px 0; text-align: center; }

.cta-eyebrow {
  font-family: var(--font-hand);
  font-size: 15px;
  color: var(--accent);
  margin-bottom: 20px;
  display: block;
}
.cta-title {
  font-family: var(--font);
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 600;
  color: var(--white);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin-bottom: 18px;
}
.cta-sub {
  font-family: var(--font);
  font-size: 15px;
  color: rgba(255,255,255,0.6);
  max-width: 420px;
  margin: 0 auto 44px;
  line-height: 1.7;
}
.cta-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.btn-cta-outline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  color: rgba(255,255,255,0.7);
  font-family: var(--font);
  font-size: 14px;
  font-weight: 500;
  padding: 14px 30px;
  border-radius: 40px;
  border: 1px solid rgba(255,255,255,0.2);
  letter-spacing: -0.2px;
  transition: border-color 0.2s, color 0.2s;
}
.btn-cta-outline:hover { border-color: rgba(255,255,255,0.5); color: var(--white); }

/* =============================================
   AI Page - Responsive
   ============================================= */
@media (max-width: 900px) {
  .ai-services-grid  { grid-template-columns: 1fr; }
  .ai-usecases-grid  { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .ai-usecases-grid  { grid-template-columns: 1fr; }
}

/* =============================================
   AI Counter Section
   ============================================= */
.ai-counter-section { padding: 70px 0; background: var(--dark); }
.ai-counter-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.ai-counter-card {
  padding: 40px 32px;
  border-right: 1px solid rgba(255,255,255,0.07);
  text-align: center;
}
.ai-counter-card:last-child { border-right: none; }
.ai-counter-number {
  display: block;
  font-family: var(--font);
  font-size: clamp(2.4rem, 4vw, 3.6rem);
  font-weight: 700;
  color: var(--white);
  letter-spacing: -2px;
  line-height: 1;
  margin-bottom: 12px;
}
.ai-counter-label {
  display: block;
  font-family: var(--font);
  font-size: 13px;
  color: rgba(255,255,255,0.45);
  line-height: 1.5;
  max-width: 160px;
  margin: 0 auto;
}
/* Neutralise .highlight-card bleed-in from branding page */
.ai-counter-section .highlight-card {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  /* no padding override - .ai-counter-card handles it */
}
.ai-counter-section .highlight-card:hover {
  box-shadow: none;
  transform: none;
}
.ai-counter-section .highlight-number {
  font-family: var(--font);
  font-size: clamp(2.2rem, 3.5vw, 3.6rem);
  font-weight: 700;
  color: var(--accent);
  letter-spacing: -2px;
  white-space: nowrap;
}
.ai-counter-label {
  color: rgba(255,255,255,0.7) !important;
  font-size: 12px;
}

/* =============================================
   AI Intro Section
   ============================================= */
/* =============================================
   AI Intro - Premium Dark Numbered Rows
   ============================================= */
.ai-intro {
  background: var(--dark);
  padding: 120px 0;
}

.ai-intro-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: end;
  margin-bottom: 72px;
}

.ai-intro-tag { color: rgba(255,255,255,0.38) !important; }

.ai-intro-title {
  color: #fff !important;
  margin-bottom: 0;
}
.ai-intro-title .accent { color: var(--accent); }

.ai-intro-lead {
  font-family: var(--font);
  font-size: 16px;
  color: rgba(255,255,255,0.42);
  line-height: 1.8;
  max-width: 480px;
  align-self: end;
}

/* Numbered rows */
.ai-svc-list {
  border-top: 1px solid rgba(255,255,255,0.07);
}

.ai-svc-row {
  display: grid;
  grid-template-columns: 88px 1fr auto;
  align-items: center;
  gap: 40px;
  padding: 44px 0;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  cursor: default;
  transition: background 0.3s ease;
}

.ai-svc-num {
  font-size: clamp(2.2rem, 3.5vw, 3.2rem);
  font-weight: 800;
  color: rgba(255,255,255,0.08);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  letter-spacing: -2px;
  transition: color 0.4s ease;
  user-select: none;
}
.ai-svc-row:hover .ai-svc-num { color: var(--accent); }

.ai-svc-title {
  font-family: var(--font);
  font-size: clamp(1.1rem, 2vw, 1.5rem);
  font-weight: 700;
  color: rgba(255,255,255,0.88);
  letter-spacing: -0.5px;
  margin-bottom: 10px;
  line-height: 1.2;
  transition: color 0.3s ease;
}
.ai-svc-row:hover .ai-svc-title { color: #fff; }

.ai-svc-desc {
  font-family: var(--font);
  font-size: 15px;
  color: rgba(255,255,255,0.38);
  line-height: 1.7;
  max-width: 520px;
  margin: 0;
  transition: color 0.3s ease;
}
.ai-svc-row:hover .ai-svc-desc { color: rgba(255,255,255,0.55); }

.ai-svc-link {
  font-family: var(--font);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  white-space: nowrap;
  padding: 10px 20px;
  border: 1.5px solid rgba(226,117,0,0.35);
  border-radius: 40px;
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 0.3s ease, transform 0.3s ease, background 0.3s ease;
}
.ai-svc-row:hover .ai-svc-link {
  opacity: 1;
  transform: translateX(0);
}
.ai-svc-link:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.ai-intro-footer {
  margin-top: 56px;
}

.ai-section-cta { margin-top: 56px; }

/* =============================================
   AI Deep Dive Sections
   ============================================= */
.ai-deep-section { background: var(--white); }
.ai-deep-section--tinted { background: #f4f4f4; }
.ai-deep-section--alt { background: var(--bg); }

.ai-deep-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.ai-deep-grid--reverse { direction: rtl; }
.ai-deep-grid--reverse > * { direction: ltr; }

.ai-deep-body {
  font-family: var(--font);
  font-size: 15px;
  color: var(--text);
  line-height: 1.8;
  margin-bottom: 18px;
}

.ai-benefits-heading {
  font-family: var(--font-hand);
  font-size: 15px;
  color: var(--muted);
  margin-bottom: 24px;
  display: block;
}

.ai-benefits-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 40px;
}
.ai-benefits-list li {
  font-family: var(--font);
  font-size: 14px;
  color: var(--text);
  line-height: 1.6;
  padding-left: 26px;
  position: relative;
}
.ai-benefits-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
  font-weight: 700;
  font-size: 13px;
}

.ai-deep-callout {
  background: var(--dark);
  border-radius: 16px;
  padding: 28px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
}
.ai-callout-number {
  font-family: var(--font);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: -2px;
  line-height: 1;
  flex-shrink: 0;
}
.ai-callout-label {
  font-family: var(--font);
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  line-height: 1.5;
}

/* =============================================
   Quote Section
   ============================================= */
.ai-quote-section {
  background: var(--dark);
  padding: 90px 0;
  text-align: center;
}
.ai-quote-text {
  font-family: var(--font);
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 600;
  color: var(--white);
  letter-spacing: -1px;
  line-height: 1.4;
  max-width: 820px;
  margin: 0 auto 40px;
  font-style: normal;
}

/* =============================================
   Bold Statement Section
   ============================================= */
.ai-bold-section {
  background: var(--dark);
  padding: 120px 0;
  text-align: center;
}
.ai-bold-eyebrow {
  font-family: var(--font-hand);
  font-size: 15px;
  color: var(--accent);
  margin-bottom: 24px;
  display: block;
}
.ai-bold-text {
  font-family: var(--font);
  font-size: clamp(2.4rem, 6vw, 5rem);
  font-weight: 700;
  color: var(--white);
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin-bottom: 24px;
}
.ai-bold-text .accent { color: var(--accent); }
.ai-bold-sub {
  font-family: var(--font);
  font-size: 16px;
  color: rgba(255,255,255,0.5);
  max-width: 480px;
  margin: 0 auto 48px;
  line-height: 1.7;
}
.ai-bold-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* =============================================
   Responsive overrides
   ============================================= */
@media (max-width: 1024px) {
  .ai-deep-grid { gap: 48px; }
}
@media (max-width: 900px) {
  .ai-counter-grid        { grid-template-columns: repeat(2, 1fr); }
  .ai-counter-card        { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.07); }
  .ai-intro-top           { grid-template-columns: 1fr; gap: 28px; }
  .ai-svc-row             { grid-template-columns: 60px 1fr; gap: 20px; padding: 32px 0; }
  .ai-svc-link            { display: none; }
  .ai-deep-grid           { grid-template-columns: 1fr; gap: 40px; }
  .ai-deep-grid--reverse  { direction: ltr; }
}
@media (max-width: 600px) {
  .ai-counter-grid        { grid-template-columns: 1fr 1fr; }
}

/* =============================================
   Wide split layout (large text deep sections)
   ============================================= */
.ai-wide-split {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 56px;
  align-items: start;
  padding: 0;
}
.ai-wide-split--reverse .ai-wide-left  { order: 2; }
.ai-wide-split--reverse .ai-wide-right { order: 1; }

.ai-xl-title {
  font-family: var(--font);
  font-size: clamp(3rem, 5.5vw, 5.2rem);
  font-weight: 700;
  line-height: 1.0;
  letter-spacing: -0.03em;
  color: var(--dark);
  margin-bottom: 48px;
}
.ai-xl-title .accent { color: var(--accent); }
.ai-wide-left .ai-xl-title { margin-bottom: 0; }

.ai-stat-row {
  display: flex;
  gap: 40px;
}
.ai-stat-num {
  display: block;
  font-family: var(--font);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 700;
  color: var(--accent);
  letter-spacing: -2px;
  line-height: 1;
  margin-bottom: 4px;
}
.ai-stat-lbl {
  display: block;
  font-family: var(--font);
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}

.ai-wide-right .ai-benefits-list { margin-bottom: 36px; }

/* =============================================
   Process - grid with giant step numbers
   ============================================= */
.ai-process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-bottom: 72px;
  border-top: 1px solid var(--border);
}
.ai-pg-step {
  padding: 48px 32px;
  border-right: 1px solid var(--border);
  position: relative;
  overflow: hidden;
  cursor: default;
  transition: background 0.35s, border-color 0.35s;
  will-change: background;
}
.ai-pg-step:last-child { border-right: none; }
.ai-pg-step:hover { background: var(--dark); }

.ai-pg-num {
  display: block;
  font-family: var(--font);
  font-size: clamp(4.5rem, 8vw, 7.5rem);
  font-weight: 700;
  color: var(--accent);
  opacity: 0.55;
  letter-spacing: -5px;
  line-height: 1;
  margin-bottom: 28px;
  transition: color 0.35s, opacity 0.35s;
  will-change: color, opacity;
}
.ai-pg-step:hover .ai-pg-num { color: var(--white); opacity: 1; }

.ai-pg-tag {
  display: block;
  font-family: var(--font-hand);
  font-size: 12px;
  color: var(--accent);
  margin-bottom: 10px;
  transition: color 0.35s;
}
.ai-pg-step:hover .ai-pg-tag { color: rgba(255,255,255,0.45); }

.ai-pg-title {
  font-family: var(--font);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.4px;
  line-height: 1.3;
  margin-bottom: 12px;
  transition: color 0.35s;
}
.ai-pg-step:hover .ai-pg-title { color: var(--white); }

.ai-pg-desc {
  font-family: var(--font);
  font-size: 13px;
  color: var(--gray);
  line-height: 1.65;
  transition: color 0.35s;
}
.ai-pg-step:hover .ai-pg-desc { color: rgba(255,255,255,0.45); }

/* Responsive */
@media (max-width: 1024px) {
  .ai-wide-split { gap: 48px; }
}
@media (max-width: 900px) {
  .ai-wide-split                 { grid-template-columns: 1fr; gap: 32px; }
  .ai-wide-split--reverse .ai-wide-left  { order: 1; }
  .ai-wide-split--reverse .ai-wide-right { order: 2; }
  .ai-process-grid               { grid-template-columns: 1fr 1fr; }
  .ai-pg-step                    { border-right: none; border-bottom: 1px solid var(--border); }
  .ai-pg-step:last-child         { border-bottom: none; }
}
@media (max-width: 600px) {
  .ai-process-grid               { grid-template-columns: 1fr; }
}

/* =============================================
   AI Workflow page - Pain section
   ============================================= */
.wf-pain { background: var(--bg); padding: 100px 0; }
.wf-pain-headline {
  font-family: var(--font);
  font-size: clamp(2rem, 4vw, 3.4rem);
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin-bottom: 72px;
}
.wf-pain-headline .accent { color: var(--accent); }
.wf-pain-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--border);
}
.wf-pain-item {
  padding: 40px 32px;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.wf-pain-item:nth-child(3n) { border-right: none; }
.wf-pain-num {
  display: block;
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 1px;
  margin-bottom: 16px;
}
.wf-pain-text {
  font-family: var(--font);
  font-size: 15px;
  color: var(--text);
  line-height: 1.7;
}

/* =============================================
   AI Workflow page - Categories
   ============================================= */
.wf-categories { background: var(--white); padding: 100px 0; }
.wf-cat-header { margin-bottom: 56px; }
.wf-cat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.wf-cat-card {
  background: var(--bg);
  border-radius: 20px;
  padding: 36px 30px;
  border: 1px solid transparent;
  transition: border-color 0.3s, box-shadow 0.3s, transform 0.3s;
  will-change: transform;
}
.wf-cat-card:hover {
  border-color: rgba(226,117,0,0.2);
  box-shadow: 0 12px 40px rgba(0,0,0,0.07);
  transform: translateY(-4px);
}
.wf-cat-title {
  font-family: var(--font);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.4px;
  margin-bottom: 12px;
}
.wf-cat-desc {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.7;
}

/* =============================================
   AI Workflow page - Before / After
   ============================================= */
.wf-compare { background: var(--dark); padding: 100px 0; }
.wf-compare .section-tag { color: rgba(255,255,255,0.45); }
.wf-compare .section-title { color: var(--white); }
.wf-compare .section-title .accent { color: var(--accent); }
.wf-compare-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  margin-top: 56px;
  margin-bottom: 56px;
  border-radius: 20px;
  overflow: hidden;
}
.wf-compare-col {
  padding: 48px 40px;
}
.wf-compare-before {
  background: rgba(255,255,255,0.04);
}
.wf-compare-after {
  background: rgba(226,117,0,0.12);
}
.wf-compare-heading {
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 32px;
}
.wf-compare-before .wf-compare-heading { color: rgba(255,255,255,0.3); }
.wf-compare-after  .wf-compare-heading { color: var(--accent); }
.wf-compare-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.wf-compare-list li {
  font-family: var(--font);
  font-size: 15px;
  line-height: 1.6;
  padding-left: 28px;
  position: relative;
}
.wf-compare-before .wf-compare-list li { color: rgba(255,255,255,0.45); }
.wf-compare-before .wf-compare-list li::before {
  content: '✕';
  position: absolute;
  left: 0;
  color: rgba(255,255,255,0.2);
  font-size: 11px;
  top: 3px;
}
.wf-compare-after .wf-compare-list li { color: rgba(255,255,255,0.85); }
.wf-compare-after .wf-compare-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 700;
  font-size: 13px;
}
.wf-compare .ai-section-cta { text-align: center; }

/* =============================================
   AI Workflow page - Process track
   ============================================= */
.wf-process { background: var(--white); padding: 100px 0; }
.wf-process .section-tag  { margin-bottom: 16px; display: block; }
.wf-process .section-title { margin-bottom: 72px; }
.wf-process-track {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 840px;
}
.wf-track-step {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 48px;
  padding: 48px 0;
  border-top: 1px solid var(--border);
  align-items: start;
  transition: background 0.3s;
}
.wf-track-step:last-child { border-bottom: 1px solid var(--border); }
.wf-track-num {
  font-family: var(--font);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 700;
  color: var(--accent);
  opacity: 0.2;
  letter-spacing: -3px;
  line-height: 1;
  transition: opacity 0.3s;
}
.wf-track-step:hover .wf-track-num { opacity: 1; }
.wf-track-tag {
  display: block;
  font-family: var(--font-hand);
  font-size: 12px;
  color: var(--accent);
  margin-bottom: 8px;
}
.wf-track-title {
  font-family: var(--font);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.5px;
  margin-bottom: 10px;
}
.wf-track-desc {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.75;
}

/* =============================================
   AI Workflow page - Who it's for
   ============================================= */
.wf-who { background: var(--bg); padding: 64px 0; }
.wf-who-grid {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 56px;
  align-items: start;
}
.wf-who-left { position: static; }
.wf-who-left .ai-xl-title { margin-bottom: 36px; }
.wf-who-right {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.wf-who-item {
  padding: 32px 0;
  border-bottom: 1px solid var(--border);
}
.wf-who-item:first-child { border-top: 1px solid var(--border); }
.wf-who-title {
  font-family: var(--font);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.4px;
  margin-bottom: 8px;
}
.wf-who-desc {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.7;
}

/* =============================================
   AI Workflow page - Integrations
   ============================================= */
.wf-integrations { background: var(--white); padding: 100px 0; }
.wf-int-header { max-width: 640px; margin-bottom: 56px; }
.wf-int-lead {
  font-family: var(--font);
  font-size: 16px;
  color: var(--gray);
  margin-top: 20px;
}
.wf-int-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.wf-int-pill {
  display: inline-block;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 500;
  color: var(--dark);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 10px 20px;
  letter-spacing: 0.1px;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.wf-int-pill:hover {
  background: var(--dark);
  color: var(--white);
  border-color: var(--dark);
}

/* =============================================
   AI Workflow page - Outcomes
   ============================================= */
.wf-outcomes { background: var(--dark); padding: 100px 0; }
.wf-outcomes .section-tag { color: rgba(255,255,255,0.45); }
.wf-outcomes-headline {
  font-family: var(--font-display);
  font-size: clamp(2.2rem,4vw,3.4rem);
  font-weight: 700;
  color: var(--white);
  letter-spacing: -0.025em;
  margin-bottom: 64px;
  max-width: 560px;
}
.wf-outcomes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: rgba(255,255,255,0.08);
  border-radius: 16px;
  overflow: hidden;
}
.wf-outcome-card {
  background: rgba(255,255,255,0.04);
  padding: 48px 40px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: background 0.25s;
}
.wf-outcome-card:hover { background: rgba(255,255,255,0.08); }
.wf-outcome-num {
  font-family: var(--font-display);
  font-size: clamp(3rem,5vw,4.8rem);
  font-weight: 700;
  color: var(--accent);
  letter-spacing: -3px;
  line-height: 1;
}
.wf-outcome-label {
  font-family: var(--font);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--white);
  letter-spacing: -0.3px;
}
.wf-outcome-desc {
  font-family: var(--font);
  font-size: 13px;
  color: rgba(255,255,255,0.5);
  line-height: 1.7;
  margin-top: 4px;
}

/* =============================================
   AI Workflow page - FAQ
   ============================================= */
.wf-faq { background: var(--bg); padding: 100px 0; }
.wf-faq-header { max-width: 600px; margin-bottom: 56px; }
.wf-faq-list { max-width: 780px; }
.wf-faq-item {
  border-bottom: 1px solid var(--border);
}
.wf-faq-item:first-child { border-top: 1px solid var(--border); }
.wf-faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 28px 0;
  cursor: pointer;
  font-family: var(--font);
  font-size: 1rem;
  font-weight: 600;
  color: var(--dark);
  letter-spacing: -0.3px;
  user-select: none;
  list-style: none;
}
.wf-faq-q::-webkit-details-marker { display: none; }
.wf-faq-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 300;
  color: var(--gray);
  transition: transform 0.3s ease, background 0.2s, color 0.2s, border-color 0.2s;
}
.wf-faq-item.open .wf-faq-icon {
  transform: rotate(45deg);
  background: var(--accent);
  color: var(--white);
  border-color: var(--accent);
}
.wf-faq-a {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.8;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.3s ease;
  padding-bottom: 0;
}
.wf-faq-item.open .wf-faq-a {
  max-height: 300px;
  padding-bottom: 28px;
}

/* =============================================
   AI Agents page - What section
   ============================================= */
.ag-what { background: var(--white); padding: 64px 0; }
.ag-what-lead {
  font-family: var(--font);
  font-size: 16px;
  color: var(--dark);
  line-height: 1.75;
  margin-bottom: 28px;
  font-weight: 500;
}
.ag-what-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ag-what-list li {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  padding-left: 20px;
  position: relative;
  line-height: 1.6;
}
.ag-what-list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--accent);
  font-size: 12px;
  top: 1px;
}

/* =============================================
   AI Agents page - Types section
   ============================================= */
.ag-types { background: var(--bg); padding: 64px 0; }

/* =============================================
   AI Agents page - How It Works
   ============================================= */
.ag-how { background: var(--white); padding: 64px 0; }
.ag-how-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  margin-top: 64px;
  background: var(--border);
  border-radius: 16px;
  overflow: hidden;
}
.ag-how-step {
  background: var(--white);
  padding: 48px 40px;
  display: flex;
  gap: 24px;
  align-items: flex-start;
  transition: background 0.25s;
}
.ag-how-step:hover { background: var(--bg); }
.ag-how-num {
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 700;
  color: var(--accent);
  opacity: 0.35;
  line-height: 1;
  flex-shrink: 0;
  transition: opacity 0.25s;
}
.ag-how-step:hover .ag-how-num { opacity: 1; }
.ag-how-body { flex: 1; }
.ag-how-tag {
  display: block;
  font-family: var(--font-hand);
  font-size: 12px;
  color: var(--accent);
  margin-bottom: 10px;
}
.ag-how-title {
  font-family: var(--font);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.4px;
  margin-bottom: 12px;
}
.ag-how-desc {
  font-family: var(--font);
  font-size: 13.5px;
  color: var(--gray);
  line-height: 1.75;
}

/* =============================================
   AI Agents page - Channels section
   ============================================= */
.ag-channels { background: var(--dark); padding: 64px 0; }
.ag-channels .section-tag { color: rgba(255,255,255,0.45); }
.ag-channels .section-title { color: var(--white); }
.ag-channels .section-title .accent { color: var(--accent); }
.ag-channels .wf-int-header { max-width: 640px; }
.ag-channels .wf-int-lead { color: rgba(255,255,255,0.5); }
.ag-channels .wf-int-pill {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.8);
}
.ag-channels .wf-int-pill:hover {
  background: var(--accent);
  color: var(--white);
  border-color: var(--accent);
}

/* =============================================
   AI Ops page - What section
   ============================================= */
.ops-what { background: var(--white); padding: 100px 0; }
.ops-what-lead {
  font-family: var(--font);
  font-size: 16px;
  font-weight: 500;
  color: var(--dark);
  line-height: 1.75;
  margin-bottom: 20px;
}
.ops-what-body {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.8;
  margin-bottom: 32px;
}
.ops-what-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.ops-tag {
  font-family: var(--font);
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  background: rgba(226,117,0,0.08);
  border: 1px solid rgba(226,117,0,0.2);
  border-radius: 100px;
  padding: 6px 14px;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

/* =============================================
   AI Ops page - Three Pillars
   ============================================= */
.ops-pillars { background: var(--dark); padding: 100px 0; }
.ops-pillars-header { margin-bottom: 64px; }
.ops-pillars .section-tag { color: rgba(255,255,255,0.45); }
.ops-pillars .section-title { color: var(--white); }
.ops-pillars .section-title .accent { color: var(--accent); }
.ops-pillar-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: rgba(255,255,255,0.08);
  border-radius: 16px;
  overflow: hidden;
}
.ops-pillar-card {
  background: rgba(255,255,255,0.04);
  padding: 48px 40px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: background 0.25s;
}
.ops-pillar-card:hover { background: rgba(255,255,255,0.08); }
.ops-pillar-card--accent { background: rgba(226,117,0,0.08); }
.ops-pillar-card--accent:hover { background: rgba(226,117,0,0.14); }
.ops-pillar-num {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 2px;
}
.ops-pillar-title {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--white);
  letter-spacing: -1px;
  margin: 0;
}
.ops-pillar-desc {
  font-family: var(--font);
  font-size: 14px;
  color: rgba(255,255,255,0.55);
  line-height: 1.75;
  flex: 1;
}
.ops-pillar-link {
  font-family: var(--font);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  letter-spacing: 0.2px;
  transition: opacity 0.2s;
}
.ops-pillar-link:hover { opacity: 0.7; }

/* =============================================
   AI Ops page - Deep Dive sections
   ============================================= */
.ops-deep--light { background: var(--white); padding: 100px 0; }
.ops-deep--dark  { background: var(--dark);  padding: 100px 0; }
.ops-deep--dark .section-tag  { color: rgba(255,255,255,0.45); }
.ops-deep--dark .ops-deep-title { color: var(--white); }
.ops-deep--dark .ops-deep-title .accent { color: var(--accent); }
.ops-deep--dark .ops-deep-intro  { color: rgba(255,255,255,0.5); }
.ops-deep--dark .ops-feature-group-title { color: rgba(255,255,255,0.7); }
.ops-deep--dark .ops-check-list li { color: rgba(255,255,255,0.55); }
.ops-deep--dark .ops-check-list li::before { color: var(--accent); }

.ops-deep-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.ops-deep-grid--reverse .ops-deep-left { order: 2; }
.ops-deep-grid--reverse .ops-deep-right { order: 1; }
.ops-deep-title {
  font-family: var(--font-display);
  font-size: clamp(2rem,3.5vw,3rem);
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -2px;
  line-height: 1.15;
  margin-bottom: 20px;
}
.ops-deep-title .accent { color: var(--accent); }
.ops-deep-intro {
  font-family: var(--font);
  font-size: 15px;
  color: var(--gray);
  line-height: 1.8;
}
.ops-deep-intro--wide { max-width: 680px; }
.ops-compliance-header { margin-bottom: 56px; }
.ops-feature-group { margin-bottom: 36px; }
.ops-feature-group:last-child { margin-bottom: 0; }
.ops-feature-group-title {
  font-family: var(--font);
  font-size: 12px;
  font-weight: 700;
  color: var(--gray);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  margin-bottom: 14px;
}
.ops-check-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ops-check-list li {
  font-family: var(--font);
  font-size: 13.5px;
  color: var(--gray);
  padding-left: 22px;
  position: relative;
  line-height: 1.65;
}
.ops-check-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--accent);
  font-size: 12px;
  font-weight: 700;
  top: 1px;
}

/* =============================================
   AI Ops page - Tool strips
   ============================================= */
.ops-tools { background: var(--bg); padding: 48px 0; }
.ops-tools--dark { background: rgba(20,22,23,0.96); }
.ops-tools--dark .ops-tools-label { color: rgba(255,255,255,0.35); }
.ops-tools--dark .wf-int-pill {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.65);
}
.ops-tools--dark .wf-int-pill:hover {
  background: var(--accent);
  color: var(--white);
  border-color: var(--accent);
}
.ops-tools-label {
  font-family: var(--font);
  font-size: 11px;
  font-weight: 600;
  color: var(--gray);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 20px;
}

/* =============================================
   AI Ops page - Compliance frameworks
   ============================================= */
.ops-fw-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 40px;
}
.ops-fw-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 32px 28px;
  transition: border-color 0.2s, transform 0.2s;
}
.ops-fw-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
}
.ops-fw-badge {
  display: inline-block;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  background: rgba(226,117,0,0.08);
  border: 1px solid rgba(226,117,0,0.2);
  border-radius: 6px;
  padding: 4px 12px;
  margin-bottom: 16px;
  letter-spacing: 0.3px;
}
.ops-fw-desc {
  font-family: var(--font);
  font-size: 13px;
  color: var(--gray);
  line-height: 1.7;
  margin: 0;
}

/* =============================================
   AI Ops page - Process track
   ============================================= */
.ops-process { background: var(--bg); padding: 100px 0; }
.ops-process-track {
  position: relative;
  margin-top: 64px;
  margin-left: 24px;
  border-left: 2px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 0;
}
.ops-process-step {
  display: flex;
  gap: 36px;
  padding: 0 0 56px 48px;
  position: relative;
}
.ops-process-step:last-child { padding-bottom: 0; }
.ops-process-dot {
  position: absolute;
  left: -9px;
  top: 6px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--accent);
  border: 3px solid var(--bg);
  flex-shrink: 0;
}
.ops-process-body { flex: 1; }
.ops-process-tag {
  display: block;
  font-family: var(--font-hand);
  font-size: 12px;
  color: var(--accent);
  margin-bottom: 10px;
}
.ops-process-title {
  font-family: var(--font);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.4px;
  margin-bottom: 12px;
}
.ops-process-desc {
  font-family: var(--font);
  font-size: 13.5px;
  color: var(--gray);
  line-height: 1.8;
  max-width: 600px;
}

/* =============================================
   AI Ops page - Monitor section
   ============================================= */
.ops-monitor { background: var(--white); padding: 100px 0; }
.ops-monitor .section-tag { }
.ops-monitor-categories {
  display: flex;
  flex-direction: column;
  gap: 48px;
  margin-top: 56px;
}
.ops-monitor-group-title {
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  color: var(--gray);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 16px;
}

/* =============================================
   Responsive - AI Ops page
   ============================================= */
@media (max-width: 1100px) {
  .ops-fw-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .ops-pillar-grid   { grid-template-columns: 1fr; }
  .ops-deep-grid     { grid-template-columns: 1fr; gap: 48px; }
  .ops-deep-grid--reverse .ops-deep-left  { order: 1; }
  .ops-deep-grid--reverse .ops-deep-right { order: 2; }
  .ops-fw-grid       { grid-template-columns: 1fr 1fr; }
  .ops-process-track { margin-left: 12px; }
  .ops-process-step  { padding-left: 32px; gap: 24px; }
}
@media (max-width: 600px) {
  .ops-pillar-card   { padding: 36px 28px; }
  .ops-fw-grid       { grid-template-columns: 1fr; }
  .ops-process-step  { padding-left: 24px; gap: 16px; }
}

/* =============================================
   Branding page - Service Nav Cards
   ============================================= */
.br-nav { background: var(--white); padding: 100px 0; }
.br-nav-header { margin-bottom: 56px; }
.br-nav-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: var(--border);
  border-radius: 16px;
  overflow: hidden;
}
.br-nav-card {
  background: var(--white);
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  text-decoration: none;
  transition: background 0.25s;
  cursor: pointer;
}
.br-nav-card:hover { background: var(--bg); }
.br-nav-num {
  font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 2px;
}
.br-nav-title {
  font-family: var(--font);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.4px;
  margin: 0;
  transition: color 0.2s;
}
.br-nav-card:hover .br-nav-title { color: var(--accent); }
.br-nav-desc {
  font-family: var(--font);
  font-size: 13px;
  color: var(--gray);
  line-height: 1.7;
  flex: 1;
}
.br-nav-link {
  font-family: var(--font);
  font-size: 12px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.2px;
  margin-top: 8px;
  display: block;
  transition: opacity 0.2s;
}
.br-nav-card:hover .br-nav-link { opacity: 0.7; }

/* =============================================
   Branding page - Service Detail Sections
   ============================================= */
.br-service { padding: 100px 0; }
.br-service--dark  { background: var(--dark); }
.br-service--light { background: var(--white); }
.br-service--bg    { background: var(--bg); }

.br-service-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.br-service-grid--reverse .br-service-left  { order: 2; }
.br-service-grid--reverse .br-service-right { order: 1; }

/* Left column */
.br-service--dark  .section-tag { color: rgba(255,255,255,0.45); }
.br-service-title {
  font-family: var(--font-display);
  font-size: clamp(2rem,3.5vw,3rem);
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -2px;
  line-height: 1.15;
  margin-bottom: 24px;
}
.br-service--dark .br-service-title { color: var(--white); }
.br-service-title .accent { color: var(--accent); }
.br-service-lead {
  font-family: var(--font);
  font-size: 15px;
  font-weight: 500;
  color: var(--dark);
  line-height: 1.75;
  margin-bottom: 16px;
}
.br-service--dark .br-service-lead { color: rgba(255,255,255,0.8); }
.br-service-body {
  font-family: var(--font);
  font-size: 14px;
  color: var(--gray);
  line-height: 1.8;
}
.br-service--dark .br-service-body { color: rgba(255,255,255,0.42); }

/* Right column - reuse ops-feature-group and ops-check-list */
.br-service--dark .ops-feature-group-title { color: rgba(255,255,255,0.5); }
.br-service--dark .ops-check-list li       { color: rgba(255,255,255,0.55); }
.br-service--dark .ops-check-list li::before { color: var(--accent); }

/* =============================================
   Responsive - Branding page
   ============================================= */
@media (max-width: 1000px) {
  .br-nav-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .br-service-grid { grid-template-columns: 1fr; gap: 48px; }
  .br-service-grid--reverse .br-service-left  { order: 1; }
  .br-service-grid--reverse .br-service-right { order: 2; }
}
@media (max-width: 600px) {
  .br-nav-grid  { grid-template-columns: 1fr; }
  .br-nav-card  { padding: 32px 24px; }
}

/* =============================================
   Responsive - AI Agents page
   ============================================= */
@media (max-width: 900px) {
  .ag-how-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .ag-how-step { flex-direction: column; gap: 12px; padding: 32px 24px; }
  .ag-how-num  { font-size: 2.5rem; }
}

/* =============================================
   Responsive - Workflow page
   ============================================= */
@media (max-width: 900px) {
  .wf-pain-grid       { grid-template-columns: 1fr 1fr; }
  .wf-pain-item:nth-child(3n)   { border-right: 1px solid var(--border); }
  .wf-pain-item:nth-child(even) { border-right: none; }
  .wf-cat-grid        { grid-template-columns: 1fr 1fr; }
  .wf-compare-grid    { grid-template-columns: 1fr; }
  .wf-who-grid        { grid-template-columns: 1fr; }
  .wf-who-left        { position: static; }
  .wf-track-step      { grid-template-columns: 80px 1fr; gap: 24px; }
  .wf-outcomes-grid   { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .wf-pain-grid       { grid-template-columns: 1fr; }
  .wf-pain-item       { border-right: none; }
  .wf-cat-grid        { grid-template-columns: 1fr; }
  .wf-track-step      { grid-template-columns: 1fr; gap: 8px; }
  .wf-track-num       { font-size: 2.5rem; }
  .wf-compare-col     { padding: 32px 24px; }
  .wf-outcomes-grid   { grid-template-columns: 1fr; }
  .wf-outcome-card    { padding: 36px 28px; }
}

/* =============================================
   MOBILE OPTIMISATION — All Pages
   Consolidated overrides for tablet + mobile.
   ============================================= */

/* ── Tablet (≤900px) ──────────────────────── */
@media (max-width: 900px) {
  /* Reduce heavy top/bottom padding on explicit sections */
  .ai-intro           { padding: 80px 0; }
  .ai-bold-section    { padding: 80px 0; }
  .wf-pain            { padding: 72px 0; }
  .wf-integrations    { padding: 72px 0; }
  .wf-faq             { padding: 72px 0; }
  .ops-monitor        { padding: 72px 0; }
  .br-service         { padding: 72px 0; }
  .br-nav             { padding: 72px 0; }
  .ai-counter-section { padding: 52px 0; }

  /* Branding service grid already goes 1-col at 900px — ensure left col reads first */
  .br-service-grid--reverse .br-service-left  { order: 1; }
  .br-service-grid--reverse .br-service-right { order: 2; }

  /* Ops compliance: centre header text when stacked */
  .ops-compliance-header { text-align: center; }

  /* Bold actions already flex-wrap — add gap breathing room */
  .ai-bold-actions { gap: 10px; }
}

/* ── Mobile (≤640px) ──────────────────────── */
@media (max-width: 640px) {
  /* ── Global ── */
  .section-title     { font-size: clamp(1.6rem, 7vw, 2.4rem); }

  /* ── Hero ── */
  .hero-badge        { font-size: 11px; padding: 6px 14px; }
  .hero-sub          { font-size: 14px; }
  .hero-cta-row      { flex-direction: column; align-items: center; gap: 10px; }
  .btn-cta-primary,
  .btn-cta-ghost     { width: 100%; max-width: 300px; justify-content: center; }

  /* ── Home: intro dark section ── */
  .ai-intro          { padding: 60px 0; }
  .ai-intro-top      { margin-bottom: 40px; }
  .ai-svc-row        { grid-template-columns: 52px 1fr; gap: 14px; padding: 26px 0; }
  .ai-svc-num        { font-size: 1.9rem; letter-spacing: -1px; }
  .ai-svc-desc       { font-size: 14px; }
  .ai-intro-footer   { margin-top: 36px; }

  /* ── Process steps ── */
  .ai-pg-step        { padding: 36px 20px; }
  .ai-pg-num         { font-size: clamp(3rem, 11vw, 5rem); }

  /* ── Stats ── */
  .ai-stat-row       { flex-wrap: wrap; gap: 20px; }

  /* ── Bold statement ── */
  .ai-bold-section   { padding: 60px 0; }
  /* ai-bold-text letter-spacing is now em-based and auto-scales — no override needed */
  .ai-bold-actions   { flex-direction: column; align-items: center; gap: 10px; }
  .ai-bold-actions .btn-cta-primary,
  .ai-bold-actions .btn-cta-outline { width: 100%; max-width: 300px; justify-content: center; }

  /* ── Section CTAs ── */
  .ai-section-cta .btn-cta-primary,
  .ai-intro-footer .btn-cta-primary { width: 100%; max-width: 300px; }

  /* ── Review author: stack on narrow ── */
  .review-author     { flex-direction: column; align-items: flex-start; gap: 3px; }

  /* ── Workflow page ── */
  .wf-pain           { padding: 60px 0; }
  .wf-integrations   { padding: 60px 0; }
  .wf-faq            { padding: 60px 0; }
  .wf-faq-header     { margin-bottom: 32px; }
  .wf-faq-q          { font-size: 15px; padding: 18px 0; }
  .wf-faq-a          { font-size: 14px; }
  .wf-who-item       { padding: 22px 0; }
  .wf-pain-headline  { letter-spacing: -1.5px; margin-bottom: 44px; }
  .wf-int-pill       { padding: 8px 16px; font-size: 12px; }
  .wf-outcome-card   { padding: 32px 24px; }

  /* ── Agents page ── */
  .ag-what-lead      { font-size: 15px; }

  /* ── Ops page ── */
  .ops-monitor       { padding: 60px 0; }
  .ops-compliance-header { margin-bottom: 36px; }
  .ops-fw-card       { padding: 28px 22px; }
  .ops-pillar-card   { padding: 36px 24px; }
  .ops-tag           { font-size: 12px; padding: 6px 14px; }
  .ops-deep-title    { letter-spacing: -1.5px; }

  /* ── Branding page ── */
  .br-service        { padding: 60px 0; }
  .br-nav            { padding: 60px 0; }
  .br-service-title  { letter-spacing: -1.5px; }
  .br-service-lead   { font-size: 14px; }
  .br-nav-card       { padding: 28px 20px; gap: 10px; }

  /* ── Counter strip ── */
  .ai-counter-section { padding: 44px 0; }
  .ai-counter-card    { padding: 28px 16px; }
  .ai-counter-label   { font-size: 12px; }
}

/* ── Small phones (≤400px) ────────────────── */
@media (max-width: 400px) {
  .ai-svc-row        { gap: 12px; padding: 22px 0; }
  .ai-svc-num        { font-size: 1.6rem; }
  .ai-counter-grid   { grid-template-columns: 1fr 1fr; }
  .ai-counter-card   { padding: 24px 12px; }
  .btn-cta-primary,
  .btn-cta-ghost,
  .ai-bold-actions .btn-cta-primary,
  .ai-bold-actions .btn-cta-outline { max-width: 100%; }
  .wf-faq-q          { font-size: 14px; }
}

/* =============================================
   ABOUT PAGE - Philanthropy / Giving Back (dark numbered rows)
   ============================================= */
.about-giving-dark {
  background: var(--dark);
  padding: 100px 0;
}
.about-giving-dark .section-tag { color: rgba(255,255,255,0.38); }
.about-giving-header-body {
  font-family: var(--font);
  font-size: 15px;
  color: rgba(255,255,255,0.42);
  line-height: 1.8;
  max-width: 580px;
  margin-bottom: 60px;
}
.about-giving-rows {
  border-top: 1px solid rgba(255,255,255,0.07);
}
.about-giving-row {
  display: grid;
  grid-template-columns: 88px 1fr;
  align-items: start;
  gap: 40px;
  padding: 48px 0;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  cursor: default;
  transition: background 0.3s ease;
}
.about-giving-row-num {
  font-size: clamp(2.2rem, 3.5vw, 3.2rem);
  font-weight: 800;
  color: rgba(255,255,255,0.07);
  line-height: 1;
  letter-spacing: -2px;
  user-select: none;
  transition: color 0.4s ease;
  padding-top: 6px;
}
.about-giving-row:hover .about-giving-row-num { color: var(--accent); }
.about-giving-row-title {
  font-family: var(--font);
  font-size: clamp(1.1rem, 2vw, 1.45rem);
  font-weight: 700;
  color: rgba(255,255,255,0.88);
  letter-spacing: -0.5px;
  margin-bottom: 12px;
  line-height: 1.2;
  transition: color 0.3s ease;
}
.about-giving-row:hover .about-giving-row-title { color: #fff; }
.about-giving-row-desc {
  font-family: var(--font);
  font-size: 15px;
  color: rgba(255,255,255,0.38);
  line-height: 1.75;
  max-width: 640px;
  margin: 0;
  transition: color 0.3s ease;
}
.about-giving-row:hover .about-giving-row-desc { color: rgba(255,255,255,0.58); }
.about-giving-footer {
  font-family: var(--font-hand);
  font-size: 15px;
  color: rgba(255,255,255,0.28);
  margin-top: 52px;
  display: block;
}
@media (max-width: 640px) {
  .about-giving-dark  { padding: 72px 0; }
  .about-giving-row   { grid-template-columns: 56px 1fr; gap: 20px; padding: 32px 0; }
  .about-giving-row-num { font-size: 1.8rem; }
}
