/* ════════════════════════════════════════════════════════
   LOCALITY PARTNERS — Sub-page styles
   Shared across About / Services / Industries / Insights / Articles
   Depends on locality.css (loaded first)
════════════════════════════════════════════════════════ */

/* ──────────── SUB-PAGE HERO ──────────── */
.page-hero {
  position: relative;
  background: var(--navy);
  color: var(--white);
  overflow: hidden;
  padding: clamp(150px, 20vh, 220px) 0 clamp(70px, 9vw, 110px);
}
.page-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(120% 90% at 80% -10%, rgba(42,84,122,0.5) 0%, rgba(13,34,64,0) 60%);
  pointer-events: none;
}
.page-hero .ph-ring {
  position: absolute; border-radius: 50%;
  border: 1px solid rgba(201,148,62,0.14); pointer-events: none;
}
.page-hero-inner { position: relative; z-index: 2; max-width: 940px; }
.crumb { display: flex; align-items: center; gap: 10px; font-size: 12px; letter-spacing: 0.5px; color: var(--text-light); margin-bottom: 28px; }
.crumb a { color: var(--text-light); transition: color 0.3s var(--ease); }
.crumb a:hover { color: var(--gold-light); }
.crumb .sep { opacity: 0.5; }
.crumb .here { color: rgba(255,255,255,0.7); }
.page-hero h1 {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(44px, 6.4vw, 88px);
  line-height: 1.06; letter-spacing: -1.5px; color: var(--white);
  margin-top: 22px; max-width: 18ch;
}
.page-hero h1 em { color: var(--gold-light); font-style: italic; }
.page-hero .lede { color: rgba(255,255,255,0.72); margin-top: 36px; max-width: 64ch; font-weight: 300; }

/* generic intro lead under section heads */
.measure { max-width: 760px; }

/* section more-link */
.section-more { display: inline-flex; align-items: center; gap: 10px; margin-top: 40px; font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold); }
.section-more .arrow { transition: transform 0.4s var(--ease); }
.section-more:hover .arrow { transform: translateX(5px); }

/* ──────────── ABOUT — FIRM STORY ──────────── */
.story-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 64px; align-items: start; margin-top: 8px; }
.story-lead { font-family: var(--serif); font-weight: 300; font-size: clamp(24px, 2.6vw, 34px); line-height: 1.5; color: var(--navy); }
.story-quote { margin-top: 30px; border-left: 2px solid var(--gold); padding-left: 22px; font-family: var(--serif); font-style: italic; font-size: clamp(20px, 2.2vw, 26px); font-weight: 300; line-height: 1.5; color: var(--text-mid); }
.story-cards { display: flex; flex-direction: column; gap: 16px; }
.story-card { background: var(--off-white); border: 1px solid var(--border-soft); border-radius: 4px; padding: 26px 28px; }
.story-card .sc-label { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); margin-bottom: 10px; }
.story-card p { font-size: 14px; color: var(--text-mid); line-height: 1.75; }
.story-card strong { color: var(--navy); }

/* credentials band */
.cred-band { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.12); border-radius: 4px; overflow: hidden; margin-top: 8px; }
.cred-cell { background: var(--navy); padding: 36px 30px; }
.cred-cell .cred-num { font-family: var(--serif); font-weight: 300; font-size: clamp(38px, 4.4vw, 56px); line-height: 1; color: var(--gold-light); letter-spacing: -1px; }
.cred-cell .cred-label { font-size: 12px; letter-spacing: 1px; color: rgba(255,255,255,0.6); margin-top: 12px; line-height: 1.5; }
.pedigree-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 40px; }
.pedigree-pill { font-size: 12px; letter-spacing: 1px; color: rgba(255,255,255,0.82); display: inline-flex; align-items: center; gap: 10px; border: 1px solid rgba(255,255,255,0.16); border-radius: 100px; padding: 9px 18px; }
.pedigree-pill::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--gold); }
.cred-foot { margin-top: 36px; max-width: 70ch; font-family: var(--serif); font-style: italic; font-weight: 300; font-size: clamp(18px, 2vw, 23px); line-height: 1.55; color: var(--gold-light); }

/* ──────────── TEAM ──────────── */
.team-list { display: flex; flex-direction: column; gap: 28px; margin-top: 60px; }
.team-card { background: var(--white); border: 1px solid var(--border-soft); border-radius: 4px; overflow: hidden; display: grid; grid-template-columns: 300px 1fr; }
.team-aside { background: var(--navy); color: var(--white); padding: 38px 32px; display: flex; flex-direction: column; }
.team-portrait { aspect-ratio: 1; border-radius: 4px; background: linear-gradient(160deg, rgba(42,84,122,0.6), rgba(13,34,64,0.2)), repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 12px); display: flex; align-items: flex-end; padding: 16px; margin-bottom: 26px; position: relative; }
.team-portrait .ph-tag { font-family: monospace; font-size: 10px; letter-spacing: 1px; color: rgba(255,255,255,0.45); border: 1px dashed rgba(255,255,255,0.25); padding: 5px 9px; border-radius: 2px; }
.team-name { font-family: var(--serif); font-size: 30px; font-weight: 400; line-height: 1.05; }
.team-role { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold-light); margin-top: 8px; }
.team-meta { margin-top: 24px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,0.14); display: flex; flex-direction: column; gap: 14px; }
.team-meta .tm-row .tm-k { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--text-light); margin-bottom: 4px; }
.team-meta .tm-row .tm-v { font-size: 13px; color: rgba(255,255,255,0.82); line-height: 1.5; }
.team-meta .tm-row a.tm-v:hover { color: var(--gold-light); }
.team-body { padding: 40px 42px; }
.team-body .tb-eyebrow { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.team-body p { font-size: 15px; color: var(--text-mid); line-height: 1.8; margin-bottom: 16px; }
.team-body p strong { color: var(--navy); font-weight: 700; }
.tb-sub { font-family: var(--serif); font-size: 20px; font-weight: 500; color: var(--navy); margin: 26px 0 14px; }
.tb-highlights { list-style: none; display: flex; flex-direction: column; gap: 1px; }
.tb-highlights li { font-size: 14px; color: var(--text-mid); line-height: 1.6; padding: 12px 0 12px 20px; position: relative; border-top: 1px solid var(--border-soft); }
.tb-highlights li::before { content: ''; position: absolute; left: 0; top: 20px; width: 5px; height: 5px; border-radius: 50%; background: var(--gold); }
.tb-edu { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.tb-edu span { font-size: 12px; letter-spacing: 0.4px; color: var(--text-mid); border: 1px solid var(--border); border-radius: 100px; padding: 6px 14px; }

/* ──────────── CASE STUDIES ──────────── */
.case-list { display: flex; flex-direction: column; gap: 24px; margin-top: 60px; }
.case-card { background: var(--white); border: 1px solid var(--border-soft); border-radius: 4px; overflow: hidden; display: grid; grid-template-columns: 1.4fr 1fr; }
.case-main { padding: 40px 42px; }
.case-tag { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.case-title { font-family: var(--serif); font-size: clamp(24px, 2.6vw, 32px); font-weight: 400; color: var(--navy); line-height: 1.15; margin-bottom: 16px; }
.case-ctx { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-light); margin: 22px 0 10px; }
.case-card p { font-size: 14px; color: var(--text-mid); line-height: 1.75; }
.case-do { list-style: none; display: flex; flex-direction: column; gap: 10px; margin-top: 8px; }
.case-do li { font-size: 14px; color: var(--text-mid); line-height: 1.6; padding-left: 20px; position: relative; }
.case-do li::before { content: ''; position: absolute; left: 0; top: 9px; width: 5px; height: 5px; border-radius: 50%; background: var(--gold); }
.case-metrics { background: var(--navy); color: var(--white); padding: 40px 36px; display: flex; flex-direction: column; gap: 26px; justify-content: center; }
.case-metric .cm-num { font-family: var(--serif); font-weight: 300; font-size: clamp(40px, 4.6vw, 56px); line-height: 1; color: var(--gold-light); letter-spacing: -1px; }
.case-metric .cm-label { font-size: 12px; letter-spacing: 0.5px; color: rgba(255,255,255,0.62); margin-top: 8px; line-height: 1.5; }

/* ──────────── SERVICES (full) ──────────── */
.svc-pillar { padding: clamp(56px, 8vw, 96px) 0; border-top: 1px solid var(--border-soft); }
.svc-pillar:first-of-type { border-top: none; }
.svc-head { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 48px; align-items: end; margin-bottom: 56px; }
.svc-pillar-num { font-family: var(--serif); font-size: clamp(56px, 8vw, 96px); font-weight: 300; color: var(--cream); line-height: 0.9; }
.svc-pillar-title { font-family: var(--serif); font-size: clamp(34px, 4.2vw, 52px); font-weight: 300; color: var(--navy); line-height: 1.05; letter-spacing: -0.5px; }
.svc-pillar-sub { font-size: clamp(16px, 1.5vw, 18px); color: var(--text-mid); line-height: 1.75; margin-top: 20px; }
.svc-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--border-soft); border: 1px solid var(--border-soft); border-radius: 4px; overflow: hidden; }
.svc-item { background: var(--white); padding: 30px 32px; transition: background 0.4s var(--ease); }
.svc-item:hover { background: var(--off-white); }
.svc-item .svc-idx { font-family: var(--serif); font-size: 14px; color: var(--gold); letter-spacing: 1px; }
.svc-item h3 { font-family: var(--serif); font-size: 23px; font-weight: 500; color: var(--navy); margin: 8px 0 12px; line-height: 1.2; }
.svc-item p { font-size: 14px; color: var(--text-mid); line-height: 1.7; }
.svc-item .svc-tags { list-style: none; display: flex; flex-wrap: wrap; gap: 6px; margin-top: 16px; }
.svc-item .svc-tags li { font-size: 11px; letter-spacing: 0.4px; color: var(--text-light); border: 1px solid var(--border); border-radius: 100px; padding: 4px 11px; }
.svc-pillar.dark { background: var(--navy); }
.svc-pillar.dark .svc-pillar-num { color: rgba(255,255,255,0.1); }
.svc-pillar.dark .svc-pillar-title { color: var(--white); }
.svc-pillar.dark .svc-pillar-sub { color: rgba(255,255,255,0.66); }
.svc-pillar.dark .svc-grid { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.12); }
.svc-pillar.dark .svc-item { background: var(--navy); }
.svc-pillar.dark .svc-item:hover { background: var(--navy-mid); }
.svc-pillar.dark .svc-item h3 { color: var(--white); }
.svc-pillar.dark .svc-item p { color: rgba(255,255,255,0.6); }
.svc-pillar.dark .svc-item .svc-tags li { color: var(--gold-light); border-color: rgba(201,148,62,0.32); }
.svc-view { margin-top: 16px; font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold); display: inline-flex; align-items: center; gap: 8px; }
.svc-view .arrow { transition: transform 0.4s var(--ease); }
a.svc-item:hover .svc-view .arrow { transform: translateX(5px); }
.svc-pillar.dark a.svc-item .svc-view { color: var(--gold-light); }
.sd-siblings { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }
.sd-sibling { font-size: 13px; color: var(--text-mid); border: 1px solid var(--border); border-radius: 100px; padding: 8px 16px; transition: border-color 0.3s var(--ease), color 0.3s var(--ease); }
.sd-sibling:hover { border-color: var(--navy); color: var(--navy); }
.sd-wrap { max-width: 860px; margin: 0 auto; }
.sd-wrap > .article-lead:first-child { margin-top: 0; }

/* sub-services list on service detail pages */
.svc-subs { display: flex; flex-direction: column; margin: 8px 0 26px; border-top: 1px solid var(--border-soft); }
.svc-sub { padding: 18px 0; border-bottom: 1px solid var(--border-soft); display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 28px; align-items: baseline; }
.svc-sub .ss-n { font-family: var(--serif); font-size: 20px; font-weight: 500; color: var(--navy); line-height: 1.3; }
.svc-sub .ss-d { font-size: 15px; color: var(--text-mid); line-height: 1.7; }
.svc-sub .ss-d strong { color: var(--navy); font-weight: 700; }
@media (max-width: 680px) { .svc-sub { grid-template-columns: 1fr; gap: 6px; } }

/* ──────────── INDUSTRIES (full) ──────────── */
.indf-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 60px; }
.indf-card { background: var(--white); border: 1px solid var(--border-soft); border-radius: 4px; padding: 38px 36px; position: relative; overflow: hidden; transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease), border-color 0.5s var(--ease); }
.indf-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform 0.5s var(--ease); }
.indf-card:hover { transform: translateY(-6px); box-shadow: 0 28px 60px -30px rgba(13,34,64,0.28); border-color: var(--border); }
.indf-card:hover::before { transform: scaleX(1); }
.indf-top { display: flex; align-items: baseline; gap: 14px; margin-bottom: 8px; }
.indf-idx { font-family: var(--serif); font-size: 16px; color: var(--gold); letter-spacing: 1px; }
.indf-name { font-family: var(--serif); font-size: clamp(26px, 2.8vw, 32px); font-weight: 400; color: var(--navy); line-height: 1.1; }
.indf-desc { font-size: 14px; color: var(--text-mid); line-height: 1.75; margin-top: 12px; }
.indf-work { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--text-light); margin: 24px 0 12px; }
.indf-points { list-style: none; display: flex; flex-direction: column; gap: 1px; }
.indf-points li { font-size: 13px; color: var(--text-mid); line-height: 1.55; padding: 10px 0 10px 18px; position: relative; border-top: 1px solid var(--border-soft); }
.indf-points li::before { content: ''; position: absolute; left: 0; top: 17px; width: 5px; height: 5px; border-radius: 50%; background: var(--gold); }
.indf-tags { list-style: none; display: flex; flex-wrap: wrap; gap: 7px; margin-top: 18px; }
.indf-tags li { font-size: 11px; letter-spacing: 0.4px; color: var(--text-light); border: 1px solid var(--border); border-radius: 100px; padding: 5px 12px; }

/* ──────────── ARTICLE ──────────── */
.article-hero { position: relative; background: var(--navy); color: var(--white); overflow: hidden; padding: clamp(140px, 18vh, 200px) 0 clamp(48px, 6vw, 72px); }
.article-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(120% 90% at 80% -10%, rgba(42,84,122,0.5) 0%, rgba(13,34,64,0) 60%); pointer-events: none; }
.article-wrap { max-width: 760px; margin: 0 auto; padding-inline: var(--gutter); position: relative; z-index: 2; }
.article-topic { font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold-light); }
.article-title { font-family: var(--serif); font-weight: 300; font-size: clamp(34px, 5vw, 60px); line-height: 1.08; letter-spacing: -0.5px; color: var(--white); margin: 20px 0 24px; }
.article-meta { display: flex; flex-wrap: wrap; gap: 8px 20px; font-size: 12px; letter-spacing: 0.5px; color: rgba(255,255,255,0.6); }
.article-meta .am-dot { color: var(--gold); }
.article-body { background: var(--white); }
.article-body .article-wrap { padding-top: clamp(56px, 7vw, 84px); padding-bottom: clamp(56px, 7vw, 84px); }
.article-lead { font-family: var(--serif); font-weight: 300; font-size: clamp(22px, 2.6vw, 28px); line-height: 1.5; color: var(--navy); margin-bottom: 36px; }
.article-body h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(26px, 3vw, 34px); color: var(--navy); line-height: 1.15; margin: 44px 0 16px; }
.article-body h3 { font-family: var(--serif); font-weight: 500; font-size: 22px; color: var(--navy); margin: 30px 0 12px; }
.article-body p { font-size: 17px; color: var(--text-body); line-height: 1.85; margin-bottom: 20px; }
.article-body p.muted { color: var(--text-mid); }
.article-body ul, .article-body ol { margin: 0 0 22px 0; padding-left: 0; list-style: none; }
.article-body li { font-size: 17px; color: var(--text-body); line-height: 1.7; padding: 8px 0 8px 26px; position: relative; }
.article-body li::before { content: ''; position: absolute; left: 0; top: 17px; width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }
.article-body ol { counter-reset: ol; }
.article-body ol li::before { counter-increment: ol; content: counter(ol); top: 8px; width: auto; height: auto; border-radius: 0; background: none; color: var(--gold); font-family: var(--serif); font-weight: 600; font-size: 16px; }
.article-pull { border-left: 3px solid var(--gold); padding: 6px 0 6px 26px; margin: 34px 0; font-family: var(--serif); font-style: italic; font-weight: 300; font-size: clamp(22px, 2.6vw, 28px); line-height: 1.45; color: var(--navy); }
.article-callout { background: var(--off-white); border: 1px solid var(--border-soft); border-radius: 4px; padding: 28px 30px; margin: 34px 0; }
.article-callout .ac-label { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); margin-bottom: 10px; }
.article-callout p { font-size: 15px; color: var(--text-mid); margin: 0; line-height: 1.7; }
.article-sign { margin-top: 48px; padding-top: 28px; border-top: 1px solid var(--border); font-size: 14px; color: var(--text-mid); }
.article-sign strong { color: var(--navy); }

/* article footer nav */
.article-more { background: var(--cream); padding: clamp(56px, 8vw, 90px) 0; }

/* ──────────── RESPONSIVE ──────────── */
@media (max-width: 1080px) {
  .cred-band { grid-template-columns: repeat(2, 1fr); }
  .story-grid { grid-template-columns: 1fr; gap: 40px; }
  .svc-head { grid-template-columns: 1fr; gap: 16px; }
  .svc-pillar-num { font-size: 64px; }
}
@media (max-width: 880px) {
  .team-card { grid-template-columns: 1fr; }
  .case-card { grid-template-columns: 1fr; }
  .indf-grid { grid-template-columns: 1fr; }
  .svc-grid { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .cred-band { grid-template-columns: 1fr; }
  .team-body { padding: 28px 24px; }
  .case-main { padding: 28px 24px; }
}
