/* ============================================================
   Tektome — Company page
   Light mode, brand tokens only. Display headings use the Light (300)
   weight with purple accent spans, matching the solution pages.
   One Arch Purple full-bleed band (the mission), per design system.
   ============================================================ */

.co-page {
  flex: 1;
  background: var(--color-draft-white);
  font-family: var(--font-sans);
  color: var(--fg-primary);
}

/* ---- shared ---- */
.co-inner {
  max-width: var(--site-width, 1100px);
  margin: 0 auto;
  padding: 0 40px;
}
/* OUR PURPOSE / OUR TEAM / CORPORATE INFO share one content width so
   their left + right edges align down the page. */
.co-mission .co-inner,
.co-team .co-inner,
.co-info[data-info="split"] .co-inner { max-width: 1040px; }
.co-inner--narrow { max-width: 880px; }
.co-h1 {
  font-family: var(--font-sans);
  font-weight: var(--fw-light);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--color-data-black);
  margin: 0;
  text-wrap: balance;
}
.co-h2 {
  font-family: var(--font-sans);
  font-weight: var(--fw-light);
  font-size: clamp(28px, 3.2vw, 42px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-data-black);
  margin: 0;
  text-wrap: balance;
}
.co-h1 .accent, .co-h2 .accent { color: var(--color-arch-purple); }

/* ===================== WHAT IS TEKTOME ===================== */
.co-intro { padding: clamp(56px, 8vw, 104px) 0 clamp(32px, 4vw, 48px); text-align: center; }
.co-intro .co-h1 { margin-bottom: 24px; }
.co-intro__lede {
  font-size: clamp(16px, 1.4vw, 18px);
  line-height: 1.75;
  color: var(--fg-secondary);
  margin: 0 auto;
  max-width: 720px;
  text-wrap: pretty;
}
.co-mark { margin-top: clamp(36px, 5vw, 56px); color: var(--color-data-black); display: flex; justify-content: center; }
.co-mark svg { width: 64px; height: 84px; }

/* ===================== MISSION ===================== */
.co-mission { padding: clamp(32px, 4vw, 48px) 0 clamp(56px, 7vw, 88px); text-align: center; }
.co-mission__title { margin-bottom: clamp(28px, 4vw, 44px); }
.co-mission__band {
  background: var(--color-arch-purple);
  border-radius: var(--radius-xl);
  padding: clamp(32px, 4vw, 48px) clamp(32px, 5vw, 72px);
  max-width: none;
  margin: 0;
}
.co-mission__band p {
  font-size: clamp(20px, 2.2vw, 28px);
  line-height: 1.45;
  font-weight: var(--fw-regular);
  color: var(--color-draft-white);
  margin: 0;
  text-wrap: balance;
}
.co-mission__band strong { font-weight: var(--fw-semibold); }
.co-mission__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: clamp(20px, 2.5vw, 28px);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-arch-purple);
  white-space: nowrap;
  transition: gap var(--duration-base) var(--ease-out);
}
.co-mission__link svg { width: 14px; height: 14px; }
.co-mission__link:hover { gap: 12px; }

/* ===================== FOUNDERS ===================== */
.co-founders { padding: clamp(40px, 5vw, 64px) 0 clamp(56px, 7vw, 88px); }
.co-founders__title { text-align: center; margin-bottom: clamp(40px, 5vw, 60px); }
.co-founders__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  max-width: 960px;
  margin: 0 auto;
}
.co-founder__photo {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--color-light-gray);
  margin-bottom: 20px;
}
.co-founder__photo img { display: block; width: 100%; height: 100%; object-fit: cover; }
.co-founder__name {
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--color-arch-purple);
  margin: 0 0 18px;
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 10px;
}
.co-founder__role {
  font-size: 13px;
  font-weight: var(--fw-semibold);
  color: var(--fg-tertiary);
  letter-spacing: 0;
}
.co-founder__bio p {
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--color-data-black);
  margin: 0 0 16px;
  text-wrap: pretty;
}
.co-founder__bio p:last-child { margin-bottom: 0; }
.co-founders__cta { display: flex; justify-content: center; margin-top: clamp(40px, 5vw, 60px); }

/* ===================== OUR TEAM ===================== */
.co-team { padding: clamp(40px, 5vw, 64px) 0 clamp(56px, 7vw, 88px); }
.co-team__title { text-align: center; margin-bottom: clamp(36px, 5vw, 52px); }
.co-team__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: none;
  margin: 0;
}
.co-team__grid--single {
  grid-template-columns: 1fr;
  max-width: 560px;
  margin: 0 auto;
}
.co-teamcard {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  text-decoration: none;
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 3.5vw, 40px);
  transition: border-color var(--duration-base) var(--ease-out),
    box-shadow var(--duration-base) var(--ease-out),
    transform var(--duration-base) var(--ease-out);
}
.co-teamcard:hover { border-color: var(--color-arch-purple); box-shadow: var(--shadow-md); }

/* Team CTA — no box. Member avatars (founder photos + roster monograms)
   over a lede and a text button, centered. Avatars are populated from the
   member-page data at runtime (see company.html), with a static fallback. */
.co-team__cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 26px;
}
.co-team__avatars { display: flex; justify-content: center; }
.co-team__avatar {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  font-size: 17px;
  letter-spacing: 0.02em;
  background: var(--a-bg, var(--purple-50));
  color: var(--a-ink, var(--color-arch-purple));
  border: 2px solid var(--color-draft-white);
  box-shadow: var(--shadow-xs);
  margin-left: -14px;
  overflow: hidden;
}
.co-team__avatar:first-child { margin-left: 0; }
.co-team__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.co-team__slot { width: 100%; height: 100%; display: block; }
.co-team__avatar--more {
  width: auto;
  min-width: 58px;
  padding: 0 18px;
  border-radius: var(--radius-pill);
  background: var(--color-light-gray);
  color: var(--fg-secondary);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.co-team__lede {
  font-size: clamp(16px, 1.4vw, 18px);
  line-height: 1.75;
  color: var(--color-data-black);
  margin: 0;
  max-width: 720px;
  text-wrap: pretty;
}
.co-team__cta .co-teamcard__cta:hover { gap: 12px; }
.co-teamcard__title {
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--color-data-black);
  margin: 0;
}
.co-teamcard__desc {
  font-size: 15px;
  line-height: 1.6;
  color: var(--fg-secondary);
  margin: 0;
  text-wrap: pretty;
  flex: 1;
}
.co-teamcard__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-arch-purple);
  white-space: nowrap;
  transition: gap var(--duration-base) var(--ease-out);
}
.co-teamcard__cta svg { width: 14px; height: 14px; }
.co-teamcard:hover .co-teamcard__cta { gap: 12px; }

/* ===================== CORPORATE INFO ===================== */
.co-info { padding: clamp(40px, 5vw, 64px) 0 clamp(72px, 9vw, 120px); }
.co-info__head { text-align: center; margin-bottom: clamp(24px, 3vw, 36px); }
.co-info__head--sub { margin-top: clamp(48px, 6vw, 72px); }
.co-info__sub {
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  font-size: clamp(20px, 2.2vw, 26px);
  color: var(--color-data-black);
  margin: 6px 0 0;
}
.co-table { margin: 0; }
.co-row {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  padding: 18px 8px;
  border-bottom: 1px solid var(--border-subtle);
  align-items: baseline;
}
.co-row:first-child { border-top: 1px solid var(--border-subtle); }
.co-row dt {
  font-size: 14px;
  font-weight: var(--fw-semibold);
  color: var(--color-data-black);
  margin: 0;
}
.co-row dd {
  font-size: 14px;
  color: var(--fg-secondary);
  margin: 0;
  text-wrap: pretty;
}

/* ===================== INFO-SECTION LAYOUT VARIATIONS ===================== */
/* Scoped to .co-info via data-info — independent of the page-wide design style.
   Wrappers (.co-infogroup) pair each head with its table. */
.co-infogroup { /* base: transparent, groups stacked */ }

/* --- "stacked" (default): two elevated white cards, one above the other --- */
.co-info[data-info="stacked"] .co-infogroup {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  padding: clamp(24px, 3.5vw, 40px) clamp(24px, 4vw, 48px);
}
.co-info[data-info="stacked"] .co-infogroup + .co-infogroup { margin-top: 24px; }
.co-info[data-info="stacked"] .co-info__head { text-align: left; margin-bottom: 20px; }
.co-info[data-info="stacked"] .co-info__head--sub { margin-top: 0; }
.co-info[data-info="stacked"] .co-row:first-child { border-top: 0; }
.co-info[data-info="stacked"] .co-row:last-child { border-bottom: 0; }
.co-info[data-info="stacked"] .co-row:last-child { padding-bottom: 0; }

/* --- "split": the two groups side by side as equal cards --- */
.co-info[data-info="split"] .co-infogroup {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  padding: clamp(24px, 3vw, 40px);
}
.co-info[data-info="split"] .co-inner--narrow { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: stretch; }
.co-info[data-info="split"] .co-eyebrow--left { grid-column: 1 / -1; }
.co-info[data-info="split"] .co-info__head { text-align: left; margin: 0 0 20px; }
.co-info[data-info="split"] .co-info__head--sub { margin-top: 0; }
.co-info[data-info="split"] .co-row { grid-template-columns: 1fr; gap: 4px; padding: 14px 0; }
.co-info[data-info="split"] .co-row:first-child { border-top: 0; }
.co-info[data-info="split"] .co-row:last-child { border-bottom: 0; padding-bottom: 0; }
.co-info[data-info="split"] .co-row dt { color: var(--fg-tertiary); font-size: 12px; }
.co-info[data-info="split"] .co-row dd { font-size: 15px; color: var(--color-data-black); }

/* --- "spec": tight definition grid — mono header, stacked label→value chips
   laid out in a multi-column spec sheet, no full-width rows --- */
.co-info[data-info="spec"] .co-info__head { text-align: left; margin-bottom: 20px; }
.co-info[data-info="spec"] .co-info__head .co-h2 {
  font-family: var(--font-mono);
  font-weight: var(--fw-semibold);
  font-size: 14px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-arch-purple);
}
.co-info[data-info="spec"] .co-info__sub { font-size: 14px; color: var(--fg-tertiary); margin-top: 4px; }
.co-info[data-info="spec"] .co-info__head--sub { margin-top: clamp(40px, 5vw, 56px); }
.co-info[data-info="spec"] .co-table {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--border-subtle);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.co-info[data-info="spec"] .co-row {
  display: block;
  grid-template-columns: none;
  background: var(--bg-surface);
  border: 0;
  padding: 18px 20px;
}
.co-info[data-info="spec"] .co-row dt {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-tertiary);
  margin-bottom: 6px;
}
.co-info[data-info="spec"] .co-row dd { font-size: 15px; color: var(--color-data-black); }
.co-info[data-info="spec"] .co-row:last-child:nth-child(odd) { grid-column: 1 / -1; }

/* ===================== EYEBROWS + DESIGN VARIATIONS ===================== */
/* Mono uppercase eyebrow — a signature brand motif. Hidden by default;
   each variation opts in. */
.co-eyebrow {
  display: none;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-arch-purple);
  margin: 0 0 16px;
}
.co-intro .co-eyebrow, .co-mission .co-eyebrow, .co-founders .co-eyebrow, .co-team .co-eyebrow { text-align: center; }

/* ---------- Variation 1: Editorial ----------
   Whitespace-led, mono eyebrows, hairline rules, light-blue mission-section
   wash, restrained. The most brand-guide-faithful direction. */
.co-page[data-variant="editorial"] .co-eyebrow { display: block; }
.co-page[data-variant="editorial"] .co-mission {
  background: var(--bg-section-alt);
  margin-top: clamp(8px, 2vw, 24px);
}
.co-page[data-variant="editorial"] .co-founders__title,
.co-page[data-variant="editorial"] .co-info__head {
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: clamp(40px, 5vw, 60px);
}
.co-page[data-variant="editorial"] .co-founder__name { color: var(--color-data-black); }
.co-page[data-variant="editorial"] .co-founder__role { color: var(--color-arch-purple); }

/* ---------- Variation 2: Blueprint ----------
   Architectural feel: faint blueprint grid behind hero + mission, sky/lavender
   section alternation, the one allowed purple gradient on the mission band,
   bordered (squared) founder cards, mono role specs. */
.co-page[data-variant="blueprint"] .co-eyebrow { display: block; }
.co-page[data-variant="blueprint"] .co-intro {
  background:
    radial-gradient(120% 90% at 50% -10%, var(--purple-50) 0%, rgba(236,236,252,0) 60%),
    var(--color-draft-white);
}
.co-page[data-variant="blueprint"] .co-mission {
  background: var(--color-draft-white);
}
.co-page[data-variant="blueprint"] .co-mission__band {
  background: var(--gradient-hero, linear-gradient(115deg, #5156DB, #8A8DE8, #AAA6F0));
}
.co-page[data-variant="blueprint"] .co-founders { background: var(--color-draft-white); }
.co-page[data-variant="blueprint"] .co-founder {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  padding: 0 0 26px;
}
.co-page[data-variant="blueprint"] .co-founder__photo { margin-bottom: 22px; }
.co-page[data-variant="blueprint"] .co-founder__name,
.co-page[data-variant="blueprint"] .co-founder__bio { padding-left: 24px; padding-right: 24px; }
.co-page[data-variant="blueprint"] .co-founder__name { color: var(--color-data-black); }
.co-page[data-variant="blueprint"] .co-founder__role {
  font-family: var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 11px;
  color: var(--color-arch-purple);
}
.co-page[data-variant="blueprint"] .co-info { background: var(--color-sky-50); }
.co-page[data-variant="blueprint"] .co-row {
  border-color: var(--color-sky-200);
}
.co-page[data-variant="blueprint"] .co-row:first-child { border-top-color: var(--color-sky-200); }

/* ---------- Variation 3: Soft cards ----------
   Light-gray canvas with elevated white cards for founders and the corporate
   info blocks; solid purple mission band; warmer, rounded, product-like. */
.co-page[data-variant="soft"] { background: var(--color-light-gray); }
.co-page[data-variant="soft"] .co-eyebrow { display: block; }
.co-page[data-variant="soft"] .co-intro,
.co-page[data-variant="soft"] .co-mission,
.co-page[data-variant="soft"] .co-founders,
.co-page[data-variant="soft"] .co-info { background: transparent; }
.co-page[data-variant="soft"] .co-founder {
  background: var(--bg-surface);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  padding: 0 0 28px;
  overflow: hidden;
}
.co-page[data-variant="soft"] .co-founder__photo { margin-bottom: 22px; }
.co-page[data-variant="soft"] .co-founder__name,
.co-page[data-variant="soft"] .co-founder__bio { padding-left: 26px; padding-right: 26px; }
.co-page[data-variant="soft"] .co-info__group,
.co-page[data-variant="soft"] .co-table {
  background: var(--bg-surface);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  padding: clamp(20px, 3vw, 36px) clamp(24px, 4vw, 44px);
}
.co-page[data-variant="soft"] .co-row:first-child { border-top: 0; }
.co-page[data-variant="soft"] .co-row:last-child { border-bottom: 0; }

/* ===================== RESPONSIVE ===================== */
@media (max-width: 820px) {
  .co-founders__grid { grid-template-columns: 1fr; gap: 48px; max-width: 480px; }
  .co-team__grid { grid-template-columns: 1fr; max-width: 480px; }
}
@media (max-width: 640px) {
  .co-inner { padding-left: 24px; padding-right: 24px; }
  .co-row { grid-template-columns: 1fr; gap: 4px; }
}
