/* ============================================================
   ABOUT PAGE — extends site-base.css
   Only about-unique sections live here: the mission split, the
   team grid + the "view bio" hover badge and the bio modal, the
   dark story band with its video card, and the values grid. All
   shared chrome/components (reset, tokens, header, footer,
   bo-hero, lead form, video modal, trust float, final-cta,
   responsive nav/footer collapse) come from site-base.css.
   ============================================================ */

/* active nav state (shared chrome + bo-hero + responsive now in site-base.css) */

/* page-specific bo-hero overrides */
.bo-hero .wrap{padding-bottom:clamp(150px,20vh,210px)}
.bo-hero h1{text-wrap:balance}
.bo-sub{margin:0 auto 2.2rem}
.bo-hero .hero-city svg{height:clamp(130px,18vh,200px)}

/* mini-hero skyline (shared by buyout/consult/about; not in site-base) */
.hero-city{position:absolute;left:0;right:0;bottom:0;z-index:1;pointer-events:none}
.hero-city svg{display:block;width:100%;height:clamp(160px,22vh,235px)}
.hero-city .w{opacity:0;animation:winOn .6s ease-out forwards;animation-delay:calc(.7s + var(--i)*.14s)}
@keyframes winOn{to{opacity:1}}
.hero-city .tw{
  opacity:0;
  animation:winOn .6s ease-out forwards, twBreathe 9s ease-in-out infinite;
  animation-delay:calc(.7s + var(--i)*.14s), calc(4s + var(--i)*1.7s);
}
@keyframes twBreathe{0%,100%{opacity:1}50%{opacity:.3}}
.sky-beacon{animation:beaconBreathe 5s ease-in-out infinite}
.sky-beacon.b2{animation-delay:2.2s}
@keyframes beaconBreathe{0%,100%{opacity:1}50%{opacity:.3}}
.city-ring{fill:none;stroke:#3FC8BC;stroke-width:1.5;opacity:0;transform-box:fill-box;transform-origin:center;animation:cityPulse 7s ease-out 2.4s infinite}
@keyframes cityPulse{0%{opacity:0;transform:scale(.3)}8%{opacity:.5}55%{opacity:.12}70%,100%{opacity:0;transform:scale(2.2)}}
@media (prefers-reduced-motion:reduce){
  .hero-city .w,.hero-city .tw{animation:none;opacity:1}
  .sky-beacon,.city-ring{animation:none}
  .city-ring{opacity:0}
}

/* video card (used by the story band; not in site-base) */
.video-card{
  position:relative;width:min(100%,360px);aspect-ratio:16/10;
  border-radius:20px;overflow:hidden;padding:0;cursor:pointer;
  border:1px solid rgba(234,245,251,.16);background:#06222F;
  box-shadow:0 30px 70px -20px rgba(0,0,0,.6);
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.video-card:hover{transform:translateY(-5px);border-color:rgba(250,215,120,.55);box-shadow:0 42px 84px -22px rgba(0,0,0,.7)}
.video-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.85}
.vc-shade{position:absolute;inset:0;background:linear-gradient(180deg, rgba(5,30,42,.05) 30%, rgba(5,30,42,.93) 100%)}
.vc-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:var(--navy);
  display:grid;place-items:center;box-shadow:0 12px 34px rgba(0,0,0,.45);
  transition:transform .3s ease;
}
.video-card:hover .vc-play{transform:translate(-50%,-60%) scale(1.1)}
.vc-play svg{width:20px;height:20px;margin-left:3px}
.vc-meta{position:absolute;left:1.1rem;right:1.1rem;bottom:.9rem;display:flex;flex-direction:column;gap:.1rem;text-align:left}
.vc-title{font-family:var(--font-display);font-weight:800;font-size:1.1rem;letter-spacing:-.01em;color:#fff}
.vc-sub{font-size:.85rem;color:var(--muted-ice)}

/* mission */
.ab-mission{padding:clamp(4.5rem,9vw,7rem) 0;background:#fff}
.ab-mission-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2.2rem,5vw,4.5rem);align-items:start}
.ab-mission h2{font-size:clamp(1.9rem,3.8vw,2.9rem);margin-top:1rem}
.ab-mission .mission-text{font-size:1.12rem;line-height:1.75;color:var(--muted)}
.ab-mission .mission-text strong{color:var(--text)}

/* team */
.ab-team{padding:clamp(4.5rem,9vw,7rem) 0;background:var(--paper)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.team-card{
  background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;
  cursor:pointer;position:relative;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.team-card:focus-visible{outline:3px solid var(--gold);outline-offset:3px}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--line-gold)}
.team-card img{width:100%;aspect-ratio:1/1.05;object-fit:cover;object-position:top;display:block}
.team-meta{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.12rem}
.team-meta h3{font-size:1.08rem;margin-bottom:.1rem}
.team-meta small{display:block;font-size:.82rem;color:var(--muted)}
.team-mail{display:inline-block;margin-top:.55rem;font-size:.8rem;color:var(--teal-dark);word-break:break-all}
.team-mail:hover{text-decoration:underline}
.team-actions{display:flex;align-items:center;gap:.6rem;margin-top:.75rem}
.team-bio-btn{
  font-family:var(--font-display);font-weight:700;font-size:.78rem;letter-spacing:.03em;
  color:var(--navy);background:var(--gold);border:none;border-radius:999px;padding:.42rem .95rem;cursor:pointer;
  transition:background .2s, transform .2s;
}
.team-bio-btn:hover{background:var(--gold-deep);transform:translateY(-1px)}
.team-li{width:32px;height:32px;flex:none;border-radius:50%;display:grid;place-items:center;background:var(--navy);color:#fff;transition:background .2s, transform .2s}
.team-li:hover{background:var(--ink);transform:translateY(-2px)}
.team-li svg{width:15px;height:15px}
/* team slider track (reuses the .rev-carousel JS; manual prev/next, no auto-advance) */
.team-track{padding-bottom:1rem}
.rev-track > .team-card{flex:0 0 clamp(230px,25%,288px)}

/* team bio modal */
.bio-modal{position:fixed;inset:0;z-index:300;display:grid;place-items:center;padding:clamp(1rem,4vw,3rem)}
.bio-modal[hidden]{display:none}
.bio-frame{
  position:relative;z-index:1;width:min(780px,100%);max-height:86vh;overflow:auto;
  background:#fff;border-radius:18px;box-shadow:0 30px 80px rgba(3,16,22,.5);
  display:grid;grid-template-columns:280px 1fr;animation:modalIn .35s cubic-bezier(.2,.65,.3,1);
}
.bio-frame > img{width:100%;height:100%;object-fit:cover;min-height:320px}
.bio-body{padding:2rem 2.2rem 2.2rem}
.bio-body h3{font-family:var(--font-display);font-weight:800;font-size:1.55rem;color:var(--ink);margin-bottom:.15rem}
.bio-role{font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-dark);margin-bottom:.6rem}
.bio-links{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem .9rem;margin-bottom:1rem}
.bio-mail{display:inline-block;font-size:.92rem;font-weight:600;color:var(--navy);text-decoration:underline;text-underline-offset:3px}
.bio-mail[hidden]{display:none}
.bio-li{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:700;color:#fff;background:#0A66C2;border-radius:999px;padding:.35rem .8rem;transition:filter .2s}
.bio-li[hidden]{display:none}
.bio-li:hover{filter:brightness(1.1)}
.bio-li svg{width:15px;height:15px}
.bio-text p{margin:.75rem 0;color:var(--text);line-height:1.62;font-size:.96rem}
.bio-close{
  position:absolute;z-index:3;top:.8rem;right:.8rem;width:40px;height:40px;border:0;border-radius:50%;
  background:var(--ice);color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;
}
.bio-close:hover{background:var(--gold)}
@media (max-width:720px){
  .bio-frame{grid-template-columns:1fr}
  .bio-frame > img{max-height:300px}
}

/* story */
.ab-story{
  position:relative;overflow:hidden;color:var(--ice);
  padding:clamp(4.5rem,9vw,7rem) 0;
  background:
    radial-gradient(820px 420px at 82% 0%, rgba(50,176,166,.16), transparent 60%),
    linear-gradient(160deg,#051E2A, var(--navy) 60%, #0C3850);
}
.ab-story-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.2rem,5vw,4rem);align-items:center}
.ab-story .eyebrow{color:var(--gold)}
.ab-story .eyebrow::before{background:var(--gold)}
.ab-story h2{color:#fff;font-size:clamp(1.9rem,3.9vw,2.9rem);margin:1rem 0 1.2rem}
.ab-story p{color:var(--muted-ice);margin-bottom:1.1rem}
.ab-story p strong{color:var(--ice)}
.ab-story .video-card{justify-self:end}

/* values */
.ab-values{padding:clamp(4.5rem,9vw,7rem) 0;background:#fff}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.value-card{
  background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:1.7rem 1.5rem;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm);border-color:var(--line-gold)}
.value-card .ico{width:46px;height:46px;border-radius:13px;background:var(--navy);color:var(--gold);display:grid;place-items:center;margin-bottom:1rem}
.value-card .ico svg{width:22px;height:22px}
.value-card h3{font-size:1.12rem;margin-bottom:.4rem}
.value-card p{font-size:.92rem;color:var(--muted)}

@media (max-width:1080px){
  .ab-mission-grid,.ab-story-grid{grid-template-columns:1fr}
  .ab-story .video-card{justify-self:start}
  .values-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  /* values stay two-up on mobile (client request); team is a horizontal slider */
  .values-grid{grid-template-columns:1fr 1fr}
}
