:root {
  --bg:      #0a0a0a;
  --surface: #111111;
  --border:  rgba(255,255,255,0.08);
  --text:    #f0ede6;
  --muted:   #666;
  --muted2:  #999;
  --accent:  #e8d5a3;
  --red:     #c0392b;
  --sans:    'Syne', sans-serif;
  --mono:    'IBM Plex Mono', monospace;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--text); font-family:var(--sans); overflow-x:hidden; cursor:none; }

body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:200;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
  opacity:.5;
}

#cur      { position:fixed; width:8px; height:8px; background:var(--text); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:transform .05s; }
#cur-ring { position:fixed; width:36px; height:36px; border:1px solid rgba(255,255,255,.3); border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:all .12s ease; }
body:has(a:hover) #cur-ring, body:has(button:hover) #cur-ring { width:56px; height:56px; border-color:var(--accent); background:rgba(232,213,163,.06); }

nav {
  position:fixed; top:0; left:0; right:0; z-index:500;
  padding:0 48px; height:64px;
  display:flex; justify-content:space-between; align-items:center;
  background:rgba(10,10,10,.85); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.nav-logo { font-family:var(--mono); font-size:14px; letter-spacing:.14em; color:var(--text); text-decoration:none; display:flex; align-items:center; gap:10px; }
.nav-logo .ndot { width:7px; height:7px; background:var(--accent); border-radius:50%; }
.nav-links { display:flex; gap:36px; list-style:none; }
.nav-links a { font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); text-decoration:none; transition:color .2s; }
.nav-links a:hover { color:var(--text); }
.nav-avail { font-family:var(--mono); font-size:10px; letter-spacing:.14em; color:var(--accent); border:1px solid rgba(232,213,163,.25); padding:5px 14px; }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:none; padding:4px; }
.hamburger span { display:block; width:22px; height:1.5px; background:var(--text); }
.mob-menu { display:none; position:fixed; inset:0; background:var(--bg); z-index:490; flex-direction:column; justify-content:center; padding:52px; gap:8px; }
.mob-menu.open { display:flex; }
.mob-menu a { font-family:var(--sans); font-size:48px; font-weight:800; color:var(--text); text-decoration:none; line-height:1.1; transition:color .2s; padding:8px 0; }
.mob-menu a:hover { color:var(--accent); }

.hero {
  min-height:100vh; padding-top:64px;
  display:grid; grid-template-columns:1fr 1fr;
  position:relative; overflow:hidden;
}
.hero-left {
  display:flex; flex-direction:column; justify-content:center;
  padding:80px 52px; border-right:1px solid var(--border);
  position:relative; z-index:2;
}
.hero-eyebrow { font-family:var(--mono); font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); margin-bottom:32px; display:flex; align-items:center; gap:12px; opacity:0; animation:fadeUp .7s ease forwards .2s; }
.hero-eyebrow::before { content:''; display:block; width:20px; height:1px; background:var(--muted); }
.hero-title { font-size:clamp(64px,8vw,112px); font-weight:800; line-height:.92; letter-spacing:-.02em; margin-bottom:36px; opacity:0; animation:fadeUp .85s ease forwards .35s; }
.hero-title .soft { color:var(--muted2); font-weight:400; }
.hero-title .gold  { color:var(--accent); }
.hero-desc { font-family:var(--mono); font-size:13px; line-height:1.85; color:var(--muted2); max-width:420px; margin-bottom:48px; opacity:0; animation:fadeUp .85s ease forwards .55s; }
.hero-desc strong { color:var(--text); font-weight:400; }
.hero-ctas { display:flex; gap:14px; opacity:0; animation:fadeUp .85s ease forwards .7s; }
.btn-fill   { padding:16px 36px; background:var(--text); color:var(--bg); font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; text-decoration:none; font-weight:400; transition:background .2s; display:inline-block; }
.btn-fill:hover  { background:var(--accent); }
.btn-line   { padding:16px 36px; border:1px solid rgba(255,255,255,.2); color:var(--muted2); font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; text-decoration:none; transition:all .2s; display:inline-block; }
.btn-line:hover  { border-color:var(--text); color:var(--text); }

.hero-right {
  display:flex; flex-direction:column; justify-content:center; align-items:flex-start;
  padding:80px 52px; gap:32px; position:relative; overflow:hidden;
}
.hero-right::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image: radial-gradient(circle, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:32px 32px;
}

.term {
  position:relative; z-index:1; width:100%;
  background:#0e0e0e; border:1px solid rgba(255,255,255,.1);
  font-family:var(--mono); font-size:12.5px;
  opacity:0; animation:fadeIn 1s ease forwards .9s;
}
.term-bar { padding:11px 16px; border-bottom:1px solid rgba(255,255,255,.07); display:flex; align-items:center; gap:7px; }
.tdot { width:10px; height:10px; border-radius:50%; }
.tdot:nth-child(1){background:#ff5f57} .tdot:nth-child(2){background:#febc2e} .tdot:nth-child(3){background:#28c840}
.term-title { margin-left:auto; font-size:10px; color:var(--muted); letter-spacing:.1em; }
.term-body { padding:20px 20px; line-height:2.1; }
.tl { display:flex; white-space:pre; }
.tp { color:#6a9f72; margin-right:10px; user-select:none; }
.tk { color:#89b4fa; }
.tv { color:#e2a272; }
.ta { color:#a8c07a; }
.tn { color:#d19a66; }
.tc { color:var(--muted); font-style:italic; }
.tcursor { display:inline-block; width:7px; height:13px; background:rgba(255,255,255,.5); animation:blink .9s step-end infinite; vertical-align:middle; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

.stack-pills {
  position:relative; z-index:1; width:100%;
  display:grid; grid-template-columns:1fr 1fr; gap:8px;
  opacity:0; animation:fadeIn 1s ease forwards 1.05s;
}
.spill {
  display:flex; align-items:center; gap:10px;
  background:var(--surface); border:1px solid var(--border);
  padding:12px 16px; transition:border-color .2s, background .2s;
}
.spill:hover { border-color:rgba(255,255,255,.2); background:#1a1a1a; }
.spill-abbr { font-family:var(--mono); font-size:13px; color:var(--accent); width:22px; flex-shrink:0; }
.spill-name { font-family:var(--mono); font-size:11px; color:var(--muted2); letter-spacing:.04em; }

.marquee-wrap { overflow:hidden; background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:13px 0; }
.marquee-track { display:flex; white-space:nowrap; animation:marquee 24s linear infinite; }
.marquee-track span { font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); padding:0 28px; }
.marquee-track .sep { color:var(--accent); opacity:.7; padding:0; font-size:9px; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

.about-section { padding:120px 48px; max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.sec-eyebrow { font-family:var(--mono); font-size:10px; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); margin-bottom:28px; display:flex; align-items:center; gap:12px; }
.sec-eyebrow::before { content:''; display:block; width:18px; height:1px; background:var(--muted); }
.about-heading { font-size:clamp(44px,5vw,68px); font-weight:800; line-height:.95; letter-spacing:-.02em; margin-bottom:36px; }
.about-heading em { font-style:italic; color:var(--accent); font-weight:400; }
.about-body { font-family:var(--mono); font-size:13px; line-height:1.9; color:var(--muted2); margin-bottom:16px; }
.about-body strong { color:var(--text); font-weight:400; }

.skills-wrap { display:grid; grid-template-columns:1fr 1fr; gap:2px; }
.skill-col { background:var(--surface); border:1px solid var(--border); padding:28px 22px; }
.skill-col-title { font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:20px; padding-bottom:12px; border-bottom:1px solid var(--border); }
.sk { margin-bottom:16px; }
.sk:last-child { margin-bottom:0; }
.sk-row { display:flex; justify-content:space-between; margin-bottom:6px; }
.sk-name { font-family:var(--mono); font-size:11px; color:var(--muted2); }
.sk-pct  { font-family:var(--mono); font-size:10px; color:var(--muted); }
.sk-track { height:1px; background:rgba(255,255,255,.1); position:relative; overflow:hidden; }
.sk-fill  { position:absolute; top:0; left:0; height:100%; background:var(--text); transform:scaleX(0); transform-origin:left; transition:transform 1.1s cubic-bezier(.16,1,.3,1); }
.sk-fill.gold { background:var(--accent); }
.skills-wrap:hover .sk-fill { transform:scaleX(1); }

.services-section { padding:0 0 120px; }
.services-inner { max-width:1280px; margin:0 auto; padding:0 48px; }
.svc-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:56px; }
.svc-big-title { font-size:clamp(52px,7vw,96px); font-weight:800; line-height:.9; letter-spacing:-.02em; }
.svc-big-title em { font-style:italic; color:var(--muted); font-weight:400; font-size:.72em; }
.svc-note { font-family:var(--mono); font-size:12px; color:var(--muted); max-width:200px; line-height:1.7; text-align:right; }
.svc-list { border-top:1px solid var(--border); }
.svc-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:32px 0; border-bottom:1px solid var(--border);
  position:relative; overflow:hidden; cursor:none;
  transition:padding-left .3s;
}
.svc-row::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:0; background:var(--surface); z-index:0;
  transition:width .35s ease;
}
.svc-row:hover { padding-left:24px; }
.svc-row:hover::before { width:100%; }
.svc-row-left { display:flex; align-items:center; gap:24px; position:relative; z-index:1; }
.svc-row-num { font-family:var(--mono); font-size:11px; color:var(--muted); letter-spacing:.14em; width:36px; }
.svc-row-name { font-size:clamp(22px,3vw,36px); font-weight:800; letter-spacing:-.01em; }
.svc-row-tags { display:flex; gap:8px; flex-wrap:wrap; position:relative; z-index:1; }
.svc-tag { font-family:var(--mono); font-size:10px; letter-spacing:.08em; padding:4px 10px; border:1px solid var(--border); color:var(--muted); transition:border-color .2s; }
.svc-row:hover .svc-tag { border-color:rgba(255,255,255,.2); }
.svc-row-arrow { font-size:24px; color:var(--accent); opacity:0; transform:translateX(-10px); transition:all .25s; position:relative; z-index:1; }
.svc-row:hover .svc-row-arrow { opacity:1; transform:translateX(0); }

.projects-section { padding:80px 48px; background:var(--surface); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.projects-inner { max-width:1280px; margin:0 auto; }
.proj-head { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:52px; }
.proj-big-title { font-size:clamp(44px,5vw,72px); font-weight:800; letter-spacing:-.02em; }
.proj-count { font-family:var(--mono); font-size:12px; color:var(--muted); }
.proj-grid { display:grid; grid-template-columns:1fr 1fr; gap:2px; }
.proj-card {
  background:var(--bg); border:1px solid var(--border); padding:40px 36px;
  display:flex; flex-direction:column; justify-content:space-between; min-height:260px;
  text-decoration:none; color:var(--text); transition:border-color .25s, background .25s;
  position:relative; overflow:hidden;
}
.proj-card::before { content:''; position:absolute; top:0; left:0; width:3px; height:0; background:var(--accent); transition:height .35s ease; }
.proj-card:hover { background:#0e0e0e; border-color:rgba(255,255,255,.18); }
.proj-card:hover::before { height:100%; }
.proj-card-top { display:flex; justify-content:space-between; }
.proj-card-num { font-family:var(--mono); font-size:11px; color:var(--muted); }
.proj-card-arrow { font-size:20px; color:var(--accent); opacity:0; transform:translateX(-6px); transition:all .22s; }
.proj-card:hover .proj-card-arrow { opacity:1; transform:translateX(0); }
.proj-card-name { font-size:26px; font-weight:800; margin:20px 0 8px; letter-spacing:-.01em; }
.proj-card-desc { font-family:var(--mono); font-size:12px; line-height:1.7; color:var(--muted2); margin-bottom:20px; }
.proj-card-tags { display:flex; flex-wrap:wrap; gap:6px; }

.stats-section { padding:80px 48px; border-bottom:1px solid var(--border); }
.stats-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); }
.stat-cell { padding:40px 48px; border-right:1px solid var(--border); text-align:center; }
.stat-cell:last-child { border-right:none; }
.stat-num { font-size:clamp(56px,7vw,96px); font-weight:800; line-height:1; letter-spacing:-.02em; }
.stat-label { font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-top:8px; }

.reviews-section { padding:120px 48px; max-width:1280px; margin:0 auto; }
.rev-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:64px; }
.rev-big-title { font-size:clamp(44px,5vw,72px); font-weight:800; line-height:.95; letter-spacing:-.02em; }
.rev-big-title em { font-style:italic; color:var(--muted); font-weight:400; font-size:.72em; display:block; }
.rev-avg { text-align:right; }
.rev-avg-num { font-size:52px; font-weight:800; line-height:1; color:var(--accent); }
.rev-avg-label { font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:4px; }
.rev-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.rev-card { background:var(--surface); border:1px solid var(--border); padding:32px 28px; transition:transform .2s, border-color .2s; }
.rev-card:hover { transform:translateY(-4px); border-color:rgba(255,255,255,.18); }
.rev-stars { display:flex; gap:3px; margin-bottom:16px; }
.rev-star { color:var(--accent); font-size:13px; }
.rev-star.e { color:var(--border); }
.rev-title-bold { font-size:15px; font-weight:700; margin-bottom:12px; }
.rev-quote { font-family:var(--mono); font-size:12px; line-height:1.8; color:var(--muted2); margin-bottom:24px; position:relative; padding-left:14px; }
.rev-quote::before { content:''; position:absolute; left:0; top:3px; bottom:3px; width:2px; background:var(--accent); opacity:.5; }
.rev-author { border-top:1px solid var(--border); padding-top:18px; }
.rev-name { font-size:13px; font-weight:700; margin-bottom:3px; }
.rev-role { font-family:var(--mono); font-size:11px; color:var(--muted); letter-spacing:.06em; }

.faq-section { padding:80px 48px; background:var(--surface); border-top:1px solid var(--border); }
.faq-inner { max-width:800px; margin:0 auto; }
.faq-title { font-size:clamp(40px,5vw,64px); font-weight:800; letter-spacing:-.02em; margin-bottom:16px; }
.faq-subtitle { font-family:var(--mono); font-size:13px; color:var(--muted); margin-bottom:52px; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-item:first-of-type { border-top:1px solid var(--border); }
.faq-q { display:flex; justify-content:space-between; align-items:center; padding:24px 0; cursor:none; transition:color .2s; }
.faq-q-text { font-size:17px; font-weight:700; }
.faq-icon { font-size:22px; color:var(--muted); transition:transform .3s, color .2s; user-select:none; }
.faq-item.open .faq-icon { transform:rotate(45deg); color:var(--accent); }
.faq-item.open .faq-q-text { color:var(--accent); }
.faq-a { font-family:var(--mono); font-size:13px; line-height:1.85; color:var(--muted2); max-height:0; overflow:hidden; transition:max-height .4s ease, padding .3s; }
.faq-item.open .faq-a { max-height:200px; padding-bottom:24px; }

.contact-section { padding:120px 48px; max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:80px; }
.ct-eyebrow { font-family:var(--mono); font-size:10px; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); margin-bottom:24px; display:flex; align-items:center; gap:12px; }
.ct-eyebrow::before { content:''; display:block; width:16px; height:1px; background:var(--muted); }
.ct-heading { font-size:clamp(48px,5.5vw,80px); font-weight:800; line-height:.9; letter-spacing:-.02em; margin-bottom:28px; }
.ct-heading em { font-style:italic; color:var(--accent); font-weight:400; }
.ct-body { font-family:var(--mono); font-size:13px; line-height:1.85; color:var(--muted2); max-width:360px; margin-bottom:44px; }
.ct-link { display:flex; align-items:center; justify-content:space-between; padding:22px 0; border-bottom:1px solid var(--border); text-decoration:none; color:var(--text); transition:padding-left .2s; }
.ct-link:first-child { border-top:1px solid var(--border); }
.ct-link:hover { padding-left:10px; }
.ct-lbl { font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:5px; }
.ct-val { font-size:15px; font-weight:700; }
.ct-arr { font-size:18px; color:var(--accent); opacity:0; transform:translateX(-6px); transition:all .2s; }
.ct-link:hover .ct-arr { opacity:1; transform:translateX(0); }

.cta-strip { background:var(--accent); padding:18px 0; overflow:hidden; }
.cta-strip-track { display:flex; white-space:nowrap; animation:marquee 18s linear infinite; }
.cta-strip-track span { font-family:var(--sans); font-size:15px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--bg); padding:0 32px; }
.cta-strip-track .sep2 { color:rgba(10,10,10,.35); padding:0; }

footer { padding:36px 48px; border-top:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; }
.ft-logo { font-family:var(--mono); font-size:14px; letter-spacing:.14em; color:var(--muted); }
.ft-copy  { font-family:var(--mono); font-size:11px; color:var(--muted); }
.ft-links { display:flex; gap:20px; }
.ft-links a { font-family:var(--mono); font-size:11px; color:var(--muted); text-decoration:none; letter-spacing:.1em; transition:color .2s; }
.ft-links a:hover { color:var(--text); }

@keyframes fadeUp  { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }
.reveal { opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.4s}

@media(max-width:960px){
  nav { padding:0 24px; }
  .nav-links,.nav-avail { display:none; }
  .hamburger { display:flex; }
  .hero { grid-template-columns:1fr; }
  .hero-left { padding:80px 24px 48px; border-right:none; border-bottom:1px solid var(--border); }
  .hero-right { padding:48px 24px; }
  .about-section { grid-template-columns:1fr; padding:80px 24px; gap:48px; }
  .skills-wrap { grid-template-columns:1fr; }
  .services-inner { padding:0 24px; }
  .svc-header { flex-direction:column; gap:16px; align-items:flex-start; }
  .svc-note { text-align:left; }
  .projects-section { padding:80px 24px; }
  .proj-grid { grid-template-columns:1fr; }
  .stats-inner { grid-template-columns:1fr; }
  .stat-cell { border-right:none; border-bottom:1px solid var(--border); }
  .stat-cell:last-child { border-bottom:none; }
  .stats-section { padding:60px 24px; }
  .reviews-section { padding:80px 24px; }
  .rev-header { flex-direction:column; gap:28px; align-items:flex-start; }
  .rev-grid { grid-template-columns:1fr; }
  .faq-section { padding:80px 24px; }
  .contact-section { grid-template-columns:1fr; padding:80px 24px; gap:48px; }
  footer { flex-direction:column; gap:16px; text-align:center; padding:28px 24px; }
  .stack-pills { grid-template-columns:1fr 1fr; }
}
@media(max-width:560px){
  .hero-title { font-size:clamp(52px,13vw,80px); }
  .stack-pills { grid-template-columns:1fr; }
}