/* ============================================================
   Apps showcase — extends styles.css design system.
   ============================================================ */

/* ===== App icon (squircle gradient with shine) ===== */
.app-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  color: #fff;
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.02em;
  flex-shrink: 0;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.35),
    inset 0 -1px 0 rgba(0,0,0,0.18),
    0 8px 18px -6px rgba(0,0,0,0.22),
    0 0 0 1px rgba(255,255,255,0.16) inset;
  transition: transform 320ms var(--ease), box-shadow 320ms var(--ease);
}
.app-icon__shine {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 50%;
  background: linear-gradient(180deg, rgba(255,255,255,0.30), rgba(255,255,255,0));
  pointer-events: none;
}
.app-icon__inner {
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,0.18));
}
.app-icon--hover,
.app-card:hover .app-icon {
  transform: translateY(-2px) rotate(-2deg) scale(1.04);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.4),
    0 16px 28px -10px rgba(0,0,0,0.35),
    0 0 0 1px rgba(255,255,255,0.18) inset;
}

/* ===== Status badge ===== */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 22px;
  padding: 0 10px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid var(--line-strong);
  background: var(--paper-2);
}
.status-badge__dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--ink-mute);
  box-shadow: 0 0 0 3px color-mix(in oklab, currentColor 14%, transparent);
}
.status-badge--live  .status-badge__dot { background: oklch(0.72 0.16 145); }
.status-badge--live  { color: oklch(0.50 0.16 145); border-color: oklch(0.84 0.10 145); background: oklch(0.97 0.04 145); }
.status-badge--beta  .status-badge__dot { background: oklch(0.72 0.16 75);  }
.status-badge--beta  { color: oklch(0.45 0.16 75);  border-color: oklch(0.86 0.10 75);  background: oklch(0.97 0.04 75); }
.status-badge--build .status-badge__dot { background: oklch(0.72 0.16 280); }
.status-badge--build { color: oklch(0.45 0.16 280); border-color: oklch(0.86 0.10 280); background: oklch(0.97 0.04 280); }

[data-theme="dark"] .status-badge--live  { background: oklch(0.22 0.06 145); border-color: oklch(0.30 0.07 145); color: oklch(0.82 0.13 145); }
[data-theme="dark"] .status-badge--beta  { background: oklch(0.22 0.06 75);  border-color: oklch(0.30 0.07 75);  color: oklch(0.82 0.13 75); }
[data-theme="dark"] .status-badge--build { background: oklch(0.22 0.06 280); border-color: oklch(0.30 0.07 280); color: oklch(0.82 0.13 280); }

/* ===== Platform chips ===== */
.platforms {
  display: inline-flex;
  gap: 4px;
}
.platforms__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: var(--paper-sunk);
  color: var(--ink-soft);
  border: 1px solid var(--line);
}
.platforms__chip svg {
  width: 13px; height: 13px;
  display: block;
}
.platforms--lg .platforms__chip { width: 32px; height: 32px; }
.platforms--lg .platforms__chip svg { width: 16px; height: 16px; }

/* ===== Rating ===== */
.rating {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: oklch(0.55 0.04 270);
  font-family: var(--font-mono);
  font-size: 12px;
}
.rating__stars {
  display: inline-flex;
  gap: 1px;
  color: var(--line-strong);
}
.rating__star svg { display: block; }
.rating__val { font-weight: 600; color: var(--ink); letter-spacing: 0.01em; }
.rating__count { color: var(--ink-mute); }

/* ===== Store badge ===== */
.store-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  height: 48px;
  padding: 0 16px 0 14px;
  border-radius: 12px;
  background: var(--ink);
  color: var(--paper);
  transition: transform 220ms var(--ease), background 220ms var(--ease);
}
.store-badge:hover { transform: translateY(-2px); }
.store-badge__icon { display: inline-flex; }
.store-badge__icon svg { display: block; }
.store-badge__text {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}
.store-badge__sup {
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 0.04em;
  opacity: 0.75;
}
.store-badge__main {
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.015em;
}

/* ===== App card (grid) ===== */
.apps-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 20px;
}
@media (min-width: 720px)  { .apps-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .apps-grid { grid-template-columns: repeat(3, 1fr); } }

.app-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper-2);
  text-decoration: none;
  color: var(--ink);
  overflow: hidden;
  transition: border-color 260ms var(--ease), box-shadow 260ms var(--ease), transform 260ms var(--ease);
  isolation: isolate;
  min-height: 360px;
}

.app-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, var(--card-tint, transparent) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 320ms var(--ease);
  z-index: 0;
  pointer-events: none;
}
.app-card:hover::before { opacity: 0.4; }
.app-card:hover {
  border-color: var(--ink);
  transform: translateY(-3px);
  box-shadow: 0 26px 50px -28px oklch(0.16 0.015 270 / 0.28);
}

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

.app-card__head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.app-card__id {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 0;
}

.app-card__name {
  font-family: var(--font-sans);
  font-weight: 500;
  letter-spacing: -0.025em;
  font-size: 22px;
  line-height: 1.1;
}
.app-card__cat {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.app-card__badges {
  display: flex;
  align-items: center;
  gap: 8px;
}

.app-card__tagline {
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: -4px 0 0;
}

.app-card__foot {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.app-card__metric {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.app-card__metric-val {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 15px;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.app-card__metric-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-mute);
}

/* ===== App card — phone-peek variant ===== */
.app-card--peek {
  padding: 0;
  gap: 0;
  min-height: 0;
  overflow: hidden;
}
.app-card__peek {
  position: relative;
  height: 224px;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  isolation: isolate;
}
/* soft fade where the phone is clipped */
.app-card__peek::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 84px;
  background: linear-gradient(to bottom, transparent, var(--paper-2));
  pointer-events: none;
  z-index: 4;
}

.phone-peek {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: center;
}
.phone-peek__device {
  position: absolute;
  top: 24px;
  transition: transform 420ms var(--ease);
  will-change: transform;
}
.phone-peek__scaler {
  transform-origin: top left;
}
.app-card--peek:hover .phone-peek__device {
  transform: translateY(-10px);
}

/* sliding viewport inside the phone */
.phone-peek__view {
  position: relative;
  height: 100%;
  width: 100%;
  overflow: hidden;
}
.phone-peek__track {
  display: flex;
  height: 100%;
  transition: transform 700ms cubic-bezier(0.65, 0, 0.2, 1);
}
.phone-peek__slide {
  flex: 0 0 auto;
  height: 100%;
  overflow: hidden;
}
.phone-peek__shot {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}

/* page dots, floating over the clipped area */
.phone-peek__dots {
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 6;
}
.phone-peek__dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: oklch(0.5 0.02 270 / 0.28);
  transition: width 320ms var(--ease), background 320ms var(--ease);
}
.phone-peek__dot.is-active {
  width: 18px;
  background: var(--ink);
}

.app-card--peek .app-card__body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px 24px 24px;
}
.app-card--peek .app-card__tagline { margin: 0; }
.app-card--peek .app-card__foot { margin-top: 6px; padding-top: 16px; }

/* ===== Apps hero ===== */
.apps-hero {
  position: relative;
  padding-top: 140px;
  padding-bottom: clamp(56px, 8vw, 80px);
  overflow: hidden;
  isolation: isolate;
}
.apps-hero__head {
  max-width: 940px;
  position: relative;
  z-index: 1;
}
.apps-hero .gravity-stars { z-index: 0; }
.apps-hero .apps-stats { position: relative; z-index: 1; }
.apps-hero__title {
  margin: 18px 0 0;
  font-family: var(--font-sans);
  font-size: clamp(48px, 7vw, 96px);
  font-weight: 500;
  letter-spacing: -0.035em;
  line-height: 0.95;
  color: var(--ink);
  text-wrap: balance;
}
.apps-hero__title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--ink-soft);
}
.apps-hero__lede {
  margin: 24px 0 0;
  max-width: 56ch;
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1.45;
  color: var(--ink-soft);
}

.apps-stats {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 720px;
}
@media (min-width: 720px) { .apps-stats { grid-template-columns: repeat(4, 1fr); } }

.apps-stat__val {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 3.2vw, 40px);
  letter-spacing: -0.03em;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
}
.apps-stat__label {
  margin-top: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-mute);
}

.apps-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 32px;
}
.apps-filters__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--paper-2);
  border: 1px solid var(--line-strong);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-soft);
  font-family: var(--font-sans);
  transition: all 200ms var(--ease);
}
.apps-filters__chip:hover { color: var(--ink); border-color: var(--ink); }
.apps-filters__chip.is-active {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

/* ===== App detail page ===== */
.app-detail__nav {
  padding-top: 110px;
  padding-bottom: 12px;
}
.app-detail__crumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
}
.app-detail__crumbs a { color: var(--ink-mute); transition: color 200ms; }
.app-detail__crumbs a:hover { color: var(--ink); }

.app-detail__hero {
  padding-block: clamp(24px, 4vw, 48px);
  position: relative;
  /* No overflow clip — the mesh + glow are allowed to bleed into
     the nav above and the section below. */
  isolation: isolate;
}
.app-detail__hero .mesh {
  inset: auto;
  top: -220px;
  right: -6%;
  bottom: -280px;
  width: 82%;
  height: auto;
  z-index: -1;
}

.app-detail__hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 48px;
  align-items: center;
}
@media (min-width: 980px) {
  .app-detail__hero-grid {
    grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
    gap: 64px;
  }
}

.app-detail__head {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 24px;
}

.app-detail__title {
  margin: 16px 0 0;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(40px, 5vw, 64px);
  letter-spacing: -0.03em;
  line-height: 1.02;
  color: var(--ink);
  text-wrap: balance;
}
.app-detail__title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--ink-soft);
}

.app-detail__tag {
  margin: 16px 0 0;
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.45;
  color: var(--ink-soft);
  max-width: 48ch;
}

.app-detail__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 22px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-mute);
}
.app-detail__meta-bar {
  width: 1px;
  height: 16px;
  background: var(--line-strong);
}

.app-detail__stores {
  margin-top: 28px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.app-detail__award {
  margin-top: 24px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: oklch(0.97 0.04 70);
  border: 1px solid oklch(0.86 0.10 70);
  border-radius: 12px;
  color: oklch(0.45 0.16 70);
  font-size: 13px;
  font-weight: 500;
}
.app-detail__award-icon {
  display: inline-flex;
}
[data-theme="dark"] .app-detail__award {
  background: oklch(0.22 0.06 70);
  border-color: oklch(0.30 0.07 70);
  color: oklch(0.82 0.13 70);
}

/* Phone stage — interactive showcase */
.phone-stage {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 52px 0 76px;
  perspective: 1400px;
  cursor: grab;
  touch-action: pan-y;
  user-select: none;
  -webkit-user-select: none;
  outline: none;
  border-radius: 24px;
}
.phone-stage.is-dragging { cursor: grabbing; }
.phone-stage:focus-visible {
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--ink) 30%, transparent);
}

.phone-stage__glow {
  position: absolute;
  /* Deliberately bleeds well past the stage — and past the hero section —
     so the color runs behind the breadcrumbs above and the section below. */
  inset: -24% -22% -30%;
  border-radius: 50%;
  background: radial-gradient(
    closest-side,
    oklch(0.62 0.16 var(--stage-hue, 270) / 0.26),
    oklch(0.62 0.16 var(--stage-hue, 270) / 0.08) 55%,
    transparent 80%
  );
  filter: blur(34px);
  pointer-events: none;
  z-index: 0;
}
[data-theme="dark"] .phone-stage__glow {
  background: radial-gradient(
    closest-side,
    oklch(0.55 0.18 var(--stage-hue, 270) / 0.38),
    oklch(0.55 0.18 var(--stage-hue, 270) / 0.1) 58%,
    transparent 78%
  );
}

.phone-stage__tilt {
  position: relative;
  width: 100%;
  height: 672px;
  display: flex;
  justify-content: center;
  align-items: center;
  transform-style: preserve-3d;
  transition: transform 480ms var(--ease);
  z-index: 1;
}

.phone-stage__phone {
  position: absolute;
  transition: transform 620ms var(--ease), filter 620ms var(--ease), opacity 620ms var(--ease);
}

/* Floating live-stat chips */
.phone-stage__chip {
  position: absolute;
  z-index: 6;
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: color-mix(in oklab, var(--paper-2) 82%, transparent);
  backdrop-filter: blur(12px) saturate(1.4);
  -webkit-backdrop-filter: blur(12px) saturate(1.4);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.4),
    0 10px 28px -14px oklch(0.16 0.015 270 / 0.35);
  pointer-events: none;
  transition: transform 600ms var(--ease);
}
[data-theme="dark"] .phone-stage__chip {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 10px 28px -14px rgba(0, 0, 0, 0.6);
}
.phone-stage__chip-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-mute);
  white-space: nowrap;
}
.phone-stage__chip-value {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
  white-space: nowrap;
}
.phone-stage__chip--tr { top: 12%; right: -2%; animation: stage-bob 5.4s ease-in-out infinite; }
.phone-stage__chip--bl { bottom: 15%; left: -2%; animation: stage-bob 6.2s ease-in-out 0.8s infinite; }
.phone-stage__chip--ml { top: 47%; left: -5%; animation: stage-bob 5.8s ease-in-out 1.6s infinite; }
@media (max-width: 1180px) {
  .phone-stage__chip--ml { display: none; }
}

@keyframes stage-bob {
  0%, 100% { margin-top: 0; }
  50% { margin-top: -8px; }
}
@media (prefers-reduced-motion: reduce) {
  .phone-stage__chip--tr, .phone-stage__chip--bl, .phone-stage__chip--ml { animation: none; }
}

/* Drag hint */
.phone-stage__hint {
  position: absolute;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-mute);
  white-space: nowrap;
  opacity: 0.85;
  transition: opacity 300ms var(--ease);
  pointer-events: none;
  z-index: 6;
}
.phone-stage.is-dragging .phone-stage__hint { opacity: 0; }

/* Named screen tabs with auto-advance fill */
.phone-stage__tabs {
  position: absolute;
  bottom: 14px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  padding: 4px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: color-mix(in oklab, var(--paper-2) 80%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 10;
}
.phone-stage__tab {
  position: relative;
  overflow: hidden;
  height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-mute);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color 220ms var(--ease), background 220ms var(--ease);
}
.phone-stage__tab:hover { color: var(--ink); }
.phone-stage__tab.is-active {
  color: var(--paper);
  background: var(--ink);
}
.phone-stage__tab-text { position: relative; z-index: 1; white-space: nowrap; }
.phone-stage__tab-fill {
  position: absolute;
  inset: 0;
  transform-origin: left;
  background: color-mix(in oklab, var(--paper) 22%, transparent);
  animation-name: stage-tab-fill;
  animation-timing-function: linear;
  animation-fill-mode: forwards;
}
@keyframes stage-tab-fill {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

@media (max-width: 720px) {
  .phone-stage { padding: 44px 0 64px; }
  .phone-stage__tilt { height: 600px; transform: scale(0.92); }
  .phone-stage__chip--tr { right: 0; top: 9%; }
  .phone-stage__chip--bl { left: 0; bottom: 12%; }
  .phone-stage__tab { padding: 0 10px; }
}

/* Faux app screens inside the iPhone frame */
.appscreen {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  font-family: var(--font-sans);
  color: #1c1c1e;
  --app-accent: oklch(0.55 0.18 250);
}

.appscreen__header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 60px 22px 14px;
}
.appscreen__avatar {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.appscreen__avatar--big { width: 72px; height: 72px; font-size: 24px; border-radius: 999px; }
.appscreen__title { flex: 1; min-width: 0; }
.appscreen__name {
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -0.015em;
}
.appscreen__sub {
  font-size: 11px;
  color: rgba(60, 60, 67, 0.65);
}
.appscreen__chip {
  width: 32px; height: 32px;
  border-radius: 999px;
  background: rgba(0,0,0,0.06);
}

.appscreen__body {
  flex: 1;
  padding: 0 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
}

.appscreen__hero {
  padding: 18px 18px 20px;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.05);
  box-shadow: 0 1px 0 rgba(255,255,255,0.6) inset, 0 10px 24px -16px rgba(0,0,0,0.18);
}
.appscreen__hero-label {
  font-size: 11px;
  color: rgba(60,60,67,0.65);
  letter-spacing: -0.005em;
}
.appscreen__hero-val {
  margin-top: 4px;
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.025em;
  font-variant-numeric: tabular-nums;
}
.appscreen__hero-meta {
  margin-top: 8px;
  font-size: 12px;
  font-weight: 500;
}

.appscreen__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.appscreen__card {
  padding: 12px 10px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.05);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.appscreen__card-h { height: 4px; width: 60%; border-radius: 99px; background: rgba(0,0,0,0.08); }
.appscreen__card-v { height: 16px; width: 80%; border-radius: 3px; background: rgba(0,0,0,0.16); margin-bottom: 4px; }
.appscreen__card-bar { height: 28px; border-radius: 6px; background: linear-gradient(180deg, var(--app-accent), transparent); opacity: 0.5; }

.appscreen__row {
  display: grid;
  grid-template-columns: 8px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.04);
  font-size: 13px;
}
.appscreen__row-dot { width: 8px; height: 8px; border-radius: 999px; }
.appscreen__row-name { color: #1c1c1e; font-weight: 500; }
.appscreen__row-val { font-family: var(--font-mono); font-size: 12px; font-variant-numeric: tabular-nums; }
.appscreen__row-val.is-up   { color: oklch(0.55 0.16 145); }
.appscreen__row-val.is-down { color: oklch(0.55 0.16 25);  }

.appscreen__pair {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 16px 18px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.05);
}
.appscreen__pair span { font-size: 12px; color: rgba(60,60,67,0.65); }
.appscreen__pair strong { font-size: 20px; font-weight: 600; font-variant-numeric: tabular-nums; }

.appscreen__chart {
  width: 100%;
  height: 110px;
  background: #fff;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,0.05);
  padding: 6px;
}

.appscreen__pillrow {
  display: flex;
  gap: 8px;
}
.appscreen__pill {
  flex: 1;
  text-align: center;
  padding: 12px 0;
  border-radius: 12px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.06);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.005em;
}

.appscreen__video {
  position: relative;
  height: 220px;
  border-radius: 18px;
  overflow: hidden;
  display: grid;
  place-items: center;
}
.appscreen__video-tag {
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(0,0,0,0.45);
  color: #fff;
  padding: 4px 9px;
  font-family: var(--font-mono);
  font-size: 10px;
  border-radius: 99px;
  letter-spacing: 0.06em;
}
.appscreen__caption { font-size: 13px; color: rgba(60,60,67,0.7); text-align: center; }

.appscreen__weekrow {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.appscreen__day {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 8px 0;
  border-radius: 12px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.04);
  font-size: 13px;
  font-weight: 600;
}
.appscreen__day small {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(60,60,67,0.65);
}
.appscreen__day strong { font-size: 15px; }

.appscreen__schedule-row {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 8px;
  padding: 12px 14px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.04);
  font-size: 12px;
}
.appscreen__schedule-t { font-family: var(--font-mono); color: rgba(60,60,67,0.65); }
.appscreen__schedule-l { display: flex; align-items: center; gap: 8px; font-weight: 500; }

.appscreen__map {
  height: 200px;
  border-radius: 18px;
  overflow: hidden;
  background: #f4f4f8;
  border: 1px solid rgba(0,0,0,0.05);
}
.appscreen__map svg { display: block; width: 100%; height: 100%; }
.appscreen__map-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.05);
}

.appscreen__lesson-meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; color: rgba(60,60,67,0.65); }
.appscreen__lesson-title { font-size: 22px; font-weight: 600; letter-spacing: -0.025em; margin-top: 4px; }
.appscreen__lesson-frac {
  margin-top: 10px;
  padding: 18px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.05);
  font-family: var(--font-serif);
  font-size: 22px;
  font-style: italic;
  display: flex;
  align-items: center;
  gap: 8px;
}
.appscreen__frac { display: inline-flex; flex-direction: column; align-items: center; line-height: 1; }
.appscreen__frac span:first-child { border-bottom: 1px solid currentColor; padding-bottom: 2px; }
.appscreen__frac span:last-child { padding-top: 2px; }

.appscreen__progress {
  height: 6px;
  border-radius: 99px;
  background: rgba(0,0,0,0.08);
  overflow: hidden;
  margin-top: 4px;
}
.appscreen__progress-fill { height: 100%; border-radius: inherit; transition: width 800ms var(--ease); }

.appscreen__chat {
  gap: 10px;
}
.appscreen__bubble {
  max-width: 80%;
  padding: 10px 14px;
  border-radius: 18px;
  font-size: 13px;
  line-height: 1.4;
}
.appscreen__bubble--in {
  align-self: flex-start;
  background: rgba(0,0,0,0.05);
  color: #1c1c1e;
  border-bottom-left-radius: 4px;
}
.appscreen__bubble--out {
  align-self: flex-end;
  background: var(--app-accent);
  color: #fff;
  border-bottom-right-radius: 4px;
}
.appscreen__typing {
  align-self: flex-start;
  display: inline-flex;
  gap: 4px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(0,0,0,0.05);
}
.appscreen__typing span {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: rgba(0,0,0,0.4);
  animation: appscreen-typing 1.4s var(--ease) infinite;
}
.appscreen__typing span:nth-child(2) { animation-delay: 0.15s; }
.appscreen__typing span:nth-child(3) { animation-delay: 0.30s; }
@keyframes appscreen-typing {
  0%, 80%, 100% { transform: scale(0.7); opacity: 0.5; }
  40%           { transform: scale(1);   opacity: 1; }
}

.appscreen__tabbar {
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 14px 24px 28px;
  background: rgba(255,255,255,0.6);
  backdrop-filter: blur(20px);
  border-top: 1px solid rgba(0,0,0,0.06);
}
.appscreen__tab {
  width: 30px;
  height: 4px;
  border-radius: 99px;
  background: rgba(0,0,0,0.18);
}
.appscreen__tab.is-active { background: var(--app-accent); }

/* ===== Detail features grid ===== */
.app-features {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 20px;
}
@media (min-width: 720px)  { .app-features { grid-template-columns: repeat(2, 1fr); } }

.app-feature {
  padding: 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: var(--paper-2);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.app-feature__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
}
.app-feature__title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 19px;
  letter-spacing: -0.018em;
}
.app-feature__desc {
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
}

/* ===== Tech stack pills ===== */
.app-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.app-stack__pill {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--paper-2);
  border: 1px solid var(--line-strong);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-soft);
}

/* ===== Press quotes ===== */
.app-press {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
}
@media (min-width: 720px) { .app-press { grid-template-columns: repeat(2, 1fr); } }

.app-press__card {
  padding: 22px;
  border-radius: var(--radius-lg);
  background: var(--paper-2);
  border: 1px solid var(--line);
}
.app-press__quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  line-height: 1.4;
  color: var(--ink);
  margin: 0;
  text-wrap: balance;
}
.app-press__source {
  margin-top: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ===== Related apps row ===== */
.app-related {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
}
@media (min-width: 720px) { .app-related { grid-template-columns: repeat(3, 1fr); } }
.app-related--peek { gap: 20px; }

/* ===== App marquee (homepage) ===== */
.app-marquee {
  padding-block: clamp(40px, 6vw, 64px);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: color-mix(in oklab, var(--ink) 3%, var(--paper-2));
  overflow: hidden;
  position: relative;
}
.app-marquee__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}
.app-marquee__title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(20px, 2.2vw, 28px);
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
}
.app-marquee__title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--ink-soft);
}
.app-marquee__cta {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--ink);
  display: inline-flex;
  gap: 6px;
  align-items: center;
}

.app-marquee__track {
  display: flex;
  gap: 18px;
  width: max-content;
  animation: appMarquee 32s linear infinite;
}
.app-marquee:hover .app-marquee__track { animation-play-state: paused; }
@keyframes appMarquee {
  to { transform: translateX(calc(-100% / 2)); }
}

/* ===== Testimonials section (homepage) ===== */
.testimonials__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 20px;
}
@media (min-width: 760px)  { .testimonials__grid { grid-template-columns: repeat(2, 1fr); } }

.testimonial {
  padding: 28px;
  border-radius: var(--radius-lg);
  background: var(--paper-2);
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  overflow: hidden;
  transition: border-color 240ms var(--ease), transform 240ms var(--ease);
}
.testimonial:hover { border-color: var(--ink); transform: translateY(-2px); }

.testimonial__mark {
  color: var(--accent);
  opacity: 0.5;
  align-self: flex-start;
}

.testimonial__quote {
  font-family: var(--font-serif);
  font-size: clamp(20px, 1.8vw, 26px);
  font-style: italic;
  font-weight: 400;
  line-height: 1.35;
  color: var(--ink);
  margin: 0;
  text-wrap: pretty;
}

.testimonial__by {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 4px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.testimonial__avatar {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  letter-spacing: -0.01em;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.3);
}

.testimonial__name {
  display: block;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.testimonial__role {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  margin-top: 2px;
}

/* ===== Sticky CTA ===== */
.sticky-cta {
  position: fixed;
  bottom: 24px;
  left: 50%;
  z-index: 80;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 8px 8px 8px 22px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  box-shadow:
    0 24px 48px -16px oklch(0.16 0.015 270 / 0.30),
    inset 0 1px 0 rgba(255,255,255,0.55);
  transform: translate3d(-50%, 16px, 0);
  opacity: 0;
  pointer-events: none;
  transition:
    transform 380ms cubic-bezier(0.34, 1.3, 0.64, 1),
    opacity 280ms var(--ease);
}
.sticky-cta.is-shown {
  transform: translate3d(-50%, 0, 0);
  opacity: 1;
  pointer-events: auto;
}

.sticky-cta__label {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
  white-space: nowrap;
}

.sticky-cta__btn {
  margin-left: 4px;
}

.sticky-cta__close {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--ink-mute);
  transition: background 200ms var(--ease), color 200ms var(--ease);
  margin-right: 2px;
}
.sticky-cta__close:hover {
  background: color-mix(in oklab, var(--ink) 8%, transparent);
  color: var(--ink);
}

@media (max-width: 560px) {
  .sticky-cta { padding: 6px 6px 6px 16px; gap: 10px; }
  .sticky-cta__label { font-size: 13px; }
}

[data-theme="dark"] .sticky-cta {
  box-shadow:
    0 24px 48px -16px rgba(0,0,0,0.5),
    inset 0 1px 0 rgba(255,255,255,0.08);
}

/* ===== Subpage hero (shared by /about, /careers, /pricing) ===== */
.sub-hero {
  position: relative;
  padding-top: 140px;
  padding-bottom: clamp(48px, 7vw, 80px);
  overflow: hidden;
  isolation: isolate;
}
.sub-hero__head { max-width: 920px; position: relative; z-index: 1; }
.sub-hero__title {
  margin: 16px 0 0;
  font-family: var(--font-sans);
  font-weight: 500;
  letter-spacing: -0.035em;
  line-height: 0.96;
  font-size: clamp(48px, 7vw, 96px);
  color: var(--ink);
  text-wrap: balance;
}
.sub-hero__title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--ink-soft);
}
.sub-hero__lede {
  margin: 24px 0 0;
  max-width: 56ch;
  font-size: clamp(17px, 1.4vw, 22px);
  line-height: 1.45;
  color: var(--ink-soft);
}

/* ===== About / Team page ===== */
.about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 80px;
}
@media (min-width: 980px) { .about-grid { grid-template-columns: minmax(0, 5fr) minmax(0, 7fr); gap: 96px; align-items: start; } }

.about-founder {
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: relative;
}
.about-founder__photo {
  width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, oklch(0.68 0.18 285), oklch(0.45 0.20 245));
  display: grid;
  place-items: center;
  color: rgba(255,255,255,0.92);
  font-family: var(--font-sans);
  font-size: 86px;
  font-weight: 500;
  letter-spacing: -0.04em;
}
.about-founder__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 14px, transparent 14px 28px);
}
.about-founder__photo--img { background: var(--paper-2); }
.about-founder__photo--img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 25%;
  display: block;
}
.about-founder__photo--img::after { display: none; }
.about-founder__caption {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.about-founder__quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(24px, 2.6vw, 36px);
  line-height: 1.25;
  color: var(--ink);
  margin: 0;
  text-wrap: balance;
}

.about-founder__sig {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-top: 8px;
}
.about-founder__sig strong { font-size: 17px; font-weight: 500; letter-spacing: -0.02em; }
.about-founder__sig span   { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.05em; color: var(--ink-mute); text-transform: uppercase; }

.about-founder__bio {
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 4px 0 0;
}

.about-story {
  display: flex;
  flex-direction: column;
  gap: 22px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink-soft);
  text-wrap: pretty;
}
.about-story p { margin: 0; }
.about-story em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--ink);
}

.about-stats {
  margin-top: 56px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
@media (min-width: 720px) { .about-stats { grid-template-columns: repeat(4, 1fr); } }
.about-stat {
  padding: 22px 0;
  border-top: 1px solid var(--line-strong);
}
.about-stat__val {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(34px, 4vw, 52px);
  letter-spacing: -0.03em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.about-stat__label {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* Team grid */
.team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
@media (min-width: 720px)  { .team-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1080px) { .team-grid { grid-template-columns: repeat(4, 1fr); } }

.team-card {
  padding: 18px;
  border-radius: var(--radius);
  background: var(--paper-2);
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.team-card__photo {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 28px;
  font-weight: 500;
  letter-spacing: -0.02em;
  font-family: var(--font-sans);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.25);
}
.team-card__name {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.team-card__role {
  font-size: 13px;
  color: var(--ink-soft);
  margin-top: 2px;
}
.team-card__loc {
  margin-top: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.team-card__loc::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--accent);
}

/* Values list */
.values-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
}
@media (min-width: 760px) { .values-list { grid-template-columns: repeat(2, 1fr); gap: 0 64px; } }
.values-list li {
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 16px;
  align-items: baseline;
}
.values-list li .num {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}
.values-list li strong {
  display: block;
  font-size: 17px;
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.values-list li p {
  margin: 6px 0 0;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.5;
}

/* ===== Careers page ===== */
.careers-perks {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
}
@media (min-width: 760px)  { .careers-perks { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .careers-perks { grid-template-columns: repeat(4, 1fr); } }

.perk {
  padding: 20px;
  border: 1px solid var(--line);
  background: var(--paper-2);
  border-radius: var(--radius);
}
.perk__title {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin-bottom: 6px;
}
.perk__desc {
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.5;
  margin: 0;
}

.role-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--line);
}
.role-row {
  border-bottom: 1px solid var(--line);
}
.role-row__link {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto auto;
  gap: 24px;
  align-items: center;
  padding: 22px 4px;
  color: var(--ink);
  transition: color 220ms var(--ease), padding 220ms var(--ease);
}
.role-row__link:hover {
  color: var(--accent);
  padding-left: 14px;
}
.role-row__title {
  font-size: clamp(19px, 1.8vw, 23px);
  font-weight: 500;
  letter-spacing: -0.018em;
}
.role-row__meta {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-mute);
}
.role-row__chev {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: var(--paper-2);
  border: 1px solid var(--line-strong);
  color: var(--ink);
  transition: transform 240ms var(--ease), background 240ms var(--ease), color 240ms var(--ease);
}
.role-row__link:hover .role-row__chev {
  background: var(--ink);
  color: var(--paper);
  transform: translateX(3px);
}
@media (max-width: 720px) {
  .role-row__link { grid-template-columns: 1fr auto; gap: 12px 16px; }
  .role-row__meta { grid-column: 1 / -1; }
}

.process-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  counter-reset: step;
}
@media (min-width: 760px) { .process-steps { grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); } }

.process-step {
  counter-increment: step;
  padding: 24px 0;
  border-bottom: 1px solid var(--line);
  position: relative;
}
@media (min-width: 760px) {
  .process-step { border-bottom: 0; padding: 28px 28px 28px 0; border-right: 1px solid var(--line); }
  .process-step:last-child { border-right: 0; padding-right: 0; }
}
.process-step__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--accent);
  text-transform: uppercase;
}
.process-step__title {
  margin: 10px 0 8px;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
}
.process-step__desc {
  font-size: 14px;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
}

/* ===== Pricing page ===== */
.pricing-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
}
@media (min-width: 760px) { .pricing-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .pricing-grid { grid-template-columns: repeat(4, 1fr); } }

.tier {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 28px 26px 32px;
  border: 1px solid var(--line);
  background: var(--paper-2);
  border-radius: var(--radius-lg);
  transition: border-color 240ms var(--ease), transform 240ms var(--ease);
}
.tier:hover { border-color: var(--ink); transform: translateY(-3px); }

.tier--featured {
  border-color: var(--accent);
  box-shadow: 0 22px 48px -22px oklch(0.62 0.18 var(--accent-hue) / 0.35);
}
.tier--featured::before {
  content: "Most popular";
  position: absolute;
  top: -10px;
  left: 22px;
  background: var(--ink);
  color: var(--paper);
  padding: 2px 10px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.tier__name {
  font-size: 19px;
  font-weight: 500;
  letter-spacing: -0.018em;
  color: var(--ink);
}
.tier__price {
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.tier__amount {
  font-family: var(--font-sans);
  font-size: 38px;
  font-weight: 500;
  letter-spacing: -0.035em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.tier__unit {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-mute);
}
.tier__blurb {
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.5;
  margin: 0;
  min-height: 56px;
}
.tier__list {
  list-style: none;
  margin: 12px 0 0;
  padding: 16px 0 0;
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.tier__list li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 8px;
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.4;
}
.tier__list li::before {
  content: "";
  width: 8px;
  height: 8px;
  margin-top: 6px;
  border-radius: 99px;
  background: var(--accent);
}
.tier__cta {
  margin-top: 14px;
}

/* ===== Contact page ===== */
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 56px;
}
@media (min-width: 920px) {
  .contact-grid { grid-template-columns: minmax(0, 4fr) minmax(0, 7fr); gap: 80px; align-items: start; }
}

.contact-aside {
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: relative;
}
@media (min-width: 920px) {
  .contact-aside { position: sticky; top: 110px; }
}

.contact-channel {
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
}
.contact-channel:last-child { border-bottom: 0; }
.contact-channel__label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--ink-mute);
}
.contact-channel__val {
  display: block;
  margin-top: 6px;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 19px;
  letter-spacing: -0.018em;
  color: var(--ink);
}
.contact-channel__val:hover { color: var(--accent); }
.contact-channel__sub {
  margin-top: 6px;
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.45;
}

.contact-offices ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.contact-offices li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
  font-size: 14px;
  color: var(--ink);
}
.contact-offices li:last-child { border-bottom: 0; }
.contact-offices li .mono-meta { font-size: 11px; }

.contact-form-wrap {
  padding: 32px;
  border-radius: var(--radius-lg);
  background: var(--paper-2);
  border: 1px solid var(--line);
  box-shadow: 0 24px 48px -28px oklch(0.16 0.015 270 / 0.18);
}
@media (max-width: 720px) { .contact-form-wrap { padding: 24px; } }

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.contact-form__row { display: flex; flex-direction: column; gap: 24px; }
.contact-form__row--two { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 600px) { .contact-form__row--two { grid-template-columns: 1fr 1fr; } }

.contact-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.contact-field__label {
  display: flex;
  align-items: baseline;
  gap: 8px;
  flex-wrap: wrap;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.contact-field__req { color: var(--accent); }
.contact-field__hint {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 400;
  color: var(--ink-mute);
  letter-spacing: 0;
}

.contact-field input[type="text"],
.contact-field input[type="email"],
.contact-field textarea {
  width: 100%;
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--ink);
  background: var(--paper);
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  padding: 12px 14px;
  transition: border-color 200ms var(--ease), box-shadow 200ms var(--ease);
}
.contact-field input:focus,
.contact-field textarea:focus {
  outline: none;
  border-color: var(--ink);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--ink) 8%, transparent);
}
.contact-field textarea { resize: vertical; min-height: 120px; line-height: 1.5; }

/* Service chips (multi-select) */
.contact-form__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.contact-chip {
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--paper);
  border: 1px solid var(--line-strong);
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-soft);
  transition: all 200ms var(--ease);
}
.contact-chip:hover { color: var(--ink); border-color: var(--ink); }
.contact-chip.is-active {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

/* Dropdown select (Budget / Timeline) — matches the language switcher pill */
.contact-select {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  height: 44px;
  padding: 0 14px;
  border-radius: 12px;
  background: var(--paper);
  border: 1px solid var(--line-strong);
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink-fade);
  letter-spacing: -0.005em;
  cursor: pointer;
  transition: border-color 200ms var(--ease), box-shadow 200ms var(--ease), color 200ms var(--ease);
}
.contact-select.has-value { color: var(--ink); font-weight: 500; }
.contact-select:hover { border-color: var(--ink); }
.contact-select[data-state="open"] {
  border-color: var(--ink);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--ink) 8%, transparent);
}
.contact-select__val { flex: 1; text-align: left; }

/* Make the dropdown panel match the trigger width */
.contact-select + .dropdown-menu__content .dropdown-menu__panel,
.dropdown-menu:has(.contact-select) .dropdown-menu__panel {
  min-width: 100%;
}
.contact-segments {
  position: relative;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 2px;
  padding: 4px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--ink) 5%, var(--paper-2));
  border: 1px solid var(--line);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
  width: 100%;
  min-width: 0;
}
.contact-segment {
  flex: 1 1 auto;
  min-width: 0;
  position: relative;
  padding: 9px 14px;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-soft);
  text-align: center;
  background: transparent;
  border: 1px solid transparent;
  white-space: nowrap;
  cursor: pointer;
  transition:
    background 280ms var(--ease),
    color 280ms var(--ease),
    border-color 280ms var(--ease),
    box-shadow 280ms var(--ease),
    font-weight 0ms;
}
.contact-segment:hover { color: var(--ink); }
.contact-segment.is-active {
  background: var(--paper-2);
  color: var(--ink);
  font-weight: 600;
  border-color: var(--line-strong);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.95),
    inset 0 -1px 0 rgba(255, 255, 255, 0.35),
    0 1px 2px oklch(0.16 0.015 270 / 0.06),
    0 6px 16px -6px oklch(0.16 0.015 270 / 0.18);
}

[data-theme="dark"] .contact-segments {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
}
[data-theme="dark"] .contact-segment.is-active {
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.20),
    0 1px 2px rgba(0, 0, 0, 0.25),
    0 6px 16px -6px rgba(0, 0, 0, 0.5);
}

/* When the row of segments is in a narrow column, allow them to wrap to 2 rows */
@media (max-width: 540px) {
  .contact-segment { flex-basis: calc(50% - 2px); }
}

/* File drop */
.contact-drop {
  border: 2px dashed var(--line-strong);
  border-radius: 14px;
  padding: 28px 20px;
  text-align: center;
  background: var(--paper);
  cursor: pointer;
  transition: border-color 200ms var(--ease), background 200ms var(--ease);
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
}
.contact-drop:hover,
.contact-drop.is-dragging {
  border-color: var(--accent);
  background: var(--accent-soft);
}
.contact-drop.has-file { padding: 18px 20px; cursor: default; }
.contact-drop strong { font-size: 14px; font-weight: 500; color: var(--ink); }
.contact-drop span { font-size: 12px; color: var(--ink-mute); }
.contact-drop__file {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-family: var(--font-mono);
  color: var(--ink);
}
.contact-drop__file button {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--paper-sunk);
  color: var(--ink-mute);
  font-size: 12px;
  line-height: 1;
  border: 1px solid var(--line-strong);
}
.contact-drop__file button:hover { color: var(--ink); border-color: var(--ink); }

.contact-form__submit {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding-top: 8px;
  flex-wrap: wrap;
}
.contact-form__note {
  font-size: 12px;
  color: var(--ink-mute);
  line-height: 1.45;
  max-width: 36ch;
  margin: 0;
}

.contact-success {
  text-align: center;
  padding: 24px 8px;
}
.contact-success__check {
  width: 64px;
  height: 64px;
  margin: 0 auto 18px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  display: grid;
  place-items: center;
}

/* ===== Process / Timeline page ===== */
.timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 32px;
  position: relative;
}

.timeline__rail {
  position: absolute;
  top: 32px;
  bottom: 32px;
  left: 27px;
  width: 2px;
  background: linear-gradient(180deg, var(--line-strong), var(--line) 60%, transparent);
  z-index: 0;
}
@media (min-width: 760px) {
  .timeline__rail { left: 35px; }
}

.timeline__phase {
  position: relative;
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
  z-index: 1;
}
@media (min-width: 760px) {
  .timeline__phase { grid-template-columns: 72px minmax(0, 1fr); gap: 32px; }
}

.timeline__node {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: #fff;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.3),
    0 8px 18px -6px rgba(0,0,0,0.22);
}
@media (min-width: 760px) {
  .timeline__node { width: 72px; height: 72px; font-size: 18px; border-radius: 20px; }
}

.timeline__card {
  padding: 24px 28px 26px;
  border-radius: var(--radius-lg);
  background: var(--paper-2);
  border: 1px solid var(--line);
  position: relative;
  transition: border-color 220ms var(--ease), transform 220ms var(--ease);
}
.timeline__card:hover { border-color: var(--ink); transform: translateY(-2px); }
.timeline__card::before {
  content: "";
  position: absolute;
  top: 28px;
  left: -10px;
  width: 12px;
  height: 12px;
  border-left: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--paper-2);
  transform: rotate(45deg);
}

.timeline__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.timeline__week {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 500;
}
.timeline__duration {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
}

.timeline__title {
  margin: 8px 0 0;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(22px, 2.3vw, 28px);
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.15;
}

.timeline__desc {
  margin: 12px 0 16px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-soft);
}

.timeline__bullets {
  list-style: none;
  margin: 0;
  padding: 16px 0;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 8px;
}
@media (min-width: 600px) {
  .timeline__bullets { grid-template-columns: repeat(2, 1fr); gap: 8px 24px; }
}
.timeline__bullets li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 8px;
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.4;
}
.timeline__bullets li::before {
  content: "";
  width: 6px;
  height: 6px;
  margin-top: 6px;
  border-radius: 99px;
  background: var(--accent);
}

.timeline__foot {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.timeline__foot-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.timeline__foot-val {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
}

/* ===== 404 page ===== */
.notfound {
  min-height: 100vh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: clamp(80px, 12vw, 140px) 24px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.notfound__code {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.08em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.notfound__title {
  margin: 16px 0 0;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(72px, 14vw, 200px);
  letter-spacing: -0.04em;
  line-height: 0.9;
  color: var(--ink);
}
.notfound__title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--ink-soft);
}
.notfound__lede {
  margin: 24px auto 0;
  max-width: 48ch;
  font-size: 17px;
  line-height: 1.5;
  color: var(--ink-soft);
}
.notfound__ctas {
  margin-top: 36px;
  display: inline-flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

.app-marquee__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px 12px 12px;
  border-radius: 18px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  flex-shrink: 0;
  text-decoration: none;
  transition: transform 220ms var(--ease), border-color 220ms var(--ease);
  min-width: 240px;
}
.app-marquee__item:hover {
  transform: translateY(-2px);
  border-color: var(--ink);
}
.app-marquee__item-name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 15px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.app-marquee__item-cat {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  text-transform: uppercase;
}

/* ===== Press strip (homepage) ===== */
.press-strip {
  padding-block: clamp(32px, 4vw, 48px);
  border-bottom: 1px solid var(--line);
}
.press-strip__label {
  text-align: center;
  margin-bottom: 22px;
}
.press-strip__row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: clamp(28px, 5vw, 56px);
}
.press-strip__logo {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 500;
  letter-spacing: -0.025em;
  color: var(--ink-fade);
  transition: color 200ms var(--ease);
}
.press-strip__logo:hover { color: var(--ink); }
.press-strip__logo--sans {
  font-family: var(--font-sans);
  font-style: normal;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: clamp(13px, 1.3vw, 17px);
}
.press-strip__logo--mono {
  font-family: var(--font-mono);
  font-style: normal;
  font-weight: 500;
  font-size: clamp(13px, 1.3vw, 16px);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
