/* ═══════════════════════════════════════════════
   DESIGN SYSTEM
   —————————————————————————————————————————————
   Navy    #000038  — Authority. Backgrounds. Power.
   Magenta #9B1F54  — Identity. Accent. Warmth.
   Orange  #E55318  — Action. CTAs only. Nothing else.
   White   #FFFFFF  — Space. Light. Breath.
   Cream   #F7F5F1  — Warmth. Section rhythm.
═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,300;1,400&display=swap');
:root {
  --navy:    #000038;
  --magenta: #9B1F54;
  --orange:  #E55318;
  --white:   #ffffff;
  --cream:   #F7F5F1;
  --silk:    #F0EDE8;
  --ink:     #0C0C28;
  --slate:   #5A5A72;
  --rule:    #E0DDD8;
  --pad:     clamp(24px,5.5vw,92px);
  --max:     1240px;
  --ease:    cubic-bezier(0.22,1,0.36,1);
}
*{ box-sizing:border-box; margin:0; padding:0;   font-family: 'Poppins', sans-serif;}
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Poppins',sans-serif;
  background:var(--white);
  color:var(--ink);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img { display:block; max-width:100%; height:auto; }
::selection { background:var(--magenta); color:#fff; }
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-thumb { background:var(--magenta); }

/* ═══════════════════════════════════════════════
   HERO
   Full viewport. Photo background. Text bottom-left.
   Inspired by Imperial College, Marquette, Stanford.
═══════════════════════════════════════════════ */
.hero {
  position:relative;
  height:100vh;
  min-height:680px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}

/* Background — campus photo or gradient placeholder */
.hero-bg {
  position:absolute;
  inset:0;
  /*
  ── PRODUCTION ──────────────────────────────────
  Replace the gradient below with a real photo:

  background: url('assets/walsh-uae-campus.jpg')
              center/cover no-repeat;

  Best shot: campus exterior at golden hour,
  or Dr. Suzy at podium with Dubai skyline.
  Minimum 1920 × 1080px, high contrast.
  ─────────────────────────────────────────────── */
  background:
    radial-gradient(ellipse at 30% 70%, rgba(155,31,84,0.15) 0%, transparent 60%),
    linear-gradient(160deg, #00001e 0%, #04022a 40%, #0d0520 100%);
}

/* Cinematic reading gradient — ensures text always legible */
.hero-gradient {
  position:absolute;
  inset:0;
  background: linear-gradient(
    to top,
    rgba(0,0,20,0.98) 0%,
    rgba(0,0,20,0.80) 30%,
    rgba(0,0,20,0.35) 65%,
    rgba(0,0,20,0.08) 100%
  );
  z-index:1;
}

/* Magenta identity glow — bottom left */
.hero-glow {
  position:absolute;
  bottom:-200px; left:-150px;
  width:clamp(400px,55vw,800px);
  height:clamp(400px,55vw,800px);
  background:radial-gradient(ellipse,
    rgba(155,31,84,0.28) 0%,
    rgba(155,31,84,0.06) 50%,
    transparent 72%
  );
  border-radius:50%;
  pointer-events:none;
  z-index:1;
}

/* Magenta top brand bar */
.hero-brand-bar {
  position:absolute;
  top:0; left:0; right:0;
  height:4px;
  background:var(--magenta);
  z-index:10;
  transform:scaleX(0);
  transform-origin:left;
  animation:brandBar .8s var(--ease) forwards;
}

/* Content */
.hero-body {
  position:relative;
  z-index:3;
  padding:clamp(48px,7vw,88px) var(--pad) 0;
  max-width:calc(var(--max) + var(--pad) * 2);
  width:100%;
}

.hero-eyebrow {
  background-color: #9B1F54;
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-size:10px;
  font-weight:600;
  padding: 10px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:rgb(255, 255, 255);
  margin-bottom:24px;
  opacity:0;
  animation:rise .6s .2s var(--ease) forwards;
}
.hero-eyebrow::before {
  content:'';
  width:28px; height:1px;
  background:rgb(255, 255, 255);
  flex-shrink:0;
}

.hero-h1 {
  font-size:clamp(42px,6.5vw,88px);
  font-weight:300;
  line-height:1.05;
  letter-spacing:-0.01em;
  color:var(--white);
  margin-bottom:28px;
  opacity:0;
  animation:rise .8s .38s var(--ease) forwards;
}
.hero-h1 .mag {
  color:var(--white);
  display:block;
  font-weight:700;
}

.hero-sub {
  font-size:clamp(16px,1.8vw,20px);
  font-weight:300;
  line-height:1.7;
  color:rgba(255,255,255,0.62);
  max-width:440px;
  margin-bottom:36px;
  opacity:0;
  animation:rise .7s .68s var(--ease) forwards;
}

/* Bottom row: CTAs left, badge right, above stats */
.hero-bottom-row {
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:clamp(16px,3vw,40px);
  margin-bottom:0;
}

.hero-ctas {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  opacity:0;
  animation:rise .6s .88s var(--ease) forwards;
}

/* Orange = only on primary CTA */
.cta-primary {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--orange);
  color:var(--white);
  padding:13px 28px;
  font-family:'Poppins',sans-serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:0.3px;
  text-decoration:none;
  transition:background .22s, transform .18s;
  white-space:nowrap;
}
.cta-primary:hover { background:#c84a12; transform:translateY(-2px); }
.cta-primary:hover svg { transform:translateX(3px); transition:transform .2s var(--ease); }
.cta-primary svg { transition:transform .2s var(--ease); }

.cta-secondary {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:transparent;
  color:var(--white);
  padding:12px 28px;
  border:1px solid rgba(255,255,255,0.35);
  font-family:'Poppins',sans-serif;
  font-size:13px;
  font-weight:400;
  text-decoration:none;
  transition:border-color .22s, background .18s;
  white-space:nowrap;
}
.cta-secondary:hover { border-color:rgba(255,255,255,0.7); background:rgba(255,255,255,0.06); }

/* Stats bar — bottom of hero */
.hero-stats {
  position:relative;
  z-index:3;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(255,255,255,0.07);
  margin-top:56px;
  opacity:0;
  animation:rise .6s 1.05s var(--ease) forwards;
}
.hstat {
  padding:clamp(18px,2.5vw,26px) clamp(12px,2vw,24px);
  border-right:1px solid rgba(255,255,255,0.07);
  text-align:center;
  transition:background .22s;
}
.hstat:last-child { border-right:none; }
.hstat:hover { background:var(--mag-mid); }
.hstat-val {
  font-size:clamp(22px,2.8vw,36px);
  font-weight:700;
  color:var(--white);
  letter-spacing:-1px;
  line-height:1;
}
.hstat-val .ctr { opacity:0; transition:opacity .2s; }
.hstat-val.popped .ctr { opacity:1; }
.hstat-sfx { font-size:0.52em; color:var(--orange); font-weight:700; }
.hstat-lbl {
  font-size:8px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.7);
  margin-top:5px;
}

/* Hero name badge — sits above stats, right-aligned */
.hero-badge {
  display:flex;
  justify-content:flex-end;
  margin-bottom:0;
  opacity:0;
  animation:rise .7s 1.1s var(--ease) forwards;
}
.hero-badge-inner {
  text-align:right;
}
.hb-name {
  font-size:clamp(13px,1.5vw,15px);
  font-weight:600;
  color:var(--white);
  margin-bottom:2px;
}
.hb-role {
  font-size:9px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--magenta);
  margin-bottom:8px;
}
.hb-tags {
  display:flex;
  flex-wrap:wrap;
  gap:5px;
  justify-content:flex-end;
}
.hb-tag {
  font-size:8px;
  font-weight:600;
  letter-spacing:1px;
  text-transform:uppercase;
  color:rgba(255,255,255,0.6);
  padding:3px 8px;
  border:1px solid rgba(255,255,255,0.6);
}

/* Scroll indicator — left side, not clashing with badge */
.hero-scroll {
  display:none;
}
@keyframes rise { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }
@keyframes brandBar { from{transform:scaleX(0)} to{transform:scaleX(1)} }
/* ── Timeline dot pulse on entry ── */
@keyframes dotPulse {
  0%   { transform:scale(0); opacity:0; }
  60%  { transform:scale(1.4); }
  100% { transform:scale(1); opacity:1; }
}
.tl-item.in::before {
  animation:dotPulse .5s var(--ease) forwards;
}

/* ── Photo ken burns slow zoom ── */
@keyframes kenBurns {
  from { transform:scale(1); }
  to   { transform:scale(1.04); }
}
.photo-img {
  animation:kenBurns 12s ease-in-out infinite alternate;
}


/* ── Timeline spine line-draw animation ── */
@keyframes drawLine {
  from { transform:scaleY(0); }
  to   { transform:scaleY(1); }
}
.tl::before {
  content:'';
  position:absolute;
  top:0; bottom:0; left:0; width:1px;
  background:linear-gradient(to bottom,
    transparent 0%, var(--rule) 6%,
    var(--rule) 94%, transparent 100%
  );
  transform-origin:top;
  animation:drawLine 1.8s var(--ease) forwards;
  animation-play-state:paused;
}
.tl.line-go::before { animation-play-state:running; }

/* ── Trust strip items — staggered slide-in ── */
.trust-item {
  opacity:0;
  transform:translateY(10px);
  transition:opacity .5s ease, transform .5s ease, background .2s;
}
.trust-item.trust-in {
  opacity:1;
  transform:translateY(0);
}

/* ── Pullquote text — line by line reveal ── */
.pq-line {
  display:block;
  opacity:0;
  transition:opacity .7s ease;
}
.pq-line.pq-in {
  opacity:1;
}

/* ── Hero stat counter — scale-in on appear ── */
@keyframes statPop {
  0%   { transform:scale(0.8); opacity:0; }
  60%  { transform:scale(1.06); }
  100% { transform:scale(1); opacity:1; }
}
.hstat-val.popped { animation:statPop .5s var(--ease) forwards; }

/* ── Magenta underline sweep on section tags ── */
.block-label::after,
.sec-tag::after {
  content:'';
  display:block;
  width:0;
  height:1px;
  background:var(--magenta);
  transition:width .6s var(--ease);
  margin-top:3px;
}
.in .block-label::after,
.in .sec-tag::after,
.block-label.in::after { width:100%; }

/* ═══════════════════════════════════════════════
   TRUST STRIP — between hero and message
   Benchmarked against HW / Wollongong credibility bars
═══════════════════════════════════════════════ */
.trust-strip {
  background: var(--white);
  border-bottom: 1px solid var(--rule);
  padding: 0 var(--pad);
}
.trust-inner {
  max-width: var(--max);
  margin: 0 auto;
  display: flex;
  align-items: stretch;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: clamp(20px,2.8vw,28px) clamp(16px,2.5vw,32px);
  flex: 1;
  transition: background .2s;
}
.trust-item:hover { background: var(--cream); }
.trust-item:hover .trust-icon { color:var(--navy); transition:color .22s; }
.trust-icon {
  color: var(--magenta);
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.trust-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.trust-name {
  font-size: clamp(11px,1.2vw,13px);
  font-weight: 700;
  color: var(--navy);
  white-space: nowrap;
}
.trust-desc {
  font-size: clamp(10px,1vw,11px);
  font-weight: 400;
  color: var(--slate);
  line-height: 1.4;
}
.trust-divider {
  width: 1px;
  background: var(--rule);
  flex-shrink: 0;
  align-self: stretch;
}

/* ═══════════════════════════════════════════════
   MESSAGE — photo + quote, white
   Walsh College blue (#003DA5) used as institutional
   accent — ties to parent brand on walshcollege.edu
═══════════════════════════════════════════════ */
:root {
  --walsh-blue: #003DA5;
}
.message {
  background:var(--white);
  padding:clamp(80px,10vw,144px) var(--pad);
}
.msg-wrap {
  max-width:var(--max);
  margin:0 auto;
  display:grid;
  grid-template-columns:320px minmax(0,1fr);
  gap:clamp(52px,7vw,120px);
  align-items:start;
}

/* Photo side */
.msg-aside {
  position:sticky;
  top:80px;
}

.photo-frame {
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--silk);
}
/* Magenta accent bar at base of photo */
.photo-frame::after {
  content:'';
  position:absolute;
  bottom:0; left:0; right:0;
  height:3px;
  background:var(--magenta);
  z-index:2;
}
.photo-img {
  width:100%; height:100%;
  object-fit:cover; object-position:center top;
  display:block;
}


/* Nameplate */
.nameplate {
  padding-top:16px;
  border-top:2px solid transparent;
  margin-top:0;
  transition:border-color .6s .4s var(--ease);
}
.in .nameplate {
  border-color:var(--magenta);
}
.np-name {
  font-size:clamp(15px,1.6vw,17px);
  font-weight:700; color:var(--navy);
  margin-bottom:3px; letter-spacing:-0.2px;
}
.np-role {
  font-size:11px; font-weight:400;
  color:var(--slate); line-height:1.55;
  margin-bottom:14px;
}
.np-tags {
  display:flex; flex-wrap:wrap; gap:5px;
}
.np-tag {
  font-size:8px; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  color:var(--magenta);
  padding:4px 9px;
  border:1px solid rgba(155,31,84,0.25);
  background:rgba(155,31,84,0.04);
}

/* Credential table */
.cred-table { margin-top:22px; }
.cred-row {
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  gap:10px;
  padding:11px 0;
  border-bottom:1px solid var(--rule);
  align-items:baseline;
}
.cred-row:first-child { border-top:1px solid var(--rule); }
.ck {
  font-size:8px; font-weight:800;
  letter-spacing:1px; text-transform:uppercase;
  color:var(--magenta); white-space:nowrap;
}
.cv {
  font-size:11px; font-weight:400;
  color:var(--slate); line-height:1.5;
}

/* Sidebar bio */
.aside-bio { margin-top:22px; padding-top:20px; border-top:1px solid var(--rule); }
.aside-lbl {
  font-size:9px; font-weight:700;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--navy); margin-bottom:12px;
}
.aside-text {
  font-size:12px; font-weight:400;
  line-height:1.85; color:var(--slate);
}
.aside-text p { margin-bottom:10px; }
.aside-text p:last-child { margin-bottom:0; }

/* Quote side 
.msg-main {}*/

.sec-tag {
  display:flex; align-items:center; gap:12px;
  font-size:10px; font-weight:700;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--magenta); margin-bottom:28px;
}
.sec-tag::before {
  content:''; width:22px; height:2px;
  background:var(--magenta); flex-shrink:0;
}

.president-quote {
  border-left:3px solid var(--walsh-blue);
  padding-left:clamp(22px,3vw,36px);
  margin-bottom:44px;
}

/* Walsh institutional blue on message section label + sig */
.message .sec-tag { color:var(--walsh-blue); }
.message .sec-tag::before { background:var(--walsh-blue); }
.message .sec-tag::after { background:var(--walsh-blue); }
.message .sig-dot { background:var(--walsh-blue); }
.message .bio-lbl { color:var(--walsh-blue); }
.president-quote p {
  font-size:clamp(15px,1.8vw,19px);
  font-weight:400;
  line-height:1.95;
  color:var(--ink);
  margin-bottom:24px;
  letter-spacing:0em;
}
.president-quote p:last-child { margin-bottom:0; }

.sig {
  display:flex; align-items:center; gap:14px;
  padding-top:26px; border-top:1px solid var(--rule);
  margin-bottom:48px;
}
.sig-dot {
  width:10px; height:10px; border-radius:50%;
  background:var(--magenta); flex-shrink:0;
}
.sig-name { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:2px; }
.sig-role { font-size:10px; font-weight:500; letter-spacing:0.5px; color:var(--slate); }

/* Full biography */
.full-bio { padding-top:40px; border-top:1px solid var(--rule); }
.bio-lbl {
  font-size:9px; font-weight:700;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--navy); margin-bottom:18px;
}
.bio-body {
  font-size:clamp(13px,1.45vw,14px);
  font-weight:400; line-height:1.9; color:var(--slate);
}
.bio-body p { margin-bottom:15px; }
.bio-body p:last-child { margin-bottom:0; }

/* ═══════════════════════════════════════════════
   PULLQUOTE — magenta full-bleed
═══════════════════════════════════════════════ */
.pullquote {
  background:var(--magenta);
  padding:clamp(64px,8vw,108px) var(--pad);
  position:relative;
  overflow:hidden;
}
/* Large ghost quote mark */
.pullquote::before {
  content:'"';
  position:absolute;
  right:calc(var(--pad) - 20px);
  top:-80px;
  font-size:clamp(240px,35vw,420px);
  font-family:Georgia,serif;
  color:rgba(255,255,255,0.05);
  line-height:1;
  user-select:none;
  pointer-events:none;
}
/* Subtle navy overlay top-right */
.pullquote::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(0,0,30,0.3) 0%, transparent 55%);
  pointer-events:none;
}
.pq-inner {
  max-width:920px; margin:0 auto;
  position:relative; z-index:1;
}
.pq-text {
  font-size:clamp(20px,2.8vw,34px);
  font-weight:300;
  color:var(--white);
  line-height:1.55;
  letter-spacing:-0.01em;
  margin-bottom:28px;
}
.pq-attr {
  font-size:10px; font-weight:600;
  letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,0.42);
}

/* ═══════════════════════════════════════════════
   STATS — navy, animated counters
═══════════════════════════════════════════════ */
.stats {
  background:var(--navy);
  display:grid;
  grid-template-columns:repeat(4,1fr);
}
.stat {
  padding:clamp(44px,5.5vw,64px) clamp(16px,2.5vw,28px);
  text-align:center;
  border-right:1px solid rgba(255,255,255,0.06);
  position:relative;
  transition:background .25s;
}
.stat:last-child { border-right:none; }
.stat::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:2px;
  background:var(--magenta);
  transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.stat:hover { background:rgba(155,31,84,0.08); }
.stat:hover .stat-val { transform:scale(1.04); transition:transform .3s var(--ease); }
.stat:hover::before { transform:scaleX(1); }
.stat-val {
  font-size:clamp(42px,5.5vw,60px);
  font-weight:700;
  color:var(--white);
  letter-spacing:-2.5px;
  line-height:1;
  display:flex; align-items:baseline;
  justify-content:center; gap:1px;
  transition:transform .3s var(--ease);
}
.stat-val .sfx { font-size:0.46em; color:var(--orange); font-weight:700; }
.stat-lbl {
  font-size:9px; font-weight:600;
  letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,0.25); margin-top:9px;
}

/* ═══════════════════════════════════════════════
   CREDENTIALS STRIP — cream
═══════════════════════════════════════════════ */
.credentials {
  background:var(--cream);
  padding:clamp(64px,8vw,100px) var(--pad);
  border-top:1px solid var(--rule);
}
.creds-grid {
  max-width:var(--max); margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:var(--rule);
  border:1px solid var(--rule);
}
.cred-box {
  background:var(--cream);
  padding:clamp(28px,3.5vw,44px) clamp(20px,3vw,32px);
  border-top:2px solid transparent;
  transition:border-color .25s, background .22s;
}
.cred-box:hover { border-color:var(--magenta); background:var(--white); }
.cred-icon { margin-bottom:16px; }
.cred-title {
  font-size:clamp(13px,1.5vw,15px);
  font-weight:700; color:var(--navy); margin-bottom:9px;
}
.cred-desc {
  font-size:clamp(11px,1.3vw,13px);
  font-weight:400; line-height:1.75; color:var(--slate);
}

/* ═══════════════════════════════════════════════
   TIMELINE — white
═══════════════════════════════════════════════ */
.timeline {
  background:var(--white);
  padding:clamp(80px,10vw,144px) var(--pad);
  border-top:1px solid var(--rule);
}
.tl-wrap { max-width:var(--max); margin:0 auto; }

.block-label {
  display:flex; align-items:center; gap:12px;
  font-size:10px; font-weight:700;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--magenta); margin-bottom:12px;
}
.block-label::before {
  content:''; width:22px; height:2px;
  background:var(--magenta); flex-shrink:0;
}

.block-title {
  font-size:clamp(28px,4vw,48px);
  font-weight:600; color:var(--navy);
  letter-spacing:-0.028em; line-height:1.08;
  margin-bottom:clamp(48px,6vw,76px);
}

.tl { position:relative; }

.tl-item {
  display:grid;
  grid-template-columns:clamp(120px,14vw,180px) minmax(0,1fr);
  gap:clamp(28px,4.5vw,64px);
  padding:clamp(36px,5vw,56px) 0 clamp(36px,5vw,56px) clamp(20px,3vw,36px);
  border-bottom:1px solid var(--rule);
  position:relative;
  opacity:0; transform:translateY(18px);
  transition:opacity .65s, transform .65s;
}
.tl-item:first-child { border-top:1px solid var(--rule); }
.tl-item.in { opacity:1; transform:translateY(0); }

/* Magenta dot on spine */
.tl-item::before {
  content:'';
  position:absolute;
  left:0; top:clamp(46px,6.5vw,66px);
  width:8px; height:8px; border-radius:50%;
  background:var(--white);
  border:2px solid var(--magenta);
  opacity:0;
}
.tl-item.in::before { opacity:1; }
.tl-item.in:hover::before { background:var(--magenta); }

.tl-year {
  padding-right:clamp(16px,2.5vw,32px);
  border-right:1px solid var(--rule);
  padding-top:2px;
  flex-shrink:0;
}
.tl-y {
  font-size:clamp(28px,3.6vw,40px);
  font-weight:700; color:var(--navy);
  letter-spacing:-2px; line-height:1;
  display:block;
}
.tl-era {
  font-size:9px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--magenta); margin-top:6px; display:block;
  opacity:0.8;
}

.tl-content {
  padding-top:2px;
  min-width:0;
  max-width:min(640px, 100%);
}
.tl-title {
  font-size:clamp(15px,1.9vw,18px);
  font-weight:600; color:var(--navy);
  margin-bottom:14px; letter-spacing:-0.01em;
}
.tl-body {
  font-size:clamp(13px,1.4vw,14px);
  font-weight:400; line-height:1.9; color:var(--slate);
}
.tl-body p { margin-bottom:12px; }
.tl-body p:last-child { margin-bottom:0; }

/* ═══════════════════════════════════════════════
   PHILOSOPHY — cream, three columns
═══════════════════════════════════════════════ */
.philosophy {
  background:var(--cream);
  padding:clamp(80px,10vw,144px) var(--pad);
  border-top:1px solid var(--rule);
}
.phil-wrap { max-width:var(--max); margin:0 auto; }

.phil-intro {
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(36px,5.5vw,88px);
  align-items:end;
  margin-bottom:clamp(52px,7vw,84px);
  opacity:0; transform:translateY(18px);
  transition:opacity .75s, transform .75s;
}
.phil-intro.in { opacity:1; transform:translateY(0); }

.phil-h {
  font-size:clamp(28px,4vw,48px);
  font-weight:600; color:var(--navy);
  letter-spacing:-0.028em; line-height:1.08;
}
.phil-h span { color:var(--magenta); }

.phil-desc {
  font-size:clamp(14px,1.6vw,16px);
  font-weight:300; line-height:1.9; color:var(--slate);
  border-left:2px solid var(--magenta);
  padding-left:clamp(18px,2.5vw,28px);
}

.phil-cols {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--rule);
  border:1px solid var(--rule);
}
.phil-col {
  background:var(--cream);
  padding:clamp(32px,4vw,52px) clamp(24px,3vw,40px);
  border-top:2px solid transparent;
  opacity:0; transform:translateY(18px);
  transition:opacity .65s, transform .65s, border-color .25s, background .22s;
}
.phil-col.in { opacity:1; transform:translateY(0); }
.phil-col:hover { border-color:var(--magenta); background:var(--white); }
.pn {
  font-size:clamp(40px,5.5vw,60px);
  font-weight:700; letter-spacing:-2.5px; line-height:1;
  color:rgba(155, 31, 85, 0.715); margin-bottom:20px;
}
.pt {
  font-size:clamp(15px,1.7vw,17px);
  font-weight:700; color:var(--navy); margin-bottom:13px;
}
.pb {
  font-size:clamp(12px,1.35vw,14px);
  font-weight:400; line-height:1.88; color:var(--slate);
}

/* ═══════════════════════════════════════════════
   VISION — dark navy editorial rows
═══════════════════════════════════════════════ */
.vision {
  background:var(--navy);
  padding:clamp(72px,9vw,120px) var(--pad) clamp(40px,5vw,64px);
}
.vis-wrap { max-width:var(--max); margin:0 auto; }

/* Opening 2-col header */
.vis-header {
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(36px,5.5vw,88px);
  align-items:end;
  padding-bottom:clamp(48px,6vw,72px);
  border-bottom:1px solid rgba(255,255,255,0.06);
  opacity:0; transform:translateY(18px);
  transition:opacity .75s, transform .75s;
}
.vis-header.in { opacity:1; transform:translateY(0); }

.vis-h {
  font-size:clamp(28px,4vw,48px);
  font-weight:600; color:var(--white);
  letter-spacing:-0.028em; line-height:1.08;
}
.vis-h span { color:var(--magenta); }

.vis-intro {
  font-size:clamp(14px,1.6vw,16px);
  font-weight:300; line-height:1.9;
  color:rgba(255,255,255,0.46);
  border-left:2px solid var(--magenta);
  padding-left:clamp(18px,2.5vw,28px);
}
.vis-intro strong { color:rgba(255,255,255,0.82); font-weight:600; }

/* Editorial numbered rows */
.vis-row {
  display:grid;
  grid-template-columns:clamp(56px,7vw,100px) minmax(0,1fr) clamp(160px,20vw,240px);
  gap:clamp(20px,4vw,56px);
  padding:clamp(44px,6vw,72px) 0;
  border-bottom:1px solid rgba(255,255,255,0.08);
  border-left:3px solid transparent;
  opacity:0; transform:translateY(18px);
  transition:border-color .35s ease, opacity .65s, transform .65s;
}
.vis-row.in { opacity:1; transform:translateY(0); }
.vis-row:last-child { border-bottom:none; }

.vn {
  font-size:clamp(40px,5.5vw,64px);
  font-weight:800;
  color:rgba(255,255,255,0.12);
  line-height:1; letter-spacing:-2px;
  padding-top:4px;
  transition:color .45s;
  font-variant-numeric:tabular-nums;
}
.vis-row:hover { border-left-color:var(--magenta); }
.vis-row:hover .vn { color:var(--magenta); }

.vr-tag {
  font-size:9px; font-weight:700;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--magenta); margin-bottom:12px;
}
.vr-title {
  font-size:clamp(18px,2.3vw,26px);
  font-weight:600; color:var(--white);
  line-height:1.15; letter-spacing:-0.025em;
  margin-bottom:18px;
}
.vr-text {
  font-size:clamp(13px,1.4vw,14px);
  font-weight:400; line-height:1.9;
  color:rgba(255,255,255,0.46);
}
.vr-text+.vr-text { margin-top:13px; }
.vr-text strong { color:rgba(255,255,255,0.82); font-weight:600; }

/* Metrics aside
.vr-aside {} */
.vr-m {
  padding:clamp(14px,1.8vw,20px) 0;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.vr-m:first-child { border-top:1px solid rgba(255,255,255,0.06); }
.vr-mv {
  font-size:clamp(20px,2.5vw,28px);
  font-weight:700; color:var(--white);
  letter-spacing:-0.5px; line-height:1;
  margin-bottom:4px;
  font-family:'Poppins',sans-serif;
  font-variant-numeric:normal;
}
.vr-mv span { color:var(--magenta); }
.vr-ml {
  font-size:9px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,0.2);
}

/* Closing presidential statement — left-aligned, editorial row style */
.vis-close {
  padding:clamp(56px,7vw,80px) 0 0;
  border-top:1px solid rgba(255,255,255,0.06);
  opacity:0; transform:translateY(18px);
  transition:opacity .75s .1s, transform .75s .1s;
}
.vis-close.in { opacity:1; transform:translateY(0); }

.vc-quote {
  font-size:clamp(20px,2.6vw,30px);
  font-weight:300;
  color:var(--white);
  line-height:1.55;
  letter-spacing:-0.01em;
  border-left:3px solid var(--magenta);
  padding-left:clamp(24px,3.5vw,44px);
  margin-bottom:28px;
  max-width:760px;
}
.vc-quote em { font-style:normal; color:var(--magenta); font-weight:500; }

.vc-attr {
  display:flex;
  align-items:center;
  gap:14px;
  padding-left:clamp(27px,3.7vw,47px);
}
.vc-dot {
  width:8px; height:8px;
  border-radius:50%;
  background:var(--magenta);
  flex-shrink:0;
}
.vc-name { font-size:13px; font-weight:700; color:var(--white); white-space:nowrap; }
.vc-divider {
  width:1px; height:16px;
  background:rgba(255,255,255,0.2);
  flex-shrink:0;
}
.vc-role {
  font-size:9px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,0.4);
}

/* ═══════════════════════════════════════════════
   CTA — white bg, clean break from navy
═══════════════════════════════════════════════ */
.cta-section {
  background:var(--white);
  border-top:1px solid var(--rule);
  padding:clamp(56px,7vw,88px) var(--pad);
}
.cta-wrap {
  max-width:var(--max); margin:0 auto;
  display:grid;
  grid-template-columns:1fr auto;
  gap:clamp(36px,5.5vw,80px);
  align-items:center;
}
.cta-lbl {
  font-size:10px; font-weight:700;
  letter-spacing:4px; text-transform:uppercase;
  color:var(--magenta); margin-bottom:10px;
}
.cta-title {
  font-size:clamp(20px,2.8vw,32px);
  font-weight:300; color:var(--navy);
  letter-spacing:-0.01em; line-height:1.35;
  margin-bottom:8px;
}
.cta-sub {
  font-size:clamp(13px,1.4vw,14px);
  color:var(--slate); line-height:1.75;
}

/* ═══════════════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════════════ */
[data-reveal] {
  opacity:0; transform:translateY(18px);
  transition:opacity .7s ease, transform .7s ease;
}
[data-reveal].in { opacity:1; transform:translateY(0); }

/* ═══════════════════════════════════════════════
   RESPONSIVE — layered mobile-first breakpoints
   1280px+ = full desktop (base styles)
   1100px  = laptop / small desktop
    880px  = tablet landscape / large tablet
    700px  = tablet portrait / large phone
    480px  = mid phone
    380px  = small phone
═══════════════════════════════════════════════ */

/* ── 1100px — laptop ── */
@media (max-width:1100px) {
  /* Vision rows: drop to 2 col, hide metrics aside */
  .vis-row {
    grid-template-columns:clamp(48px,6vw,72px) minmax(0,1fr);
    gap:clamp(16px,3vw,32px);
  }
  .vn { font-size:clamp(32px,4vw,44px); }
  .vr-aside { display:none; }

  /* Vision closing: full width centred, no change needed at 1100px */
}

/* ── 880px — tablet landscape ── */
@media (max-width:880px) {
  /* Trust strip: 3 items visible, hide last 2 dividers + items */
  .trust-inner > *:nth-child(n+7) { display:none; }
  .trust-item { padding:18px 14px; gap:10px; }
  .trust-desc { display:none; }
  .trust-name { font-size:11px; white-space:normal; }
  /* Hero */
  .hero-badge,.hero-scroll { display:none; }
  .hero-bottom-row { flex-direction:column; align-items:flex-start; gap:20px; }
  .hero-h1 { font-size:clamp(36px,5.5vw,64px); }
  .hero-stats { grid-template-columns:1fr 1fr; }
  .hstat:nth-child(2) { border-right:none; }
  .hstat:nth-child(3),.hstat:nth-child(4) { border-top:1px solid rgba(255,255,255,0.07); }

  /* Message: stack photo above quote */
  .msg-wrap { grid-template-columns:1fr; gap:44px; }
  .msg-aside { position:static; max-width:100%; }
  .photo-frame { aspect-ratio:3/2; max-height:340px; }

  /* Stats: 2x2 grid */
  .stats { grid-template-columns:1fr 1fr; }
  .stat:nth-child(2) { border-right:none; }
  .stat:nth-child(3) { border-top:1px solid rgba(255,255,255,0.08); }
  .stat:nth-child(4) { border-top:1px solid rgba(255,255,255,0.08); }

  /* Credentials: 2 col */
  .creds-grid { grid-template-columns:1fr 1fr; }

  /* Philosophy intro: stack */
  .phil-intro { grid-template-columns:1fr; gap:20px; }

  /* Vision header: stack */
  .vis-header { grid-template-columns:1fr; gap:20px; }

  /* CTA: stack */
  .cta-wrap { grid-template-columns:1fr; gap:24px; }
  /* vis-close: left-aligned, no override needed */
}

/* ── 700px — tablet portrait / large phone ── */
@media (max-width:700px) {
  /* Trust strip: scroll horizontally */
  .trust-inner {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .trust-inner::-webkit-scrollbar { display:none; }
  .trust-item { flex-shrink:0; min-width:140px; flex-direction:column; align-items:flex-start; gap:8px; padding:16px 14px; }
  .trust-desc { display:none; }
  .trust-name { font-size:11px; white-space:normal; }
  /* Hero stats: 2x2 */
  .hero-stats { 
    margin-top: 45px;
    grid-template-columns:1fr 1fr; }

    .in .nameplate {
    border-color: #fff;
}
  /* Philosophy cards: 1 col */
  .phil-cols { grid-template-columns:1fr; }

  /* Credentials: 1 col */
  .creds-grid { grid-template-columns:1fr; }

  /* Timeline: stack year above content */
  .tl-item {
    grid-template-columns:1fr;
    gap:0;
    padding-left:clamp(16px,4vw,28px);
  }
  .tl-year {
    display:flex;
    gap:14px;
    align-items:center;
    border-right:none;
    border-bottom:1px solid var(--rule);
    padding-bottom:12px;
    padding-right:0;
    margin-bottom:14px;
  }
  .tl-y { font-size:24px; }
  .tl-content { padding-top:0; }

  /* Vision: single col, number small */
  .vis-row { grid-template-columns:1fr; gap:0; }
  .vn {
    font-size:22px;
    color:rgba(255, 255, 255, 0.633);
    margin-bottom:12px;
    display:block;
    letter-spacing:-1px;
  }

  /* Block titles smaller */
  .block-title { margin-bottom:clamp(32px,5vw,52px); }
}

/* ── 480px — mid phone ── */
@media (max-width:480px) {
  /* Hero: tighter padding */
  .hero { 
    height: 60vh;
    min-height: 400px;
  }
  .hero-body { padding-top:clamp(36px,8vw,64px); }
  .hero-h1 { font-size:clamp(32px,8vw,48px); }
  .hero-sub { font-size:14px; max-width:100%; }
  .hero-ctas { flex-direction:column; gap:10px; }
  .cta-primary,.cta-secondary { justify-content:center; }

  /* Hero stats: 2x2 tighter */
  .hstat { padding:14px 10px; }
  .hstat-val { font-size:22px; }

  /* Stats section */
  .stats { grid-template-columns:1fr 1fr; }
  .stat { padding:clamp(28px,5vw,44px) clamp(12px,3vw,20px); }
  .stat-val { font-size:clamp(32px,8vw,44px); }

  /* Pullquote */
  .pq-text { font-size:clamp(18px,5vw,26px); }

  /* Message photo smaller */
  .photo-frame { aspect-ratio:1/1; max-height:280px; }

  /* Padding reduction on sections */
  .message,.timeline,.philosophy,.vision,.credentials,.cta-section {
    padding-top:clamp(48px,8vw,72px);
    padding-bottom:clamp(48px,8vw,72px);
  }
}

/* ── 380px — small phone ── */
@media (max-width:380px) {
  .hero-h1 { font-size:30px; }
  .hero-stats { grid-template-columns:1fr 1fr; }
  .hstat-val { font-size:20px; }
  .stat-val { font-size:28px; }
  .block-title { font-size:24px; }
  .phil-h,.vis-h { font-size:24px; }
  .np-tags { flex-wrap:wrap; }
}

/* ── Scroll progress — magenta line left edge ── */
.scroll-progress {
  position:fixed;
  top:0; left:0;
  width:3px;
  height:0%;
  background:var(--magenta);
  z-index:9999;
  transition:height .1s linear;
}