/* ============================================================
   components.css — Reusable building blocks
   Components: site-nav, site-footer, btn (primary / secondary / tertiary),
   chip, card-block (+ .is-forest / .is-lime), input, hero, section-head, glyph.
   card-block-metric + card-image-led were Direction-phase reserve patterns;
   their CSS was removed from v1 until a screen uses them. Concept is
   preserved in `02-design-direction/direction-A-green/preview.html`.
   footer-character (lime blob) removed 2026-06-03; the brief footer-mark
   chip that replaced it was also removed shortly after — it wasn't adding value.
   ============================================================ */

/* ----- SITE NAV (sitewide) ----- */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg-base);
  border-bottom: 1px solid var(--border-base);
  height: 56px; /* DS v1 spec — see design-system-v1.md § Layout */
  padding: 0 var(--content-pad-x);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-display);
}
.site-nav .logo {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-h4);
  letter-spacing: -0.015em;
  text-decoration: none;
  color: var(--text-base);
}
.site-nav .logo .dot {
  background: var(--accent-lime);
  color: var(--text-base);
  padding: 0 4px;
  border-radius: 2px;
  margin-left: 1px;
}
.site-nav-links {
  display: flex;
  gap: 32px;
  list-style: none;
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.site-nav-links a {
  color: var(--text-base);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  padding-bottom: 4px;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.site-nav-links a:hover {
  border-color: var(--accent-lime);
}
.site-nav-links a[aria-current="page"] {
  border-bottom-color: var(--text-base);
}

/* mobile menu toggle (hidden on desktop) */
.nav-toggle {
  display: none;
  width: 44px;  /* 44x44 touch target — design-voice density rule */
  height: 44px;
  position: relative;
  background: transparent;
}
.nav-toggle::before,
.nav-toggle::after {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  height: 2px;
  background: var(--text-base);
  transition: transform var(--dur-fast) var(--ease-out);
}
.nav-toggle::before { top: 16px; }
.nav-toggle::after  { bottom: 16px; }
.nav-toggle[aria-expanded="true"]::before { transform: translateY(5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"]::after  { transform: translateY(-5px) rotate(-45deg); }

@media (max-width: 720px) {
  .site-nav { padding: 0 var(--content-pad-x-mobile); }
  .nav-toggle { display: block; }
  .site-nav-links {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg-base);
    border-bottom: 1px solid var(--border-base);
    flex-direction: column;
    gap: 0;
    padding: 8px 0;
  }
  .site-nav-links.is-open { display: flex; }
  .site-nav-links a {
    display: block;
    padding: 16px var(--content-pad-x-mobile);
    border-bottom-width: 0;
  }
  .site-nav-links a:hover { background: var(--accent-soft); border-bottom-width: 0; }
}

/* ----- SITE FOOTER (light closer)
   Updated 2026-06-03: removed the lime-blob character (off-system, read
   consumer-app for a senior B2B audience). Footer now relies on the rotated
   lime-soft headline accent + chip vocabulary used throughout the site. */
.site-footer {
  margin-top: var(--space-10);
  padding: var(--space-9) 0 var(--space-7);
  background: var(--bg-base);
  color: var(--text-base);
  border-top: 2px solid var(--text-base);
}
.site-footer .footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: var(--space-9);
  align-items: end;
}
.site-footer .footer-headline {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(56px, 9vw, 112px);
  /* line-height >= 1.1 — required for rotated .accent block clearance */
  line-height: 1.1;
  letter-spacing: var(--tracking-tight);
  color: var(--text-base);
  max-width: 14ch;
  margin-bottom: var(--space-5);
}
.site-footer .footer-headline .accent {
  display: inline-block;
  background: var(--accent-soft);
  color: var(--text-base);
  padding: 0 0.18em;
  margin: 0 -0.05em;
  border-radius: 6px;
  transform: rotate(-1deg);
}
.site-footer .footer-body {
  color: var(--text-muted);
  max-width: 42ch;
  font-size: var(--fs-body-lg);
  line-height: 1.55;
}
.site-footer .footer-col-label {
  font-family: var(--font-display);
  font-size: var(--fs-micro);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: var(--space-3);
}
.site-footer .footer-link {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text-base);
  text-decoration: none;
  padding: 8px 0;
  border-bottom: 2px solid transparent;
  width: max-content;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.site-footer .footer-link:hover { border-color: var(--accent-lime); }
/* External-link arrow — SVG icon, stroke-linejoin: round matches the page's
   "round" treatment (numerals, glyphs). Inherits color via currentColor. */
.site-footer .footer-link-arrow {
  display: inline-block;
  width: 0.7em;
  height: 0.7em;
  margin-left: 0.18em;
  vertical-align: -0.06em;
  transition: transform var(--dur-fast) var(--ease-out);
}
.site-footer .footer-link:hover .footer-link-arrow {
  transform: translate(2px, -2px); /* arrow chases its own diagonal on hover */
}
.site-footer .footer-bottom {
  margin-top: var(--space-8);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-base);
  font-family: var(--font-display);
  font-size: var(--fs-micro);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 600;
}

@media (max-width: 720px) {
  .site-footer .footer-grid { grid-template-columns: 1fr; gap: var(--space-7); align-items: start; }
}

/* ----- BUTTON ----- */
.btn {
  font-family: var(--font-display);
  font-size: var(--fs-small);
  font-weight: 600;
  letter-spacing: 0.02em;
  border: 2px solid transparent;
  border-radius: var(--radius-pill);
  padding: 16px 32px;
  cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              transform var(--dur-press) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.btn-primary {
  background: var(--text-base);
  color: var(--accent-lime);
  border-color: var(--text-base);
}
.btn-primary:hover {
  background: var(--accent-lime);
  color: var(--text-base);
  border-color: var(--accent-lime);
  transform: translateY(-2px);
  box-shadow: var(--shadow-cta);
}
.btn-primary:active { transform: translateY(0); }
.btn-primary:focus-visible { outline: 2px solid var(--text-base); outline-offset: 4px; }
.btn-primary[disabled],
.btn-primary[aria-disabled="true"] {
  background: var(--border-base);
  color: var(--text-subtle);
  border-color: var(--border-base);
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.btn-secondary {
  background: transparent;
  color: var(--text-base);
  border-color: var(--text-base);
}
.btn-secondary:hover { background: var(--text-base); color: var(--accent-lime); }
.btn-secondary:active { transform: translateY(1px); }
.btn-secondary:focus-visible { outline: 2px solid var(--text-base); outline-offset: 4px; }
.btn-secondary[disabled],
.btn-secondary[aria-disabled="true"] {
  color: var(--text-subtle);
  border-color: var(--text-subtle);
  cursor: not-allowed;
}

.btn-tertiary {
  background: transparent;
  color: var(--text-base);
  padding: 12px 4px;
  text-decoration: none;
  border-radius: 0;
  border-bottom: 2px solid currentColor;
  border-top: 2px solid transparent;
  border-left: 2px solid transparent;
  border-right: 2px solid transparent;
  transition: color var(--dur-micro) var(--ease-out);
}
.btn-tertiary:hover { color: var(--text-muted); }
.btn-tertiary:active { color: var(--text-muted); border-bottom-color: var(--text-muted); }
.btn-tertiary[disabled],
.btn-tertiary[aria-disabled="true"] {
  color: var(--text-subtle);
  border-bottom-color: var(--text-subtle);
  cursor: not-allowed;
}

/* ----- CHIP ----- */
.chip {
  display: inline-block;
  background: var(--text-base);
  color: var(--accent-lime);
  font-family: var(--font-display);
  font-size: var(--fs-micro);
  font-weight: 700;
  letter-spacing: var(--tracking-caps);
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  text-transform: uppercase;
}
.chip-rotated { transform: rotate(-1deg); }

/* ----- CARD: color-block monogram (case-study tile)
   Full-bleed saturated background per card with a giant Unbounded monogram letter
   as the visual anchor. Two variants alternate across the work strip: `is-forest`
   (forest bg + lime/cream ink) and `is-lime` (lime bg + forest ink).
   Color discipline (per direction-statement.md § Palette):
   - Forest is always foreground on lime. Cream is never on lime (fails 1.4:1).
   - Lime is always a background fill, never small foreground text on light.
   ----- */
.card-block {
  border-radius: var(--radius-l);
  padding: var(--space-6) var(--space-5);
  min-height: 480px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-decoration: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform var(--dur-med) var(--ease-out), box-shadow var(--dur-med) var(--ease-out);
}
.card-block:hover,
.card-block:focus-visible {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
/* Keyboard focus keeps a visible ring. The outline sits on the page background
   at 4px offset, so it reads against both .is-forest and .is-lime card bgs. */
.card-block:focus-visible {
  outline: 2px solid var(--text-base);
  outline-offset: 4px;
}
.card-block:active {
  transform: translateY(-2px);
  transition-duration: 0.08s;
}
/* Disabled — visual only; the anchor remains focusable so SR users can hear
   why a case isn't open yet. JS may still want to preventDefault on click. */
.card-block[aria-disabled="true"] {
  opacity: 0.55;
  cursor: not-allowed;
}
.card-block[aria-disabled="true"]:hover,
.card-block[aria-disabled="true"]:focus-visible {
  transform: none;
  box-shadow: none;
}
.card-block[aria-disabled="true"] .card-mono { transform: none; }

.card-block .card-num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-small);
  letter-spacing: 0.08em;
  margin-bottom: var(--space-4);
}

.card-block .card-chip {
  display: block;
  width: 100%;
  text-align: left;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-micro);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 4px 20px;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-6);
}

.card-block .card-mono {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(140px, 14vw, 190px);
  line-height: 0.85;
  letter-spacing: -0.04em;
  margin: var(--space-2) 0 var(--space-5);
  /* transform-origin bottom-left so the letter grows up + right on hover without nudging
     the title below (transform doesn't reflow) and without crashing into the chip above. */
  transform-origin: 0 100%;
  transition: transform var(--dur-med) var(--ease-out);
}
.card-block:hover .card-mono,
.card-block:focus-visible .card-mono {
  transform: scale(1.08);
}

.card-block .card-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--fs-h3);
  line-height: 1.1;
  letter-spacing: -0.01em;
  /* Reserve 2 lines (2 × line-height 1.1) so single-line titles ("Order History")
     push their description to the same baseline as the two-line title
     ("Handling Guide Online"). Mirrors hgo-step-title + the stats-band stretch fix.
     Reset below where cards go full-width and titles fit on one line. */
  min-height: 2.2em;
  margin-bottom: var(--space-3);
}
@media (max-width: 920px) {
  .card-block .card-title { min-height: 0; }
  .card-block .card-desc { min-height: 0; max-width: none; }
}

.card-block .card-desc {
  font-family: var(--font-body);
  font-size: var(--fs-body-sm);
  line-height: 1.55;
  margin-bottom: var(--space-5);
  max-width: 66%;        /* 2/3 of the card width — responsive, not a fixed ch */
  min-height: 4.65em;    /* reserve ~3 lines so the card height stays constant regardless of copy length */
}

.card-block .card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  margin-top: auto;
  padding-top: var(--space-4);
  font-family: var(--font-body);
  font-size: var(--fs-micro);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
/* "Explore" arrow — design-system SVG arrow (replaces the &rarr; glyph); slides on card hover */
.card-explore { display: inline-flex; align-items: center; gap: 6px; }
.card-arrow { width: 15px; height: 15px; flex: none; transition: transform var(--dur-fast) var(--ease-out); }
.card-block:hover .card-arrow { transform: translateX(3px); }

/* --- Variant: forest bg --- */
.card-block.is-forest {
  background: var(--text-base);
  color: var(--accent-lime);
}
.card-block.is-forest .card-num { color: var(--accent-lime); }
.card-block.is-forest .card-chip {
  background: var(--bg-elevated);
  color: var(--text-base);
}
.card-block.is-forest .card-mono,
.card-block.is-forest .card-title { color: var(--bg-elevated); }
.card-block.is-forest .card-desc { color: var(--accent-soft); }
.card-block.is-forest .card-meta {
  color: var(--accent-soft);
  border-top: 1px solid rgba(212, 245, 197, 0.30);
}

/* --- Variant: lime bg --- */
.card-block.is-lime {
  background: var(--accent-lime);
  color: var(--text-base);
}
.card-block.is-lime .card-num { color: var(--text-base); }
.card-block.is-lime .card-chip {
  background: var(--text-base);
  color: var(--accent-lime);
}
.card-block.is-lime .card-mono,
.card-block.is-lime .card-title { color: var(--text-base); }
.card-block.is-lime .card-desc { color: var(--text-base); opacity: 0.78; }
.card-block.is-lime .card-meta {
  color: var(--text-base);
  border-top: 1px solid rgba(8, 52, 0, 0.25);
}

/* ----- INPUT ----- */
.input-group { max-width: 480px; }
.input-label {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-micro);
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--text-base);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps-wide);
}
.input-wrap { position: relative; }
.input-field {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  padding: 18px 20px;
  background: var(--bg-elevated);
  border: 2px solid var(--text-base);
  border-radius: var(--radius-s);
  color: var(--text-base);
  min-height: 60px;
  transition: background-color var(--dur-micro) var(--ease-out);
  position: relative;
  z-index: 1;
}
.input-field::placeholder { color: var(--text-subtle); font-weight: 400; }
.input-field:hover { background: var(--accent-soft); }
.input-field:focus { outline: none; background: var(--bg-elevated); }
.input-field[aria-invalid="true"] {
  border-color: var(--error);
}
.input-field:disabled {
  background: var(--border-base);
  color: var(--text-subtle);
  border-color: var(--border-base);
  cursor: not-allowed;
}
.input-field:disabled::placeholder { color: var(--text-subtle); }
.input-wrap::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -3px;
  height: 6px;
  background: var(--accent-lime);
  border: 1px solid var(--text-base);
  border-radius: var(--radius-pill);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--dur-med) var(--ease-out);
  z-index: 0;
}
.input-wrap:focus-within::after { transform: scaleX(1); }
.input-help { margin-top: 14px; font-size: var(--fs-small); color: var(--text-muted); font-style: italic; line-height: 1.5; }
.input-error { margin-top: 8px; font-size: var(--fs-small); color: var(--error); font-weight: 600; }

/* ----- HERO ----- */
.hero {
  padding-top: var(--space-9);
  padding-bottom: var(--space-9);
  border-bottom: 1px solid var(--border-base);
}
.hero-subline {
  font-family: var(--font-display);
  font-size: var(--fs-small);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps-wide);
  color: var(--text-muted);
  margin-bottom: var(--space-5);
  display: inline-block;
}
.hero-headline {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-display);
  /* line-height must stay >= 1.1 — rotated .accent block clips into next line otherwise */
  line-height: 1.1;
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-6);
  max-width: 14ch;
}
@keyframes hero-accent-enter {
  from { transform: rotate(0deg) scale(0.96); opacity: 0.4; }
  to   { transform: rotate(-1deg) scale(1);    opacity: 1; }
}
.hero-headline .accent {
  display: inline-block;
  background: var(--accent-soft);
  color: var(--text-base);
  padding: 0 0.18em;
  margin: 0 -0.05em;
  border-radius: 6px;
  font-style: normal;
  font-weight: 600;
  transform: rotate(-1deg);
  /* On-load entry per prototype-strategy ("subtle 1° rotation, on-load only").
     1.2s harmonizes with About + Work hero accents — sitewide pacing.
     base.css forces animation-duration to 0.01ms under prefers-reduced-motion,
     so the accent snaps to its final rotated state without motion. */
  animation: hero-accent-enter var(--dur-reveal) var(--ease-out) both;
}
.hero-body {
  font-size: var(--fs-body-lg);
  line-height: 1.55;
  color: var(--text-muted);
  max-width: 56ch;
  margin-bottom: 0;   /* hero-body is the last hero element now (CTA removed 2026-06-10) */
}

/* ----- SECTION HEADER ----- */
.section-head {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--space-6);
  align-items: baseline;
  margin-bottom: var(--space-6);
}
.section-head .num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 48px;
  color: var(--text-base);
  line-height: 0.9;
  letter-spacing: -0.02em;
  background: var(--accent-lime);
  padding: 4px 14px;
  border-radius: var(--radius-s);
  display: inline-block;
  transform: rotate(-2deg);
  justify-self: start;
}
.section-head h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-h2);
  line-height: var(--lh-snug);
  letter-spacing: -0.015em;
}

@media (max-width: 720px) {
  .section-head { grid-template-columns: 1fr; gap: var(--space-3); }
  .section-head .num { font-size: 32px; }
}

/* ----- ANON CUE: "redrawn" caption + info popover under the hero wireframe -----
   Replaces the old full-width banner (2026-06-10). The hero is dense, so the
   disclosure lives at the visual: a quiet caption + an info popover that shows on
   hover and on focus/tap (:focus-within, touch-safe) carrying the full
   confidentiality statement. The full text also rides the button's aria-label
   for screen readers, so it never depends on the visual popover.
   Scoped to .case-hero-media so the shared .case-hero-image (e.g. Xplicity,
   which is not anonymized) keeps its original stretch behaviour. */
.case-hero-media { display: flex; flex-direction: column; gap: var(--space-3); }
.case-hero-media .case-hero-image { flex: 1 1 auto; min-height: 0; height: auto; }
.case-hero-media--start { align-self: start; }      /* square heroes (e.g. SS) — size to image, no stretch */
.case-hero-media--start .case-hero-image { flex: none; }

.anon-cue {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  align-self: flex-start;
}
.anon-cue-label { font-size: var(--fs-small); color: var(--text-subtle); }
.anon-cue--inline { margin-left: var(--space-2); vertical-align: middle; }   /* icon trailing a paragraph (home Selected work) */
.anon-cue-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  padding: 0;
  border: 1px solid var(--border-base);
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--text-subtle);
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.anon-cue-btn:hover { border-color: var(--text-subtle); color: var(--text-base); }
.anon-cue-btn:focus-visible { outline: 2px solid var(--text-base); outline-offset: 2px; }
.anon-cue-btn svg { width: 14px; height: 14px; }
.anon-cue-pop {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 20;
  width: 300px;
  max-width: 78vw;
  padding: var(--space-3) var(--space-4);
  background: var(--bg-elevated);
  border: 1px solid var(--border-base);
  border-radius: var(--radius-m);
  box-shadow: var(--shadow-md);
  font-size: var(--fs-body-sm);
  line-height: var(--lh-relaxed);
  color: var(--text-muted);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), visibility var(--dur-fast);
}
.anon-cue:hover .anon-cue-pop,
.anon-cue:focus-within .anon-cue-pop {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .anon-cue-pop { transition: opacity var(--dur-fast) linear, visibility var(--dur-fast); transform: none; }
  .anon-cue:hover .anon-cue-pop, .anon-cue:focus-within .anon-cue-pop { transform: none; }
}
@media (max-width: 720px) {
  .anon-cue-pop { left: auto; right: 0; }
}

/* ----- CASE END-NOTE: full-bleed forest band ("full project in interviews") -----
   Forest band matches the case's stats/research band rhythm so it reads as part
   of the page, not a tacked-on card. */
.case-endnote {
  margin-top: 0;
  padding: var(--space-9) 0;
  background: var(--accent-soft);
  color: var(--text-base);
}
.case-endnote-eyebrow {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fs-micro);
  font-weight: 700;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-base);
  opacity: 0.65;
  margin-bottom: var(--space-4);
}
.case-endnote-h {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-h2);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--text-base);
  margin-bottom: var(--space-3);
  max-width: 20ch;
}
.case-endnote-b {
  font-size: var(--fs-body-lg);
  line-height: 1.55;
  color: var(--text-base);
  opacity: 0.78;
  max-width: 52ch;
}
