/* ============================================================
   Solvo — About + Insights page styles (loads after site-home.css)
   ============================================================ */

/* image-slot defaults so empty slots read on-brand */
image-slot {
  display: block;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line);
  --is-placeholder-color: var(--fg-40);
}

/* ---- About: opening statement ----------------------------- */
.about-open { display: grid; grid-template-columns: 1.35fr 1fr; gap: clamp(32px, 5vw, 80px); align-items: start; }
.about-open__lede { font-size: clamp(1.3rem, 1rem + 1.5vw, 2rem); line-height: 1.32; letter-spacing: -0.015em; font-weight: 500; margin: 0; text-wrap: pretty; }
.about-open__lede .serif-it { white-space: nowrap; }
.about-open__body { color: var(--fg-70); font-size: 1.02rem; line-height: 1.65; margin: 22px 0 0; max-width: 46ch; }
.about-stats { display: grid; gap: 0; border-top: 1px solid var(--line); }
.about-stat { display: flex; align-items: baseline; gap: 14px; padding: 20px 0; border-bottom: 1px solid var(--line); }
.about-stat__n { font-family: var(--mono); font-size: clamp(1.6rem, 1rem + 2vw, 2.4rem); color: var(--cyan); letter-spacing: -0.02em; line-height: 1; min-width: 4ch; }
.about-stat__l { font-size: 0.95rem; color: var(--fg-55); line-height: 1.4; }
@media (max-width: 860px) { .about-open { grid-template-columns: 1fr; } }

/* ---- group photo ------------------------------------------ */
.about-photo { width: 100%; height: auto; aspect-ratio: 16 / 8; border-radius: 16px; }
.about-photo__cap { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-40); margin-top: 14px; }

/* ---- investors strip -------------------------------------- */
.invest__inner { display: flex; align-items: center; gap: clamp(24px, 5vw, 56px); padding-block: 30px; flex-wrap: wrap; }
.invest__label { font-family: var(--mono); font-size: 0.7rem; color: var(--fg-55); letter-spacing: 0.06em; text-transform: uppercase; white-space: nowrap; }
.invest__logos { display: flex; align-items: center; gap: clamp(24px, 4vw, 52px); flex-wrap: wrap; }
.invest__name { font-family: var(--serif); font-size: clamp(1.3rem, 1rem + 1vw, 1.7rem); color: var(--fg-70); letter-spacing: -0.01em; }
.invest__logo { background: transparent; border: 0; }
.invest__logo::part(frame) { background: transparent; }
.invest__logo::part(ring) { display: none; }

/* ---- values grid ------------------------------------------ */
.values { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 2vw, 22px); }
.value { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: 14px; padding: clamp(24px, 2.6vw, 32px); background: rgba(255,255,255,0.02); transition: border-color .25s var(--ease), background .25s; }
.value:hover { border-color: rgba(123,227,242,0.35); background: rgba(123,227,242,0.03); }
.value__n { font-family: var(--mono); font-size: 0.72rem; color: var(--fg-40); letter-spacing: 0.08em; }
.value__icon { color: var(--cyan); margin: 16px 0 18px; }
.value__t { font-size: clamp(1.15rem, 1rem + 0.6vw, 1.4rem); line-height: 1.15; letter-spacing: -0.015em; font-weight: 600; margin: 0; text-wrap: balance; }
.value__d { color: var(--fg-55); font-size: 0.95rem; line-height: 1.55; margin: 12px 0 0; }
@media (max-width: 900px) { .values { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .values { grid-template-columns: 1fr; } }

/* ---- team groups ------------------------------------------ */
.people-group + .people-group { margin-top: clamp(48px, 6vw, 80px); }
.people-group__head { display: flex; align-items: baseline; gap: 16px; margin-bottom: clamp(24px, 3vw, 36px); padding-bottom: 16px; border-bottom: 1px solid var(--line); width: 100%; background: none; border-top: 0; border-left: 0; border-right: 0; text-align: left; cursor: pointer; color: inherit; font: inherit; transition: border-color .2s var(--ease); }
.people-group__head:hover { border-bottom-color: var(--cyan); }
.people-group:not(.is-open) .people-group__head { margin-bottom: 0; }
.people-group__count { margin-left: 6px; font-family: var(--mono); font-size: 0.7rem; color: var(--fg-40); letter-spacing: 0.04em; align-self: center; }
.people-group__chev { margin-left: auto; align-self: center; color: var(--fg-55); display: inline-flex; transition: transform .25s var(--ease), color .2s var(--ease); }
.people-group__head:hover .people-group__chev { color: var(--cyan); }
.people-group.is-open .people-group__chev { transform: rotate(180deg); }
.people-group__t { font-size: clamp(1.2rem, 1rem + 0.8vw, 1.55rem); font-weight: 600; letter-spacing: -0.02em; margin: 0; }
.people-group__n { font-family: var(--mono); font-size: 0.72rem; color: var(--cyan); letter-spacing: 0.06em; }

.people { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 2.4vw, 30px); }
@media (max-width: 1000px) { .people { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .people { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 440px) { .people { grid-template-columns: 1fr; } }

.person { display: flex; flex-direction: column; }
.person__photo { width: 100%; height: auto; aspect-ratio: 4 / 5; border-radius: 12px; }
.person__role { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--cyan); margin: 16px 0 6px; }
.person__name { font-size: 1.1rem; font-weight: 600; letter-spacing: -0.01em; display: flex; align-items: baseline; gap: 9px; flex-wrap: wrap; }
.person__loc { font-family: var(--mono); font-size: 0.66rem; color: var(--fg-40); letter-spacing: 0.04em; text-transform: uppercase; }
.person__bio { color: var(--fg-55); font-size: 0.88rem; line-height: 1.55; margin: 11px 0 0; }
.person__link { display: inline-flex; align-items: center; gap: 7px; font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--fg-55); margin-top: 14px; transition: color .2s; width: fit-content; }
.person__link:hover { color: var(--cyan); }
.person__link svg { transition: transform .25s var(--ease); }
.person__link:hover svg { transform: translate(2px,-2px); }

/* ---- hiring band ------------------------------------------ */
.hiring__inner { display: flex; align-items: center; justify-content: space-between; gap: clamp(24px, 4vw, 56px); flex-wrap: wrap; }
.hiring__t { font-size: clamp(1.6rem, 1rem + 2.4vw, 2.6rem); line-height: 1.05; letter-spacing: -0.03em; font-weight: 700; margin: 0; max-width: 18ch; text-wrap: balance; }
.hiring__d { color: var(--fg-55); font-size: 1rem; line-height: 1.55; margin: 14px 0 0; max-width: 44ch; }

/* ============================================================
   Insights
   ============================================================ */
.ins-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: clamp(28px, 4vw, 44px); }
.ins-filter {
  background: transparent; border: 1px solid var(--line); color: var(--fg-55);
  font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 9px 16px; border-radius: 100px; cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px;
  transition: color .2s, border-color .2s, background .2s;
}
.ins-filter:hover { color: var(--fg); border-color: var(--fg-40); }
.ins-filter.is-on { color: var(--ink); background: var(--cyan); border-color: var(--cyan); }
.ins-filter__n { opacity: 0.6; font-size: 0.62rem; }
.ins-filter.is-on .ins-filter__n { opacity: 0.75; }

/* featured */
.ins-feature { display: grid; grid-template-columns: 1.15fr 1fr; gap: clamp(28px, 4vw, 56px); align-items: center; padding-bottom: clamp(40px, 5vw, 64px); margin-bottom: clamp(40px, 5vw, 64px); border-bottom: 1px solid var(--line); }
.ins-feature__cover { width: 100%; height: auto; aspect-ratio: 4 / 3; border-radius: 16px; }
.ins-feature__title { font-size: clamp(1.7rem, 1rem + 2.4vw, 3rem); line-height: 1.05; letter-spacing: -0.03em; font-weight: 700; margin: 18px 0 0; text-wrap: balance; }
.ins-feature__excerpt { color: var(--fg-70); font-size: 1.05rem; line-height: 1.6; margin: 18px 0 0; max-width: 52ch; }
@media (max-width: 880px) { .ins-feature { grid-template-columns: 1fr; } }

/* card grid */
.ins-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(22px, 2.6vw, 36px); }
@media (max-width: 920px) { .ins-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .ins-grid { grid-template-columns: 1fr; } }

.ins-card { display: flex; flex-direction: column; cursor: pointer; }
.ins-card__cover { width: 100%; height: auto; aspect-ratio: 16 / 10; border-radius: 12px; }
.ins-card__title { font-size: clamp(1.15rem, 1rem + 0.5vw, 1.35rem); line-height: 1.18; letter-spacing: -0.015em; font-weight: 600; margin: 16px 0 0; text-wrap: balance; transition: color .2s; }
.ins-card:hover .ins-card__title { color: var(--cyan); }
.ins-card__excerpt { color: var(--fg-55); font-size: 0.92rem; line-height: 1.55; margin: 10px 0 0; }
.ins-card__meta { display: flex; align-items: center; gap: 10px; margin-top: 16px; font-family: var(--mono); font-size: 0.68rem; color: var(--fg-40); letter-spacing: 0.04em; }
.ins-card__meta .dot-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--fg-40); }

/* category chip */
.ins-chip {
  display: inline-flex; align-items: center; gap: 7px; width: fit-content;
  font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--cyan); border: 1px solid var(--line); border-radius: 100px; padding: 5px 11px;
}
.ins-chip::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.ins-chip--news { color: var(--cyan); }
.ins-chip--blog { color: var(--amber); }
.ins-chip--thought { color: var(--coral); }
.ins-chip--press { color: #9FB7E8; }

/* press enquiry footer line */
.ins-enquiry { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-top: clamp(48px, 6vw, 80px); padding-top: 28px; border-top: 1px solid var(--line); }
.ins-enquiry__t { font-family: var(--mono); font-size: 0.74rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--fg-55); }
