/*
Theme Name: Amos Makori Portfolio v2
Theme URI: #
Author: Amos Makori Maengwe
Author URI: mailto:amos4makori@gmail.com
Description: A bold, electric-terminal style IT portfolio. Every section is editable via the WordPress Customizer. Built for ICT professionals who want to stand out.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: amos-v2
Tags: portfolio, dark, terminal, IT, cybersecurity, creative
*/

/* ────────────────────────────────────────────
   DESIGN TOKENS
──────────────────────────────────────────── */
:root {
  /* Palette */
  --bg:        #0d0d12;
  --bg2:       #121218;
  --bg3:       #181820;
  --bg4:       #1e1e28;
  --card:      #14141c;
  --border:    rgba(139,92,246,0.12);
  --border-hi: rgba(139,92,246,0.4);

  --violet:    #8b5cf6;
  --violet-2:  #a78bfa;
  --violet-3:  #c4b5fd;
  --electric:  #38bdf8;
  --neon:      #34d399;
  --warn:      #fb923c;
  --danger:    #f43f5e;

  --text:      #e2e2f0;
  --text-2:    #9494b0;
  --text-3:    #5a5a78;

  /* Typography */
  --display:  'Barlow Condensed', 'Arial Narrow', sans-serif;
  --mono:     'JetBrains Mono', 'Fira Code', 'Courier New', monospace;
  --body:     'Syne', 'Trebuchet MS', sans-serif;

  /* Misc */
  --ease:     cubic-bezier(.4,0,.2,1);
  --t:        0.28s var(--ease);
  --glow-v:   0 0 24px rgba(139,92,246,0.35);
  --glow-e:   0 0 24px rgba(56,189,248,0.3);
  --r:        4px;
}

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

::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--violet);border-radius:2px}

/* ────────────────────────────────────────────
   GLOBAL GRID BACKGROUND
──────────────────────────────────────────── */
body::before{
  content:'';
  position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(139,92,246,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(139,92,246,.04) 1px,transparent 1px);
  background-size:48px 48px;
  pointer-events:none;z-index:0;
}

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

/* ────────────────────────────────────────────
   LAYOUT
──────────────────────────────────────────── */
.wrap{max-width:1200px;margin:0 auto;padding:0 2.5rem;position:relative;z-index:1}
section{padding:6.5rem 0;position:relative}

/* ────────────────────────────────────────────
   TYPOGRAPHY UTILITIES
──────────────────────────────────────────── */
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--violet);
  display:inline-flex;align-items:center;gap:.75rem;
}
.eyebrow::before{content:'//';opacity:.5;font-size:.8em}

.display-heading{
  font-family:var(--display);
  font-size:clamp(2.8rem,6vw,5rem);
  font-weight:700;
  line-height:1.0;
  letter-spacing:.01em;
  text-transform:uppercase;
}

.violet{color:var(--violet)}
.electric{color:var(--electric)}
.neon{color:var(--neon)}

/* ────────────────────────────────────────────
   NAV
──────────────────────────────────────────── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:800;
  padding:1.25rem 0;
  transition:var(--t);
  border-bottom:1px solid transparent;
}
#nav.stuck{
  background:rgba(13,13,18,.92);
  backdrop-filter:blur(20px);
  border-bottom-color:var(--border);
}
#nav .wrap{display:flex;align-items:center;justify-content:space-between}

.nav-logo{
  font-family:var(--mono);
  font-size:.9rem;letter-spacing:.08em;
  color:var(--text);
  display:flex;align-items:center;gap:.5rem;
}
.nav-logo-bracket{color:var(--violet);font-size:1.1rem}
.nav-logo-name{font-weight:700}
.nav-logo-cursor{
  display:inline-block;width:8px;height:16px;
  background:var(--violet);
  animation:blink .9s step-end infinite;
  vertical-align:middle;
  margin-left:2px;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

.nav-items{display:flex;align-items:center;gap:1.75rem}
.nav-items a{
  font-family:var(--mono);
  font-size:.72rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--text-2);
  transition:var(--t);
}
.nav-items a:hover{color:var(--violet)}
.nav-hire{
  padding:.5rem 1.3rem;
  border:1px solid var(--violet);
  color:var(--violet)!important;
  border-radius:var(--r);
  background:rgba(139,92,246,.08);
  transition:var(--t);
}
.nav-hire:hover{background:var(--violet);color:#fff!important;box-shadow:var(--glow-v)}

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

/* ────────────────────────────────────────────
   HERO
──────────────────────────────────────────── */
#hero{
  min-height:100vh;
  display:flex;align-items:center;
  overflow:hidden;padding:0;
}

.hero-inner{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:0;min-height:100vh;width:100%;
}

.hero-content-col{
  display:flex;flex-direction:column;justify-content:center;
  padding:9rem 5rem 5rem calc((100vw - 1200px)/2 + 2.5rem);
  position:relative;z-index:1;
}

/* animated scan line */
.hero-content-col::after{
  content:'';
  position:absolute;
  left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(139,92,246,.6),transparent);
  animation:scan 4s linear infinite;
  pointer-events:none;
}
@keyframes scan{
  0%{top:-2px;opacity:0}
  5%{opacity:1}
  95%{opacity:1}
  100%{top:100%;opacity:0}
}

.hero-terminal-bar{
  display:flex;align-items:center;gap:.6rem;
  margin-bottom:2rem;
  opacity:0;animation:slideUp .7s .1s forwards;
}
.t-dot{width:10px;height:10px;border-radius:50%}
.t-dot-r{background:#f43f5e}
.t-dot-y{background:#fb923c}
.t-dot-g{background:#34d399}
.t-cmd{
  font-family:var(--mono);font-size:.75rem;
  color:var(--text-3);letter-spacing:.08em;margin-left:.5rem;
}
.t-cmd span{color:var(--violet)}

.hero-eyebrow{margin-bottom:1rem;opacity:0;animation:slideUp .7s .25s forwards}

.hero-name{
  font-family:var(--display);
  font-size:clamp(3.5rem,7vw,7rem);
  font-weight:800;
  line-height:.95;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin-bottom:.6rem;
  opacity:0;animation:slideUp .7s .4s forwards;
}
.hero-name-line2{
  color:transparent;
  -webkit-text-stroke:2px var(--violet);
  display:block;
}

.hero-title{
  font-family:var(--mono);
  font-size:clamp(.9rem,1.8vw,1.1rem);
  color:var(--electric);
  letter-spacing:.06em;
  margin-bottom:1.75rem;
  opacity:0;animation:slideUp .7s .55s forwards;
}
.hero-title::before{content:'> ';color:var(--violet);opacity:.6}

.hero-bio{
  font-size:1rem;color:var(--text-2);
  max-width:520px;line-height:1.8;
  margin-bottom:2.5rem;
  opacity:0;animation:slideUp .7s .7s forwards;
}

.hero-btns{
  display:flex;gap:1rem;flex-wrap:wrap;
  opacity:0;animation:slideUp .7s .85s forwards;
  margin-bottom:3.5rem;
}

.btn-v{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.85rem 1.8rem;border-radius:var(--r);
  font-family:var(--mono);font-size:.8rem;letter-spacing:.08em;
  text-transform:uppercase;font-weight:600;
  background:var(--violet);color:#fff;
  transition:var(--t);border:1px solid var(--violet);
}
.btn-v:hover{background:transparent;color:var(--violet);box-shadow:var(--glow-v)}

.btn-o{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.85rem 1.8rem;border-radius:var(--r);
  font-family:var(--mono);font-size:.8rem;letter-spacing:.08em;
  text-transform:uppercase;font-weight:600;
  border:1px solid var(--border-hi);color:var(--text-2);
  transition:var(--t);
}
.btn-o:hover{border-color:var(--electric);color:var(--electric)}

.hero-stats{
  display:flex;gap:2.5rem;
  padding-top:2.5rem;
  border-top:1px solid var(--border);
  opacity:0;animation:slideUp .7s 1s forwards;
}
.hstat-n{
  font-family:var(--display);font-size:2.4rem;font-weight:700;
  color:var(--violet);line-height:1;
}
.hstat-l{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--text-3);margin-top:.3rem;
}

/* HERO RIGHT — visual panel */
.hero-visual-col{
  background:var(--bg2);
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:1.5rem;padding:4rem 2rem;
}

/* diagonal stripe pattern */
.hero-visual-col::before{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(
    -45deg,
    rgba(139,92,246,.04) 0px,
    rgba(139,92,246,.04) 1px,
    transparent 1px,
    transparent 24px
  );
}

.hero-photo-wrap{
  position:relative;z-index:1;
  width:280px;height:320px;
}
.hero-photo-border{
  position:absolute;inset:-3px;
  border:1px solid var(--violet);
  border-radius:var(--r);
  animation:borderPulse 3s ease-in-out infinite;
}
@keyframes borderPulse{0%,100%{opacity:.4;box-shadow:none}50%{opacity:1;box-shadow:var(--glow-v)}}

.hero-photo-border-2{
  position:absolute;inset:-10px;
  border:1px dashed rgba(139,92,246,.2);
  border-radius:var(--r);
}
.hero-photo-inner{
  width:100%;height:100%;
  background:var(--bg3);
  border-radius:var(--r);overflow:hidden;
}
.hero-photo-inner 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;
  gap:.75rem;color:var(--text-3);font-family:var(--mono);font-size:.68rem;
  text-align:center;padding:1.5rem;letter-spacing:.08em;
}

/* status badge */
.hero-status{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:.75rem;
  background:rgba(52,211,153,.08);
  border:1px solid rgba(52,211,153,.2);
  padding:.65rem 1.25rem;border-radius:var(--r);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;
  color:var(--neon);
}
.status-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--neon);
  box-shadow:0 0 8px var(--neon);
  animation:pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

/* mini terminal widget */
.hero-terminal{
  position:relative;z-index:1;
  width:100%;max-width:320px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;
}
.term-header{
  padding:.6rem 1rem;
  background:var(--bg3);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:.5rem;
}
.term-title{font-family:var(--mono);font-size:.68rem;color:var(--text-3);letter-spacing:.06em}
.term-body{padding:1rem;font-family:var(--mono);font-size:.72rem;line-height:1.9}
.term-line{display:flex;gap:.5rem}
.term-prompt{color:var(--violet)}
.term-cmd{color:var(--electric)}
.term-out{color:var(--neon);padding-left:1.25rem}
.term-out.warn{color:var(--warn)}

/* ────────────────────────────────────────────
   ABOUT
──────────────────────────────────────────── */
#about{background:var(--bg2)}
#about::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--violet),transparent);
}

.about-grid{
  display:grid;grid-template-columns:320px 1fr;
  gap:5rem;align-items:start;
}

.about-id-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r);
  overflow:hidden;
}
.id-card-top{
  background:var(--violet);
  padding:1.5rem;text-align:center;
  position:relative;
}
.id-card-top::after{
  content:'ID CARD';
  font-family:var(--mono);font-size:.55rem;letter-spacing:.4em;
  color:rgba(255,255,255,.3);
  position:absolute;top:.5rem;right:.75rem;
}
.id-avatar{
  width:80px;height:80px;border-radius:50%;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;
  font-family:var(--display);font-size:2rem;color:#fff;
  border:2px solid rgba(255,255,255,.3);
}
.id-name{font-family:var(--display);font-size:1.3rem;font-weight:700;color:#fff;text-transform:uppercase}
.id-role{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;color:rgba(255,255,255,.7);margin-top:.3rem}

.id-card-body{padding:1.25rem}
.id-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:.6rem 0;border-bottom:1px solid var(--border);
  font-family:var(--mono);font-size:.72rem;
}
.id-row:last-child{border:none}
.id-key{color:var(--text-3);letter-spacing:.1em;text-transform:uppercase}
.id-val{color:var(--text);font-weight:500}
.id-val a{color:var(--violet)}
.id-val.online{color:var(--neon)}

.about-content{}
.about-summary{
  font-size:1rem;color:var(--text-2);line-height:1.85;
  margin:1.5rem 0 2rem;
}
.about-highlight{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1rem;margin-bottom:2.5rem;
}
.hl-chip{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r);padding:1rem 1.25rem;
  transition:var(--t);
}
.hl-chip:hover{border-color:var(--violet);box-shadow:var(--glow-v);transform:translateY(-2px)}
.hl-chip-icon{font-size:1.3rem;margin-bottom:.5rem}
.hl-chip-title{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--violet)}
.hl-chip-desc{font-size:.85rem;color:var(--text-2);margin-top:.25rem}

.comp-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.ctag{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.05em;
  padding:.28rem .7rem;border-radius:2px;
  background:rgba(139,92,246,.08);
  border:1px solid rgba(139,92,246,.18);
  color:var(--violet-3);
  transition:var(--t);
}
.ctag:hover{background:rgba(139,92,246,.18)}

/* ────────────────────────────────────────────
   SKILLS
──────────────────────────────────────────── */
#skills{background:var(--bg)}
#skills::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--electric),transparent);
}

.skills-header{
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:end;margin-bottom:3.5rem;
}
.skills-desc{color:var(--text-2);font-size:1rem;line-height:1.8;margin-top:1rem}

.skills-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
}
.sk-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:1.5rem;
  transition:var(--t);
  position:relative;overflow:hidden;
}
.sk-card::before{
  content:attr(data-n);
  position:absolute;bottom:-.5rem;right:.75rem;
  font-family:var(--display);font-size:5rem;font-weight:800;
  color:rgba(139,92,246,.06);line-height:1;pointer-events:none;
}
.sk-card:hover{
  border-color:var(--border-hi);
  transform:translateY(-4px);
  box-shadow:var(--glow-v);
}
.sk-icon{
  font-size:1.6rem;
  width:44px;height:44px;
  background:rgba(139,92,246,.1);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1rem;
}
.sk-name{
  font-family:var(--display);
  font-size:1.05rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--text);margin-bottom:.75rem;
}
.sk-items{display:flex;flex-wrap:wrap;gap:.4rem}
.sk-item{
  font-family:var(--mono);font-size:.63rem;letter-spacing:.04em;
  padding:.22rem .55rem;
  background:rgba(56,189,248,.06);
  border:1px solid rgba(56,189,248,.12);
  color:var(--electric);border-radius:2px;
}

/* big featured card */
.sk-card.sk-feat{
  grid-column:span 2;
  background:linear-gradient(135deg,rgba(139,92,246,.12) 0%,rgba(56,189,248,.06) 100%);
  border-color:rgba(139,92,246,.25);
}
.sk-card.sk-feat .sk-name{color:var(--violet-2);font-size:1.3rem}

/* ────────────────────────────────────────────
   EXPERIENCE
──────────────────────────────────────────── */
#experience{background:var(--bg2)}
#experience::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--violet),transparent);
}

.exp-grid{display:grid;grid-template-columns:260px 1fr;gap:4.5rem;margin-top:3.5rem}

/* sticky sidebar */
.exp-sidebar{position:sticky;top:5.5rem;align-self:start}
.exp-sidebar-label{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--text-3);
  margin-bottom:1rem;
  padding-bottom:.75rem;border-bottom:1px solid var(--border);
}
.exp-tab{
  display:flex;align-items:flex-start;gap:.85rem;
  padding:.9rem 1rem;border-radius:var(--r);
  cursor:pointer;margin-bottom:.4rem;
  border:1px solid transparent;transition:var(--t);
}
.exp-tab:hover{background:rgba(139,92,246,.06)}
.exp-tab.on{
  background:rgba(139,92,246,.1);
  border-color:rgba(139,92,246,.25);
}
.exp-tab-bar{
  width:3px;flex-shrink:0;border-radius:2px;margin-top:.3rem;
  background:var(--text-3);min-height:32px;transition:var(--t);
}
.exp-tab.on .exp-tab-bar{background:var(--violet)}
.exp-tab-co{
  font-weight:700;font-size:.88rem;color:var(--text-2);
  transition:var(--t);line-height:1.3;
}
.exp-tab.on .exp-tab-co{color:var(--violet-2)}
.exp-tab-yr{font-family:var(--mono);font-size:.65rem;letter-spacing:.08em;color:var(--text-3);margin-top:.2rem}

/* panels */
.exp-panel{display:none;animation:fadeIn .4s var(--ease)}
.exp-panel.on{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.exp-panel-head{padding-bottom:1.75rem;margin-bottom:1.75rem;border-bottom:1px solid var(--border)}
.exp-role-title{
  font-family:var(--display);
  font-size:clamp(1.8rem,3vw,2.5rem);
  font-weight:700;text-transform:uppercase;
  color:var(--text);margin-bottom:.5rem;
}
.exp-badges{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}
.exp-co-badge{
  font-family:var(--mono);font-size:.75rem;
  padding:.3rem .9rem;border-radius:var(--r);
  background:rgba(139,92,246,.12);
  border:1px solid rgba(139,92,246,.25);
  color:var(--violet-2);
}
.exp-period-badge{
  font-family:var(--mono);font-size:.72rem;
  letter-spacing:.08em;color:var(--text-3);
}
.exp-type-badge{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.1em;
  padding:.2rem .7rem;border-radius:100px;
  background:rgba(52,211,153,.1);
  border:1px solid rgba(52,211,153,.2);
  color:var(--neon);
}

.exp-duties-list{margin-bottom:1.75rem}
.exp-duty{
  display:flex;gap:1rem;
  padding:.85rem 0;border-bottom:1px solid rgba(139,92,246,.06);
}
.exp-duty:last-child{border:none}
.duty-arrow{
  color:var(--violet);font-family:var(--mono);
  font-size:.85rem;flex-shrink:0;margin-top:.15rem;
}
.duty-txt{color:var(--text-2);font-size:.95rem;line-height:1.7}

.exp-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}
.tech-tag{
  font-family:var(--mono);font-size:.65rem;letter-spacing:.05em;
  padding:.25rem .65rem;border-radius:2px;
  background:rgba(56,189,248,.06);
  border:1px solid rgba(56,189,248,.12);
  color:var(--electric);
}

/* ────────────────────────────────────────────
   ACHIEVEMENTS
──────────────────────────────────────────── */
#achievements{background:var(--bg)}

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

.ach-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}
.ach-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:2rem 1.75rem;
  position:relative;overflow:hidden;
  transition:var(--t);
}
.ach-card::after{
  content:'';
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--violet),var(--electric));
  transform:scaleX(0);transform-origin:left;transition:transform var(--t);
}
.ach-card:hover{transform:translateY(-4px);border-color:var(--border-hi)}
.ach-card:hover::after{transform:scaleX(1)}

.ach-card-icon{
  width:48px;height:48px;border-radius:var(--r);
  background:rgba(139,92,246,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;margin-bottom:1.25rem;
}
.ach-stat{
  font-family:var(--display);
  font-size:2.6rem;font-weight:800;
  color:var(--violet);line-height:1;margin-bottom:.3rem;
}
.ach-card-title{font-weight:700;font-size:.95rem;color:var(--text);margin-bottom:.5rem}
.ach-card-desc{font-size:.85rem;color:var(--text-2);line-height:1.7}

/* ────────────────────────────────────────────
   EDUCATION & CERTS
──────────────────────────────────────────── */
#education{background:var(--bg2)}
#education::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--neon),transparent);
}

.edu-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:3.5rem}

.edu-section-label{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--neon);
  margin-bottom:2rem;padding-bottom:.75rem;
  border-bottom:1px solid rgba(52,211,153,.15);
  display:flex;align-items:center;gap:.6rem;
}
.edu-section-label::before{content:'[ ';opacity:.5}
.edu-section-label::after{content:' ]';opacity:.5}

.edu-entry{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:1.5rem 1.75rem;
  margin-bottom:1rem;transition:var(--t);
}
.edu-entry:hover{border-color:rgba(52,211,153,.25)}
.edu-deg{font-family:var(--display);font-size:1.15rem;font-weight:700;text-transform:uppercase;color:var(--text);margin-bottom:.3rem}
.edu-school{font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;color:var(--neon);margin-bottom:.2rem}
.edu-year{font-family:var(--mono);font-size:.7rem;color:var(--text-3)}

.cert-item{
  display:flex;align-items:center;gap:1rem;
  padding:.9rem 1.1rem;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);margin-bottom:.6rem;transition:var(--t);
}
.cert-item:hover{border-color:rgba(52,211,153,.2);transform:translateX(4px)}
.cert-bullet{
  width:28px;height:28px;border-radius:var(--r);
  background:rgba(52,211,153,.1);
  border:1px solid rgba(52,211,153,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;flex-shrink:0;
}
.cert-name{font-size:.88rem;color:var(--text);font-weight:600;flex:1}
.cert-org{font-family:var(--mono);font-size:.65rem;color:var(--text-3);letter-spacing:.06em;margin-top:.15rem}

/* ────────────────────────────────────────────
   CONTACT
──────────────────────────────────────────── */
#contact{background:var(--bg)}
#contact::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--violet),transparent);
}

.contact-wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:5rem;margin-top:3.5rem}

.contact-cta-big{
  font-family:var(--display);
  font-size:clamp(2rem,4vw,3rem);font-weight:700;
  text-transform:uppercase;color:var(--text);
  line-height:1.1;margin:1.25rem 0 1.75rem;
}
.contact-cta-big span{color:var(--violet)}

.contact-lead{color:var(--text-2);font-size:1rem;line-height:1.8;margin-bottom:2.5rem}

.contact-methods{display:flex;flex-direction:column;gap:.85rem}
.cmethod{
  display:flex;align-items:center;gap:1.1rem;
  padding:1.1rem 1.25rem;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);transition:var(--t);
}
.cmethod:hover{border-color:var(--border-hi);box-shadow:var(--glow-v);transform:translateX(4px)}
.cmethod-icon{
  width:40px;height:40px;border-radius:var(--r);
  background:rgba(139,92,246,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;flex-shrink:0;
}
.cmethod-lbl{font-family:var(--mono);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-3)}
.cmethod-val{font-size:.92rem;color:var(--text);margin-top:.15rem}

/* contact form */
.cform-wrap{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:2rem;
}
.cform-title{
  font-family:var(--mono);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--violet);margin-bottom:1.5rem;
  display:flex;align-items:center;gap:.5rem;
}
.cform-title::before{content:'_';animation:blink .9s step-end infinite}
.cf-group{margin-bottom:1.1rem}
.cf-group label{
  display:block;font-family:var(--mono);font-size:.65rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-3);margin-bottom:.4rem;
}
.cf-group input,.cf-group textarea{
  width:100%;
  background:var(--bg3);border:1px solid var(--border);
  border-radius:var(--r);padding:.8rem 1rem;
  color:var(--text);font-family:var(--mono);font-size:.85rem;
  outline:none;transition:var(--t);resize:vertical;
}
.cf-group input::placeholder,.cf-group textarea::placeholder{color:var(--text-3)}
.cf-group input:focus,.cf-group textarea:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(139,92,246,.1)}
.cf-group textarea{min-height:110px}
.cf-submit{
  width:100%;padding:.9rem;border:none;border-radius:var(--r);
  background:var(--violet);color:#fff;
  font-family:var(--mono);font-size:.82rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;transition:var(--t);
}
.cf-submit:hover{background:var(--violet-2);box-shadow:var(--glow-v);transform:translateY(-1px)}

/* ────────────────────────────────────────────
   REFERENCES
──────────────────────────────────────────── */
#references{background:var(--bg2)}
#references::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--electric),transparent);
}

.ref-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3.5rem}
.ref-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:2rem;transition:var(--t);
}
.ref-card:hover{border-color:var(--border-hi);transform:translateY(-4px);box-shadow:var(--glow-v)}

.ref-initials{
  width:52px;height:52px;border-radius:var(--r);
  background:linear-gradient(135deg,var(--violet),var(--electric));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:1.2rem;font-weight:800;color:#fff;
  margin-bottom:1.25rem;
}
.ref-name{font-family:var(--display);font-size:1.2rem;font-weight:700;text-transform:uppercase;color:var(--text);margin-bottom:.25rem}
.ref-role{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:var(--violet-3);margin-bottom:.25rem}
.ref-company{font-size:.85rem;color:var(--text-3);margin-bottom:1rem}
.ref-links{display:flex;flex-direction:column;gap:.4rem}
.ref-links a{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;
  color:var(--text-3);display:flex;align-items:center;gap:.5rem;transition:var(--t);
}
.ref-links a:hover{color:var(--violet)}

/* ────────────────────────────────────────────
   FOOTER
──────────────────────────────────────────── */
#footer{
  background:var(--bg);
  border-top:1px solid var(--border);
  padding:2.5rem 0;
}
#footer .wrap{display:flex;align-items:center;justify-content:space-between}
.footer-logo{font-family:var(--mono);font-size:.85rem;letter-spacing:.06em;color:var(--text-3)}
.footer-logo span{color:var(--violet)}
.footer-copy{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;color:var(--text-3)}
.footer-up{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--text-3);
  display:flex;align-items:center;gap:.4rem;transition:var(--t);
}
.footer-up:hover{color:var(--violet)}

/* ────────────────────────────────────────────
   ANIMATIONS
──────────────────────────────────────────── */
@keyframes slideUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

.reveal{opacity:1;transform:none}
.js-loaded .reveal{
  opacity:0;transform:translateY(30px);
  transition:opacity .6s var(--ease),transform .6s var(--ease);
}
.js-loaded .reveal.in{opacity:1;transform:translateY(0)}

/* ────────────────────────────────────────────
   RESPONSIVE
──────────────────────────────────────────── */
@media(max-width:1100px){
  .skills-grid{grid-template-columns:repeat(2,1fr)}
  .sk-card.sk-feat{grid-column:span 2}
}
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr}
  .hero-content-col{padding:8rem 2.5rem 4rem}
  .hero-visual-col{min-height:400px;padding:3rem 2rem}
  .about-grid{grid-template-columns:1fr;gap:3rem}
  .exp-grid{grid-template-columns:1fr;gap:2.5rem}
  .exp-sidebar{position:static;display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.5rem}
  .exp-tab{flex-shrink:0}
  .skills-header{grid-template-columns:1fr}
  .ach-top{grid-template-columns:1fr}
  .ach-grid{grid-template-columns:1fr 1fr}
  .contact-wrap{grid-template-columns:1fr;gap:3rem}
  .ref-grid{grid-template-columns:1fr 1fr}
  .edu-wrap{grid-template-columns:1fr;gap:3rem}
}
@media(max-width:640px){
  .wrap{padding:0 1.5rem}
  section{padding:4.5rem 0}
  .ach-grid,.ref-grid,.about-highlight{grid-template-columns:1fr}
  .skills-grid{grid-template-columns:1fr}
  .hero-stats{gap:1.5rem}
  .nav-items{display:none}
  .nav-items.open{
    display:flex;flex-direction:column;
    position:fixed;inset:0;background:var(--bg);
    z-index:700;align-items:center;justify-content:center;gap:2.5rem;
  }
  .nav-items.open a{font-size:1rem}
  .nav-burger{display:flex}
  #footer .wrap{flex-direction:column;gap:1rem;text-align:center}
}
