:root{
  --sand: #E8D9C2;
  --paper: #F1E5D1;
  --ink: #241D17;
  --terracotta: #B0532A;
  --terracotta-deep: #8A4222;
  --clay: #6E5640;
  --hairline: #CDB48C;
  --glow: #E0A876;
}

*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  background:var(--sand);
  color:var(--ink);
  font-family:'Inter', sans-serif;
  line-height:1.6;
  position:relative;
  overflow-x:hidden;
}

/* paper grain texture */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:1;
  pointer-events:none;
  opacity:0.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

.wrap{ max-width: 760px; margin: 0 auto; padding: 0 28px; position:relative; z-index:2; }

/* ---------- NAV ---------- */
nav{
  display:flex; justify-content:space-between; align-items:center;
  padding: 32px 0;
}
.nav-mark{
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  color:var(--clay);
  letter-spacing:0.04em;
}
.nav-links{ display:flex; gap:28px; }
.nav-links a{
  color:var(--ink);
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  opacity:0.75;
  transition: opacity 0.2s ease, color 0.2s ease;
}
.nav-links a:hover{ opacity:1; color:var(--terracotta); }

/* ---------- HERO ---------- */
header.hero{
  position:relative;
  padding: 70px 0 100px;
  text-align:left;
}

.glow{
  position:absolute;
  width:420px; height:420px;
  border-radius:50%;
  background: radial-gradient(circle, var(--glow) 0%, rgba(240,194,154,0) 70%);
  top:-120px; left:-60px;
  z-index:-1;
  filter: blur(10px);
  animation: breathe 9s ease-in-out infinite;
}
@keyframes breathe{
  0%, 100% { opacity:0.55; transform:scale(1); }
  50% { opacity:0.85; transform:scale(1.08); }
}

.eyebrow{
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  color:var(--terracotta-deep);
  letter-spacing:0.06em;
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:22px;
  opacity:0;
  animation: fadeUp 0.8s ease forwards;
  animation-delay: 0.1s;
}
.eyebrow::before{
  content:"";
  width:7px; height:7px;
  border-radius:50%;
  background:var(--terracotta);
  display:inline-block;
}

h1.greeting{
  font-family:'Fraunces', serif;
  font-weight:500;
  font-size: clamp(2.4rem, 6vw, 3.6rem);
  line-height:1.12;
  letter-spacing:-0.01em;
  margin-bottom:22px;
  opacity:0;
  animation: fadeUp 0.8s ease forwards;
  animation-delay: 0.25s;
}
h1.greeting em{
  font-style:italic;
  font-weight:400;
  color:var(--terracotta-deep);
}

.hero p.sub{
  font-size:1.08rem;
  color:var(--clay);
  max-width:480px;
  margin-bottom:34px;
  opacity:0;
  animation: fadeUp 0.8s ease forwards;
  animation-delay: 0.4s;
}

.hero-actions{
  display:flex; gap:14px; flex-wrap:wrap;
  opacity:0;
  animation: fadeUp 0.8s ease forwards;
  animation-delay: 0.55s;
}

@keyframes fadeUp{
  from { opacity:0; transform: translateY(14px); }
  to { opacity:1; transform: translateY(0); }
}

/* scroll fade-in */
.fade-in{
  opacity:0;
  transform: translateY(24px);
  transition: opacity 0.9s ease, transform 0.9s ease;
}
.fade-in.visible{
  opacity:1;
  transform: translateY(0);
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:13px 24px;
  border-radius:14px;
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.btn-primary{
  background:var(--terracotta);
  color:var(--paper);
  box-shadow: 0 6px 18px -6px rgba(194,104,61,0.55);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow: 0 10px 22px -6px rgba(194,104,61,0.6); }
.btn-ghost{
  border:1.5px solid var(--hairline);
  color:var(--ink);
  background:transparent;
}
.btn-ghost:hover{ border-color:var(--terracotta); color:var(--terracotta-deep); transform:translateY(-2px); }

/* ---------- SECTION HEADERS ---------- */
.section{ padding: 64px 0; border-top: 1px solid var(--hairline); }
.section-head{
  display:flex; align-items:baseline; gap:14px;
  margin-bottom:36px;
}
.section-num{
  font-family:'JetBrains Mono', monospace;
  font-size:13px; color:var(--terracotta);
}
.section-title{
  font-family:'Fraunces', serif;
  font-weight:500;
  font-size:1.6rem;
}

/* ---------- ABOUT ---------- */
.about-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:36px;
}
.about p{ color:var(--ink); font-size:1.02rem; max-width:580px; }
.about p + p{ margin-top:16px; }
.about strong{ color:var(--terracotta-deep); font-weight:600; }

.facts{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:14px;
  margin-top:30px;
}
.fact{
  background:var(--paper);
  border:1px solid var(--hairline);
  border-radius:16px;
  padding:18px 20px;
}
.fact .label{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--clay);
  text-transform:uppercase;
  letter-spacing:0.06em;
  margin-bottom:6px;
}
.fact .value{ font-size:0.95rem; font-weight:500; }

/* ---------- WORK ---------- */
.projects{ display:flex; flex-direction:column; gap:18px; }

.project-card{
  background:var(--paper);
  border:1px solid var(--hairline);
  border-radius:20px;
  padding:28px;
  text-decoration:none;
  color:var(--ink);
  display:block;
  position:relative;
  overflow:hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.project-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 16px 32px -18px rgba(46,38,32,0.25);
  border-color: var(--terracotta);
}
.project-top{
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:10px;
}
.project-title{
  font-family:'Fraunces', serif;
  font-size:1.25rem;
  font-weight:500;
}
.project-arrow{
  font-size:18px;
  color:var(--terracotta);
  transition: transform 0.25s ease;
}
.project-card:hover .project-arrow{ transform: translate(3px,-3px); }
.project-desc{ color:var(--clay); font-size:0.95rem; max-width:520px; margin-bottom:14px; }
.tags{ display:flex; gap:8px; flex-wrap:wrap; }
.tag{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--terracotta-deep);
  background:rgba(194,104,61,0.1);
  padding:5px 10px;
  border-radius:8px;
}

/* ---------- SKILLS ---------- */
.skills-cloud{ display:flex; flex-wrap:wrap; gap:10px; }
.skill-pill{
  border:1px solid var(--hairline);
  background:var(--paper);
  padding:9px 16px;
  border-radius:999px;
  font-size:13.5px;
  font-weight:500;
  color:var(--ink);
  transition: border-color 0.2s ease, color 0.2s ease;
}
.skill-pill:hover{ border-color:var(--terracotta); color:var(--terracotta-deep); }

/* ---------- CONTACT ---------- */
.contact-box{
  background: linear-gradient(135deg, var(--paper), var(--sand));
  border:1px solid var(--hairline);
  border-radius:24px;
  padding:44px 36px;
  text-align:center;
  position:relative;
}
.contact-box h2{
  font-family:'Fraunces', serif;
  font-size:1.8rem;
  font-weight:500;
  margin-bottom:12px;
}
.contact-box p{ color:var(--clay); margin-bottom:26px; }

footer{
  text-align:center;
  padding: 40px 0 50px;
  color:var(--clay);
  font-size:13px;
}
footer a{ color:var(--terracotta-deep); text-decoration:none; }

@media (max-width: 600px){
  .facts{ grid-template-columns: 1fr; }
  nav .nav-links{ gap:18px; }
  .glow{ width:280px; height:280px; top:-80px; left:-40px; }
}

@media (prefers-reduced-motion: reduce){
  .glow{ animation:none; }
  html{ scroll-behavior:auto; }
  .eyebrow, h1.greeting, .hero p.sub, .hero-actions{ opacity:1; animation:none; }
  .fade-in{ opacity:1; transform:none; transition:none; }
}
