/* ============================================================
   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.
   ============================================================ */

/* ---- Scroll reveal (fade + rise) — the single animation workflow on
   this page. [data-reveal] is added by JS, so without JS / on failure
   elements stay visible. Gated behind reduced-motion. Specificity scoped
   to .co-page[data-variant] so it wins over later-loaded transitions. ---- */
@media (prefers-reduced-motion: no-preference) {
  .co-page[data-variant] [data-reveal] {
    opacity: 0;
    transform: translate(var(--reveal-x, 0px), var(--reveal-y, 12px));
    transition-property: opacity, transform;
    transition-duration: var(--reveal-dur, 320ms);
    transition-timing-function: var(--ease-out, cubic-bezier(0.2, 0.8, 0.2, 1));
    transition-delay: var(--reveal-delay, 0ms);
    will-change: opacity, transform;
  }
  .co-page[data-variant] [data-reveal].is-revealed { opacity: 1; transform: none; }
}

.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;
}
.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: 17px;
  line-height: 1.7;
  color: var(--fg-secondary);
  margin: 0 auto;
  max-width: 620px;
  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); }
/* Mission CTA card — mirrors the Leadership & Team banner card, with the
   Tektome hexagon mark in the icon slot in place of the founder photos. */
/* Vision & Philosophy card visibility (baked default: hidden). */
.co-mission[data-vision="hidden"] .co-mission__cardwrap { display: none; }
.co-mission__cardwrap {
  max-width: none;
  margin: clamp(28px, 4vw, 44px) 0 0;
  text-align: left;
}
.co-mission__cardwrap .co-mission__card {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  align-items: center;
  gap: 22px;
}
.co-mission__cardwrap .co-mission__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  grid-row: 1 / span 2;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-md);
  background: var(--purple-50);
  color: var(--color-arch-purple);
}
.co-mission__cardwrap .co-mission__mark svg { width: auto; height: 34px; display: block; }
.co-mission__cardwrap .co-teamcard__title { grid-column: 2; }
.co-mission__cardwrap .co-teamcard__desc { grid-column: 2; flex: none; }
.co-mission__cardwrap .co-teamcard__cta { grid-column: 3; grid-row: 1 / span 2; white-space: nowrap; }
@media (max-width: 560px) {
  .co-mission__cardwrap .co-mission__card { grid-template-columns: 56px 1fr; }
  .co-mission__cardwrap .co-teamcard__cta { grid-column: 2; grid-row: auto; }
}

/* OUR PURPOSE / OUR TEAM / CORPORATE INFO share one content width */
.co-mission .co-inner,
.co-team .co-inner,
.co-info[data-info="split"] .co-inner { max-width: 1040px; }

/* ===================== 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;
  gap: 24px;
  max-width: 640px;
  margin: 0 auto;
}
.co-teamcard__icon { display: none; }
.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);
}
.co-teamcard:hover { border-color: var(--color-arch-purple); box-shadow: var(--shadow-md); }
.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; }

/* ===================== 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); }

/* ===================== 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 --- */
/* max-width set in shared alignment block above (.co-mission .co-inner, .co-team .co-inner, .co-info[data-info="split"] .co-inner) */
.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; }
}

/* ============================================================
   Single team card — 4 layouts via data-team-link on .co-team
   ============================================================ */
/* a · Card (default): centered single card, icon shown above title. */
.co-team[data-team-link="card"] .co-teamcard { align-items: center; text-align: center; }
.co-team[data-team-link="card"] .co-teamcard__icon { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: var(--radius-md); background: var(--purple-50); color: var(--color-arch-purple); }
.co-team[data-team-link="card"] .co-teamcard__icon svg { width: 28px; height: 28px; }
.co-team[data-team-link="card"] .co-teamcard__cta { justify-content: center; }

/* b · Banner: wide horizontal card — icon left, content centre, CTA right. */
.co-team[data-team-link="banner"] .co-team__grid { max-width: none; }
.co-team[data-team-link="banner"] .co-teamcard {
  display: grid; grid-template-columns: 56px 1fr auto; align-items: center;
  gap: 22px; text-align: left;
}
.co-team[data-team-link="banner"] .co-teamcard__icon { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; border-radius: var(--radius-md); background: var(--purple-50); color: var(--color-arch-purple); grid-row: 1 / span 2; }
.co-team[data-team-link="banner"] .co-teamcard__icon svg { width: 30px; height: 30px; }
.co-team[data-team-link="banner"] .co-teamcard__title { grid-column: 2; }
.co-team[data-team-link="banner"] .co-teamcard__desc { grid-column: 2; flex: none; }
.co-team[data-team-link="banner"] .co-teamcard__cta { grid-column: 3; grid-row: 1 / span 2; white-space: nowrap; }

/* c · Panel: lavender split — icon panel left, content on white. */
.co-team[data-team-link="panel"] .co-team__grid { max-width: 880px; }
.co-team[data-team-link="panel"] .co-teamcard { flex-direction: row; align-items: stretch; gap: 0; padding: 0; overflow: hidden; }
.co-team[data-team-link="panel"] .co-teamcard__icon { display: flex; align-items: center; justify-content: center; flex: 0 0 132px; background: var(--gradient-hero); color: var(--color-draft-white); }
.co-team[data-team-link="panel"] .co-teamcard__icon svg { width: 44px; height: 44px; }
.co-team[data-team-link="panel"] .co-teamcard__title,
.co-team[data-team-link="panel"] .co-teamcard__desc { padding-left: clamp(24px, 3vw, 36px); padding-right: clamp(24px, 3vw, 36px); }
.co-team[data-team-link="panel"] .co-teamcard__title { padding-top: clamp(26px, 3vw, 36px); }
.co-team[data-team-link="panel"] .co-teamcard__cta { padding: 0 clamp(24px, 3vw, 36px) clamp(26px, 3vw, 36px); }

/* d · Minimal: borderless hairline row, no card chrome. */
.co-team[data-team-link="minimal"] .co-team__grid { max-width: 720px; }
.co-team[data-team-link="minimal"] .co-teamcard { background: transparent; border: none; border-top: 1px solid var(--border-default); border-radius: 0; padding: clamp(24px, 3vw, 32px) 0; }
.co-team[data-team-link="minimal"] .co-teamcard:hover { box-shadow: none; border-color: var(--border-default); border-top-color: var(--color-arch-purple); }
.co-team[data-team-link="minimal"] .co-teamcard__title { font-size: clamp(20px, 2.4vw, 26px); }

/* ============================================================
   Founder photos — 4 styles via data-team-photos on .co-team
   ============================================================ */
.co-team[data-team-photos] .co-teamcard__icon { background: transparent; width: auto; height: auto; border-radius: 0; display: inline-flex; align-items: center; }
.co-team[data-team-photos] .co-teamcard__icon svg { display: none; }
.co-team[data-team-photos] .co-face { object-fit: cover; display: block; background: var(--color-light-gray); }
.co-team[data-team-link="banner"][data-team-photos] .co-teamcard { grid-template-columns: auto 1fr auto; }

/* a · Stack — overlapping circles */
.co-team[data-team-photos="stack"] .co-face { width: 56px; height: 56px; border-radius: 50%; border: 2px solid var(--bg-surface); }
.co-team[data-team-photos="stack"] .co-face + .co-face { margin-left: -18px; }

/* b · Pair — two rounded-square photos side by side */
.co-team[data-team-photos="pair"] .co-teamcard__icon { gap: 8px; }
.co-team[data-team-photos="pair"] .co-face { width: 52px; height: 52px; border-radius: var(--radius-md); }

/* c · Ring — larger overlapping circles with white ring */
.co-team[data-team-photos="ring"] .co-face { width: 62px; height: 62px; border-radius: 50%; border: 3px solid var(--bg-surface); box-shadow: 0 0 0 1px var(--border-subtle); }
.co-team[data-team-photos="ring"] .co-face + .co-face { margin-left: -24px; }

/* d · Stacked — two circles stacked vertically */
.co-team[data-team-photos="stacked"] .co-teamcard__icon { flex-direction: column; gap: 6px; }
.co-team[data-team-photos="stacked"] .co-face { width: 44px; height: 44px; border-radius: 50%; }
