/* ============================================================
   Gregor Jovanovic, Portfolio
   Indigo editorial · neutral palette · rounded panels
   ============================================================ */

:root {
  --accent:      #4F46E5;
  --accent-2:    #6366F1;
  --accent-soft: #E0E7FF;
  --accent-wash: #EEF2FF;
  --text-strong: #0F1115;
  --bg:          #FFFFFF;
  --surface:     #F7F7F6;
  --surface-2:   #F1F1F0;
  --border:      #E6E6E9;
  --border-2:    #D1D1D6;
  --text:        #0F1115;
  --text-2:      #52525B;
  --text-3:      #8C8C95;

  --radius:     16px;
  --radius-md:  22px;
  --radius-lg:  32px;
  --radius-xl:  48px;

  --ease:       cubic-bezier(0.22, 1, 0.36, 1);
  --t-fast:     180ms;
  --t-med:      320ms;
  --t-slow:     520ms;

  --container:  1240px;
  --gutter:     clamp(20px, 4vw, 48px);
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: 100px;
  overscroll-behavior: none;
}
body {
  font-family:
    -apple-system, BlinkMacSystemFont,
    'SF Pro Display', 'SF Pro Text',
    'Inter', system-ui,
    'Segoe UI', Roboto, sans-serif;
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: -0.011em;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'kern', 'calt', 'ss01', 'cv11';
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
::selection { background: var(--text-strong); color: var(--accent); }
:focus-visible { outline: 2px solid var(--text-strong); outline-offset: 3px; border-radius: 6px; }

/* ---------- Skip link ---------- */
.skip-link {
  position: absolute;
  top: -100px; left: 16px;
  padding: 10px 14px;
  background: var(--text-strong); color: #fff;
  border-radius: 8px; z-index: 100;
  transition: top var(--t-fast) var(--ease);
}
.skip-link:focus { top: 16px; }

/* ---------- Layout helpers ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

.section {
  padding-top: clamp(96px, 12vw, 180px);
  padding-bottom: clamp(96px, 12vw, 180px);
  position: relative;
}

/* ---------- Typography (Apple-like sans-only system) ---------- */
.h2 {
  font-size: clamp(2.1rem, 4.8vw, 3.8rem);
  font-weight: 600;
  line-height: 1.04;
  letter-spacing: -0.042em;
  margin: 0;
  text-wrap: balance;
}
.h2--center { text-align: center; }
.h2 em, .h2--center em {
  font-style: normal;
  font-weight: 600;
  color: var(--text-3);
}

.kicker {
  display: inline-block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-3);
  margin: 0 0 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.kicker--center { display: block; text-align: center; }
.kicker--dark { color: rgba(0,0,0,.6); }

/* ============================================================
   Floating black nav pill (centered, with icons)
   ============================================================ */
.topbar {
  position: fixed;
  top: 14px;
  left: 0;
  right: 0;
  z-index: 60;
  pointer-events: none;
  display: flex;
  justify-content: center;
  padding: 0 var(--gutter);
  transition: top var(--t-med) var(--ease);
}
.topbar.is-scrolled { top: 10px; }

.topbar__inner {
  pointer-events: auto;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px;
  background: rgba(255,255,255,.78);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
          backdrop-filter: saturate(180%) blur(14px);
  border: 1px solid rgba(15,17,21,.08);
  border-radius: 999px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.6) inset,
    0 10px 30px -16px rgba(15,17,21,.18),
    0 2px 6px rgba(15,17,21,.06);
  transition: padding var(--t-med) var(--ease), background var(--t-med) var(--ease);
}
.topbar.is-scrolled .topbar__inner {
  background: rgba(255,255,255,.92);
}

/* === Case study topbar tinted by brand secondary accent === */
.case-study-body .topbar__inner {
  background: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 14%, rgba(255,255,255,0.85));
  border-color: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 32%, transparent);
}
.case-study-body .topbar.is-scrolled .topbar__inner {
  background: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 18%, rgba(255,255,255,0.92));
}
.case-study-body .topbar__nav a.is-active {
  background: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 22%, transparent);
  color: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 70%, #0A0A0A);
}
.case-study-body .lang-switch {
  background: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 14%, rgba(255,255,255,0.85));
  border-color: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 32%, transparent);
}
.case-study-body .lang-switch button.is-active {
  background: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 22%, transparent);
  color: color-mix(in srgb, var(--cs-accent-2-page, #6366F1) 70%, #0A0A0A);
}

/* Section nav (no icons, gray-tone pill) */
.topbar__nav {
  display: none;
  align-items: center;
  gap: 2px;
}
@media (min-width: 640px) { .topbar__nav { display: inline-flex; } }
.topbar__nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 9px 16px;
  border-radius: 999px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-2);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  white-space: nowrap;
  letter-spacing: -0.005em;
}
.topbar__nav a:hover { background: rgba(15,17,21,.05); color: var(--text); }
.topbar__nav a.is-active {
  background: rgba(15,17,21,.06);
  color: var(--text-strong);
  font-weight: 600;
}

/* Icons removed from nav per design, keep markup but hide visually */
.navicon { display: none; }

/* ============================================================
   Language switcher (floating, top-right, glass pill)
   ============================================================ */
.lang-switch {
  position: fixed;
  top: 14px;
  right: clamp(12px, 3vw, 24px);
  z-index: 61;
  display: inline-flex;
  gap: 2px;
  padding: 5px;
  background: rgba(255, 255, 255, 0.78);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
          backdrop-filter: saturate(180%) blur(14px);
  border: 1px solid rgba(15, 17, 21, 0.08);
  border-radius: 999px;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.6) inset,
    0 10px 30px -16px rgba(15, 17, 21, 0.18),
    0 2px 6px rgba(15, 17, 21, 0.06);
  transition: top var(--t-med) var(--ease), background var(--t-med) var(--ease);
}
.topbar.is-scrolled ~ .lang-switch { top: 10px; }
.lang-switch button {
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--text-2);
  background: transparent;
  border: 0;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  min-width: 32px;
}
.lang-switch button:hover {
  background: rgba(15, 17, 21, 0.05);
  color: var(--text);
}
.lang-switch button.is-active {
  background: var(--text-strong);
  color: #fff;
}
@media (max-width: 480px) {
  .lang-switch { top: 10px; right: 10px; padding: 4px; }
  .lang-switch button { padding: 6px 10px; font-size: 11.5px; }
}

/* Mobile menu trigger (sits inside dark pill) */
.menu-toggle {
  width: 40px; height: 40px;
  border-radius: 999px;
  background: transparent;
  border: 0;
  position: relative; display: inline-flex;
  flex-shrink: 0;
  color: var(--text);
}
.menu-toggle span {
  position: absolute; left: 11px; right: 11px;
  height: 1.5px; background: var(--text); border-radius: 1px;
  transition: top var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.menu-toggle span:nth-child(1) { top: 16px; }
.menu-toggle span:nth-child(2) { top: 22px; }
.menu-toggle[aria-expanded="true"] span:nth-child(1) { top: 19px; transform: rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2) { top: 19px; transform: rotate(-45deg); }
@media (min-width: 640px) { .menu-toggle { display: none; } }

.mobile-menu {
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 220px;
  padding: 8px;
  background: rgba(255,255,255,.92);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
          backdrop-filter: saturate(180%) blur(16px);
  border: 1px solid rgba(15,17,21,.08);
  border-radius: 18px;
  display: flex; flex-direction: column;
  box-shadow: 0 24px 60px -20px rgba(15,17,21,.18);
  z-index: 59;
  animation: drop var(--t-med) var(--ease);
}
.mobile-menu[hidden] { display: none; }
.mobile-menu a {
  padding: 14px 16px;
  font-size: 16px; font-weight: 500;
  border-radius: 12px;
  color: var(--text);
}
.mobile-menu a:hover { background: var(--surface); }
@keyframes drop { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }

/* ============================================================
   Hero (full-viewport, photo as prominent centerpiece)
   ============================================================ */
.hero { padding: 0; }
.hero__panel {
  position: relative;
  border-radius: 0 0 var(--radius-xl) var(--radius-xl);
  overflow: hidden;
  isolation: isolate;
  padding: clamp(110px, 13vw, 170px) clamp(24px, 4vw, 56px) 0;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: clamp(8px, 1.4vw, 20px);
  min-height: 100vh;
  min-height: 100dvh;
}
.hero__bg {
  position: absolute; inset: 0; z-index: -2;
  background:
    /* Bottom corner soft-fade-to-white */
    radial-gradient(ellipse 70% 55% at 0% 100%,  rgba(255,255,255,.7) 0%, transparent 55%),
    radial-gradient(ellipse 70% 55% at 100% 100%, rgba(255,255,255,.7) 0%, transparent 55%),
    /* Strong bottom fade-out for clean handoff to logo strip */
    linear-gradient(180deg, transparent 50%, rgba(255,255,255,.45) 80%, #fff 100%),
    /* Pink hint at lower-center */
    radial-gradient(ellipse 60% 40% at 50% 78%, rgba(245,208,254,.55) 0%, rgba(245,208,254,0) 70%),
    /* Mint hotspot right */
    radial-gradient(ellipse 65% 75% at 92% 45%, #A7F3D0 0%, rgba(167,243,208,0) 60%),
    /* Lavender hotspot left */
    radial-gradient(ellipse 65% 75% at 10% 25%, #C7D2FE 0%, rgba(199,210,254,0) 60%),
    /* Base soft gradient */
    linear-gradient(125deg, #DBEAFE 0%, #FAF5FF 50%, #ECFDF5 100%);
}
/* Subtle film-grain noise overlay (feTurbulence) */
.hero__bg::after {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.04;
  pointer-events: none;
  mix-blend-mode: multiply;
  z-index: 1;
}

.hero__top {
  display: flex; flex-direction: column; gap: 16px;
  align-items: flex-start;
}
@media (min-width: 880px) {
  .hero__top {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }
}

.pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.7);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border: 1px solid rgba(0,0,0,.08);
  font-size: 13px; font-weight: 500;
  color: var(--text);
}
.pill__dot {
  width: 8px; height: 8px; border-radius: 999px;
  background: #1bb454;
  box-shadow: 0 0 0 4px rgba(27,180,84,.25);
  animation: pulse 2.4s var(--ease) infinite;
}
@keyframes pulse {
  0%,100% { box-shadow: 0 0 0 4px rgba(27,180,84,.25); }
  50%     { box-shadow: 0 0 0 7px rgba(27,180,84,0); }
}

.hero__sub {
  margin: 0;
  max-width: 30ch;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text);
  text-align: right;
  font-weight: 500;
}
@media (max-width: 879px) { .hero__sub { text-align: left; } }

.hero__heading {
  margin: 0;
  text-align: center;
  align-self: start;
  padding-top: clamp(4px, 1vw, 16px);
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 1.6vw, 24px);
}
.hero__title {
  margin: 0;
  font-size: clamp(3.6rem, 11.5vw, 10.5rem);
  font-weight: 900;
  line-height: 0.9;
  letter-spacing: -0.05em;
  color: #000;
}
.hero__title em {
  display: block;
  font-family: inherit;
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-top: 4px;
  color: var(--text-strong);
}

.hero__photo-block {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  width: clamp(520px, 76vw, 1140px);
  height: clamp(52vh, 70vh, 76vh);
  border: 0;
  border-radius: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
  z-index: 2;
  pointer-events: none;
}
.hero__portrait-svg { width: 100%; height: 100%; }
.hero__photo-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center bottom;
  display: block;
  border: 0;
  background: transparent;
  /* Two-axis fade: vertical (strong bottom + slight top), horizontal (soft side cut) */
  -webkit-mask-image:
    linear-gradient(180deg, #000 0%, #000 55%, rgba(0,0,0,.55) 82%, transparent 100%),
    linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%);
          mask-image:
    linear-gradient(180deg, #000 0%, #000 55%, rgba(0,0,0,.55) 82%, transparent 100%),
    linear-gradient(90deg, transparent 0%, #000 9%, #000 91%, transparent 100%);
  -webkit-mask-composite: source-in;
          mask-composite: intersect;
}

/* Side text blocks (vertically centered, flanking the photo) */
.hero__side {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  margin: 0;
  max-width: 240px;
  font-size: clamp(15px, 1.25vw, 18px);
  line-height: 1.45;
  font-weight: 600;
  color: #0a0a0a;
  letter-spacing: -0.005em;
  z-index: 3;
}
.hero__side--left  { left:  clamp(40px, 7vw, 130px); text-align: left;  }
.hero__side--right { right: clamp(40px, 7vw, 130px); text-align: right; }
@media (max-width: 1024px) {
  .hero__side--left  { left:  clamp(24px, 4vw, 56px); }
  .hero__side--right { right: clamp(24px, 4vw, 56px); }
}
@media (max-width: 880px) {
  .hero__side { font-size: 13px; max-width: 170px; }
}
@media (max-width: 600px) {
  .hero__side { display: none; }
}

/* Layering: corner labels on top, photo above headline (head overlaps text) */
.hero__corner { position: absolute; z-index: 3; }
.hero__heading { position: relative; z-index: 1; }

/* Bottom corner labels */
.hero__corner {
  bottom: clamp(20px, 3vw, 40px);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 12px;
  font-weight: 400;
  color: #555;
  letter-spacing: 0.02em;
}
.hero__corner--left  { left:  clamp(20px, 4vw, 56px); }
.hero__corner--right { right: clamp(20px, 4vw, 56px); }

/* Trust element (bottom-left of hero): avatars + "Trusted by …" */
.hero-trust {
  position: absolute;
  bottom: clamp(20px, 3vw, 40px);
  left: clamp(20px, 4vw, 56px);
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 14px;
}
.hero-trust__avatars {
  display: inline-flex;
  align-items: center;
}
.hero-trust__avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: #fff;
  border: 2px solid #fffdf2;
  box-shadow: 0 1px 2px rgba(15,17,21,.10);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  font-size: 13px;
  font-weight: 700;
  color: #fffdf2;
}
.hero-trust__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-trust__avatar + .hero-trust__avatar { margin-left: -10px; }
.hero-trust__avatar--dark { background: #0F1115; }
.hero-trust__avatar--more {
  background: #0a0a0a;
}
.hero-trust__label {
  display: inline-flex;
  flex-direction: column;
  line-height: 1.25;
  color: #0a0a0a;
}
.hero-trust__label strong {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.005em;
}
.hero-trust__sub {
  font-size: 12px;
  font-weight: 500;
  color: #555;
  letter-spacing: 0.005em;
}
@media (max-width: 600px) {
  .hero-trust__sub { display: none; }
  .hero-trust__avatar { width: 28px; height: 28px; }
}

.hero__bottom {
  display: flex; flex-direction: column; gap: 16px;
  align-items: flex-start;
  position: relative;
  z-index: 2;
}
@media (min-width: 720px) {
  .hero__bottom { flex-direction: row; justify-content: space-between; align-items: center; }
}

.trust {
  display: flex; align-items: center; gap: 12px;
}
.trust__avatars { display: inline-flex; }
.trust__avatars .avatar {
  width: 32px; height: 32px;
  border-radius: 999px;
  border: 2px solid #fff;
  background: linear-gradient(135deg, #ddd, #aaa);
  margin-left: -10px;
}
.trust__avatars .avatar:first-child { margin-left: 0; }
.avatar--1 { background: linear-gradient(135deg, #ffe2a8, #ffb97a); }
.avatar--2 { background: linear-gradient(135deg, #c8e8ff, #7eb8e6); }
.avatar--3 { background: linear-gradient(135deg, #e0d4ff, #9d8aea); }
.trust p {
  margin: 0;
  font-size: 12.5px;
  line-height: 1.4;
  color: var(--text);
  font-weight: 500;
}

/* ============================================================
   Buttons
   ============================================================ */
.btn-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 13px 8px 13px 22px;
  border-radius: 999px;
  font-size: 14px; font-weight: 500;
  border: 1px solid var(--text-strong);
  background: transparent;
  color: var(--text);
  transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
  white-space: nowrap;
}
.btn-pill:hover { transform: translateY(-1px); }
.btn-pill__arrow {
  width: 28px; height: 28px;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent);
  color: var(--text-strong);
  transition: transform var(--t-fast) var(--ease);
}
.btn-pill:hover .btn-pill__arrow { transform: translateX(2px); }
.btn-pill--dark {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.btn-pill--dark:hover { background: var(--accent-2); border-color: var(--accent-2); }
.btn-pill--dark .btn-pill__arrow {
  background: #fff;
  color: var(--accent);
}

/* ============================================================
   Logo strip
   ============================================================ */
.logos {
  padding: clamp(40px, 6vw, 60px) 0;
  border-bottom: 1px solid var(--border);
  border-top: 1px solid var(--border);
  margin-top: clamp(40px, 6vw, 80px);
}
.logos__rail {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}
.logos__track {
  display: flex; gap: 56px;
  animation: marquee 40s linear infinite;
  width: max-content;
  align-items: center;
}
.logo {
  font-size: clamp(18px, 2.2vw, 26px);
  font-weight: 600;
  color: var(--text-3);
  letter-spacing: -0.02em;
  white-space: nowrap;
  transition: color var(--t-fast) var(--ease);
}
.logo:hover { color: var(--text); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================================
   Showcase strip
   ============================================================ */
.showcase {
  padding: clamp(48px, 6vw, 80px) var(--gutter) 0;
}
.showcase__panel {
  position: relative;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--accent-soft) 0%, var(--surface) 70%, #fff 100%);
  padding: clamp(28px, 4vw, 56px) 0 clamp(28px, 4vw, 64px);
  overflow: hidden;
}

.showcase__overlay {
  position: relative;
  z-index: 2;
  text-align: center;
  margin-bottom: 32px;
  padding: 0 var(--gutter);
}
.showcase__title {
  margin: 0;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--text-strong);
  text-wrap: balance;
}
.showcase__title em {
  font-family: inherit;
  font-weight: 400;
}

.showcase__rail {
  list-style: none; margin: 0; padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  position: relative;
  z-index: 1;
}
@media (min-width: 720px)  { .showcase__rail { grid-template-columns: repeat(3, 1fr); gap: 18px; } }

.showcase__card {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 24px 50px -20px rgba(0,0,0,.25), 0 1px 0 rgba(0,0,0,.04);
  background: #fff;
  align-self: start;
}
.showcase__card svg,
.showcase__card img { width: 100%; height: auto; display: block; }
@media (min-width: 720px) {
  .showcase__card--1 { transform: translateY(20px) rotate(-1deg); }
  .showcase__card--2 { transform: translateY(0)    rotate(0deg);  z-index: 2; }
  .showcase__card--3 { transform: translateY(20px) rotate(1deg); }
}

/* ============================================================
   Mission, scattered floating colored glyphs around statement
   ============================================================ */
.mission {
  padding: clamp(64px, 8vw, 110px) 0;
  text-align: center;
  position: relative;
}
.mission__inner {
  position: relative;
  min-height: clamp(360px, 46vh, 480px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.mission__greeting {
  font-size: clamp(1.1rem, 1.6vw, 1.4rem);
  font-weight: 500;
  margin: 0 0 28px;
  color: var(--text-3);
  letter-spacing: -0.01em;
}
.mission__copy {
  margin: 0;
  max-width: 720px;
  font-size: clamp(1.6rem, 3.6vw, 2.8rem);
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: -0.038em;
  text-wrap: balance;
  color: var(--text);
  position: relative;
  z-index: 2;
}
.mission__copy em {
  font-style: normal;
  font-weight: 600;
  color: var(--text-3);
}

/* Mobile: chips stack as flex below statement */
.mission__chips {
  list-style: none;
  margin: 32px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 14px 22px;
  justify-content: center;
}

/* Desktop (≥880px): chips scattered absolutely around the statement */
@media (min-width: 880px) {
  .mission__chips {
    position: absolute;
    inset: 0;
    margin: 0;
    pointer-events: none;
    display: block;
  }
  .mchip {
    position: absolute;
    left: var(--x);
    top: var(--y);
    transform: translate(-50%, -50%);
    pointer-events: auto;
  }
}

.mchip {
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.01em;
}
.mchip__inner {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 10px 18px 10px 12px;
  white-space: nowrap;
  background: rgba(255,255,255,.85);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  border: 1px solid rgba(15,17,21,.06);
  border-radius: 999px;
  box-shadow: 0 1px 0 rgba(255,255,255,.5) inset, 0 8px 22px -10px rgba(0,0,0,.18);
  animation: mchipFloat 8s var(--ease) infinite;
  animation-delay: var(--d, 0s);
  will-change: transform;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.mchip:hover .mchip__inner {
  transform: translateY(-3px);
  box-shadow: 0 1px 0 rgba(255,255,255,.5) inset, 0 14px 28px -12px rgba(0,0,0,.22);
}

.mchip__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}
.mchip__icon svg { width: 26px; height: 26px; }
.mchip__label { white-space: nowrap; font-size: 15px; }

/* Colored glyph variants, color the SVG itself, no background */
.mchip--blue    .mchip__icon { color: #2563eb; }
.mchip--purple  .mchip__icon { color: #7c3aed; }
.mchip--cyan    .mchip__icon { color: #0891b2; }
.mchip--orange  .mchip__icon { color: #ea580c; }
.mchip--green   .mchip__icon { color: #10b981; }
.mchip--rose    .mchip__icon { color: #e11d48; }
.mchip--indigo  .mchip__icon { color: #4338ca; }
.mchip--emerald .mchip__icon { color: #047857; }
.mchip--mono    .mchip__icon { color: #0a0a0a; }

/* Gentle floating motion */
@keyframes mchipFloat {
  0%   { transform: translateY(0)    rotate(0deg); }
  25%  { transform: translateY(-5px) rotate(-1deg); }
  50%  { transform: translateY(0)    rotate(0deg); }
  75%  { transform: translateY(4px)  rotate(1deg); }
  100% { transform: translateY(0)    rotate(0deg); }
}
@media (prefers-reduced-motion: reduce) {
  .mchip__inner { animation: none; }
}

/* legacy chip row (kept for fallback) */
.focus-chips {
  list-style: none;
  margin: clamp(40px, 5vw, 56px) auto 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px 8px 8px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--border);
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  box-shadow: 0 1px 0 rgba(0,0,0,.02), 0 6px 16px -10px rgba(0,0,0,.10);
  transition: transform var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  white-space: nowrap;
  width: fit-content;
}
.chip:hover { transform: translateY(-2px); border-color: var(--border-2); }
.chip__icon {
  width: 24px; height: 24px;
  border-radius: 999px;
  background: var(--accent);
  color: var(--text-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* ============================================================
   Services (4-card grid with yellow icon squares)
   ============================================================ */
.services__head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-bottom: clamp(40px, 5vw, 64px);
  align-items: end;
}
@media (min-width: 880px) {
  .services__head { grid-template-columns: 1fr 1.4fr; gap: 56px; }
}
.services__head .kicker { margin: 0 0 14px; }
.services__title { display: flex; flex-direction: column; }
.services__head .h2 { max-width: 22ch; }
.services__intro {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--text-2);
  max-width: 44ch;
  align-self: end;
}

.services__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 640px)  { .services__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .services__grid { grid-template-columns: repeat(4, 1fr); } }

.service {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 28px 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 260px;
  transition:
    transform var(--t-med) var(--ease),
    border-color var(--t-fast) var(--ease),
    background var(--t-fast) var(--ease);
}
.service:hover {
  transform: translateY(-2px);
  border-color: var(--border-2);
  background: #fff;
}
.service__icon {
  width: 40px; height: 40px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
}
.service__title {
  margin: 0;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.015em;
}
.service__desc {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-2);
}

/* ============================================================
   How I Work (clean numbered list, with deliverables)
   ============================================================ */
.process__head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  align-items: end;
  margin-bottom: clamp(40px, 5vw, 64px);
}
@media (min-width: 880px) {
  .process__head { grid-template-columns: 1.4fr 1fr; gap: 56px; }
}
.process__head .kicker { margin-bottom: 0; }
.process__head .h2 { max-width: 24ch; }
.process__intro {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--text-2);
  max-width: 44ch;
}

.process__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--border);
}

.step {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  padding: 28px 0;
  border-bottom: 1px solid var(--border);
  transition: padding var(--t-med) var(--ease);
}
@media (min-width: 880px) {
  .step {
    grid-template-columns: 220px 1fr 1fr;
    column-gap: 56px;
    align-items: start;
    padding: 40px 0;
  }
  .step:hover { padding-left: 8px; padding-right: 8px; }
}

.step__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
@media (min-width: 880px) {
  .step__head {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 12px;
  }
}
.step__lead { display: inline-flex; align-items: center; gap: 12px; }
.step__num {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 12px;
  color: var(--text-3);
  letter-spacing: 0.04em;
}
.step__label {
  display: inline-flex; align-items: center;
  padding: 4px 12px;
  font-size: 11.5px;
  font-weight: 500;
  border-radius: 999px;
  background: var(--accent);
  color: var(--text-strong);
  letter-spacing: 0.005em;
}
.step__duration {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.02em;
}

.step__title {
  margin: 0;
  font-size: clamp(1.2rem, 1.9vw, 1.6rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.2;
}
.step__desc {
  margin: 10px 0 0;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--text-2);
  max-width: 50ch;
}

.step__deliverables {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex; flex-direction: column;
  gap: 8px;
  margin-top: 14px;
}
@media (min-width: 880px) {
  .step__deliverables { margin-top: 0; align-self: start; }
}
.step__deliverables li {
  position: relative;
  padding-left: 22px;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-2);
}
.step__deliverables li::before {
  content: "";
  position: absolute;
  left: 0; top: 8px;
  width: 12px; height: 2px;
  background: var(--accent);
  border-radius: 1px;
}

/* ============================================================
   Testimonials — 3 floating cards (Apple-style scroll reveal)
   ============================================================ */
.testimonials-float {
  position: relative;
  padding: clamp(96px, 12vw, 160px) var(--gutter);
  isolation: isolate;
  overflow: hidden;
  --scroll-y: 0;  /* JS updates this 0..1 as section scrolls through viewport */
}
/* Ambient soft wash — radial fades naturally on every edge.
   Opacity is 0 by default and fades in once when section first enters viewport.
   Vertical mask makes top + bottom edges blend smoothly into surrounding white. */
.testimonials-float::before {
  content: "";
  position: absolute;
  inset: -10%;
  background: radial-gradient(ellipse 70% 55% at 50% 50%, var(--accent-wash) 0%, rgba(238, 242, 255, 0.4) 45%, transparent 75%);
  z-index: -2;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1800ms cubic-bezier(0.22, 1, 0.36, 1);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 22%, #000 78%, transparent 100%);
          mask-image: linear-gradient(180deg, transparent 0%, #000 22%, #000 78%, transparent 100%);
}
.testimonials-float.is-revealed::before {
  opacity: 1;
}
.testimonials-float__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
  /* Same vertical fade-mask so blobs + wave bleed seamlessly into surrounding white */
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
          mask-image: linear-gradient(180deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
}
/* Lavender blob top-left — drifts up as user scrolls down */
.testimonials-float__bg::before {
  content: "";
  position: absolute;
  top: -180px;
  left: -120px;
  width: 640px;
  height: 640px;
  background: radial-gradient(circle, var(--accent-soft) 0%, transparent 65%);
  opacity: 0.7;
  transform: translate3d(0, calc((var(--scroll-y) - 0.5) * -120px), 0);
  will-change: transform;
}
/* Mint blob bottom-right — drifts down */
.testimonials-float__bg::after {
  content: "";
  position: absolute;
  bottom: -200px;
  right: -160px;
  width: 720px;
  height: 720px;
  background: radial-gradient(circle, #DCFCE7 0%, transparent 65%);
  opacity: 0.55;
  transform: translate3d(0, calc((var(--scroll-y) - 0.5) * 100px), 0);
  will-change: transform;
}
/* Wave drifts up (parallax depth) + path-draw animation on first reveal.
   overflow: visible so paths can extend beyond viewBox to the screen edges. */
.testimonials-float__wave {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.85;
  overflow: visible;
  transform: translate3d(calc((var(--scroll-y) - 0.5) * 24px), calc((var(--scroll-y) - 0.5) * -180px), 0);
  will-change: transform;
}
/* Path-draw: JS sets dasharray + negative initial dashoffset → both paths draw top→bottom.
   7500ms duration so the drawing is clearly perceptible. */
.testimonials-float__wave path {
  transition: stroke-dashoffset 7500ms cubic-bezier(0.22, 1, 0.36, 1);
}
.testimonials-float.is-revealed .testimonials-float__wave path {
  stroke-dashoffset: 0 !important;
}
@media (prefers-reduced-motion: reduce) {
  .testimonials-float__wave,
  .testimonials-float__bg::before,
  .testimonials-float__bg::after {
    transform: none !important;
  }
}
.testimonials-float__head {
  text-align: center;
  margin-bottom: clamp(48px, 6vw, 80px);
}
.testimonials-float__head .kicker { margin-bottom: 14px; }
.testimonials-float__head .h2 em {
  font-family: inherit;
  font-weight: 400;
  font-style: italic;
  color: var(--accent);
}

.testimonials-float__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 1120px;
  margin: 0 auto;
  perspective: 1200px;
}
@media (min-width: 760px) {
  .testimonials-float__grid { grid-template-columns: repeat(3, 1fr); gap: 28px; }
}

.testimonials-float__card {
  position: relative;
  padding: 26px 26px 22px;
  background: #fff;
  border: 1px solid rgba(15, 17, 21, 0.06);
  border-radius: 22px;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.8) inset,
    0 32px 64px -28px rgba(15, 17, 21, 0.18),
    0 12px 24px -12px rgba(15, 17, 21, 0.05);
  display: flex;
  flex-direction: column;
  gap: 18px;
  isolation: isolate;
  overflow: hidden;
  transition: box-shadow var(--t-med) var(--ease), transform var(--t-med) var(--ease);
}
.testimonials-float__card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.8) inset,
    0 44px 88px -28px rgba(15, 17, 21, 0.22),
    0 16px 30px -14px rgba(79, 70, 229, 0.18);
}

/* Apple-style entry — bigger movement, scale, longer duration, generous stagger */
.testimonials-float__card.reveal {
  opacity: 0;
  transform: translateY(60px) scale(0.94);
  transition:
    opacity 900ms cubic-bezier(0.16, 1, 0.3, 1),
    transform 900ms cubic-bezier(0.16, 1, 0.3, 1);
  transition-delay: calc(var(--i, 0) * 180ms);
}
.testimonials-float__card.reveal.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  animation: card-gentle-bob 7s ease-in-out infinite;
  animation-delay: calc(1100ms + var(--i, 0) * 180ms);
}
/* Slightly different durations per card so phases drift apart over time = organic */
.testimonials-float__card:nth-child(2).reveal.is-visible { animation-duration: 8.2s; }
.testimonials-float__card:nth-child(3).reveal.is-visible { animation-duration: 6.4s; }

@keyframes card-gentle-bob {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50%      { transform: translate3d(0, -4px, 0) scale(1); }
}

.testimonials-float__card.reveal.is-visible:hover {
  transform: translateY(-4px) scale(1);
  animation-play-state: paused;
}
@media (prefers-reduced-motion: reduce) {
  .testimonials-float__card.reveal.is-visible { animation: none; }
}

/* Top accent rim (very subtle) */
.testimonials-float__card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(79, 70, 229, 0.4) 50%, transparent 100%);
  pointer-events: none;
}

/* Header — avatar + name + role at TOP */
.testimonials-float__meta {
  display: flex;
  align-items: center;
  gap: 12px;
}
.testimonials-float__avatar {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  object-fit: cover;
  background: #fff;
  border: 1px solid var(--border);
  flex-shrink: 0;
}
.testimonials-float__avatar--mono {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #fff;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  border-color: transparent;
}
.testimonials-float__id { min-width: 0; }
.testimonials-float__name {
  margin: 0;
  font-size: 14.5px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text-strong);
  line-height: 1.2;
}
.testimonials-float__role {
  margin: 3px 0 0;
  font-size: 12px;
  color: var(--text-3);
  font-weight: 500;
  line-height: 1.4;
}

/* Quote */
.testimonials-float__quote {
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  color: var(--text);
  letter-spacing: -0.005em;
  text-wrap: pretty;
  flex: 1;
}

/* Quote mark at bottom as soft accent */
.testimonials-float__mark {
  width: 28px;
  height: 28px;
  color: var(--accent);
  opacity: 0.18;
  align-self: flex-end;
  display: block;
}

/* Old single-editorial testimonial — kept as fallback if section is re-used */
.testimonial-solo {
  padding: clamp(48px, 6vw, 80px) var(--gutter);
}
.testimonial-solo__panel {
  position: relative;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--accent-soft) 0%, var(--surface) 58%, #fff 100%);
  padding: clamp(56px, 7vw, 104px) clamp(24px, 4vw, 56px);
  overflow: hidden;
  isolation: isolate;
}
.testimonial-solo__bg-mark {
  position: absolute;
  top: clamp(12px, 2.5vw, 28px);
  left: clamp(16px, 3vw, 40px);
  width: clamp(160px, 22vw, 280px);
  height: auto;
  color: var(--accent);
  opacity: 0.12;
  z-index: 0;
  pointer-events: none;
}
.testimonial-solo__inner {
  position: relative;
  z-index: 1;
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(20px, 2.4vw, 28px);
}
.testimonial-solo__quote {
  margin: 0;
  font-family: inherit;
  font-weight: 500;
  font-size: clamp(1.3rem, 2.4vw, 1.95rem);
  line-height: 1.35;
  letter-spacing: -0.018em;
  color: var(--text-strong);
  text-wrap: balance;
}
.testimonial-solo__highlight {
  background-image: linear-gradient(180deg, transparent 62%, var(--accent-soft) 62%, var(--accent-soft) 94%, transparent 94%);
  padding: 0 4px;
  border-radius: 2px;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
.testimonial-solo__outcomes {
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
.testimonial-solo__outcomes li {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--border);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-2);
  letter-spacing: -0.005em;
}
.testimonial-solo__outcomes li::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--accent);
  flex-shrink: 0;
}
.testimonial-solo__attribution {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  margin-top: clamp(8px, 1.2vw, 16px);
  padding: 14px 22px 14px 18px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 999px;
  box-shadow: 0 8px 24px -16px rgba(15,17,21,.18);
}
.testimonial-solo__brand {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  object-fit: cover;
  background: #fff;
  flex-shrink: 0;
}
.testimonial-solo__meta { text-align: left; line-height: 1.3; }
.testimonial-solo__name {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-strong);
  letter-spacing: -0.005em;
}
.testimonial-solo__role {
  margin: 2px 0 0;
  font-size: 12.5px;
  color: var(--text-3);
  font-weight: 500;
}

.testimonials__head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-bottom: clamp(40px, 5vw, 56px);
  align-items: end;
}
@media (min-width: 720px) {
  .testimonials__head {
    grid-template-columns: 1fr auto;
    gap: 32px;
    align-items: center;
  }
}
.testimonials__head-text { display: flex; flex-direction: column; gap: 12px; }
.testimonials__sub {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--text-2);
  max-width: 38ch;
}
.testimonials__nav { display: inline-flex; gap: 10px; justify-self: end; }
.circle-btn {
  width: 44px; height: 44px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--border);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  cursor: pointer;
}
.circle-btn:hover { transform: translateY(-1px); border-color: var(--border-2); }
.circle-btn--filled {
  background: var(--text-strong);
  border-color: var(--text-strong);
  color: #fff;
}
.circle-btn--filled:hover { background: #1a1a1a; border-color: #1a1a1a; }

.testimonials__rail {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
@media (min-width: 720px)  { .testimonials__rail { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .testimonials__rail { grid-template-columns: repeat(4, 1fr); } }

.quote {
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  gap: 0;
  border-bottom: 1px solid var(--border);
}
.quote:last-child { border-bottom: 0; }
@media (min-width: 720px) {
  .quote {
    border-right: 1px solid var(--border);
    border-bottom: 0;
  }
  .quote:nth-child(2n) { border-right: 0; }
}
@media (min-width: 1080px) {
  .quote { border-right: 1px solid var(--border); }
  .quote:nth-child(2n) { border-right: 1px solid var(--border); }
  .quote:nth-child(4n) { border-right: 0; }
}

.quote__brand {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
}
.quote__brand svg { color: var(--text-strong); flex-shrink: 0; }
.quote__brand img {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  object-fit: cover;
  flex-shrink: 0;
  background: #fff;
}

.quote__name {
  margin: 24px 0 0;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.015em;
}
.quote__body {
  margin: 8px 0 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-2);
}
.quote__author {
  margin: 14px 0 0;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-3);
  letter-spacing: 0;
}

/* ============================================================
   (legacy) Quote pair
   ============================================================ */
.quotes__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: start;
  max-width: 980px;
  margin: 0 auto;
}
@media (min-width: 880px) {
  .quotes__inner { grid-template-columns: 1fr 1fr; gap: 56px; }
}
.quote-mark {
  position: absolute;
  font-family: inherit;
  font-size: 80px;
  color: var(--accent);
  line-height: 0.5;
  display: none;
  top: 20px; left: 50%; transform: translateX(-50%);
}
@media (min-width: 880px) { .quote-mark { display: block; } }

.quote-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 28px 28px 24px;
  background: #fff;
  display: flex; flex-direction: column;
  gap: 18px;
  box-shadow: 0 1px 0 rgba(0,0,0,.02);
}
.quote-card--right { background: var(--surface); }
.quote-card__body {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--text);
}
.quote-card__person {
  display: flex; align-items: center; gap: 12px;
  border-top: 1px solid var(--border);
  padding-top: 16px;
}
.quote-card__person .avatar {
  width: 36px; height: 36px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), #A78BFA);
  flex-shrink: 0;
}
.quote-card__person .avatar--alt {
  background: linear-gradient(135deg, #ffd0b0, #b87340);
}
.quote-card__name { margin: 0; font-size: 14px; font-weight: 600; }
.quote-card__role { margin: 2px 0 0; font-size: 12.5px; color: var(--text-3); }

/* ============================================================
   Selected Work, dark panel
   ============================================================ */
.works {
  padding: clamp(48px, 6vw, 80px) var(--gutter);
}
.works__panel {
  position: relative;
  border-radius: var(--radius-lg);
  background: #0a0a0a;
  color: #fafafa;
  padding: clamp(56px, 8vw, 120px) clamp(28px, 4vw, 64px);
  overflow: hidden;
}
.works__panel::before {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 28px 28px;
  -webkit-mask-image: radial-gradient(80% 60% at 50% 0%, #000, transparent 80%);
          mask-image: radial-gradient(80% 60% at 50% 0%, #000, transparent 80%);
  opacity: .8;
}

.works__head {
  position: relative;
  z-index: 1;
  text-align: center;
  margin-bottom: clamp(48px, 6vw, 72px);
}
.works__head .h2 { color: #fafafa; max-width: 18ch; margin: 0 auto; }
.works__head .h2 em { color: rgba(255,255,255,.55); }
.works__sub {
  margin: 18px auto 0;
  max-width: 50ch;
  font-size: 14.5px;
  line-height: 1.55;
  color: rgba(255,255,255,.65);
}
.kicker--invert { color: rgba(255,255,255,.55); }

.works__grid {
  list-style: none; margin: 0 auto; padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  position: relative;
  z-index: 1;
  max-width: 1180px;
}
@media (min-width: 720px)  { .works__grid { grid-template-columns: repeat(2, 1fr); gap: 16px; } }
@media (min-width: 1080px) { .works__grid { grid-template-columns: repeat(3, 1fr); gap: 18px; } }

.work { display: flex; flex-direction: column; gap: 10px; }
.work__media {
  display: block;
  aspect-ratio: 4 / 3;
  border-radius: 16px;
  overflow: hidden;
  background: transparent;
  border: 0;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.45s ease;
}
.work__media svg,
.work__media img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1); }
.work__media:hover { transform: translateY(-2px); box-shadow: 0 16px 36px -18px rgba(0,0,0,.5); }
.work__media:hover svg,
.work__media:hover img { transform: scale(1.015); }

/* Mobile card variant, phone screenshot floating on aurora gradient */
.work__media--mobile {
  background:
    radial-gradient(ellipse 60% 70% at 30% 30%, rgba(244,114,182,.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 70% at 70% 70%, rgba(99,102,241,.24) 0%, transparent 60%),
    linear-gradient(135deg, #0A0A0F 0%, #1a1530 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 0;
}
.work__media--mobile img {
  width: auto;
  height: 96%;
  max-width: 50%;
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 18px 36px -14px rgba(0,0,0,.55);
}

/* Gallery item, mobile aurora panel (legacy) */
.case-gallery__item--mobile {
  background:
    radial-gradient(ellipse 60% 70% at 30% 30%, rgba(244,114,182,.16) 0%, transparent 60%),
    radial-gradient(ellipse 60% 70% at 70% 70%, rgba(99,102,241,.22) 0%, transparent 60%),
    linear-gradient(135deg, #0A0A0F 0%, #16142B 100%);
  padding: 28px 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.case-gallery__item--mobile img {
  width: auto;
  height: auto;
  max-height: 600px;
  max-width: 60%;
  border-radius: 24px;
  box-shadow: 0 24px 50px -18px rgba(0,0,0,.55);
}

/* Phone variant, realistic iPhone frame on dark studio stage */
.case-phones-stage {
  background:
    radial-gradient(ellipse 60% 70% at 25% 30%, rgba(244,114,182,.10) 0%, transparent 60%),
    radial-gradient(ellipse 60% 70% at 75% 65%, rgba(99,102,241,.16) 0%, transparent 60%),
    linear-gradient(135deg, #0A0A0F 0%, #14122A 100%);
  border-radius: var(--radius-lg);
  padding: clamp(20px, 3vw, 36px) clamp(12px, 2vw, 24px);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(12px, 1.6vw, 24px);
  max-width: 100%;
}
.case-phones-stage .case-gallery__item--phone {
  flex: 1 1 0;
  max-width: 240px;
  background: transparent;
  border: 0;
  box-shadow: none;
  border-radius: 0;
  overflow: visible;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.case-phones-stage .case-gallery__item--phone img {
  width: 100%;
  height: auto;
  border-radius: 32px;
  display: block;
  image-rendering: -webkit-optimize-contrast;
  box-shadow:
    0 0 0 3px #0a0a0a,
    0 0 0 4px rgba(255,255,255,.06),
    0 28px 56px -24px rgba(0,0,0,.55),
    0 12px 24px -12px rgba(0,0,0,.35);
}
@media (max-width: 600px) {
  .case-phones-stage { gap: 8px; padding: 16px 8px; }
  .case-phones-stage .case-gallery__item--phone { max-width: 140px; }
  .case-phones-stage .case-gallery__item--phone img { border-radius: 22px; }
}

.work__caption {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 2px;
  gap: 10px;
}
.work__title {
  margin: 0;
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: #fafafa;
}
.work__tags { display: inline-flex; gap: 6px; }
.tag {
  display: inline-flex; align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.7);
  border: 1px solid rgba(255,255,255,.10);
  font-weight: 500;
}

/* ============================================================
   About / Pushing Boundaries
   ============================================================ */
.about__grid {
  margin-top: 64px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: start;
}
@media (min-width: 880px) {
  .about__grid { grid-template-columns: 1fr 1.1fr; gap: 56px; }
}
.about__photo {
  width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--surface-2);
}
.about__photo-svg { width: 100%; height: 100%; }
.about__photo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.about__lede {
  margin: 0 0 28px;
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--text-2);
}
.experience {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  margin-top: 8px;
}
.experience thead th {
  font-weight: 600;
  text-align: left;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-3);
  padding: 0 0 12px;
  border-bottom: 1px solid var(--border);
}
.experience tbody td {
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.experience tbody tr:last-child td { border-bottom: 0; }
.experience tbody td:first-child { font-weight: 600; color: var(--text); }
.experience tbody td:nth-child(2) { color: var(--text-2); }
.experience tbody td:last-child { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 12px; color: var(--text-2); text-align: right; white-space: nowrap; }

.about__signoff {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 6px;
  align-items: flex-start;
}
.about__name {
  margin: 0;
  font-family: inherit;
  font-size: clamp(1.5rem, 3vw, 2rem);
  letter-spacing: -0.01em;
}
.about__role { margin: 0; font-size: 13px; color: var(--text-3); }
.about__socials { display: inline-flex; gap: 10px; margin-top: 8px; }
.about__socials a {
  width: 36px; height: 36px;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--border);
  color: var(--text);
  transition: background var(--t-fast) var(--ease);
}
.about__socials a:hover { background: var(--surface); }

/* ============================================================
   CTA strip
   ============================================================ */
.cta {
  padding: clamp(40px, 6vw, 80px) var(--gutter) 0;
}
.cta__panel {
  position: relative;
  border-radius: var(--radius-lg);
  padding: clamp(40px, 5vw, 80px) clamp(24px, 4vw, 56px);
  overflow: hidden;
  isolation: isolate;
}
.cta__bg {
  position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(120% 100% at 50% 100%, var(--accent-soft) 0%, var(--accent-wash) 60%, #fff 100%);
}
.cta__bg::after {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(0,0,0,.05) 1px, transparent 1px);
  background-size: 22px 22px;
  -webkit-mask-image: radial-gradient(60% 80% at 50% 50%, #000, transparent);
          mask-image: radial-gradient(60% 80% at 50% 50%, #000, transparent);
  opacity: .55;
}
.cta__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(28px, 3vw, 48px);
  align-items: start;
  max-width: 1200px;
  margin: 0 auto;
}
@media (min-width: 980px) {
  .cta__grid { grid-template-columns: 1fr 1.05fr; gap: clamp(40px, 4vw, 64px); }
}
.cta__intro { display: flex; flex-direction: column; gap: 18px; }
.cta__title {
  margin: 0;
  font-size: clamp(2.2rem, 4.6vw, 3.4rem);
  font-weight: 600;
  letter-spacing: -0.035em;
  line-height: 1.05;
  color: var(--text-strong);
  text-wrap: balance;
}
.cta__title em {
  font-family: 'Instrument Serif', 'Iowan Old Style', Georgia, serif;
  font-style: italic;
  font-weight: 400;
}
.cta__sub {
  margin: 0;
  max-width: 50ch;
  font-size: 15px;
  line-height: 1.55;
  color: var(--text);
  font-weight: 500;
}
.cta__channels {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cta__channels li {
  display: grid;
  grid-template-columns: 36px 100px 1fr;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(15,17,21,.06);
  border-radius: 14px;
  backdrop-filter: blur(6px);
}
.cta__channel-icon {
  width: 36px; height: 36px;
  background: transparent;
  color: var(--accent);
  display: inline-flex; align-items: center; justify-content: center;
}
.cta__channel-icon svg { width: 24px; height: 24px; }
.cta__channel-label {
  font-size: 11.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-3);
}
.cta__channel-link {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
  word-break: break-word;
}
a.cta__channel-link:hover { color: var(--accent); }

/* ============================================================
   Booking card (on-page CTA + modal trigger)
   ============================================================ */
.booking-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 22px;
  padding: clamp(24px, 3.2vw, 36px);
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  box-shadow: 0 30px 60px -30px rgba(15, 17, 21, 0.18);
  overflow: hidden;
  isolation: isolate;
}
.booking-card::before {
  content: "";
  position: absolute;
  top: -55%;
  right: -25%;
  width: 460px;
  height: 460px;
  background: radial-gradient(closest-side, var(--accent-soft) 0%, transparent 70%);
  opacity: 0.7;
  pointer-events: none;
  z-index: 0;
}
.booking-card::after {
  content: "";
  position: absolute;
  bottom: -40%;
  left: -20%;
  width: 360px;
  height: 360px;
  background: radial-gradient(closest-side, #E6F0FF 0%, transparent 70%);
  opacity: 0.5;
  pointer-events: none;
  z-index: 0;
}
.booking-card > * { position: relative; z-index: 1; }

/* Profile header — avatar, name/role, live indicator */
.booking-card__profile {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.booking-card__avatar {
  width: 52px;
  height: 52px;
  border-radius: 999px;
  overflow: hidden;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--accent-soft) 0%, #DCFCE7 100%);
  border: 1px solid var(--border);
  display: block;
  position: relative;
}
.booking-card__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 5%;
  display: block;
}
.booking-card__id { min-width: 0; }
.booking-card__name {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--text-strong);
  letter-spacing: -0.01em;
}
.booking-card__role {
  margin: 3px 0 0;
  font-size: 12.5px;
  line-height: 1.35;
  color: var(--text-3);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.booking-card__live {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 11px 5px 10px;
  border-radius: 999px;
  background: rgba(27, 180, 84, 0.08);
  color: #0F7A33;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.booking-card__dot {
  width: 7px; height: 7px;
  border-radius: 999px;
  background: #1bb454;
  box-shadow: 0 0 0 3px rgba(27, 180, 84, 0.18);
  animation: booking-dot-pulse 2.4s ease-in-out infinite;
}
@keyframes booking-dot-pulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(27, 180, 84, 0.18); }
  50%      { box-shadow: 0 0 0 6px rgba(27, 180, 84, 0.04); }
}
@media (prefers-reduced-motion: reduce) {
  .booking-card__dot { animation: none; }
}

/* Body — title, subtitle, meta chips */
.booking-card__body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.booking-card__title {
  margin: 0;
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: -0.025em;
  color: var(--text-strong);
}
.booking-card__sub {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--text-2);
  max-width: 52ch;
}
.booking-card__meta {
  list-style: none;
  margin: 4px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.booking-card__meta li {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--border);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-2);
  letter-spacing: -0.005em;
}
.booking-card__meta svg { color: var(--accent); flex-shrink: 0; }

/* CTA — large indigo button */
.booking-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 2px;
  padding: 18px 26px;
  background: var(--accent);
  color: #fff;
  border-radius: 14px;
  font-size: 15.5px;
  font-weight: 600;
  letter-spacing: -0.01em;
  cursor: pointer;
  border: 0;
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  box-shadow: 0 14px 30px -14px rgba(79, 70, 229, 0.55), inset 0 1px 0 rgba(255,255,255,0.18);
}
.booking-card__cta:hover {
  background: var(--accent-2);
  transform: translateY(-1px);
  box-shadow: 0 18px 36px -12px rgba(79, 70, 229, 0.6), inset 0 1px 0 rgba(255,255,255,0.22);
}
.booking-card__cta:active { transform: translateY(0); }
.booking-card__cta svg { transition: transform var(--t-fast) var(--ease); }
.booking-card__cta:hover svg { transform: translateX(3px); }

.booking-card__note {
  margin: 0;
  font-size: 12.5px;
  color: var(--text-3);
  text-align: center;
}
.booking-card__note a { color: var(--accent); font-weight: 600; }
.booking-card__note a:hover { text-decoration: underline; }

/* ============================================================
   Booking modal (native <dialog>) — branded
   ============================================================ */
.booking-modal {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  max-width: none;
  max-height: none;
  padding: 0;
  margin: 0;
  border: 0;
  background: transparent;
  color: inherit;
  overflow: hidden;
}
.booking-modal::backdrop {
  background: rgba(15, 17, 21, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.booking-modal[open] {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(12px, 3vw, 32px);
}
.booking-modal__inner {
  width: min(720px, 100%);
  max-height: min(960px, calc(100vh - 24px));
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  box-shadow: 0 40px 80px -20px rgba(15, 17, 21, 0.4);
  overflow: hidden;
  animation: booking-modal-in 320ms var(--ease);
}
@keyframes booking-modal-in {
  from { opacity: 0; transform: translateY(12px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0)    scale(1);    }
}
@media (prefers-reduced-motion: reduce) {
  .booking-modal__inner { animation: none; }
}

.booking-modal__head {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--accent-soft) 0%, #fff 100%);
  flex-shrink: 0;
  overflow: hidden;
}
.booking-modal__head::after {
  content: "";
  position: absolute;
  top: -80%;
  right: -10%;
  width: 240px;
  height: 240px;
  background: radial-gradient(closest-side, rgba(79, 70, 229, 0.16) 0%, transparent 70%);
  pointer-events: none;
}
.booking-modal__profile {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  position: relative;
  z-index: 1;
}
.booking-modal__avatar {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  overflow: hidden;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--accent-soft) 0%, #DCFCE7 100%);
  border: 1px solid #fff;
  box-shadow: 0 4px 12px -4px rgba(15, 17, 21, 0.18);
  display: block;
}
.booking-modal__avatar img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 50% 5%;
  display: block;
}
.booking-modal__id { min-width: 0; }
.booking-modal__title {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text-strong);
  line-height: 1.2;
}
.booking-modal__sub {
  margin: 2px 0 0;
  font-size: 12.5px;
  color: var(--text-2);
  font-weight: 500;
  line-height: 1.3;
}
.booking-modal__close {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--border);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.booking-modal__close:hover {
  background: var(--text-strong);
  color: #fff;
  border-color: var(--text-strong);
}
.booking-modal__frame {
  flex: 1;
  min-height: 0;
  background: var(--surface);
  overflow: hidden;
}
.booking-modal__frame iframe {
  width: 100%;
  height: 100%;
  min-height: 800px;
  border: 0;
  display: block;
  background: #fff;
}
body.is-modal-open { overflow: hidden; }

/* ============================================================
   Legal pages (Impressum, Datenschutz) — editorial long-form
   ============================================================ */
.legal-body {
  background: linear-gradient(180deg, var(--accent-wash) 0%, #fff 320px);
}
.legal {
  padding: clamp(110px, 14vw, 160px) 0 clamp(80px, 10vw, 120px);
}
.legal__inner {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.legal__back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-2);
  margin-bottom: 32px;
  transition: color var(--t-fast) var(--ease);
}
.legal__back:hover { color: var(--accent); }
.legal__back svg { transition: transform var(--t-fast) var(--ease); }
.legal__back:hover svg { transform: translateX(-2px); }

.legal__head {
  margin-bottom: clamp(40px, 5vw, 64px);
  padding-bottom: clamp(24px, 3vw, 40px);
  border-bottom: 1px solid var(--border);
}
.legal__head .kicker { margin: 0 0 12px; }
.legal__title {
  margin: 0;
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--text-strong);
}
.legal__sub {
  margin: 14px 0 0;
  font-size: 15.5px;
  color: var(--text-2);
  line-height: 1.5;
  max-width: 52ch;
}

.legal section {
  margin-bottom: clamp(32px, 4vw, 48px);
}
.legal h2 {
  margin: 0 0 14px;
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--text-strong);
  line-height: 1.25;
}
.legal p {
  margin: 0 0 14px;
  font-size: 15px;
  line-height: 1.7;
  color: var(--text);
}
.legal p:last-child { margin-bottom: 0; }
.legal a {
  color: var(--accent);
  font-weight: 500;
  border-bottom: 1px solid rgba(79, 70, 229, 0.25);
  transition: border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.legal a:hover {
  color: var(--accent-2);
  border-bottom-color: var(--accent);
}
.legal ul {
  margin: 8px 0 14px;
  padding: 0 0 0 20px;
  font-size: 15px;
  line-height: 1.7;
  color: var(--text);
}
.legal ul li { margin-bottom: 4px; }
.legal code {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 13px;
  padding: 2px 6px;
  background: var(--surface);
  border-radius: 4px;
  color: var(--text-strong);
}
.legal strong { font-weight: 600; color: var(--text-strong); }
.legal__updated {
  margin-top: clamp(32px, 4vw, 48px);
  padding-top: clamp(24px, 3vw, 32px);
  border-top: 1px solid var(--border);
  font-size: 13px;
  color: var(--text-3);
  font-style: italic;
}

/* Mobile tweaks */
@media (max-width: 560px) {
  .booking-card__profile { grid-template-columns: auto 1fr; row-gap: 8px; }
  .booking-card__live { grid-column: 1 / -1; justify-self: start; }
  .booking-card__role { white-space: normal; }
}

/* ============================================================
   Footer (multi-column + technical signature)
   ============================================================ */
.footer {
  padding: clamp(56px, 8vw, 96px) 0 32px;
  border-top: 1px solid var(--border);
  margin-top: clamp(56px, 8vw, 100px);
  background: var(--bg);
}
.footer__inner { display: flex; flex-direction: column; gap: 48px; }

.footer__cols {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px 24px;
}
@media (min-width: 720px)  { .footer__cols { grid-template-columns: repeat(4, 1fr); } }

.footer__col {
  display: flex; flex-direction: column; gap: 8px;
}
.footer__h {
  font-size: 12px;
  font-weight: 600;
  margin: 0 0 8px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-3);
}
.footer__col a, .footer__col span {
  font-size: 13.5px;
  color: var(--text-2);
  transition: color var(--t-fast) var(--ease);
}
.footer__col a:hover { color: var(--text); }

.footer__signature {
  display: flex; flex-direction: column; gap: 16px;
  padding-top: 32px;
  border-top: 1px solid var(--border);
}
@media (min-width: 720px) {
  .footer__signature { flex-direction: row; justify-content: space-between; align-items: flex-end; }
}
.footer__sig-name {
  margin: 0;
  font-size: clamp(1.25rem, 2.4vw, 1.75rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text);
}
.footer__sig-role {
  margin: 4px 0 0;
  font-size: 13px;
  color: var(--text-2);
}
.footer__sig-meta {
  margin: 0;
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11.5px;
  color: var(--text-3);
  letter-spacing: 0.02em;
}
.dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 999px;
  background: var(--text-3);
}
.dot--live {
  background: #1bb454;
  box-shadow: 0 0 0 4px rgba(27,180,84,.18);
}

.footer__copy {
  margin: 0;
  font-size: 12px;
  color: var(--text-3);
  text-align: center;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}

.footer__mark {
  margin: clamp(32px, 5vw, 56px) 0 clamp(16px, 2vw, 24px);
  text-align: center;
  font-family: inherit;
  font-weight: 400;
  font-size: clamp(2.4rem, 6vw, 4.8rem);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--text);
}
.footer__mark em { font-style: normal; font-weight: 600; color: var(--text-2); }

/* ============================================================
   Reveal-on-scroll
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity var(--t-slow) var(--ease),
    transform var(--t-slow) var(--ease);
  transition-delay: calc(var(--i, 0) * 70ms);
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
  .logos__track { animation: none; }
}

/* ============================================================
   Case Study pages (work/*.html)
   ============================================================ */
.case-study-body { background: var(--bg); }

.case {
  display: block;
}

.case-hero {
  padding: clamp(120px, 14vw, 180px) var(--gutter) clamp(40px, 5vw, 70px);
  background:
    radial-gradient(ellipse 50% 60% at 20% 20%, #E0E7FF 0%, rgba(224,231,255,0) 60%),
    linear-gradient(180deg, #F8F9FE 0%, #ffffff 100%);
  border-bottom: 0;
}
.case-hero .container {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 2.4vw, 32px);
  max-width: 1100px;
}
.case-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 20px;
  font-size: 14.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--text);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 999px;
  width: max-content;
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.case-back svg { color: var(--accent); transition: transform var(--t-fast) var(--ease); }
.case-back:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-wash);
  transform: translateX(-2px);
}
.case-back:hover svg { transform: translateX(-2px); }

.case-title {
  margin: 0;
  font-size: clamp(2.5rem, 6.5vw, 5rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--text);
}
.case-title em {
  font-family: 'Instrument Serif', 'Iowan Old Style', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -0.02em;
}
.case-tagline {
  margin: 0;
  font-size: clamp(17px, 1.5vw, 22px);
  font-weight: 500;
  line-height: 1.45;
  color: var(--text-2);
  max-width: 60ch;
}

.case-meta {
  list-style: none;
  margin: clamp(8px, 1vw, 16px) 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: clamp(16px, 2vw, 28px);
  border-top: 1px solid var(--border);
  padding-top: clamp(20px, 2.4vw, 28px);
}
.case-meta li {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
}
.case-meta__label {
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-3);
}

.case-cover {
  padding: clamp(24px, 4vw, 56px) var(--gutter);
  background: var(--bg);
}
.case-cover .container { max-width: 1100px; }
.case-cover__media {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 0;
  outline: 0;
  background: transparent;
  aspect-ratio: 16 / 9;
  box-shadow: none;
}
.case-cover__media svg,
.case-cover__media img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.case-cover__media--dark { background: #0F1115; }

/* Mobile cover variant, single phone screenshot centered on aurora gradient panel */
.case-cover__media--mobile {
  background:
    radial-gradient(ellipse 50% 60% at 25% 30%, rgba(244,114,182,.16) 0%, transparent 60%),
    radial-gradient(ellipse 55% 65% at 75% 65%, rgba(99,102,241,.22) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 50% 50%, rgba(20,184,166,.10) 0%, transparent 70%),
    linear-gradient(135deg, #0A0A0F 0%, #16142B 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4% 0;
}
.case-cover__media--mobile img {
  width: auto;
  height: 92%;
  max-width: 30%;
  object-fit: contain;
  object-position: center;
  border-radius: 32px;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,.55);
}
@media (max-width: 720px) {
  .case-cover__media--mobile img { max-width: 60%; }
}

.case-body {
  padding: clamp(40px, 6vw, 96px) var(--gutter) clamp(48px, 6vw, 100px);
}
.case-body__grid {
  max-width: 1100px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(40px, 4vw, 64px);
}
@media (min-width: 880px) {
  .case-body__grid { grid-template-columns: minmax(0, 1.7fr) minmax(240px, 1fr); }
}
.case-body__main h2 {
  margin: clamp(28px, 3vw, 40px) 0 14px;
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 700;
  letter-spacing: -0.018em;
  color: var(--text);
}
.case-body__main h2:first-child { margin-top: 0; }
.case-body__main p {
  margin: 0 0 16px;
  font-size: 16.5px;
  line-height: 1.65;
  color: var(--text-2);
  max-width: 64ch;
}
.case-body__main p strong { color: var(--text); font-weight: 600; }
.case-body__main ul {
  margin: 0 0 18px;
  padding-left: 20px;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-2);
}
.case-body__main ul li { margin-bottom: 6px; }
.case-body__main blockquote {
  margin: 24px 0;
  padding: 16px 20px;
  border-left: 3px solid var(--accent);
  background: var(--accent-wash);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-size: 16px;
  line-height: 1.55;
  color: var(--text);
}

.case-body__side {
  display: flex;
  flex-direction: column;
  gap: 28px;
  position: sticky;
  top: 110px;
  align-self: start;
}
@media (max-width: 879px) {
  .case-body__side { position: static; }
}
.case-body__side h3 {
  margin: 0 0 10px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-3);
}
.case-stats {
  list-style: none;
  margin: 0 0 4px;
  padding: 18px 20px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.case-stats li {
  display: flex;
  flex-direction: column;
  font-size: 12px;
  color: var(--text-3);
  letter-spacing: 0.005em;
}
.case-stats li strong {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
}
.case-tech {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.case-tech li {
  font-size: 12.5px;
  font-weight: 500;
  padding: 6px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  color: var(--text);
}

/* Sidebar text/list variants, for "About the Client" and "Scope of Work" */
.case-side__text {
  margin: 0;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  font-size: 14px;
  line-height: 1.6;
  color: var(--text);
  letter-spacing: -0.005em;
}
.case-side__text strong { font-weight: 700; }
.case-side__muted { color: var(--text-3); font-size: 12.5px; }

.case-side__list {
  list-style: none;
  margin: 0;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.case-side__list li {
  position: relative;
  padding-left: 20px;
  font-size: 13.5px;
  line-height: 1.45;
  color: var(--text);
}
.case-side__list li::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 9px;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--accent);
}

.case-gallery {
  padding: clamp(40px, 5vw, 80px) var(--gutter);
  background: var(--surface);
  border-top: 1px solid var(--border);
}
.case-gallery .container { max-width: 1100px; }
.case-gallery h2 {
  margin: 0 0 clamp(20px, 2.4vw, 32px);
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
}
.case-gallery__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 2vw, 28px);
}
@media (min-width: 720px) {
  .case-gallery__grid { grid-template-columns: repeat(2, 1fr); }
}
.case-gallery__grid > .case-gallery__item:nth-child(odd):last-child {
  grid-column: 1 / -1;
}
.case-gallery__item {
  border-radius: var(--radius);
  overflow: hidden;
  border: 0;
  background: #fff;
  align-self: start;
  box-shadow: 0 14px 32px -22px rgba(15,17,21,.22);
}
.case-gallery__item svg { width: 100%; height: auto; display: block; }
.case-gallery__item img { width: 100%; height: auto; display: block; }

/* All Case Studies grid (replaces single "Next" link) */
.case-all {
  padding: clamp(48px, 6vw, 96px) var(--gutter) clamp(64px, 7vw, 110px);
  background: var(--surface);
  border-top: 1px solid var(--border);
}
.case-all .container { max-width: 1180px; }
.case-all__head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: clamp(24px, 3vw, 40px);
}
.case-all__head h2 {
  margin: 0;
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 800;
  letter-spacing: -0.025em;
  color: var(--text);
}
.case-all__head h2 em {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-weight: 400;
}
.case-all__back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 999px;
  transition: all var(--t-fast) var(--ease);
}
.case-all__back svg { color: var(--accent); }
.case-all__back:hover {
  border-color: var(--accent);
  background: var(--accent-wash);
  color: var(--accent);
}
.case-all__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(14px, 1.6vw, 22px);
}
.case-mini {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 14px;
  border-radius: var(--radius);
  background: #fff;
  border: 1px solid var(--border);
  transition: transform var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.case-mini:hover {
  transform: translateY(-3px);
  border-color: var(--accent-soft);
  box-shadow: 0 14px 28px -16px rgba(15,17,21,.18);
}
.case-mini.is-current {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent), 0 14px 28px -16px rgba(79,70,229,.20);
  pointer-events: none;
  cursor: default;
  position: relative;
}
.case-mini.is-current:hover {
  transform: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent), 0 14px 28px -16px rgba(79,70,229,.20);
}
.case-mini__current {
  position: absolute;
  top: 22px;
  right: 22px;
  z-index: 2;
  padding: 4px 10px;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #fff;
  background: var(--accent);
  border-radius: 999px;
}
.case-mini__media {
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: var(--surface-2);
}
.case-mini__media svg { width: 100%; height: 100%; display: block; }
.case-mini__title {
  margin: 0;
  font-size: 16.5px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text);
}
.case-mini__tags {
  margin: 0;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-3);
  letter-spacing: 0.005em;
}

/* Cross-document View Transitions: card → case cover morph */
@view-transition { navigation: auto; }
::view-transition-group(*) {
  animation-duration: 480ms;
  animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
}
::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 320ms;
}
.work__media { view-transition-name: var(--vt-name, none); }
.case-cover__media { view-transition-name: var(--vt-name, none); }

/* ============================================================
   CASE STUDY SYSTEM — World-class agency theme
   All classes prefixed .cs- and scoped under .case-study root.
   Each case study sets its own CSS variables inline via style="".
   ============================================================ */

.case-study {
  font-family: 'Helvetica Neue', 'Inter', Arial, sans-serif;
  background: var(--cs-bg-1, #fafafa);
  color: var(--cs-text, #0a0a0a);
  --cs-max: 1280px;
  --cs-gutter: clamp(24px, 4vw, 56px);
  position: relative;
  overflow-x: hidden;
}
.case-study,
.case-study * { cursor: none; }
@media (hover: none) {
  .case-study, .case-study * { cursor: auto; }
}

/* ─── 1. HERO ─── */
.cs-hero {
  position: relative;
  width: 100vw;
  height: 90vh;
  min-height: 600px;
  overflow: hidden;
  background: var(--cs-bg-hero, var(--cs-bg-1));
  isolation: isolate;
}
.cs-hero__image {
  position: absolute;
  top: -10%; left: 0;
  width: 100%; height: 120%;
  will-change: transform;
}
.cs-hero__image img,
.cs-hero__image .cs-placeholder {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.cs-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,0.35) 100%);
  pointer-events: none;
}
.case-study[data-theme="light"] .cs-hero__overlay {
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.08) 100%);
}
.cs-hero__inner {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(40px, 6vw, 96px);
  z-index: 3;
  pointer-events: none;
}
.cs-hero__inner > * { pointer-events: auto; }
.cs-hero__title {
  font-size: clamp(3rem, 7vw, 6rem);
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 0.98;
  margin: 0;
  color: var(--cs-hero-text, #fff);
  text-wrap: balance;
}
.cs-hero__tagline {
  font-size: clamp(1rem, 2vw, 1.4rem);
  font-weight: 400;
  line-height: 1.45;
  max-width: 58ch;
  margin: 24px 0 0;
  color: var(--cs-hero-text, #fff);
  opacity: 0.75;
}
.cs-hero__back {
  position: absolute;
  top: clamp(80px, 8vw, 110px);
  left: clamp(24px, 4vw, 48px);
  z-index: 3;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; letter-spacing: 0.04em;
  color: var(--cs-hero-text, #fff);
  text-decoration: none;
  opacity: 0.85;
  transition: opacity .25s ease;
}
.cs-hero__back:hover { opacity: 1; }
.cs-hero__scroll-indicator {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: var(--cs-hero-text, #fff);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  opacity: 0.6;
  animation: cs-scroll-pulse 2s ease-in-out infinite;
}
.cs-hero__scroll-indicator::after {
  content: "";
  width: 1px; height: 36px;
  background: currentColor;
  animation: cs-scroll-line 2s ease-in-out infinite;
}
@keyframes cs-scroll-pulse {
  0%, 100% { opacity: 0.4; } 50% { opacity: 0.8; }
}
@keyframes cs-scroll-line {
  0%   { transform: scaleY(0.4); transform-origin: top; }
  50%  { transform: scaleY(1);   transform-origin: top; }
  50.01% { transform-origin: bottom; }
  100% { transform: scaleY(0);   transform-origin: bottom; }
}
.cs-hero__scroll-indicator.is-hidden { opacity: 0; transition: opacity .4s ease; }

/* ─── FLOATING ELEMENTS ─── */
.cs-float {
  position: absolute;
  z-index: 4;
  will-change: transform;
  animation: cs-float-y var(--cs-float-dur, 4s) ease-in-out infinite;
  animation-delay: var(--cs-float-delay, 0s);
}
.cs-float--slow { --cs-float-dur: 6s; }
.cs-float--mid  { --cs-float-dur: 4s; }
.cs-float--fast { --cs-float-dur: 2.8s; }
.cs-float--wide  { --cs-float-y: 18px; --cs-float-rot: 2deg; }
.cs-float--tight { --cs-float-y: 8px;  --cs-float-rot: 1deg; }
@keyframes cs-float-y {
  0%, 100% { transform: translateY(calc(var(--cs-float-y, 12px) *  1)) rotate(calc(var(--cs-float-rot, 1deg) * -1)); }
  50%      { transform: translateY(calc(var(--cs-float-y, 12px) * -1)) rotate(var(--cs-float-rot, 1deg)); }
}

.cs-card {
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 14px;
  padding: 14px 18px;
  color: var(--cs-hero-text, #fff);
  font-size: 13px;
  line-height: 1.4;
  box-shadow: 0 16px 40px -16px rgba(0,0,0,0.4);
}
.case-study[data-theme="light"] .cs-card {
  background: rgba(255,255,255,0.7);
  border-color: rgba(15,17,21,0.08);
  color: var(--cs-text);
}
.cs-card--stat { padding: 18px 22px; }
.cs-card__num { display: block; font-size: 28px; font-weight: 600; letter-spacing: -0.02em; line-height: 1; color: var(--cs-accent); }
.cs-card__lbl { display: block; margin-top: 6px; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; opacity: 0.7; }
.cs-card--tag {
  display: inline-flex; align-items: center;
  padding: 7px 12px;
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--cs-accent);
  color: #fff;
  border-color: transparent;
  font-weight: 600;
}
.cs-card--quote { max-width: 260px; font-style: italic; font-size: 13px; line-height: 1.5; }
.cs-card__author { display: block; margin-top: 10px; font-style: normal; font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; opacity: 0.7; }
.cs-card--swatch { display: flex; align-items: center; gap: 12px; padding: 12px 16px; }
.cs-card--swatch::before { content: ""; width: 24px; height: 24px; border-radius: 6px; background: var(--cs-swatch-color, var(--cs-accent)); flex-shrink: 0; }
.cs-card__hex { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.04em; }

/* ─── 2. INTRO BLOCK ─── */
.cs-intro {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  max-width: var(--cs-max);
  margin: 0 auto;
  padding: clamp(80px, 10vw, 140px) var(--cs-gutter);
}
@media (min-width: 880px) {
  .cs-intro { grid-template-columns: 1.4fr 1fr; gap: 96px; align-items: start; }
}
.cs-intro__desc { font-size: clamp(1.15rem, 1.55vw, 1.5rem); line-height: 1.7; font-weight: 400; margin: 0; letter-spacing: -0.005em; }
.cs-intro__meta { display: flex; flex-direction: column; gap: 32px; }
.cs-meta-block__label { font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cs-text-muted, #888); margin: 0 0 12px; font-weight: 500; }
.cs-meta-block__value { font-size: 15px; margin: 0; }
.cs-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.cs-tag {
  display: inline-block;
  padding: 9px 16px;
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1px dashed var(--cs-tag-border, var(--cs-accent));
  border-radius: 999px;
  color: var(--cs-text);
}
.cs-client-link { display: inline-flex; align-items: center; gap: 8px; color: var(--cs-accent); font-size: 14px; text-decoration: none; transition: gap .25s ease; }
.cs-client-link:hover { gap: 14px; }

/* ─── 3. STATEMENT IMAGE ─── */
.cs-statement {
  width: 100vw;
  height: 56vh;
  min-height: 420px;
  max-height: 720px;
  overflow: hidden;
  position: relative;
}
.cs-statement img,
.cs-statement .cs-placeholder { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ─── 4. NARRATIVE ─── */
.cs-narrative {
  position: relative;
  max-width: var(--cs-max);
  margin: 0 auto;
  padding: clamp(80px, 10vw, 140px) var(--cs-gutter);
}
.cs-narrative__kicker { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cs-text-muted); margin: 0 0 24px; font-weight: 500; opacity: 0.7; }
.cs-narrative__h { font-size: clamp(1.8rem, 3.2vw, 3rem); font-weight: 500; letter-spacing: -0.025em; line-height: 1.08; margin: 0 0 32px; max-width: 22ch; text-wrap: balance; }
.cs-narrative__p { font-size: 1.0625rem; line-height: 1.7; margin: 0 0 1.2em; max-width: 64ch; color: var(--cs-text); }
.cs-narrative__p strong { font-weight: 600; }
.cs-narrative--with-float { display: grid; grid-template-columns: 1fr; gap: 60px; }
@media (min-width: 980px) { .cs-narrative--with-float { grid-template-columns: 1.6fr 1fr; gap: 96px; align-items: center; } }
.cs-narrative__aside { position: relative; min-height: 280px; }

/* ─── 5. TYPOGRAPHY ─── */
.cs-type {
  background: var(--cs-bg-2);
  padding: clamp(100px, 14vw, 200px) var(--cs-gutter);
  text-align: center;
  overflow: hidden;
}
.cs-type__ghost { font-size: clamp(8rem, 22vw, 22rem); font-weight: 200; line-height: 0.9; letter-spacing: -0.06em; color: var(--cs-text); opacity: 0.18; margin: 0; white-space: nowrap; user-select: none; }
.cs-type__meta { max-width: 540px; margin: 40px auto 0; }
.cs-type__name { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--cs-text-muted); margin: 0 0 16px; }
.cs-type__sample { font-size: clamp(1.4rem, 2.6vw, 2.2rem); font-weight: 400; line-height: 1.25; letter-spacing: -0.015em; color: var(--cs-text); margin: 0; }
.cs-type__weights { display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; margin-top: 24px; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cs-text-muted); }

/* ─── 6. COLOR PALETTE ─── */
.cs-palette { background: var(--cs-bg-1); padding: clamp(80px, 10vw, 140px) 0; }
.cs-palette__head { max-width: var(--cs-max); margin: 0 auto clamp(40px, 5vw, 64px); padding: 0 var(--cs-gutter); }
.cs-palette__grid { display: grid; grid-template-columns: repeat(5, 1fr); width: 100%; padding-bottom: 72px; }
@media (max-width: 880px) { .cs-palette__grid { grid-template-columns: repeat(2, 1fr); } }
.cs-swatch {
  position: relative;
  display: block;
  background: var(--swatch);
  height: 220px;
  transition: transform .4s cubic-bezier(0.22,1,0.36,1), opacity .6s ease;
  opacity: 0;
  transform: translateY(20px);
  border: 1px solid color-mix(in srgb, var(--cs-text) 6%, transparent);
}
.cs-swatch.is-visible { opacity: 1; transform: translateY(0); }
.cs-swatch:hover { transform: translateY(-4px); }
.cs-swatch__meta { position: absolute; bottom: -56px; left: 0; padding: 14px 18px; font-family: 'JetBrains Mono', monospace; }
.cs-swatch__name { display: block; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; margin: 0 0 4px; color: var(--cs-text-muted); }
.cs-swatch__hex { display: block; font-size: 13px; color: var(--cs-text); opacity: 0.65; transition: opacity .3s ease; }
.cs-swatch:hover .cs-swatch__hex { opacity: 1; }

/* ─── 7. SPLIT PAIR ─── */
.cs-split-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  width: 100vw;
}
.cs-split-pair > * { aspect-ratio: 1 / 1; overflow: hidden; }
.cs-split-pair > * > img,
.cs-split-pair > * > .cs-placeholder { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 767px) { .cs-split-pair { grid-template-columns: 1fr; } }

/* ─── 8. TECH STACK ─── */
.cs-tech { background: var(--cs-bg-2); padding: clamp(80px, 10vw, 140px) var(--cs-gutter); }
.cs-tech__head { max-width: var(--cs-max); margin: 0 auto clamp(40px, 5vw, 64px); }
.cs-tech__grid { max-width: var(--cs-max); margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 600px) { .cs-tech__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .cs-tech__grid { grid-template-columns: repeat(4, 1fr); } }
.cs-tech__card {
  padding: 24px;
  background: var(--cs-bg-1);
  border: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent);
  border-radius: 14px;
  transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.cs-tech__card:hover {
  transform: translateY(-4px);
  border-color: var(--cs-accent);
  box-shadow: 0 12px 32px -12px color-mix(in srgb, var(--cs-accent) 25%, transparent);
}
.cs-tech__icon {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--cs-accent) 18%, transparent);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--cs-accent);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  margin-bottom: 16px;
}
.cs-tech__name { font-size: 15px; font-weight: 600; margin: 0 0 6px; color: var(--cs-text); }
.cs-tech__desc { font-size: 13px; line-height: 1.5; color: var(--cs-text-muted); margin: 0; }

/* ─── 9. FEATURE ─── */
.cs-feature {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  max-width: var(--cs-max);
  margin: 0 auto;
  padding: clamp(80px, 10vw, 140px) var(--cs-gutter);
  align-items: center;
}
@media (min-width: 880px) {
  .cs-feature { grid-template-columns: 60% 40%; gap: 80px; }
  .cs-feature.is-flipped > :first-child { order: 2; }
}
.cs-feature__media { overflow: hidden; border-radius: 4px; }
.cs-feature__media img, .cs-feature__media .cs-placeholder {
  width: 100%; aspect-ratio: 4 / 3; object-fit: cover; display: block;
  transform: scale(1.05);
  transition: transform 1s cubic-bezier(0.22,1,0.36,1);
}
.cs-feature.is-visible .cs-feature__media img,
.cs-feature.is-visible .cs-feature__media .cs-placeholder { transform: scale(1); }
.cs-feature__h { font-size: clamp(1.5rem, 2.4vw, 2rem); font-weight: 500; letter-spacing: -0.02em; line-height: 1.15; margin: 0 0 20px; }
.cs-feature__p { font-size: 1rem; line-height: 1.7; color: var(--cs-text); margin: 0 0 1.2em; max-width: 50ch; }
.cs-feature__cta { display: inline-flex; align-items: center; gap: 10px; color: var(--cs-accent); font-size: 14px; text-decoration: none; transition: gap .25s ease; }
.cs-feature__cta:hover { gap: 16px; }

/* ─── 10. RESULTS ─── */
.cs-results {
  background: var(--cs-bg-3);
  padding: clamp(100px, 12vw, 180px) var(--cs-gutter);
  color: var(--cs-results-text, #fff);
}
.cs-results__head { max-width: var(--cs-max); margin: 0 auto clamp(40px, 5vw, 72px); text-align: center; }
.cs-results__h { font-size: clamp(1.6rem, 2.6vw, 2.2rem); font-weight: 500; letter-spacing: -0.02em; margin: 0; color: inherit; }
.cs-results__grid { display: grid; grid-template-columns: 1fr; gap: 56px; max-width: var(--cs-max); margin: 0 auto; text-align: center; }
@media (min-width: 760px) { .cs-results__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .cs-results__grid { grid-template-columns: repeat(4, 1fr); } }
.cs-stat-number { display: block; font-size: clamp(3rem, 6vw, 5rem); font-weight: 700; letter-spacing: -0.04em; line-height: 1; color: inherit; font-variant-numeric: tabular-nums; }
.cs-stat-label { display: block; margin-top: 14px; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; opacity: 0.85; }

/* ─── 11. CLOSING IMAGE ─── */
.cs-closing { position: relative; width: 100vw; height: 80vh; min-height: 540px; overflow: hidden; }
.cs-closing__image { position: absolute; top: -10%; left: 0; width: 100%; height: 120%; will-change: transform; }
.cs-closing__image img, .cs-closing__image .cs-placeholder { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ─── 12. NEXT CASE ─── */
.cs-next {
  position: relative;
  display: block;
  width: 100vw;
  height: 70vh;
  min-height: 480px;
  background: var(--cs-next-bg, #f0f0f0);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  isolation: isolate;
}
.cs-next__bg { position: absolute; inset: 0; z-index: 0; clip-path: inset(0 100% 0 0); transition: clip-path .7s cubic-bezier(0.76,0,0.24,1); }
.cs-next:hover .cs-next__bg, .cs-next:focus-visible .cs-next__bg { clip-path: inset(0 0% 0 0); }
.cs-next__bg img, .cs-next__bg .cs-placeholder { width: 100%; height: 100%; object-fit: cover; display: block; }
.cs-next__overlay {
  position: relative; z-index: 1; height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 32px;
  mix-blend-mode: difference;
  color: #fff;
}
.cs-next__kicker { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; margin: 0 0 16px; opacity: 0.8; }
.cs-next__title { font-size: clamp(2.5rem, 6vw, 5rem); font-weight: 500; letter-spacing: -0.03em; margin: 0; text-align: center; }

/* ─── PLACEHOLDER ─── */
.cs-placeholder {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 14px;
  background: color-mix(in srgb, var(--cs-accent) 10%, white);
  border: 2px dashed var(--cs-accent);
  padding: 32px;
  text-align: center;
  min-height: 200px;
  width: 100%; height: 100%;
}
.case-study[data-theme="dark"] .cs-placeholder { background: color-mix(in srgb, var(--cs-accent) 10%, var(--cs-bg-1)); }
.cs-placeholder__tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.2em;
  color: var(--cs-accent);
  padding: 5px 10px;
  border: 1px solid var(--cs-accent);
  border-radius: 4px;
  text-transform: uppercase;
}
.cs-placeholder__desc {
  font-size: 12px; letter-spacing: 0.05em;
  color: var(--cs-accent);
  margin: 0; max-width: 60ch; line-height: 1.4; opacity: 0.85;
}

/* ─── WOW EFFECTS (Apple/clay.global-style) ─── */
/* Word-by-word reveal — splits headings into <span class="cs-word"> via JS */
.cs-word-reveal { display: block; }
.cs-word {
  display: inline-block;
  opacity: 0;
  transform: translateY(0.4em);
  will-change: opacity, transform;
  transition: opacity .85s cubic-bezier(0.22,1,0.36,1), transform .85s cubic-bezier(0.22,1,0.36,1);
}
.cs-word-reveal.is-visible .cs-word { opacity: 1; transform: none; }

/* Apple-style image scale-in: image is over-scaled then settles to 1 on enter */
.cs-scale-img { overflow: hidden; }
.cs-scale-img > img,
.cs-scale-img > .cs-placeholder {
  transform: scale(1.15);
  transition: transform 1.6s cubic-bezier(0.22,1,0.36,1);
}
.cs-scale-img.is-visible > img,
.cs-scale-img.is-visible > .cs-placeholder { transform: scale(1); }

/* Code snippet — used in technical case studies */
.cs-code {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  background: var(--cs-bg-2);
  border: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent);
  padding: 24px 28px;
  border-radius: 12px;
  font-size: 12.5px;
  line-height: 1.7;
  color: var(--cs-text);
  overflow-x: auto;
  white-space: pre;
  margin: 0 0 1.4em;
}
.cs-code__line--accent { color: var(--cs-accent); }
.cs-code__line--muted  { color: var(--cs-text-muted); }

/* Sticky kicker — kicker pins while paragraphs scroll past in tall narratives */
.cs-narrative--sticky-kicker { display: grid; grid-template-columns: 1fr; gap: 32px; }
@media (min-width: 980px) {
  .cs-narrative--sticky-kicker { grid-template-columns: 220px 1fr; gap: 80px; }
  .cs-narrative--sticky-kicker > :first-child {
    position: sticky; top: 120px; align-self: start;
  }
}

/* Tech callout/decisions list */
.cs-decisions { list-style: none; margin: 0; padding: 0; display: grid; gap: 18px; }
.cs-decisions li {
  padding: 20px 24px;
  background: var(--cs-bg-2);
  border-left: 3px solid var(--cs-accent);
  border-radius: 0 10px 10px 0;
}
.cs-decisions__h {
  font-size: 14px; font-weight: 600; letter-spacing: -0.005em; margin: 0 0 6px; color: var(--cs-text);
}
.cs-decisions__p {
  font-size: 13.5px; line-height: 1.6; color: var(--cs-text-muted); margin: 0;
}

/* ─── SCROLL ANIMATION CLASSES ─── */
.cs-fade-up    { opacity: 0; transform: translateY(50px); transition: opacity .85s cubic-bezier(0.22,1,0.36,1), transform .85s cubic-bezier(0.22,1,0.36,1); }
.cs-fade-in    { opacity: 0; transition: opacity .85s ease; }
.cs-reveal-clip{ clip-path: inset(100% 0 0 0); transition: clip-path 1.1s cubic-bezier(0.76,0,0.24,1); }
.cs-slide-left { opacity: 0; transform: translateX(-80px); transition: opacity .85s ease, transform .9s cubic-bezier(0.22,1,0.36,1); }
.cs-slide-right{ opacity: 0; transform: translateX( 80px); transition: opacity .85s ease, transform .9s cubic-bezier(0.22,1,0.36,1); }
.cs-scale-in   { opacity: 0; transform: scale(0.85); transition: opacity .9s ease, transform .9s cubic-bezier(0.22,1,0.36,1); }
.cs-fade-up.is-visible, .cs-fade-in.is-visible, .cs-slide-left.is-visible, .cs-slide-right.is-visible, .cs-scale-in.is-visible { opacity: 1; transform: none; }
.cs-reveal-clip.is-visible { clip-path: inset(0%); }
[data-delay="1"] { transition-delay: 0.08s; }
[data-delay="2"] { transition-delay: 0.16s; }
[data-delay="3"] { transition-delay: 0.24s; }
[data-delay="4"] { transition-delay: 0.32s; }
[data-delay="5"] { transition-delay: 0.40s; }
[data-delay="6"] { transition-delay: 0.48s; }
[data-delay="7"] { transition-delay: 0.56s; }
[data-delay="8"] { transition-delay: 0.64s; }

/* ─── CUSTOM CURSOR ─── */
.cs-cursor {
  position: fixed;
  top: 0; left: 0;
  width: 12px; height: 12px;
  border: 1px solid var(--cs-cursor-color, var(--cs-accent, #fff));
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: difference;
  transform: translate(-50%, -50%);
  transition: width .25s ease, height .25s ease, background .25s ease, border-color .25s ease;
  display: none;
}
.cs-cursor.is-active { display: block; }
.cs-cursor.is-img { width: 60px; height: 60px; background: color-mix(in srgb, var(--cs-cursor-color, var(--cs-accent)) 20%, transparent); }
.cs-cursor.is-link { width: 80px; height: 80px; background: color-mix(in srgb, var(--cs-cursor-color, var(--cs-accent)) 30%, transparent); }
.cs-cursor__label { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: #fff; opacity: 0; transition: opacity .2s ease; }
.cs-cursor.is-link .cs-cursor__label { opacity: 1; }

/* ─── REDUCED MOTION ─── */
@media (prefers-reduced-motion: reduce) {
  .cs-fade-up, .cs-fade-in, .cs-reveal-clip, .cs-slide-left, .cs-slide-right, .cs-scale-in, .cs-feature .cs-feature__media img, .cs-feature .cs-feature__media .cs-placeholder, .cs-swatch, .cs-word, .cs-scale-img > img, .cs-scale-img > .cs-placeholder {
    opacity: 1 !important; transform: none !important; clip-path: none !important; transition: none !important;
  }
  .cs-float, .cs-hero__image, .cs-closing__image, .cs-hero__scroll-indicator, .cs-hero__scroll-indicator::after {
    animation: none !important; transform: none !important;
  }
}

/* ─── SIGNATURE BLOCKS (per-case-study product proof) ─── */

/* Phone stack — for mobile case studies */
.cs-phone-stack {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 2vw, 32px);
  max-width: 1080px;
  margin: 0 auto;
  padding: clamp(80px, 10vw, 140px) var(--cs-gutter);
}
@media (max-width: 767px) { .cs-phone-stack { grid-template-columns: 1fr; max-width: 320px; gap: 24px; } }
.cs-phone {
  position: relative;
  aspect-ratio: 9 / 19.5;
  background: linear-gradient(180deg, #1a1a1a 0%, #0a0a0a 100%);
  border-radius: 36px;
  padding: 8px;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.05), 0 30px 60px -30px rgba(0,0,0,0.6), 0 8px 20px -12px rgba(0,0,0,0.3);
}
.cs-phone__notch {
  position: absolute; top: 14px; left: 50%; transform: translateX(-50%);
  width: 100px; height: 26px;
  background: #0a0a0a; border-radius: 18px; z-index: 2;
}
.cs-phone__screen {
  width: 100%; height: 100%;
  border-radius: 30px;
  overflow: hidden;
  background: var(--cs-bg-2);
}
.cs-phone__screen img, .cs-phone__screen .cs-placeholder { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Browser frame — for web app / marketing site case studies */
.cs-browser {
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(60px, 8vw, 120px) var(--cs-gutter);
}
.cs-browser__chrome {
  background: var(--cs-bg-2);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--cs-text) 6%, transparent), 0 40px 80px -30px rgba(0,0,0,0.4);
}
.cs-browser__bar {
  padding: 14px 18px;
  display: flex; align-items: center; gap: 16px;
  background: color-mix(in srgb, var(--cs-text) 5%, var(--cs-bg-2));
  border-bottom: 1px solid color-mix(in srgb, var(--cs-text) 6%, transparent);
}
.cs-browser__dots { display: flex; gap: 8px; }
.cs-browser__dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--cs-text) 18%, transparent);
}
.cs-browser__url {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--cs-text-muted);
  padding: 6px 14px;
  background: color-mix(in srgb, var(--cs-text) 6%, transparent);
  border-radius: 999px;
  letter-spacing: 0.02em;
}
.cs-browser__screen { background: #fff; aspect-ratio: 16 / 10; overflow: hidden; }
.cs-browser__screen img, .cs-browser__screen .cs-placeholder { width: 100%; height: 100%; object-fit: cover; object-position: top; display: block; }

/* Pipeline stage grid — for process / pipeline case studies */
.cs-stage-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: color-mix(in srgb, var(--cs-text) 10%, transparent);
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
@media (min-width: 600px) { .cs-stage-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .cs-stage-grid { grid-template-columns: repeat(3, 1fr); } }
.cs-stage {
  padding: clamp(28px, 4vw, 44px) clamp(24px, 3vw, 36px);
  background: var(--cs-bg-1);
  transition: background .35s ease;
}
.cs-stage:hover { background: var(--cs-bg-2); }
.cs-stage__num {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  color: var(--cs-accent);
  letter-spacing: 0.22em;
  font-weight: 600;
}
.cs-stage__name {
  display: block;
  font-size: 19px;
  font-weight: 600;
  margin: 14px 0 10px;
  color: var(--cs-text);
  letter-spacing: -0.01em;
}
.cs-stage__desc { font-size: 13.5px; line-height: 1.65; color: var(--cs-text-muted); margin: 0; }

/* Photo gallery — for photography-led case studies */
.cs-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
@media (min-width: 880px) {
  .cs-gallery { grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; }
  .cs-gallery > *:nth-child(1) { grid-row: span 2; }
}
.cs-gallery > * { overflow: hidden; aspect-ratio: 1; position: relative; margin: 0; }
.cs-gallery > * > img, .cs-gallery > * > .cs-placeholder { width: 100%; height: 100%; object-fit: cover; display: block; }
.cs-gallery__label {
  position: absolute;
  bottom: 14px;
  left: 16px;
  padding: 6px 12px;
  background: color-mix(in srgb, var(--cs-bg-1, #000) 75%, transparent);
  color: var(--cs-text, #fff);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-radius: 6px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid color-mix(in srgb, var(--cs-accent, #D97706) 28%, transparent);
}

/* Metric row — for data / ops case studies */
.cs-metric-row {
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid color-mix(in srgb, var(--cs-text) 14%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--cs-text) 14%, transparent);
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
@media (min-width: 760px) { .cs-metric-row { grid-template-columns: repeat(4, 1fr); } }
.cs-metric {
  padding: clamp(28px, 4vw, 48px) clamp(20px, 3vw, 40px);
  border-right: 1px solid color-mix(in srgb, var(--cs-text) 10%, transparent);
}
.cs-metric:last-child { border-right: 0; }
@media (max-width: 759px) {
  .cs-metric { border-right: 0; border-bottom: 1px solid color-mix(in srgb, var(--cs-text) 10%, transparent); }
  .cs-metric:last-child { border-bottom: 0; }
}
.cs-metric__num {
  display: block;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--cs-text);
  font-variant-numeric: tabular-nums;
  font-family: 'JetBrains Mono', monospace;
}
.cs-metric__lbl {
  display: block;
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cs-text-muted);
  margin-top: 10px;
}

/* ─── BRAND-SPECIFIC ANIMATED VISUALS ─── */

.cs-vis {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  overflow: hidden;
  isolation: isolate;
}
.cs-vis--full { aspect-ratio: 16 / 7; min-height: 420px; }
.cs-vis--tall { aspect-ratio: 16 / 9; min-height: 540px; }

/* === AUVIO: Audio waveform bars === */
.cs-vis--waveform {
  background: radial-gradient(ellipse at 50% 50%, #1F0F2E 0%, #0A0A0F 100%);
  display: flex; align-items: center; justify-content: center;
  padding: clamp(40px, 6vw, 80px);
}
.cs-vis__bars {
  display: flex; align-items: center; gap: 6px;
  height: 60%; width: 100%;
  max-width: 1100px;
}
.cs-vis__bar {
  flex: 1;
  border-radius: 4px;
  background: linear-gradient(180deg, #FF6BCB 0%, #8B5CF6 50%, #00D9FF 100%);
  height: 20%;
  animation: cs-vis-bar-pulse 1.4s ease-in-out infinite;
  animation-delay: var(--d, 0s);
  transform-origin: center;
  box-shadow: 0 0 16px -2px rgba(255, 107, 203, 0.4);
}
@keyframes cs-vis-bar-pulse {
  0%, 100% { height: 12%; opacity: 0.65; }
  25%      { height: 78%; opacity: 1; }
  50%      { height: 30%; opacity: 0.8; }
  75%      { height: 92%; opacity: 1; }
}

/* === Insivo App: 4-layer security shield === */
.cs-vis--shield {
  background: radial-gradient(ellipse at 50% 50%, #1A1F36 0%, #0F1115 100%);
  display: flex; align-items: center; justify-content: center;
  padding: 80px;
}
.cs-vis__shield {
  position: relative;
  width: 380px; height: 380px;
}
.cs-vis__shield-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1.5px solid #6366F1;
  opacity: 0.85;
  animation: cs-vis-shield-pulse 3.2s ease-in-out infinite;
}
.cs-vis__shield-ring:nth-child(1) { inset: 0; animation-delay: 0s; }
.cs-vis__shield-ring:nth-child(2) { inset: 12%; opacity: 0.7; animation-delay: -0.4s; }
.cs-vis__shield-ring:nth-child(3) { inset: 26%; opacity: 0.55; animation-delay: -0.8s; }
.cs-vis__shield-ring:nth-child(4) { inset: 40%; opacity: 0.4; animation-delay: -1.2s; }
@keyframes cs-vis-shield-pulse {
  0%, 100% { transform: scale(1); border-color: #6366F1; }
  50%      { transform: scale(1.08); border-color: #A5B4FC; }
}
.cs-vis__shield-core {
  position: absolute;
  inset: 50%;
  width: 36px; height: 36px;
  transform: translate(-50%, -50%);
  background: linear-gradient(135deg, #6366F1, #A5B4FC);
  border-radius: 8px;
  box-shadow: 0 0 32px 4px rgba(99, 102, 241, 0.5);
}
.cs-vis__shield-label {
  position: absolute;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: #A5B4FC;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
}
.cs-vis__shield-label--1 { top: -10px; left: 50%; transform: translateX(-50%); }
.cs-vis__shield-label--2 { top: 14%; left: -2%; transform: translateY(-50%); }
.cs-vis__shield-label--3 { bottom: 14%; right: -2%; transform: translateY(50%); }
.cs-vis__shield-label--4 { bottom: -10px; left: 50%; transform: translateX(-50%); }

/* === CLAYMR: Pipeline with travelling dots === */
.cs-vis--pipeline {
  background: linear-gradient(180deg, #0F0E1A 0%, #1B1A2E 100%);
  padding: clamp(60px, 8vw, 100px) clamp(24px, 4vw, 48px);
}
.cs-vis__pipeline {
  max-width: 1100px;
  margin: 0 auto;
  width: 100%;
  height: auto;
}
.cs-vis__pipeline-node {
  fill: #1B1A2E;
  stroke: #22D3EE;
  stroke-width: 1.5;
  opacity: 0.92;
}
.cs-vis__pipeline-link {
  fill: none;
  stroke: #22D3EE;
  stroke-width: 1.5;
  stroke-dasharray: 4 8;
  opacity: 0.35;
}
.cs-vis__pipeline-dot {
  fill: #22D3EE;
  filter: drop-shadow(0 0 8px #22D3EE);
}
.cs-vis__pipeline-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  fill: #C7D2FE;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

/* === Stash: Live terminal feed === */
.cs-vis--terminal {
  background: #0A0A0A;
  padding: clamp(48px, 6vw, 80px);
  border: 1px solid color-mix(in srgb, #FBBF24 22%, transparent);
  border-radius: 20px;
  max-width: min(1280px, 92vw);
  margin: clamp(40px, 5vw, 72px) auto;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
}
.cs-vis__terminal {
  max-width: 880px;
  margin: 0 auto;
  height: 320px;
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 82%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 82%, transparent 100%);
}
.cs-vis__terminal-head {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #FBBF24;
  margin: 0 auto 24px;
  max-width: 880px;
  text-align: center;
}
.cs-vis__feed {
  position: absolute;
  top: 0; left: 0; right: 0;
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  line-height: 2.1;
  color: #71717A;
  animation: cs-vis-feed-scroll 22s linear infinite;
}
.cs-vis__feed-line { display: grid; grid-template-columns: 90px 110px 1fr 80px; gap: 24px; padding: 0 24px; }
.cs-vis__feed-time { color: #52525B; }
.cs-vis__feed-actor { color: #A1A1AA; }
.cs-vis__feed-action { color: #F4F4F5; }
.cs-vis__feed-line--alert .cs-vis__feed-action { color: #FBBF24; font-weight: 600; }
.cs-vis__feed-line--delete .cs-vis__feed-action { color: #EF4444; font-weight: 600; }
.cs-vis__feed-tag {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #52525B;
  text-align: right;
}
@keyframes cs-vis-feed-scroll {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}

/* === AUVIO: Track queue feed (Stash-style with iridescent palette) === */
.cs-vis--track-feed {
  background: linear-gradient(135deg, #0A0A0F 0%, #15132B 100%);
  padding: clamp(48px, 6vw, 80px);
  border-top: 1px solid color-mix(in srgb, #FF6BCB 24%, transparent);
  border-bottom: 1px solid color-mix(in srgb, #FF6BCB 24%, transparent);
}
.cs-vis--track-feed .cs-vis__terminal-head { color: #FF6BCB; }
.cs-vis--track-feed .cs-vis__feed-line { grid-template-columns: 90px 1fr 100px 90px 80px; gap: 24px; }
.cs-vis--track-feed .cs-vis__feed-time { color: #52525B; }
.cs-vis--track-feed .cs-vis__feed-title { color: #FAFAFA; font-weight: 500; letter-spacing: -0.005em; }
.cs-vis--track-feed .cs-vis__feed-genre { color: #8B8B98; font-size: 11px; }
.cs-vis--track-feed .cs-vis__feed-status { color: #00D9FF; font-size: 11px; letter-spacing: 0.1em; }
.cs-vis--track-feed .cs-vis__feed-status--gen { color: #FF6BCB; }
.cs-vis--track-feed .cs-vis__feed-status--draft { color: #8B8B98; }
.cs-vis--track-feed .cs-vis__feed-tier {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: #8B5CF6; text-align: right;
}
.cs-vis--track-feed .cs-vis__feed-tier--studio { color: #00D9FF; }
.cs-vis--track-feed .cs-vis__feed-tier--free { color: #6b6b80; }

/* === Insivo.ai: Deploy log feed === */
.cs-vis--deploy-log {
  background: #0F1115;
  padding: clamp(48px, 6vw, 80px);
  border-top: 1px solid color-mix(in srgb, #6366F1 28%, transparent);
  border-bottom: 1px solid color-mix(in srgb, #6366F1 28%, transparent);
}
.cs-vis--deploy-log .cs-vis__terminal-head { color: #A5B4FC; }
.cs-vis--deploy-log .cs-vis__feed-line {
  grid-template-columns: 28px 1fr 140px;
  gap: 16px;
  color: #71717A;
}
.cs-vis--deploy-log .cs-vis__feed-check {
  color: #6366F1;
  font-weight: 600;
  text-align: center;
}
.cs-vis--deploy-log .cs-vis__feed-msg { color: #F4F4F5; }
.cs-vis--deploy-log .cs-vis__feed-meta { color: #A5B4FC; font-size: 11px; text-align: right; letter-spacing: 0.06em; }
.cs-vis--deploy-log .cs-vis__feed-line--head .cs-vis__feed-msg { color: #6366F1; }
.cs-vis--deploy-log .cs-vis__feed-line--head .cs-vis__feed-check { color: #6366F1; }

/* === PBA&B: Editorial typographic moment === */
.cs-vis--editorial {
  background: var(--cs-bg-1, #FAF8F3);
  padding: clamp(120px, 18vw, 220px) clamp(24px, 4vw, 64px);
  position: relative;
  isolation: isolate;
}
.cs-vis__editorial-inner {
  max-width: 1200px;
  margin: 0 auto;
}
.cs-vis__editorial-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cs-accent, #D97706);
  margin: 0 0 48px;
  font-weight: 500;
}
.cs-vis__editorial-quote {
  font-family: 'Instrument Serif', 'Iowan Old Style', Georgia, serif;
  font-size: clamp(2.6rem, 9vw, 8.5rem);
  font-weight: 400;
  font-style: italic;
  line-height: 0.96;
  letter-spacing: -0.04em;
  color: var(--cs-text, #1C1917);
  margin: 0;
  text-wrap: balance;
  max-width: 14ch;
}
.cs-vis__editorial-quote em {
  font-style: italic;
  color: var(--cs-accent, #D97706);
  position: relative;
  display: inline-block;
}
.cs-vis__editorial-sub {
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.6;
  color: var(--cs-text-muted, #78716C);
  margin: 40px 0 0;
  max-width: 52ch;
}
.cs-vis__editorial-author {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cs-text-muted, #78716C);
  margin: 32px 0 0;
}
.cs-vis__editorial-floaters {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}
.cs-vis__editorial-floaters > .cs-card {
  position: absolute;
  pointer-events: auto;
}
@media (max-width: 768px) { .cs-vis__editorial-floaters { display: none; } }
/* Decorative giant brand initial behind the quote */
.cs-vis__editorial-mark {
  position: absolute;
  top: 50%;
  right: -4%;
  transform: translateY(-50%);
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: clamp(20rem, 36vw, 42rem);
  line-height: 1;
  color: var(--cs-accent, #D97706);
  opacity: 0.08;
  user-select: none;
  pointer-events: none;
  z-index: 0;
}
.cs-vis__editorial-inner { position: relative; z-index: 1; }
@media (max-width: 760px) {
  .cs-vis__editorial-mark { font-size: 20rem; right: -10%; }
}

/* === AUVIO: Flowing iridescent ribbon (design-driven, not code-feed) === */
.cs-vis--ribbon {
  background: linear-gradient(135deg, #0A0A0F 0%, #15132B 50%, #1F0F2E 100%);
  height: 480px;
  overflow: hidden;
  position: relative;
}
.cs-vis__ribbon-svg {
  position: absolute;
  inset: 0;
  width: 200%;
  height: 100%;
  will-change: transform;
}
.cs-vis__ribbon-svg--1 { animation: cs-ribbon-scroll 14s linear infinite; }
.cs-vis__ribbon-svg--2 { animation: cs-ribbon-scroll 22s linear infinite; opacity: 0.65; }
.cs-vis__ribbon-svg--3 { animation: cs-ribbon-scroll 18s linear infinite reverse; opacity: 0.45; }
@keyframes cs-ribbon-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.cs-vis__ribbon-path { fill: none; stroke-width: 2.5; stroke-linecap: round; }
.cs-vis__ribbon-label {
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  font-family: 'Helvetica Neue', sans-serif;
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: #FAFAFA;
  text-shadow: 0 0 32px rgba(255, 107, 203, 0.4);
  text-align: center;
  padding: 32px;
  pointer-events: none;
}

/* === CLAYMR: Aurora sky cinematic (slow drifting color field) === */
.cs-vis--sky {
  background: #0F0E1A;
  height: 70vh;
  min-height: 480px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.cs-vis__sky-layer {
  position: absolute;
  inset: -20%;
  filter: blur(80px);
  mix-blend-mode: screen;
  animation: cs-sky-drift 24s ease-in-out infinite;
  will-change: transform;
}
.cs-vis__sky-layer--1 {
  background: radial-gradient(ellipse 60% 40% at 30% 40%, #22D3EE 0%, transparent 60%);
}
.cs-vis__sky-layer--2 {
  background: radial-gradient(ellipse 50% 35% at 70% 60%, #818CF8 0%, transparent 60%);
  animation-delay: -8s;
  animation-duration: 30s;
}
.cs-vis__sky-layer--3 {
  background: radial-gradient(ellipse 45% 35% at 50% 30%, #6366F1 0%, transparent 60%);
  animation-delay: -16s;
  animation-duration: 36s;
}
.cs-vis__sky-layer--4 {
  background: radial-gradient(ellipse 35% 30% at 20% 80%, #C7D2FE 0%, transparent 60%);
  animation-delay: -4s;
  animation-duration: 28s;
}
@keyframes cs-sky-drift {
  0%, 100% { transform: translate(0,0) scale(1); }
  33%      { transform: translate(-8%, 6%) scale(1.12); }
  66%      { transform: translate(6%, -4%) scale(0.95); }
}
.cs-vis__sky-label {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
  padding: 48px;
}
.cs-vis__sky-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #22D3EE;
  margin: 0 0 24px;
  opacity: 0.85;
}
.cs-vis__sky-h {
  font-family: 'Helvetica Neue', sans-serif;
  font-size: clamp(2.2rem, 5.5vw, 4.5rem);
  font-weight: 500;
  letter-spacing: -0.035em;
  color: #F4F4F5;
  margin: 0;
  line-height: 1.05;
  text-wrap: balance;
  max-width: 18ch;
  text-shadow: 0 0 60px rgba(34, 211, 238, 0.4);
}

/* === Insivo.ai: Compliance badges with pulsing rings === */
.cs-vis--compliance {
  background: #FAFAFA;
  padding: clamp(100px, 14vw, 180px) clamp(24px, 4vw, 64px);
  text-align: center;
}
.cs-vis__compliance-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  max-width: 1080px;
  margin: 0 auto clamp(48px, 6vw, 80px);
}
@media (min-width: 760px) { .cs-vis__compliance-grid { grid-template-columns: repeat(3, 1fr); } }
.cs-vis__badge {
  position: relative;
  padding: 56px 32px 40px;
  background: #fff;
  border: 1px solid rgba(79, 70, 229, 0.1);
  border-radius: 16px;
  overflow: hidden;
}
.cs-vis__badge-ring {
  position: absolute;
  top: -40px; left: 50%;
  transform: translateX(-50%) scale(0.4);
  width: 160px; height: 160px;
  border-radius: 50%;
  border: 1.5px solid #4F46E5;
  opacity: 0;
  animation: cs-badge-ring 3.6s ease-out infinite;
}
.cs-vis__badge--1 .cs-vis__badge-ring { animation-delay: 0s; }
.cs-vis__badge--2 .cs-vis__badge-ring { animation-delay: 1.2s; }
.cs-vis__badge--3 .cs-vis__badge-ring { animation-delay: 2.4s; }
@keyframes cs-badge-ring {
  0%   { transform: translateX(-50%) scale(0.4); opacity: 0; }
  15%  { opacity: 0.55; }
  100% { transform: translateX(-50%) scale(1.6); opacity: 0; }
}
.cs-vis__badge-icon {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px;
  border-radius: 14px;
  background: linear-gradient(135deg, #EEF2FF 0%, #fff 100%);
  border: 1px solid rgba(79, 70, 229, 0.18);
  color: #4F46E5;
  margin: 0 auto 24px;
  z-index: 1;
}
.cs-vis__badge-icon svg { width: 26px; height: 26px; }
.cs-vis__badge-title {
  display: block;
  font-size: 11.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #4F46E5;
  font-weight: 600;
  margin-bottom: 8px;
}
.cs-vis__badge-meta {
  display: block;
  font-size: 12.5px;
  color: #71717A;
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.02em;
}
.cs-vis__compliance-h {
  font-size: clamp(1.8rem, 3.6vw, 3rem);
  font-weight: 500;
  letter-spacing: -0.025em;
  margin: 0;
  color: #0A0A0A;
  text-wrap: balance;
  max-width: 24ch;
  margin-left: auto; margin-right: auto;
}
.cs-vis__compliance-h em { color: #4F46E5; font-style: normal; }
.cs-vis__compliance-sub {
  margin: 16px auto 0;
  font-size: 14px;
  color: #71717A;
  max-width: 52ch;
  line-height: 1.5;
}

@media (prefers-reduced-motion: reduce) {
  .cs-vis__ribbon-svg, .cs-vis__sky-layer, .cs-vis__badge-ring { animation: none !important; }
}

/* === Scene: product UI embedded in atmospheric backdrop (concrete + palm shadows) === */
.cs-scene {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  aspect-ratio: 16 / 10;
  min-height: 620px;
  overflow: hidden;
  isolation: isolate;
  background: var(--scene-bg, linear-gradient(135deg, #c8b8a0 0%, #a8907a 70%, #6a5a48 100%));
  display: flex; align-items: center; justify-content: center;
  padding: clamp(48px, 6vw, 96px);
}
/* Concrete texture overlay (radial vignettes for depth + uneven lighting) */
.cs-scene::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 25% 20%, rgba(255,255,255,0.14), transparent 45%),
    radial-gradient(ellipse at 75% 80%, rgba(0,0,0,0.22), transparent 50%),
    radial-gradient(circle at 50% 50%, transparent 60%, rgba(0,0,0,0.35) 100%);
  z-index: 0;
  pointer-events: none;
}
/* Subtle film grain via repeating noise */
.cs-scene::after {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity: 0.18;
  z-index: 1;
  pointer-events: none;
}
.cs-scene__shadows {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  z-index: 2;
  pointer-events: none;
  mix-blend-mode: multiply;
}
.cs-scene__device {
  position: relative;
  z-index: 3;
  width: min(78%, 1000px);
  filter:
    drop-shadow(0 6px 12px rgba(0,0,0,0.15))
    drop-shadow(0 32px 56px rgba(0,0,0,0.28))
    drop-shadow(50px 30px 80px rgba(0,0,0,0.35));
}
.cs-scene__device--phone {
  width: min(36%, 360px);
  aspect-ratio: 9 / 19.5;
  background: linear-gradient(180deg, #1a1a1a 0%, #0a0a0a 100%);
  border-radius: 36px;
  padding: 8px;
  position: relative;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.05) inset;
}
.cs-scene__device--phone .cs-phone__notch {
  position: absolute; top: 14px; left: 50%; transform: translateX(-50%);
  width: 100px; height: 26px;
  background: #0a0a0a; border-radius: 18px; z-index: 2;
}
.cs-scene__device--phone .cs-phone__screen {
  width: 100%; height: 100%;
  border-radius: 30px; overflow: hidden; background: #000;
}
.cs-scene__device--phone img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cs-scene__device--laptop .cs-laptop__bezel,
.cs-scene__device--laptop .cs-laptop__base { width: 100%; }
.cs-scene__device--laptop {
  aspect-ratio: 16 / 10;
  border-radius: 12px;
  overflow: hidden;
  background: #0a0a0a;
}
.cs-scene__device--laptop > img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Brand-specific scene atmospheres */
.cs-scene--stash {
  --scene-bg: linear-gradient(135deg, #d4c4a8 0%, #9a8870 50%, #5a4a38 100%);
}
.cs-scene--insivo-app {
  --scene-bg: linear-gradient(135deg, #cbd1db 0%, #8a93a4 50%, #4a5366 100%);
}
.cs-scene--insivo-ai {
  --scene-bg: linear-gradient(135deg, #f0e8d8 0%, #d8cbb0 50%, #a89878 100%);
}
.cs-scene--pba {
  --scene-bg: linear-gradient(135deg, #eddbb8 0%, #c4a574 50%, #885e2c 100%);
}
.cs-scene--auvio {
  --scene-bg: linear-gradient(135deg, #2a1a3a 0%, #1a0f2c 60%, #0a0a14 100%);
}
.cs-scene--auvio::before {
  background:
    radial-gradient(ellipse at 25% 20%, rgba(255, 107, 203, 0.22), transparent 45%),
    radial-gradient(ellipse at 80% 75%, rgba(0, 217, 255, 0.14), transparent 45%),
    radial-gradient(circle at 50% 50%, transparent 55%, rgba(0,0,0,0.55) 100%);
}

@media (max-width: 767px) {
  .cs-scene { min-height: 480px; aspect-ratio: 4 / 5; }
  .cs-scene__device { width: 88%; }
  .cs-scene__device--phone { width: 60%; max-width: 280px; }
}

/* === Scene-Photo: pre-composed Clay-style scene as single full-bleed image === */
.cs-scene-photo {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--cs-bg-1, #0a0a0a);
}
.cs-scene-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 767px) {
  .cs-scene-photo { aspect-ratio: 4 / 5; }
}

/* === Tech stack as scrolling big-type marquee (replaces 4-card grid) === */
.cs-stack-marquee {
  background: var(--cs-bg-2, var(--cs-bg-1));
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.cs-stack-marquee__head {
  text-align: center;
  margin-bottom: clamp(56px, 7vw, 88px);
  padding: 0 var(--cs-gutter);
  max-width: var(--cs-max);
  margin-left: auto; margin-right: auto;
}
.cs-stack-marquee__tracks {
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 1.2vw, 18px);
}
.cs-stack-marquee__track {
  display: flex;
  gap: clamp(40px, 5vw, 80px);
  width: max-content;
  white-space: nowrap;
  align-items: center;
  animation: cs-marq-l 38s linear infinite;
  will-change: transform;
}
.cs-stack-marquee__track--rev { animation: cs-marq-r 44s linear infinite; }
.cs-stack-marquee__track--meta { animation-duration: 52s; }
@keyframes cs-marq-l { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes cs-marq-r { from { transform: translateX(-50%); } to { transform: translateX(0); } }
.cs-stack-marquee__big {
  font-family: 'Helvetica Neue', sans-serif;
  font-size: clamp(2.4rem, 7vw, 5.5rem);
  font-weight: 500;
  letter-spacing: -0.04em;
  color: var(--cs-text);
  line-height: 0.95;
  display: inline-flex; align-items: center;
}
.cs-stack-marquee__big::after {
  content: "";
  display: inline-block;
  width: 0.32em; height: 0.32em;
  border-radius: 50%;
  background: var(--cs-accent);
  margin-left: clamp(20px, 2.5vw, 40px);
}
.cs-stack-marquee__small {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--cs-text-muted);
  display: inline-flex; align-items: center;
}
.cs-stack-marquee__small::after {
  content: "·";
  margin-left: 32px;
  color: var(--cs-text-muted);
  opacity: 0.4;
}
@media (prefers-reduced-motion: reduce) {
  .cs-stack-marquee__track { animation: none !important; }
}

/* === Stack-Tracklist (AUVIO) — vinyl-label numbered list === */
.cs-stack-tracklist { background: var(--cs-bg-2, var(--cs-bg-1)); padding: clamp(80px, 10vw, 140px) var(--cs-gutter); }
.cs-stack-tracklist__inner { max-width: 920px; margin: 0 auto; }
.cs-stack-tracklist__head { text-align: center; margin-bottom: clamp(56px, 7vw, 96px); }
.cs-stack-tracklist__list { list-style: none; margin: 0; padding: 0; }
.cs-stack-tracklist__item {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  align-items: baseline;
  gap: clamp(20px, 3vw, 48px);
  padding: clamp(22px, 2.4vw, 32px) 0;
  border-bottom: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent);
}
.cs-stack-tracklist__item:first-child { border-top: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent); }
.cs-stack-tracklist__num { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--cs-text-muted); opacity: 0.6; letter-spacing: 0.1em; }
.cs-stack-tracklist__name { font-family: 'Helvetica Neue', sans-serif; font-size: clamp(1.5rem, 3vw, 2.4rem); font-weight: 500; letter-spacing: -0.02em; color: var(--cs-text); }
.cs-stack-tracklist__meta { font-family: 'JetBrains Mono', monospace; font-size: 11.5px; color: var(--cs-text-muted); text-align: right; letter-spacing: 0.02em; }
@media (max-width: 767px) { .cs-stack-tracklist__item { grid-template-columns: 40px 1fr; } .cs-stack-tracklist__meta { grid-column: 2; text-align: left; padding-top: 4px; } }

/* === Stack-Compliance (Insivo App) — receipt-style checklist === */
.cs-stack-compliance { background: var(--cs-bg-2, var(--cs-bg-1)); padding: clamp(80px, 10vw, 140px) var(--cs-gutter); }
.cs-stack-compliance__inner { max-width: 980px; margin: 0 auto; }
.cs-stack-compliance__head { margin-bottom: clamp(48px, 6vw, 80px); max-width: 640px; }
.cs-stack-compliance__list { display: grid; gap: 0; }
.cs-stack-compliance__item {
  display: grid;
  grid-template-columns: 36px 1fr 260px;
  align-items: center;
  gap: clamp(16px, 2vw, 32px);
  padding: clamp(18px, 2vw, 28px) 0;
  border-top: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent);
}
.cs-stack-compliance__item:last-child { border-bottom: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent); }
.cs-stack-compliance__check { width: 22px; height: 22px; border-radius: 50%; background: var(--cs-accent); display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 13px; font-weight: 700; }
.cs-stack-compliance__name { font-family: 'Helvetica Neue', sans-serif; font-size: clamp(1.1rem, 1.8vw, 1.4rem); font-weight: 500; letter-spacing: -0.01em; color: var(--cs-text); }
.cs-stack-compliance__meta { font-family: 'JetBrains Mono', monospace; font-size: 11.5px; color: var(--cs-text-muted); letter-spacing: 0.04em; }
@media (max-width: 767px) { .cs-stack-compliance__item { grid-template-columns: 28px 1fr; } .cs-stack-compliance__meta { grid-column: 2; padding-top: 4px; } }

/* === Stack-Flow (CLAYMR) — pipeline chips with connector arrows === */
.cs-stack-flow { background: var(--cs-bg-2, var(--cs-bg-1)); padding: clamp(80px, 10vw, 140px) var(--cs-gutter); }
.cs-stack-flow__inner { max-width: var(--cs-max); margin: 0 auto; }
.cs-stack-flow__head { text-align: center; margin-bottom: clamp(56px, 7vw, 96px); }
.cs-stack-flow__list { display: flex; flex-wrap: wrap; gap: clamp(12px, 1.4vw, 20px); align-items: center; justify-content: center; }
.cs-stack-flow__item {
  display: inline-flex;
  flex-direction: column;
  gap: 6px;
  padding: 18px 26px;
  background: color-mix(in srgb, var(--cs-text) 4%, transparent);
  border: 1px solid color-mix(in srgb, var(--cs-accent) 22%, transparent);
  border-radius: 10px;
  text-align: center;
  min-width: 180px;
}
.cs-stack-flow__name { font-family: 'JetBrains Mono', monospace; font-size: 14px; color: var(--cs-accent); font-weight: 600; letter-spacing: 0.02em; }
.cs-stack-flow__meta { font-size: 11.5px; color: var(--cs-text-muted); letter-spacing: 0.01em; }
.cs-stack-flow__arrow { font-family: 'JetBrains Mono', monospace; color: var(--cs-accent); font-size: 22px; opacity: 0.55; user-select: none; }

/* === Stack-Registry (Stash) — service registry grid === */
.cs-stack-registry { background: var(--cs-bg-2, var(--cs-bg-1)); padding: clamp(80px, 10vw, 140px) var(--cs-gutter); }
.cs-stack-registry__inner { max-width: var(--cs-max); margin: 0 auto; }
.cs-stack-registry__head { margin-bottom: clamp(48px, 6vw, 80px); max-width: 640px; }
.cs-stack-registry__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  font-family: 'JetBrains Mono', monospace;
  border-top: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent);
  border-left: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent);
}
@media (max-width: 980px) { .cs-stack-registry__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .cs-stack-registry__grid { grid-template-columns: 1fr; } }
.cs-stack-registry__item {
  position: relative;
  display: flex; flex-direction: column; gap: 8px;
  padding: clamp(20px, 2.4vw, 32px);
  border-right: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--cs-text) 8%, transparent);
}
.cs-stack-registry__status { position: absolute; top: 20px; right: 20px; width: 8px; height: 8px; border-radius: 50%; background: var(--cs-accent); box-shadow: 0 0 12px var(--cs-accent); }
.cs-stack-registry__name { font-size: 13px; color: var(--cs-text); font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; }
.cs-stack-registry__meta { font-size: 11px; color: var(--cs-text-muted); letter-spacing: 0.02em; line-height: 1.5; }

/* === Tech stack as editorial big-type list (replaces card grid for light cases) === */
.cs-stack-typo {
  background: var(--cs-bg-2, var(--cs-bg-1));
  padding: clamp(80px, 10vw, 140px) var(--cs-gutter);
}
.cs-stack-typo__inner { max-width: var(--cs-max); margin: 0 auto; }
.cs-stack-typo__head { margin-bottom: clamp(48px, 6vw, 80px); }
.cs-stack-typo__list { list-style: none; margin: 0; padding: 0; }
.cs-stack-typo__item {
  display: grid;
  grid-template-columns: 60px 1fr 320px;
  gap: clamp(20px, 3vw, 48px);
  align-items: baseline;
  padding: clamp(24px, 3vw, 40px) 0;
  border-bottom: 1px solid color-mix(in srgb, var(--cs-text) 10%, transparent);
}
.cs-stack-typo__item:first-child { border-top: 1px solid color-mix(in srgb, var(--cs-text) 10%, transparent); }
.cs-stack-typo__num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12.5px;
  letter-spacing: 0.18em;
  color: var(--cs-accent);
  font-weight: 600;
}
.cs-stack-typo__name {
  font-family: 'Helvetica Neue', sans-serif;
  font-size: clamp(1.6rem, 3.2vw, 2.6rem);
  font-weight: 500;
  letter-spacing: -0.025em;
  color: var(--cs-text);
  line-height: 1.05;
}
.cs-stack-typo--editorial .cs-stack-typo__name {
  font-family: 'Instrument Serif', 'Iowan Old Style', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.8rem, 3.8vw, 3rem);
}
.cs-stack-typo__desc {
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--cs-text-muted);
}
@media (max-width: 760px) {
  .cs-stack-typo__item { grid-template-columns: 36px 1fr; }
  .cs-stack-typo__desc { grid-column: 1 / -1; margin-top: 8px; padding-left: 56px; }
}

/* === Insivo App: Vertical layer-stack with horizontal data pulses === */
.cs-vis--layers {
  background: linear-gradient(180deg, #0F1115 0%, #16181D 100%);
  padding: clamp(100px, 14vw, 180px) clamp(24px, 4vw, 56px);
  position: relative;
  isolation: isolate;
}
.cs-vis__layers-head {
  text-align: center;
  margin-bottom: clamp(56px, 7vw, 96px);
  max-width: 800px;
  margin-left: auto; margin-right: auto;
}
.cs-vis__layers-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #A5B4FC;
  margin: 0 0 28px;
  font-weight: 500;
}
.cs-vis__layers-h {
  font-family: 'Helvetica Neue', sans-serif;
  font-size: clamp(2rem, 4.5vw, 3.6rem);
  font-weight: 500;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: #F4F4F5;
  margin: 0;
  text-wrap: balance;
}
.cs-vis__layers-stack {
  position: relative;
  max-width: 780px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cs-vis__layer {
  position: relative;
  padding: 26px 36px;
  background: rgba(99, 102, 241, 0.06);
  border: 1px solid rgba(99, 102, 241, 0.18);
  border-radius: 14px;
  display: grid;
  grid-template-columns: 48px 1fr auto;
  gap: 28px;
  align-items: center;
  overflow: hidden;
}
.cs-vis__layer::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent 0%, rgba(165, 180, 252, 0.32) 50%, transparent 100%);
  transform: translateX(-110%);
  animation: cs-layer-pulse 9s ease-in-out infinite;
  will-change: transform;
}
.cs-vis__layer--1::before { animation-delay: 0s; }
.cs-vis__layer--2::before { animation-delay: 0.8s; }
.cs-vis__layer--3::before { animation-delay: 1.6s; }
.cs-vis__layer--4::before { animation-delay: 2.4s; }
@keyframes cs-layer-pulse {
  0%   { transform: translateX(-110%); }
  30%  { transform: translateX(220%); }
  100% { transform: translateX(220%); }
}
.cs-vis__layer-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  color: #A5B4FC;
  letter-spacing: 0.14em;
  font-weight: 600;
}
.cs-vis__layer-name {
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: #F4F4F5;
}
.cs-vis__layer-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  color: #71717A;
  letter-spacing: 0.04em;
}
@media (max-width: 600px) {
  .cs-vis__layer { grid-template-columns: 40px 1fr; gap: 12px; padding: 22px 24px; }
  .cs-vis__layer-meta { grid-column: 1 / -1; margin-top: 4px; }
}
@media (prefers-reduced-motion: reduce) {
  .cs-vis__layer::before { animation: none !important; }
}

/* === Sky variants — same atmospheric design language, different brand palettes === */
.cs-vis--sky--iridescent {
  background: #0A0A0F;
}
.cs-vis--sky--iridescent .cs-vis__sky-layer--1 { background: radial-gradient(ellipse 60% 40% at 30% 40%, #FF6BCB 0%, transparent 60%); }
.cs-vis--sky--iridescent .cs-vis__sky-layer--2 { background: radial-gradient(ellipse 50% 35% at 70% 60%, #8B5CF6 0%, transparent 60%); }
.cs-vis--sky--iridescent .cs-vis__sky-layer--3 { background: radial-gradient(ellipse 45% 35% at 50% 30%, #00D9FF 0%, transparent 60%); }
.cs-vis--sky--iridescent .cs-vis__sky-layer--4 { background: radial-gradient(ellipse 35% 30% at 20% 80%, #FF6BCB 0%, transparent 60%); }
.cs-vis--sky--iridescent .cs-vis__sky-kicker { color: #FF6BCB; }
.cs-vis--sky--iridescent .cs-vis__sky-h { text-shadow: 0 0 60px rgba(255, 107, 203, 0.35); }

.cs-vis--sky--indigo {
  background: #0F1115;
}
.cs-vis--sky--indigo .cs-vis__sky-layer--1 { background: radial-gradient(ellipse 60% 40% at 30% 40%, #6366F1 0%, transparent 60%); }
.cs-vis--sky--indigo .cs-vis__sky-layer--2 { background: radial-gradient(ellipse 50% 35% at 70% 60%, #818CF8 0%, transparent 60%); }
.cs-vis--sky--indigo .cs-vis__sky-layer--3 { background: radial-gradient(ellipse 45% 35% at 50% 30%, #4F46E5 0%, transparent 60%); }
.cs-vis--sky--indigo .cs-vis__sky-layer--4 { background: radial-gradient(ellipse 35% 30% at 20% 80%, #A5B4FC 0%, transparent 60%); }
.cs-vis--sky--indigo .cs-vis__sky-kicker { color: #A5B4FC; }
.cs-vis--sky--indigo .cs-vis__sky-h { text-shadow: 0 0 60px rgba(99, 102, 241, 0.4); }

/* === Insivo.ai: Editorial light moment (design-driven, paper-backed) === */
.cs-vis--editorial-light {
  background: #FAFAFA;
  position: relative;
  padding: clamp(120px, 16vw, 220px) clamp(24px, 4vw, 64px);
  overflow: hidden;
  isolation: isolate;
}
.cs-vis__el-bg {
  position: absolute;
  inset: -25%;
  background:
    radial-gradient(ellipse 55% 40% at 22% 30%, rgba(79, 70, 229, 0.22), transparent 65%),
    radial-gradient(ellipse 50% 40% at 78% 70%, rgba(165, 180, 252, 0.28), transparent 65%),
    radial-gradient(ellipse 40% 35% at 55% 50%, rgba(199, 210, 254, 0.18), transparent 65%);
  filter: blur(56px);
  animation: cs-el-drift 22s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
  will-change: transform;
}
@keyframes cs-el-drift {
  0%, 100% { transform: translate(0,0) scale(1); }
  33%      { transform: translate(-4%, 3%) scale(1.06); }
  66%      { transform: translate(3%, -2%) scale(0.98); }
}
.cs-vis__el-inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
}
.cs-vis__el-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #4F46E5;
  margin: 0 0 32px;
  font-weight: 500;
}
.cs-vis__el-h {
  font-family: 'Helvetica Neue', sans-serif;
  font-size: clamp(2.8rem, 7vw, 6.5rem);
  font-weight: 600;
  letter-spacing: -0.045em;
  line-height: 0.98;
  color: #0A0A0A;
  margin: 0 0 36px;
  text-wrap: balance;
  max-width: 18ch;
}
.cs-vis__el-h em {
  color: #4F46E5;
  font-style: normal;
  font-weight: 600;
  position: relative;
  display: inline-block;
}
.cs-vis__el-h em::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: 0.06em;
  height: 3px;
  background: #4F46E5;
  opacity: 0.18;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 1.6s cubic-bezier(0.22,1,0.36,1) 1s;
}
.cs-vis--editorial-light.is-visible .cs-vis__el-h em::after,
.cs-word-reveal.is-visible.cs-vis__el-h em::after { transform: scaleX(1); }
.cs-vis__el-sub {
  font-size: clamp(1rem, 1.4vw, 1.25rem);
  line-height: 1.55;
  color: #52525B;
  max-width: 56ch;
  margin: 0;
}
@media (prefers-reduced-motion: reduce) {
  .cs-vis__el-bg { animation: none !important; }
}

/* === Insivo.ai: Indigo aurora gradient === */
.cs-vis--aurora {
  background: #FAFAFA;
  position: relative;
  height: 480px;
  overflow: hidden;
}
.cs-vis__aurora {
  position: absolute;
  inset: -20%;
  background:
    radial-gradient(ellipse 60% 50% at 30% 40%, rgba(79, 70, 229, 0.35), transparent 70%),
    radial-gradient(ellipse 50% 45% at 70% 60%, rgba(165, 180, 252, 0.4), transparent 70%),
    radial-gradient(ellipse 40% 40% at 50% 30%, rgba(199, 210, 254, 0.3), transparent 70%);
  filter: blur(40px);
  animation: cs-vis-aurora-drift 18s ease-in-out infinite;
}
@keyframes cs-vis-aurora-drift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%      { transform: translate(-3%, 2%) scale(1.05); }
  66%      { transform: translate(2%, -2%) scale(1.02); }
}
.cs-vis__aurora-label {
  position: relative;
  z-index: 1;
  display: flex; align-items: center; justify-content: center;
  height: 100%;
  font-family: 'Helvetica Neue', sans-serif;
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: 500;
  letter-spacing: -0.03em;
  color: #0A0A0A;
  text-align: center;
  padding: 32px;
  text-wrap: balance;
}

/* === PBA&B: Architectural line drawing === */
.cs-vis--architecture {
  background: #FAF8F3;
  padding: clamp(60px, 8vw, 100px) clamp(24px, 4vw, 48px);
}
.cs-vis__architecture {
  max-width: 1000px;
  margin: 0 auto;
  width: 100%;
  height: auto;
}
.cs-vis__arch-line {
  fill: none;
  stroke: #1C1917;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 2000;
  stroke-dashoffset: 2000;
  transition: stroke-dashoffset 3.2s cubic-bezier(0.22, 1, 0.36, 1);
}
.cs-vis--architecture.is-visible .cs-vis__arch-line { stroke-dashoffset: 0; }
.cs-vis__arch-line--accent { stroke: #D97706; stroke-dasharray: 500; stroke-dashoffset: 500; transition-delay: 1.2s; }
.cs-vis--architecture.is-visible .cs-vis__arch-line--accent { stroke-dashoffset: 0; }
.cs-vis__arch-window {
  fill: rgba(217, 119, 6, 0.08);
  stroke: #D97706;
  stroke-width: 1;
  opacity: 0;
  transition: opacity .4s ease;
  transition-delay: calc(2s + var(--i, 0) * 80ms);
}
.cs-vis--architecture.is-visible .cs-vis__arch-window { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
  .cs-vis__bar, .cs-vis__shield-ring, .cs-vis__pipeline-dot, .cs-vis__feed, .cs-vis__aurora { animation: none !important; }
}

/* ─── RESPONSIVE TIGHTENING ─── */
@media (max-width: 767px) {
  .cs-hero { height: 80vh; min-height: 520px; }
  .cs-hero__floaters { display: none; }
  .cs-narrative, .cs-intro, .cs-feature, .cs-tech, .cs-results, .cs-palette { padding-top: 60px; padding-bottom: 60px; }
  .cs-statement { height: 60vh; min-height: 360px; }
}

/* ============================================
   PREMIUM HTML MOCKUPS — Clay-quality, code-rendered
============================================ */

/* === CLAYMR Pipeline Cinematic === */
.cs-pipeline-cinematic {
  background:
    radial-gradient(ellipse at 25% 30%, rgba(34,211,238,0.10), transparent 55%),
    radial-gradient(ellipse at 75% 70%, rgba(129,140,248,0.08), transparent 55%),
    linear-gradient(180deg, #0F0E1A 0%, #1B1A2E 100%);
  padding: clamp(100px, 12vw, 180px) var(--cs-gutter);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cs-pipeline-cinematic__inner { max-width: 1100px; margin: 0 auto; position: relative; z-index: 1; }
.cs-pipeline-cinematic__head { max-width: 720px; margin: 0 auto clamp(56px, 7vw, 96px); }
.cs-pipeline-cinematic__viz { display: block; width: 100%; height: auto; }
.cs-pipeline-node circle.cs-pn-glow { animation: cs-pn-pulse 3.4s ease-in-out infinite; transform-origin: center; transform-box: fill-box; }
.cs-pipeline-node:nth-child(1) .cs-pn-glow { animation-delay: 0s; }
.cs-pipeline-node:nth-child(2) .cs-pn-glow { animation-delay: 0.4s; }
.cs-pipeline-node:nth-child(3) .cs-pn-glow { animation-delay: 0.8s; }
.cs-pipeline-node:nth-child(4) .cs-pn-glow { animation-delay: 1.2s; }
.cs-pipeline-node:nth-child(5) .cs-pn-glow { animation-delay: 1.6s; }
.cs-pipeline-node:nth-child(6) .cs-pn-glow { animation-delay: 2.0s; }
@keyframes cs-pn-pulse { 0%,100% { opacity: 0.55; transform: scale(1); } 50% { opacity: 1; transform: scale(1.15); } }
.cs-pipeline-cinematic__labels {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(8px, 1.2vw, 16px);
  margin-top: clamp(20px, 2.4vw, 32px);
}
.cs-pipeline-cinematic__label {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(9.5px, 0.9vw, 11px);
  letter-spacing: 0.12em;
  color: rgba(244,244,245,0.55);
  text-transform: uppercase;
  text-align: center;
}
@media (max-width: 767px) { .cs-pipeline-cinematic__labels { grid-template-columns: repeat(3, 1fr); row-gap: 14px; } }

/* === CLAYMR Notion Handoff card === */
.cs-notion-mock {
  background: linear-gradient(180deg, #1B1A2E 0%, #1A1928 100%);
  border: 1px solid rgba(34,211,238,0.18);
  border-radius: 14px;
  padding: clamp(24px, 3vw, 36px);
  color: #F4F4F5;
  box-shadow:
    0 4px 12px rgba(0,0,0,0.25),
    0 28px 64px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.04);
  position: relative;
  font-family: 'Inter', sans-serif;
}
.cs-notion-mock::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(34,211,238,0.05), transparent 32%);
  border-radius: inherit; pointer-events: none;
}
.cs-notion-mock__head {
  display: flex; align-items: center; gap: 14px;
  padding-bottom: 18px;
  margin-bottom: 22px;
  border-bottom: 1px solid rgba(34,211,238,0.1);
  position: relative;
}
.cs-notion-mock__pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: #22D3EE; box-shadow: 0 0 12px #22D3EE;
  animation: cs-mock-pulse 2.4s ease-in-out infinite;
}
@keyframes cs-mock-pulse { 50% { opacity: 0.35; transform: scale(0.85); } }
.cs-notion-mock__crumb {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em;
  color: rgba(244,244,245,0.62);
}
.cs-notion-mock__badge {
  margin-left: auto;
  padding: 5px 11px;
  background: rgba(34,211,238,0.12);
  color: #22D3EE;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.14em; font-weight: 600;
  border-radius: 4px;
}
.cs-notion-mock__items {
  display: flex; flex-direction: column; gap: 14px;
  margin-bottom: 22px;
}
.cs-notion-mock__row {
  display: grid;
  grid-template-columns: 18px 1fr auto auto;
  gap: 14px; align-items: center;
}
.cs-notion-mock__check {
  width: 16px; height: 16px; border-radius: 4px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cs-notion-mock__check--done { background: #22D3EE; color: #0F0E1A; }
.cs-notion-mock__check--pending { background: transparent; border: 1px solid rgba(244,244,245,0.22); }
.cs-notion-mock__check svg { width: 10px; height: 10px; }
.cs-notion-mock__label { font-size: 13px; color: #F4F4F5; letter-spacing: -0.005em; }
.cs-notion-mock__time { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; color: rgba(244,244,245,0.35); }
.cs-notion-mock__status {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 3px;
}
.cs-notion-mock__status--ok { background: rgba(34,211,238,0.1); color: #22D3EE; }
.cs-notion-mock__status--wait { background: rgba(244,244,245,0.06); color: rgba(244,244,245,0.5); }
.cs-notion-mock__quote {
  padding: 18px 22px;
  background: rgba(34,211,238,0.06);
  border-left: 2px solid #22D3EE;
  border-radius: 0 8px 8px 0;
  font-size: 13.5px; line-height: 1.7;
  color: rgba(244,244,245,0.92);
  font-style: italic;
  margin-bottom: 22px;
  position: relative;
}
.cs-notion-mock__quote-meta {
  display: block;
  font-style: normal;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.1em;
  color: rgba(244,244,245,0.4);
  margin-top: 10px;
}
.cs-notion-mock__actions { display: flex; gap: 10px; }
.cs-notion-mock__btn {
  flex: 1;
  padding: 12px;
  border-radius: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
  cursor: pointer; border: none;
  transition: transform 0.2s ease, box-shadow 0.25s ease, background 0.2s ease;
}
.cs-notion-mock__btn--approve {
  background: #22D3EE; color: #0F0E1A;
  box-shadow: 0 0 0 0 rgba(34,211,238,0);
}
.cs-notion-mock__btn--approve:hover {
  transform: translateY(-1px);
  box-shadow: 0 0 24px rgba(34,211,238,0.4);
}
.cs-notion-mock__btn--reject {
  background: transparent;
  color: rgba(244,244,245,0.55);
  border: 1px solid rgba(244,244,245,0.14);
}
.cs-notion-mock__btn--reject:hover { color: #F4F4F5; border-color: rgba(244,244,245,0.3); }

/* === PBA&B Deploy Diagram === */
.cs-deploy-mock {
  background: color-mix(in srgb, var(--cs-bg-2, #FAF8F3) 60%, transparent);
  border: 1px solid color-mix(in srgb, var(--cs-accent, #D97706) 14%, transparent);
  border-radius: 14px;
  padding: clamp(28px, 4vw, 44px);
  display: flex; flex-direction: column;
  gap: 32px;
}
.cs-deploy-mock__flow {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: clamp(10px, 1.6vw, 18px);
  align-items: stretch;
}
.cs-deploy-mock__node {
  background: color-mix(in srgb, var(--cs-bg-1) 75%, transparent);
  border-radius: 10px;
  padding: 22px;
  display: flex; flex-direction: column;
  gap: 14px;
  border: 1px solid color-mix(in srgb, var(--cs-accent) 12%, transparent);
}
.cs-deploy-mock__node-icon {
  width: 34px; height: 34px;
  background: color-mix(in srgb, var(--cs-accent) 12%, transparent);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--cs-accent);
}
.cs-deploy-mock__node-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.16em;
  color: var(--cs-text-muted); text-transform: uppercase;
}
.cs-deploy-mock__node-value {
  font-size: 14px; color: var(--cs-text);
  font-weight: 500; letter-spacing: -0.01em;
  line-height: 1.45;
}
.cs-deploy-mock__node-value em {
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  color: var(--cs-accent);
  font-weight: 400;
}
.cs-deploy-mock__arrow {
  display: flex; align-items: center; justify-content: center;
  color: var(--cs-accent);
  opacity: 0.6;
}
.cs-deploy-mock__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.cs-deploy-mock__stat {
  background: color-mix(in srgb, var(--cs-bg-1) 75%, transparent);
  border-radius: 10px;
  padding: 20px;
  border: 1px solid color-mix(in srgb, var(--cs-accent) 10%, transparent);
}
.cs-deploy-mock__stat-num {
  font-family: 'Instrument Serif', 'Georgia', serif;
  font-style: italic;
  font-size: clamp(1.7rem, 2.6vw, 2.3rem);
  font-weight: 400;
  color: var(--cs-accent);
  letter-spacing: -0.02em;
  line-height: 1;
}
.cs-deploy-mock__stat-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.14em;
  color: var(--cs-text-muted); text-transform: uppercase;
  margin-top: 8px;
}
@media (max-width: 767px) {
  .cs-deploy-mock__flow { grid-template-columns: 1fr; }
  .cs-deploy-mock__arrow { transform: rotate(90deg); padding: 4px 0; }
  .cs-deploy-mock__stats { grid-template-columns: repeat(2, 1fr); }
}

/* === Insivo.ai Compliance Evidence === */
.cs-compliance-mock {
  background: white;
  border: 1px solid rgba(79,70,229,0.1);
  border-radius: 14px;
  padding: clamp(28px, 4vw, 44px);
  display: flex; flex-direction: column;
  gap: 28px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.04);
}
.cs-compliance-mock__head { display: flex; flex-direction: column; gap: 8px; }
.cs-compliance-mock__kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.16em;
  color: #71717A; text-transform: uppercase;
}
.cs-compliance-mock__h {
  font-size: clamp(1.1rem, 1.8vw, 1.35rem);
  font-weight: 500; letter-spacing: -0.012em;
  color: #0A0A0A; margin: 0;
}
.cs-compliance-mock__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.cs-compliance-mock__card {
  padding: 22px;
  background: #FAFAFA;
  border-radius: 10px;
  display: flex; flex-direction: column;
  gap: 12px;
  border: 1px solid transparent;
  transition: background 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
  cursor: default;
}
.cs-compliance-mock__card:hover {
  background: #F5F5F8;
  border-color: rgba(79,70,229,0.12);
  transform: translateY(-2px);
}
.cs-compliance-mock__card-icon {
  width: 42px; height: 42px;
  background: rgba(79,70,229,0.1);
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  color: #4F46E5;
}
.cs-compliance-mock__card-label {
  font-size: 13px; color: #0A0A0A;
  font-weight: 500; letter-spacing: -0.005em;
}
.cs-compliance-mock__card-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  color: #71717A;
  letter-spacing: 0.04em;
}
.cs-compliance-mock__footer {
  padding-top: 20px;
  border-top: 1px solid rgba(79,70,229,0.08);
  font-size: 13px;
  color: #52525B;
  line-height: 1.7;
}
.cs-compliance-mock__footer strong { color: #0A0A0A; font-weight: 600; }
@media (max-width: 767px) { .cs-compliance-mock__grid { grid-template-columns: 1fr; } }

/* ============================================
   MOBILE FIXES — case study hero readability + narrative aside stack
============================================ */
@media (max-width: 767px) {
  /* Strong hero overlay so the underlying screenshot's text doesn't fight the case study title */
  .cs-hero__image img { filter: brightness(0.55) blur(1.5px); }
  .cs-hero__overlay {
    background: linear-gradient(180deg, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.7) 100%);
  }
  .case-study[data-theme="light"] .cs-hero__image img { filter: brightness(1.05) blur(1.5px) saturate(0.6); }
  .case-study[data-theme="light"] .cs-hero__overlay {
    background: linear-gradient(180deg, rgba(255,255,255,0.55) 0%, rgba(255,255,255,0.85) 100%);
  }
  /* Trim hero title size on mobile so it doesn't crash into nav/back-link */
  .cs-hero__title { font-size: clamp(2.2rem, 10vw, 3rem); letter-spacing: -0.03em; }
  .cs-hero__tagline { font-size: 0.95rem; line-height: 1.5; }
  .cs-hero__inner { padding: clamp(24px, 5vw, 48px); }
  /* Make sure hero floaters stay hidden on mobile (already in base, here as safety) */
  .cs-hero__floaters { display: none !important; }

  /* Narrative aside: cards stack as a column with breathing room instead of absolute scatter */
  .cs-narrative--with-float { grid-template-columns: 1fr; gap: 32px; }
  .cs-narrative__aside {
    position: relative; min-height: 0;
    display: flex; flex-direction: column; gap: 12px;
  }
  .cs-narrative__aside .cs-card,
  .cs-narrative__aside .cs-float {
    position: relative !important; top: auto !important; left: auto !important; right: auto !important;
    animation: none !important;
  }

  /* Tighter cs-statement on mobile (full image still readable) */
  .cs-statement { height: 50vh; min-height: 320px; max-height: 520px; }

  /* Narrative paragraph max width — let it use the full mobile column */
  .cs-narrative__p, .cs-narrative__h { max-width: none; }

  /* Editorial vis (PBA&B) — sub paragraph readable on mobile */
  .cs-vis__editorial-sub { margin-top: 24px; font-size: 0.95rem; }
  .cs-vis__editorial-mark { font-size: clamp(14rem, 50vw, 22rem); right: -14%; opacity: 0.05; }
}

/* ============================================
   CTA-GLASS — Glassmorphism contact banner
   Floating glass cards on graffiti-textured gradient
============================================ */
.cta-glass {
  position: relative;
  overflow: hidden;
  padding: clamp(80px, 10vw, 160px) var(--cs-gutter, 24px);
  isolation: isolate;
  margin: 0;
  border-radius: 0;
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
.cta-glass__bg {
  position: absolute; inset: 0; z-index: 0;
  background-image: url("../img/contact-bonsai-mac.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.cta-glass__inner {
  position: relative; z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
}
.cta-glass__head {
  margin-bottom: clamp(40px, 5vw, 64px);
  padding: clamp(24px, 3vw, 36px);
  background: rgba(255, 255, 255, 0.45);
  backdrop-filter: blur(32px) saturate(140%);
  -webkit-backdrop-filter: blur(32px) saturate(140%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 20px;
  box-shadow:
    0 8px 24px rgba(0, 0, 0, 0.06),
    0 1px 0 rgba(255, 255, 255, 0.8) inset;
}
.cta-glass__kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.55);
  margin: 0 0 16px;
}
.cta-glass__title {
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: #1A1A2E;
  margin: 0 0 14px;
  max-width: 18ch;
}
.cta-glass__title em {
  font-family: 'Instrument Serif', 'Georgia', serif;
  font-style: italic; font-weight: 400;
}
.cta-glass__sub {
  font-size: clamp(1rem, 1.4vw, 1.1rem);
  color: rgba(26, 26, 46, 0.7);
  max-width: 56ch;
  margin: 0;
  line-height: 1.6;
}

/* === Card Grid === */
.cta-glass__cards {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  grid-template-rows: auto auto auto auto;
  gap: 14px;
}
@media (max-width: 880px) {
  .cta-glass__cards { grid-template-columns: 1fr; }
}

/* === Shared Card === */
.cta-glass__card {
  background: rgba(255, 255, 255, 0.42);
  backdrop-filter: blur(32px) saturate(140%);
  -webkit-backdrop-filter: blur(32px) saturate(140%);
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: 18px;
  padding: clamp(20px, 2.4vw, 28px);
  box-shadow:
    0 6px 20px rgba(0, 0, 0, 0.05),
    0 1px 0 rgba(255, 255, 255, 0.75) inset;
  position: relative;
}

/* === Main Profile Card (large left) === */
.cta-glass__card--main {
  grid-row: 1 / span 2;
  grid-column: 1;
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 2.4vw, 28px);
  padding: clamp(24px, 3vw, 36px);
}
@media (max-width: 880px) {
  .cta-glass__card--main { grid-row: auto; grid-column: 1; }
}
.cta-glass__card-head {
  display: grid;
  grid-template-columns: 52px 1fr auto;
  gap: 14px;
  align-items: center;
}
.cta-glass__avatar {
  width: 52px; height: 52px;
  border-radius: 50%;
  overflow: hidden;
  background: linear-gradient(135deg, #FF6BCB, #4F46E5);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cta-glass__avatar img { width: 100%; height: 100%; object-fit: cover; }
.cta-glass__name {
  font-size: 17px; font-weight: 500;
  color: #1A1A2E;
  margin: 0; letter-spacing: -0.012em;
}
.cta-glass__role {
  font-size: 12.5px;
  color: rgba(26, 26, 46, 0.55);
  margin: 2px 0 0;
}
.cta-glass__head-action {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.5);
  display: flex; align-items: center; justify-content: center;
  color: #1A1A2E;
  text-decoration: none;
  transition: background 0.2s ease;
}
.cta-glass__head-action:hover { background: rgba(255, 255, 255, 0.9); }

.cta-glass__main-tag {
  font-size: 13.5px;
  color: rgba(26, 26, 46, 0.65);
  margin: 0;
}
.cta-glass__main-headline {
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  font-weight: 500;
  color: #1A1A2E;
  letter-spacing: -0.012em;
  margin: 4px 0 0;
  line-height: 1.35;
}
.cta-glass__highlight {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px;
  background: rgba(20, 184, 166, 0.12);
  border: 1px solid rgba(20, 184, 166, 0.18);
  border-radius: 12px;
  font-size: 13.5px;
  color: #1A1A2E;
}
.cta-glass__highlight svg { flex-shrink: 0; color: #0E7F76; }

.cta-glass__contact-line {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px;
  padding: 14px 0 0;
  border-top: 1px solid rgba(26, 26, 46, 0.08);
}
.cta-glass__contact-text {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  color: rgba(26, 26, 46, 0.85);
  letter-spacing: 0.02em;
  word-break: break-all;
  text-decoration: none;
}
.cta-glass__contact-text:hover { color: #4F46E5; }
.cta-glass__copy {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.05);
  border: none;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  color: rgba(26, 26, 46, 0.7);
  flex-shrink: 0;
  transition: background 0.2s ease;
}
.cta-glass__copy:hover { background: rgba(0, 0, 0, 0.1); }

/* === Toolbar Card (icon row) === */
.cta-glass__card--toolbar {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
  padding: 14px 18px;
}
.cta-glass__icon-btn {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.03);
  display: flex; align-items: center; justify-content: center;
  color: rgba(26, 26, 46, 0.78);
  text-decoration: none;
  transition: background 0.2s ease, transform 0.2s ease;
  border: none;
  cursor: pointer;
}
.cta-glass__icon-btn:hover {
  background: rgba(0, 0, 0, 0.08);
  transform: translateY(-1px);
}
.cta-glass__icon-btn.is-active { background: rgba(0, 0, 0, 0.08); }

/* === Pills Card === */
.cta-glass__card--pills {
  grid-column: 2;
  grid-row: 2;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  padding: 14px 16px;
}
.cta-glass__pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px 8px 8px;
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 14px;
  font-size: 12.5px;
  font-weight: 500;
  color: #1A1A2E;
  letter-spacing: -0.005em;
}
.cta-glass__pill-dot {
  width: 28px; height: 28px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cta-glass__pill-dot--cyan { background: #C8F0EC; color: #0E7F76; }
.cta-glass__pill-dot--pink { background: #C7E6E2; color: #0F766E; }
.cta-glass__pill-dot--violet { background: #CFE3F2; color: #1E40AF; }
.cta-glass__pill-dot--amber { background: #D7E5EE; color: #1E3A5F; }

/* === Booking Card (expanded, takes 2 rows on right) === */
.cta-glass__card--booking {
  grid-column: 2;
  grid-row: 2;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: clamp(24px, 3vw, 36px);
  justify-content: center;
}
.cta-glass__booking-label {
  font-size: clamp(1.15rem, 1.8vw, 1.5rem);
  font-weight: 500;
  color: #1A1A2E;
  margin: 0;
  letter-spacing: -0.018em;
  line-height: 1.2;
}
.cta-glass__booking-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  color: rgba(26, 26, 46, 0.55);
  margin: 0;
  letter-spacing: 0.06em;
}
.cta-glass__booking-btn {
  margin-top: 10px;
  padding: 18px 22px;
  background: #1A1A2E;
  color: white;
  border: none;
  border-radius: 14px;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -0.005em;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  transition: background 0.2s ease, transform 0.2s ease;
}
.cta-glass__booking-btn:hover { background: #0A0A1A; transform: translateY(-1px); }
.cta-glass__booking-btn svg { flex-shrink: 0; }

/* === Trust Card === */
.cta-glass__card--trust {
  grid-column: 2;
  grid-row: 3;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
}
.cta-glass__trust-avatars { display: flex; flex-shrink: 0; }
.cta-glass__trust-avatars > * {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.9);
  background: white;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06);
}
.cta-glass__trust-avatars > *:not(:first-child) { margin-left: -10px; }
.cta-glass__trust-avatars img { width: 72%; height: 72%; object-fit: contain; }
.cta-glass__trust-label {
  font-size: 12.5px;
  color: rgba(26, 26, 46, 0.65);
  margin: 0;
  line-height: 1.4;
}
.cta-glass__trust-label strong { color: #1A1A2E; font-weight: 600; }

@media (max-width: 880px) {
  .cta-glass__card--toolbar,
  .cta-glass__card--pills,
  .cta-glass__card--booking,
  .cta-glass__card--trust { grid-column: 1; grid-row: auto; }
}

/* === About — premium layout with quote, gradient skills-wall, grouped chips === */
.about__quote {
  font-family: 'Instrument Serif', 'Georgia', serif;
  font-style: italic;
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  letter-spacing: -0.025em;
  line-height: 1.02;
  margin: 0 0 28px;
  color: var(--text);
}
.about__quote em {
  font-style: italic;
  background: linear-gradient(135deg, #06B6D4 0%, #14B8A6 50%, #3B82F6 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.about__lede--secondary { margin-top: 18px; color: var(--text-2); }

.about__copy { display: flex; flex-direction: column; gap: 16px; }
.about__lede em { font-style: italic; font-family: 'Instrument Serif', 'Georgia', serif; color: #0E7490; }

.about__skills-wall {
  position: relative;
  margin-top: 8px;
  padding: clamp(16px, 1.8vw, 22px);
  border-radius: 16px;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgba(6, 182, 212, 0.12);
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(8px);
}
.about__skills-bg {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(ellipse 60% 60% at 10% 10%, rgba(6, 182, 212, 0.14), transparent 65%),
    radial-gradient(ellipse 50% 50% at 90% 30%, rgba(20, 184, 166, 0.12), transparent 65%),
    radial-gradient(ellipse 60% 50% at 80% 90%, rgba(59, 130, 246, 0.12), transparent 65%),
    radial-gradient(ellipse 40% 40% at 20% 80%, rgba(16, 185, 129, 0.10), transparent 65%);
}
.about__skills-inner {
  display: flex; flex-direction: column;
  gap: 14px;
}
.about__skills-group { display: flex; flex-direction: column; gap: 8px; }
.about__skills-group + .about__skills-group {
  padding-top: 14px;
  border-top: 1px solid rgba(15, 118, 110, 0.1);
}
.about__skills-group-title {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-2);
  margin: 0;
  opacity: 0.7;
}

.about__skills {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 7px 8px;
  margin: 0;
  padding: 0;
}
.about__skills .chip {
  padding: 5px 12px 5px 5px;
  font-size: 12px;
  gap: 7px;
}
.about__skills .chip__icon { width: 22px; height: 22px; }
.about__skills .chip__icon svg { width: 12px; height: 12px; }
.about__skills .chip {
  padding: 8px 16px 8px 7px;
  font-size: 13.5px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  cursor: default;
  position: relative;
  overflow: hidden;
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    background 0.45s ease,
    border-color 0.45s ease,
    box-shadow 0.45s ease,
    color 0.45s ease;
}
.about__skills .chip__icon {
  width: 28px; height: 28px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: rgba(0, 0, 0, 0.05);
  color: rgba(0, 0, 0, 0.55);
  transition:
    transform 0.7s cubic-bezier(0.22, 1, 0.36, 1),
    background 0.45s ease,
    color 0.45s ease,
    box-shadow 0.45s ease;
}
.about__skills .chip:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px -10px rgba(0, 0, 0, 0.18);
}
.about__skills .chip:hover .chip__icon {
  transform: rotate(360deg) scale(1.12);
}

/* === Color variants === */
.chip--teal .chip__icon { background: rgba(20, 184, 166, 0.14); color: #0F766E; }
.chip--teal:hover { background: rgba(20, 184, 166, 0.06); border-color: rgba(20, 184, 166, 0.35); color: #0F766E; }
.chip--teal:hover .chip__icon { background: rgba(20, 184, 166, 0.28); box-shadow: 0 0 16px rgba(20, 184, 166, 0.25); }

.chip--cyan .chip__icon { background: rgba(6, 182, 212, 0.14); color: #0E7490; }
.chip--cyan:hover { background: rgba(6, 182, 212, 0.06); border-color: rgba(6, 182, 212, 0.35); color: #0E7490; }
.chip--cyan:hover .chip__icon { background: rgba(6, 182, 212, 0.28); box-shadow: 0 0 16px rgba(6, 182, 212, 0.25); }

.chip--blue .chip__icon { background: rgba(59, 130, 246, 0.14); color: #1D4ED8; }
.chip--blue:hover { background: rgba(59, 130, 246, 0.06); border-color: rgba(59, 130, 246, 0.35); color: #1D4ED8; }
.chip--blue:hover .chip__icon { background: rgba(59, 130, 246, 0.28); box-shadow: 0 0 16px rgba(59, 130, 246, 0.25); }

.chip--indigo .chip__icon { background: rgba(79, 70, 229, 0.14); color: #4338CA; }
.chip--indigo:hover { background: rgba(79, 70, 229, 0.06); border-color: rgba(79, 70, 229, 0.35); color: #4338CA; }
.chip--indigo:hover .chip__icon { background: rgba(79, 70, 229, 0.28); box-shadow: 0 0 16px rgba(79, 70, 229, 0.25); }

.chip--slate .chip__icon { background: rgba(71, 85, 105, 0.14); color: #334155; }
.chip--slate:hover { background: rgba(71, 85, 105, 0.06); border-color: rgba(71, 85, 105, 0.35); color: #334155; }
.chip--slate:hover .chip__icon { background: rgba(71, 85, 105, 0.28); box-shadow: 0 0 14px rgba(71, 85, 105, 0.2); }

.chip--emerald .chip__icon { background: rgba(16, 185, 129, 0.14); color: #047857; }
.chip--emerald:hover { background: rgba(16, 185, 129, 0.06); border-color: rgba(16, 185, 129, 0.35); color: #047857; }
.chip--emerald:hover .chip__icon { background: rgba(16, 185, 129, 0.28); box-shadow: 0 0 16px rgba(16, 185, 129, 0.25); }

.chip--sky .chip__icon { background: rgba(14, 165, 233, 0.14); color: #0369A1; }
.chip--sky:hover { background: rgba(14, 165, 233, 0.06); border-color: rgba(14, 165, 233, 0.35); color: #0369A1; }
.chip--sky:hover .chip__icon { background: rgba(14, 165, 233, 0.28); box-shadow: 0 0 16px rgba(14, 165, 233, 0.25); }

/* === Organic scattered offsets within each group (editorial feel) === */
.about__skills li:nth-child(2)  { transform: translate(6px, 3px); }
.about__skills li:nth-child(3)  { transform: translate(-2px, -2px); }
.about__skills li:nth-child(4)  { transform: translate(10px, 4px); }
.about__skills li:nth-child(5)  { transform: translate(-4px, -1px); }
.about__skills li:nth-child(6)  { transform: translate(8px, 3px); }
.about__skills li.chip:hover { transform: translateY(-3px) !important; }
@media (max-width: 640px) {
  .about__skills li[class] { transform: none; }
  .about__skills li.chip:hover { transform: translateY(-3px) !important; }
}
