/* ═══════════════════════════════════════════════════════
   DAVID ADENIRAN — PORTFOLIO
   ═══════════════════════════════════════════════════════ */

:root {
  --ink:    #0A0807;
  --ink-2:  #3D3830;
  --ink-3:  #8A837A;
  --cream:  #F5F0E9;
  --cr2:    #EDE8DF;
  --cr3:    #E2DBD0;
  --gold:   #B8943A;
  --gold-l: #D4AF6A;
  --bdr:    rgba(10,8,7,0.1);
  --bdr2:   rgba(10,8,7,0.16);
  --serif:  'Bodoni Moda', Georgia, serif;
  --sans:   'Space Grotesk', system-ui, sans-serif;
  --ease:   cubic-bezier(0.76, 0, 0.24, 1);
  --eout:   cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:var(--sans);font-weight:300;overflow-x:hidden;cursor:none;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
ul{list-style:none}
::selection{background:var(--ink);color:var(--cream)}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--ink-3)}
/* grain */
body::after{content:'';position:fixed;inset:0;z-index:9970;pointer-events:none;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:160px}


/* ════════════════════════════════════
   PRELOADER
   ════════════════════════════════════ */
#preloader{
  position:fixed;inset:0;z-index:9999;
  background:var(--ink);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:12px;
  transition:transform 1.2s var(--ease);
}
#preloader.done{transform:translateY(-100%)}

.pre-letters{
  display:flex;gap:3px;overflow:hidden;
}
.pre-letters span{
  font-family:var(--serif);
  font-size:clamp(2.8rem,8vw,7.5rem);
  font-weight:300;color:var(--cream);
  display:inline-block;
  transform:translateY(105%);opacity:0;
  transition:transform .7s var(--eout),opacity .5s ease;
}
.pre-letters span.up{transform:translateY(0);opacity:1}

.pre-sub{
  font-size:.65rem;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(245,240,233,.3);
  opacity:0;transition:opacity .6s ease .9s;
}
.pre-sub.up{opacity:1}

.pre-foot{
  position:absolute;bottom:40px;left:0;right:0;
  padding:0 56px;display:flex;align-items:center;gap:14px;
}
.pre-track{flex:1;height:1px;background:rgba(245,240,233,.1);overflow:hidden}
.pre-bar{height:100%;width:0;background:linear-gradient(90deg,transparent,var(--gold),.7)}
.pre-num{font-family:var(--serif);font-size:.9rem;color:rgba(245,240,233,.35);min-width:28px;text-align:right}


/* ════════════════════════════════════
   CURSOR  — two separate fixed elements
   ════════════════════════════════════ */
#curDot{
  position:fixed;top:0;left:0;
  width:6px;height:6px;
  background:var(--gold);
  border-radius:50%;
  pointer-events:none;
  z-index:9990;
  transform:translate(-50%,-50%);
  transition:width .15s,height .15s,opacity .3s;
}
#curRing{
  position:fixed;top:0;left:0;
  width:40px;height:40px;
  border:1.5px solid var(--gold);
  border-radius:50%;
  pointer-events:none;
  z-index:9989;
  transform:translate(-50%,-50%);
  display:flex;align-items:center;justify-content:center;
  transition:width .35s var(--ease),height .35s var(--ease),background .3s,border-color .3s;
}
#curLabel{
  font-size:.5rem;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--cream);
  opacity:0;white-space:nowrap;
  transition:opacity .25s;
  position:absolute;
}
body.cur-hover #curRing{width:52px;height:52px}
body.cur-big   #curRing{width:72px;height:72px;background:var(--gold);border-color:var(--gold)}
body.cur-big   #curDot {opacity:0}
body.cur-big   #curLabel{opacity:1}
body.cur-click #curRing{transform:translate(-50%,-50%) scale(.85)}

@media(hover:none),(pointer:coarse){
  #curDot,#curRing{display:none}
  body{cursor:auto}
}


/* ════════════════════════════════════
   NAV
   ════════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:24px 60px;
  display:flex;align-items:center;justify-content:space-between;
  transition:padding .4s var(--ease),background .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
#nav.stuck{
  padding:13px 60px;
  background:rgba(245,240,233,.93);
  backdrop-filter:blur(18px);
  border-color:var(--bdr);
}
.nav-logo{
  font-family:var(--serif);font-size:1.15rem;font-weight:500;
  letter-spacing:.2em;color:var(--ink);transition:opacity .3s;
}
.nav-logo:hover{opacity:.5}
.nav-links{display:flex;gap:32px}
.nav-links a{
  font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--ink-3);position:relative;padding-bottom:2px;transition:color .3s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-1px;left:0;
  width:0;height:1px;background:var(--ink);
  transition:width .4s var(--ease);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}

.nav-toggle{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;
}
.nav-toggle span{
  display:block;height:1px;background:var(--ink);
  transition:all .4s var(--ease);
}
.nav-toggle span:first-child{width:24px}
.nav-toggle span:last-child{width:16px}
.nav-toggle.open span:first-child{width:22px;transform:translateY(6px) rotate(45deg)}
.nav-toggle.open span:last-child{width:22px;transform:translateY(-1px) rotate(-45deg)}

#navDrawer{
  position:fixed;inset:0;z-index:490;
  background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;
  transform:translateX(100%);transition:transform .6s var(--ease);
}
#navDrawer.open{transform:translateX(0)}
.nd-link{
  font-family:var(--serif);
  font-size:clamp(2.2rem,9vw,4rem);
  font-weight:300;color:var(--cream);letter-spacing:.03em;
  transition:opacity .3s;
}
.nd-link:hover{opacity:.45}

@media(max-width:768px){
  #nav{padding:16px 24px}
  #nav.stuck{padding:12px 24px}
  .nav-links{display:none}
  .nav-toggle{display:flex}
}


/* ════════════════════════════════════
   HERO  — flex column, name centered
   ════════════════════════════════════ */
#hero{
  position:relative;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

/* Split background — absolute, behind everything */
.hero-bg{
  position:absolute;inset:0;
  display:grid;grid-template-columns:1fr 1fr;
  z-index:0;pointer-events:none;
}
.hbg-dark{background:var(--ink)}
.hbg-light{background:var(--cream)}

/* Top row */
.hero-top{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;
  padding-top:76px; /* clear the nav */
  flex-shrink:0;
}
.ht-col{
  padding:36px 52px 28px;
  display:flex;flex-direction:column;gap:10px;
  opacity:0;transform:translateY(18px);
  animation:fadeUp .85s var(--eout) forwards;
}
.ht-col:nth-child(1){animation-delay:.25s}
.ht-col:nth-child(2){animation-delay:.4s}
.col-dark{color:var(--cream)}
.col-light{color:var(--ink)}
.col-tag{
  font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);
}
.col-desc{
  font-family:var(--serif);
  font-size:clamp(.95rem,1.5vw,1.3rem);
  font-weight:300;line-height:1.55;
}
.col-dark .col-desc{color:rgba(245,240,233,.65)}
.col-light .col-desc{color:var(--ink-2)}

/* Name band — flex:1 so it fills remaining vertical space */
.hero-name-band{
  flex:1;
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:16px 0;
  opacity:0;
  animation:fadeIn .5s ease .6s forwards;
}
.hero-firstname{
  font-family:var(--serif);
  font-size:clamp(.9rem,1.6vw,1.4rem);
  font-weight:300;letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:4px;
}
.hero-surname{
  position:relative;
  line-height:.9;
  width:100%;text-align:center;
}
.hn{
  display:block;
  font-family:var(--serif);
  font-size:clamp(3.5rem,13vw,17rem);
  font-weight:300;letter-spacing:-.02em;
  width:100%;text-align:center;
}
/* Left half cream (on dark bg) */
.hn-cream{
  color:var(--cream);
  clip-path:inset(0 50% 0 0);
}
/* Right half ink (on cream bg) — stacked on top via absolute */
.hn-ink{
  color:var(--ink);
  position:absolute;top:0;left:0;
  clip-path:inset(0 0 0 50%);
}

/* Bottom row */
.hero-bottom{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid rgba(245,240,233,.1);
  flex-shrink:0;
}
.hb-col{
  padding:24px 52px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  opacity:0;animation:fadeUp .85s var(--eout) forwards;
}
.hb-col:nth-child(1){animation-delay:.75s}
.hb-col.hb-right{animation-delay:.9s;border-left:1px solid rgba(245,240,233,.1)}

.cred-pill{
  font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);
  border:1px solid rgba(184,148,58,.3);
  padding:6px 12px;
  white-space:nowrap;
}
.dark-pill{border-color:rgba(184,148,58,.22);color:var(--gold)}

.hb-cta{
  font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;
  border-bottom:1px solid;padding-bottom:2px;
  transition:opacity .3s;white-space:nowrap;
}
.light-cta{color:var(--cream);border-color:rgba(245,240,233,.3)}
.light-cta:hover{opacity:.6}
.dark-cta{color:var(--ink);border-color:rgba(10,8,7,.2)}
.dark-cta:hover{opacity:.6}

/* Scroll indicator */
.hero-scroll{
  position:absolute;bottom:28px;left:56px;z-index:3;
  display:flex;align-items:center;gap:12px;
  font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(245,240,233,.4);
  opacity:0;animation:fadeIn 1s ease 1.1s forwards;
}
.hs-track{width:44px;height:1px;background:rgba(245,240,233,.15);overflow:hidden}
.hs-track span{
  display:block;width:100%;height:100%;background:var(--gold);
  transform:translateX(-100%);
  animation:lineFlow 2.4s ease-in-out infinite 1.3s;
}
@keyframes lineFlow{0%{transform:translateX(-100%)}50%{transform:translateX(0)}100%{transform:translateX(100%)}}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{to{opacity:1}}

/* ── Mobile hero ── */
@media(max-width:860px){
  /* Full dark background on mobile */
  .hbg-dark{grid-column:1/-1;background:var(--ink)}
  .hbg-light{display:none}
  .hero-bg{grid-template-columns:1fr}

  .hero-top{grid-template-columns:1fr;padding-top:66px}
  .ht-col{padding:24px 24px 16px}
  .col-light{color:rgba(245,240,233,.9)}
  .col-light .col-desc{color:rgba(245,240,233,.6)}

  /* Name: all cream on dark bg */
  .hn-cream{clip-path:none}
  .hn-ink{display:none}
  .hero-firstname{color:var(--gold-l)}

  .hero-bottom{grid-template-columns:1fr}
  .hb-col{padding:16px 24px}
  .hb-col.hb-right{border-left:none;border-top:1px solid rgba(245,240,233,.08)}
  .dark-cta{color:var(--cream);border-color:rgba(245,240,233,.25)}
  .hero-scroll{display:none}
}


/* ════════════════════════════════════
   SHARED / UTILITIES
   ════════════════════════════════════ */
.container{max-width:1140px;margin:0 auto;padding:0 60px}
@media(max-width:768px){.container{padding:0 24px}}

.eyebrow{
  display:block;font-size:.64rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--gold);margin-bottom:16px;
}
.sec-title{
  font-family:var(--serif);
  font-size:clamp(2.4rem,4.5vw,4.8rem);
  font-weight:300;line-height:1.06;
  color:var(--ink);margin-bottom:52px;
}
.sec-title em{font-style:italic;color:var(--gold)}

/* clip-path reveal on scroll */
.reveal-clip{
  clip-path:polygon(0 100%,100% 100%,100% 100%,0 100%);
  transition:clip-path .95s var(--ease);
}
.reveal-clip.visible{clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}

/* fade-up reveal on scroll */
.reveal-up{
  opacity:0;transform:translateY(32px);
  transition:opacity .85s var(--eout),transform .85s var(--eout);
}
.reveal-up.visible{opacity:1;transform:translateY(0)}


/* ════════════════════════════════════
   EXPERTISE
   ════════════════════════════════════ */
#expertise{
  padding:clamp(64px,8vw,110px) 0;
  border-top:1px solid var(--bdr);
  border-bottom:1px solid var(--bdr);
}
.exp-grid{
  display:grid;grid-template-columns:1fr 1px 1fr;
  gap:0 52px;align-items:start;
}
.exp-divider{background:var(--bdr);align-self:stretch}
.exp-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}
.exp-num{
  font-family:var(--serif);font-size:.78rem;
  color:var(--gold);letter-spacing:.14em;margin-top:8px;flex-shrink:0;
}
.exp-header h3{
  font-family:var(--serif);font-size:clamp(1.7rem,2.8vw,2.6rem);
  font-weight:300;line-height:1.12;color:var(--ink);
}
.exp-desc{
  font-size:.88rem;color:var(--ink-3);line-height:1.85;
  margin-bottom:28px;padding-left:34px;
}
.skill-list{padding-left:34px;display:flex;flex-direction:column}
.skill-list li{
  display:flex;align-items:baseline;gap:14px;
  padding:10px 0;border-bottom:1px solid var(--bdr);
}
.skill-list li:last-child{border-bottom:none}
.skill-list span{
  font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);flex-shrink:0;width:84px;
}
.skill-list em{font-style:normal;font-size:.82rem;color:var(--ink-2);line-height:1.5}

@media(max-width:820px){
  .exp-grid{grid-template-columns:1fr;gap:0}
  .exp-divider{height:1px;width:100%;margin:44px 0;align-self:auto}
  .exp-desc,.skill-list{padding-left:0}
}


/* ════════════════════════════════════
   CREDENTIALS
   ════════════════════════════════════ */
#credentials{
  padding:clamp(64px,8vw,110px) 0;
  background:var(--ink);
}
#credentials .eyebrow{color:rgba(184,148,58,.6)}
#credentials .sec-title{color:var(--cream)}
#credentials .sec-title em{color:var(--gold-l)}

.cred-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:rgba(245,240,233,.07);
  border:1px solid rgba(245,240,233,.07);
  margin-bottom:1px;
}
.cred-card{
  background:rgba(255,255,255,.025);
  padding:48px 44px;
  transition:background .4s;
  position:relative;overflow:hidden;
}
.cred-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(184,148,58,.05),transparent 60%);
  opacity:0;transition:opacity .4s;
}
.cred-card:hover{background:rgba(255,255,255,.045)}
.cred-card:hover::after{opacity:1}

.cc-icon{width:48px;height:48px;color:rgba(184,148,58,.55);margin-bottom:24px;transition:color .3s}
.cc-icon svg{width:100%;height:100%}
.cred-card:hover .cc-icon{color:var(--gold-l)}
.cc-org{font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:6px}
.cc-name{
  font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.8rem);
  font-weight:300;color:var(--cream);line-height:1.1;margin-bottom:16px;
}
.cc-desc{font-size:.84rem;color:rgba(245,240,233,.48);line-height:1.8;margin-bottom:22px}
.cc-tags{display:flex;flex-wrap:wrap;gap:8px}
.cc-tags span{
  font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;
  border:1px solid rgba(184,148,58,.2);padding:4px 10px;
  color:rgba(184,148,58,.65);
}

/* Stats */
.stats-row{
  display:flex;align-items:stretch;
  border:1px solid rgba(245,240,233,.07);
  border-top:none;
}
.si{
  flex:1;padding:32px 28px;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:6px;
}
.si-num{
  font-family:var(--serif);font-size:clamp(2rem,3.5vw,3.5rem);
  font-weight:300;color:var(--cream);line-height:1;
  display:flex;align-items:baseline;gap:2px;
}
.si-num span:last-child{font-size:clamp(1.2rem,2vw,2rem);color:var(--gold)}
.si-lbl{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,240,233,.3)}
.si-div{width:1px;background:rgba(245,240,233,.07);flex-shrink:0}

@media(max-width:720px){
  .cred-grid{grid-template-columns:1fr}
  .cred-card{padding:36px 24px}
  .stats-row{flex-wrap:wrap}
  .si{width:50%;border-bottom:1px solid rgba(245,240,233,.07)}
  .si:nth-child(n+5){border-bottom:none}
  .si-div{display:none}
}


/* ════════════════════════════════════
   TAPE
   ════════════════════════════════════ */
.tape{
  overflow:hidden;background:var(--cr2);
  border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);
  padding:14px 0;
}
.tape-track{
  display:flex;align-items:center;gap:36px;
  width:max-content;
  animation:tapeScroll 32s linear infinite;
}
.tape-track span{font-family:var(--serif);font-size:1rem;font-weight:300;color:var(--ink-2);white-space:nowrap;letter-spacing:.05em}
.tape-track b{font-size:.38rem;color:var(--gold);font-weight:400}
.tape:hover .tape-track{animation-play-state:paused}
@keyframes tapeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}


/* ════════════════════════════════════
   PROJECTS
   ════════════════════════════════════ */
#projects{padding:clamp(64px,8vw,110px) 0;border-bottom:1px solid var(--bdr)}

.proj-list{
  padding:0 60px;max-width:1140px;margin:0 auto;
  display:flex;flex-direction:column;
  gap:1px;background:var(--bdr);
  border:1px solid var(--bdr);
}

.proj-row{
  background:var(--cream);
  display:grid;grid-template-columns:340px 1fr auto;
  align-items:stretch;
  transition:background .35s;
}
.proj-row:hover{background:var(--cr2)}

.pr-img{
  height:260px;
  position:relative;overflow:hidden;
  transition:transform .8s var(--ease);
}
.pr-img::after{
  content:'';position:absolute;inset:0;
  background:rgba(10,8,7,.4);opacity:0;transition:opacity .4s;
}
.proj-row:hover .pr-img{transform:scale(1.03)}
.proj-row:hover .pr-img::after{opacity:1}

.grad-1{background:linear-gradient(135deg,#0d1b30,#183268,#2a5ab8)}
.grad-2{background:linear-gradient(135deg,#091409,#1a4020,#317a36)}
.grad-3{background:linear-gradient(135deg,#1c0e04,#5c3010,#a86320)}

.pr-photo{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;
  opacity:0;transition:opacity .4s;
}
.pr-photo[src]:not([src=""]){opacity:1}

.pr-body{padding:36px 44px;display:flex;flex-direction:column;justify-content:center}
.pr-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.pr-tags{display:flex;flex-wrap:wrap;gap:6px}
.pr-tags span{
  font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--gold);border:1px solid rgba(184,148,58,.2);padding:3px 9px;
}
.proj-row:hover .pr-tags span{border-color:rgba(184,148,58,.45)}
.pr-yr{font-size:.68rem;letter-spacing:.1em;color:var(--ink-3)}
.pr-title{
  font-family:var(--serif);
  font-size:clamp(1.5rem,2.4vw,2.5rem);
  font-weight:300;color:var(--ink);line-height:1.1;margin-bottom:12px;
}
.pr-desc{font-size:.84rem;color:var(--ink-3);line-height:1.8;margin-bottom:20px;max-width:420px}
.pr-link{
  font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--ink);border-bottom:1px solid var(--bdr2);padding-bottom:2px;
  transition:color .3s,border-color .3s,letter-spacing .4s var(--ease);
  width:fit-content;
}
.pr-link:hover{color:var(--gold);border-color:var(--gold);letter-spacing:.22em}
.pr-num{
  font-family:var(--serif);font-size:.65rem;color:var(--ink-3);
  letter-spacing:.16em;padding:24px 28px;align-self:flex-start;flex-shrink:0;
}

@media(max-width:860px){
  .proj-list{padding:0 24px}
  .proj-row{grid-template-columns:1fr;grid-template-rows:220px auto auto}
  .pr-img{height:220px}
  .pr-body{padding:24px}
  .pr-num{padding:10px 24px}
}
.proj-private{padding-top:48px;text-align:center}
.private-projects-link{
  font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);border-bottom:1px solid var(--bdr2);padding-bottom:2px;
  transition:color .3s,border-color .3s,letter-spacing .4s var(--ease);
}
.private-projects-link:hover{color:var(--gold);border-color:var(--gold);letter-spacing:.26em}


/* ════════════════════════════════════
   CONTACT
   ════════════════════════════════════ */
#contact{
  padding:clamp(64px,8vw,110px) 0;
  background:var(--cr2);
  border-bottom:1px solid var(--bdr);
}
.contact-inner{
  display:grid;grid-template-columns:1fr 1.15fr;
  gap:72px;align-items:start;
}
.contact-h{
  font-family:var(--serif);
  font-size:clamp(2.5rem,4.5vw,5rem);
  font-weight:300;line-height:1.05;
  color:var(--ink);margin-bottom:20px;
}
.contact-h em{font-style:italic;color:var(--gold)}
.contact-sub{font-size:.88rem;color:var(--ink-3);line-height:1.85;margin-bottom:24px;max-width:400px}
.contact-email{
  display:block;font-family:var(--serif);
  font-size:clamp(1rem,2vw,1.8rem);
  font-weight:400;color:var(--ink);
  border-bottom:1px solid var(--bdr2);padding-bottom:3px;
  width:fit-content;margin-bottom:24px;
  transition:color .3s,border-color .3s;
}
.contact-email:hover{color:var(--gold);border-color:var(--gold)}
.contact-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:28px}
.avail{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-2);border:1px solid var(--bdr);padding:6px 13px;
}
.avail-dot{width:6px;height:6px;border-radius:50%;background:#5cb85c;flex-shrink:0;animation:pulse 2.4s ease infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(92,184,92,.4)}50%{box-shadow:0 0 0 5px rgba(92,184,92,0)}}
.contact-loc{font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}
.socials{display:flex;gap:20px;flex-wrap:wrap}
.soc{
  font-size:.68rem;letter-spacing:.17em;text-transform:uppercase;
  color:var(--ink-3);border-bottom:1px solid transparent;padding-bottom:2px;
  transition:color .3s,border-color .3s;
}
.soc:hover{color:var(--ink);border-color:var(--bdr2)}

/* Form */
.ci-right{display:flex;flex-direction:column;gap:28px}
.field{position:relative}
.field input,.field textarea,.field select{
  width:100%;background:transparent;border:none;
  border-bottom:1px solid var(--bdr2);
  padding:12px 0 9px;
  color:var(--ink);font-family:var(--sans);font-size:.88rem;font-weight:300;
  outline:none;resize:none;transition:border-color .3s;
  -webkit-appearance:none;
}
.field select option{background:var(--cream);color:var(--ink)}
.field input:not(:placeholder-shown)~label,
.field input:focus~label,
.field textarea:not(:placeholder-shown)~label,
.field textarea:focus~label{
  top:-13px;font-size:.56rem;color:var(--gold);letter-spacing:.2em;
}
.field select~.select-label{top:-13px;font-size:.56rem;color:var(--gold);letter-spacing:.2em}
.field label,.field .select-label{
  position:absolute;top:12px;left:0;
  font-size:.82rem;color:var(--ink-3);
  pointer-events:none;
  transition:top .3s var(--ease),font-size .3s,color .3s,letter-spacing .3s;
}
.fl{
  position:absolute;bottom:0;left:0;
  width:0;height:1px;background:var(--gold);
  transition:width .5s var(--ease);
}
.field:focus-within .fl{width:100%}

.send-btn{
  display:inline-flex;align-items:center;gap:10px;align-self:flex-start;
  padding:13px 40px;
  background:var(--ink);color:var(--cream);
  font-family:var(--sans);font-size:.7rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  border:none;cursor:pointer;position:relative;overflow:hidden;
}
.send-btn::before{
  content:'';position:absolute;inset:0;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);
}
.send-btn span,.btn-arr{position:relative;z-index:1}
.send-btn:hover::before{transform:scaleX(1)}
.btn-arr{transition:transform .3s}
.send-btn:hover .btn-arr{transform:translateX(4px)}

@media(max-width:860px){
  .contact-inner{grid-template-columns:1fr;gap:48px}
}


/* ════════════════════════════════════
   FOOTER
   ════════════════════════════════════ */
#footer{background:var(--ink);padding:24px 0}
.foot-row{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:10px;
}
.foot-name{font-family:var(--serif);font-size:1rem;letter-spacing:.2em;color:rgba(245,240,233,.6)}
.foot-copy{font-size:.66rem;letter-spacing:.06em;color:rgba(245,240,233,.28)}
.foot-top{
  font-size:.66rem;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(245,240,233,.35);border-bottom:1px solid rgba(245,240,233,.1);
  padding-bottom:2px;transition:color .3s,border-color .3s;
}
.foot-top:hover{color:var(--cream);border-color:rgba(245,240,233,.4)}
@media(max-width:600px){.foot-row{flex-direction:column;align-items:center;text-align:center}}


/* ════════════════════════════════════
   TOAST NOTIFICATION
   ════════════════════════════════════ */
#toast{
  position:fixed;bottom:36px;left:50%;
  transform:translateX(-50%) translateY(16px);
  background:var(--ink);color:var(--cream);
  padding:14px 32px;
  font-family:var(--sans);font-size:.72rem;font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;
  border-bottom:2px solid var(--gold);
  opacity:0;pointer-events:none;
  z-index:9996;white-space:nowrap;
  transition:opacity .4s var(--eout),transform .4s var(--eout);
}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.error{border-color:#c0392b}
#toast.success{border-color:#5cb85c}

/* Required field asterisk */
label .req{color:var(--gold);font-size:.65em;margin-left:2px}
