/* ------------------------------------------------------------------ */
/*  Global page styles                                                 */
/*                                                                     */
/*  Most component styling lives in shadow DOM via @unbndl/html.       */
/*  This file covers:                                                  */
/*    - body / typography                                              */
/*    - light DOM layout primitives ( .page, .section, .stack )        */
/*    - shared form / button / card styles for the auth pages          */
/* ------------------------------------------------------------------ */

/* ---------- Body & typography ---------- */

body {
  background-color: var(--surface-page);
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: var(--text-md);
  font-weight: 400;
  line-height: var(--leading-body);
  background-image:
    radial-gradient(
      circle at 0% 0%,
      color-mix(in srgb, var(--accent-warm) 8%, transparent) 0,
      transparent 40%
    ),
    radial-gradient(
      circle at 100% 100%,
      color-mix(in srgb, var(--color-teal-soft) 12%, transparent) 0,
      transparent 45%
    );
  background-attachment: fixed;
}

h1,
h2,
h3 {
  font-family: var(--font-serif);
  color: var(--ink-strong);
  line-height: var(--leading-tight);
}

h2 {
  font-size: var(--text-xl);
  color: var(--accent);
  margin-bottom: var(--space-sm);
  letter-spacing: 0.2px;
}

h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-sm);
}

a {
  color: var(--accent-link);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease);
}

a:hover {
  color: color-mix(in srgb, var(--accent-link) 80%, var(--ink));
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ---------- Layout primitives ---------- */

.page {
  display: block;
  min-height: 100vh;
}

main {
  padding: var(--space-xl) var(--space-lg);
  max-width: var(--content-max);
  margin: 0 auto;
}

.stack > * + * {
  margin-top: var(--space-md);
}

/* Center auth-style narrow pages.  login.html / sign-up.html use
   <main class="page"> so we provide a centered narrow layout there. */
main.page {
  max-width: var(--content-narrow);
  padding: var(--space-2xl) var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  align-items: stretch;
  text-align: center;
}

main.page h2 {
  margin: 0;
}

main.page > p {
  color: var(--ink-muted);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
}

.auth-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  text-align: center;
}

.auth-header h2 {
  margin: 0;
}

.auth-header p {
  color: var(--ink-muted);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
}

/* ---------- Card ---------- */

.card {
  background: var(--surface-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  box-shadow: var(--shadow-md);
  text-align: left;
}

/* ---------- Forms (auth pages, generic) ---------- */

form {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

label {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink-muted);
  text-align: left;
}

label > span {
  letter-spacing: 0.3px;
  text-transform: uppercase;
  font-size: var(--text-xs);
}

input[type="text"],
input[type="email"],
input[type="password"],
input:not([type]) {
  width: 100%;
  padding: 10px 14px;
  background: var(--surface-card-alt);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--ink);
  transition:
    border-color var(--duration-fast) var(--ease),
    box-shadow var(--duration-fast) var(--ease);
}

input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
}

/* ---------- Buttons ---------- */

button,
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: 10px 22px;
  background: var(--accent);
  color: var(--ink-on-accent);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 600;
  letter-spacing: 0.2px;
  border: 0;
  border-radius: var(--radius-sm);
  text-decoration: none;
  cursor: pointer;
  transition:
    background var(--duration-fast) var(--ease),
    transform var(--duration-fast) var(--ease),
    box-shadow var(--duration-fast) var(--ease);
}

button:hover,
.btn:hover {
  background: color-mix(in srgb, var(--accent) 85%, black);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  color: var(--ink-on-accent);
}

button:active,
.btn:active {
  transform: translateY(1px);
}

.btn-ghost {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--border-strong);
}

.btn-ghost:hover {
  background: var(--surface-sunken);
  color: var(--ink-strong);
}
