:root {
  --bg: #f5f2ec;
  --ink: #1f1d1a;
  --accent: #1d5c54;
  --card: #fffaf0;
  --shadow: 0 20px 60px rgba(0,0,0,0.08);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  color: var(--ink);
  background: radial-gradient(1200px 600px at 20% -10%, #e5ded0 0%, transparent 60%),
              radial-gradient(900px 500px at 90% 10%, #efe8d8 0%, transparent 60%),
              var(--bg);
}
.bg-noise {
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events: none;
}
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 28px 6vw; position: sticky; top: 0;
  background: rgba(245,242,236,0.7); backdrop-filter: blur(6px); z-index: 10;
}
.logo { font-family: "Fraunces", serif; font-weight: 700; font-size: 22px; }
.links a { margin-right: 18px; text-decoration: none; color: var(--ink); opacity: 0.8; }
.cta, .btn { text-decoration: none; border-radius: 999px; padding: 10px 18px; font-weight: 600; display: inline-block; }
.cta { background: var(--accent); color: white; }
.hero { padding: 80px 6vw 40px; max-width: 900px; }
.badge { display: inline-block; padding: 6px 12px; background: #efe8d8; border-radius: 999px; font-size: 12px; letter-spacing: 0.04em; text-transform: uppercase; }
.hero h1 { font-family: "Fraunces", serif; font-size: 54px; margin: 18px 0 10px; }
.hero p { font-size: 18px; max-width: 700px; line-height: 1.6; }
.hero-actions { margin: 18px 0 14px; }
.btn.primary { background: var(--accent); color: #fff; margin-right: 10px; }
.btn.ghost { border: 1px solid var(--ink); color: var(--ink); }
.hero-metrics { display: flex; gap: 22px; font-size: 14px; opacity: 0.75; }
.hero-metrics span { font-weight: 700; }

.grid, .timeline, .stack, .contact { padding: 40px 6vw; }
.cards { display: grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: 20px; }
.cards article { background: var(--card); padding: 18px; border-radius: 16px; box-shadow: var(--shadow); }
.timeline ol { list-style: none; padding: 0; display: grid; gap: 14px; }
.timeline li { background: #fff; padding: 14px 16px; border-radius: 12px; }
.stack-row { display: flex; flex-wrap: wrap; gap: 12px; }
.stack-row span { background: #fff; padding: 8px 12px; border-radius: 999px; font-weight: 600; }

.contact-form { background: #fff; padding: 18px; border-radius: 16px; box-shadow: var(--shadow); max-width: 720px; }
.contact-form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.contact-form input, .contact-form textarea {
  width: 100%; border: 1px solid #ddd; padding: 10px 12px; border-radius: 10px; font-family: inherit;
}
.form-status { display: none; margin-top: 10px; font-size: 14px; color: var(--accent); }

.footer { padding: 30px 6vw; display: flex; justify-content: space-between; opacity: 0.7; }
@media (max-width: 720px) {
  .hero h1 { font-size: 38px; }
  .nav { flex-direction: column; gap: 12px; }
  .contact-form .row { grid-template-columns: 1fr; }
}
