/* Casterly & Co. — ERI register
   Photography-led, institutional, full-bleed. Built on the locked tokens
   (colors.css, typography.css) and self-hosted fonts. Imagery is rendered in
   a slate duotone so disparate photographs read as one brand language.
   Type: Bodoni Moda = display, Cormorant Garamond = body/subhead,
   Cormorant SC = labels, Libre Caslon = wordmark/cipher accents only. */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }
body {
  margin: 0;
  background: var(--cco-vellum);
  color: var(--cco-slate);
  font-family: var(--cco-font-body);
  font-size: 20px;
  line-height: 1.62;
  font-variant-numeric: lining-nums tabular-nums;
  font-feature-settings: "kern" 1, "liga" 1, "calt" 1, "lnum" 1, "tnum" 1;
  font-kerning: normal;
}

/* White theme: remap the vellum grounds to crisp near-white. Slate and bronze
   are untouched. Applied via body.theme-white on the white variant file. */
body.theme-white {
  --cco-vellum: #FFFFFF;
  --cco-vellum-warm: #F4F3EF;
  --cco-vellum-deep: #E6E4DE;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--cco-slate); color: var(--cco-vellum); }
html { scrollbar-color: color-mix(in srgb, var(--cco-slate) 60%, var(--cco-vellum)) transparent; }
/* keyboard focus reads in brand bronze, never the UA blue */
:focus-visible { outline: 1.5px solid var(--cco-bronze-deep); outline-offset: 4px; }
.bay--slate :focus-visible, .vinth :focus-visible, .navmenu :focus-visible, .foot :focus-visible,
.statband :focus-visible, .thesis :focus-visible, .nav :focus-visible { outline-color: var(--cco-bronze-light); }

/* ---------- film grain: one printed surface across video, duotone and white ---------- */
body::after {
  content: ""; position: fixed; inset: 0; z-index: 44; pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='240' height='240' filter='url%28%23g%29'/></svg>");
  background-size: 240px 240px; opacity: 0.05; mix-blend-mode: overlay;
}
@media print { body::after { display: none; } }

/* ---------- word-cascade display reveals (spans injected by eri.js) ---------- */
.sl-split { opacity: 1 !important; transform: none !important; }
.sl-split .w { display: inline-block; opacity: 0; transform: translateY(0.5em); transition: opacity 640ms ease, transform 860ms cubic-bezier(0.16,1,0.3,1); }
.sl-split.in .w { opacity: 1; transform: none; }

/* ---------- duotone imagery ---------- */
.duo { position: relative; overflow: hidden; background: var(--cco-slate-darker); }
.duo > img, .duo > video {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: grayscale(1) contrast(1.06) brightness(1.03);
}
/* slate tint over the monochrome base = cohesive duotone */
.duo::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: var(--cco-slate); mix-blend-mode: color; opacity: 0.92;
}
/* a faint warm lift so highlights aren't dead grey */
.duo::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 1;
  background: var(--cco-bronze-deep); mix-blend-mode: overlay; opacity: 0.16;
}
/* clean, bright variant for panels where text sits beside (not over) the image */
.duo--clean > img { filter: grayscale(1) contrast(1.02) brightness(1.16); }
.duo--clean::after { opacity: 0.82; }
.duo--clean::before { opacity: 0.10; }
.duo__scrim { position: absolute; inset: 0; z-index: 2; pointer-events: none; }
.duo__scrim--bottom { background: linear-gradient(to top, color-mix(in srgb, var(--cco-slate-darker) 94%, transparent), color-mix(in srgb, var(--cco-slate-darker) 30%, transparent) 46%, transparent 78%); }
.duo__scrim--center { background: radial-gradient(120% 90% at 50% 60%, transparent 30%, color-mix(in srgb, var(--cco-slate-darker) 72%, transparent) 100%); }
.duo__scrim--veil { background: color-mix(in srgb, var(--cco-slate-darker) 52%, transparent); }

/* ---------- type atoms ---------- */
.eyebrow {
  font-family: var(--cco-font-smallcaps); text-transform: uppercase;
  letter-spacing: 0.42em; text-indent: 0.42em; font-size: 0.72rem; font-weight: 500;
  color: var(--cco-bronze-deep); margin: 0; line-height: 1;
}
.eyebrow.on-dark { color: var(--cco-bronze-light); }
.display {
  font-family: var(--cco-font-editorial); font-weight: 400;
  letter-spacing: -0.01em; line-height: 1.08; margin: 0; color: var(--cco-slate);
  font-feature-settings: "kern" 1, "liga" 1, "lnum" 1; text-wrap: balance;
}
.display.on-dark { color: var(--cco-vellum); }
.subhead { font-family: var(--cco-font-body); font-weight: 500; letter-spacing: 0.005em; line-height: 1.2; color: var(--cco-slate); margin: 0; }
.subhead.on-dark { color: var(--cco-vellum); }
.lede { font-family: var(--cco-font-body); font-weight: 400; font-size: clamp(1.34rem, 1.6vw, 1.7rem); line-height: 1.52; color: color-mix(in srgb, var(--cco-slate) 90%, var(--cco-vellum)); margin: 0; }
.lede.on-dark { color: color-mix(in srgb, var(--cco-vellum) 90%, transparent); }
.prose { color: var(--cco-slate); }
.prose.on-dark { color: color-mix(in srgb, var(--cco-vellum) 84%, transparent); }
em { font-family: var(--cco-font-body); font-style: italic; }
/* italic emphasis in display headings → Cormorant Garamond italic (clean in gold),
   not Bodoni italic, which reads spindly/error-like. Bronze color set per context. */
.display em, .statement__line em, .invite__line em, .feature__line em, .thesis__title em {
  font-family: var(--cco-font-body); font-style: italic;
}
.rule { display: block; width: 72px; height: 1px; border: 0; background: var(--cco-bronze-deep); }
.rule.on-dark { background: var(--cco-bronze-light); }

/* ---------- fixed nav ---------- */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 60;
  display: flex; align-items: center; justify-content: space-between;
  padding: 26px clamp(28px, 5vw, 72px) 12px;
  padding-top: max(26px, env(safe-area-inset-top, 0px));
  transition: background 600ms ease, padding 500ms ease, border-color 600ms ease, transform 560ms cubic-bezier(0.16,1,0.3,1);
  border-bottom: 1px solid transparent;
}
/* retreat state: set by eri.js on downward scroll past the hero */
.nav.is-hidden { transform: translateY(-104%); }
.nav__mark { height: clamp(58px, 9vw, 94px); width: auto; transition: height 520ms cubic-bezier(0.16,1,0.3,1), opacity 400ms ease, filter 400ms ease; }
.nav__mark--light { filter: drop-shadow(0 2px 14px rgba(19,31,44,0.5)); }
.nav__mark--dark { display: none; }
.nav__links { display: flex; align-items: center; gap: clamp(18px, 2vw, 32px); margin-left: auto; }
.nav__links a {
  white-space: nowrap;
  font-family: var(--cco-font-smallcaps); text-transform: uppercase;
  letter-spacing: 0.26em; font-size: 0.66rem; font-weight: 500;
  color: var(--cco-vellum); position: relative; padding-bottom: 4px;
  transition: color 360ms ease;
}
.nav__links a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: 0; height: 1px; background: var(--cco-bronze-light); transition: right 420ms cubic-bezier(0.22,1,0.36,1); }
.nav__links a:hover::after { right: 0; }
/* solid state after hero */
.nav.is-solid { background: color-mix(in srgb, var(--cco-vellum) 94%, transparent); backdrop-filter: saturate(120%) blur(8px); border-bottom-color: var(--cco-vellum-deep); padding-top: max(18px, env(safe-area-inset-top, 0px)); padding-bottom: 18px; }
/* glass state: still over the dark header media, but page type has scrolled up
   to meet the bar -- frost it so type never collides with type */
.nav.is-glass { background: color-mix(in srgb, var(--cco-slate-darker) 80%, transparent); -webkit-backdrop-filter: blur(14px) saturate(120%); backdrop-filter: blur(14px) saturate(120%); border-bottom-color: color-mix(in srgb, var(--cco-vellum) 10%, transparent); }
.nav.is-solid .nav__mark--light { display: none; }
.nav.is-solid .nav__mark { height: clamp(42px, 5vw, 56px); }
.nav.is-solid .nav__mark--dark { display: block; }
.nav.is-solid .nav__links a { color: var(--cco-slate); }
.nav.is-solid .nav__links a::after { background: var(--cco-bronze-deep); }
/* the links never crowd the wordmark: below this width they drop out entirely
   and the persistent hamburger (full directory) carries navigation */
@media (max-width: 1080px) { .nav__links { display: none; } }

/* ---------- mobile menu (hamburger + slate overlay) ---------- */
/* persistent directory button: available at ALL widths (the top nav is intentionally
   trimmed, so the full menu stays one click away beside Contact) */
.nav__toggle { display: flex; flex-direction: column; justify-content: center; gap: 5px; width: 44px; height: 44px; padding: 11px 7px; margin-left: clamp(10px, 1.4vw, 20px); background: transparent; border: 0; cursor: pointer; }
.nav__toggle span { display: block; height: 1.5px; width: 100%; background: var(--cco-vellum); border-radius: 2px; transform-origin: center; transition: transform 460ms cubic-bezier(0.16,1,0.3,1), opacity 280ms ease, background 360ms ease; }
.nav.is-solid .nav__toggle span { background: var(--cco-slate); }
.nav.menu-open .nav__toggle span { background: var(--cco-vellum); }
.nav.menu-open .nav__toggle span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav.menu-open .nav__toggle span:nth-child(2) { opacity: 0; }
.nav.menu-open .nav__toggle span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
/* over the open slate menu the bar goes transparent and the light wordmark shows */
.nav.menu-open { background: transparent !important; border-bottom-color: transparent !important; backdrop-filter: none !important; }
.nav.menu-open .nav__mark--light { display: block; }
.nav.menu-open .nav__mark--dark { display: none; }

/* ---------- mobile menu: Directory shelf (frosted glass, drops from top) ---------- */
.navmenu-scrim {
  display: block; position: fixed; inset: 0; z-index: 54;
  background: color-mix(in srgb, var(--cco-slate-darker) 40%, transparent);
  opacity: 0; visibility: hidden; transition: opacity 460ms ease, visibility 460ms;
}
.navmenu-scrim.is-open { opacity: 1; visibility: visible; }
.navmenu {
  display: flex; position: fixed; top: 0; left: 0; right: 0; z-index: 55;
  background: color-mix(in srgb, var(--cco-slate-darker) 66%, transparent);
  -webkit-backdrop-filter: blur(22px) saturate(125%); backdrop-filter: blur(22px) saturate(125%);
  border-bottom: 1px solid color-mix(in srgb, var(--cco-bronze-light) 30%, transparent);
  box-shadow: 0 28px 56px -28px rgba(0,0,0,0.55);
  flex-direction: column; gap: clamp(14px, 2.4vh, 20px);
  padding: calc(max(20px, env(safe-area-inset-top, 0px)) + 76px) clamp(24px, 7vw, 40px) clamp(24px, 4vh, 32px);
  transform: translateY(-101%); visibility: hidden; transition: transform 560ms cubic-bezier(0.16,1,0.3,1), visibility 0s linear 560ms;
}
.navmenu.is-open { transform: none; visibility: visible; transition: transform 560ms cubic-bezier(0.16,1,0.3,1); }
/* solid fallback where backdrop-filter is unsupported */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .navmenu { background: color-mix(in srgb, var(--cco-slate-darker) 96%, transparent); }
}
.navmenu__inner { display: flex; flex-direction: column; }
.navmenu__inner a {
  display: flex; align-items: baseline; gap: 16px;
  padding: clamp(13px, 2.4vh, 17px) 0;
  border-top: 1px solid color-mix(in srgb, var(--cco-bronze-light) 16%, transparent);
  opacity: 0; transform: translateY(10px); transition: opacity 540ms cubic-bezier(0.16,1,0.3,1), transform 540ms cubic-bezier(0.16,1,0.3,1);
}
.navmenu__inner a:first-child { border-top: 0; }
.navmenu__n { font-family: var(--cco-font-editorial); font-size: 0.82rem; color: var(--cco-bronze-light); width: 22px; flex: none; }
.navmenu__t { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.95rem; font-weight: 500; color: color-mix(in srgb, var(--cco-vellum) 92%, transparent); }
.navmenu.is-open .navmenu__inner a { opacity: 1; transform: none; }
.navmenu.is-open .navmenu__inner a:nth-child(1) { transition-delay: 120ms; }
.navmenu.is-open .navmenu__inner a:nth-child(2) { transition-delay: 180ms; }
.navmenu.is-open .navmenu__inner a:nth-child(3) { transition-delay: 240ms; }
.navmenu.is-open .navmenu__inner a:nth-child(4) { transition-delay: 300ms; }
.navmenu__foot { display: flex; flex-direction: column; gap: 6px; margin-top: clamp(8px, 2vh, 16px); padding-top: clamp(14px, 2.4vh, 18px); border-top: 1px solid color-mix(in srgb, var(--cco-bronze-light) 16%, transparent); opacity: 0; transition: opacity 600ms ease; transition-delay: 340ms; }
.navmenu.is-open .navmenu__foot { opacity: 1; }
.navmenu__lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.58rem; color: var(--cco-bronze-light); }
.navmenu__foot a { font-family: var(--cco-font-editorial); font-size: 1.05rem; color: var(--cco-vellum); letter-spacing: -0.005em; }
@media (max-width: 720px) {
  /* on small screens the trimmed links collapse entirely into the directory menu */
  .nav__links { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  .navmenu, .navmenu__inner a, .navmenu__foot, .navmenu-scrim { transition: opacity 200ms ease !important; }
  .navmenu { transform: none !important; }
  .navmenu__inner a { transform: none !important; }
}
@media (max-width: 560px) {
  .nav { padding-left: clamp(13px, 3.5vw, 18px); padding-right: clamp(22px, 6.5vw, 30px); padding-top: max(36px, calc(env(safe-area-inset-top, 0px) + 14px)); padding-bottom: 10px; }
  .nav__home { margin-top: 4px; }
  .nav__mark { height: 58px; }
  .nav.is-solid { padding-top: max(20px, calc(env(safe-area-inset-top, 0px) + 6px)); padding-bottom: 12px; }
  .nav.is-solid .nav__mark { height: 44px; }
  .nav__links a { font-size: 0.62rem; letter-spacing: 0.22em; }
}

/* ---------- hero ---------- */
.hero { position: relative; height: 100vh; min-height: 640px; display: flex; align-items: flex-end; overflow: hidden; }
@supports (height: 100dvh) { .hero { height: 100dvh; } }
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__media img, .hero__media video { width: 100%; height: 120%; }
/* nudge the hero video framing down so open sky sits behind the nav (keeps the
   wordmark/links over clear space rather than building tops) */
.hero__video { object-fit: cover; object-position: center 32%; }
@media (max-width: 640px) {
  /* keep the elevated full-bleed hero; just centre the crop on the middle of the skyline */
  .hero__video { object-position: 50% 38%; }
}
/* a deeper, taller wash behind the text block so the eyebrow holds over bright glass */
.hero__scrim--top { background: linear-gradient(to bottom, color-mix(in srgb, var(--cco-slate-darker) 78%, transparent), color-mix(in srgb, var(--cco-slate-darker) 30%, transparent) 42%, transparent 70%); }
.hero__scrim { background: linear-gradient(to top, color-mix(in srgb, var(--cco-slate-darker) 92%, transparent), color-mix(in srgb, var(--cco-slate-darker) 58%, transparent) 30%, color-mix(in srgb, var(--cco-slate-darker) 18%, transparent) 58%, transparent 82%); }
.hero__inner { position: relative; z-index: 3; width: 100%; padding: clamp(48px, 8vh, 104px) clamp(28px, 5vw, 88px); }
.hero__rule { display: block; width: clamp(48px, 6vw, 72px); height: 1px; background: var(--cco-bronze-light); transform-origin: left center; margin-bottom: clamp(22px, 2.6vw, 34px); box-shadow: 0 1px 10px rgba(19,31,44,0.4); }
.hero__eyebrow { margin-bottom: clamp(24px, 3vw, 36px); }
.hero__display { font-size: clamp(2.7rem, 6.2vw, 6.2rem); max-width: 18ch; margin-bottom: clamp(28px, 3vw, 40px); }
.hero__display .soft { color: var(--cco-bronze-light); font-style: italic; }
.hero__lede { max-width: 48ch; }
/* lede-leads hero: enlarged firm-identity lead line, then the detail beneath */
.hero__lead {
  font-family: var(--cco-font-body); font-weight: 500;
  font-size: clamp(2.05rem, 3.5vw, 3.35rem); line-height: 1.14; letter-spacing: 0.004em;
  max-width: 21ch; margin: 0 0 clamp(22px, 2.4vw, 34px); color: var(--cco-vellum);
  text-wrap: balance; font-feature-settings: "kern" 1, "liga" 1, "lnum" 1;
}
.hero__lead em { font-style: italic; color: var(--cco-bronze-light); }
.hero__cont {
  font-family: var(--cco-font-body); font-weight: 400;
  font-size: clamp(1.3rem, 1.55vw, 1.62rem); line-height: 1.5; margin: 0;
  max-width: 52ch; color: color-mix(in srgb, var(--cco-vellum) 86%, transparent);
}
.hero__cue { position: absolute; right: clamp(28px, 5vw, 88px); bottom: clamp(24px, 4vh, 40px); z-index: 3; display: grid; justify-items: center; gap: 10px; transition: opacity 700ms ease; }
/* the cue greets once; after the first scroll it retires for the rest of the visit */
.hero__cue.is-spent { opacity: 0; pointer-events: none; }
.hero__cue span { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.4em; font-size: 0.58rem; color: var(--cco-bronze-light); }
.hero__cue i { width: 1px; height: 44px; background: color-mix(in srgb, var(--cco-bronze-light) 60%, transparent); animation: cue 2.4s ease-in-out infinite; transform-origin: top; }
@keyframes cue { 0%,100% { transform: scaleY(0.4); opacity: 0.4; } 50% { transform: scaleY(1); opacity: 1; } }

/* ---------- generic section frame ---------- */
.bay { padding: clamp(104px, 14vw, 200px) clamp(28px, 7vw, 128px); }
.bay--slate { background: var(--cco-slate); color: var(--cco-vellum); }
.bay--warm { background: var(--cco-vellum-warm); }
.wrap { max-width: 1280px; margin: 0 auto; }
.wrap--narrow { max-width: 880px; }
.sec-index { display: flex; align-items: center; gap: 18px; margin-bottom: clamp(36px, 4vw, 60px); }
/* the index hairline draws itself in as the section arrives */
.sec-index .ln { transform: scaleX(0); transform-origin: left center; transition: transform 1300ms cubic-bezier(0.16,1,0.3,1) 160ms; }
.sec-index.in .ln { transform: scaleX(1); }
@media (prefers-reduced-motion: reduce) { .sec-index .ln { transform: none; transition: none; } }
.sec-index .num { font-family: var(--cco-font-body); font-weight: 500; font-size: 1.04rem; color: var(--cco-bronze-deep); font-feature-settings: "lnum" 1, "tnum" 1; }
.bay--slate .sec-index .num { color: var(--cco-bronze-light); }
.sec-index .lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.66rem; }
.sec-index .ln { flex: 1; height: 1px; background: var(--cco-vellum-deep); }
.bay--slate .sec-index .ln { background: color-mix(in srgb, var(--cco-bronze-light) 28%, transparent); }

/* ---------- intro statement ---------- */
.intro__statement { font-family: var(--cco-font-body); font-weight: 500; font-size: clamp(1.5rem, 2.3vw, 2.15rem); line-height: 1.38; letter-spacing: 0.005em; max-width: 32ch; margin: 0 0 clamp(40px, 5vw, 64px); color: var(--cco-slate); }
.intro__statement em { font-style: italic; color: var(--cco-bronze-deep); }
.intro__grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(32px, 5vw, 96px); align-items: start; }
.intro__grid p { margin: 0 0 1.2em; font-size: 1.18rem; line-height: 1.62; }
.intro__grid p:last-child { margin-bottom: 0; }

/* ---------- full-bleed feature band ---------- */
.feature { position: relative; height: clamp(440px, 78vh, 760px); display: flex; align-items: center; justify-content: center; text-align: center; overflow: hidden; }
.feature__media { position: absolute; inset: 0; z-index: 0; }
.feature__media img { width: 100%; height: 116%; }
.feature__inner { position: relative; z-index: 3; padding: 0 clamp(28px, 6vw, 96px); width: 100%; display: flex; flex-direction: column; align-items: center; }
.feature__line { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(1.9rem, 3.8vw, 3.4rem); line-height: 1.26; letter-spacing: -0.005em; color: var(--cco-vellum); max-width: 17ch; }
.feature__line em { color: var(--cco-bronze-light); }
.feature__cap { margin-top: 24px; font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.36em; font-size: 0.6rem; color: var(--cco-bronze-light); }

/* ---------- approach (sticky two-column principles) ---------- */
.approach__grid { display: grid; grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr); gap: clamp(40px, 7vw, 140px); align-items: start; }
.approach__aside { position: sticky; top: clamp(96px, 14vh, 160px); }
.approach__title { font-size: clamp(2.1rem, 3.6vw, 3.4rem); margin: 22px 0 28px; max-width: 16ch; }
.approach__note { max-width: 34ch; }
.principles { display: grid; }
.principle { display: grid; grid-template-columns: 64px 1fr; gap: clamp(18px, 3vw, 44px); padding: clamp(36px, 4.5vw, 60px) 0; border-top: 1px solid color-mix(in srgb, var(--cco-bronze-light) 26%, transparent); }
.principle:first-child { border-top: 0; padding-top: 0; }
.principle__num { font-family: var(--cco-font-editorial); font-size: 1.4rem; color: var(--cco-bronze-light); line-height: 1.2; }
.principle__name { font-family: var(--cco-font-body); font-weight: 500; font-size: clamp(1.5rem, 2.2vw, 2.05rem); color: var(--cco-vellum); line-height: 1.16; margin: 0 0 16px; letter-spacing: 0.005em; }
.principle__body { font-size: 1.12rem; line-height: 1.62; color: color-mix(in srgb, var(--cco-vellum) 82%, transparent); margin: 0; }
@media (max-width: 880px) {
  .approach__grid { grid-template-columns: 1fr; gap: 56px; }
  .approach__aside { position: static; }
}

/* ---------- track record ---------- */
.record { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--cco-vellum-deep); }
.record__cell { padding: clamp(32px, 4vw, 56px) clamp(20px, 3vw, 44px) 0 0; }
.record__cell + .record__cell { border-left: 1px solid var(--cco-vellum-deep); padding-left: clamp(24px, 3vw, 48px); }
.record__fig { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(2.4rem, 4.4vw, 4rem); line-height: 1; color: var(--cco-slate); letter-spacing: -0.015em; margin-bottom: 16px; }
.record__fig .u { color: var(--cco-bronze-deep); }
.record__lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.64rem; color: var(--cco-bronze-deep); }
@media (max-width: 720px) { .record { grid-template-columns: 1fr; } .record__cell + .record__cell { border-left: 0; border-top: 1px solid var(--cco-vellum-deep); padding-left: 0; } }

/* ---------- focus: interactive selector ---------- */
.focus__head { max-width: 46ch; margin-bottom: clamp(48px, 6vw, 84px); }
.focus__head .display { font-size: clamp(2.1rem, 3.6vw, 3.4rem); margin-bottom: 22px; }
.focusx { display: grid; grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr); gap: clamp(36px, 5vw, 96px); align-items: stretch; }
.focusx__tabs { display: grid; align-content: start; border-top: 1px solid var(--cco-vellum-deep); }
.focusx__tab {
  display: grid; grid-template-columns: 48px 1fr; align-items: center; gap: 20px;
  width: 100%; text-align: left; background: transparent; border: 0; cursor: pointer;
  padding: clamp(22px, 2.4vw, 30px) 6px; border-bottom: 1px solid var(--cco-vellum-deep);
  position: relative; transition: padding-left 520ms cubic-bezier(0.16,1,0.3,1);
}
.focusx__tab::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--cco-bronze-deep); transform: scaleY(0); transform-origin: top; transition: transform 520ms cubic-bezier(0.16,1,0.3,1); }
.focusx__tab.is-active::before { transform: scaleY(1); }
.focusx__tab.is-active { padding-left: 22px; }
.focusx__tn { font-family: var(--cco-font-editorial); font-size: 0.96rem; color: var(--cco-bronze-deep); transition: opacity 400ms ease; }
.focusx__tt { font-family: var(--cco-font-body); font-weight: 500; font-size: clamp(1.25rem, 1.8vw, 1.65rem); line-height: 1.18; letter-spacing: 0.005em; color: color-mix(in srgb, var(--cco-slate) 52%, var(--cco-vellum)); transition: color 460ms ease; }
.focusx__tab.is-active .focusx__tt { color: var(--cco-slate); }
.focusx__tab:hover .focusx__tt { color: color-mix(in srgb, var(--cco-slate) 80%, var(--cco-vellum)); }
.focusx__stage { position: relative; background: var(--cco-vellum-warm); border: 1px solid var(--cco-vellum-deep); overflow: hidden; min-height: 340px; }
.focusx__panel { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: center; padding: clamp(36px, 4.5vw, 72px); opacity: 0; transform: translateY(16px); transition: opacity 700ms cubic-bezier(0.16,1,0.3,1), transform 700ms cubic-bezier(0.16,1,0.3,1); pointer-events: none; }
.focusx__panel.is-active { position: relative; inset: auto; opacity: 1; transform: none; pointer-events: auto; }pacity 700ms cubic-bezier(0.16,1,0.3,1), transform 700ms cubic-bezier(0.16,1,0.3,1); pointer-events: none; }
.focusx__panel.is-active { opacity: 1; transform: none; pointer-events: auto; }
.focusx__bignum { position: absolute; top: clamp(24px, 3vw, 40px); right: clamp(28px, 3.5vw, 52px); font-family: var(--cco-font-editorial); font-size: clamp(3.4rem, 7vw, 6rem); line-height: 1; color: color-mix(in srgb, var(--cco-bronze-deep) 22%, transparent); letter-spacing: -0.02em; }
.focusx__label { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.32em; font-size: 0.62rem; color: var(--cco-bronze-deep); margin-bottom: clamp(18px, 2vw, 26px); }
.focusx__title { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(1.7rem, 2.8vw, 2.6rem); line-height: 1.16; letter-spacing: -0.005em; color: var(--cco-slate); margin: 0 0 clamp(18px, 2vw, 26px); max-width: 18ch; }
.focusx__body { font-size: 1.16rem; line-height: 1.62; color: color-mix(in srgb, var(--cco-slate) 76%, var(--cco-vellum)); max-width: 40ch; margin: 0; }
.focusx-m { display: none; }
@media (max-width: 860px) {
  .focusx { grid-template-columns: 1fr; gap: 0; }
  .focusx__stage { display: block; min-height: 0; margin-top: 20px; }
  .focusx__tabs { border-top: 0; }
  .focusx__tab { grid-template-columns: 40px 1fr; }
  .focusx__tab.is-active { padding-left: 16px; }
  .focusx__panel.is-active { padding-top: clamp(48px, 14vw, 64px); }
  .focusx-m { display: none; }
}

/* ---------- integration ---------- */
.integration__title { font-size: clamp(2rem, 3.4vw, 3.2rem); max-width: 20ch; margin-bottom: clamp(40px, 5vw, 64px); }
.chips { display: flex; flex-wrap: wrap; gap: 12px; }
.chip { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.74rem; color: var(--cco-vellum); border: 1px solid color-mix(in srgb, var(--cco-bronze-light) 36%, transparent); padding: 14px 22px; }

/* ---------- split: image + strategy panel ---------- */
.split { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); min-height: clamp(560px, 76vh, 820px); }
.split__media { position: relative; }
.split__media img { position: absolute; inset: 0; width: 100%; height: 100%; }
.split__panel { background: var(--cco-slate); color: var(--cco-vellum); display: flex; flex-direction: column; justify-content: center; padding: clamp(48px, 6vw, 104px); }
.split__panel .eyebrow { margin-bottom: clamp(24px, 3vw, 36px); }
.split__title { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(1.9rem, 2.8vw, 2.9rem); line-height: 1.2; letter-spacing: -0.005em; color: var(--cco-vellum); max-width: 18ch; margin: 0 0 clamp(28px, 3vw, 40px); }
.split__body { font-size: 1.16rem; line-height: 1.62; color: color-mix(in srgb, var(--cco-vellum) 84%, transparent); max-width: 44ch; margin: 0 0 clamp(36px, 4vw, 52px); }
.split__chips { display: flex; flex-wrap: wrap; gap: 10px; }
.split__chips .chip { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.18em; font-size: 0.66rem; color: color-mix(in srgb, var(--cco-vellum) 86%, transparent); border: 1px solid color-mix(in srgb, var(--cco-bronze-light) 34%, transparent); padding: 9px 16px; }
@media (max-width: 860px) { .split { grid-template-columns: 1fr; } .split__media { min-height: 380px; } }

/* ---------- vertical integration (refined process spine, on white) ---------- */
.vint__grid { display: grid; grid-template-columns: minmax(0, 0.84fr) minmax(0, 1.16fr); gap: clamp(40px, 7vw, 132px); align-items: start; }
.vint__aside { position: sticky; top: clamp(96px, 14vh, 158px); }
.vint__aside .eyebrow { margin-bottom: clamp(22px, 2.5vw, 32px); }
.vint__title { font-size: clamp(2.1rem, 3.6vw, 3.4rem); margin-bottom: clamp(22px, 2.5vw, 32px); max-width: 15ch; }
.vint__note { max-width: 36ch; }
.vint__count { display: flex; align-items: baseline; gap: 14px; margin-top: clamp(32px, 4vw, 52px); }
.vint__count b { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(2.4rem, 4vw, 3.4rem); color: var(--cco-bronze-deep); line-height: 1; letter-spacing: -0.02em; }
.vint__count span { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.64rem; color: color-mix(in srgb, var(--cco-slate) 64%, var(--cco-vellum)); max-width: 16ch; }

.vint__spine { position: relative; --inset: clamp(34px, 3.6vw, 52px); padding-left: var(--inset); }
.vint__line { position: absolute; left: 6px; top: 8px; bottom: 8px; width: 1px; background: color-mix(in srgb, var(--cco-bronze-deep) 46%, transparent); transform: scaleY(0); transform-origin: top; transition: transform 1400ms cubic-bezier(0.16,1,0.3,1); transition-delay: 80ms; }
.vint__line.in { transform: scaleY(1); }
.vphase { padding: clamp(8px, 1vw, 14px) 0; }
.vphase + .vphase { border-top: 1px solid var(--cco-vellum-deep); margin-top: clamp(20px, 2.4vw, 32px); padding-top: clamp(24px, 2.8vw, 38px); }
.vphase__head { display: flex; align-items: baseline; gap: 14px; margin-bottom: clamp(14px, 1.6vw, 22px); }
.vphase__n { font-family: var(--cco-font-editorial); font-size: 1.2rem; color: var(--cco-bronze-deep); }
.vphase__name { font-family: var(--cco-font-editorial); font-style: italic; font-size: clamp(1.4rem, 2vw, 1.9rem); color: var(--cco-slate); letter-spacing: -0.005em; }
.vstep { position: relative; display: grid; grid-template-columns: 42px 1fr; align-items: baseline; gap: 20px; padding: clamp(10px, 1.1vw, 14px) 0; }
.vstep::before { content: ""; position: absolute; left: calc(-1 * var(--inset) + 2px); top: 0.85em; width: 9px; height: 9px; border-radius: 50%; background: var(--cco-vellum); border: 1.5px solid var(--cco-bronze-deep); transform: translateY(-50%) scale(0); transition: transform 480ms cubic-bezier(0.16,1,0.3,1); transition-delay: var(--d, 0ms); }
.vstep.in::before { transform: translateY(-50%) scale(1); }
.vstep__n { font-family: var(--cco-font-editorial); font-size: 0.94rem; color: var(--cco-bronze-deep); }
.vstep__t { font-family: var(--cco-font-body); font-weight: 500; font-size: clamp(1.08rem, 1.4vw, 1.34rem); letter-spacing: 0.005em; color: var(--cco-slate); }
.vstep__t small { display: block; font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.22em; font-size: 0.56rem; font-weight: 500; color: color-mix(in srgb, var(--cco-slate) 56%, var(--cco-vellum)); margin-top: 5px; }
@media (max-width: 880px) { .vint__grid { grid-template-columns: 1fr; gap: 48px; } .vint__aside { position: static; } }


/* ---------- inquiry form ---------- */
.contact { background: var(--cco-vellum-warm); }
.contact__grid { display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr); gap: clamp(48px, 7vw, 128px); align-items: start; }
.contact__aside .invite-seal { width: clamp(80px, 8vw, 104px); height: auto; margin-bottom: clamp(28px, 3vw, 40px); }
.contact__title { font-size: clamp(2rem, 3.2vw, 3rem); margin-bottom: clamp(24px, 3vw, 36px); max-width: 16ch; }
.contact__note { max-width: 36ch; margin-bottom: clamp(36px, 4vw, 52px); }
.contact__details { display: grid; gap: 20px; padding-top: clamp(28px, 3vw, 40px); border-top: 1px solid var(--cco-vellum-deep); }
.cdetail { display: grid; gap: 6px; }
.cdetail__lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.6rem; color: var(--cco-bronze-deep); }
.cdetail__val { font-family: var(--cco-font-editorial); font-size: 1.22rem; color: var(--cco-slate); letter-spacing: -0.005em; }
.cdetail__val a:hover { color: var(--cco-bronze-deep); }

.form { display: grid; gap: clamp(20px, 2.2vw, 28px); }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 3vw, 40px); }
.field { display: grid; gap: 10px; }
.field label { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.62rem; color: var(--cco-bronze-deep); }
.field input, .field textarea {
  font-family: var(--cco-font-body); font-size: 1.16rem; color: var(--cco-slate);
  background: transparent; border: 0; border-bottom: 1px solid color-mix(in srgb, var(--cco-slate) 26%, var(--cco-vellum));
  padding: 8px 0 12px; line-height: 1.4; transition: border-color 360ms ease;
}
.field textarea { resize: vertical; min-height: 96px; }
.field input::placeholder, .field textarea::placeholder { color: color-mix(in srgb, var(--cco-slate) 42%, var(--cco-vellum)); }
.field input:focus, .field textarea:focus { outline: none; border-bottom-color: var(--cco-bronze-deep); }
.form__foot { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; margin-top: 4px; }
.form__note { font-family: var(--cco-font-body); font-style: italic; font-size: 0.98rem; color: color-mix(in srgb, var(--cco-slate) 64%, var(--cco-vellum)); margin: 0; }
.form__note--top { margin: 0 0 clamp(6px, 1vw, 12px); }
.submit {
  font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.72rem; color: var(--cco-vellum);
  background: var(--cco-slate); border: 0; padding: 18px 36px; cursor: pointer; transition: background 360ms ease, letter-spacing 360ms ease;
}
.submit:hover { background: var(--cco-slate-deep); letter-spacing: 0.3em; }
.form.is-sent .form__fields { display: none; }
.form__thanks { display: none; }
.form.is-sent .form__thanks { display: grid; gap: 14px; padding: clamp(32px, 4vw, 48px) 0; }
.form__thanks .display { font-size: clamp(1.6rem, 2.4vw, 2.1rem); }
.form__thanks p { margin: 0; color: color-mix(in srgb, var(--cco-slate) 74%, var(--cco-vellum)); }
@media (max-width: 860px) { .contact__grid { grid-template-columns: 1fr; gap: 56px; } .form__row { grid-template-columns: 1fr; } }

/* ---------- page-load intro sequence ---------- */
.intro-veil {
  position: fixed; inset: 0; z-index: 200; background: var(--cco-slate);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: clamp(28px, 4vh, 48px);
  opacity: 1; transition: opacity 900ms cubic-bezier(0.16,1,0.3,1);
}
.intro-veil.is-done { opacity: 0; pointer-events: none; }
.intro-veil__seal { width: clamp(96px, 12vw, 150px); height: auto; opacity: 0; animation: introSeal 1200ms cubic-bezier(0.16,1,0.3,1) 200ms forwards; }
.intro-veil__mark { width: clamp(190px, 24vw, 300px); height: auto; opacity: 0; animation: introMark 1100ms cubic-bezier(0.16,1,0.3,1) 760ms forwards; }
.intro-veil__line { width: 0; height: 1px; background: color-mix(in srgb, var(--cco-bronze-light) 60%, transparent); animation: introLine 1400ms cubic-bezier(0.16,1,0.3,1) 560ms forwards; }
/* opacity-only fades keep the vector marks razor-sharp (a scaled/translated layer
   gets cached soft by the compositor); the bronze rule supplies the motion. */
@keyframes introSeal { to { opacity: 1; } }
@keyframes introMark { to { opacity: 1; } }
@keyframes introLine { 0% { width: 0; opacity: 0; } 30% { opacity: 1; } 100% { width: clamp(160px, 22vw, 280px); opacity: 1; } }
@media (prefers-reduced-motion: reduce) {
  .intro-veil { display: none; }
}

/* ---------- contact (composed bordered panel) ---------- */
.contact__panel { border: 1px solid var(--cco-vellum-deep); display: grid; grid-template-columns: 0.66fr 1.34fr; }
.contact__left { display: flex; align-items: center; justify-content: center; padding: clamp(32px, 3.4vw, 56px); border-right: 1px solid var(--cco-vellum-deep); background: transparent; }
.contact__right { padding: clamp(34px, 3.6vw, 60px); display: flex; flex-direction: column; align-items: flex-start; justify-content: center; }
.contact__right .eyebrow { margin-bottom: clamp(16px, 1.8vw, 22px); }
.contact__right .contact__title { font-size: clamp(1.6rem, 2.3vw, 2.3rem); max-width: 24ch; margin: 0 0 clamp(26px, 3vw, 38px); line-height: 1.2; }
.contact__right .contact__details { display: flex; flex-wrap: wrap; gap: clamp(24px, 3vw, 44px); margin-bottom: clamp(26px, 3vw, 38px); }
.seal-medallion { width: clamp(108px, 11vw, 150px); aspect-ratio: 1; border-radius: 50%; overflow: hidden; box-shadow: 0 0 0 1px color-mix(in srgb, var(--cco-bronze-deep) 30%, transparent), 0 9px 22px -12px rgba(19,31,44,0.4); } -15px rgba(19,31,44,0.30); }
.seal-medallion img { width: 100%; height: 100%; display: block; }
/* Vector marks must not be rasterized by the Ken-Burns scale, or they soften.
   Keep the fade-in (container opacity) but render the SVG at full sharpness. */
.seal-medallion.r-media img, .modal__seal img { transform: none !important; }
@media (max-width: 860px) {
  .contact__panel { grid-template-columns: 1fr; }
  .contact__left { border-right: 0; border-bottom: 1px solid var(--cco-vellum-deep); }
}
.inquiry-btn {
  font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.74rem;
  color: var(--cco-vellum); background: var(--cco-slate); border: 0; padding: 20px 44px; cursor: pointer;
  transition: background 380ms ease, letter-spacing 380ms ease;
}
.inquiry-btn:hover { background: var(--cco-slate-deep); letter-spacing: 0.32em; }

/* ---------- inquiry modal ---------- */
.modal { position: fixed; inset: 0; z-index: 100; visibility: hidden; }
.modal.is-open { visibility: visible; }
.modal__scrim { position: absolute; inset: 0; background: color-mix(in srgb, var(--cco-slate-darker) 72%, transparent); backdrop-filter: blur(6px) saturate(120%); opacity: 0; transition: opacity 420ms ease; }
.modal.is-open .modal__scrim { opacity: 1; }
.modal__viewport { position: absolute; inset: 0; overflow: auto; display: flex; align-items: flex-start; justify-content: center; padding: clamp(20px, 6vh, 72px) 20px; }
.modal__dialog {
  position: relative; width: 100%; max-width: 620px; background: var(--cco-vellum);
  border-top: 2px solid var(--cco-bronze);
  box-shadow: 0 50px 130px -50px rgba(19,31,44,0.7);
  transform: translateY(20px) scale(0.985); opacity: 0; overflow: hidden;
  transition: transform 540ms cubic-bezier(0.16,1,0.3,1), opacity 460ms ease;
}
.modal.is-open .modal__dialog { transform: none; opacity: 1; }
.modal__close {
  position: absolute; top: 18px; right: 18px; width: 40px; height: 40px; border: 0; background: transparent; cursor: pointer;
  color: var(--cco-vellum); opacity: 0.66; transition: opacity 300ms ease; display: grid; place-items: center; z-index: 2;
}
.modal__close:hover { opacity: 1; }
.modal__close::before, .modal__close::after { content: ""; position: absolute; width: 18px; height: 1px; background: currentColor; }
.modal__close::before { transform: rotate(45deg); }
.modal__close::after { transform: rotate(-45deg); }
.modal__banner { background: var(--cco-slate); color: var(--cco-vellum); padding: clamp(34px, 4vw, 52px) clamp(34px, 4vw, 56px); display: flex; align-items: center; justify-content: space-between; gap: clamp(20px, 3vw, 40px); }
.modal__banner .eyebrow { color: var(--cco-bronze-light); margin-bottom: 16px; }
.modal__banner .display { color: var(--cco-vellum); font-size: clamp(1.7rem, 2.6vw, 2.3rem); max-width: 15ch; }
.modal__seal { width: clamp(64px, 7vw, 84px); aspect-ratio: 1; border-radius: 50%; overflow: hidden; flex-shrink: 0; box-shadow: 0 18px 40px -20px rgba(0,0,0,0.55), inset 0 0 0 1px color-mix(in srgb, var(--cco-bronze-light) 30%, transparent); }
.modal__seal img { width: 100%; height: 100%; display: block; }
.modal__body { padding: clamp(34px, 4vw, 52px) clamp(34px, 4vw, 56px) clamp(30px, 3.5vw, 46px); }
@media (max-width: 520px) { .modal__seal { display: none; } }
@media (prefers-reduced-motion: reduce) {
  .modal__scrim, .modal__dialog { transition: none !important; }
  .modal__dialog { transform: none !important; }
}

/* ---------- contact / invitation ---------- */
.invite { position: relative; overflow: hidden; }
.invite__media { position: absolute; inset: 0; z-index: 0; }
.invite__media img { width: 100%; height: 116%; }
.invite__inner { position: relative; z-index: 3; padding: clamp(104px, 14vw, 200px) clamp(28px, 7vw, 128px); text-align: center; }
.invite__seal { width: clamp(96px, 11vw, 132px); height: auto; margin: 0 auto clamp(36px, 4vw, 56px); }
.invite__line { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(2rem, 3.8vw, 3.4rem); line-height: 1.24; letter-spacing: -0.005em; max-width: 20ch; margin: 0 auto clamp(44px, 5vw, 68px); color: var(--cco-vellum); }
.invite__contact { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(32px, 5vw, 88px); }
.cgroup { display: grid; gap: 8px; }
.cgroup__lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.32em; font-size: 0.6rem; color: var(--cco-bronze-light); }
.cgroup__val { font-family: var(--cco-font-editorial); font-size: 1.3rem; color: var(--cco-vellum); letter-spacing: -0.005em; }
.cgroup__val a:hover { color: var(--cco-bronze-light); }

/* ---------- what we pursue (slate accordion) ---------- */
.pursue { background: var(--cco-slate); color: var(--cco-vellum); }
.pursue__head { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 28px; margin-bottom: clamp(48px, 6vw, 84px); }
.pursue__head .display { font-size: clamp(2.1rem, 3.6vw, 3.4rem); max-width: 16ch; }
.pursue__note { max-width: 34ch; color: color-mix(in srgb, var(--cco-vellum) 78%, transparent); }
.accord { border-top: 1px solid color-mix(in srgb, var(--cco-bronze-light) 24%, transparent); }
.accord__item { border-bottom: 1px solid color-mix(in srgb, var(--cco-bronze-light) 24%, transparent); }
.accord__head {
  display: grid; grid-template-columns: 56px 1fr 40px; align-items: center; gap: clamp(16px, 2.5vw, 40px);
  width: 100%; text-align: left; background: transparent; border: 0; cursor: pointer; color: inherit;
  padding: clamp(28px, 3.4vw, 46px) 0; transition: padding-left 560ms cubic-bezier(0.16,1,0.3,1);
}
.accord__item:hover .accord__head { padding-left: 12px; }
.accord__num { font-family: var(--cco-font-editorial); font-size: 1.3rem; color: var(--cco-bronze-light); }
.accord__name { font-family: var(--cco-font-body); font-weight: 500; font-size: clamp(1.5rem, 2.5vw, 2.3rem); line-height: 1.14; letter-spacing: 0.005em; color: color-mix(in srgb, var(--cco-vellum) 72%, transparent); transition: color 460ms ease; }
.accord__item.is-open .accord__name { color: var(--cco-vellum); }
.accord__plus { position: relative; width: 22px; height: 22px; justify-self: end; }
.accord__plus::before, .accord__plus::after { content: ""; position: absolute; left: 50%; top: 50%; background: var(--cco-bronze-light); transition: transform 520ms cubic-bezier(0.16,1,0.3,1), opacity 420ms ease; }
.accord__plus::before { width: 16px; height: 1px; transform: translate(-50%,-50%); }
.accord__plus::after { width: 1px; height: 16px; transform: translate(-50%,-50%); }
.accord__item.is-open .accord__plus::after { transform: translate(-50%,-50%) rotate(90deg); opacity: 0; }
.accord__panel { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 640ms cubic-bezier(0.16,1,0.3,1); }
.accord__item.is-open .accord__panel { grid-template-rows: 1fr; }
.accord__inner {
  overflow: hidden;
  margin-left: clamp(0px, 6vw, 88px);
  border-left: 2px solid var(--cco-bronze-light);
  background: color-mix(in srgb, var(--cco-vellum) 6%, transparent);
  backdrop-filter: blur(16px) saturate(116%);
  -webkit-backdrop-filter: blur(16px) saturate(116%);
}
.accord__desc {
  margin: 0; max-width: 64ch;
  font-size: clamp(1.08rem, 1.4vw, 1.24rem); line-height: 1.64;
  color: color-mix(in srgb, var(--cco-vellum) 84%, transparent);
  padding: clamp(26px, 2.8vw, 40px) clamp(28px, 3.2vw, 48px);
  opacity: 0; transform: translateY(10px);
  transition: opacity 600ms ease 150ms, transform 700ms cubic-bezier(0.16,1,0.3,1) 150ms;
}
.accord__item.is-open .accord__desc { opacity: 1; transform: none; }
.accord__desc + .accord__desc { padding-top: 0; }
@media (max-width: 640px) { .accord__head { grid-template-columns: 40px 1fr 28px; } .accord__inner { margin-left: 0; } }

/* ---------- contact CTA (slate close: large seal + stacked inquiry) ---------- */
.contact--close { background: var(--cco-slate); color: var(--cco-vellum); }
.contact--close .sec-index .lbl { color: var(--cco-vellum); }
.contact--close .sec-index .ln { background: color-mix(in srgb, var(--cco-bronze-light) 28%, transparent); }
.contact2 { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(40px, 7vw, 110px); align-items: center; }
.contact2__sealwrap { display: flex; justify-content: center; }
.contact2__seal { width: 100%; max-width: clamp(260px, 42vw, 500px); height: auto; aspect-ratio: 1; }
.contact2__body { display: grid; gap: clamp(26px, 3vw, 40px); align-content: center; justify-items: start; max-width: 30ch; }
.contact2__eyebrow { color: var(--cco-bronze-light); }
.contact2__title { font-family: var(--cco-font-body); font-weight: 400; font-style: italic; letter-spacing: 0.005em; font-size: clamp(1.85rem, 2.9vw, 2.95rem); line-height: 1.32; color: var(--cco-vellum); margin: 0; }
.contact2__details { display: grid; gap: clamp(18px, 2vw, 26px); width: 100%; padding-top: clamp(22px, 2.6vw, 32px); border-top: 1px solid color-mix(in srgb, var(--cco-bronze-light) 24%, transparent); }
.contact2 .cdetail { display: grid; gap: 6px; }
.contact2 .cdetail__lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.6rem; color: var(--cco-bronze-light); }
.contact2 .cdetail__val { font-family: var(--cco-font-editorial); font-size: 1.3rem; letter-spacing: -0.005em; color: var(--cco-vellum); }
.contact2 .cdetail__val a:hover { color: var(--cco-bronze-light); }
.contact2__btn { display: inline-flex; align-items: center; gap: 16px; margin-top: clamp(6px, 1vw, 10px); padding: clamp(18px, 1.9vw, 23px) clamp(32px, 3.2vw, 46px); border: 1px solid color-mix(in srgb, var(--cco-bronze-light) 60%, transparent); color: var(--cco-vellum); font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.28em; font-size: 0.7rem; transition: background 460ms ease, color 460ms ease, gap 460ms ease, border-color 460ms ease; }
.contact2__btn:hover { background: var(--cco-bronze-light); border-color: var(--cco-bronze-light); color: var(--cco-slate); gap: 24px; }
.contact2__btn i { width: 26px; height: 1px; background: currentColor; position: relative; display: block; }
.contact2__btn i::after { content: ""; position: absolute; right: 0; top: -3px; width: 7px; height: 7px; border-top: 1px solid currentColor; border-right: 1px solid currentColor; transform: rotate(45deg); }
@media (max-width: 760px) { .contact2 { grid-template-columns: 1fr; gap: clamp(34px, 8vw, 48px); text-align: left; } .contact2__seal { max-width: 280px; } .contact2__sealwrap { order: -1; } }

/* ---------- contact page (Get in touch: form + inquiry directory) ---------- */
.cpage__lead { max-width: 48ch; margin-bottom: clamp(44px, 6vw, 72px); }
.cpage__lead .display { font-size: clamp(2rem, 3.2vw, 3rem); margin-bottom: clamp(14px, 1.6vw, 20px); }
.cpage__grid { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(0, 0.72fr); gap: clamp(40px, 6vw, 104px); align-items: start; }
.cside { display: grid; gap: clamp(26px, 3vw, 38px); align-content: start; }
.cside__group { display: grid; gap: 8px; padding-bottom: clamp(20px, 2.4vw, 30px); border-bottom: 1px solid var(--cco-vellum-deep); }
.cside__group:last-child { border-bottom: 0; }
.cside__lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.62rem; color: var(--cco-bronze-deep); }
.cside__email { font-family: var(--cco-font-body); font-weight: 500; font-size: clamp(1.18rem, 1.45vw, 1.4rem); letter-spacing: 0.005em; color: var(--cco-slate); transition: color 320ms ease; }
.cside__email a, .cside__email { color: var(--cco-slate); }
.cside__email a:hover { color: var(--cco-bronze-deep); }
.field .opt { opacity: 0.5; text-transform: none; letter-spacing: 0; }
.field .req { color: var(--cco-bronze-deep); }
.field textarea { border: 1px solid color-mix(in srgb, var(--cco-slate) 24%, var(--cco-vellum)); border-radius: 2px; padding: 16px 18px; min-height: 150px; transition: border-color 360ms ease; }
.field textarea:focus { border-color: var(--cco-bronze-deep); }
/* Message field: no divider above (read as a second underline on Company); spacing carries the separation */
.cform .field:has(textarea) { padding-top: clamp(18px, 2vw, 26px); margin-top: clamp(2px, 0.6vw, 6px); }
.cform .field:has(textarea) label { margin-top: 0; }
/* form rhythm: tuck each input line up under its own label, and add clear
   separation between fields so a line never reads as belonging to the label below it */
.cform .form__fields { display: grid; gap: clamp(24px, 2.8vw, 32px); }
.cform .field { gap: 7px; }
.cform .field input { padding: 5px 0 8px; }
.cform .field:has(textarea) { margin-top: 0; padding-top: clamp(22px, 2.6vw, 32px); }
.submit:disabled { opacity: 0.42; cursor: not-allowed; }
.submit:disabled:hover { background: var(--cco-slate); letter-spacing: 0.26em; }
/* inline validation: button stays live brand-slate; errors surface here instead */
.form__error { font-family: var(--cco-font-body); font-style: italic; font-size: 1rem; line-height: 1.4; color: var(--cco-bronze-deep); margin: 14px 0 0; }
.field input.is-invalid, .field textarea.is-invalid { border-bottom-color: var(--cco-bronze-deep); }
.field textarea.is-invalid { border-color: var(--cco-bronze-deep); }
@media (max-width: 860px) { .cpage__grid { grid-template-columns: 1fr; gap: clamp(40px, 7vw, 56px); } }

/* ---------- footer ---------- */
.foot { background: var(--cco-slate-darker); color: var(--cco-vellum); padding: clamp(48px, 6vw, 76px) clamp(28px, 7vw, 128px); display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 20px; }
.foot__mark { width: 220px; height: auto; }
.foot p { margin: 0; font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.28em; font-size: 0.6rem; color: color-mix(in srgb, var(--cco-vellum) 58%, transparent); }
.foot__variant { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.28em; font-size: 0.6rem; color: var(--cco-bronze-light); transition: color 320ms ease; }
.foot__variant:hover { color: var(--cco-vellum); }

/* ---------- cinematic stat band (full-bleed image + oversized numerals) ---------- */
.statband { position: relative; overflow: hidden; padding: clamp(100px, 14vw, 188px) clamp(28px, 7vw, 128px); color: var(--cco-vellum); }
.statband__media { position: absolute; inset: 0; z-index: 0; }
.statband__media img { width: 100%; height: 118%; }
.statband__inner { position: relative; z-index: 3; max-width: 1280px; margin: 0 auto; }
.statband__head { display: flex; align-items: center; gap: 18px; margin-bottom: clamp(48px, 6vw, 84px); }
.statband__head .lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.3em; font-size: 0.66rem; color: var(--cco-bronze-light); }
.statband__head .ln { flex: 1; height: 1px; background: color-mix(in srgb, var(--cco-bronze-light) 32%, transparent); }
.statband__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(32px, 4vw, 72px); }
.statbig { display: grid; gap: 0; align-content: start; }
.statbig__fig { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(3rem, 7vw, 6rem); line-height: 1; letter-spacing: -0.02em; color: var(--cco-vellum); white-space: nowrap; min-height: clamp(3rem, 7vw, 6rem); display: flex; align-items: flex-end; margin-bottom: clamp(16px, 1.6vw, 22px); }
.statbig__fig .u { color: var(--cco-bronze-light); }
.statbig__lbl { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.66rem; color: var(--cco-bronze-light); display: block; padding-top: clamp(14px, 1.4vw, 18px); border-top: 1px solid color-mix(in srgb, var(--cco-bronze-light) 28%, transparent); margin-bottom: clamp(16px, 1.8vw, 24px); }
.statbig__note { font-size: 1.04rem; line-height: 1.55; color: color-mix(in srgb, var(--cco-vellum) 80%, transparent); max-width: 34ch; margin: 0; }
.statbig__fig--word { font-size: clamp(2.2rem, 4vw, 3.8rem); letter-spacing: -0.01em; }
@media (max-width: 760px) { .statband__grid { grid-template-columns: 1fr; gap: 44px; } }

/* ---------- portfolio grid ---------- */
.portfolio__head { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 28px; margin-bottom: clamp(48px, 6vw, 84px); }
.portfolio__head .display { font-size: clamp(2.1rem, 3.6vw, 3.4rem); max-width: 18ch; }
.portfolio__note { max-width: 34ch; color: color-mix(in srgb, var(--cco-slate) 76%, var(--cco-vellum)); }
.pf__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px, 1.6vw, 26px); }
.pf__item { display: block; }
.pf__media { position: relative; aspect-ratio: 4 / 5; overflow: hidden; }
.pf__media img { width: 100%; height: 100%; transition: transform 1200ms cubic-bezier(0.16,1,0.3,1); }
.pf__item:hover .pf__media img { transform: scale(1.05); }
.pf__cap { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; padding: 16px 2px 0; border-top: 1px solid var(--cco-vellum-deep); margin-top: 16px; }
.pf__name { font-family: var(--cco-font-body); font-weight: 500; font-size: 1.16rem; color: var(--cco-slate); letter-spacing: 0.005em; }
.pf__meta { font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.22em; font-size: 0.58rem; color: var(--cco-bronze-deep); white-space: nowrap; }
.portfolio__foot { margin-top: clamp(36px, 4vw, 56px); font-family: var(--cco-font-body); font-style: italic; font-size: 1.04rem; color: color-mix(in srgb, var(--cco-slate) 62%, var(--cco-vellum)); }
@media (max-width: 880px) { .pf__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .pf__grid { grid-template-columns: 1fr; } }

/* ---------- Florida thesis (full-bleed + overlaid column) ---------- */
.thesis { position: relative; overflow: hidden; min-height: clamp(560px, 84vh, 880px); display: flex; align-items: flex-end; }
.thesis__media { position: absolute; inset: 0; z-index: 0; }
.thesis__media img { width: 100%; height: 116%; }
.thesis__inner { position: relative; z-index: 3; width: 100%; max-width: 1280px; margin: 0 auto; padding: clamp(56px, 9vh, 128px) clamp(28px, 7vw, 128px); }
.thesis__col { max-width: 44ch; background: color-mix(in srgb, var(--cco-slate-darker) 78%, transparent); backdrop-filter: blur(5px) saturate(125%); padding: clamp(36px, 4vw, 60px); }
.thesis__eyebrow { margin-bottom: clamp(22px, 3vw, 34px); }
.thesis__title { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(2.1rem, 4.2vw, 3.8rem); line-height: 1.12; letter-spacing: -0.01em; color: var(--cco-vellum); margin: 0 0 clamp(24px, 3vw, 36px); }
.thesis__body { font-size: 1.18rem; line-height: 1.62; color: color-mix(in srgb, var(--cco-vellum) 88%, transparent); }

/* section-index hairline draws in on reveal */
.sec-index .ln { transform: scaleX(0); transform-origin: left center; transition: transform 1000ms cubic-bezier(0.16,1,0.3,1); transition-delay: 220ms; }
.sec-index.in .ln { transform: scaleX(1); }

/* ---------- firm: editorial split with sticky plate ---------- */
.firm2 { display: grid; grid-template-columns: minmax(0, 1.32fr) minmax(0, 0.68fr); gap: clamp(40px, 6vw, 112px); align-items: start; }
.firm2__lead { font-family: var(--cco-font-body); font-weight: 500; font-size: clamp(1.6rem, 2.5vw, 2.3rem); line-height: 1.34; letter-spacing: 0.005em; color: var(--cco-slate); max-width: 26ch; margin: 0 0 clamp(40px, 5vw, 64px); }
.firm2__lead em { font-style: italic; color: var(--cco-bronze-deep); }
.firm2__cols { display: grid; gap: 1.3em; max-width: 56ch; }
.firm2__cols p { margin: 0; font-size: 1.18rem; line-height: 1.64; }
.firm2__media { position: sticky; top: clamp(104px, 15vh, 160px); }
.firm2__frame { aspect-ratio: 3 / 4; width: 100%; }
.firm2__cap { display: flex; align-items: center; gap: 12px; margin: 18px 0 0; font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.26em; font-size: 0.6rem; color: var(--cco-bronze-deep); }
.firm2__cap::before { content: ""; width: 22px; height: 1px; background: var(--cco-bronze-deep); display: inline-block; }
@media (max-width: 880px) {
  .firm2 { grid-template-columns: 1fr; gap: 48px; }
  .firm2__media { position: static; order: -1; }
  .firm2__frame { aspect-ratio: 16 / 10; }
}

/* ---------- motion (crisp; transforms only on media + non-text) ---------- */
.r { opacity: 0; transform: translateY(22px); transition: opacity 900ms cubic-bezier(0.16,1,0.3,1), transform 900ms cubic-bezier(0.16,1,0.3,1); transition-delay: var(--d, 0ms); }
.r.in { opacity: 1; transform: none; }
.r-rule { transform: scaleX(0); transform-origin: left center; transition: transform 1000ms cubic-bezier(0.16,1,0.3,1); transition-delay: var(--d, 0ms); }
.r-rule.in { transform: scaleX(1); }
.r-head { clip-path: inset(0 0 102% 0); transition: clip-path 1100ms cubic-bezier(0.16,1,0.3,1); transition-delay: var(--d, 0ms); }
.r-head.in { clip-path: inset(0 0 -10% 0); }
/* media reveal: slow settle of the image scale (image only, never text) */
.r-media img { transform: scale(1.12); transition: transform 1800ms cubic-bezier(0.16,1,0.3,1); }
.r-media.in img { transform: scale(1); }
/* ---- track-record reveal variants (compared via the review toggle on home) ----
   All use a smooth ease (not the snappy global expo) so none feel jumpy. */
/* Quiet fade: uniform fade + small lift, no directional wipe */
.statband[data-stat-anim="fade"] .statbig.r { transform: translateY(12px); transition: opacity 1500ms cubic-bezier(0.33,0,0.2,1), transform 1500ms cubic-bezier(0.33,0,0.2,1); transition-delay: var(--d, 0ms); }
.statband[data-stat-anim="fade"] .statbig__fig.r-head { clip-path: none; transition: none; }
/* Soft diagonal: keep the top-down figure wipe + gentle column stagger, slowed and eased */
.statband[data-stat-anim="diagonal"] .statbig.r { transform: translateY(16px); transition-duration: 1450ms; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); }
.statband[data-stat-anim="diagonal"] .statbig__fig.r-head { transition-duration: 1650ms; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); }
/* Stationary: figures simply present in full, no entrance motion */
.statband[data-stat-anim="stationary"] .statbig.r { opacity: 1; transform: none; transition: none; }
.statband[data-stat-anim="stationary"] .statbig__fig.r-head { clip-path: none; transition: none; }
@media (prefers-reduced-motion: reduce) {
  .r, .r-rule, .r-head { transition: none !important; opacity: 1 !important; transform: none !important; clip-path: none !important; }
  .r-media img { transition: none !important; transform: none !important; }
  .hero__cue i { animation: none; }
}

/* ============================================================
   COPY-UPDATE ADDITIONS (Dec 2026) — bronze-italic on display
   headings, light accordion variant, Strategies + Beyond sections
   ============================================================ */

/* Bronze treatment on italicized phrases inside display headings.
   Light grounds use bronze-deep; dark grounds use bronze-light. */
.display em,
.split__title em,
.vint__title em,
.thesis__title em,
.approach__title em,
.contact__title em,
.focusx__title em,
.strat__lede em,
.beyond__title em,
.pursue__head .display em { font-style: italic; color: var(--cco-bronze-deep); }
.display.on-dark em,
.split__title em,
.vint--dark .vint__title em,
.thesis__title em,
.beyond__title em,
.pursue__head .display em,
.bay--slate .display em { color: var(--cco-bronze-light); }

/* ---------- Strategies (white accordion variant) ---------- */
.strat__lede { font-family: var(--cco-font-body); font-weight: 500; font-style: italic; font-size: clamp(1.5rem, 2.2vw, 2.1rem); line-height: 1.4; letter-spacing: 0.005em; color: var(--cco-slate); max-width: 30ch; margin: 0 0 clamp(48px, 6vw, 80px); }
.accord--light { border-top-color: var(--cco-vellum-deep); }
.accord--light .accord__item { border-bottom-color: var(--cco-vellum-deep); }
.accord--light .accord__num { color: var(--cco-bronze-deep); }
.accord--light .accord__name { color: color-mix(in srgb, var(--cco-slate) 64%, var(--cco-vellum)); }
.accord--light .accord__item.is-open .accord__name { color: var(--cco-slate); }
.accord--light .accord__inner { background: color-mix(in srgb, var(--cco-slate) 4%, transparent); border-left-color: var(--cco-bronze-deep); }
.accord--light .accord__plus::before, .accord--light .accord__plus::after { background: var(--cco-bronze-deep); }
.accord--light .accord__desc { color: color-mix(in srgb, var(--cco-slate) 76%, var(--cco-vellum)); }
.accord__desc:last-child { margin-bottom: clamp(34px, 4vw, 52px); }

/* ---------- Beyond Real Estate (slate feature) ---------- */
.beyond { position: relative; overflow: hidden; }
.beyond__grid { display: grid; grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr); gap: clamp(40px, 7vw, 120px); align-items: start; }
.beyond__aside .eyebrow { margin-bottom: clamp(20px, 2.4vw, 30px); }
.beyond__title { font-family: var(--cco-font-editorial); font-weight: 400; font-size: clamp(2rem, 3.6vw, 3.4rem); line-height: 1.12; letter-spacing: -0.01em; color: var(--cco-vellum); margin: 0; max-width: 16ch; }
.beyond__medallion { width: clamp(132px, 14vw, 188px); height: auto; margin-bottom: clamp(28px, 3vw, 40px); opacity: 0.95; }
.beyond__body { display: grid; gap: 1.3em; max-width: 56ch; }
.beyond__body p { margin: 0; font-size: 1.18rem; line-height: 1.64; color: color-mix(in srgb, var(--cco-vellum) 84%, transparent); }
@media (max-width: 880px) { .beyond__grid { grid-template-columns: 1fr; gap: 44px; } }

/* ---------- Track Record footnotes + superscripts ---------- */
.statbig__lbl sup { font-size: 0.62em; vertical-align: super; color: var(--cco-bronze-light); font-family: var(--cco-font-body); letter-spacing: 0; margin-left: 2px; }
.statband__notes { max-width: 1280px; margin: clamp(56px, 7vw, 96px) auto 0; padding-top: clamp(28px, 3vw, 40px); border-top: 1px solid color-mix(in srgb, var(--cco-bronze-light) 26%, transparent); display: grid; gap: 14px; }
.statband__notes p { margin: 0; font-size: 0.84rem; line-height: 1.55; color: color-mix(in srgb, var(--cco-vellum) 62%, transparent); max-width: 96ch; }
.statband__notes sup { color: var(--cco-bronze-light); }

/* ---------- site legal (compact triggers, expand on click) ---------- */
.legal { background: var(--cco-slate-darker); color: var(--cco-vellum); padding: clamp(14px, 1.6vw, 20px) clamp(20px, 4vw, 56px) clamp(16px, 2vw, 24px); }
.legal__bar { display: flex; flex-wrap: wrap; align-items: center; gap: 12px 26px; padding-top: clamp(12px, 1.4vw, 18px); border-top: 1px solid color-mix(in srgb, var(--cco-bronze-light) 14%, transparent); }
.legal__trigger { background: none; border: 0; cursor: pointer; font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.24em; font-size: 0.58rem; color: color-mix(in srgb, var(--cco-vellum) 64%, transparent); display: inline-flex; align-items: center; gap: 8px; padding: 0; transition: color 300ms ease; }
.legal__trigger:hover { color: var(--cco-vellum); }
.legal__trigger i { position: relative; width: 9px; height: 9px; color: var(--cco-bronze-light); }
.legal__trigger i::before, .legal__trigger i::after { content: ""; position: absolute; left: 50%; top: 50%; background: currentColor; }
.legal__trigger i::before { width: 9px; height: 1px; transform: translate(-50%,-50%); }
.legal__trigger i::after { width: 1px; height: 9px; transform: translate(-50%,-50%); transition: transform 360ms ease, opacity 300ms ease; }
.legal__trigger[aria-expanded="true"] i::after { transform: translate(-50%,-50%) rotate(90deg); opacity: 0; }
.legal__copy { margin-left: auto; font-family: var(--cco-font-smallcaps); text-transform: uppercase; letter-spacing: 0.22em; font-size: 0.56rem; color: color-mix(in srgb, var(--cco-vellum) 46%, transparent); }
.legal__expand { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 480ms cubic-bezier(0.16,1,0.3,1); }
.legal__expand.is-open { grid-template-rows: 1fr; }
.legal__expand > div { overflow: hidden; }
.legal__notes { display: grid; gap: 5px; padding-top: clamp(16px, 1.8vw, 22px); margin: 0; }
.legal__notes p { margin: 0; font-size: 0.6rem; line-height: 1.5; color: color-mix(in srgb, var(--cco-vellum) 56%, transparent); max-width: 130ch; }
.legal__notes sup { color: color-mix(in srgb, var(--cco-bronze-light) 72%, transparent); margin-right: 2px; }
.legal__disc { display: grid; gap: 8px; padding-top: clamp(16px, 1.8vw, 22px); }
.legal__disc p { margin: 0; font-size: 0.58rem; line-height: 1.55; color: color-mix(in srgb, var(--cco-vellum) 46%, transparent); max-width: 130ch; letter-spacing: 0.005em; }

/* Our Philosophy: longer multi-paragraph tab panels */
.focusx__body p + p { margin-top: 1em; }
.focusx__body strong { font-style: italic; font-weight: 500; color: var(--cco-bronze-deep); }
.focusx__panel { justify-content: flex-start; }
.focusx__panel.is-active { padding-top: clamp(56px, 6vw, 84px); }
