*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f2ed;
  --surface:#ffffff;
  --text:#0f0e0c;
  --muted:#6b6760;
  --border:rgba(15,14,12,0.1);
  --accent:#d4500a;
  --accent2:#1a5c8a;
  --accent-light:#fdf0e8;
  --green:#1a6645;
  --green-light:#e6f4ec;
  --yellow:#c49a00;
  --yellow-light:#fdf8e1;
}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.7;overflow-x:hidden}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(245,242,237,0.93);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:0 2.5rem;height:60px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{font-family:'Instrument Serif',serif;font-size:20px;color:var(--text);text-decoration:none;font-style:italic}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{text-decoration:none;font-size:13px;font-weight:500;color:var(--muted);letter-spacing:0.04em;text-transform:uppercase;transition:color 0.2s}
.nav-links a:hover{color:var(--text)}
.nav-links a.nav-resume{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 18px;border-radius:40px;
  font-size:12.5px;font-weight:700;letter-spacing:0.03em;
  background:var(--accent);color:#ffffff;
  text-decoration:none;border:none;cursor:pointer;
  transition:all 0.2s;text-transform:uppercase;
}
.nav-links a.nav-resume:hover{background:#b84208;color:#ffffff;transform:translateY(-1px)}
.nav-links a.nav-resume svg{width:13px;height:13px;fill:none;stroke:#ffffff;stroke-width:2}

main{padding-top:60px}
section{padding:90px 2.5rem;max-width:860px;margin:0 auto}

/* HERO */
.hero{
  min-height:calc(100vh - 60px);
  display:flex;flex-direction:column;justify-content:center;
  padding-top:48px;padding-bottom:48px;
  position:relative;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green-light);color:var(--green);
  font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  padding:6px 14px;border-radius:40px;margin-bottom:2rem;
  border:1px solid rgba(26,102,69,0.15);
  width:fit-content;
}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.85)}}

.hero h1{
  font-family:'Instrument Serif',serif;
  font-size:clamp(52px,8vw,88px);
  line-height:1.02;letter-spacing:-0.025em;
  color:var(--text);margin-bottom:1.5rem;
}
.hero h1 .word-accent{color:var(--accent);font-style:italic}

.hero-bio{
  font-size:17px;color:var(--muted);
  max-width:500px;margin-bottom:2.5rem;line-height:1.8;font-weight:400;
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:3.5rem}

.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:12px 26px;border-radius:40px;
  font-size:13px;font-weight:700;text-decoration:none;
  letter-spacing:0.03em;text-transform:uppercase;
  transition:all 0.22s;cursor:pointer;border:none;
}
.btn-primary{background:var(--text);color:#fff}
.btn-primary:hover{background:#2a2926;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--text);transform:translateY(-2px)}

.hero-stats{
  display:flex;gap:2.5rem;flex-wrap:wrap;
  padding-top:2.5rem;border-top:1px solid var(--border);
}
.stat-num{font-family:'Instrument Serif',serif;font-size:36px;color:var(--text);line-height:1;letter-spacing:-0.02em}
.stat-num span{color:var(--accent)}
.stat-label{font-size:12px;color:var(--muted);font-weight:500;letter-spacing:0.04em;text-transform:uppercase;margin-top:2px}

/* MARQUEE */
.marquee-wrap{
  overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:var(--text);padding:14px 0;
  margin:0;
}
.marquee-track{
  display:flex;gap:0;white-space:nowrap;
  animation:marquee 22s linear infinite;
}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{
  font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);padding:0 2rem;
  display:inline-flex;align-items:center;gap:2rem;
}
.marquee-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);display:inline-block;flex-shrink:0}

/* SECTION LABELS */
.section-label{
  font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:2.5rem;
  display:flex;align-items:center;gap:12px;font-weight:700;
}
.section-label::after{content:'';flex:1;height:1px;background:var(--border);max-width:200px}

/* ABOUT */
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.about-left p{font-size:17px;color:var(--muted);line-height:1.85;margin-bottom:1.25rem}
.hire-card{
  background:var(--text);color:#fff;
  border-radius:20px;padding:2rem;margin-bottom:1.5rem;
}
.hire-card-top{display:flex;align-items:center;gap:10px;margin-bottom:1rem}
.hire-dot{width:9px;height:9px;border-radius:50%;background:#4ade80;animation:pulse 2s infinite;flex-shrink:0}
.hire-status{font-size:12px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:#4ade80}
.hire-card h3{font-family:'Instrument Serif',serif;font-size:24px;line-height:1.2;margin-bottom:0.6rem;font-style:italic}
.hire-card p{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.7;margin-bottom:1.25rem}
.hire-cta{
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;color:var(--text);
  padding:9px 18px;border-radius:40px;
  font-size:12px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;
  text-decoration:none;transition:all 0.2s;
}
.hire-cta:hover{background:#e8e6e2;transform:translateY(-1px)}

.skills-list{display:flex;flex-wrap:wrap;gap:7px}
.skill-pill{
  font-size:12.5px;font-weight:600;letter-spacing:0.02em;
  padding:6px 14px;border-radius:40px;
  background:var(--surface);border:1.5px solid var(--border);
  color:var(--text);transition:all 0.18s;
}
.skill-pill:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
.skill-pill.hl{background:var(--accent-light);color:var(--accent);border-color:rgba(212,80,10,0.2)}

/* PROJECTS */
.projects-stack{display:grid;gap:16px}
.project-card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:20px;padding:2rem 2.25rem;
  transition:all 0.22s;position:relative;overflow:hidden;
}
.project-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s ease;
}
.project-card:hover{border-color:rgba(212,80,10,0.25);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,0.07)}
.project-card:hover::before{transform:scaleX(1)}
.project-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:0.75rem}
.project-title{font-family:'Instrument Serif',serif;font-size:24px;letter-spacing:-0.01em;color:var(--text)}
.project-type{
  font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  padding:4px 12px;border-radius:20px;flex-shrink:0;margin-top:4px;
}
.type-web{background:var(--yellow-light);color:var(--yellow)}
.type-game{background:var(--accent-light);color:var(--accent)}
.type-backend{background:#eef2ff;color:#3730a3}
.project-desc{font-size:14px;color:var(--muted);line-height:1.75;margin-bottom:1.25rem}
.project-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:0.75rem}
.tech-row{display:flex;flex-wrap:wrap;gap:6px}
.tech-chip{
  font-size:11.5px;font-weight:600;letter-spacing:0.02em;
  padding:4px 10px;border-radius:20px;
  background:var(--bg);border:1px solid var(--border);color:var(--muted);
}
.private-badge, .public-badge{
  display:flex;align-items:center;gap:6px;
  font-size:11.5px;color:var(--muted);font-weight:600;
  text-decoration:none;transition:all 0.2s;
  padding:4px 10px;border:1px solid var(--border);
  border-radius:20px;background:rgba(15,14,12,0.02);
}
.public-badge:hover{color:var(--accent);border-color:rgba(212,80,10,0.2);background:var(--accent-light)}
.private-badge svg, .public-badge svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.6}
.public-badge svg{fill:currentColor;stroke:none}

/* HIRE SECTION */
.hire-section{background:var(--text);border-radius:28px;padding:4rem 3rem;text-align:center;position:relative;overflow:hidden}
.hire-section::before{
  content:'Open to Work';
  position:absolute;top:-18px;left:50%;transform:translateX(-50%);
  font-family:'Instrument Serif',serif;font-size:120px;font-style:italic;
  color:rgba(255,255,255,0.03);white-space:nowrap;pointer-events:none;
  letter-spacing:-0.03em;
}
.hire-section-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(74,222,128,0.12);color:#4ade80;
  font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  padding:6px 14px;border-radius:40px;margin-bottom:1.75rem;
  border:1px solid rgba(74,222,128,0.2);
}
.hire-section h2{
  font-family:'Instrument Serif',serif;
  font-size:clamp(36px,5vw,56px);
  color:#fff;line-height:1.1;letter-spacing:-0.02em;margin-bottom:1rem;
}
.hire-section h2 em{font-style:italic;color:#f97316}
.hire-section p{font-size:16px;color:rgba(255,255,255,0.5);max-width:440px;margin:0 auto 2.5rem;line-height:1.8}
.hire-points{
  display:flex;justify-content:center;gap:3rem;flex-wrap:wrap;margin-bottom:2.75rem;
}
.hire-point{text-align:left}
.hire-point-label{font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:4px}
.hire-point-val{font-size:15px;font-weight:500;color:#fff}
.hire-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.btn-green{background:#4ade80;color:#0f0e0c;font-weight:700}
.btn-green:hover{background:#22c55e;transform:translateY(-2px)}
.btn-white-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.2)}
.btn-white-outline:hover{border-color:rgba(255,255,255,0.5);transform:translateY(-2px)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:18px;padding:1.75rem;
  text-decoration:none;color:var(--text);
  transition:all 0.2s;display:flex;flex-direction:column;gap:0.5rem;
}
.contact-card:hover{border-color:var(--text);transform:translateY(-3px)}
.contact-card-icon{font-size:22px;margin-bottom:0.25rem}
.contact-card-name{font-weight:700;font-size:15px}
.contact-card-sub{font-size:13px;color:var(--muted)}
.contact-card-arrow{margin-top:auto;font-size:18px;color:var(--muted);align-self:flex-end}

footer{
  text-align:center;padding:2.5rem;
  font-size:12px;color:var(--muted);
  border-top:1px solid var(--border);font-weight:500;letter-spacing:0.03em;
}

/* BURGER MENU */
.nav-toggle{display:none}
.nav-burger{display:none;cursor:pointer;flex-direction:column;gap:4px;z-index:110}
.nav-burger span{width:22px;height:2px;background:var(--text);border-radius:2px;transition:0.3s}

@media(max-width:768px){
  .nav-burger{display:flex}
  .nav-links{
    position:fixed;top:60px;left:0;right:0;bottom:0;
    background:var(--bg);flex-direction:column;
    padding:4rem 2rem;gap:2.5rem;
    transform:translateX(100%);transition:transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    z-index:105;height:calc(100vh - 60px);
  }
  .nav-links a{font-size:18px}
  .nav-toggle:checked ~ .nav-links{transform:translateX(0)}
  
  /* Burger Animation */
  .nav-toggle:checked + .nav-burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav-toggle:checked + .nav-burger span:nth-child(2){opacity:0}
  .nav-toggle:checked + .nav-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  /* Speed up marquee significantly on mobile */
  .marquee-track{
    animation-duration: 6s;
    will-change: transform;
  }
  .marquee-item{
    padding: 0 1rem;
    gap: 1rem;
  }
}

@media(max-width:640px){
  section{padding:60px 1.25rem}
  .about-layout{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  nav{padding:0 1.25rem}
  .hero-stats{gap:1.5rem}
  .hire-section{padding:2.5rem 1.5rem}
  .hire-points{gap:1.5rem}
}
