/* ====================================================================
   About page — slate redesign component styles
   Ported from design_handoff_about/about.css (Claude Design handoff,
   2026-05-29). Pure CONSUMER of the token system in
   extensions/index_new/styles.css (--accent/--brand/--surface/--text-*/
   --sp-*/--radius-*/--shadow-card, .container/.section/.stats-row/
   .cta-card/.btn/.eyebrow). The .ab-* CSS here is hand-authored and arrives
   via <link> after index_new/styles.css (it is NOT compiled by the CSS
   Builder); the companion about_loggedin_test.php markup IS registered in
   the scanner's $page_map['about'] so any wrapper utility classes are
   picked up. All rules scoped under .ab-root so they never leak into the
   surrounding chrome.

   Minimalist: lots of air, centered rhythm, one warm coral accent.
   ==================================================================== */

/* ---------- Root + in-app shell offset ----------
   Logged-out: .ab-root is the full-width marketing surface (marketing nav
   + footer baked into the body).
   Logged-in: .ab-root.ab-inapp is offset to clear the fixed member-nav
   chrome — 60px icon rail + 224px home_loggedin secondary nav = 284px,
   plus the 68px top bar. Breakpoints mirror home_loggedin/secondary_nav.css
   (secondary nav hides < 1180px → icon-rail-only; both rails hide < 880px). */
.ab-root { min-height: 100%; }

/* ---------- Local theme props ----------
   --ab-on-fill is white text sitting on a colored/gradient fill (the brand
   avatar gradient + the CTA card's translucent ghost buttons). It must stay
   white in BOTH themes — those fills are dark/colored regardless of theme —
   so it carries no dark override (unlike a surface/text token). */
.mv-root.ab-root { --ab-on-fill: #FFFFFF; }

.mv-root.ab-inapp {
  margin-left: 284px;
  padding-top: 68px;
  min-height: calc(100vh - 68px);
}
@media (max-width: 1180px) {
  .mv-root.ab-inapp { margin-left: 60px; }
}
@media (max-width: 880px) {
  .mv-root.ab-inapp { margin-left: 0; }
}
/* iPad-portrait gutter fix: the icon rail goes off-canvas via the scanner's tlp-
   (768–1180px device-width, portrait), but the reset above only fires at <=880,
   leaving a dead 60px gutter on large portrait tablets (iPad Pro 12.9" = 1024px).
   Re-assert across the full tablet-portrait range; landscape keeps its rail. */
@media only screen and (min-device-width: 768px) and (max-device-width: 1180px) and (orientation: portrait) {
  .mv-root.ab-inapp { margin-left: 0; }
}
/* track the fixed top bar height (top_row: 68px desktop / 64px tablet-portrait / 60px phone-portrait) */
@media (max-width: 768px) { .mv-root.ab-inapp { padding-top: 64px; } }
@media (max-width: 560px) { .mv-root.ab-inapp { padding-top: 60px; } }
/* in-app density: tighter hero + narrower reading column than marketing */
.mv-root.ab-inapp .container { max-width: 1080px; }
.mv-root.ab-inapp .ab-hero { padding-top: var(--sp-12); }
.mv-root.ab-inapp .ab-hero h1 { font-size: 52px; }

/* ---------- Breadcrumb (logged-out only) ---------- */
.ab-root .nav-brand { white-space: nowrap; }
.ab-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px;
  color: var(--text-3);
  padding-top: var(--sp-8);
}
.ab-bc-link { cursor: pointer; color: var(--text-3); text-decoration: none; }
.ab-bc-link:hover { color: var(--text-1); }
/* the shared 'chev' glyph points down; rotate it to a right-facing breadcrumb separator */
.ab-bc-chev { opacity: 0.5; transform: rotate(-90deg); }
.ab-bc-current { color: var(--text-2); font-weight: 500; }

/* ---------- HERO (centered, quiet) ---------- */
.ab-hero {
  text-align: center;
  max-width: 860px;
  margin: 0 auto;
  padding: var(--sp-24) 0 var(--sp-16);
}
.ab-hero .eyebrow { display: inline-block; margin-bottom: var(--sp-5); }
.ab-hero h1 {
  font-size: 64px;
  line-height: 1.04;
  letter-spacing: -0.022em;
  margin: 0 auto;
}
.ab-hero h1 em { font-style: italic; font-weight: 500; color: var(--brand); }
.ab-hero .ab-lede {
  font-size: 19px;
  line-height: 1.65;
  color: var(--text-2);
  max-width: 620px;
  margin: var(--sp-6) auto 0;
}
.ab-hero-cta {
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-8);
}
.ab-hero-cta .btn { text-decoration: none; }
.ab-divider {
  width: 64px; height: 1px;
  background: var(--border-strong);
  border: 0;
  margin: var(--sp-12) auto 0;
}

/* ---------- STATS ---------- */
.ab-stats { padding-top: var(--sp-4); }

/* ---------- STORY CARD ---------- */
.ab-story {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--sp-16);
  box-shadow: var(--shadow-card);
}
.ab-story-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--sp-12);
  align-items: center;
}
.ab-story-grid .eyebrow { display: inline-block; margin-bottom: var(--sp-4); }
.ab-story-grid h2 {
  font-size: 42px;
  letter-spacing: -0.02em;
  margin-bottom: var(--sp-5);
}
.ab-story-body { display: flex; flex-direction: column; gap: var(--sp-4); }
.ab-story-body p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--text-2);
}
.ab-signature {
  display: flex; align-items: center; gap: 12px;
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--border);
}
.ab-signature .av {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), var(--accent));
  display: flex; align-items: center; justify-content: center;
  color: var(--ab-on-fill); font-weight: 600; font-size: 14px;
  flex-shrink: 0;
}
.ab-signature .nm { font-weight: 600; font-size: 14px; color: var(--text-1); }
.ab-signature .rl { font-size: 12px; color: var(--text-3); }

/* founder + family photo — 3/2 to match the real landscape asset
   (images/brown_family_picture.jpg is 700x466) without side-cropping faces */
.ab-photo {
  position: relative;
  aspect-ratio: 3 / 2;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  background: linear-gradient(160deg, var(--brand-soft), var(--accent-soft));
}
.ab-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

/* ---------- APPROACH (value cards) ---------- */
.ab-values {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
  margin-top: var(--sp-12);
}
.ab-value {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--sp-8);
  box-shadow: var(--shadow-card);
}
.ab-value .ic {
  width: 46px; height: 46px;
  border-radius: 12px;
  background: var(--brand-soft);
  color: var(--brand);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--sp-5);
}
.ab-value:nth-child(2) .ic { background: var(--accent-soft); color: var(--accent); }
.ab-value:nth-child(3) .ic { background: var(--success-soft); color: var(--success); }
.ab-value h3 {
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 8px;
  letter-spacing: -0.012em;
}
.ab-value p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-2);
}

/* ---------- MISSION / VERSE MOMENT ---------- */
.ab-verse {
  text-align: center;
  max-width: 820px;
  margin: 0 auto;
  padding: var(--sp-8) 0;
}
.ab-verse .mark {
  color: var(--brand);
  opacity: 0.45;
  margin-bottom: var(--sp-4);
}
.ab-verse blockquote {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 40px;
  font-weight: 500;
  line-height: 1.22;
  letter-spacing: -0.018em;
  color: var(--text-1);
  text-wrap: balance;
}
.ab-verse blockquote em { font-style: italic; color: var(--brand); }
.ab-verse cite {
  display: block;
  margin-top: var(--sp-6);
  font-family: var(--font-mono);
  font-size: 13px;
  font-style: normal;
  letter-spacing: 0.06em;
  color: var(--text-3);
  text-transform: uppercase;
}

/* ---------- GUIDING PRINCIPLES ---------- */
.ab-principles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-10);
  margin-top: var(--sp-12);
  padding-top: var(--sp-12);
  border-top: 1px solid var(--border);
}
.ab-principle .n {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--brand);
  letter-spacing: 0.1em;
  margin-bottom: var(--sp-3);
}
.ab-principle h4 {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 8px;
  letter-spacing: -0.012em;
}
.ab-principle p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-2);
}

/* ---------- MEET THE TEAM ---------- */
.ab-team {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-5);
  margin-top: var(--sp-12);
}
.ab-member {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--sp-8);
  box-shadow: var(--shadow-card);
  display: flex;
  flex-direction: column;
}
.ab-member-head { display: flex; align-items: center; gap: 12px; margin-bottom: var(--sp-5); }
.ab-member-head .av {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), var(--accent));
  display: flex; align-items: center; justify-content: center;
  color: var(--ab-on-fill); font-weight: 600; font-size: 16px;
  flex-shrink: 0;
}
.ab-member:nth-child(2) .ab-member-head .av { background: linear-gradient(135deg, var(--accent), var(--brand)); }
.ab-member-head .nm { font-weight: 600; font-size: 17px; color: var(--text-1); letter-spacing: -0.01em; }
.ab-member-head .rl { font-size: 13px; color: var(--text-3); margin-top: 2px; }
.ab-member-bio { display: flex; flex-direction: column; gap: var(--sp-3); flex: 1; }
.ab-member-bio p { font-size: 14px; line-height: 1.65; color: var(--text-2); }
.ab-member-verse {
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.ab-member-verse blockquote {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.55;
  color: var(--text-2);
}
.ab-member-verse cite {
  display: block;
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-style: normal;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand);
}

/* ---------- JOIN THE TEAM (intern application) ---------- */
.ab-join {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--sp-16);
  box-shadow: var(--shadow-card);
}
.ab-join-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--sp-12);
  align-items: start;
}
.ab-join-copy .eyebrow { display: inline-block; margin-bottom: var(--sp-4); }
.ab-join-copy h2 { font-size: 42px; letter-spacing: -0.02em; margin-bottom: var(--sp-5); }
.ab-join-copy p { font-size: 16px; line-height: 1.7; color: var(--text-2); }
.ab-join-copy .ab-join-note { margin-top: var(--sp-4); font-size: 14px; color: var(--text-3); }
.ab-field { margin-bottom: var(--sp-4); }
.ab-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
  margin-bottom: 7px;
}
.ab-label .opt { font-weight: 400; color: var(--text-3); }
.ab-input, .ab-textarea {
  width: 100%;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 13px 15px;
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--text-1);
  transition: border-color .15s, box-shadow .15s, background .15s;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
}
.ab-textarea { min-height: 130px; resize: vertical; line-height: 1.55; }
.ab-input::placeholder, .ab-textarea::placeholder { color: var(--text-3); }
.ab-input:focus, .ab-textarea:focus {
  outline: none;
  background: var(--surface);
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.ab-join-submit { width: 100%; justify-content: center; cursor: pointer; }
.ab-join-thanks { text-align: center; padding: var(--sp-10) var(--sp-4); }
.ab-join-thanks .ic {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--success-soft);
  color: var(--success);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--sp-5);
}
.ab-join-thanks h3 { font-size: 22px; font-weight: 600; letter-spacing: -0.012em; margin-bottom: 8px; }
.ab-join-thanks p { font-size: 14px; line-height: 1.6; color: var(--text-2); }

/* ---------- CTA card link reset ---------- */
.ab-root .cta-actions .btn { text-decoration: none; }

/* ---------- CTA headline (shared .cta-headline is a fixed 76px in
   index_new; scale it down so it never overflows in-app or on phones) ---------- */
.mv-root.ab-inapp .cta-headline { font-size: 56px; }

/* ====================================================================
   Responsive
   ==================================================================== */
@media (max-width: 1024px) {
  .ab-hero h1, .mv-root.ab-inapp .ab-hero h1 { font-size: 48px; }
  .ab-story { padding: var(--sp-10); }
  .ab-story-grid { gap: var(--sp-8); }
  .ab-story-grid h2 { font-size: 34px; }
  .ab-root .cta-headline, .mv-root.ab-inapp .cta-headline { font-size: 52px; }
  .ab-join { padding: var(--sp-10); }
  .ab-join-grid { gap: var(--sp-8); }
  .ab-join-copy h2 { font-size: 34px; }
}
@media (max-width: 880px) {
  .ab-story-grid { grid-template-columns: 1fr; }
  .ab-story-grid .ab-photo { order: -1; max-width: 460px; margin: 0 auto; width: 100%; }
  .ab-values { grid-template-columns: 1fr; }
  .ab-team { grid-template-columns: 1fr; }
  .ab-join-grid { grid-template-columns: 1fr; }
  .ab-principles { grid-template-columns: 1fr; gap: var(--sp-6); }
  /* stats strip: 4 cols is too tight on phones — drop to 2 and clear inner borders */
  .ab-stats .stats-row { grid-template-columns: repeat(2, minmax(0, 1fr)); row-gap: var(--sp-6); }
  .ab-stats .stat-cell:nth-child(2n) { border-right: 0; }
}
@media (max-width: 768px) {
  .ab-hero, .mv-root.ab-inapp .ab-hero { padding: var(--sp-12) 0 var(--sp-10); }
  .ab-hero h1, .mv-root.ab-inapp .ab-hero h1 { font-size: 38px; }
  .ab-hero .ab-lede { font-size: 17px; }
  .ab-verse blockquote { font-size: 30px; }
  .ab-story-grid h2 { font-size: 30px; }
  .ab-root .cta-headline, .mv-root.ab-inapp .cta-headline { font-size: 40px; }
  .ab-root .cta-sub { font-size: 17px; }
}
@media (max-width: 560px) {
  .ab-hero h1, .mv-root.ab-inapp .ab-hero h1 { font-size: 32px; }
  .ab-hero-cta { flex-direction: column; align-items: stretch; }
  .ab-hero-cta .btn { justify-content: center; }
  .ab-story { padding: var(--sp-6); }
  .ab-value { padding: var(--sp-6); }
  .ab-member { padding: var(--sp-6); }
  .ab-join { padding: var(--sp-6); }
  .ab-join-copy h2 { font-size: 30px; }
  .ab-verse blockquote { font-size: 26px; }
  .ab-root .cta-headline, .mv-root.ab-inapp .cta-headline { font-size: 32px; }
  /* single-column stats on very narrow phones; clear all inner borders */
  .ab-stats .stats-row { grid-template-columns: 1fr; }
  .ab-stats .stat-cell { border-right: 0; }
}

/* Phone portrait: hide the hero eyebrow/pill above the main H1 (section eyebrows stay). */
@media (max-width: 560px) { .mv-root .ab-hero .eyebrow { display: none !important; } }
