
/* ─────────────────────────────────────────
   DESIGN TOKENS
───────────────────────────────────────── */
:root {
  --earth:   #243D1A;
  --earth2:  #2D4A22;
  --savanna: #C8983A;
  --sand:    #F0E6CC;
  --dark:    #0E1509;
  --mid:     #4A6741;
  --light:   #F7F3EC;
  --accent:  #D9522A;
  --muted:   #8A9E82;
  --border:  rgba(45,74,34,0.13);
  --max:     860px;
  --fd: 'Playfair Display', Georgia, serif;
  --fb: 'DM Sans', sans-serif;
  --fm: 'Space Mono', monospace;
}

/* ─────────────────────────────────────────
   RESET & BASE
───────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--light);color:var(--dark);font-family:var(--fb);font-weight:300;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}

/* ─────────────────────────────────────────
   LAYOUT
───────────────────────────────────────── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 2rem}
.pt-nav{padding-top:58px}

/* ─────────────────────────────────────────
   PAGE ENTRY ANIMATION
───────────────────────────────────────── */
main{animation:fadeUp .45s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.fade1{animation:fadeUp .55s .08s ease both}
.fade2{animation:fadeUp .55s .18s ease both}
.fade3{animation:fadeUp .55s .28s ease both}
.fade4{animation:fadeUp .55s .38s ease both}
.fade5{animation:fadeUp .55s .48s ease both}

/* ─────────────────────────────────────────
   NAVIGATION
───────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  background:rgba(247,243,236,.93);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.nav__inner{
  max-width:var(--max);margin:0 auto;padding:0 2rem;
  height:58px;display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.nav__logo{font-family:var(--fd);font-size:1.12rem;color:var(--earth);letter-spacing:-.02em;text-decoration:none}
.nav__links{display:flex;gap:.1rem}
.nav__links a{
  font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--mid);padding:.4rem .65rem;border-radius:2px;transition:color .2s,background .2s;
}
.nav__links a:hover,.nav__links a.active{color:var(--accent);background:rgba(217,82,42,.07)}
.nav__socials{display:flex;gap:.4rem}
.sicon{
  width:30px;height:30px;border-radius:50%;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--mid);transition:color .2s,border-color .2s,background .2s;
}
.sicon:hover{color:var(--accent);border-color:var(--accent);background:rgba(217,82,42,.06)}
.sicon svg{width:13px;height:13px;fill:currentColor}

/* ─────────────────────────────────────────
   SHARED COMPONENTS
───────────────────────────────────────── */
/* Section label */
.slabel{
  font-family:var(--fm);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--savanna);display:flex;align-items:center;gap:.8rem;margin-bottom:2.5rem;
}
.slabel::after{content:'';flex:1;height:1px;background:var(--border)}
.slabel--lt::after{background:rgba(200,152,58,.25)}

/* Page header band */
.phead{background:var(--earth);padding:5rem 0 4rem;position:relative;overflow:hidden}
.phead::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(200,152,58,.12) 0%,transparent 70%);pointer-events:none}
.phead .wrap{position:relative;z-index:2}
.phead__tag{font-family:var(--fm);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--savanna);margin-bottom:1rem}
.phead__title{font-family:var(--fd);font-size:clamp(2.2rem,4vw,3.2rem);color:var(--sand);line-height:1.1;letter-spacing:-.02em}
.phead__title em{font-style:italic;color:var(--savanna)}
.phead__desc{font-size:.92rem;color:rgba(240,230,204,.65);margin-top:.8rem;max-width:52ch;line-height:1.7}

/* Buttons */
.btn{display:inline-block;font-family:var(--fm);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;padding:.75rem 1.6rem;border:none;cursor:pointer;transition:all .2s}
.btn:hover{transform:translateY(-2px)}
.btn-dark{background:var(--earth);color:var(--sand)}.btn-dark:hover{background:var(--accent)}
.btn-gold{background:var(--savanna);color:var(--dark)}.btn-gold:hover{background:var(--accent);color:var(--sand)}
.btn-outline{background:transparent;border:1px solid var(--earth);color:var(--earth)}.btn-outline:hover{background:var(--earth);color:var(--sand)}

/* Tag pill */
.tag{font-family:var(--fm);font-size:.55rem;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .6rem;background:rgba(200,152,58,.12);color:var(--savanna)}

/* Pub link */
.pub-link{font-family:var(--fm);font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .8rem;border:1px solid var(--border);color:var(--mid);transition:all .2s}
.pub-link:hover{background:var(--earth);color:var(--sand);border-color:var(--earth)}

/* Social icon large */
.sicon-lg{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--mid);transition:all .2s}
.sicon-lg:hover{color:var(--accent);border-color:var(--accent)}
.sicon-lg svg{width:15px;height:15px;fill:currentColor}

/* Filter buttons */
.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.fbtn{font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:.4rem 1rem;border:1px solid var(--border);background:transparent;color:var(--mid);cursor:pointer;transition:all .2s}
.fbtn:hover,.fbtn.active{background:var(--earth);color:var(--sand);border-color:var(--earth)}

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
.footer{background:var(--dark);padding:2.5rem 0;border-top:1px solid rgba(200,152,58,.12)}
.footer__inner{max-width:var(--max);margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer__logo{font-family:var(--fd);color:var(--sand);font-size:1rem;text-decoration:none}
.footer__socials{display:flex;gap:.45rem}
.footer__si{width:30px;height:30px;border-radius:50%;border:1px solid rgba(200,152,58,.2);display:flex;align-items:center;justify-content:center;color:rgba(240,230,204,.45);transition:all .2s}
.footer__si:hover{color:var(--savanna);border-color:var(--savanna)}
.footer__si svg{width:12px;height:12px;fill:currentColor}
.footer__copy{font-family:var(--fm);font-size:.58rem;letter-spacing:.1em;color:rgba(240,230,204,.3);text-transform:uppercase}

/* ══════════════════════════════════════════
   HOME
══════════════════════════════════════════ */
.hero{min-height:calc(100vh - 58px);display:grid;grid-template-columns:1fr 400px;max-width:var(--max);margin:0 auto;padding:0 2rem;align-items:center}
.hero__l{padding:4rem 3rem 4rem 0}
.hero__tag{font-family:var(--fm);font-size:.6rem;letter-spacing:.2em;color:var(--savanna);text-transform:uppercase;margin-bottom:1.4rem;display:flex;align-items:center;gap:.7rem}
.hero__tag::before{content:'';width:1.8rem;height:1px;background:var(--savanna)}
.hero__name{font-family:var(--fd);font-size:clamp(3rem,5.5vw,4.8rem);line-height:1;color:var(--earth);letter-spacing:-.03em;margin-bottom:.2rem}
.hero__name em{font-style:italic;color:var(--accent)}
.hero__sub{font-size:1rem;color:var(--mid);font-weight:400;margin-bottom:1.5rem;line-height:1.6}
.hero__desc{font-size:.92rem;color:#627558;line-height:1.85;margin-bottom:2rem;max-width:44ch}
.hero__cta{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.hero__link{font-family:var(--fm);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--earth);border-bottom:1px solid var(--earth);padding-bottom:2px;transition:color .2s,border-color .2s;cursor:pointer}
.hero__link:hover{color:var(--accent);border-color:var(--accent)}

.hero__r{height:calc(100vh - 58px);position:relative;overflow:hidden;background:var(--earth)}
.hero__r::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(200,152,58,.18) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(123,175,212,.15) 0%,transparent 50%)}
.hero__grid{position:absolute;inset:0;background-image:linear-gradient(rgba(200,152,58,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(200,152,58,.07) 1px,transparent 1px);background-size:36px 36px}
.hero__map{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:68%;opacity:.15;fill:var(--savanna)}
.hdot{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--savanna);animation:pdot 3s ease-in-out infinite}
@keyframes pdot{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:.9;transform:scale(1.7)}}
.hero__badge{position:absolute;bottom:2.5rem;left:-1.5rem;background:var(--sand);padding:1.2rem 1.6rem;box-shadow:0 16px 48px rgba(0,0,0,.25);max-width:210px;animation:floatB 5s ease-in-out infinite}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero__badge-l{font-family:var(--fm);font-size:.55rem;letter-spacing:.15em;color:var(--savanna);text-transform:uppercase;margin-bottom:.3rem}
.hero__badge-v{font-family:var(--fd);font-size:.92rem;color:var(--earth)}

/* Skills strip */
.skills-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:3.5rem 0;background:white}
.skills-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.skill-block{padding:1.5rem 1.8rem;border-right:1px solid var(--border);transition:background .2s}
.skill-block:last-child{border-right:none}
.skill-block:hover{background:rgba(200,152,58,.04)}
.skill-block__icon{font-size:1.4rem;margin-bottom:.7rem}
.skill-block__name{font-family:var(--fd);font-size:.95rem;color:var(--earth);margin-bottom:.45rem}
.skill-block__tags{display:flex;flex-wrap:wrap;gap:.35rem}
.skill-block__tag{font-family:var(--fm);font-size:.52rem;letter-spacing:.06em;text-transform:uppercase;padding:.2rem .55rem;border:1px solid var(--border);color:var(--mid)}

/* Home sections */
.home-sec{padding:4rem 0}
.home-sec__head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem}
.home-sec__h{font-family:var(--fd);font-size:clamp(1.6rem,2.5vw,2rem);color:var(--earth);letter-spacing:-.02em}
.home-sec__h em{font-style:italic;color:var(--accent)}
.home-sec__more{font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);border-bottom:1px solid var(--border);padding-bottom:2px;cursor:pointer;transition:color .2s,border-color .2s;white-space:nowrap}
.home-sec__more:hover{color:var(--accent);border-color:var(--accent)}

/* Project cards */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.pcard{border:1px solid var(--border);background:white;overflow:hidden;transition:transform .25s,box-shadow .25s;cursor:pointer}
.pcard:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(45,74,34,.1)}
.pcard__top{height:110px;position:relative;overflow:hidden;background:var(--earth);display:flex;align-items:center;justify-content:center}
.pcard__top img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.7;transition:opacity .3s}
.pcard:hover .pcard__top img{opacity:.85}
.pcard__geo{position:absolute;inset:0;background-image:linear-gradient(rgba(200,152,58,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(200,152,58,.07) 1px,transparent 1px);background-size:28px 28px}
.pcard__icon{font-size:2.2rem;position:relative;z-index:2}
.pcard__body{padding:1.2rem 1.3rem}
.pcard__status{font-family:var(--fm);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;color:var(--savanna);margin-bottom:.4rem}
.pcard__title{font-family:var(--fd);font-size:.95rem;color:var(--earth);margin-bottom:.45rem;line-height:1.3}
.pcard__desc{font-size:.8rem;color:var(--muted);line-height:1.6;margin-bottom:.8rem}
.pcard__tech{display:flex;flex-wrap:wrap;gap:.35rem}
.pcard__tech span{font-family:var(--fm);font-size:.52rem;letter-spacing:.06em;text-transform:uppercase;padding:.2rem .55rem;border:1px solid var(--border);color:var(--mid)}

/* Blog cards (home) */
.blog-list{display:flex;flex-direction:column}
.bcard{border-bottom:1px solid var(--border)}
.bcard__inner{display:grid;grid-template-columns:80px 1fr;gap:1.5rem;padding:1.6rem 0;align-items:start;cursor:pointer;transition:background .2s}
.bcard__inner:hover{background:rgba(200,152,58,.04)}
.bcard__date{font-family:var(--fm);font-size:.58rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;line-height:1.6;padding-top:.2rem}
.bcard__date strong{display:block;font-size:.65rem;color:var(--savanna);font-weight:700}
.bcard__tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.45rem}
.bcard__title{font-family:var(--fd);font-size:1.1rem;color:var(--earth);margin-bottom:.35rem;line-height:1.3;transition:color .2s}
.bcard__inner:hover .bcard__title{color:var(--accent)}
.bcard__exc{font-size:.83rem;color:var(--muted);line-height:1.7}
.bcard__meta{display:flex;align-items:center;gap:1rem;margin-top:.5rem}
.bcard__rt{font-size:.75rem;color:var(--muted)}
.bcard__rd{font-family:var(--fm);font-size:.58rem;color:var(--accent);letter-spacing:.06em}

/* Podcast strip */
.pod-strip{background:var(--earth);padding:4rem 0;position:relative;overflow:hidden}
.pod-strip::before{content:'GEO';position:absolute;bottom:-1rem;right:-.5rem;font-family:var(--fd);font-size:10rem;color:rgba(200,152,58,.05);letter-spacing:-.05em;pointer-events:none;line-height:1}
.pod-strip .wrap{position:relative;z-index:2}
.pod-strip .slabel{color:var(--savanna)}
.pod-strip .slabel::after{background:rgba(200,152,58,.25)}
.pod-strip .home-sec__h{color:var(--sand)}
.pod-strip .home-sec__more{color:rgba(240,230,204,.5);border-color:rgba(240,230,204,.2)}
.pod-strip .home-sec__more:hover{color:var(--savanna);border-color:var(--savanna)}

/* Episode rows */
.ep-row{display:grid;grid-template-columns:50px 1fr 40px;gap:1.2rem;padding:1.2rem 0;border-bottom:1px solid rgba(200,152,58,.1);align-items:center;transition:background .2s;cursor:pointer}
.ep-row:last-child{border-bottom:none}
.ep-row:hover{background:rgba(200,152,58,.06)}
.ep-row__num{font-family:var(--fm);font-size:.62rem;color:var(--savanna);text-align:center}
.ep-row__date{font-family:var(--fm);font-size:.55rem;letter-spacing:.08em;color:rgba(240,230,204,.4);text-transform:uppercase;margin-bottom:.25rem}
.ep-row__title{font-family:var(--fd);font-size:.98rem;color:var(--sand);margin-bottom:.25rem}
.ep-row__desc{font-size:.8rem;color:rgba(240,230,204,.5);line-height:1.5}
.ep-play{width:36px;height:36px;border-radius:50%;border:1.5px solid rgba(200,152,58,.4);display:flex;align-items:center;justify-content:center;color:var(--savanna);font-size:.7rem;flex-shrink:0;transition:all .2s}
.ep-row:hover .ep-play{background:var(--savanna);color:var(--dark);border-color:var(--savanna)}

/* ══════════════════════════════════════════
   ABOUT / CV
══════════════════════════════════════════ */
.about-body{padding:3.5rem 0 5rem}
.about-layout{display:grid;grid-template-columns:220px 1fr;gap:4rem;align-items:start}

/* Profile photo - shows image if set, initials fallback if not */
.avatar{width:180px;height:180px;background:var(--earth);overflow:hidden;margin-bottom:1.4rem}
.avatar img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.avatar__init{font-family:var(--fd);font-size:2.5rem;color:var(--sand);background:radial-gradient(ellipse at 40% 40%,rgba(200,152,58,.2) 0%,transparent 70%),var(--earth);width:100%;height:100%;display:flex;align-items:center;justify-content:center}

.sb__name{font-family:var(--fd);font-size:1.15rem;color:var(--earth);margin-bottom:.2rem}
.sb__title{font-size:.82rem;color:var(--mid);line-height:1.55;margin-bottom:1.2rem}
.sb__socials{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:1.5rem}
.sb__info{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.8rem}
.sb__info-item{display:flex;gap:.6rem;align-items:flex-start;font-size:.8rem;color:var(--mid)}
.sb__info-icon{font-size:.9rem;min-width:18px}

/* ── Photo grid (adventures / life section) ── */
.photo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:160px;
  gap:8px;
  margin-top:1.5rem;
}
.photo-grid__item{
  overflow:hidden;background:var(--earth);position:relative;cursor:pointer;
}
.photo-grid__item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;display:block;
}
.photo-grid__item:hover img{transform:scale(1.05)}
/* Size variants - apply to specific grid items */
.photo-grid__item--wide{grid-column:span 2}
.photo-grid__item--tall{grid-row:span 2}
.photo-grid__item--large{grid-column:span 2;grid-row:span 2}
/* Placeholder shown when no image URL set */
.photo-grid__item__ph{
  width:100%;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:.4rem;
  background:var(--earth);opacity:.5;
}
.photo-grid__item__ph span{font-size:1.6rem}
.photo-grid__item__ph p{font-family:var(--fm);font-size:.52rem;letter-spacing:.1em;color:var(--sand);text-transform:uppercase}
/* Caption overlay on hover */
.photo-grid__item__cap{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent,rgba(14,21,9,.75));
  padding:.6rem .8rem;font-size:.75rem;color:var(--sand);
  opacity:0;transition:opacity .3s;line-height:1.4;
}
.photo-grid__item:hover .photo-grid__item__cap{opacity:1}

@media(max-width:760px){
  .photo-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .photo-grid__item--large{grid-column:span 2;grid-row:span 1}
}
.cv-sec{margin-bottom:3rem}
.cv-sec__title{font-family:var(--fd);font-size:1.2rem;color:var(--earth);margin-bottom:1.2rem;padding-bottom:.5rem;border-bottom:2px solid var(--savanna)}
.cv-intro{font-size:.93rem;color:#5a6e52;line-height:1.88}
.cv-entry{display:grid;grid-template-columns:110px 1fr;gap:1.5rem;padding:1.2rem 0;border-bottom:1px solid var(--border)}
.cv-entry__period{font-family:var(--fm);font-size:.56rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;line-height:1.5;padding-top:.1rem}
.cv-entry__year{display:block;font-size:.62rem;color:var(--savanna);font-weight:700;margin-bottom:.1rem}
.cv-entry__role{font-family:var(--fd);font-size:1rem;color:var(--earth);margin-bottom:.2rem}
.cv-entry__place{font-size:.82rem;color:var(--mid);margin-bottom:.45rem}
.cv-entry__bullets{font-size:.82rem;color:var(--muted);line-height:1.75;margin-left:1rem}
.cv-entry__bullets li{margin-bottom:.2rem;list-style:disc}
.skills-block{margin-bottom:1.5rem}
.skills-block__label{font-family:var(--fm);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--savanna);margin-bottom:.65rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{font-size:.8rem;padding:.35rem .9rem;border:1px solid var(--border);color:var(--mid);background:white}

/* ══════════════════════════════════════════
   BLOG LIST
══════════════════════════════════════════ */
.blog-body{padding:3.5rem 0 5rem}
.blog-full-list{display:flex;flex-direction:column}
.bitem{display:grid;grid-template-columns:90px 1fr;gap:1.5rem;padding:1.8rem 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s;align-items:start}
.bitem:hover{background:rgba(200,152,58,.04)}
.bitem__date{font-family:var(--fm);font-size:.58rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;line-height:1.6;padding-top:.2rem}
.bitem__date strong{display:block;font-size:.65rem;color:var(--savanna);font-weight:700}
.bitem__tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.5rem}
.bitem__title{font-family:var(--fd);font-size:1.2rem;color:var(--earth);margin-bottom:.4rem;line-height:1.3;transition:color .2s}
.bitem:hover .bitem__title{color:var(--accent)}
.bitem__exc{font-size:.85rem;color:var(--muted);line-height:1.7}
.bitem__meta{display:flex;align-items:center;gap:1rem;margin-top:.6rem;font-size:.75rem;color:var(--muted)}
.bitem__rd{font-family:var(--fm);font-size:.6rem;color:var(--accent);letter-spacing:.06em}

/* ══════════════════════════════════════════
   BLOG POST
══════════════════════════════════════════ */
.post-header{background:var(--earth);padding:5rem 0 4rem;position:relative;overflow:hidden}
.post-header::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 80%,rgba(200,152,58,.12) 0%,transparent 60%);pointer-events:none}
.post-header .wrap{position:relative;z-index:2}
.post-back{font-family:var(--fm);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--savanna);display:inline-flex;align-items:center;gap:.4rem;margin-bottom:1.5rem;cursor:pointer;transition:gap .2s}
.post-back:hover{gap:.7rem}
.post-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}
.post-title-h{font-family:var(--fd);font-size:clamp(1.8rem,3.5vw,2.8rem);color:var(--sand);line-height:1.2;letter-spacing:-.02em;margin-bottom:1rem}
.post-meta{display:flex;gap:1.5rem;font-family:var(--fm);font-size:.6rem;letter-spacing:.08em;color:rgba(240,230,204,.5)}
.post-body{padding:3.5rem 0 5rem}
.post-layout{display:grid;grid-template-columns:1fr 190px;gap:4rem;align-items:start}
.post-content{max-width:66ch}
.post-content h2{font-family:var(--fd);font-size:1.5rem;color:var(--earth);margin:2.5rem 0 1rem}
.post-content h3{font-family:var(--fd);font-size:1.15rem;color:var(--earth2);margin:2rem 0 .7rem}
.post-content p{font-size:.95rem;line-height:1.9;color:#4a5e40;margin-bottom:1.2rem}
.post-content a{color:var(--accent);border-bottom:1px solid rgba(217,82,42,.3)}
.post-content blockquote{border-left:3px solid var(--savanna);padding:1rem 1.5rem;margin:2rem 0;background:rgba(200,152,58,.06);font-family:var(--fd);font-style:italic;font-size:1.05rem;color:var(--earth)}
.post-content ul,.post-content ol{margin:1rem 0 1.2rem 1.2rem}
.post-content li{font-size:.93rem;line-height:1.8;color:#4a5e40;margin-bottom:.3rem;list-style:disc}
.post-content ol li{list-style:decimal}
.post-content .callout{background:var(--earth);color:var(--sand);padding:1.4rem 1.8rem;margin:2rem 0;font-size:.9rem;line-height:1.8}
.post-content .callout strong{color:var(--savanna)}
.post-sidebar{position:sticky;top:76px}
.sidebar-card{background:white;border:1px solid var(--border);padding:1.4rem;margin-bottom:1.2rem}
.sidebar-card__label{font-family:var(--fm);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--savanna);margin-bottom:.8rem}
.toc-list li+li{margin-top:.5rem}
.toc-list a{font-size:.82rem;color:var(--mid);padding-left:.6rem;border-left:2px solid transparent;display:block;transition:color .2s,border-color .2s}
.toc-list a:hover{color:var(--accent);border-left-color:var(--savanna)}
.toc-list a.toc-active{color:var(--accent);border-left-color:var(--savanna);font-weight:500}
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:3.5rem;padding-top:2rem;border-top:1px solid var(--border)}
.pnav-item{border:1px solid var(--border);padding:1.2rem;cursor:pointer;transition:border-color .2s}
.pnav-item:hover{border-color:var(--savanna)}
.pnav-dir{font-family:var(--fm);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem}
.pnav-title{font-family:var(--fd);font-size:.9rem;color:var(--earth);line-height:1.3}
.pnav-item--next{text-align:right}

/* ══════════════════════════════════════════
   PUBLICATIONS
══════════════════════════════════════════ */
.pub-body{padding:3.5rem 0 5rem}
.pub-year-group{margin-bottom:3rem}
.pub-year{font-family:var(--fd);font-size:2.5rem;color:rgba(45,74,34,.1);font-style:italic;margin-bottom:1.2rem;letter-spacing:-.02em;line-height:1}
.pub-item{display:grid;grid-template-columns:4px 1fr;gap:1.5rem;padding:1.5rem 0;border-bottom:1px solid var(--border);align-items:start}
.pub-item__line{background:transparent;transition:background .25s;width:4px;margin-top:.3rem;border-radius:2px}
.pub-item:hover .pub-item__line{background:var(--savanna)}
.pub-item__type{font-family:var(--fm);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:var(--savanna);margin-bottom:.35rem}
.pub-item__title{font-family:var(--fd);font-size:1.05rem;color:var(--earth);margin-bottom:.4rem;line-height:1.35}
.pub-item__authors{font-size:.82rem;color:var(--muted);margin-bottom:.3rem;font-style:italic}
.pub-item__authors strong{color:var(--mid);font-style:normal}
.pub-item__venue{font-size:.82rem;color:var(--mid);margin-bottom:.7rem}
.pub-item__links{display:flex;gap:.6rem;flex-wrap:wrap}

/* ══════════════════════════════════════════
   PROJECTS PAGE
══════════════════════════════════════════ */
.proj-body{padding:3.5rem 0 5rem}
.proj-full-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.pcard-lg .pcard__top{height:130px}
.pcard-lg .pcard__body{padding:1.5rem 1.6rem}
.pcard-lg .pcard__title{font-size:1.05rem}
.pcard-lg .pcard__desc{font-size:.83rem}

/* ══════════════════════════════════════════
   PODCAST PAGE
══════════════════════════════════════════ */
.pod-hero{background:var(--earth);padding:5rem 0 4rem;position:relative;overflow:hidden}
.pod-hero::before{content:'GEOSPATIALLY';position:absolute;bottom:-1.5rem;right:-1rem;font-family:var(--fd);font-size:9rem;color:rgba(200,152,58,.05);letter-spacing:-.05em;pointer-events:none;line-height:1}
.pod-hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.pod-hero__tag{font-family:var(--fm);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--savanna);margin-bottom:1rem}
.pod-hero__title{font-family:var(--fd);font-size:clamp(2rem,3.5vw,3rem);color:var(--sand);line-height:1.15;margin-bottom:1rem;letter-spacing:-.02em}
.pod-hero__title em{color:var(--savanna)}
.pod-hero__desc{font-size:.9rem;line-height:1.85;color:rgba(240,230,204,.65);margin-bottom:1.5rem}
.listen-links{display:flex;flex-wrap:wrap;gap:.7rem}
.lbtn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--fm);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;padding:.6rem 1.2rem;border:1px solid rgba(200,152,58,.4);color:var(--sand);transition:all .2s}
.lbtn:hover{background:var(--savanna);border-color:var(--savanna);color:var(--dark)}
.pod-art{background:rgba(200,152,58,.1);border:1px solid rgba(200,152,58,.2);height:260px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.pod-art__inner{text-align:center}
.pod-art__icon{font-size:3.5rem;margin-bottom:.7rem}
.pod-art__title{font-family:var(--fd);font-size:1.3rem;color:var(--sand)}
.pod-art__sub{font-family:var(--fm);font-size:.6rem;letter-spacing:.15em;color:var(--savanna);text-transform:uppercase;margin-top:.3rem}
.waves{display:flex;align-items:center;gap:3px;margin:.8rem auto 0;justify-content:center}
.wave{width:3px;background:var(--savanna);border-radius:2px;animation:wv 1.2s ease-in-out infinite}
.wave:nth-child(1){height:10px;animation-delay:0s}.wave:nth-child(2){height:20px;animation-delay:.1s}
.wave:nth-child(3){height:14px;animation-delay:.2s}.wave:nth-child(4){height:24px;animation-delay:.3s}
.wave:nth-child(5){height:16px;animation-delay:.15s}.wave:nth-child(6){height:10px;animation-delay:.25s}
@keyframes wv{0%,100%{transform:scaleY(.5)}50%{transform:scaleY(1)}}
.ep-body{padding:3.5rem 0 5rem}
.ep-full-row{display:grid;grid-template-columns:52px 1fr 42px;gap:1.5rem;padding:1.5rem 0;border-bottom:1px solid var(--border);align-items:center;transition:background .2s}
.ep-full-row:hover{background:rgba(200,152,58,.04)}
.ep-full-row__num{font-family:var(--fm);font-size:.65rem;color:var(--savanna);text-align:center}
.ep-full-row__date{font-family:var(--fm);font-size:.55rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-bottom:.3rem}
.ep-full-row__title{font-family:var(--fd);font-size:1rem;color:var(--earth);margin-bottom:.25rem}
.ep-full-row__desc{font-size:.82rem;color:var(--muted);line-height:1.55}
.ep-full-play{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--earth);display:flex;align-items:center;justify-content:center;color:var(--earth);font-size:.75rem;flex-shrink:0;transition:all .2s;text-decoration:none}
.ep-full-row:hover .ep-full-play{background:var(--earth);color:var(--sand)}

/* ══════════════════════════════════════════
   CONTACT
══════════════════════════════════════════ */
.contact-body{padding:3.5rem 0 5rem}
.contact-layout{display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:start}
.contact-heading{font-family:var(--fd);font-size:1.8rem;color:var(--earth);margin-bottom:1rem;line-height:1.25}
.contact-text{font-size:.92rem;color:var(--muted);line-height:1.85;margin-bottom:2rem}
.contact-links{display:flex;flex-direction:column}
.clink{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border);transition:all .2s;color:var(--earth)}
.clink:hover{padding-left:.5rem;color:var(--accent)}
.clink__icon{width:38px;height:38px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .2s}
.clink__icon svg{width:14px;height:14px;fill:currentColor}
.clink:hover .clink__icon{border-color:var(--accent)}
.clink__label{font-family:var(--fm);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.1rem}
.clink__val{font-size:.88rem}
.clink:hover .clink__val{color:var(--accent)}
.form-card{background:white;padding:2rem;border:1px solid var(--border)}
.form-card__title{font-family:var(--fd);font-size:1.1rem;color:var(--earth);margin-bottom:1.5rem}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}
.fl{font-family:var(--fm);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mid)}
.fi{background:var(--light);border:1px solid var(--border);padding:.72rem .9rem;font-family:var(--fb);font-size:.88rem;color:var(--dark);outline:none;transition:border-color .2s,background .2s;width:100%}
.fi:focus{border-color:var(--savanna);background:white}
textarea.fi{resize:vertical;min-height:110px}
.success-msg{background:rgba(45,74,34,.08);border-left:3px solid var(--earth);padding:1rem 1.2rem;font-size:.88rem;color:var(--earth);margin-bottom:1.5rem;display:none}
.success-msg.show{display:block}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
/* ─── HAMBURGER BUTTON ─── */
.nav__burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;cursor:pointer;padding:4px;border-radius:2px;
  background:none;border:none;flex-shrink:0;
}
.nav__burger span{
  display:block;height:1.5px;background:var(--earth);
  transition:transform .3s,opacity .3s,width .3s;transform-origin:center;
}
.nav__burger span:nth-child(2){width:70%}
.nav__burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0;width:100%}
.nav__burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ─── MOBILE DRAWER ─── */
.nav__drawer{
  position:fixed;top:58px;left:0;right:0;bottom:0;z-index:299;
  background:rgba(247,243,236,.98);backdrop-filter:blur(16px);
  display:flex;flex-direction:column;padding:2rem;
  transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}
.nav__drawer.open{transform:translateX(0)}
.nav__drawer a{
  font-family:var(--fm);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--mid);padding:1.1rem 0;border-bottom:1px solid var(--border);
  text-align:left;width:100%;transition:color .2s,padding-left .2s;
}
.nav__drawer a:hover,.nav__drawer a.active{color:var(--accent);padding-left:.5rem}
.nav__drawer__socials{display:flex;gap:.6rem;margin-top:2rem}

@media(max-width:760px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .hero{grid-template-columns:1fr}
  .hero__r{display:none}
  .hero__l{padding:3rem 0 2rem}
  .skills-grid{grid-template-columns:1fr 1fr}
  .skill-block:nth-child(2){border-right:none}
  .proj-grid,.proj-full-grid{grid-template-columns:1fr}
  .about-layout{grid-template-columns:1fr;gap:2rem}
  .cv-entry{grid-template-columns:1fr;gap:.3rem}
  .bitem,.bcard__inner{grid-template-columns:1fr}
  .bitem__date,.bcard__date{display:flex;gap:.4rem;align-items:baseline}
  .bitem__date strong,.bcard__date strong{display:inline}
  .post-layout{grid-template-columns:1fr}
  .post-sidebar{display:none}
  .post-nav{grid-template-columns:1fr}
  .pod-hero .wrap{grid-template-columns:1fr}
  .pod-art{display:none}
  .ep-full-row,.ep-row{grid-template-columns:44px 1fr 36px;gap:.8rem}
  .contact-layout{grid-template-columns:1fr;gap:2.5rem}
  .frow{grid-template-columns:1fr}
  .footer__inner{flex-direction:column;text-align:center}
}

.nav__drawer a{display:block;text-decoration:none;}
.post-content h2, .post-content h3 { scroll-margin-top: 72px; }