/* =============================================
   TOKENS
   ============================================= */
:root {
  --cream:      #FDFAF4;
  --cream2:     #F5F0E6;
  --cream3:     #EDE5D4;
  --forest:     #2A6B45;
  --forest2:    #1F5235;
  --leaf:       #4AB068;
  --leaf2:      #6DC985;
  --sage:       #8FB89A;
  --sage2:      #B8D4C0;
  --ink:        #1C2B22;
  --ink2:       #2E4035;
  --muted:      #5A7060;
  --muted2:     #8FAA96;
  --warm:       #D4956A;
  --warm2:      #E8B48A;
  --line:       rgba(42,107,69,0.12);
  --line2:      rgba(42,107,69,0.07);
  --card:       rgba(255,255,255,0.85);
  --card2:      rgba(245,240,230,0.7);
  --glow:       rgba(42,107,69,0.08);
  --page:       #FDFAF4;
  --shadow:     0 4px 24px rgba(28,43,34,0.08);
  --shadow-lg:  0 12px 48px rgba(28,43,34,0.13);
  --font-serif: 'Fraunces', Georgia, serif;
  --font-mono:  'DM Mono', monospace;
  --font-body:  'Nunito', system-ui, sans-serif;
  --r: 12px;
}
[data-theme="dark"] {
  --cream:      #0E1A13;
  --cream2:     #121F17;
  --cream3:     #172819;
  --forest:     #4AB068;
  --forest2:    #6DC985;
  --leaf:       #5DC87A;
  --leaf2:      #80D994;
  --sage:       #4A7A5A;
  --sage2:      #3A5F47;
  --ink:        #E8F4EC;
  --ink2:       #C8E0D0;
  --muted:      #8ABFA0;
  --muted2:     #5A8A6E;
  --warm:       #D4956A;
  --warm2:      #C07850;
  --line:       rgba(74,176,104,0.15);
  --line2:      rgba(74,176,104,0.08);
  --card:       rgba(18,31,23,0.9);
  --card2:      rgba(14,26,19,0.8);
  --glow:       rgba(74,176,104,0.07);
  --page:       #0E1A13;
  --shadow:     0 4px 24px rgba(0,0,0,0.3);
  --shadow-lg:  0 12px 48px rgba(0,0,0,0.4);
}

/* =============================================
   RESET
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--page);color:var(--ink);
  font-family:var(--font-body);font-size:16px;line-height:1.65;
  overflow-x:hidden;transition:background .4s,color .4s;
  cursor:none;
}
::selection{background:rgba(42,107,69,0.15);color:var(--forest)}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--cream2)}
::-webkit-scrollbar-thumb{background:var(--forest);border-radius:2px}

/* =============================================
   CUSTOM CURSOR
   ============================================= */
#cursor{
  position:fixed;z-index:9999;pointer-events:none;
  width:12px;height:12px;border-radius:50%;
  background:var(--forest);
  transform:translate(-50%,-50%);
  transition:transform .1s,background .2s,width .2s,height .2s;
  mix-blend-mode:multiply;
}
[data-theme="dark"] #cursor{mix-blend-mode:screen}
#cursor-ring{
  position:fixed;z-index:9998;pointer-events:none;
  width:36px;height:36px;border-radius:50%;
  border:1.5px solid var(--forest);
  transform:translate(-50%,-50%);
  transition:transform .15s ease,width .2s,height .2s,opacity .2s;
  opacity:0.5;
}
body:hover #cursor{opacity:1}

/* =============================================
   WELCOME OVERLAY
   ============================================= */
#welcome-overlay{
  position:fixed;inset:0;z-index:10000;
  background:var(--cream);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:0;
  transition:opacity .6s ease,transform .6s ease;
}
#welcome-overlay.exit{opacity:0;transform:scale(1.04);pointer-events:none}

.wlc-top{
  display:flex;flex-direction:column;align-items:center;
  gap:12px;margin-bottom:32px;
}
.wlc-doodle{
  font-size:80px;
  animation:wave 1.2s ease-in-out infinite alternate;
  filter:drop-shadow(0 4px 12px rgba(42,107,69,0.2));
}
@keyframes wave{0%{transform:rotate(-8deg) scale(1)}100%{transform:rotate(8deg) scale(1.08)}}

.wlc-title{
  font-family:var(--font-serif);font-size:clamp(24px,4vw,38px);
  font-weight:700;color:var(--ink);text-align:center;
  font-style:italic;line-height:1.2;
}
.wlc-sub{
  font-family:var(--font-body);font-size:15px;color:var(--muted);
  text-align:center;max-width:340px;line-height:1.6;
}

.name-form{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  width:100%;max-width:340px;
}
.name-label{
  font-family:var(--font-mono);font-size:11px;
  color:var(--forest);letter-spacing:.15em;text-transform:uppercase;
}
.name-input{
  width:100%;padding:14px 20px;
  background:var(--card);border:2px solid var(--line);
  border-radius:50px;
  font-family:var(--font-serif);font-size:18px;font-style:italic;
  color:var(--ink);text-align:center;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.name-input:focus{border-color:var(--forest);box-shadow:0 0 0 4px rgba(42,107,69,0.1)}
.name-input::placeholder{color:var(--muted2)}

.enter-btn{
  background:var(--forest);color:white;
  font-family:var(--font-body);font-size:15px;font-weight:700;
  padding:13px 36px;border:none;border-radius:50px;
  cursor:pointer;transition:all .2s;
  box-shadow:0 4px 16px rgba(42,107,69,0.3);
  display:flex;align-items:center;gap:8px;
}
.enter-btn:hover{background:var(--forest2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(42,107,69,0.4)}
.enter-btn:active{transform:translateY(0)}

.skip-link{
  font-family:var(--font-mono);font-size:11px;color:var(--muted2);
  background:none;border:none;cursor:pointer;
  letter-spacing:.08em;text-decoration:underline;
  transition:color .2s;margin-top:4px;
}
.skip-link:hover{color:var(--muted)}

/* =============================================
   CAT COMPANION
   ============================================= */
#cat-companion{
  position:fixed;bottom:20px;right:20px;z-index:500;
  display:flex;flex-direction:column;align-items:flex-end;gap:8px;
  opacity:0;transform:translateY(20px);
  transition:opacity .5s,transform .5s;
  pointer-events:none;
}
#cat-companion.visible{opacity:1;transform:translateY(0);pointer-events:all}

.cat-bubble{
  background:var(--card);border:1.5px solid var(--line);
  border-radius:16px 16px 4px 16px;
  padding:10px 14px;max-width:220px;
  font-size:13px;color:var(--ink);line-height:1.5;
  box-shadow:var(--shadow);
  display:none;
  animation:bubblePop .3s cubic-bezier(0.34,1.56,0.64,1);
}
.cat-bubble.show{display:block}
@keyframes bubblePop{0%{opacity:0;transform:scale(0.8) translateY(8px)}100%{opacity:1;transform:scale(1) translateY(0)}}

.cat-emoji{
  font-size:38px;cursor:pointer;
  animation:catBob 3s ease-in-out infinite;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,0.15));
  transition:transform .2s;
}
.cat-emoji:hover{transform:scale(1.2) rotate(10deg)}
@keyframes catBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* =============================================
   NAV
   ============================================= */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:62px;padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(253,250,244,0.88);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--line);
  transition:background .4s,border-color .4s;
}
[data-theme="dark"] nav{background:rgba(14,26,19,0.92)}

.nav-logo{
  font-family:var(--font-serif);font-size:20px;font-weight:700;
  color:var(--forest);text-decoration:none;font-style:italic;
  display:flex;align-items:center;gap:8px;
}
.logo-leaf{
  display:inline-block;font-size:16px;
  animation:sway 4s ease-in-out infinite;
}
@keyframes sway{0%,100%{transform:rotate(-10deg)}50%{transform:rotate(10deg)}}

.nav-links{display:flex;gap:28px;list-style:none}
.nav-links a{
  font-family:var(--font-body);font-size:13px;font-weight:600;
  color:var(--muted);text-decoration:none;
  position:relative;padding:4px 0;transition:color .2s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:2px;background:var(--forest);border-radius:1px;
  transition:width .3s cubic-bezier(.4,0,.2,1);
}
.nav-links a:hover{color:var(--forest)}
.nav-links a:hover::after{width:100%}

.nav-right{display:flex;align-items:center;gap:12px}

.visitor-badge{
  font-family:var(--font-mono);font-size:11px;
  color:var(--warm);background:rgba(212,149,106,0.12);
  border:1px solid rgba(212,149,106,0.25);
  padding:4px 12px;border-radius:20px;
  display:none;
}
.visitor-badge.show{display:inline-block}

.theme-btn{
  width:42px;height:24px;border-radius:12px;
  background:var(--cream3);border:1.5px solid var(--line);
  cursor:pointer;position:relative;transition:background .3s;
}
.theme-btn::after{
  content:'';position:absolute;top:2px;left:2px;
  width:16px;height:16px;border-radius:50%;
  background:var(--forest);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  box-shadow:0 1px 4px rgba(0,0,0,.15);
}
[data-theme="dark"] .theme-btn::after{transform:translateX(18px)}

.hire-btn{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  color:var(--forest);border:1.5px solid var(--forest);
  padding:7px 16px;border-radius:6px;text-decoration:none;
  letter-spacing:.06em;text-transform:uppercase;transition:all .2s;
}
.hire-btn:hover{background:var(--forest);color:white}

/* =============================================
   DOODLES (inline SVG decorations)
   ============================================= */
.doodle{
  position:absolute;pointer-events:none;
  opacity:0;transition:opacity .8s ease,transform .8s ease;
}
.doodle.appear{opacity:1;transform:none!important}

/* =============================================
   SECTIONS
   ============================================= */
main{position:relative;z-index:1}
section{padding:100px 5%;position:relative}
section+section{border-top:1px solid var(--line2)}

/* =============================================
   HERO
   ============================================= */
#hero{
  min-height:100vh;padding-top:110px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:50px;align-items:center;
  background:radial-gradient(ellipse 70% 60% at 80% 40%,rgba(42,107,69,0.05),transparent);
}

.hero-greeting{
  font-family:var(--font-mono);font-size:12px;
  color:var(--warm);letter-spacing:.14em;text-transform:uppercase;
  margin-bottom:16px;display:flex;align-items:center;gap:8px;
}
.hero-greeting-name{color:var(--forest);font-weight:500}
.greeting-wave{display:inline-block;animation:waveHand .8s ease-in-out infinite alternate}
@keyframes waveHand{0%{transform:rotate(-10deg)}100%{transform:rotate(15deg)}}

.hero-h1{
  font-family:var(--font-serif);
  font-size:clamp(46px,5.5vw,78px);
  line-height:1.0;letter-spacing:-.02em;
  margin-bottom:10px;
}
.hero-h1 .name-regular{color:var(--ink);font-weight:700}
.hero-h1 .name-italic{color:var(--forest);font-style:italic;font-weight:500}

.hero-title-line{
  font-family:var(--font-serif);font-size:clamp(16px,2vw,24px);
  color:var(--muted);font-style:italic;
  margin-bottom:24px;
}

.hero-desc{
  font-size:16px;color:var(--muted);line-height:1.8;
  max-width:480px;margin-bottom:36px;
}
.hero-desc strong{color:var(--ink);font-weight:700}

.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}

.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--forest);color:white;
  font-weight:700;font-size:14px;padding:13px 28px;
  border-radius:50px;text-decoration:none;
  box-shadow:0 4px 18px rgba(42,107,69,0.3);
  transition:all .25s cubic-bezier(.34,1.56,.64,1);
}
.btn-primary:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 8px 28px rgba(42,107,69,0.4)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--forest);border:2px solid var(--forest);
  font-weight:700;font-size:14px;padding:11px 28px;
  border-radius:50px;text-decoration:none;
  transition:all .2s;background:transparent;
}
.btn-ghost:hover{background:rgba(42,107,69,0.06)}

.hero-socials{display:flex;gap:10px}
.soc-btn{
  display:flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:11px;color:var(--muted2);
  text-decoration:none;padding:7px 12px;
  border:1px solid var(--line);border-radius:8px;
  background:var(--card);
  transition:all .2s;
}
.soc-btn:hover{border-color:var(--forest);color:var(--forest);background:var(--glow)}

/* HERO RIGHT */
.hero-right{display:flex;flex-direction:column;gap:14px;position:relative}

.stat-card{
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:18px 20px;
  display:flex;align-items:center;gap:16px;
  box-shadow:var(--shadow);
  transition:all .3s cubic-bezier(.4,0,.2,1);
  cursor:default;
}
.stat-card:hover{transform:translateX(6px);border-color:var(--forest);box-shadow:var(--shadow-lg)}
.stat-icon{
  width:44px;height:44px;border-radius:10px;
  background:rgba(42,107,69,0.08);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
}
.stat-num{
  font-family:var(--font-serif);font-size:28px;font-weight:700;
  color:var(--forest);line-height:1;
}
.stat-label{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:1px}
.stat-sub{font-family:var(--font-mono);font-size:10px;color:var(--muted2);letter-spacing:.03em}

/* =============================================
   SECTION HEADER
   ============================================= */
.sh{margin-bottom:52px}
.sh-eye{
  font-family:var(--font-mono);font-size:11px;color:var(--forest);
  letter-spacing:.2em;text-transform:uppercase;
  margin-bottom:8px;display:flex;align-items:center;gap:10px;
}
.sh-eye::before{content:'';width:24px;height:1.5px;background:var(--forest)}
.sh-title{
  font-family:var(--font-serif);
  font-size:clamp(28px,3.5vw,46px);
  line-height:1.1;letter-spacing:-.015em;color:var(--ink);
}
.sh-title em{color:var(--forest);font-style:italic}
.sh-sub{font-size:15px;color:var(--muted);margin-top:10px;line-height:1.7}

/* =============================================
   ABOUT — SWIPE CARDS
   ============================================= */
.about-tabs{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.atab{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  padding:7px 16px;border-radius:20px;
  border:1.5px solid var(--line);background:var(--card);
  color:var(--muted);cursor:pointer;transition:all .2s;
  letter-spacing:.05em;
}
.atab.active,.atab:hover{border-color:var(--forest);color:var(--forest);background:var(--glow)}
.acard-wrap{position:relative;min-height:220px}
.acard-panel{
  display:none;
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:28px 32px;
  box-shadow:var(--shadow);
  animation:cardIn .3s cubic-bezier(.34,1.2,.64,1);
}
.acard-panel.active{display:block}
@keyframes cardIn{0%{opacity:0;transform:translateY(10px) scale(.98)}100%{opacity:1;transform:none}}
.acard-panel p{font-size:15px;color:var(--muted);line-height:1.85;margin-bottom:14px}
.acard-panel p:last-child{margin-bottom:0}
.acard-panel p strong{color:var(--ink);font-weight:700}
.phil-tag{
  font-family:var(--font-mono);font-size:9px;color:var(--forest);
  letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px;
}
.phil-quote{
  font-family:var(--font-serif);font-size:16px;font-style:italic;
  color:var(--ink);line-height:1.75;
  padding-left:16px;border-left:3px solid var(--forest);
}
.sg-title{
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  color:var(--muted2);letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px;
}
.skill-row{margin-bottom:16px}
.skill-row:last-child{margin-bottom:0}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{
  font-family:var(--font-mono);font-size:11px;padding:5px 12px;
  border-radius:20px;border:1px solid var(--line);
  color:var(--muted);background:var(--card);cursor:default;transition:all .2s;
}
.chip:hover{border-color:var(--forest);color:var(--forest);background:var(--glow)}
.chip.p{border-color:rgba(42,107,69,.3);color:var(--forest);background:var(--glow)}
.chip.l{border-style:dashed;color:var(--warm);border-color:rgba(212,149,106,.35);background:transparent}

/* =============================================
   EXPERIENCE — TIMELINE
   ============================================= */
#experience .tl{position:relative}
#experience .tl::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:1px;
  background:linear-gradient(180deg,transparent,var(--line) 10%,var(--line) 90%,transparent);
}
.ei{
  display:grid;grid-template-columns:170px 1fr;
  gap:0;padding:0 0 44px;position:relative;
}
.ei:last-child{padding-bottom:0}
.ei-dot{
  position:absolute;left:-5px;top:8px;
  width:10px;height:10px;border-radius:50%;
  background:var(--forest);border:2px solid var(--page);
  box-shadow:0 0 0 3px var(--glow);
}
.ei.current .ei-dot{animation:pulse-green 2.5s ease-in-out infinite}
@keyframes pulse-green{
  0%,100%{box-shadow:0 0 0 3px var(--glow)}
  50%{box-shadow:0 0 0 9px rgba(42,107,69,0)}
}
.ei-meta{padding-left:22px;padding-right:16px}
.ei-period{font-family:var(--font-mono);font-size:10px;color:var(--muted2);letter-spacing:.04em;margin-bottom:4px}
.ei-company{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:2px}
.ei-loc{font-family:var(--font-mono);font-size:10px;color:var(--muted2)}
.ei-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--font-mono);font-size:9px;
  color:var(--leaf2);border:1px solid var(--leaf);
  padding:2px 7px;border-radius:3px;margin-top:7px;
  letter-spacing:.07em;text-transform:uppercase;
}

.ei-box{
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:22px 26px;
  box-shadow:var(--shadow);transition:box-shadow .3s,border-color .3s;
}
.ei-box:hover{box-shadow:var(--shadow-lg);border-color:var(--line)}
.ei-role{
  font-family:var(--font-serif);font-size:20px;font-weight:600;
  color:var(--ink);margin-bottom:12px;line-height:1.2;
}
.ei-desc{
  font-size:13px;color:var(--muted);line-height:1.7;
  margin-bottom:10px;
  background:rgba(42,107,69,0.05);border-radius:8px;padding:10px 12px;
  border-left:2px solid var(--leaf);
}
.ei-bullets{list-style:none;display:flex;flex-direction:column;gap:8px}
.ei-bullets li{font-size:13px;color:var(--muted);line-height:1.65;display:flex;gap:9px;align-items:flex-start}
.ei-bullets li::before{content:'▸';color:var(--forest);flex-shrink:0;font-size:10px;margin-top:4px}
.ei-bullets li strong{color:var(--ink);font-weight:700}
.ei-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:12px}
.ei-tag{
  font-family:var(--font-mono);font-size:10px;padding:3px 9px;
  border-radius:4px;background:var(--cream2);color:var(--muted);
  border:1px solid var(--line);
}

/* =============================================
   PROJECTS
   ============================================= */
#projects .pg{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}
.pc{
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:26px;
  display:flex;flex-direction:column;gap:0;
  box-shadow:var(--shadow);
  transition:all .3s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
}
.pc::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--forest),var(--leaf));
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.pc:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(42,107,69,.25)}
.pc:hover::after{transform:scaleX(1)}
.pc.featured{border-color:rgba(42,107,69,.3)}
.pc.featured::after{transform:scaleX(1)}
.pc.wip{border-style:dashed}

.pc-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.pc-num{font-family:var(--font-mono);font-size:10px;color:var(--muted2);letter-spacing:.1em}
.pc-badges{display:flex;gap:5px;flex-wrap:wrap}
.pbadge{font-family:var(--font-mono);font-size:9px;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.07em}
.pb-solo{background:rgba(42,107,69,.1);color:var(--forest);border:1px solid rgba(42,107,69,.2)}
.pb-live{background:rgba(46,196,100,.1);color:#1A8040;border:1px solid rgba(46,196,100,.25)}
.pb-wip{background:rgba(212,149,106,.1);color:var(--warm);border:1px solid rgba(212,149,106,.25)}

.pc-title{font-family:var(--font-serif);font-size:20px;font-weight:600;color:var(--ink);margin-bottom:4px;line-height:1.2}
.pc-org{font-family:var(--font-mono);font-size:11px;color:var(--forest);margin-bottom:10px;letter-spacing:.03em}
.pc-desc{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:14px;flex:1}

.pc-hl{
  list-style:none;display:flex;flex-direction:column;gap:5px;
  margin-bottom:14px;padding:10px 12px;
  background:var(--card2);border-radius:8px;border:1px solid var(--line2);
}
.pc-hl li{font-size:12px;color:var(--muted);display:flex;gap:7px;align-items:flex-start;line-height:1.5}
.pc-hl li::before{content:'✦';color:var(--forest);font-size:8px;flex-shrink:0;margin-top:3px}

.pc-metrics{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.pm{display:flex;flex-direction:column;gap:1px}
.pm-v{font-family:var(--font-serif);font-size:20px;font-weight:700;color:var(--forest);line-height:1}
.pm-l{font-family:var(--font-mono);font-size:9px;color:var(--muted2);text-transform:uppercase;letter-spacing:.07em}

.pc-stack{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px}
.ptag{
  font-family:var(--font-mono);font-size:10px;padding:3px 8px;
  border-radius:4px;background:var(--cream2);color:var(--muted);
  border:1px solid var(--line);
}

.pc-links{display:flex;gap:10px}
.plink{
  font-family:var(--font-mono);font-size:11px;color:var(--muted2);
  text-decoration:none;display:flex;align-items:center;gap:5px;
  border-bottom:1px solid var(--line);padding-bottom:1px;transition:all .2s;
}
.plink:hover{color:var(--forest);border-color:var(--forest)}

/* =============================================
   VISION
   ============================================= */
#vision{background:var(--cream2)}
.vg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:44px}
.vc{background:var(--card);padding:30px 26px;position:relative;overflow:hidden;transition:background .3s}
.vc:hover{background:var(--cream2)}
.vc-icon{font-size:28px;margin-bottom:12px}
.vc-title{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px}
.vc-desc{font-size:13px;color:var(--muted);line-height:1.65}

.building{
  margin-top:36px;padding:20px 26px;
  background:rgba(42,107,69,.07);border:1px solid var(--line);
  border-radius:10px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
}
.building-label{font-family:var(--font-mono);font-size:10px;color:var(--forest);letter-spacing:.18em;text-transform:uppercase;white-space:nowrap}
.building-items{display:flex;gap:10px;flex-wrap:wrap}
.bi{font-family:var(--font-mono);font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}
.bi::before{content:'◆';font-size:6px;color:var(--forest)}

/* =============================================
   CONTACT
   ============================================= */
#contact .cg{display:grid;grid-template-columns:1.1fr .9fr;gap:60px}
.c-heading{
  font-family:var(--font-serif);font-size:clamp(28px,3.5vw,50px);
  line-height:1.1;letter-spacing:-.01em;margin-bottom:16px;color:var(--ink);
}
.c-heading em{color:var(--forest);font-style:italic}
.c-desc{font-size:15px;color:var(--muted);line-height:1.75;margin-bottom:28px;max-width:420px}
.clinks{display:flex;flex-direction:column;gap:9px}
.clink{
  display:flex;align-items:center;gap:12px;
  padding:13px 16px;border-radius:10px;
  border:1px solid var(--line);text-decoration:none;
  background:var(--card);box-shadow:var(--shadow);transition:all .2s;
}
.clink:hover{border-color:var(--forest);transform:translateX(4px);background:var(--glow)}
.ci{
  width:34px;height:34px;border-radius:7px;
  background:var(--glow);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;
}
.cl{font-family:var(--font-mono);font-size:10px;color:var(--muted2);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1px}
.cv{font-size:13px;font-weight:600;color:var(--ink)}
.ca{margin-left:auto;color:var(--muted2);transition:color .2s}
.clink:hover .ca{color:var(--forest)}

.acard{
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);padding:22px;margin-bottom:12px;
  box-shadow:var(--shadow);
}
.at{font-family:var(--font-mono);font-size:10px;color:var(--muted2);letter-spacing:.15em;text-transform:uppercase;margin-bottom:10px}
.as{display:flex;align-items:center;gap:9px;margin-bottom:8px}
.adot{
  width:8px;height:8px;border-radius:50%;background:#2DC870;flex-shrink:0;
  box-shadow:0 0 0 0 rgba(45,200,112,.4);animation:sonar 2s infinite;
}
@keyframes sonar{0%{box-shadow:0 0 0 0 rgba(45,200,112,.4)}70%{box-shadow:0 0 0 8px rgba(45,200,112,0)}100%{box-shadow:0 0 0 0 rgba(45,200,112,0)}}
.atext{font-size:14px;font-weight:700;color:#1A8040}
.adetail{font-size:13px;color:var(--muted);line-height:1.6}

.looking{list-style:none;display:flex;flex-direction:column;gap:8px}
.looking li{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:9px}
.looking li::before{content:'→';color:var(--forest);font-family:var(--font-mono);font-size:11px;flex-shrink:0}

/* =============================================
   FOOTER
   ============================================= */
footer{
  padding:22px 5%;border-top:1px solid var(--line2);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:10px;
}
.ft{font-family:var(--font-mono);font-size:11px;color:var(--muted2)}
.ft a{color:var(--forest);text-decoration:none}

/* =============================================
   SCROLL REVEAL
   ============================================= */
.r{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}
.r.v{opacity:1;transform:translateY(0)}
.r1{transition-delay:.1s}.r2{transition-delay:.2s}.r3{transition-delay:.3s}

/* =============================================
   RESPONSIVE
   ============================================= */
@media(max-width:860px){
  .nav-links{display:none}
  #hero{grid-template-columns:1fr;padding-top:95px}
  #about .ag{grid-template-columns:1fr}
  .ei{grid-template-columns:1fr}
  .ei-meta{padding-left:22px;padding-bottom:10px}
  .vg{grid-template-columns:1fr}
  #contact .cg{grid-template-columns:1fr}
  section{padding:70px 5%}
  footer{flex-direction:column;text-align:center}
}