/* Components: buttons, cards, forms — adapted from boilerplate-v2 for dark theme. */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: 0.85rem 1.4rem;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  font-family: inherit;
  font-size: var(--step-0);
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
  white-space: nowrap;
}
.btn:hover { text-decoration: none; transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-lg { padding: 1.05rem 1.9rem; font-size: var(--step-1); }

.btn-primary {
  background: var(--color-accent);
  color: var(--color-bg);
  box-shadow: 0 8px 24px -8px rgba(20, 184, 166, 0.6);
}
.btn-primary:hover { background: #2dd4bf; color: var(--color-bg); box-shadow: 0 12px 32px -8px rgba(20, 184, 166, 0.8); }

.btn-ghost {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-border-hi);
}
.btn-ghost:hover { background: var(--color-surface); color: var(--color-text); border-color: var(--color-accent); }

.card {
  padding: var(--space-xl);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: transform var(--dur-normal) var(--ease), border-color var(--dur-normal) var(--ease);
}
.card:hover { transform: translateY(-3px); border-color: var(--color-accent); }
.card h3 { margin-bottom: var(--space-sm); color: var(--color-text); }
.card p { color: var(--color-text-muted); margin-bottom: 0; }

/* Contact form */
.contact-form {
  display: grid;
  gap: var(--space-md);
  padding: var(--space-xl);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.field { display: grid; gap: var(--space-2xs); }
.field label { font-weight: 600; font-size: var(--step--1); color: var(--color-text); }
.field input,
.field textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  font: inherit;
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border-hi);
  border-radius: var(--radius-md);
  transition: border-color var(--dur-fast) var(--ease);
}
.field input:focus,
.field textarea:focus {
  border-color: var(--color-accent);
  outline: none;
  box-shadow: 0 0 0 3px var(--color-accent-soft);
}
.field textarea { resize: vertical; min-height: 7rem; }
.form-note { font-size: var(--step--1); color: var(--color-text-muted); margin: 0; }
.hp { position: absolute; left: -9999px; }

.contact-list { list-style: none; padding: 0; margin: var(--space-lg) 0; }
.contact-list li { padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-border); color: var(--color-text-muted); }
.contact-list li strong { color: var(--color-text); margin-right: var(--space-sm); }
.contact-list li:last-child { border-bottom: 0; }
