@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600&display=swap");

:root{
  --bg:#f5f5f5;
  --text:#151515;
  --muted:#4b4b4b;
  --line:#d8d8d8;
  --card:#fafafa;
  --shadow:0 10px 30px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: "Space Grotesk", "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 10% 0%, rgba(0,0,0,.06), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(0,0,0,.05), transparent 55%),
    var(--bg);
}
a{color:inherit}
.page{
  min-height:100%;
  max-width:860px;
  margin:0 auto;
  padding:72px 20px 48px;
  display:flex;
  flex-direction:column;
  gap:56px;
}
.hero{
  text-align:center;
  padding:40px 20px;
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:var(--shadow);
  animation:fadeUp .7s ease both;
}
.hero h1{
  margin:0;
  font-size:clamp(28px, 4vw, 44px);
  letter-spacing:.5px;
  text-transform:uppercase;
}
.projects{
  display:flex;
  flex-direction:column;
  gap:18px;
  animation:fadeUp .7s ease both;
  animation-delay:.12s;
}
.section-head{
  display:flex;
  align-items:center;
  gap:12px;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:2px;
  color:var(--muted);
}
.section-head::after{
  content:"";
  flex:1;
  height:1px;
  background:var(--line);
}
.projects h2{
  margin:0;
  font-size:12px;
  font-weight:600;
}
.project-link{
  text-decoration:none;
  border:1px solid var(--line);
  padding:18px 22px;
  background:var(--card);
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-size:18px;
  box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease;
}
.project-link::after{
  content:">";
  font-size:20px;
}
.project-link:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 40px rgba(0,0,0,.12);
}
.footer{
  border-top:1px solid var(--line);
  padding-top:18px;
  font-size:13px;
  color:var(--muted);
  text-align:center;
  animation:fadeUp .7s ease both;
  animation-delay:.24s;
}
.footer p{margin:0}
@keyframes fadeUp{
  0%{opacity:0;transform:translateY(12px)}
  100%{opacity:1;transform:translateY(0)}
}
@media (prefers-reduced-motion: reduce){
  .hero,.projects,.footer{animation:none}
  .project-link{transition:none}
}
@media (max-width:640px){
  .page{padding:56px 16px 40px;gap:40px}
  .hero{padding:32px 16px}
  .project-link{font-size:16px;padding:16px 18px}
}
