/* ════════════════════════════════════════════════════════════════
   About page — page hero, magazine-style story split, value rows,
   team grid, certifications, IRIBA parent-company strip, final CTA.
   ════════════════════════════════════════════════════════════════ */

/* ── PAGE HERO ───────────────────────────────── */
.page-hero{
  padding:80px 0 72px;position:relative;overflow:hidden;
  background-image:var(--page-hero-image, none);
  background-size:cover;background-position:center 40%;
}
.page-hero.no-image{background:linear-gradient(135deg,#0c1a2e 0%,var(--navy) 60%,#254f7a 100%);}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(110deg,rgba(8,18,34,.88) 0%,rgba(20,40,70,.68) 100%);z-index:0;}
.page-hero-inner{position:relative;z-index:1;max-width:760px;}
.page-hero h1{font-family:'Montserrat',sans-serif;font-size:clamp(34px,5vw,64px);font-weight:900;color:#fff;line-height:1.05;letter-spacing:-.025em;margin-top:18px;}
.page-hero p{margin-top:22px;font-size:18px;color:rgba(255,255,255,.78);max-width:600px;line-height:1.65;}

/* ── STORY SPLIT (signature element) ─────────── */
.story-section{padding:100px 0;background:var(--white);}
.story-split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.story-pullquote{
  font-family:'Montserrat',sans-serif;font-size:clamp(22px,2.8vw,34px);
  font-weight:800;font-style:italic;color:var(--navy);line-height:1.35;
  border-left:4px solid var(--blue);padding-left:28px;margin-bottom:40px;
}
.story-stats{display:flex;flex-direction:column;gap:36px;}
.story-stat-num{
  font-family:'Montserrat',sans-serif;font-size:clamp(52px,6vw,80px);font-weight:900;
  line-height:1;color:var(--navy);letter-spacing:-.04em;display:flex;align-items:baseline;gap:4px;
}
.story-stat-num .sup{font-size:.4em;color:var(--blue);font-weight:700;margin-left:2px;}
.story-stat-label{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px;}
.story-stat-divider{width:48px;height:2px;background:var(--line);}

.story-right h2{font-family:'Montserrat',sans-serif;font-size:clamp(26px,3vw,40px);font-weight:900;color:var(--navy);letter-spacing:-.02em;line-height:1.15;margin-bottom:24px;}
.story-right p{font-size:16px;color:var(--ink-soft);line-height:1.8;margin-bottom:18px;}
.story-right p strong{color:var(--navy);font-weight:600;}
.story-highlight{
  background:var(--blue-pale);border-left:3px solid var(--blue);
  border-radius:0 var(--r) var(--r) 0;padding:20px 24px;margin:28px 0;
  font-family:'Montserrat',sans-serif;font-size:17px;font-weight:700;
  color:var(--navy);line-height:1.45;font-style:italic;
}
.story-actions{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap;}

/* ── VALUES (editorial rows) ──────────────────── */
.values-section{padding:100px 0;background:var(--paper);}
.values-head{margin-bottom:64px;}
.values-head h2{font-family:'Montserrat',sans-serif;font-size:clamp(28px,3.5vw,46px);font-weight:900;color:var(--navy);letter-spacing:-.025em;line-height:1.1;margin-top:14px;}
.value-row{
  display:grid;grid-template-columns:280px 1fr;gap:48px;
  padding:36px 0;border-top:1px solid var(--line);align-items:center;transition:background .2s;
}
.value-row:last-child{border-bottom:1px solid var(--line);}
.value-row:hover{background:var(--blue-pale);margin:0 -48px;padding:36px 48px;}
.value-name{font-family:'Montserrat',sans-serif;font-size:clamp(22px,2.5vw,30px);font-weight:900;color:var(--navy);transition:transform .2s;}
.value-row:hover .value-name{transform:translateX(6px);color:var(--blue);}
.value-body{font-size:16px;color:var(--ink-soft);line-height:1.75;}
.value-body strong{color:var(--navy);font-weight:600;}

/* ── TEAM ──────────────────────────────────────── */
.team-section{padding:100px 0;background:var(--white);}
.team-section h2{font-family:'Montserrat',sans-serif;font-size:clamp(28px,3.5vw,46px);font-weight:900;color:var(--navy);letter-spacing:-.025em;line-height:1.1;margin-top:14px;margin-bottom:16px;}
.team-section .intro{color:var(--ink-soft);font-size:16px;line-height:1.7;max-width:560px;margin-bottom:56px;}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;}
.team-card{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);transition:box-shadow .2s,transform .2s;}
.team-card:hover{box-shadow:var(--sh-lg);transform:translateY(-4px);}
.team-photo{
  aspect-ratio:3/4;background:var(--blue-pale);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--blue);
}
.team-photo svg{width:48px;height:48px;opacity:.3;}
.team-photo span{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.4;text-align:center;padding:0 16px;}
.team-info{padding:20px 20px 24px;}
.team-name{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;color:var(--navy);}
.team-role{font-size:13.5px;color:var(--ink-soft);margin-top:4px;}

/* ── CERTIFICATIONS ───────────────────────────── */
.certs-section{padding:80px 0;background:var(--paper);border-top:1px solid var(--line);}
.certs-section h2{font-family:'Montserrat',sans-serif;font-size:clamp(24px,3vw,36px);font-weight:900;color:var(--navy);letter-spacing:-.02em;margin-top:12px;margin-bottom:40px;}
.certs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.cert-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px 20px;text-align:center;transition:box-shadow .2s,border-color .2s;
}
.cert-card:hover{box-shadow:var(--sh);border-color:rgba(58,124,166,.2);}
.cert-icon{width:64px;height:64px;border-radius:50%;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.cert-icon svg{width:30px;height:30px;color:var(--blue);}
.cert-name{font-family:'Montserrat',sans-serif;font-size:14px;font-weight:800;color:var(--navy);margin-bottom:6px;}
.cert-desc{font-size:13px;color:var(--ink-soft);line-height:1.55;}

/* ── IRIBA STRIP ──────────────────────────────── */
.iriba-strip{background:var(--navy);padding:80px 0;display:flex;align-items:center;}
.iriba-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.iriba-text .eyebrow{color:var(--blue-lt);}
.iriba-text h2{font-family:'Montserrat',sans-serif;font-size:clamp(26px,3vw,40px);font-weight:900;color:#fff;line-height:1.15;letter-spacing:-.02em;margin-top:14px;margin-bottom:20px;}
.iriba-text p{color:rgba(255,255,255,.72);font-size:16px;line-height:1.75;}
.iriba-text p strong{color:#fff;}
.iriba-visual-box{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-lg);padding:40px;display:flex;flex-direction:column;gap:24px;
}
.iriba-stat{display:flex;align-items:center;gap:20px;}
.iriba-stat-num{font-family:'Montserrat',sans-serif;font-size:36px;font-weight:900;color:#fff;min-width:100px;line-height:1;}
.iriba-stat-num span{font-size:.55em;color:var(--blue-lt);}
.iriba-stat-label{font-size:14px;color:rgba(255,255,255,.65);line-height:1.4;}
.iriba-stat-divider{height:1px;background:rgba(255,255,255,.08);}

/* ── FINAL CTA ───────────────────────────────── */
.final-cta{background:var(--blue);padding:100px 0;text-align:center;position:relative;overflow:hidden;}
.final-cta::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:48px 48px;}
.final-cta-inner{position:relative;z-index:1;}
.final-cta h2{font-family:'Montserrat',sans-serif;font-size:clamp(28px,4vw,52px);font-weight:900;color:#fff;letter-spacing:-.025em;line-height:1.1;margin-top:14px;margin-bottom:16px;}
.final-cta p{color:rgba(255,255,255,.8);font-size:17px;margin-bottom:36px;max-width:460px;margin-left:auto;margin-right:auto;line-height:1.6;}
.final-cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:1024px){
  .story-split{grid-template-columns:1fr;gap:48px;}
  .iriba-inner{grid-template-columns:1fr;gap:40px;}
  .team-grid{grid-template-columns:1fr 1fr;}
  .certs-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .value-row{grid-template-columns:1fr;gap:12px;}
  .value-row:hover{margin:0 -20px;padding:36px 20px;}
  .team-grid{grid-template-columns:1fr;}
  .certs-grid{grid-template-columns:1fr 1fr;}
}
