/* ============================================================
   pages.css — Specialized page components
   Loaded after styles.css
   ============================================================ */

/* ── Home hero ──────────────────────────────────────────── */
.hero { position: relative; background: var(--color-navy-deep); color: var(--color-cream); overflow: hidden; }
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 28%; opacity: 0.42; filter: saturate(0.9); }
.hero__bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(105deg, var(--color-navy-deep) 18%, rgba(6,15,30,0.86) 46%, rgba(6,15,30,0.45) 100%), linear-gradient(0deg, rgba(6,15,30,0.85) 0%, transparent 45%); }
.hero__inner { position: relative; z-index: 1; padding: clamp(80px, 12vh, 150px) 0 clamp(72px, 10vh, 130px); }
.hero__content { max-width: 760px; }
.hero .eyebrow { color: var(--color-gold-light); margin-bottom: var(--space-6); display: block; }
.hero h1 { color: var(--color-cream); margin-bottom: var(--space-6); }
.hero__sub { font-size: var(--text-lg); color: rgba(255,253,247,0.82); margin-bottom: var(--space-8); max-width: 54ch; line-height: var(--leading-normal); }
.hero__sub strong { color: var(--color-gold-light); font-weight: 600; }
.hero .btn-row { margin-bottom: var(--space-10); }
.trust-strip { display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-6); align-items: center; padding-top: var(--space-6); border-top: 1px solid rgba(255,255,255,0.12); }
.trust-strip span { font-size: var(--text-sm); font-weight: 600; letter-spacing: var(--tracking-wide); color: rgba(255,253,247,0.78); text-transform: uppercase; display: inline-flex; align-items: center; gap: var(--space-3); }
.trust-strip span strong { color: var(--color-gold-light); }
.trust-strip span:not(:last-child)::after { content: "·"; color: var(--color-gold); margin-left: var(--space-3); }

/* ── Hybrid pyramid ─────────────────────────────────────── */
.pyramid { display: flex; flex-direction: column; align-items: center; gap: 6px; max-width: 460px; margin: 0 auto; }
.pyramid__tier { color: var(--color-cream); border-radius: var(--radius-md); padding: var(--space-4) var(--space-5); text-align: center; width: 100%; box-shadow: var(--shadow-card); opacity: 0; transform: translateY(24px); transition: opacity 0.5s ease, transform 0.5s ease; }
.pyramid.is-built .pyramid__tier { opacity: 1; transform: none; }
.pyramid.is-built .pyramid__tier:nth-child(1) { transition-delay: 0s; }
.pyramid.is-built .pyramid__tier:nth-child(2) { transition-delay: 0.18s; }
.pyramid.is-built .pyramid__tier:nth-child(3) { transition-delay: 0.36s; }
.pyramid.is-built .pyramid__tier:nth-child(4) { transition-delay: 0.54s; }
.pyramid__tier .tier-name { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); letter-spacing: var(--tracking-wide); }
.pyramid__tier .tier-desc { font-size: var(--text-xs); opacity: 0.82; margin-top: 3px; letter-spacing: var(--tracking-wide); text-transform: uppercase; }
.pyramid__tier--shield { width: 46%; background: var(--color-gold-light); color: var(--color-navy); }
.pyramid__tier--hands { width: 64%; background: var(--color-gold); }
.pyramid__tier--mind { width: 82%; background: var(--color-slate); }
.pyramid__tier--soul { width: 100%; background: var(--color-navy); border: 1px solid rgba(212,168,85,0.4); }
.pyramid__tier--shield .tier-desc { opacity: 0.7; }

/* tier feature cards */
.tier-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.tier-card { padding: var(--space-6); border-radius: var(--radius-lg); border: 1px solid var(--color-mist); background: var(--color-white); }
.tier-card__icon { width: 48px; height: 48px; border-radius: var(--radius-md); background: var(--color-navy); color: var(--color-gold-light); display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-4); }
.tier-card__icon svg { width: 26px; height: 26px; }
.tier-card h3 { font-size: var(--text-xl); margin-bottom: var(--space-2); }
.tier-card .tier-tag { font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-gold); display: block; margin-bottom: var(--space-3); }
.tier-card p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); }

/* ── Institution cards (home carousel) ──────────────────── */
.inst-rail { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(300px, 1fr); gap: var(--space-6); overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: var(--space-4); margin: 0 calc(-1 * var(--space-6)); padding-left: var(--space-6); padding-right: var(--space-6); scrollbar-width: thin; }
.inst-rail::-webkit-scrollbar { height: 6px; }
.inst-rail::-webkit-scrollbar-thumb { background: var(--color-mist); border-radius: 3px; }
.inst-card { scroll-snap-align: start; background: var(--color-white); border: 1px solid var(--color-mist); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: transform var(--transition-base), box-shadow var(--transition-base); }
.inst-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }
.inst-card__media { aspect-ratio: 16/10; position: relative; }
.inst-card__media .brand-panel { min-height: 100%; height: 100%; border-radius: 0; }
.inst-card__media img { width: 100%; height: 100%; object-fit: cover; }
.inst-card__body { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; }
.inst-card__meta { font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-gold); }
.inst-card__body h3 { font-size: var(--text-xl); }
.inst-card__body p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); flex: 1; }

/* ── Legacy (3 generations) ─────────────────────────────── */
.legacy-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); position: relative; }
.legacy-row::before { content: ""; position: absolute; top: 90px; left: 12%; right: 12%; height: 1px; background: linear-gradient(90deg, transparent, var(--color-gold) 18%, var(--color-gold) 82%, transparent); z-index: 0; }
.legacy-card { position: relative; z-index: 1; text-align: center; transition: opacity var(--transition-base); }
.legacy-row:hover .legacy-card { opacity: 0.55; }
.legacy-row .legacy-card:hover { opacity: 1; }
.legacy-portrait { width: 180px; height: 180px; margin: 0 auto var(--space-5); border-radius: 50%; overflow: hidden; border: 3px solid var(--color-gold); background: var(--color-parchment); box-shadow: var(--shadow-card); }
.legacy-portrait img { width: 100%; height: 100%; object-fit: cover; }
.legacy-portrait .brand-panel { min-height: 100%; height: 100%; border-radius: 0; }
.legacy-portrait .brand-panel__inner img { height: 44px; margin: 0; opacity: 0.85; }
.legacy-card .role { font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-gold); display: block; margin-bottom: var(--space-2); }
.legacy-card h3 { font-size: var(--text-xl); margin-bottom: var(--space-1); }
.legacy-card .relation { font-size: var(--text-sm); color: var(--color-slate-light); margin-bottom: var(--space-4); display: block; }
.legacy-card p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); text-align: left; }

/* ── Vision roadmap ─────────────────────────────────────── */
.roadmap { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); position: relative; margin-top: var(--space-12); }
.roadmap::before { content: ""; position: absolute; top: 9px; left: 8%; right: 8%; height: 2px; background-image: linear-gradient(90deg, var(--color-gold) 60%, transparent 0); background-size: 14px 2px; }
.roadmap-goal { position: relative; padding-top: var(--space-8); }
.roadmap-goal::before { content: ""; position: absolute; top: 0; left: 0; width: 20px; height: 20px; background: var(--color-gold); transform: rotate(45deg); border: 3px solid var(--color-cream); box-shadow: var(--shadow-sm); }
.section-alt .roadmap-goal::before { border-color: var(--color-parchment); }
.roadmap-goal .goal-tag { font-size: var(--text-xs); font-weight: 700; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-gold); }
.roadmap-goal h3 { font-size: var(--text-xl); margin: var(--space-2) 0 var(--space-3); }
.roadmap-goal p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); }

/* ── Testimonial carousel ───────────────────────────────── */
.testimonials { position: relative; max-width: 820px; margin: 0 auto; text-align: center; }
.testimonial-track { position: relative; min-height: 200px; }
.testimonial { position: absolute; inset: 0; opacity: 0; visibility: hidden; transition: opacity var(--transition-slow); display: flex; flex-direction: column; justify-content: center; }
.testimonial.is-active { opacity: 1; visibility: visible; position: relative; }
.testimonial blockquote { font-family: var(--font-display); font-style: italic; font-size: clamp(var(--text-xl), 2.6vw, var(--text-3xl)); line-height: var(--leading-quote); color: var(--color-navy); margin-bottom: var(--space-6); }
.section-dark .testimonial blockquote { color: var(--color-cream); }
.testimonial cite { font-style: normal; font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-gold); }
.testimonial .verified { display: inline-flex; align-items: center; gap: 6px; margin-top: var(--space-3); font-size: var(--text-xs); color: var(--color-aqqa); font-weight: 600; }
.testimonial .verified svg { width: 15px; height: 15px; }
.carousel-dots { display: flex; gap: var(--space-2); justify-content: center; margin-top: var(--space-10); }
.carousel-dots button { width: 9px; height: 9px; border-radius: 50%; border: 0; background: var(--color-mist); transition: all var(--transition-base); padding: 0; }
.carousel-dots button.is-active { background: var(--color-gold); width: 26px; border-radius: 5px; }

/* ── Writing / blog cards ───────────────────────────────── */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); }
.post-card { display: flex; flex-direction: column; background: var(--color-white); border: 1px solid var(--color-mist); border-radius: var(--radius-lg); overflow: hidden; transition: transform var(--transition-base), box-shadow var(--transition-base); }
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }
.post-card__media { aspect-ratio: 16/9; position: relative; }
.post-card__media .brand-panel { height: 100%; min-height: 100%; border-radius: 0; }
.post-card__body { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; }
.post-card__body h3 { font-size: var(--text-xl); }
.post-card__date { font-size: var(--text-sm); color: var(--color-slate-light); }
.post-card__body p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); flex: 1; }
.featured-essay { display: grid; grid-template-columns: 1.1fr 1fr; gap: var(--space-12); align-items: center; background: var(--color-white); border: 1px solid var(--color-mist); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-card); }
.featured-essay__media { min-height: 360px; }
.featured-essay__body { padding: var(--space-12); }
.filter-row { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-8); }
.filter-chip { font-size: var(--text-sm); font-weight: 500; color: var(--color-slate); background: transparent; border: 1px solid var(--color-mist); border-radius: var(--radius-pill); padding: 8px 18px; transition: all var(--transition-fast); }
.filter-chip:hover { border-color: var(--color-gold); color: var(--color-gold); }
.filter-chip.is-active { background: var(--color-navy); color: var(--color-cream); border-color: var(--color-navy); }

/* ── Hybrid model page: TOC + tiers + comparison ────────── */
.toc-layout { display: grid; grid-template-columns: 240px 1fr; gap: var(--space-16); align-items: start; }
.toc { position: sticky; top: calc(var(--header-h) + 24px); }
.toc__label { font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--color-gold); margin-bottom: var(--space-4); }
.toc ul { display: flex; flex-direction: column; gap: var(--space-1); border-left: 1px solid var(--color-mist); }
.toc a { display: block; padding: 8px 16px; font-size: var(--text-base); color: var(--color-slate); border-left: 2px solid transparent; margin-left: -1px; transition: all var(--transition-fast); }
.toc a:hover { color: var(--color-navy); }
.toc a.is-active { color: var(--color-gold); border-left-color: var(--color-gold); font-weight: 600; }
.toc-mobile { display: none; }
.tier-block { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-12); align-items: center; padding: var(--space-12) 0; border-top: 1px solid var(--color-mist); }
.tier-block:nth-child(even) .tier-block__media { order: 2; }
.tier-block__num { font-family: var(--font-display); font-weight: 700; font-size: clamp(5rem, 12vw, 10rem); color: var(--color-gold); opacity: 0.18; line-height: 0.8; }
.tier-block__media { position: relative; }
.tier-block h3 { font-size: var(--text-3xl); margin: var(--space-2) 0 var(--space-2); }
.tier-block .tier-sub { font-size: var(--text-sm); color: var(--color-gold-muted); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; margin-bottom: var(--space-4); display: block; }
.tier-block .tier-list { font-size: var(--text-base); color: var(--color-teal); font-weight: 500; margin-bottom: var(--space-5); }
.compare-table { width: 100%; border-collapse: collapse; }
.compare-table th, .compare-table td { padding: var(--space-5) var(--space-5); text-align: left; vertical-align: top; border-bottom: 1px solid var(--color-mist); font-size: var(--text-base); }
.compare-table thead th { font-family: var(--font-display); font-size: var(--text-lg); color: var(--color-navy); border-bottom: 2px solid var(--color-navy); }
.compare-table thead th.col-hybrid { color: var(--color-gold); border-bottom-color: var(--color-gold); }
.compare-table .col-label { font-weight: 600; color: var(--color-navy); font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; width: 18%; }
.compare-table .col-hybrid { background: rgba(184,137,62,0.06); color: var(--color-ink); font-weight: 500; border-left: 1px solid rgba(184,137,62,0.2); border-right: 1px solid rgba(184,137,62,0.2); }
.compare-table td:not(.col-label):not(.col-hybrid) { color: var(--color-slate); }
.proof-list { display: flex; flex-direction: column; gap: var(--space-6); max-width: 760px; }
.proof-item { display: flex; gap: var(--space-4); align-items: flex-start; }
.proof-item .check { flex-shrink: 0; width: 30px; height: 30px; border-radius: 50%; background: var(--color-aqqa-pale); color: var(--color-aqqa); display: flex; align-items: center; justify-content: center; }
.proof-item .check svg { width: 18px; height: 18px; }
.proof-item p { font-family: var(--font-display); font-size: var(--text-xl); color: var(--color-navy); line-height: var(--leading-quote); }
.section-dark .proof-item p { color: var(--color-cream); }
.audience-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.audience-card { padding: var(--space-6); border-radius: var(--radius-lg); background: var(--color-white); border: 1px solid var(--color-mist); border-left: 3px solid var(--color-gold); display: flex; flex-direction: column; gap: var(--space-3); }
.audience-card h3 { font-size: var(--text-lg); }
.audience-card p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); flex: 1; }

/* ── Institutions page bands ────────────────────────────── */
.inst-band { padding: var(--section-pad-md) 0; border-bottom: 1px solid var(--color-mist); position: relative; scroll-margin-top: var(--header-h); }
.inst-band:nth-child(even) { background: var(--color-parchment); }
.inst-band__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-16); align-items: center; }
.inst-band:nth-child(even) .inst-band__media { order: 2; }
.inst-band__media { position: relative; }
.inst-band__media .img-frame, .inst-band__media .brand-panel { aspect-ratio: 4/3; }
.inst-band h2 { font-size: clamp(var(--text-3xl), 3vw, var(--text-4xl)); margin: var(--space-3) 0 var(--space-5); }
.inst-band__body p { font-size: var(--text-md); color: var(--color-slate); line-height: var(--leading-body); margin-bottom: var(--space-5); }
.inst-jumpnav { position: sticky; top: calc(var(--header-h) + 12px); z-index: 40; background: rgba(255,253,247,0.9); backdrop-filter: blur(10px); border-bottom: 1px solid var(--color-mist); }
.inst-jumpnav__inner { display: flex; gap: var(--space-1); overflow-x: auto; padding: var(--space-3) 0; scrollbar-width: none; }
.inst-jumpnav__inner::-webkit-scrollbar { display: none; }
.inst-jumpnav a { white-space: nowrap; font-size: var(--text-sm); font-weight: 500; color: var(--color-slate); padding: 6px 14px; border-radius: var(--radius-pill); transition: all var(--transition-fast); }
.inst-jumpnav a:hover, .inst-jumpnav a.is-active { background: var(--color-navy); color: var(--color-cream); }

.program-menu { display: grid; gap: var(--space-3); }
.program-menu .prog { display: grid; grid-template-columns: 1fr auto; gap: var(--space-4); padding: var(--space-4) var(--space-5); border: 1px solid var(--color-mist); border-radius: var(--radius-md); background: var(--color-white); align-items: center; }
.program-menu .prog strong { display: block; font-family: var(--font-display); font-size: var(--text-md); color: var(--color-navy); }
.program-menu .prog span { font-size: var(--text-sm); color: var(--color-slate); }
.program-menu .prog .age { font-size: var(--text-xs); font-weight: 600; color: var(--color-aqqa); white-space: nowrap; }
.pillar-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin-top: var(--space-6); }
.pillar { padding: var(--space-5); border-radius: var(--radius-lg); background: var(--color-white); border-top: 3px solid var(--color-teal); border-left: 1px solid var(--color-mist); border-right: 1px solid var(--color-mist); border-bottom: 1px solid var(--color-mist); }
.pillar h4 { font-family: var(--font-display); font-size: var(--text-lg); color: var(--color-teal); margin-bottom: var(--space-2); }
.pillar p { font-size: var(--text-sm); color: var(--color-slate); line-height: var(--leading-normal); }

/* ── Impact page ────────────────────────────────────────── */
.metric-table { width: 100%; border-collapse: collapse; }
.metric-table th, .metric-table td { padding: var(--space-4) var(--space-5); text-align: left; border-bottom: 1px solid var(--color-mist); font-size: var(--text-base); }
.metric-table thead th { font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-navy); border-bottom: 2px solid var(--color-gold); }
.metric-table tbody tr:nth-child(even) { background: var(--color-parchment); }
.metric-table .metric-name { font-weight: 600; color: var(--color-navy); }
.metric-table .target-2030 { border-left: 3px solid var(--color-gold); font-weight: 600; color: var(--color-gold-muted); }
.metric-table .pending { color: var(--color-slate-light); font-style: italic; }
.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.kpi-card { padding: var(--space-6); border-radius: var(--radius-lg); background: var(--color-white); border: 1px solid var(--color-mist); border-top: 3px solid var(--color-teal); }
.kpi-card .stat-num { font-size: clamp(var(--text-4xl), 4vw, var(--text-5xl)); }
.kpi-card .stat-label { font-size: var(--text-sm); }
.report-cta { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: var(--space-12); align-items: center; background: var(--color-navy); color: var(--color-cream); border-radius: var(--radius-xl); padding: var(--space-12); }
.report-cta h2 { color: var(--color-cream); }
.report-mockup { aspect-ratio: 3/4; border-radius: var(--radius-md); background: linear-gradient(160deg, var(--color-navy-mid), var(--color-navy-deep)); border: 1px solid rgba(212,168,85,0.3); display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-elevated); position: relative; overflow: hidden; max-width: 280px; }
.report-mockup .geo-watermark { opacity: 0.08; }
.report-mockup__label { position: relative; z-index: 1; text-align: center; padding: var(--space-6); }
.report-mockup img { height: 54px; margin: 0 auto var(--space-4); }

/* ── Donate page ────────────────────────────────────────── */
.give-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); align-items: stretch; }
.give-card { display: flex; flex-direction: column; gap: var(--space-4); padding: var(--space-8); border-radius: var(--radius-xl); background: var(--color-white); border: 1px solid var(--color-mist); }
.give-card--feature { border-top: 3px solid var(--color-gold); box-shadow: var(--shadow-card); }
.give-card h3 { font-size: var(--text-2xl); }
.give-card .amount-row { display: flex; justify-content: space-between; gap: var(--space-4); padding: var(--space-3) 0; border-bottom: 1px solid var(--color-mist); }
.give-card .amount-row strong { font-family: var(--font-display); color: var(--color-gold-muted); white-space: nowrap; }
.give-card .amount-row span { font-size: var(--text-sm); color: var(--color-slate); }
.give-card p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); }
.give-card .btn { margin-top: auto; justify-content: center; }
.badge-jariyah { align-self: flex-start; font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-gold); border: 1px solid var(--color-gold); border-radius: var(--radius-pill); padding: 4px 12px; }
.campaign { padding: var(--space-3) 0; border-bottom: 1px solid var(--color-mist); }
.campaign:last-of-type { border-bottom: 0; }
.campaign .c-head { display: flex; justify-content: space-between; gap: var(--space-3); font-size: var(--text-base); margin-bottom: var(--space-2); }
.campaign .c-head strong { color: var(--color-navy); font-family: var(--font-display); }
.progress { height: 7px; border-radius: 4px; background: var(--color-mist); overflow: hidden; }
.progress > span { display: block; height: 100%; background: var(--color-gold); border-radius: 4px; }
.calculator { background: var(--color-white); border: 1px solid var(--color-mist); border-radius: var(--radius-xl); padding: var(--space-10); box-shadow: var(--shadow-card); max-width: 720px; margin: 0 auto; }
.calc-chips { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-5); }
.calc-chip { font-size: var(--text-md); font-weight: 600; color: var(--color-navy); border: 1px solid var(--color-mist); border-radius: var(--radius-pill); padding: 8px 18px; background: transparent; transition: all var(--transition-fast); }
.calc-chip:hover { border-color: var(--color-gold); }
.calc-chip.is-active { background: var(--color-gold); color: var(--color-cream); border-color: var(--color-gold); }
.calc-input-wrap { display: flex; gap: var(--space-3); align-items: center; margin-bottom: var(--space-6); }
.calc-input-wrap .cur { font-family: var(--font-display); font-size: var(--text-3xl); color: var(--color-gold); }
.calc-input-wrap input { font-family: var(--font-display); font-size: var(--text-4xl); font-weight: 700; color: var(--color-navy); border: 0; border-bottom: 2px solid var(--color-mist); width: 100%; padding: 8px 0; background: transparent; }
.calc-input-wrap input:focus { outline: none; border-bottom-color: var(--color-gold); }
.calc-output { background: var(--color-parchment); border-radius: var(--radius-lg); padding: var(--space-6); text-align: center; font-family: var(--font-display); font-size: var(--text-xl); color: var(--color-navy); line-height: var(--leading-quote); min-height: 90px; display: flex; align-items: center; justify-content: center; }
.allocation { display: flex; flex-direction: column; gap: var(--space-4); }
.alloc-row { display: grid; grid-template-columns: 1fr; gap: var(--space-2); }
.alloc-row .alloc-head { display: flex; justify-content: space-between; font-size: var(--text-base); }
.alloc-row .alloc-head strong { color: var(--color-navy); }
.alloc-bar { height: 10px; border-radius: 5px; background: var(--color-mist); overflow: hidden; }
.alloc-bar > span { display: block; height: 100%; border-radius: 5px; }
.payment-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); }
.payment-col { padding: var(--space-8); border-radius: var(--radius-lg); border: 1px solid var(--color-mist); background: var(--color-white); }
.payment-col__icon { width: 46px; height: 46px; border-radius: var(--radius-md); background: var(--color-parchment); color: var(--color-gold); display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-5); }
.payment-col__icon svg { width: 24px; height: 24px; }
.payment-col h3 { font-size: var(--text-lg); margin-bottom: var(--space-4); }
.payment-list { display: flex; flex-direction: column; gap: var(--space-3); }
.payment-list li { font-size: var(--text-base); color: var(--color-slate); padding-bottom: var(--space-3); border-bottom: 1px solid var(--color-mist); }
.payment-list li:last-child { border-bottom: 0; }
.payment-list strong { color: var(--color-navy); display: block; font-size: var(--text-sm); margin-bottom: 2px; }
.payment-list .mono { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: var(--text-sm); color: var(--color-teal); word-break: break-all; }
.trust-row { display: flex; flex-wrap: wrap; gap: var(--space-6); justify-content: center; margin-top: var(--space-8); color: var(--color-slate-light); font-size: var(--text-sm); }
.trust-row span { display: inline-flex; align-items: center; gap: var(--space-2); }
.trust-row svg { width: 18px; height: 18px; color: var(--color-aqqa); }

/* ── Accordion (FAQ) ────────────────────────────────────── */
.accordion { max-width: 820px; margin: 0 auto; }
.acc-item { border-bottom: 1px solid var(--color-mist); }
.acc-trigger { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); padding: var(--space-6) 0; text-align: left; background: transparent; border: 0; font-family: var(--font-display); font-size: var(--text-xl); color: var(--color-navy); }
.acc-trigger .acc-icon { flex-shrink: 0; width: 26px; height: 26px; position: relative; }
.acc-trigger .acc-icon::before, .acc-trigger .acc-icon::after { content: ""; position: absolute; background: var(--color-gold); border-radius: 2px; transition: transform var(--transition-base); }
.acc-trigger .acc-icon::before { top: 12px; left: 4px; right: 4px; height: 2px; }
.acc-trigger .acc-icon::after { left: 12px; top: 4px; bottom: 4px; width: 2px; }
.acc-item.is-open .acc-icon::after { transform: scaleY(0); }
.acc-panel { max-height: 0; overflow: hidden; transition: max-height var(--transition-slow); }
.acc-panel__inner { padding-bottom: var(--space-6); font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-body); max-width: 68ch; }

/* ── Contact routing cards ──────────────────────────────── */
.routing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.routing-card { padding: var(--space-6); border-radius: var(--radius-lg); background: var(--color-white); border: 1px solid var(--color-mist); border-left: 3px solid var(--color-gold); display: flex; flex-direction: column; gap: var(--space-3); }
.routing-card__icon { width: 42px; height: 42px; border-radius: var(--radius-md); background: var(--color-parchment); color: var(--color-gold); display: flex; align-items: center; justify-content: center; }
.routing-card__icon svg { width: 22px; height: 22px; }
.routing-card h3 { font-size: var(--text-md); font-family: var(--font-display); }
.routing-card p { font-size: var(--text-sm); color: var(--color-slate); line-height: var(--leading-normal); flex: 1; }
.routing-card .r-email { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: var(--text-sm); color: var(--color-teal); word-break: break-all; }
.routing-card .r-email:hover { color: var(--color-gold); }
.location-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
.location-card { padding: var(--space-6); border-radius: var(--radius-lg); background: var(--color-white); border: 1px solid var(--color-mist); display: flex; gap: var(--space-4); }
.location-card__icon { flex-shrink: 0; color: var(--color-gold); }
.location-card__icon svg { width: 22px; height: 22px; }
.location-card h3 { font-size: var(--text-md); font-family: var(--font-display); margin-bottom: var(--space-1); }
.location-card p { font-size: var(--text-sm); color: var(--color-slate); line-height: var(--leading-normal); }
.social-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.social-card { padding: var(--space-6); border-radius: var(--radius-lg); background: var(--color-white); border: 1px solid var(--color-mist); text-align: center; transition: all var(--transition-base); }
.social-card:hover { border-color: var(--color-gold); transform: translateY(-3px); box-shadow: var(--shadow-card); }
.social-card__icon { width: 48px; height: 48px; border-radius: 50%; background: var(--color-navy); color: var(--color-gold-light); display: flex; align-items: center; justify-content: center; margin: 0 auto var(--space-4); }
.social-card__icon svg { width: 24px; height: 24px; }
.social-card .handle { font-family: var(--font-display); font-size: var(--text-md); color: var(--color-navy); }
.social-card p { font-size: var(--text-xs); color: var(--color-slate-light); margin-top: var(--space-2); }

/* ── Three-way CTA ──────────────────────────────────────── */
.cta-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.cta-card { padding: var(--space-8); border-radius: var(--radius-xl); background: var(--color-white); border: 1px solid var(--color-mist); display: flex; flex-direction: column; gap: var(--space-4); text-align: center; align-items: center; }
.cta-card--give { border-top: 3px solid var(--color-gold); box-shadow: var(--shadow-card); }
.cta-card__icon { width: 56px; height: 56px; border-radius: 50%; background: var(--color-parchment); color: var(--color-gold); display: flex; align-items: center; justify-content: center; }
.cta-card__icon svg { width: 28px; height: 28px; }
.cta-card .verb { font-size: var(--text-xs); font-weight: 700; letter-spacing: var(--tracking-widest); text-transform: uppercase; color: var(--color-gold); }
.cta-card h3 { font-size: var(--text-xl); }
.cta-card p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); flex: 1; }
.cta-card .btn { margin-top: auto; }

/* ── Speaking ───────────────────────────────────────────── */
.reel-frame { position: relative; border: 2px solid var(--color-navy); border-radius: var(--radius-lg); padding: var(--space-2); background: var(--color-navy); }
.reel-frame__inner { aspect-ratio: 16/9; border-radius: var(--radius-md); overflow: hidden; position: relative; display: flex; align-items: center; justify-content: center; background: var(--color-navy-deep); }
.reel-frame__inner img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.5; }
.reel-frame__overlay { position: relative; z-index: 1; text-align: center; color: var(--color-cream); }
.reel-frame__play { width: 72px; height: 72px; border-radius: 50%; background: rgba(184,137,62,0.92); display: flex; align-items: center; justify-content: center; margin: 0 auto var(--space-4); }
.reel-frame__play svg { width: 30px; height: 30px; color: var(--color-cream); }
.talk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
.talk-card { padding: var(--space-8); border-radius: var(--radius-lg); background: var(--color-white); border: 1px solid var(--color-mist); border-top: 3px solid var(--color-gold); }
.talk-card .talk-meta { font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-gold); margin-bottom: var(--space-3); display: block; }
.talk-card h3 { font-size: var(--text-xl); margin-bottom: var(--space-3); }
.talk-card p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); }
.topic-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
.topic-card { display: flex; gap: var(--space-4); padding: var(--space-5); }
.topic-card__icon { flex-shrink: 0; width: 44px; height: 44px; border-radius: var(--radius-md); background: var(--color-navy); color: var(--color-gold-light); display: flex; align-items: center; justify-content: center; }
.topic-card__icon svg { width: 22px; height: 22px; }
.topic-card h3 { font-size: var(--text-md); font-family: var(--font-body); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-navy); margin-bottom: var(--space-1); }
.topic-card p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-10); }
.why-point .why-num { font-family: var(--font-display); font-weight: 700; font-size: var(--text-5xl); color: var(--color-gold); line-height: 1; }
.section-dark .why-point .why-num { color: var(--color-gold-light); }
.why-point h3 { font-size: var(--text-xl); margin: var(--space-3) 0 var(--space-2); }
.why-point p { font-size: var(--text-base); color: var(--color-slate); line-height: var(--leading-normal); }
.section-dark .why-point p { color: rgba(255,253,247,0.7); }
.events-list { display: flex; flex-direction: column; }
.event-row { display: grid; grid-template-columns: 1fr auto; gap: var(--space-4); padding: var(--space-5) 0; border-bottom: 1px solid var(--color-mist); align-items: baseline; }
.event-row .e-name { font-family: var(--font-display); font-size: var(--text-lg); color: var(--color-navy); }
.event-row .e-meta { font-size: var(--text-sm); color: var(--color-slate-light); }

/* About credentials split */
.cred-split { display: grid; grid-template-columns: 1fr 1px 1fr; gap: var(--space-12); }
.cred-split .divider-v { background: var(--color-gold); opacity: 0.4; }
.cred-col__head { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-6); }
.cred-col__head .ic { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--color-gold); color: var(--color-gold); display: flex; align-items: center; justify-content: center; }
.cred-col__head .ic svg { width: 22px; height: 22px; }
.cred-col__head h3 { font-size: var(--text-2xl); }
.cred-list li { padding: var(--space-4) var(--space-2); border-bottom: 1px solid var(--color-mist); font-size: var(--text-base); color: var(--color-slate); transition: background var(--transition-fast); border-radius: var(--radius-sm); }
.cred-list li:hover { background: var(--color-parchment); }
.cred-list strong { color: var(--color-navy); display: block; font-family: var(--font-display); font-size: var(--text-md); }

/* About narrative imagery */
.narrative-img { margin: var(--space-10) 0; }
.narrative-img figcaption { font-size: var(--text-sm); color: var(--color-gold-muted); margin-top: var(--space-3); font-style: italic; }
.dark-cta-band { background: var(--color-navy); color: var(--color-cream); text-align: center; }
.dark-cta-band .lead { color: rgba(255,253,247,0.8); max-width: 60ch; margin: 0 auto var(--space-8); }

/* Responsive overrides */
@media (max-width: 1080px) {
  .toc-layout { grid-template-columns: 1fr; gap: var(--space-8); }
  .toc { display: none; }
  .toc-mobile { display: block; position: sticky; top: calc(var(--header-h) + 8px); z-index: 40; margin-bottom: var(--space-8); }
  .toc-mobile select { width: 100%; padding: 14px 16px; border-radius: var(--radius-md); border: 1px solid var(--color-mist); background: var(--color-white); font-family: var(--font-body); font-size: var(--text-md); color: var(--color-navy); }
  .featured-essay { grid-template-columns: 1fr; }
  .featured-essay__media { min-height: 240px; }
  .featured-essay__body { padding: var(--space-8); }
}
@media (max-width: 860px) {
  .tier-cards, .post-grid, .audience-grid, .kpi-grid, .give-grid, .payment-cols, .routing-grid, .cta-cards, .talk-grid, .topic-grid, .why-grid, .pillar-grid, .social-grid { grid-template-columns: 1fr; }
  .legacy-row, .roadmap { grid-template-columns: 1fr; gap: var(--space-10); }
  .legacy-row::before, .roadmap::before { display: none; }
  .tier-block, .inst-band__grid, .report-cta, .cred-split { grid-template-columns: 1fr; gap: var(--space-8); }
  .tier-block:nth-child(even) .tier-block__media, .inst-band:nth-child(even) .inst-band__media { order: 0; }
  .cred-split .divider-v { display: none; }
  .kpi-grid { grid-template-columns: 1fr 1fr; }
  .compare-table, .compare-table thead, .compare-table tbody, .compare-table th, .compare-table td, .compare-table tr { display: block; }
  .compare-table thead { display: none; }
  .compare-table tr { margin-bottom: var(--space-6); border: 1px solid var(--color-mist); border-radius: var(--radius-lg); overflow: hidden; }
  .compare-table td { border-bottom: 1px solid var(--color-mist); }
  .compare-table td::before { content: attr(data-label); display: block; font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-gold); margin-bottom: 4px; }
  .metric-table, .metric-table thead, .metric-table tbody, .metric-table th, .metric-table td, .metric-table tr { display: block; }
  .metric-table thead { display: none; }
  .metric-table tr { margin-bottom: var(--space-5); border: 1px solid var(--color-mist); border-radius: var(--radius-lg); padding: var(--space-3); }
  .metric-table td { border-bottom: 1px solid var(--color-mist); }
  .metric-table td::before { content: attr(data-label) ": "; font-weight: 600; color: var(--color-navy); }
  .metric-table .target-2030 { border-left: 0; }
  .routing-grid, .social-grid, .location-grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .kpi-grid { grid-template-columns: 1fr; }
}
