.page{
  max-width: 960px;
  margin: 0 auto;
  padding: 3rem 1.5rem 5rem;
}

.top-nav{
  display:flex;
  gap: 1rem;
  align-items:center;
}

/* HERO */
.hero{
  padding: 2.5rem 0 2rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2rem;
}

.headline{
  font-size: 2.25rem;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 0.75rem;
}

.subhead{
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--muted);
  max-width: 42rem;
}

.cta-row{
  display:flex;
  gap: 0.75rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 0.65rem 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--text);
  background: var(--text);
  color: #fff;
  font-size: 0.9rem;
  transition: transform .15s ease, opacity .15s ease;
}
.btn:hover{ transform: translateY(-1px); opacity: 0.92; }

.btn-ghost{
  background: transparent;
  color: var(--text);
}

/* BLOCKS */
.block{
  padding: 2rem 0;
  border-bottom: 1px solid var(--border);
}

.block-head h2{
  font-size: 1.15rem;
  margin-bottom: 0.35rem;
}

.block-head p{
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 1.25rem;
}

/* CARD */
.card{
  background: var(--card-bg);
  border-radius: var(--radius);
  padding: 1.25rem;
  box-shadow: var(--shadow);
}

.card-title{
  font-weight: 700;
  margin-bottom: 0.35rem;
}

.card-desc{
  color: var(--muted);
  line-height: 1.7;
}

.card-actions{
  margin-top: 0.9rem;
}

.link{
  text-decoration: underline;
  text-underline-offset: 3px;
}

.muted{
  color: var(--muted);
}

/* GRID TILES */
.grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

.tile{
  background: var(--card-bg);
  border-radius: var(--radius);
  padding: 1.25rem;
  box-shadow: var(--shadow);
  transition: transform .15s ease, box-shadow .15s ease;
  display:flex;
  flex-direction:column;
  min-height: 120px;
}
.tile:hover{
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.10);
}

.tile-title{
  font-weight: 700;
  margin-bottom: 0.35rem;
}
.tile-desc{
  color: var(--muted);
  line-height: 1.6;
}

/* CONTACT */
.contact{
  border-bottom: none;
  padding-bottom: 0;
}
.contact-row{
  display:flex;
  gap: 0.75rem;
  align-items:center;
  flex-wrap: wrap;
}
.dot{ color: var(--muted); }

.footer-note{
  margin-top: 2rem;
  color: var(--muted);
  font-size: 0.85rem;
}

/* MOBILE */
@media (max-width: 600px){
  .page{ padding: 2.5rem 1.25rem 4rem; }
  .headline{ font-size: 1.85rem; }
  .grid{ grid-template-columns: 1fr; }
}
