:root {
  --gold:#C9963A; --gold-light:#E8C06A; --gold-pale:#F5E6C3;
  --terra:#B85C38; --terra-dk:#7A2E10;
  --grn:#1B4A3A; --grn-mid:#2D6B55;
  --cream:#FAF5EC; --ink:#1A1208; --ink-m:#5C4A2A;
  --pat:rgba(201,150,58,0.09);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:'Archivo',sans-serif;overflow-x:hidden}

/* particles */
#cvs{position:fixed;inset:0;z-index:0;pointer-events:none}

/* grid bg */
.gbg{position:fixed;inset:0;z-index:0;pointer-events:none;
background-image:repeating-linear-gradient(0deg,transparent,transparent 39px,var(--pat) 40px),
repeating-linear-gradient(90deg,transparent,transparent 39px,var(--pat) 40px)}

/* cursor — hidden on touch devices */
.cd{position:fixed;width:8px;height:8px;background:var(--gold);border-radius:50%;
pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
.cr{position:fixed;width:32px;height:32px;border:1.5px solid var(--gold);border-radius:50%;
pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.55;transition:all .1s ease-out}
@media(pointer:coarse){.cd,.cr{display:none}}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;
padding:1.2rem 4rem;background:rgba(250,245,236,.9);backdrop-filter:blur(16px);
border-bottom:1px solid rgba(201,150,58,.18);transform:translateY(-100%);
animation:navIn .7s .3s ease forwards}
@keyframes navIn{to{transform:translateY(0)}}
.logo{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--gold);letter-spacing:.05em}
.logo span{color:var(--terra)}
.nl{display:flex;gap:2.5rem;list-style:none}
.nl a{font-size:.78rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-m);
text-decoration:none;font-family:'DM Mono',monospace;transition:color .2s;position:relative}
.nl a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--gold);transition:width .3s}
.nl a:hover,.nl a[aria-current="page"]{color:var(--gold)}
.nl a:hover::after,.nl a[aria-current="page"]::after{width:100%}

/* hamburger button */
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.4rem;
background:none;border:none;z-index:200;flex-shrink:0}
.ham span{display:block;width:24px;height:2px;background:var(--ink);transition:all .3s}
.ham.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* mobile nav overlay */
.mnav{position:fixed;inset:0;background:var(--cream);z-index:150;display:flex;flex-direction:column;
align-items:center;justify-content:center;gap:2.5rem;
transform:translateX(100%);transition:transform .35s ease;pointer-events:none}
.mnav.open{transform:translateX(0);pointer-events:all}
.mnav a{font-family:'DM Mono',monospace;font-size:1.1rem;font-weight:600;letter-spacing:.2em;
text-transform:uppercase;color:var(--ink-m);text-decoration:none;transition:color .2s}
.mnav a:hover{color:var(--gold)}

/* scroll-to-top */
.stt{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;background:var(--gold);
border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
font-size:1.1rem;z-index:90;opacity:0;transform:translateY(10px);
transition:opacity .3s,transform .3s;pointer-events:none;color:var(--ink);
clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%)}
.stt.vis{opacity:1;transform:none;pointer-events:all}
.stt:hover{background:var(--gold-light)}

/* hero */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:7rem 5rem 4rem;overflow:hidden}
.hcross{position:absolute;right:-60px;top:50%;transform:translateY(-50%);width:580px;height:580px;opacity:.055;
animation:spin 60s linear infinite}
@keyframes spin{to{transform:translateY(-50%) rotate(360deg)}}
.hc{position:relative;z-index:1;max-width:720px}
.hl{font-family:'DM Mono',monospace;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;
color:var(--terra);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;
opacity:0;animation:fu .6s .5s ease forwards}
.hl::before{content:'';display:inline-block;width:32px;height:1px;background:var(--terra)}
.hn{font-family:'Playfair Display',serif;font-size:clamp(3.5rem,8vw,6.5rem);font-weight:900;line-height:1;color:var(--ink);
opacity:0;animation:fu .7s .65s ease forwards}
.hn .gld{color:var(--gold)}
.hn .str{position:relative;color:var(--terra);display:inline-block}
.hn .str::after{content:'';position:absolute;bottom:6px;left:0;right:0;height:3px;background:var(--grn);opacity:.5;
transform:scaleX(0);transform-origin:left;animation:lg .8s 1.6s ease forwards}
@keyframes lg{to{transform:scaleX(1)}}
.hr{font-family:'DM Mono',monospace;font-size:1rem;color:var(--grn);margin:1rem 0 1.5rem;
opacity:0;animation:fu .6s .85s ease forwards}
.htags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem;opacity:0;animation:fu .6s 1s ease forwards}
.htag{font-family:'DM Mono',monospace;font-size:.68rem;padding:.28rem .75rem;letter-spacing:.07em;
background:rgba(201,150,58,.11);color:var(--terra-dk);border:1px solid rgba(201,150,58,.3)}
.hcta{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fu .6s 1.15s ease forwards}
.bp{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2.2rem;background:var(--gold);color:var(--ink);
font-family:'DM Mono',monospace;font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
text-decoration:none;cursor:pointer;transition:all .25s;border:none;
clip-path:polygon(10px 0%,100% 0%,calc(100% - 10px) 100%,0% 100%)}
.bp:hover{background:var(--gold-light);transform:translateY(-3px)}
.bo{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2.2rem;background:transparent;color:var(--grn);
font-family:'DM Mono',monospace;font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
text-decoration:none;border:1.5px solid var(--grn);cursor:pointer;transition:all .25s}
.bo:hover{background:var(--grn);color:var(--cream)}

/* stripe */
.stripe{height:6px;position:relative;z-index:1;
background:linear-gradient(90deg,var(--terra) 33%,var(--gold) 33% 66%,var(--grn) 66%);
transform:scaleX(0);transform-origin:left;animation:strv 1s 1.5s ease forwards}
@keyframes strv{to{transform:scaleX(1)}}

/* sections */
section{position:relative;z-index:1;padding:7rem 5rem}
.sl{font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.st{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:700;color:var(--ink);line-height:1.1;margin-bottom:3rem}
.st .a{color:var(--terra)}

/* about */
#about{background:var(--grn);color:var(--cream)}
#about .st{color:var(--cream)} #about .sl{color:var(--gold-light)} #about .a{color:var(--gold-light)}
.ag{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.at p{font-size:1.05rem;line-height:1.9;color:rgba(250,245,236,.82);margin-bottom:1.2rem}
.srow{display:flex;gap:3rem;margin-top:2.5rem;flex-wrap:wrap}
.sn{font-family:'Playfair Display',serif;font-size:2.8rem;font-weight:900;color:var(--gold);line-height:1}
.slab{font-family:'DM Mono',monospace;font-size:.68rem;color:rgba(250,245,236,.6);letter-spacing:.1em;text-transform:uppercase;margin-top:.2rem}
.lr{display:flex;gap:1.2rem;flex-wrap:wrap;margin-top:2rem}
.lp{display:flex;align-items:center;gap:.6rem;padding:.5rem 1rem;
background:rgba(255,255,255,.06);border:1px solid rgba(201,150,58,.28);
font-family:'DM Mono',monospace;font-size:.74rem;color:var(--gold-light);letter-spacing:.07em;
transition:background .2s,transform .2s}
.lp:hover{background:rgba(201,150,58,.15);transform:translateY(-2px)}
.af{display:flex;flex-direction:column;gap:1.2rem}

/* profile avatar */
.avatar{width:88px;height:88px;background:var(--gold);border-radius:50%;
display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;
font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:900;color:var(--ink);
border:3px solid rgba(201,150,58,.5);flex-shrink:0;letter-spacing:.05em}

.fc{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem 1.4rem;
background:rgba(255,255,255,.05);border-left:3px solid var(--gold);transition:all .2s}
.fc:hover{border-color:var(--gold-light);background:rgba(255,255,255,.09)}
.fi{font-size:1.2rem;margin-top:2px}
.fc h4{font-family:'DM Mono',monospace;font-size:.68rem;letter-spacing:.1em;color:var(--gold-light);text-transform:uppercase;margin-bottom:.3rem}
.fc p{font-size:.9rem;color:rgba(250,245,236,.75);margin:0}

/* skills */
#skills{background:var(--cream)}
.sg{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.sc{padding:1.8rem;background:white;border:1px solid rgba(201,150,58,.2);position:relative;overflow:hidden;
transition:transform .3s,border-color .3s,box-shadow .3s}
.sc::before{content:'';position:absolute;top:0;left:0;height:3px;width:0;background:var(--gold);transition:width .4s}
.sc:hover{transform:translateY(-5px);border-color:var(--gold);box-shadow:0 12px 32px rgba(201,150,58,.12)}
.sc:hover::before{width:100%}
.si{width:44px;height:44px;background:var(--gold-pale);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem}
.sc h3{font-family:'Playfair Display',serif;font-size:1.05rem;margin-bottom:.8rem;color:var(--ink)}
.tgs{display:flex;flex-wrap:wrap;gap:.4rem}
.tg{font-family:'DM Mono',monospace;font-size:.67rem;padding:.27rem .6rem;background:var(--gold-pale);color:var(--terra-dk);letter-spacing:.04em;transition:all .2s}
.tg:hover{background:var(--gold);color:white}
.tg.g{background:rgba(27,74,58,.1);color:var(--grn)}.tg.g:hover{background:var(--grn);color:white}

/* experience */
#experience{background:linear-gradient(140deg,var(--ink) 0%,#2C1A08 100%);color:var(--cream)}
#experience .st{color:var(--cream)} #experience .sl{color:var(--gold)} #experience .a{color:var(--gold)}
.ei{display:grid;grid-template-columns:160px 1fr;gap:2rem;padding:2.5rem 0;border-bottom:1px solid rgba(201,150,58,.12);position:relative}
.edot{position:absolute;left:160px;top:2.8rem;width:14px;height:14px;background:var(--gold);transform:rotate(45deg) translateX(-7px);transition:background .2s}
.ei:hover .edot{background:var(--gold-light)}
.edate{font-family:'DM Mono',monospace;font-size:.72rem;color:var(--gold);letter-spacing:.1em;text-align:right;padding-top:4px}
.ec h3{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--cream);margin-bottom:.2rem}
.eco{font-size:.82rem;color:var(--gold-light);margin-bottom:.75rem;font-family:'DM Mono',monospace}
.ec p{font-size:.93rem;line-height:1.75;color:rgba(250,245,236,.68)}

/* projects */
#projects{background:var(--cream)}
.pf{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2.5rem}
.fb{font-family:'DM Mono',monospace;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:.45rem 1.1rem;
background:transparent;color:var(--ink-m);border:1px solid rgba(201,150,58,.3);cursor:pointer;transition:all .2s}
.fb:hover,.fb.active{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.pg{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.8rem}
.pc{background:white;border:1px solid rgba(201,150,58,.18);overflow:hidden;position:relative;
transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .3s}
.pc:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 16px 40px rgba(26,18,8,.1)}
.pb_{height:5px}
.pb_.c{background:linear-gradient(90deg,#6A3FA0,var(--gold))}
.pb_.g{background:linear-gradient(90deg,var(--grn),#4CAF80)}
.pb_.t{background:linear-gradient(90deg,var(--terra-dk),var(--terra))}
.pb_.b{background:linear-gradient(90deg,#1565C0,#42A5F5)}
.pb_.o{background:linear-gradient(90deg,#E65100,var(--gold))}
.pbd{padding:1.6rem}
.pn{font-family:'DM Mono',monospace;font-size:.67rem;color:var(--gold);letter-spacing:.2em;margin-bottom:.6rem}
.pbd h3{font-family:'Playfair Display',serif;font-size:1.2rem;margin-bottom:.6rem;color:var(--ink)}
.pbd p{font-size:.88rem;line-height:1.7;color:var(--ink-m);margin-bottom:1.1rem}
.plnks{display:flex;gap:.6rem;margin-top:1rem}
.pla{font-family:'DM Mono',monospace;font-size:.68rem;padding:.35rem .85rem;letter-spacing:.06em;
text-decoration:none;border:1px solid rgba(201,150,58,.35);color:var(--ink-m);transition:all .2s;display:inline-flex;align-items:center;gap:.3rem}
.pla:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.plb{position:absolute;top:1rem;right:1rem;font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:.05em;
padding:.2rem .5rem;background:var(--gold-pale);color:var(--terra-dk)}

/* education */
#education{background:#F0EAD8}
.el{position:relative;padding-left:2.5rem}
.el::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
background:linear-gradient(to bottom,var(--gold),var(--terra),var(--grn))}
.eit{position:relative;margin-bottom:2.5rem;padding-left:2rem;transition:transform .2s}
.eit:hover{transform:translateX(6px)}
.eit::before{content:'';position:absolute;left:-7px;top:8px;width:12px;height:12px;
background:var(--gold);transform:rotate(45deg);transition:background .2s}
.eit:hover::before{background:var(--terra)}
.eyr{font-family:'DM Mono',monospace;font-size:.7rem;color:var(--terra);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.3rem}
.eit h3{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--ink);margin-bottom:.2rem}
.eit p{font-size:.85rem;color:var(--ink-m)}
.ethdiv{display:flex;align-items:center;gap:1rem;margin:3.5rem 0 2rem}
.ethdiv::before,.ethdiv::after{content:'';flex:1;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
.ethdiv span{color:var(--gold);font-size:1.2rem}
.cg{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.5rem}
.cc{padding:1rem 1.4rem;background:white;border:1px solid rgba(201,150,58,.25);transition:transform .2s,border-color .2s}
.cc:hover{transform:translateY(-3px);border-color:var(--gold)}
.clb{font-family:'DM Mono',monospace;font-size:.63rem;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.3rem}
.cc strong{font-size:.9rem;color:var(--ink)}
.cc p{font-size:.78rem;color:var(--ink-m);margin-top:.2rem}

/* contact */
#contact{background:var(--terra);color:var(--cream);text-align:center}
#contact .st{color:var(--cream)} #contact .sl{color:rgba(250,245,236,.6)}
.cdesc{font-size:1.05rem;line-height:1.8;opacity:.88;max-width:500px;margin:0 auto 3rem}
.cls{display:flex;justify-content:center;gap:1.2rem;flex-wrap:wrap}
.cla{display:flex;align-items:center;gap:.6rem;padding:.9rem 1.6rem;background:rgba(255,255,255,.1);
color:var(--cream);text-decoration:none;font-family:'DM Mono',monospace;font-size:.8rem;letter-spacing:.07em;
border:1px solid rgba(255,255,255,.22);transition:all .25s}
.cla:hover{background:rgba(255,255,255,.22);transform:translateY(-3px)}

/* footer */
footer{position:relative;z-index:1;background:var(--ink);color:rgba(250,245,236,.45);text-align:center;
padding:2rem;font-family:'DM Mono',monospace;font-size:.73rem;letter-spacing:.05em}
footer span{color:var(--gold)}

/* reveal */
.r{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.r.v{opacity:1;transform:none}
.r.lft{transform:translateX(-28px)}.r.rgt{transform:translateX(28px)}
.r.lft.v,.r.rgt.v{transform:none}

/* typed */
#typed::after{content:'|';animation:bl 1s step-end infinite;color:var(--terra)}
@keyframes bl{0%,100%{opacity:1}50%{opacity:0}}
@keyframes fu{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  #cvs{display:none}
}

@media(max-width:768px){
  nav{padding:1rem 1.5rem}
  .nl{display:none}
  .ham{display:flex}
  section{padding:4rem 1.5rem} #hero{padding:6rem 1.5rem 4rem}
  .ag{grid-template-columns:1fr} .ei{grid-template-columns:1fr} .edot{display:none}
  .edate{text-align:left}
  .stt{bottom:1.5rem;right:1.5rem}
  .avatar{margin-left:auto;margin-right:auto}
}
