/* ============================================
   HARESH AMBALIYA — PORTFOLIO
   Theme: Crisp White / Gold / Charcoal
   Responsive Edition — mobile-first breakpoints
   ============================================ */

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

/* ─── CSS VARIABLES ─────────────────────── */
:root {
  --bg:        #FFFFFF;
  --bg-2:      #F7F5F2;
  --bg-3:      #F0EDE8;
  --surface:   #E8E4DE;
  --border:    rgba(0,0,0,0.11);
  --gold:      #A67800;
  --gold-lt:   #C99B10;
  --gold-dim:  rgba(166,120,0,0.4);
  --text:      #0F0D0B;
  --text-2:    #2E2A26;
  --text-3:    #6B6055;
  --heading:   #0F0D0B;
  --speed:     0.38s;
  --radius:    3px;
}

/* ─── RESET ─────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:18px; }

body {
  font-family: 'Syne', sans-serif;
  background: var(--bg);
  color: var(--text-2);
  line-height: 1.78;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

a { color:inherit; text-decoration:none; transition:color var(--speed); }
a:hover { color:var(--gold); }
img { display:block; max-width:100%; }

h1,h2,h3,h4 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.025em;
  color: var(--heading);
}

/* ─── SECTION LABEL ─────────────────────── */
.section-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.88rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 3.2rem;
}
.section-label::before { content:''; width:44px; height:1px; background:var(--gold); flex-shrink:0; }
.section-label::after  { content:''; flex:1; height:1px; background:var(--border); }

/* ─── LAYOUT ────────────────────────────── */
.container { max-width:1300px; margin:0 auto; padding:0 6%; }
section    { padding:120px 0; }

/* ─── NOISE TEXTURE ─────────────────────── */
body::before {
  content:'';
  position:fixed; inset:0; pointer-events:none; z-index:9998; opacity:.15;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
}

/* ══════════════════════════════════════════
   NAVIGATION
══════════════════════════════════════════ */
#navbar {
  position:fixed; top:0; width:100%;
  padding:22px 6%;
  display:flex; justify-content:space-between; align-items:center;
  z-index:1000;
  transition:all .32s ease;
}
#navbar.scrolled {
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:14px 6%;
  border-bottom:1px solid var(--border);
  box-shadow:0 2px 24px rgba(0,0,0,.07);
}
.logo {
  font-family:'Cormorant Garamond',serif;
  font-size:1.85rem; font-weight:700; letter-spacing:-.05em;
  color:var(--heading);
  position:relative; z-index:10;
}
.logo span { color:var(--gold); }

/* desktop nav links */
.nav-links {
  display:flex; gap:34px; align-items:center;
  font-size:.82rem; font-weight:700; letter-spacing:.1em;
  text-transform:uppercase; color:var(--text-3);
}
.nav-links a:hover { color:var(--heading); }
.nav-cta {
  padding:10px 28px;
  border:1px solid var(--gold); border-radius:var(--radius);
  color:var(--gold) !important;
  font-size:.76rem; letter-spacing:.16em;
  transition:all .3s !important;
}
.nav-cta:hover { background:var(--gold) !important; color:#fff !important; }

/* hamburger button — hidden on desktop */
#menu-btn {
  display:none;
  background:none; border:none; cursor:pointer;
  font-size:1.3rem; color:var(--heading);
  padding:6px; z-index:10;
  transition:color var(--speed);
}
#menu-btn:hover { color:var(--gold); }

/* mobile menu drawer */
#mobile-menu {
  display:none;
  position:fixed;
  top:0; left:0; right:0;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  padding:90px 7% 48px;
  border-bottom:2px solid var(--gold);
  z-index:999;
  flex-direction:column;
  gap:0;
  transform:translateY(-100%);
  transition:transform .36s cubic-bezier(.4,0,.2,1);
  box-shadow:0 8px 40px rgba(0,0,0,.1);
}
#mobile-menu.open {
  display:flex;
  transform:translateY(0);
}
#mobile-menu a {
  font-family:'Syne',sans-serif;
  font-size:1.1rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-2);
  padding:18px 0;
  border-bottom:1px solid var(--border);
  display:block;
  transition:color var(--speed);
}
#mobile-menu a:last-child { border-bottom:none; }
#mobile-menu a:hover { color:var(--gold); }
#mobile-menu .mob-cta {
  margin-top:28px; padding:16px 0;
  background:var(--gold); color:#fff !important;
  text-align:center; border-radius:var(--radius);
  border:none; display:block;
}

/* ─── BUTTONS ───────────────────────────── */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 38px;
  background:var(--gold); color:#fff;
  font-size:.84rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase;
  border-radius:var(--radius); transition:all .3s ease;
  white-space:nowrap;
}
.btn-primary:hover { background:var(--gold-lt); color:#fff; transform:translateY(-2px); }

.btn-ghost {
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 38px;
  border:1.5px solid rgba(0,0,0,0.25); color:var(--text-2);
  font-size:.84rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase;
  border-radius:var(--radius); transition:all .3s ease;
  white-space:nowrap;
}
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); }

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
#hero {
  position:relative; width:100%; min-height:100vh;
  display:flex; align-items:flex-end;
  overflow:hidden;
  border-bottom:1px solid var(--border);
}
.hero-bg-img { position:absolute; inset:0; z-index:0; }
.hero-bg-img img {
  width:100%; height:100%;
  object-fit:cover; object-position:center top; display:block;
}
.hero-bg-img::after {
  content:''; position:absolute; inset:0;
  background:
    linear-gradient(to right,
      rgba(255,255,255,.97) 0%, rgba(255,255,255,.84) 36%,
      rgba(255,255,255,.30) 62%, rgba(255,255,255,.04) 100%),
    linear-gradient(to bottom,
      rgba(255,255,255,.65) 0%, transparent 28%,
      transparent 66%, rgba(255,255,255,.90) 100%);
}
.hero-content {
  position:relative; z-index:2; width:100%;
  padding-top:148px; padding-bottom:92px;
}
.hero-inner { max-width:680px; }

.hero-badges { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:28px; }
.badge {
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  padding:8px 18px;
  border:1.5px solid rgba(166,120,0,0.45);
  color:var(--gold); border-radius:2px;
  background:rgba(255,255,255,.80);
  backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  font-weight:700;
}
.hero-inner h1 {
  font-size:clamp(3.6rem,6.8vw,7.2rem);
  font-weight:700; line-height:.92; margin-bottom:22px;
  color:var(--heading);
}
.hero-inner h1 em { font-style:italic; color:var(--gold); }
.hero-tagline {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.15rem,1.85vw,1.55rem);
  font-weight:400; font-style:italic;
  color:#1E1B18; line-height:1.58;
  margin-bottom:44px; max-width:560px;
}
.hero-stats { display:flex; flex-wrap:wrap; gap:36px 52px; margin-bottom:48px; }
.hero-stat-val {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.1rem,3.4vw,3rem);
  font-weight:700; color:var(--heading); line-height:1; margin-bottom:5px;
}
.hero-stat-label {
  font-size:.76rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-3); font-weight:700;
}
.hero-actions { display:flex; gap:14px; align-items:center; flex-wrap:wrap; }

/* ══════════════════════════════════════════
   MANIFESTO
══════════════════════════════════════════ */
#manifesto { background:var(--bg-2); border-bottom:1px solid var(--border); }
.manifesto-body {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.65rem,2.7vw,2.65rem);
  font-weight:500; line-height:1.62;
  color:var(--heading); max-width:1040px;
}

/* ══════════════════════════════════════════
   THOUGHT LEADERSHIP
══════════════════════════════════════════ */
#thought-leadership { border-bottom:1px solid var(--border); }
.tl-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--border); border:1px solid var(--border);
}
.tl-card {
  background:var(--bg); padding:56px 46px;
  position:relative; overflow:hidden;
  transition:background var(--speed);
}
.tl-card::before {
  content:''; position:absolute; top:0; left:0;
  width:100%; height:3px; background:var(--gold);
  transform:scaleX(0); transform-origin:left; transition:transform .4s ease;
}
.tl-card:hover { background:var(--surface); }
.tl-card:hover::before { transform:scaleX(1); }
.tl-number {
  font-family:'Cormorant Garamond',serif;
  font-size:4.2rem; font-weight:300;
  color:rgba(0,0,0,.08); line-height:1; margin-bottom:26px;
  transition:color var(--speed);
}
.tl-card:hover .tl-number { color:rgba(166,120,0,.2); }
.tl-card h4 { font-size:1.6rem; margin-bottom:16px; color:var(--heading); }
.tl-card p  { color:var(--text-2); font-size:1.08rem; line-height:1.8; }

/* ══════════════════════════════════════════
   VISION IMAGE
══════════════════════════════════════════ */
#vision-image {
  padding:0; position:relative;
  height:58vh; overflow:hidden;
  border-bottom:1px solid var(--border);
}
#vision-image img { width:100%; height:100%; object-fit:cover; filter:brightness(.50) saturate(.72); }
.vision-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,
    rgba(255,255,255,.88) 0%, rgba(255,255,255,0) 28%,
    rgba(255,255,255,0) 72%, rgba(255,255,255,.88) 100%);
  display:flex; align-items:center; justify-content:center;
}
.vision-quote { text-align:center; max-width:800px; padding:0 6%; }
.vision-quote blockquote {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.4rem,3vw,3.1rem);
  font-weight:400; font-style:italic;
  color:#fff; line-height:1.42;
  text-shadow:0 2px 18px rgba(0,0,0,.55);
}

/* ══════════════════════════════════════════
   ARTICLES
══════════════════════════════════════════ */
#articles { background:var(--bg-2); border-bottom:1px solid var(--border); }
.articles-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:1px; background:var(--border); border:1px solid var(--border);
}
.article-card {
  background:var(--bg-2); padding:56px 52px;
  display:flex; flex-direction:column; justify-content:space-between;
  gap:28px; min-height:320px;
  transition:background var(--speed);
}
.article-card:hover { background:var(--surface); }
.article-number {
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem; color:var(--text-3); letter-spacing:.1em;
  margin-bottom:10px; font-weight:700;
}
.article-card h4 {
  font-family:'Cormorant Garamond',serif;
  font-size:2rem; font-weight:700;
  color:var(--heading); line-height:1.22; margin-bottom:14px;
}
.article-card p { color:var(--text-2); font-size:1.08rem; line-height:1.8; }
.article-link {
  display:inline-flex; align-items:center; gap:10px;
  font-size:.78rem; font-weight:700;
  letter-spacing:.13em; text-transform:uppercase;
  color:var(--gold); transition:gap .3s ease; margin-top:auto;
}
.article-card:hover .article-link { gap:16px; }
.article-link svg { width:15px; height:15px; stroke:var(--gold); fill:none; stroke-width:2; }

/* ══════════════════════════════════════════
   EXPERTISE TABS
══════════════════════════════════════════ */
#expertise { border-bottom:1px solid var(--border); }
.tabs-nav {
  display:flex; flex-wrap:wrap; gap:0;
  border-bottom:1px solid var(--border); margin-bottom:0;
}
.tab-btn {
  font-family:'Syne',sans-serif;
  font-size:.82rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:22px 32px;
  background:transparent; color:var(--text-3);
  border:none; border-bottom:2px solid transparent;
  margin-bottom:-1px; cursor:pointer; transition:all .3s ease;
}
.tab-btn:hover { color:var(--text-2); }
.tab-btn.active { color:var(--gold); border-bottom-color:var(--gold); }
.tab-panels { position:relative; }
.tab-panel { display:none; padding:68px 0 0; animation:fadeIn .4s ease; }
.tab-panel.active { display:grid; grid-template-columns:1fr 1.2fr; gap:84px; align-items:start; }
@keyframes fadeIn { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.tab-panel-text h3 { font-size:clamp(2.1rem,3.8vw,3.5rem); margin-bottom:22px; color:var(--heading); }
.tab-panel-text p  { color:var(--text-2); font-size:1.12rem; line-height:1.84; margin-bottom:18px; }
.tab-panel-visual  { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.skill-pill {
  padding:16px 22px;
  border:1.5px solid var(--border); border-radius:2px;
  font-size:.92rem; color:var(--text-2); font-weight:700;
  background:var(--bg-3);
  display:flex; align-items:center; gap:10px;
  transition:all .3s ease;
}
.skill-pill:hover { border-color:var(--gold-dim); color:var(--gold); background:var(--surface); }
.skill-pill::before { content:''; width:7px; height:7px; border-radius:50%; background:var(--gold); flex-shrink:0; }

/* ══════════════════════════════════════════
   METRICS
══════════════════════════════════════════ */
#impact { background:var(--bg-3); border-bottom:1px solid var(--border); }
#impact > .container { padding-bottom:50px; }
.metrics-row {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; background:var(--border); border:1px solid var(--border);
}
.metric-item {
  background:var(--bg-3); padding:70px 40px;
  text-align:center; transition:background var(--speed);
}
.metric-item:hover { background:var(--surface); }
.metric-val {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3.4rem,5.5vw,6rem);
  font-weight:700; color:var(--heading); line-height:1;
  margin-bottom:14px;
  display:flex; align-items:center; justify-content:center;
}
.metric-cursor {
  display:inline-block; width:3px; height:.8em;
  background:var(--gold); margin-left:4px;
  animation:blink 1s step-end infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
.metric-label { font-size:.82rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-3); font-weight:700; }

/* ══════════════════════════════════════════
   SIGNATURE INITIATIVES
══════════════════════════════════════════ */
#initiatives { border-bottom:1px solid var(--border); }
.initiatives-layout {
  display:grid; grid-template-columns:1fr 1fr;
  gap:0; background:var(--border); border:1px solid var(--border);
  align-items:stretch;
}
.initiative-image-col { position:relative; overflow:hidden; min-height:0; }
.initiative-image-col img {
  width:100%; height:100%;
  object-fit:cover; object-position:center top; display:block;
  filter:brightness(.93) saturate(.95);
  transition:transform .55s ease, filter .4s ease;
}
.initiative-image-col:hover img { transform:scale(1.03); filter:brightness(1); }
.initiative-image-caption {
  position:absolute; bottom:0; left:0; right:0;
  padding:22px 28px;
  background:linear-gradient(to top, rgba(255,255,255,.92), transparent);
  font-family:'JetBrains Mono',monospace;
  font-size:.7rem; letter-spacing:.14em;
  color:var(--gold); text-transform:uppercase; font-weight:700;
}
.initiative-cards {
  display:grid; grid-template-rows:repeat(3,1fr);
  gap:0; background:var(--border);
}
.initiative-card {
  padding:42px 46px;
  background:var(--bg); border-bottom:1px solid var(--border);
  position:relative; transition:background var(--speed);
  display:flex; flex-direction:column; justify-content:center;
}
.initiative-card:last-child { border-bottom:none; }
.initiative-card::before {
  content:''; position:absolute; left:0; top:0;
  width:3px; height:0; background:var(--gold);
  transition:height .4s ease;
}
.initiative-card:hover { background:var(--surface); }
.initiative-card:hover::before { height:100%; }
.initiative-card h4 { font-size:1.5rem; margin-bottom:13px; color:var(--heading); padding-left:18px; }
.initiative-card p  { font-size:1.05rem; color:var(--text-2); line-height:1.78; padding-left:18px; }

/* ══════════════════════════════════════════
   EXPERIENCE / TIMELINE
══════════════════════════════════════════ */
#experience { background:var(--bg-2); border-bottom:1px solid var(--border); }
#experience .section-label { font-size:1rem; letter-spacing:.2em; margin-bottom:3.6rem; }
.timeline { position:relative; max-width:920px; padding-left:38px; }
.timeline::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:1px;
  background:linear-gradient(to bottom, var(--gold-dim), transparent);
}
.timeline-item { position:relative; margin-bottom:76px; }
.timeline-dot {
  position:absolute; left:-42px; top:8px;
  width:11px; height:11px; border-radius:50%;
  background:var(--bg-2); border:2px solid var(--gold);
  transition:all .3s ease;
}
.timeline-item:hover .timeline-dot { background:var(--gold); box-shadow:0 0 14px var(--gold-dim); }
.timeline-date {
  font-family:'JetBrains Mono',monospace;
  font-size:.76rem; letter-spacing:.16em;
  color:var(--gold); text-transform:uppercase; margin-bottom:10px; font-weight:700;
}
.timeline-item h3 { font-size:clamp(2rem,3vw,2.8rem); margin-bottom:6px; color:var(--heading); }
.timeline-item h4 {
  font-family:'Syne',sans-serif;
  font-size:1.05rem; font-weight:600;
  color:var(--text-2); margin-bottom:22px; letter-spacing:.03em;
}
.timeline-item ul { list-style:none; }
.timeline-item li {
  position:relative; padding-left:22px;
  margin-bottom:10px;
  font-size:1.06rem; color:var(--text-2); line-height:1.75;
}
.timeline-item li::before { content:'—'; position:absolute; left:0; color:var(--text-3); }

/* ══════════════════════════════════════════
   CREDENTIALS
══════════════════════════════════════════ */
#credentials { border-bottom:1px solid var(--border); }
.creds-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--border); border:1px solid var(--border);
}
.cred-card { background:var(--bg); padding:52px 46px; transition:background var(--speed); }
.cred-card:hover { background:var(--surface); }
.cred-card-title {
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); font-weight:700;
  margin-bottom:28px; padding-bottom:16px; border-bottom:1px solid var(--border);
}
.cred-item {
  display:flex; align-items:flex-start; gap:14px;
  padding:14px 0; border-bottom:1px solid var(--border);
}
.cred-item:last-child { border-bottom:none; }
.cred-check {
  width:19px; height:19px; border-radius:50%;
  background:rgba(166,120,0,.1); border:1.5px solid var(--gold-dim);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; margin-top:2px;
}
.cred-check::after { content:'✓'; font-size:.65rem; color:var(--gold); line-height:1; font-weight:700; }
.cred-item p { font-size:1.02rem; color:var(--text-2); font-weight:500; }
.edu-block { margin-bottom:28px; }
.edu-block:last-child { margin-bottom:0; }
.edu-year   { font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--text-3); letter-spacing:.1em; margin-bottom:5px; font-weight:700; }
.edu-degree { font-size:1.15rem; color:var(--heading); font-weight:700; margin-bottom:4px; font-family:'Cormorant Garamond',serif; }
.edu-school { font-size:1rem; color:var(--text-2); }

/* ══════════════════════════════════════════
   LANDSCAPE DIVIDER
══════════════════════════════════════════ */
#reflections {
  padding:0; position:relative;
  height:44vh; overflow:hidden;
  border-bottom:1px solid var(--border);
}
#reflections img { width:100%; height:100%; object-fit:cover; filter:brightness(.5) saturate(.6); }
.reflections-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,
    rgba(255,255,255,.90) 0%, rgba(255,255,255,0) 24%,
    rgba(255,255,255,0) 76%, rgba(255,255,255,.90) 100%);
  display:flex; align-items:center; justify-content:center;
}
.reflections-text {
  text-align:center;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.1rem,2.4vw,2.2rem);
  font-style:italic; font-weight:500;
  color:#fff; max-width:640px; line-height:1.55; padding:0 6%;
  text-shadow:0 2px 18px rgba(0,0,0,.5);
}

/* ══════════════════════════════════════════
   CONTACT / FOOTER
══════════════════════════════════════════ */
#contact { padding:120px 6% 64px; background:var(--bg-2); text-align:center; }
.contact-super {
  font-family:'JetBrains Mono',monospace;
  font-size:.8rem; letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold); margin-bottom:28px; font-weight:700;
}
.contact-headline {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.4rem,7vw,8.5rem);
  font-weight:700; letter-spacing:-.045em;
  color:var(--heading); line-height:.9;
  margin-bottom:48px; display:block;
  transition:color .3s;
}
.contact-headline:hover { color:var(--gold); }
.contact-meta { font-size:1.05rem; color:var(--text-2); margin-bottom:60px; line-height:2.1; }
.social-row { display:flex; gap:14px; justify-content:center; margin-bottom:80px; flex-wrap:wrap; }
.social-btn {
  display:flex; align-items:center; justify-content:center;
  width:54px; height:54px;
  border:1.5px solid rgba(0,0,0,.15); border-radius:2px;
  color:var(--text-2); font-size:1.2rem;
  transition:all .3s ease;
}
.social-btn:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-3px); }
.footer-bar {
  padding-top:32px; border-top:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center;
  font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--text-3); font-weight:600;
}

/* ─── SCROLL REVEAL ─────────────────────── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .82s ease, transform .82s cubic-bezier(.2,.8,.2,1); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ─── SCROLLBAR ─────────────────────────── */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:rgba(0,0,0,.18); border-radius:2px; }
::-webkit-scrollbar-thumb:hover { background:var(--gold); }


/* ══════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   Large tablet  →  max-width: 1140px
   Tablet        →  max-width: 1024px
   Phablet       →  max-width: 768px
   Mobile        →  max-width: 480px
   Small mobile  →  max-width: 360px
══════════════════════════════════════════════════════════ */

/* ── 1140px: Initiatives stack ──────────── */
@media (max-width:1140px) {
  .initiatives-layout {
    grid-template-columns:1fr;
  }
  .initiative-image-col {
    min-height:380px;
    aspect-ratio:16/9;
  }
  .initiative-cards {
    grid-template-rows:auto auto auto;
  }
}

/* ── 1024px: Major grid collapses ────────── */
@media (max-width:1024px) {
  section { padding:90px 0; }

  /* Thought Leadership */
  .tl-grid { grid-template-columns:1fr; }
  .tl-card { padding:44px 36px; }

  /* Credentials */
  .creds-grid { grid-template-columns:1fr; }
  .cred-card { padding:40px 36px; }

  /* Tab panels */
  .tab-panel.active { grid-template-columns:1fr; gap:40px; }
  .tab-panel { padding:50px 0 0; }

  /* Metrics */
  .metrics-row { grid-template-columns:repeat(2,1fr); }
  .metric-item { padding:56px 32px; }

  /* Articles */
  .articles-grid { grid-template-columns:1fr; }
  .article-card { padding:44px 40px; min-height:auto; }

  /* Footer */
  .footer-bar { flex-direction:column; gap:12px; text-align:center; }

  /* Hero */
  .hero-inner { max-width:90%; }
}

/* ── 768px: Mobile — hamburger nav, stacked layout ── */
@media (max-width:768px) {
  html { font-size:16px; }
  section { padding:72px 0; }
  .container { padding:0 5%; }

  /* NAV: hide desktop links, show hamburger */
  .nav-links { display:none; }
  #menu-btn  { display:flex; align-items:center; justify-content:center; }

  /* HERO */
  #hero { align-items:flex-start; min-height:100svh; }
  .hero-bg-img::after {
    background:
      linear-gradient(to bottom,
        rgba(255,255,255,.97) 0%,
        rgba(255,255,255,.88) 50%,
        rgba(255,255,255,.82) 100%),
      linear-gradient(to right,
        rgba(255,255,255,.98) 0%, rgba(255,255,255,.40) 100%);
  }
  .hero-bg-img img { object-position:75% top; }
  .hero-content { padding-top:110px; padding-bottom:64px; }
  .hero-inner { max-width:100%; }

  .hero-badges { gap:8px; margin-bottom:22px; }
  .badge { font-size:.65rem; padding:6px 14px; }

  .hero-inner h1 { font-size:clamp(2.8rem,11vw,4.5rem); margin-bottom:18px; }

  .hero-tagline {
    font-size:clamp(1rem,4vw,1.3rem);
    margin-bottom:32px; max-width:100%;
  }

  .hero-stats { gap:22px 36px; margin-bottom:36px; }
  .hero-stat-val { font-size:clamp(1.8rem,6vw,2.4rem); }
  .hero-stat-label { font-size:.68rem; }

  .hero-actions { flex-direction:column; gap:12px; width:100%; }
  .btn-primary, .btn-ghost {
    width:100%; justify-content:center;
    padding:15px 24px; font-size:.8rem;
  }

  /* MANIFESTO */
  #manifesto { padding:64px 0; }
  .manifesto-body { font-size:clamp(1.25rem,4.5vw,1.7rem); line-height:1.55; }

  /* SECTION LABEL */
  .section-label { font-size:.76rem; margin-bottom:2.2rem; }

  /* THOUGHT LEADERSHIP */
  .tl-card { padding:36px 28px; }
  .tl-number { font-size:3rem; margin-bottom:18px; }
  .tl-card h4 { font-size:1.35rem; }
  .tl-card p  { font-size:1rem; }

  /* VISION IMAGE */
  #vision-image { height:38vh; }
  .vision-quote blockquote { font-size:clamp(1.1rem,4vw,1.6rem); }

  /* ARTICLES */
  .article-card { padding:36px 28px; }
  .article-card h4 { font-size:1.6rem; }
  .article-card p  { font-size:1rem; }

  /* TABS */
  .tabs-nav {
    overflow-x:auto; flex-wrap:nowrap;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .tabs-nav::-webkit-scrollbar { display:none; }
  .tab-btn { white-space:nowrap; padding:16px 20px; font-size:.76rem; }
  .tab-panel { padding:40px 0 0; }
  .tab-panel-text h3 { font-size:clamp(1.7rem,5vw,2.4rem); }
  .tab-panel-text p  { font-size:1rem; }
  .tab-panel-visual  { grid-template-columns:1fr 1fr; gap:10px; }
  .skill-pill { padding:12px 14px; font-size:.82rem; }

  /* METRICS */
  .metrics-row { grid-template-columns:1fr 1fr; }
  .metric-item { padding:44px 20px; }
  .metric-val  { font-size:clamp(2.6rem,9vw,4rem); }
  .metric-label{ font-size:.72rem; letter-spacing:.12em; }

  /* INITIATIVES */
  .initiative-image-col { min-height:280px; aspect-ratio:4/3; }
  .initiative-card { padding:32px 28px; }
  .initiative-card h4 { font-size:1.3rem; padding-left:14px; }
  .initiative-card p  { font-size:.98rem; padding-left:14px; }

  /* TIMELINE */
  .timeline { padding-left:26px; }
  .timeline-dot { left:-30px; width:10px; height:10px; }
  .timeline-item { margin-bottom:56px; }
  .timeline-item h3 { font-size:clamp(1.5rem,5vw,2rem); }
  .timeline-item h4 { font-size:.95rem; margin-bottom:16px; }
  .timeline-item li { font-size:.98rem; }
  .timeline-date { font-size:.68rem; }

  /* CREDENTIALS */
  .cred-card { padding:32px 28px; }
  .cred-item p { font-size:.96rem; }

  /* REFLECTIONS */
  #reflections { height:32vh; }

  /* CONTACT */
  #contact { padding:72px 5% 48px; }
  .contact-headline { font-size:clamp(2rem,10vw,4.5rem); margin-bottom:32px; }
  .contact-meta { font-size:.95rem; }

  /* FOOTER BAR */
  .footer-bar { font-size:.7rem; gap:10px; }
}

/* ── 480px: Small phones ─────────────────── */
@media (max-width:480px) {
  html { font-size:15px; }
  section { padding:60px 0; }
  .container { padding:0 4.5%; }

  /* HERO */
  .hero-content { padding-top:100px; padding-bottom:52px; }
  .hero-inner h1 { font-size:clamp(2.4rem,12vw,3.6rem); line-height:.95; }
  .hero-tagline { font-size:clamp(.95rem,4.5vw,1.2rem); margin-bottom:28px; }
  .hero-stats { gap:20px 28px; margin-bottom:30px; }
  .hero-stat-val { font-size:clamp(1.6rem,7vw,2.1rem); }
  .badge { font-size:.6rem; padding:6px 12px; }

  /* MANIFESTO */
  .manifesto-body { font-size:clamp(1.15rem,5vw,1.5rem); }

  /* SECTION LABEL */
  .section-label { font-size:.7rem; gap:12px; letter-spacing:.16em; margin-bottom:1.8rem; }
  .section-label::before { width:28px; }

  /* THOUGHT LEADERSHIP */
  .tl-card { padding:30px 22px; }
  .tl-number { font-size:2.5rem; }
  .tl-card h4 { font-size:1.25rem; }

  /* ARTICLES */
  .article-card { padding:30px 22px; }
  .article-card h4 { font-size:1.45rem; }

  /* TABS */
  .tab-btn { padding:14px 16px; font-size:.72rem; }
  .tab-panel-visual { grid-template-columns:1fr; }
  .skill-pill { padding:12px 14px; font-size:.8rem; }

  /* METRICS */
  .metrics-row { grid-template-columns:1fr 1fr; }
  .metric-item { padding:36px 14px; }
  .metric-val  { font-size:clamp(2.2rem,10vw,3.2rem); }
  .metric-label { font-size:.65rem; letter-spacing:.1em; }

  /* INITIATIVES */
  .initiative-image-col { min-height:220px; }
  .initiative-card { padding:26px 22px; }
  .initiative-card h4 { font-size:1.2rem; padding-left:12px; }
  .initiative-card p  { font-size:.93rem; padding-left:12px; }

  /* TIMELINE */
  .timeline { padding-left:22px; }
  .timeline-dot { left:-26px; }
  .timeline-item h3 { font-size:clamp(1.35rem,6vw,1.8rem); }
  .timeline-item h4 { font-size:.9rem; }

  /* CREDENTIALS */
  .cred-card { padding:28px 20px; }

  /* VISION IMAGE */
  #vision-image { height:30vh; }
  .vision-quote blockquote { font-size:clamp(1rem,4.5vw,1.4rem); }

  /* CONTACT */
  #contact { padding:60px 4.5% 40px; }
  .contact-headline { font-size:clamp(1.8rem,11vw,3.5rem); margin-bottom:28px; }
  .social-btn { width:48px; height:48px; }

  /* FOOTER */
  .footer-bar { font-size:.62rem; }
}

/* ── 360px: Very small phones ────────────── */
@media (max-width:360px) {
  html { font-size:14px; }
  .container { padding:0 4%; }

  .hero-inner h1 { font-size:clamp(2.1rem,13vw,3rem); }
  .badge { font-size:.58rem; padding:5px 10px; }

  .metrics-row { grid-template-columns:1fr 1fr; }
  .metric-val  { font-size:clamp(1.9rem,10vw,2.6rem); }

  .hero-actions { gap:10px; }
  .btn-primary, .btn-ghost { font-size:.76rem; padding:13px 20px; }

  .tabs-nav { gap:0; }
  .tab-btn  { padding:12px 14px; font-size:.68rem; }
}
