/*
Theme Name: Wanjiru Portfolio
Theme URI: #
Author: Demo Portfolio
Description: A warm, editorial-style creative portfolio for Kenyan professionals. Bold typography, rich color, fully editable via Customizer.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: wanjiru-portfolio
Tags: portfolio, creative, editorial, warm, kenya
*/

/* ─────────────────────────────────────────
   TOKENS
───────────────────────────────────────── */
:root {
  --cream:   #f5f0e8;
  --cream-2: #ede7d9;
  --cream-3: #e4dccf;
  --ink:     #1a1a14;
  --ink-2:   #2e2e22;
  --ink-3:   #4a4a38;
  --forest:  #1e4d35;
  --forest-2:#2a6347;
  --ember:   #c95f2a;
  --ember-2: #e07040;
  --gold:    #c9a227;
  --mist:    #8a9e8d;
  --white:   #ffffff;

  --font-serif:  'Playfair Display', 'Georgia', serif;
  --font-sans:   'Outfit', 'Trebuchet MS', sans-serif;
  --font-mono:   'IBM Plex Mono', 'Courier New', monospace;

  --r:       6px;
  --ease:    cubic-bezier(.4,0,.2,1);
  --t:       0.35s var(--ease);
  --shadow:  0 4px 24px rgba(26,26,20,0.12);
  --shadow-lg: 0 12px 48px rgba(26,26,20,0.18);
}

/* ─────────────────────────────────────────
   RESET
───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-sans);
  line-height:1.75;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;transition:var(--t)}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
::selection{background:var(--forest);color:var(--cream)}

/* scrollbar */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--cream-2)}
::-webkit-scrollbar-thumb{background:var(--forest);border-radius:3px}

/* ─────────────────────────────────────────
   TYPOGRAPHY
───────────────────────────────────────── */
.label{
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--ember);
  display:inline-flex;align-items:center;gap:.6rem;
}
.label::before{content:'';width:28px;height:1px;background:var(--ember);flex-shrink:0}

.section-heading{
  font-family:var(--font-serif);
  font-size:clamp(2.4rem,5.5vw,4rem);
  font-weight:700;
  line-height:1.08;
  color:var(--ink);
}
.section-heading em{
  font-style:italic;
  color:var(--forest);
}

/* ─────────────────────────────────────────
   LAYOUT
───────────────────────────────────────── */
.wrap{max-width:1240px;margin:0 auto;padding:0 2.5rem}
section{padding:7rem 0;position:relative}

/* ─────────────────────────────────────────
   TEXTURE OVERLAY
───────────────────────────────────────── */
body::after{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;z-index:9000;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23g)' opacity='.035'/%3E%3C/svg%3E");
  opacity:.5;
}

/* ─────────────────────────────────────────
   NAV
───────────────────────────────────────── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:1.5rem 0;
  transition:var(--t);
}
#nav.stuck{
  background:rgba(245,240,232,.94);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(26,26,20,.08);
  padding:1rem 0;
  box-shadow:0 2px 16px rgba(26,26,20,.06);
}
#nav .wrap{display:flex;align-items:center;justify-content:space-between}

.nav-brand{
  font-family:var(--font-serif);
  font-size:1.35rem;
  font-weight:700;
  color:var(--ink);
  letter-spacing:-.01em;
}
.nav-brand span{color:var(--ember)}

.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{
  font-family:var(--font-sans);
  font-size:.82rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-3);
  font-weight:500;
  position:relative;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:-3px;
  width:0;height:1.5px;background:var(--ember);
  transition:width var(--t);
}
.nav-links a:hover{color:var(--ember)}
.nav-links a:hover::after{width:100%}

.nav-cta{
  background:var(--forest);
  color:var(--cream)!important;
  padding:.55rem 1.4rem;
  border-radius:100px;
  font-size:.8rem!important;
  font-weight:600!important;
  transition:var(--t);
}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--ember);color:var(--white)!important}

.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-burger span{display:block;width:22px;height:2px;background:var(--ink);transition:var(--t);border-radius:1px}

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
#hero{
  min-height:100vh;
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:0;
  padding:0;
  overflow:hidden;
}

.hero-left{
  padding:10rem 4rem 6rem 0;
  padding-left:calc((100vw - 1240px)/2 + 2.5rem);
  position:relative;
  z-index:1;
}

.hero-right{
  background:var(--forest);
  min-height:100vh;
  position:relative;
  overflow:hidden;
  display:flex;align-items:flex-end;
}

/* geometric pattern on hero right */
.hero-right::before{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg,rgba(245,240,232,.04) 0,rgba(245,240,232,.04) 1px,transparent 0,transparent 50%);
  background-size:24px 24px;
}
.hero-right::after{
  content:'';position:absolute;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,39,.15) 0%,transparent 70%);
  top:15%;right:-100px;
  pointer-events:none;
}

.hero-photo-area{
  position:relative;z-index:1;
  width:100%;
  padding:4rem 3rem 0;
  display:flex;flex-direction:column;gap:2rem;
  align-items:center;
}

.hero-photo-frame{
  width:300px;height:360px;
  border-radius:180px 180px 40px 40px;
  background:var(--cream-2);
  overflow:hidden;
  border:4px solid rgba(245,240,232,.15);
  position:relative;
}
.hero-photo-frame img{width:100%;height:100%;object-fit:cover}
.hero-photo-placeholder{
  width:100%;height:100%;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
}

.hero-photo-upload-hint{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:.75rem;
  color:rgba(245,240,232,.4);
  font-family:var(--font-mono);
  font-size:.65rem;letter-spacing:.08em;text-align:center;
  padding:1.5rem;
  width:100%;height:100%;
}
.hero-photo-upload-hint strong{
  color:rgba(245,240,232,.6);
  font-size:.75rem;font-weight:600;
}
.hero-photo-upload-hint em{
  font-style:normal;
  color:var(--gold);
}

.hero-photo-upload-link{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:.75rem;
  width:100%;height:100%;
  text-decoration:none;
  color:rgba(245,240,232,.5);
  font-family:var(--font-mono);
  font-size:.65rem;letter-spacing:.08em;text-align:center;
  padding:1.5rem;
  border:2px dashed rgba(245,240,232,.2);
  border-radius:176px 176px 36px 36px;
  transition:all .25s ease;
  cursor:pointer;
}
.hero-photo-upload-link:hover{
  color:rgba(245,240,232,.9);
  border-color:var(--gold);
  background:rgba(245,240,232,.05);
}
.hero-photo-upload-link strong{
  color:rgba(245,240,232,.8);
  font-size:.8rem;font-weight:600;
  transition:color .25s;
}
.hero-photo-upload-link:hover strong{ color:var(--gold); }
.hero-photo-upload-link span{
  font-size:.6rem;opacity:.6;
}

.hero-availability{
  display:inline-flex;align-items:center;gap:.6rem;
  background:rgba(245,240,232,.1);
  border:1px solid rgba(245,240,232,.2);
  padding:.5rem 1.2rem;
  border-radius:100px;
  color:rgba(245,240,232,.8);
  font-family:var(--font-mono);
  font-size:.7rem;letter-spacing:.1em;
}
.avail-dot{
  width:7px;height:7px;border-radius:50%;
  background:#4ade80;
  box-shadow:0 0 8px #4ade80;
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.hero-tag{
  position:absolute;
  background:var(--ember);
  color:var(--white);
  font-family:var(--font-mono);
  font-size:.68rem;
  letter-spacing:.1em;
  padding:.4rem 1rem;
  border-radius:100px;
}
.hero-tag-1{top:2.5rem;left:1rem;transform:rotate(-8deg)}
.hero-tag-2{top:4rem;right:.5rem;transform:rotate(6deg);background:var(--gold);color:var(--ink)}

.hero-eyebrow{margin-bottom:1.2rem}
.hero-name{
  font-family:var(--font-serif);
  font-size:clamp(3rem,6vw,5.5rem);
  font-weight:700;
  line-height:1.02;
  letter-spacing:-.02em;
  color:var(--ink);
  margin-bottom:.75rem;
}
.hero-name em{
  display:block;
  font-style:italic;
  color:var(--forest);
}
.hero-role{
  font-family:var(--font-sans);
  font-size:1.1rem;
  color:var(--ink-3);
  font-weight:500;
  margin-bottom:1.8rem;
}
.hero-bio{
  font-size:1rem;
  color:var(--ink-3);
  max-width:480px;
  margin-bottom:2.8rem;
  line-height:1.8;
}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3.5rem}

.btn-solid{
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--forest);color:var(--cream);
  padding:.9rem 2rem;border-radius:100px;
  font-family:var(--font-sans);font-size:.88rem;font-weight:600;
  letter-spacing:.02em;transition:var(--t);
}
.btn-solid:hover{background:var(--ember);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,95,42,.3)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:.6rem;
  border:1.5px solid var(--ink-3);color:var(--ink);
  padding:.9rem 2rem;border-radius:100px;
  font-family:var(--font-sans);font-size:.88rem;font-weight:600;
  transition:var(--t);
}
.btn-ghost:hover{border-color:var(--forest);color:var(--forest)}

.hero-counters{
  display:flex;gap:2.5rem;
  padding-top:2rem;
  border-top:1px solid var(--cream-3);
}
.counter-n{
  font-family:var(--font-serif);
  font-size:2.2rem;font-weight:700;
  color:var(--forest);line-height:1;
}
.counter-l{
  font-family:var(--font-mono);
  font-size:.68rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-3);
  margin-top:.25rem;
}

/* ─────────────────────────────────────────
   ABOUT
───────────────────────────────────────── */
#about{background:var(--white)}
#about .wrap{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:6rem;align-items:start;
}
.about-sidebar{}
.about-portrait{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  border-radius:12px 12px 80px 12px;
  margin-bottom:1.5rem;
}
.about-portrait-placeholder{
  width:100%;aspect-ratio:3/4;
  background:var(--cream);
  border-radius:12px 12px 80px 12px;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:1rem;
  color:var(--mist);
  font-family:var(--font-mono);font-size:.75rem;text-align:center;
  border:2px dashed var(--cream-3);
  margin-bottom:1.5rem;padding:2rem;
}
.about-facts{display:flex;flex-direction:column;gap:.75rem}
.fact-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:.75rem 0;border-bottom:1px solid var(--cream-2);
}
.fact-k{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--mist)}
.fact-v{font-size:.92rem;color:var(--ink);font-weight:500;text-align:right}

.about-body{}
.about-pull{
  font-family:var(--font-serif);
  font-size:clamp(1.3rem,2.5vw,1.7rem);
  font-weight:700;
  line-height:1.45;
  color:var(--ink);
  margin:1.5rem 0 1.5rem;
  padding-left:1.5rem;
  border-left:3px solid var(--ember);
}
.about-p{color:var(--ink-3);margin-bottom:1.2rem;font-size:1rem}
.about-values{
  display:grid;grid-template-columns:1fr 1fr;
  gap:.75rem;margin-top:2rem;
}
.value-chip{
  display:flex;align-items:center;gap:.7rem;
  background:var(--cream);
  padding:.85rem 1.1rem;border-radius:8px;
  border:1px solid var(--cream-3);
  transition:var(--t);
}
.value-chip:hover{border-color:var(--forest);background:var(--white)}
.value-chip-icon{font-size:1.2rem}
.value-chip-text{font-size:.88rem;font-weight:500;color:var(--ink-2)}

/* ─────────────────────────────────────────
   SKILLS
───────────────────────────────────────── */
#skills{background:var(--cream)}

.skills-intro{
  display:grid;grid-template-columns:1fr 2fr;
  gap:5rem;align-items:end;margin-bottom:4rem;
}
.skills-intro-copy{color:var(--ink-3);font-size:1rem;line-height:1.8;margin-top:1.2rem}

.skills-mosaic{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}
.skill-tile{
  background:var(--white);
  border:1px solid var(--cream-3);
  border-radius:12px;
  padding:1.75rem;
  transition:var(--t);
  position:relative;
  overflow:hidden;
}
.skill-tile::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--forest),var(--ember));
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--t);
}
.skill-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.skill-tile:hover::after{transform:scaleX(1)}

.skill-tile-icon{
  font-size:1.8rem;margin-bottom:1rem;
  width:48px;height:48px;
  background:var(--cream);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
}
.skill-tile-name{
  font-family:var(--font-serif);
  font-size:1.05rem;font-weight:700;
  color:var(--ink);margin-bottom:.6rem;
}
.skill-tile-items{
  display:flex;flex-wrap:wrap;gap:.4rem;
}
.stag{
  font-family:var(--font-mono);font-size:.68rem;
  letter-spacing:.04em;padding:.25rem .6rem;
  background:var(--cream);color:var(--ink-3);
  border-radius:4px;
  border:1px solid var(--cream-3);
}
/* featured tile */
.skill-tile.featured{
  background:var(--forest);border-color:var(--forest);
  grid-row:span 2;
}
.skill-tile.featured .skill-tile-name{color:var(--cream)}
.skill-tile.featured .skill-tile-icon{background:rgba(245,240,232,.12)}
.skill-tile.featured .stag{background:rgba(245,240,232,.1);color:rgba(245,240,232,.75);border-color:rgba(245,240,232,.1)}
.skill-tile.featured::after{display:none}
.skill-tile.featured:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(30,77,53,.35)}

/* ─────────────────────────────────────────
   EXPERIENCE
───────────────────────────────────────── */
#experience{background:var(--ink);color:var(--cream)}
#experience .label{color:var(--gold)}
#experience .label::before{background:var(--gold)}
#experience .section-heading{color:var(--cream)}
#experience .section-heading em{color:var(--ember-2)}

.exp-layout{
  display:grid;grid-template-columns:280px 1fr;
  gap:5rem;margin-top:3.5rem;
}
.exp-nav{position:sticky;top:7rem;align-self:start}
.exp-nav-item{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.25rem;
  border-radius:8px;
  cursor:pointer;
  transition:var(--t);
  margin-bottom:.5rem;
  border:1px solid transparent;
}
.exp-nav-item:hover{background:rgba(245,240,232,.06)}
.exp-nav-item.active{background:rgba(245,240,232,.08);border-color:rgba(245,240,232,.1)}
.exp-nav-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--mist);flex-shrink:0;transition:var(--t);
}
.exp-nav-item.active .exp-nav-dot{background:var(--ember)}
.exp-nav-co{font-weight:600;font-size:.9rem;color:rgba(245,240,232,.85)}
.exp-nav-yr{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;color:var(--mist)}

.exp-panels{}
.exp-panel{display:none;animation:panelIn .4s var(--ease)}
.exp-panel.active{display:block}
@keyframes panelIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.exp-header{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid rgba(245,240,232,.08)}
.exp-role{
  font-family:var(--font-serif);
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:700;color:var(--cream);
  margin-bottom:.4rem;
}
.exp-meta{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center}
.exp-co{
  display:inline-flex;align-items:center;gap:.5rem;
  color:var(--ember-2);font-weight:600;font-size:.95rem;
}
.exp-period{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em;color:var(--mist)}
.exp-type{
  display:inline-block;
  padding:.2rem .75rem;border-radius:100px;
  font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;
  background:rgba(201,162,39,.15);color:var(--gold);
  border:1px solid rgba(201,162,39,.2);
}

.exp-duties{margin-bottom:2rem}
.duty-item{
  display:flex;gap:1rem;padding:.9rem 0;
  border-bottom:1px solid rgba(245,240,232,.05);
}
.duty-item:last-child{border:none}
.duty-bullet{
  width:6px;height:6px;border-radius:50%;
  background:var(--ember);flex-shrink:0;margin-top:.55rem;
}
.duty-text{color:rgba(245,240,232,.75);font-size:.95rem;line-height:1.7}

.exp-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.exp-tag{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;
  padding:.3rem .75rem;border-radius:4px;
  background:rgba(245,240,232,.05);
  color:rgba(245,240,232,.5);
  border:1px solid rgba(245,240,232,.08);
}

/* ─────────────────────────────────────────
   ACHIEVEMENTS
───────────────────────────────────────── */
#achievements{background:var(--cream-2)}
.ach-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;margin-top:3.5rem;
}
.ach-card{
  background:var(--white);
  border-radius:12px;
  padding:2rem;
  border:1px solid var(--cream-3);
  transition:var(--t);
  position:relative;
  overflow:hidden;
}
.ach-card::before{
  content:attr(data-num);
  position:absolute;top:-10px;right:1rem;
  font-family:var(--font-serif);font-size:5rem;font-weight:700;
  color:var(--cream);line-height:1;pointer-events:none;
}
.ach-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.ach-icon{
  width:52px;height:52px;border-radius:10px;
  background:var(--forest);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:1.25rem;
}
.ach-stat{
  font-family:var(--font-serif);
  font-size:2.2rem;font-weight:700;
  color:var(--ember);line-height:1;
  margin-bottom:.4rem;
}
.ach-title{font-weight:700;font-size:1rem;color:var(--ink);margin-bottom:.5rem}
.ach-desc{font-size:.88rem;color:var(--ink-3);line-height:1.7}

/* ─────────────────────────────────────────
   EDUCATION & CERTS
───────────────────────────────────────── */
#education{background:var(--white)}
.edu-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;margin-top:3.5rem;
}
.edu-block-label{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.25em;
  text-transform:uppercase;color:var(--forest);
  margin-bottom:1.75rem;display:flex;align-items:center;gap:.75rem;
}
.edu-block-label::after{content:'';flex:1;height:1px;background:var(--cream-3)}

.edu-card{
  background:var(--cream);border-radius:12px;
  padding:1.75rem;margin-bottom:1rem;
  border:1px solid var(--cream-3);transition:var(--t);
}
.edu-card:hover{border-color:var(--forest);background:var(--white)}
.edu-deg{font-family:var(--font-serif);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:.3rem}
.edu-school{font-size:.88rem;color:var(--forest);font-weight:600;margin-bottom:.2rem}
.edu-yr{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;color:var(--mist)}

.cert-row{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.25rem;
  background:var(--cream);border-radius:8px;
  border:1px solid var(--cream-3);
  margin-bottom:.6rem;transition:var(--t);
}
.cert-row:hover{border-color:var(--ember);background:var(--white)}
.cert-badge{
  width:36px;height:36px;border-radius:6px;
  background:var(--ember);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;flex-shrink:0;
}
.cert-name{font-size:.9rem;font-weight:600;color:var(--ink);flex:1}
.cert-org{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;color:var(--mist);margin-top:.15rem}

/* ─────────────────────────────────────────
   CONTACT
───────────────────────────────────────── */
#contact{
  background:var(--forest);
  color:var(--cream);overflow:hidden;
}
#contact::before{
  content:'';position:absolute;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,95,42,.2) 0%,transparent 65%);
  right:-200px;top:-200px;pointer-events:none;
}
#contact .label{color:var(--gold)}
#contact .label::before{background:var(--gold)}
#contact .section-heading{color:var(--cream)}
#contact .section-heading em{color:var(--ember-2)}

.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;margin-top:3.5rem;align-items:start;
}
.contact-lead{
  font-size:1.05rem;color:rgba(245,240,232,.7);
  line-height:1.85;margin-bottom:2.5rem;
}
.contact-cards{display:flex;flex-direction:column;gap:1rem}
.contact-card{
  display:flex;align-items:center;gap:1.25rem;
  padding:1.25rem 1.5rem;
  background:rgba(245,240,232,.06);
  border:1px solid rgba(245,240,232,.1);
  border-radius:10px;transition:var(--t);
}
.contact-card:hover{background:rgba(245,240,232,.1);border-color:rgba(245,240,232,.2);transform:translateX(4px)}
.contact-icon{
  width:44px;height:44px;border-radius:8px;
  background:rgba(201,95,42,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.contact-lbl{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;color:rgba(245,240,232,.4);text-transform:uppercase}
.contact-val{font-size:.95rem;color:rgba(245,240,232,.85);font-weight:500;margin-top:.1rem}

.contact-form-side{}
.form-group{margin-bottom:1.25rem}
.form-group label{
  display:block;font-family:var(--font-mono);font-size:.7rem;
  letter-spacing:.15em;text-transform:uppercase;
  color:rgba(245,240,232,.5);margin-bottom:.5rem;
}
.form-group input,
.form-group textarea{
  width:100%;
  background:rgba(245,240,232,.06);
  border:1px solid rgba(245,240,232,.12);
  border-radius:8px;
  padding:.9rem 1.1rem;
  color:var(--cream);
  font-family:var(--font-sans);font-size:.95rem;
  outline:none;transition:var(--t);
  resize:vertical;
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:rgba(245,240,232,.25)}
.form-group input:focus,
.form-group textarea:focus{border-color:var(--ember);background:rgba(245,240,232,.08)}
.form-group textarea{min-height:120px}
.form-submit{
  width:100%;padding:1rem;
  background:var(--ember);color:var(--white);
  border:none;border-radius:100px;
  font-family:var(--font-sans);font-size:.95rem;font-weight:700;
  cursor:pointer;transition:var(--t);letter-spacing:.02em;
}
.form-submit:hover{background:var(--ember-2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,95,42,.4)}

/* ─────────────────────────────────────────
   REFERENCES
───────────────────────────────────────── */
#references{background:var(--cream-2)}
.ref-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5rem;margin-top:3.5rem;
}
.ref-card{
  background:var(--white);border-radius:12px;
  padding:2rem;border:1px solid var(--cream-3);
  transition:var(--t);
}
.ref-card:hover{border-color:var(--forest);transform:translateY(-3px);box-shadow:var(--shadow)}
.ref-initials{
  width:56px;height:56px;border-radius:12px;
  background:var(--forest);color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif);font-size:1.3rem;font-weight:700;
  margin-bottom:1.25rem;
}
.ref-name{font-family:var(--font-serif);font-size:1.15rem;font-weight:700;color:var(--ink);margin-bottom:.25rem}
.ref-title{font-size:.85rem;color:var(--forest);font-weight:600;margin-bottom:1rem}
.ref-contacts{display:flex;flex-direction:column;gap:.4rem}
.ref-contacts a{font-size:.85rem;color:var(--ink-3);display:flex;align-items:center;gap:.5rem;transition:var(--t)}
.ref-contacts a:hover{color:var(--ember)}

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
#footer{
  background:var(--ink-2);
  padding:2.5rem 0;
}
#footer .wrap{display:flex;align-items:center;justify-content:space-between}
.footer-brand{font-family:var(--font-serif);font-size:1.1rem;font-weight:700;color:var(--cream)}
.footer-brand span{color:var(--ember)}
.footer-copy{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;color:var(--mist)}
.footer-top{
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--mist);
  display:flex;align-items:center;gap:.5rem;transition:var(--t);
}
.footer-top:hover{color:var(--ember)}

/* ─────────────────────────────────────────
   ANIMATIONS
───────────────────────────────────────── */
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.h-a1{animation:heroIn .8s .1s both}
.h-a2{animation:heroIn .8s .25s both}
.h-a3{animation:heroIn .8s .4s both}
.h-a4{animation:heroIn .8s .55s both}
.h-a5{animation:heroIn .8s .7s both}
.h-a6{animation:heroIn .8s .85s both}

/* scroll reveal */
.reveal{opacity:1;transform:none}
.js-on .reveal{opacity:0;transform:translateY(32px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.js-on .reveal.in{opacity:1;transform:translateY(0)}

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media(max-width:1024px){
  #hero{grid-template-columns:1fr}
  .hero-left{padding:9rem 2.5rem 4rem;padding-left:2.5rem}
  .hero-right{min-height:400px;align-items:center;justify-content:center}
  .skills-mosaic{grid-template-columns:repeat(2,1fr)}
  .skill-tile.featured{grid-row:auto}
  .exp-layout{grid-template-columns:1fr;gap:2rem}
  .exp-nav{position:static;display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem}
  .exp-nav-item{flex-shrink:0}
}
@media(max-width:768px){
  section{padding:4rem 0}
  .wrap{padding:0 1.5rem}
  #about .wrap,
  .skills-intro,
  .edu-layout,
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  .ach-grid,.ref-grid{grid-template-columns:1fr}
  .skills-mosaic{grid-template-columns:1fr}
  .about-values{grid-template-columns:1fr}
  .hero-counters{gap:1.5rem}
  .nav-links{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:fixed;inset:0;background:var(--cream);
    z-index:400;align-items:center;justify-content:center;gap:2.5rem;
  }
  .nav-links.open a{font-size:1.1rem}
  .nav-burger{display:flex}
  #footer .wrap{flex-direction:column;gap:1rem;text-align:center}
}
