:root{
  --ink:#11150f;
  --paper:#f4f1e8;
  --paper-2:#e4ddc9;
  --moss:#2f4429;
  --moss-bright:#5a7a3c;
  --rust:#a83d22;
  --gold:#9a6a14;
  --line:#c7bda3;
  --muted:#3a3f31;
  --muted-2:#4c5142;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Newsreader',Georgia,serif;
  font-size:18px;
  line-height:1.55;
  overflow-x:hidden;
  display:flex;
  flex-direction:column;
  min-height:100vh;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:0.35;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
.wrap{max-width:1120px;margin:0 auto;padding:0 32px;position:relative;z-index:2;width:100%}

/* nav */
nav{position:sticky;top:0;z-index:50;background:rgba(244,241,232,0.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px}
.brand{font-family:'Space Mono',monospace;font-weight:700;font-size:14px;letter-spacing:0.18em;text-transform:uppercase;text-decoration:none;color:var(--ink)}
.navlinks{display:flex;gap:28px}
.navlinks a{font-family:'Space Mono',monospace;font-size:12.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink);text-decoration:none;opacity:0.6;transition:opacity .2s;padding-bottom:2px;border-bottom:2px solid transparent}
.navlinks a:hover{opacity:1}
.navlinks a.active{opacity:1;border-bottom-color:var(--rust)}
@media(max-width:720px){.navlinks{gap:16px}.navlinks a{font-size:11px}}

main{flex:1 0 auto}

/* hero / page head */
.page-head{padding:84px 0 56px;border-bottom:1px solid var(--line)}
.eyebrow{font-family:'Space Mono',monospace;font-size:13px;letter-spacing:0.22em;text-transform:uppercase;color:var(--rust);margin-bottom:24px;display:flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:46px;height:1px;background:var(--rust)}
h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(46px,8vw,104px);line-height:0.94;letter-spacing:-0.02em;margin-bottom:26px}
h1 .l2{display:block;font-style:italic;color:var(--moss)}
.lede{font-size:clamp(19px,2.2vw,23px);max-width:660px;color:var(--muted)}
.lede b{color:var(--ink);font-weight:600}

.page-title{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(40px,7vw,78px);line-height:0.96;letter-spacing:-0.02em;margin-bottom:20px}
.page-title em{font-style:italic;color:var(--moss)}

/* buttons */
.herometa{margin-top:38px;display:flex;flex-wrap:wrap;gap:13px}
.pill{font-family:'Space Mono',monospace;font-size:12.5px;letter-spacing:0.05em;text-transform:uppercase;border:1px solid var(--ink);border-radius:40px;padding:10px 19px;text-decoration:none;color:var(--ink);transition:all .2s;display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.pill:hover{background:var(--ink);color:var(--paper)}
.pill.solid{background:var(--moss);border-color:var(--moss);color:#f4f1e8}
.pill.solid:hover{background:var(--moss-bright);border-color:var(--moss-bright);color:#fff}

/* sections */
section{padding:60px 0;border-top:1px solid var(--line)}
section:first-of-type{border-top:0}
.sectlabel{font-family:'Space Mono',monospace;font-size:12.5px;letter-spacing:0.2em;text-transform:uppercase;color:var(--rust);margin-bottom:12px}
.secthead{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(28px,4.2vw,44px);letter-spacing:-0.01em;line-height:1.04;margin-bottom:36px;max-width:780px}
.secthead em{font-style:italic;color:var(--moss)}

/* about */
.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:54px;align-items:start}
@media(max-width:780px){.about-grid{grid-template-columns:1fr;gap:32px}}
.prose p{font-size:20px;margin-bottom:20px;color:var(--muted)}
.prose p b{color:var(--ink);font-weight:600}

/* fact card: darker bg, light text for contrast */
.factcard{background:var(--moss);border:1px solid var(--moss);border-radius:6px;padding:30px;color:#eef0e6}
.factcard .factrow{padding:16px 0;border-bottom:1px dashed rgba(238,240,230,0.28)}
.factcard .factrow:first-child{padding-top:0}
.factcard .factrow:last-child{border-bottom:0;padding-bottom:0}
.factcard h4{font-family:'Space Mono',monospace;font-size:11.5px;letter-spacing:0.18em;text-transform:uppercase;color:#cdd8a8;margin-bottom:6px}
.factcard .big{font-family:'Fraunces',serif;font-size:21px;font-weight:600;line-height:1.2;color:#fbfbf4}
.factcard .sub{font-size:15px;color:#d7dcc6;margin-top:2px}

/* projects */
.proj{display:grid;grid-template-columns:80px 1fr auto;gap:28px;align-items:baseline;padding:34px 0;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);position:relative;transition:padding-left .3s}
.proj:hover{padding-left:16px}
.proj::after{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--moss);opacity:0.06;transition:width .3s;z-index:-1}
.proj:hover::after{width:100%}
.proj .idx{font-family:'Space Mono',monospace;font-size:14px;color:var(--rust);padding-top:6px}
.proj h3{font-family:'Fraunces',serif;font-size:clamp(23px,3.3vw,32px);font-weight:600;letter-spacing:-0.01em;margin-bottom:10px;line-height:1.06}
.proj p{font-size:17.5px;color:var(--muted);max-width:580px;margin-bottom:14px}
.tags{display:flex;flex-wrap:wrap;gap:8px}
.tag{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:0.04em;text-transform:uppercase;background:var(--paper-2);border:1px solid var(--line);border-radius:3px;padding:5px 10px;color:var(--muted-2)}
.arrow{font-family:'Space Mono',monospace;font-size:22px;align-self:center;opacity:0.4;transition:transform .25s,opacity .25s;color:var(--ink)}
.proj:hover .arrow{transform:translate(4px,-4px);opacity:1;color:var(--rust)}
@media(max-width:680px){.proj{grid-template-columns:1fr;gap:8px}.proj .idx{padding-top:0}.arrow{display:none}}

/* detailed project blocks (work page) */
.projfull{padding:44px 0;border-bottom:1px solid var(--line)}
.projfull:last-child{border-bottom:0}
.projfull .meta{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--rust);margin-bottom:12px}
.projfull h3{font-family:'Fraunces',serif;font-size:clamp(26px,4vw,40px);font-weight:600;letter-spacing:-0.01em;line-height:1.04;margin-bottom:18px}
.projfull .desc{font-size:19px;color:var(--muted);max-width:720px;margin-bottom:18px}
.bullets{list-style:none;max-width:720px;margin-bottom:22px}
.bullets li{position:relative;padding-left:26px;margin-bottom:11px;font-size:17.5px;color:var(--muted)}
.bullets li::before{content:"›";position:absolute;left:0;color:var(--rust);font-weight:700;font-size:20px;line-height:1.2}

/* skills */
.skill-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(max-width:680px){.skill-grid{grid-template-columns:1fr}}
.skillcard{border:1px solid var(--line);border-radius:6px;padding:26px;background:var(--paper)}
.skillcard h4{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--rust);margin-bottom:16px}
.skillcard p{font-size:16px;color:var(--muted);margin-bottom:16px}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{font-family:'Newsreader',serif;font-size:16px;border:1px solid var(--ink);border-radius:40px;padding:5px 15px;background:var(--paper);color:var(--ink)}

/* timeline */
.tl{border-left:2px solid var(--line);margin-left:8px;padding-left:30px}
.tl-item{position:relative;padding-bottom:38px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:-39px;top:6px;width:14px;height:14px;border-radius:50%;background:var(--rust);border:3px solid var(--paper)}
.tl-when{font-family:'Space Mono',monospace;font-size:12.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--moss-bright);margin-bottom:6px}
.tl-item h3{font-family:'Fraunces',serif;font-size:24px;font-weight:600;margin-bottom:6px}
.tl-item .role{font-size:16px;color:var(--muted-2);margin-bottom:12px;font-style:italic}
.tl-item p{font-size:17px;color:var(--muted);max-width:680px}

/* contact */
.contact-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:36px}
@media(max-width:680px){.contact-grid{grid-template-columns:1fr}}
.contactcard{border:1px solid var(--line);border-radius:6px;padding:26px;background:var(--paper);text-decoration:none;display:block;transition:all .2s}
.contactcard:hover{background:var(--moss);border-color:var(--moss)}
.contactcard:hover h4,.contactcard:hover .val{color:#fbfbf4}
.contactcard h4{font-family:'Space Mono',monospace;font-size:11.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--rust);margin-bottom:8px;transition:color .2s}
.contactcard .val{font-family:'Fraunces',serif;font-size:21px;font-weight:600;color:var(--ink);transition:color .2s;word-break:break-word}

footer{flex-shrink:0;border-top:1px solid var(--line);padding:30px 0;text-align:center;font-family:'Space Mono',monospace;font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;color:#6f7363}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
