:root {
  --site-bg: #0b1220;
  --site-surface: rgba(255, 255, 255, 0.06);
  --site-border: rgba(255, 255, 255, 0.10);
  --site-text: #0f172a;
  --site-muted: rgba(15, 23, 42, 0.75);
  --site-brand: #f97316; /* orange-500 */
  --site-brand-strong: #ea580c; /* orange-600 */
  --site-link: #0284c7; /* sky-600 */
  --site-link-hover: #f97316; /* orange-500 */
}

/* Better focus defaults across the site */
:where(a, button, input, select, textarea, [tabindex]):focus-visible {
  outline: 3px solid rgba(249, 115, 22, 0.45);
  outline-offset: 2px;
}

/* Layout primitives */
.site-page {
  background: #f8fafc;
  color: var(--site-text);
}

.site-container {
  max-width: 72rem; /* ~1152px */
  margin-inline: auto;
  padding-inline: 1rem;
}
@media (min-width: 1024px) {
  .site-container {
    padding-inline: 2rem;
  }
}

.site-section {
  padding-block: 2.25rem;
}
@media (min-width: 1024px) {
  .site-section {
    padding-block: 3.5rem;
  }
}

.site-card {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  box-shadow: 0 16px 40px rgba(2, 6, 23, 0.08);
}

.site-card--soft {
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(10px);
}

.site-stack > * + * {
  margin-top: 1rem;
}

/* Typography helpers */
.site-title {
  font-size: 1.875rem;
  line-height: 2.25rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}
@media (min-width: 1024px) {
  .site-title {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }
}

.site-kicker {
  color: rgba(255, 255, 255, 0.85);
  font-weight: 600;
}

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

.site-prose :where(p, li) {
  line-height: 1.9;
}

.site-prose :where(a) {
  color: var(--site-link);
  text-decoration: none;
  transition: color 160ms ease, text-decoration-color 160ms ease;
}
.site-prose :where(a:hover) {
  color: var(--site-link-hover);
}

/* Buttons */
.site-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-radius: 0.75rem;
  padding: 0.6rem 1rem;
  font-weight: 700;
  transition: transform 120ms ease, background-color 160ms ease, box-shadow 160ms ease;
  user-select: none;
  white-space: nowrap;
}
.site-btn:active {
  transform: translateY(1px);
}
.site-btn--primary {
  background: var(--site-brand-strong);
  color: #fff;
  box-shadow: 0 12px 24px rgba(249, 115, 22, 0.22);
}
.site-btn--primary:hover {
  background: #c2410c; /* orange-700 */
}
.site-btn--ghost {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.14);
}
.site-btn--ghost:hover {
  background: rgba(255, 255, 255, 0.14);
}

/* Form controls */
.site-field {
  display: grid;
  gap: 0.4rem;
}
.site-label {
  font-weight: 700;
  font-size: 0.95rem;
}
.site-input,
.site-select,
.site-textarea {
  width: 100%;
  border-radius: 0.75rem;
  border: 1px solid rgba(15, 23, 42, 0.14);
  background: rgba(255, 255, 255, 0.92);
  padding: 0.6rem 0.85rem;
  transition: border-color 160ms ease, box-shadow 160ms ease;
}
.site-input:focus,
.site-select:focus,
.site-textarea:focus {
  border-color: rgba(249, 115, 22, 0.65);
  box-shadow: 0 0 0 4px rgba(249, 115, 22, 0.15);
  outline: none;
}

/* Shared hero */
.site-hero {
  position: relative;
  overflow: hidden;
}
.site-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}
.site-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(2, 6, 23, 0.78), rgba(2, 6, 23, 0.25));
}
.site-hero__inner {
  position: relative;
  z-index: 10;
  padding-block: 5rem;
}
@media (min-width: 1024px) {
  .site-hero__inner {
    padding-block: 8rem;
  }
}
.site-hero__title {
  color: #fff;
  font-size: 2.25rem;
  line-height: 2.5rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
@media (min-width: 1024px) {
  .site-hero__title {
    font-size: 2.75rem;
    line-height: 3rem;
  }
}
.site-hero__subtitle {
  margin-top: 0.75rem;
  max-width: 48rem;
  color: rgba(255, 255, 255, 0.85);
}

