/* ================================================================
   MMSAHADRABBI.COM — THEME 2: EDITORIAL LIGHT
   Fonts: Manrope (display) · Inter (body) · DM Mono (labels)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Inter:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=DM+Mono:wght@300;400;500&display=swap');

:root {
  --warm-white:  #f7f5f1;
  --pure-white:  #ffffff;
  --cream:       #f0ece4;
  --navy:        #0d1b2a;
  --navy-mid:    #162336;
  --navy-light:  #1e3a5f;
  --red:         #c0392b;
  --red-lt:      #e74c3c;
  --gold:        #c8882a;
  --gold-lt:     #e6a840;
  --ink:         #111118;
  --ink-2:       #3a3830;
  --ink-3:       #7a7570;
  --ink-4:       #b8b4ae;
  --border:      #e4e0d8;
  --border-dk:   #c8c4bc;

  --ff-display:  'Manrope', system-ui, sans-serif;
  --ff-body:     'Inter', system-ui, sans-serif;
  --ff-mono:     'DM Mono', monospace;

  --ease:        0.4s cubic-bezier(0.25,0.46,0.45,0.94);
  --r:           6px;
  --r-lg:        16px;
  --r-xl:        24px;
  --shadow-sm:   0 2px 12px rgba(13,27,42,0.08);
  --shadow-md:   0 8px 32px rgba(13,27,42,0.12);
  --shadow-lg:   0 20px 60px rgba(13,27,42,0.16);
  --shadow-xl:   0 40px 100px rgba(13,27,42,0.2);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px }
body { font-family:var(--ff-body); background:var(--warm-white); color:var(--ink); line-height:1.7; overflow-x:hidden }
img { display:block; max-width:100% }
a { text-decoration:none; color:inherit }
button { cursor:pointer; border:none; background:none; font:inherit }
ul,ol { list-style:none }
::selection { background:var(--navy); color:var(--pure-white) }
::-webkit-scrollbar { width:3px }
::-webkit-scrollbar-track { background:var(--cream) }
::-webkit-scrollbar-thumb { background:var(--navy-light); border-radius:2px }

.wrap { max-width:1200px; margin:0 auto; padding:0 48px; width:100% }

/* ── NAV ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(247,245,241,0.92);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border); transition:var(--ease);
}
.nav::before {
  content:''; display:block; height:3px;
  background:linear-gradient(90deg,var(--navy) 0%,var(--red) 50%,var(--gold) 100%);
}
.nav.scrolled { background:rgba(247,245,241,0.98); box-shadow:var(--shadow-sm) }
.nav-inner {
  max-width:1200px; margin:0 auto; padding:0 48px;
  height:68px; display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  font-family:var(--ff-display); font-size:1.1rem; font-weight:700;
  letter-spacing:-0.01em; color:var(--ink); white-space:nowrap; flex-shrink:0;
}
.nav-links { display:flex; align-items:center; gap:32px }
.nav-link {
  font-family:var(--ff-body); font-size:0.78rem; font-weight:500;
  letter-spacing:0.04em; text-transform:uppercase;
  color:var(--ink-3); transition:color var(--ease);
  position:relative; white-space:nowrap;
}
.nav-link::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:2px; background:var(--red); transition:width var(--ease);
}
.nav-link:hover, .nav-link.active { color:var(--ink) }
.nav-link:hover::after, .nav-link.active::after { width:100% }
.nav-portal-link { color:var(--gold) !important; border:1px solid rgba(200,136,42,0.4); border-radius:4px; padding:4px 12px !important; font-size:0.74rem !important; }
.nav-portal-link:hover { background:rgba(200,136,42,0.1); }
.nav-portal-link::after { display:none !important; }
.nav-dropdown { position:relative }
.nav-dropdown-toggle {
  font-family:var(--ff-body); font-size:0.78rem; font-weight:500;
  letter-spacing:0.04em; text-transform:uppercase;
  color:var(--ink-3); cursor:pointer; display:flex; align-items:center;
  gap:5px; transition:color var(--ease); white-space:nowrap;
}
.nav-dropdown-toggle::after { content:'▾'; font-size:0.6rem; transition:transform var(--ease) }
.nav-dropdown:hover .nav-dropdown-toggle { color:var(--ink) }
.nav-dropdown:hover .nav-dropdown-toggle::after { transform:rotate(180deg) }
.nav-dropdown-menu {
  position:absolute; top:100%; left:50%; padding-top:12px;
  opacity:0; pointer-events:none;
  transform:translateX(-50%) translateY(-8px);
  transition:all var(--ease); z-index:200;
}
.nav-dropdown-menu-inner {
  background:var(--pure-white); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:6px; min-width:220px;
  box-shadow:var(--shadow-md);
}
.nav-dropdown:hover .nav-dropdown-menu {
  opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0);
}
.nav-dropdown-item {
  display:block; padding:12px 16px; font-size:0.82rem;
  color:var(--ink-2); border-radius:var(--r); transition:all var(--ease);
}
.nav-dropdown-item:hover { background:var(--cream); color:var(--ink) }
.nav-dropdown-item strong { display:block; font-family:var(--ff-display); color:var(--ink); font-size:0.86rem; margin-bottom:2px }
.nav-dropdown-item span { font-size:0.74rem; color:var(--ink-3) }
.nav-hamburger {
  display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px;
}
.nav-hamburger span {
  display:block; width:22px; height:1.5px; background:var(--ink-3); transition:var(--ease);
}
.nav-hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg) }
.nav-hamburger.open span:nth-child(2) { opacity:0 }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg) }
.mobile-nav {
  display:none; position:fixed; inset:0;
  background:var(--pure-white); z-index:998;
  flex-direction:column; align-items:center; justify-content:center; gap:28px;
}
.mobile-nav.open { display:flex }
.mobile-nav-link {
  font-family:var(--ff-display); font-size:2.2rem; font-weight:700;
  color:var(--ink-3); transition:color var(--ease);
}
.mobile-nav-link:hover { color:var(--ink) }
.mobile-nav-close { position:absolute; top:22px; right:28px; font-size:1.4rem; color:var(--ink-3); cursor:pointer }
.mobile-nav-sub {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  border-top:1px solid var(--border); padding-top:16px; margin-top:4px;
}
.mobile-nav-sub a {
  font-size:0.82rem; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--ink-4); transition:color var(--ease);
}
.mobile-nav-sub a:hover { color:var(--red) }

/* ── BUTTONS ── */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 32px; background:var(--navy); color:var(--pure-white);
  font-family:var(--ff-display); font-size:0.78rem; font-weight:700;
  letter-spacing:0.06em; text-transform:uppercase; border-radius:var(--r);
  transition:var(--ease); border:2px solid var(--navy);
}
.btn-primary:hover { background:transparent; color:var(--navy); transform:translateY(-2px); box-shadow:var(--shadow-md) }
.btn-outline {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 32px; border:2px solid var(--border-dk);
  color:var(--ink-2); font-family:var(--ff-display); font-size:0.78rem;
  font-weight:600; letter-spacing:0.06em; text-transform:uppercase;
  border-radius:var(--r); transition:var(--ease);
}
.btn-outline:hover { border-color:var(--navy); color:var(--navy); transform:translateY(-2px) }
.btn-red {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 32px; background:var(--red); color:var(--pure-white);
  font-family:var(--ff-display); font-size:0.78rem; font-weight:700;
  letter-spacing:0.06em; text-transform:uppercase; border-radius:var(--r);
  transition:var(--ease); border:2px solid var(--red);
}
.btn-red:hover { background:transparent; color:var(--red); transform:translateY(-2px) }
.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  color:var(--navy); font-family:var(--ff-display); font-size:0.84rem;
  font-weight:600; letter-spacing:0.02em; transition:var(--ease);
  border-bottom:1px solid transparent; padding-bottom:2px;
}
.btn-ghost:hover { gap:13px; border-bottom-color:var(--navy) }

/* ── HERO ── */
.hero {
  min-height:100vh; padding-top:71px;
  display:flex; align-items:stretch;
  position:relative; overflow:hidden; background:var(--pure-white);
}
.hero-inner {
  max-width:1200px; margin:0 auto; padding:0 48px;
  width:100%; display:grid; grid-template-columns:1fr 1fr;
  align-items:center; gap:0;
}
.hero-content {
  padding:80px 60px 80px 0;
  border-right:1px solid var(--border);
  position:relative; z-index:1;
}
.hero-issue {
  font-family:var(--ff-mono); font-size:0.68rem;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--red); margin-bottom:28px;
  display:flex; align-items:center; gap:12px;
}
.hero-issue::before { content:''; display:block; width:28px; height:2px; background:var(--red) }
.hero-name {
  font-family:var(--ff-display); font-size:clamp(3.2rem,5.5vw,6rem);
  font-weight:800; line-height:1; letter-spacing:-0.03em;
  color:var(--ink); margin-bottom:16px;
}
.hero-name em { font-style:normal; color:var(--red) }
.hero-rule { display:flex; align-items:center; gap:16px; margin-bottom:24px }
.hero-rule-line { flex:1; height:1px; background:var(--border) }
.hero-rule-text {
  font-family:var(--ff-mono); font-size:0.68rem;
  letter-spacing:0.15em; text-transform:uppercase;
  color:var(--ink-3); white-space:nowrap;
}
.hero-role-text {
  font-family:var(--ff-mono); font-size:0.75rem;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-3); margin-bottom:28px; min-height:1.2em;
}
.typing-cursor {
  display:inline-block; width:2px; height:0.85em;
  background:var(--red); margin-left:2px;
  animation:blink 1s step-end infinite; vertical-align:text-bottom;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
.hero-bio { font-size:1.02rem; color:var(--ink-2); line-height:1.85; max-width:480px; margin-bottom:40px }
.hero-bio strong { color:var(--ink); font-weight:600 }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap }
.hero-visual { padding:80px 0 80px 60px; display:flex; flex-direction:column; align-items:center; justify-content:center; position:relative }
.hero-img-frame { width:100%; max-width:380px; aspect-ratio:3/4; position:relative; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-xl) }
.hero-img-frame img { width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform 0.8s ease }
.hero-img-frame:hover img { transform:scale(1.04) }
.hero-img-frame::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,transparent 60%,rgba(13,27,42,0.4)) }
.hero-tag-stack {
  position:absolute; bottom:24px; left:24px; right:24px; z-index:2;
  background:rgba(255,255,255,0.95); backdrop-filter:blur(10px);
  border-radius:var(--r-lg); padding:16px 20px;
  display:flex; align-items:center; gap:12px; box-shadow:var(--shadow-md);
}
.hero-tag-dot {
  width:8px; height:8px; background:var(--red); border-radius:50%; flex-shrink:0;
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{box-shadow:0 0 0 0 rgba(192,57,43,0.4)} 50%{box-shadow:0 0 0 8px rgba(192,57,43,0)} }
.hero-tag-text { font-family:var(--ff-display); font-size:0.92rem; font-weight:600; color:var(--ink) }
.hero-stats-row {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:var(--border); border:1px solid var(--border);
  border-radius:var(--r-lg); overflow:hidden; margin-top:20px;
  width:100%; max-width:380px;
}
.hero-stat { background:var(--pure-white); padding:16px 12px; text-align:center; border-right:1px solid var(--border) }
.hero-stat:last-child { border-right:none }
.hero-stat-num { font-family:var(--ff-display); font-size:1.8rem; font-weight:800; color:var(--navy); line-height:1 }
.hero-stat-label { font-family:var(--ff-mono); font-size:0.58rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-3); margin-top:5px }

/* ── MARQUEE ── */
.marquee-strip { padding:16px 0; background:var(--navy); overflow:hidden }
.marquee-track { display:flex; animation:marquee 35s linear infinite; white-space:nowrap }
.marquee-item { font-family:var(--ff-mono); font-size:0.65rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:rgba(255,255,255,0.5); padding:0 28px; flex-shrink:0 }
.marquee-item em { color:var(--gold); font-style:normal }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── SECTIONS ── */
.section { padding:120px 0; position:relative }
.section-sm { padding:80px 0 }
.section-navy { background:var(--navy); color:var(--pure-white) }
.section-cream { background:var(--cream) }
.section-white { background:var(--pure-white) }
.divider-line { height:1px; background:var(--border); max-width:1200px; margin:0 auto }

.section-eyebrow {
  font-family:var(--ff-mono); font-size:0.68rem; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--red); margin-bottom:16px;
  display:flex; align-items:center; gap:12px;
}
.section-eyebrow::before { content:''; display:block; width:24px; height:2px; background:var(--red) }
.section-eyebrow.light { color:var(--gold) }
.section-eyebrow.light::before { background:var(--gold) }
.section-title {
  font-family:var(--ff-display); font-size:clamp(2.4rem,4.5vw,4rem);
  font-weight:800; line-height:1.08; color:var(--ink); letter-spacing:-0.02em;
}
.section-title.light { color:var(--pure-white) }
.section-title em { font-style:normal; color:var(--red); font-weight:800 }
.section-title.light em { color:rgba(255,220,160,0.9) }
.section-desc { margin-top:18px; font-size:1.05rem; color:var(--ink-2); max-width:600px; line-height:1.85 }
.section-desc.light { color:rgba(255,255,255,0.7) }

/* ── PAGE HERO ── */
.page-hero {
  padding:140px 0 80px; background:var(--pure-white);
  border-bottom:1px solid var(--border); position:relative; overflow:hidden;
}
.page-hero::after {
  content:attr(data-num); position:absolute; right:48px; bottom:-20px;
  font-family:var(--ff-display); font-size:18rem; font-weight:900;
  color:rgba(13,27,42,0.03); line-height:1; pointer-events:none;
}
.page-hero-back {
  font-family:var(--ff-mono); font-size:0.66rem; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--ink-4); transition:color var(--ease);
  display:inline-flex; align-items:center; gap:8px; margin-bottom:24px;
}
.page-hero-back:hover { color:var(--red) }
.page-hero-eyebrow {
  font-family:var(--ff-mono); font-size:0.68rem; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--red); margin-bottom:20px;
  display:flex; align-items:center; gap:12px;
}
.page-hero-eyebrow::before { content:''; display:block; width:24px; height:2px; background:var(--red) }
.page-hero-title {
  font-family:var(--ff-display); font-size:clamp(2.8rem,6vw,5.6rem);
  font-weight:800; line-height:1.04; color:var(--ink); max-width:820px;
  letter-spacing:-0.03em;
}
.page-hero-title em { font-style:normal; color:var(--red) }
.page-hero-sub { margin-top:20px; font-size:1.05rem; color:var(--ink-2); max-width:580px; line-height:1.85 }

/* ── BENTO GRID ── */
.bento-grid { display:grid; grid-template-columns:repeat(3,1fr); grid-template-rows:auto; gap:16px }
.bento-card {
  background:var(--pure-white); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:36px 32px;
  transition:var(--ease); position:relative; overflow:hidden;
}
.bento-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--border); transition:var(--ease) }
.bento-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:transparent }
.bento-card:hover::before { background:var(--red) }
.bento-card.featured { grid-column:span 2; background:var(--navy); border-color:transparent }
.bento-card.featured::before { background:var(--gold) }
.bento-num { font-family:var(--ff-display); font-size:2.8rem; font-weight:900; color:var(--border); line-height:1; margin-bottom:16px; transition:var(--ease) }
.bento-card:hover .bento-num { color:var(--red) }
.bento-card.featured .bento-num { color:rgba(255,255,255,0.1) }
.bento-title { font-family:var(--ff-display); font-size:1.2rem; font-weight:700; color:var(--ink); margin-bottom:10px }
.bento-card.featured .bento-title { color:var(--pure-white) }
.bento-desc { font-size:0.88rem; color:var(--ink-3); line-height:1.75 }
.bento-card.featured .bento-desc { color:rgba(255,255,255,0.65) }

/* ── TTL SHOWCASE ── */
.ttl-showcase { display:grid; grid-template-columns:1fr 1fr; gap:0; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-xl) }
.ttl-showcase-left { background:var(--navy); padding:60px 56px; display:flex; flex-direction:column; justify-content:space-between }
.ttl-showcase-right { background:var(--pure-white); padding:60px 56px }
.ttl-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px; background:rgba(200,136,42,0.2);
  border:1px solid rgba(200,136,42,0.4); border-radius:100px;
  font-family:var(--ff-mono); font-size:0.66rem; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--gold-lt); margin-bottom:24px;
}
.ttl-badge::before { content:'●'; font-size:0.5rem; animation:pulse 2s infinite }
.ttl-showcase-title { font-family:var(--ff-display); font-size:2.8rem; font-weight:800; color:var(--pure-white); line-height:1.1; margin-bottom:20px; letter-spacing:-0.02em }
.ttl-showcase-desc { font-size:0.95rem; color:rgba(255,255,255,0.7); line-height:1.85; margin-bottom:32px }
.ttl-numbers { display:flex; flex-direction:column; gap:0 }
.ttl-number-item { display:flex; align-items:baseline; gap:12px; padding:16px 0; border-top:1px solid rgba(255,255,255,0.1) }
.ttl-number-item:first-child { border-top:none }
.ttl-number-val { font-family:var(--ff-display); font-size:2.4rem; font-weight:800; color:var(--gold-lt); line-height:1 }
.ttl-number-lbl { font-size:0.82rem; color:rgba(255,255,255,0.5) }
.ttl-right-eyebrow { font-family:var(--ff-mono); font-size:0.66rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--red); margin-bottom:20px; display:flex; align-items:center; gap:10px }
.ttl-right-eyebrow::before { content:''; display:block; width:20px; height:2px; background:var(--red) }
.ttl-right-title { font-family:var(--ff-display); font-size:1.8rem; font-weight:800; color:var(--ink); margin-bottom:16px; letter-spacing:-0.02em }
.ttl-program-list { display:flex; flex-direction:column; gap:12px; margin:24px 0 }
.ttl-program { display:flex; gap:14px; align-items:flex-start; padding:14px 16px; background:var(--warm-white); border-radius:var(--r); border-left:3px solid var(--navy) }
.ttl-program-name { font-family:var(--ff-display); font-weight:700; font-size:0.88rem; color:var(--ink); margin-bottom:3px }
.ttl-program-desc { font-size:0.78rem; color:var(--ink-3); line-height:1.6 }

/* ── ARTICLE CARDS ── */
.article-hero-card { display:grid; grid-template-columns:1fr 1fr; gap:0; border-radius:var(--r-xl); overflow:hidden; border:1px solid var(--border); transition:var(--ease); text-decoration:none; color:inherit }
.article-hero-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:transparent }
.article-hero-thumb { background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%); display:flex; align-items:center; justify-content:center; min-height:320px; font-size:5rem; position:relative; overflow:hidden }
.article-hero-body { padding:48px; background:var(--pure-white) }
.article-tag { font-family:var(--ff-mono); font-size:0.66rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--red); margin-bottom:14px; display:flex; align-items:center; gap:8px }
.article-tag::before { content:''; display:block; width:16px; height:2px; background:var(--red) }
.article-hero-title { font-family:var(--ff-display); font-size:1.85rem; font-weight:800; color:var(--ink); line-height:1.15; margin-bottom:14px; letter-spacing:-0.02em }
.article-hero-excerpt { font-size:0.95rem; color:var(--ink-2); line-height:1.8; margin-bottom:22px }
.article-meta { font-family:var(--ff-mono); font-size:0.64rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-4); display:flex; align-items:center; gap:12px }
.article-meta-dot { width:3px; height:3px; background:var(--ink-4); border-radius:50% }

/* ── CONTACT ── */
.contact-split { display:grid; grid-template-columns:1fr 1.3fr; gap:80px; align-items:start }
.contact-info-block { display:flex; align-items:flex-start; gap:16px; margin-bottom:24px }
.contact-icon-box { width:42px; height:42px; background:var(--cream); border:1px solid var(--border); border-radius:var(--r); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:1rem }
.contact-info-label { font-family:var(--ff-mono); font-size:0.66rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); margin-bottom:4px }
.contact-info-value { font-size:0.92rem; color:var(--ink) }
.contact-form-card { background:var(--pure-white); border:1px solid var(--border); border-radius:var(--r-xl); padding:48px; box-shadow:var(--shadow-md) }
.contact-form-title { font-family:var(--ff-display); font-size:1.7rem; font-weight:800; color:var(--ink); margin-bottom:6px; letter-spacing:-0.02em }
.contact-form-sub { font-size:0.84rem; color:var(--ink-3); margin-bottom:28px }

/* ── TIMELINE ── */
.timeline { position:relative; padding-left:32px }
.timeline::before { content:''; position:absolute; top:0; bottom:0; left:0; width:2px; background:linear-gradient(to bottom,var(--red),var(--navy),var(--gold)) }
.timeline-item { position:relative; padding-bottom:40px }
.timeline-item:last-child { padding-bottom:0 }
.timeline-dot { position:absolute; left:-38px; top:6px; width:12px; height:12px; background:var(--pure-white); border:2px solid var(--red); border-radius:50%; box-shadow:0 0 0 4px rgba(192,57,43,0.12); transition:var(--ease) }
.timeline-item:hover .timeline-dot { background:var(--red) }
.timeline-year { font-family:var(--ff-mono); font-size:0.68rem; letter-spacing:0.1em; color:var(--red); margin-bottom:6px }
.timeline-title { font-family:var(--ff-display); font-size:1.15rem; font-weight:700; color:var(--ink); margin-bottom:3px }
.timeline-org { font-size:0.84rem; color:var(--ink-3); margin-bottom:8px }
.timeline-desc { font-size:0.84rem; color:var(--ink-3); line-height:1.7 }

/* ── AWARD LIST ── */
.award-list { display:flex; flex-direction:column; gap:0 }
.award-item { display:flex; align-items:center; gap:20px; padding:22px 0; border-bottom:1px solid var(--border); transition:var(--ease) }
.award-item:first-child { border-top:1px solid var(--border) }
.award-item:hover { padding-left:8px }
.award-icon { width:44px; height:44px; background:var(--navy); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0 }
.award-title { font-family:var(--ff-display); font-size:1.05rem; font-weight:700; color:var(--ink); margin-bottom:3px }
.award-org { font-size:0.78rem; color:var(--ink-3) }

/* ── TEAM ── */
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.team-card { background:var(--pure-white); border:1px solid var(--border); border-radius:var(--r-xl); overflow:hidden; transition:var(--ease) }
.team-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-4px); border-color:transparent }
.team-card.featured { border-color:var(--navy); border-width:2px }
.team-card-img { aspect-ratio:1; background:var(--cream); display:flex; align-items:center; justify-content:center; font-size:2.5rem; overflow:hidden }
.team-card-img img { width:100%; height:100%; object-fit:cover; object-position:top }
.team-card-body { padding:22px }
.team-card-name { font-family:var(--ff-display); font-size:1.1rem; font-weight:700; color:var(--ink); margin-bottom:4px }
.team-card-role { font-family:var(--ff-mono); font-size:0.62rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--red); margin-bottom:10px }
.team-card-desc { font-size:0.8rem; color:var(--ink-3); line-height:1.7 }

/* ── PROGRAM CARDS ── */
.program-card { border-radius:var(--r-xl); overflow:hidden; border:1px solid var(--border); margin-bottom:16px; transition:var(--ease) }
.program-card:hover { box-shadow:var(--shadow-md) }
.program-card-head { padding:28px 36px; display:flex; align-items:center; justify-content:space-between; gap:20px }
.program-card-num { font-family:var(--ff-display); font-size:2.5rem; font-weight:900; opacity:0.12; line-height:1; flex-shrink:0 }
.program-card-title { font-family:var(--ff-display); font-size:1.35rem; font-weight:700; color:var(--ink); margin-bottom:4px }
.program-card-partners { font-size:0.78rem; color:var(--ink-3) }
.program-card-body { padding:0 36px 28px }
.program-card-desc { font-size:0.9rem; color:var(--ink-2); line-height:1.8; margin-bottom:16px }

/* ── TAGS ── */
.tag { display:inline-block; padding:5px 13px; background:var(--cream); border:1px solid var(--border); border-radius:100px; font-size:0.74rem; font-weight:500; color:var(--ink-2); margin:4px; transition:var(--ease) }
.tag:hover, .tag.active { background:var(--navy); color:var(--pure-white); border-color:var(--navy) }

/* ── ARTICLE BODY ── */
.article-body { max-width:700px; margin:0 auto }
.article-body h2 { font-family:var(--ff-display); font-size:2rem; font-weight:800; color:var(--ink); margin:48px 0 18px; letter-spacing:-0.02em }
.article-body p { font-size:1.05rem; color:var(--ink-2); line-height:1.9; margin-bottom:20px }
.article-body blockquote { border-left:3px solid var(--red); padding:8px 28px; margin:36px 0; font-family:var(--ff-display); font-size:1.4rem; font-weight:600; color:var(--navy); line-height:1.5 }
.article-body ul { margin:18px 0 }
.article-body ul li { position:relative; padding-left:20px; font-size:1.02rem; color:var(--ink-2); margin-bottom:10px; line-height:1.8 }
.article-body ul li::before { content:''; position:absolute; left:0; top:11px; width:8px; height:2px; background:var(--red) }
.article-body strong { color:var(--ink); font-weight:600 }
.article-lead { font-size:1.2rem !important; color:var(--ink) !important; line-height:1.8 !important; font-weight:300 }

/* ── PULL QUOTE ── */
.pull-quote { padding:60px; background:var(--navy); border-radius:var(--r-xl); margin:40px 0; position:relative }
.pull-quote::before { content:'\201C'; font-family:var(--ff-display); font-size:8rem; color:rgba(255,255,255,0.06); position:absolute; top:-10px; left:40px; line-height:1 }
.pull-quote-text { font-family:var(--ff-display); font-size:1.6rem; font-weight:600; color:var(--pure-white); line-height:1.5; position:relative; z-index:1 }
.pull-quote-attr { font-family:var(--ff-mono); font-size:0.7rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--gold-lt); margin-top:20px }

/* ── FOOTER ── */
.footer { background:var(--navy); padding:64px 0 32px }
.footer-grid { display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:56px; margin-bottom:48px }
.footer-brand { font-family:var(--ff-display); font-size:1.35rem; font-weight:800; color:var(--pure-white); margin-bottom:12px; letter-spacing:-0.01em }
.footer-desc { font-size:0.85rem; color:rgba(255,255,255,0.5); line-height:1.75; margin-bottom:24px }
.footer-socials { display:flex; gap:10px }
.footer-social { width:36px; height:36px; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:0.82rem; color:rgba(255,255,255,0.5); transition:var(--ease) }
.footer-social:hover { background:var(--red); color:var(--pure-white); border-color:var(--red) }
.footer-col-title { font-family:var(--ff-mono); font-size:0.64rem; letter-spacing:0.16em; text-transform:uppercase; color:rgba(255,255,255,0.3); margin-bottom:18px }
.footer-link { display:block; font-size:0.85rem; color:rgba(255,255,255,0.55); padding:5px 0; transition:color var(--ease) }
.footer-link:hover { color:var(--pure-white) }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding-top:24px; display:flex; align-items:center; justify-content:space-between }
.footer-copy { font-size:0.74rem; color:rgba(255,255,255,0.3) }
.back-top { font-family:var(--ff-mono); font-size:0.66rem; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.3); cursor:pointer; transition:color var(--ease) }
.back-top:hover { color:var(--gold-lt) }

/* ── FAQ ── */
.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px }
.faq-item { padding:26px; background:var(--pure-white); border:1px solid var(--border); border-radius:var(--r-xl) }
.faq-q { font-family:var(--ff-display); font-size:1rem; font-weight:700; color:var(--ink); margin-bottom:9px }
.faq-a { font-size:0.84rem; color:var(--ink-2); line-height:1.75 }

/* ── REVEAL ── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity 0.7s ease,transform 0.7s ease }
.reveal-left { opacity:0; transform:translateX(-28px); transition:opacity 0.7s ease,transform 0.7s ease }
.reveal-right { opacity:0; transform:translateX(28px); transition:opacity 0.7s ease,transform 0.7s ease }
.reveal.visible, .reveal-left.visible, .reveal-right.visible { opacity:1; transform:none }
.reveal-d1{transition-delay:0.1s} .reveal-d2{transition-delay:0.2s}
.reveal-d3{transition-delay:0.3s} .reveal-d4{transition-delay:0.4s}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{display:none}
  .hero-content{padding:80px 0;border-right:none;border-bottom:1px solid var(--border)}
  .ttl-showcase{grid-template-columns:1fr}
  .bento-grid{grid-template-columns:repeat(2,1fr)}
  .bento-card.featured{grid-column:span 2}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .article-hero-card{grid-template-columns:1fr}
  .contact-split{grid-template-columns:1fr}
}
@media(max-width:768px){
  .wrap{padding:0 16px}
  .nav-inner{padding:0 16px}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .section{padding:60px 0}
  .section-sm{padding:48px 0}
  .page-hero{padding:120px 0 48px}
  .page-hero::after{display:none}
  .bento-grid{grid-template-columns:1fr}
  .bento-card.featured{grid-column:span 1}
  .team-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  .hero-cta{flex-direction:column;align-items:flex-start}
  .faq-grid{grid-template-columns:1fr}
  .contact-form-card{padding:24px 16px}
  .ttl-showcase-left,.ttl-showcase-right{padding:32px 20px}
  .pull-quote{padding:32px 20px}
  .pull-quote-text{font-size:1.15rem}
  .hero-name{font-size:clamp(2.4rem,10vw,4rem);word-break:break-word}
  .hero-rule-text{white-space:normal;font-size:0.62rem}
  .hero-bio{font-size:0.95rem;max-width:100%}
  .page-hero-title{font-size:clamp(2rem,8vw,3.5rem);word-break:break-word}
  .page-hero-sub{font-size:0.95rem;max-width:100%}
  .section-title>h2{font-size:clamp(1.6rem,6vw,2.4rem);word-break:break-word}
  .ttl-showcase{grid-template-columns:1fr}
  .article-hero-card{grid-template-columns:1fr}
  .article-hero-thumb{min-height:180px}
  pre,code{overflow-x:auto;white-space:pre-wrap}
  table{display:block;overflow-x:auto}
}

/* ── DARK MODE ── */
[data-theme="dark"]{
  --ink:#e8e6e2; --ink-2:rgba(232,230,226,.75); --ink-3:rgba(232,230,226,.45);
  --bg:#111118; --bg-2:#18181f; --bg-3:#1e1e26;
  --border:rgba(255,255,255,.1); --pure-white:#e8e6e2;
  --surface:#1a1a22; --gold:#d4952f;
}
[data-theme="dark"] body{background:#111118;color:#e8e6e2}
[data-theme="dark"] .nav{background:rgba(17,17,24,.96);border-color:rgba(255,255,255,.08)}
[data-theme="dark"] .section-dark{background:#0d0d14}
[data-theme="dark"] .off-bg,[data-theme="dark"] .page-hero{background:#111118}
[data-theme="dark"] .bento-card{background:#18181f;border-color:rgba(255,255,255,.08)}
[data-theme="dark"] .footer{background:#0d0d14}
[data-theme="dark"] .hero-name{color:#e8e6e2}
[data-theme="dark"] .contact-form-card{background:#18181f;border-color:rgba(255,255,255,.08)}
[data-theme="dark"] input,[data-theme="dark"] textarea,[data-theme="dark"] select{background:#1e1e26;border-color:rgba(255,255,255,.1);color:#e8e6e2}

/* Dark mode toggle button */
.dark-toggle{position:fixed;bottom:24px;right:24px;z-index:999;
  width:44px;height:44px;border-radius:50%;
  background:#f7f5f1;border:1px solid #e4e0d8;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;transition:background .25s,border-color .25s,transform .2s;
  box-shadow:0 2px 12px rgba(0,0,0,.1)}
.dark-toggle:hover{transform:scale(1.1)}
[data-theme="dark"] .dark-toggle{background:#1e1e26;border-color:rgba(255,255,255,.12)}
