/* The Quiet Work — site layer
 * Base reset plus the design-system components recreated as CSS classes,
 * ported one-to-one from the design bundle (Wordmark, Divider, Prose,
 * SiteFooter and the page shell). Values come from the --tqw-* tokens;
 * nothing is forked. Shared by every page state of thequietwork.ai.
 */

/* ---- Base reset ---- */
*, *::before, *::after { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
  background: var(--tqw-surface-page);
  color: var(--tqw-text-body);
  font-family: var(--tqw-font-body);
  font-size: var(--tqw-size-body-md);
  line-height: var(--tqw-leading-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Desktop breathes wider; mobile-first gutter is the default. */
@media (min-width: 48rem) {
  :root { --tqw-page-gutter: var(--tqw-page-gutter-lg); }
}

/* Quiet by default: fades and slow eases only, and none at all when asked. */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ---- Page shell ---- */
.tqw-page {
  min-height: 100vh;
  background: var(--tqw-surface-page);
  display: flex;
  flex-direction: column;
}

.tqw-header {
  padding: var(--tqw-space-5) var(--tqw-page-gutter);
  text-align: center;
}

.tqw-header__home {
  text-decoration: none;
  display: inline-block;
}

.tqw-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--tqw-space-8) var(--tqw-page-gutter);
}

.tqw-container {
  width: 100%;
  max-width: var(--tqw-content-max);
}

/* ---- Wordmark — "The Quiet Work" set in Cormorant Garamond ---- */
.tqw-wordmark {
  font-family: var(--tqw-font-display);
  font-weight: var(--tqw-weight-medium);
  font-size: 1.75rem;            /* md (default) */
  line-height: 1.05;
  letter-spacing: 0.005em;
  color: var(--tqw-ink);
  text-decoration: none;
  display: inline-block;
}
.tqw-wordmark--sm { font-size: 1.25rem; }   /* >= the ~20px Cormorant floor */
.tqw-wordmark--lg { font-size: 2.5rem; }
.tqw-wordmark--xl { font-size: 3.5rem; }

/* ---- Page title (display md) ---- */
.tqw-title {
  font-family: var(--tqw-font-display);
  font-weight: var(--tqw-weight-display);
  font-size: var(--tqw-size-display-md);
  line-height: var(--tqw-leading-display);
  letter-spacing: var(--tqw-tracking-display);
  color: var(--tqw-text-strong);
  margin: 0;
}

/* ---- Divider — a quiet horizontal rule ---- */
.tqw-divider {
  border: 0;
  height: 1px;
  width: 100%;
  background: var(--tqw-rule-hairline);
  margin: var(--tqw-space-7) 0;
}
.tqw-divider--privacy { margin: var(--tqw-space-5) 0; }

/* ---- Prose — the reading column (Source Serif 4, capped at the measure) ---- */
.tqw-prose {
  font-family: var(--tqw-font-body);
  font-size: var(--tqw-size-body-lg);
  line-height: var(--tqw-leading-body);
  color: var(--tqw-text-body);
  max-width: var(--tqw-measure);
  text-align: left;
  text-wrap: pretty;
}
.tqw-prose--lead { font-size: var(--tqw-size-body-xl); }
.tqw-prose p { margin: 0 0 1.25em 0; }
.tqw-prose p:last-child { margin-bottom: 0; }
.tqw-prose em { font-style: italic; }
.tqw-prose h1, .tqw-prose h2, .tqw-prose h3 {
  font-family: var(--tqw-font-display);
  font-weight: var(--tqw-weight-display);
  line-height: var(--tqw-leading-display);
  letter-spacing: var(--tqw-tracking-display);
  color: var(--tqw-text-strong);
  margin: 0 0 0.6em 0;
}
.tqw-prose h1 { font-size: var(--tqw-size-display-lg); }
.tqw-prose h2 { font-size: var(--tqw-size-display-md); }
.tqw-prose h3 { font-size: var(--tqw-size-display-sm); }
.tqw-prose a {
  color: var(--tqw-text-link);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color var(--tqw-dur-base) var(--tqw-ease-quiet);
}
.tqw-prose a:hover { color: var(--tqw-text-link-hover); }
.tqw-prose a:focus-visible { outline: none; box-shadow: var(--tqw-focus-ring); border-radius: 2px; }

/* ---- Footer — one line, shared by every page state ---- */
.tqw-footer {
  font-family: var(--tqw-font-ui);
  font-size: var(--tqw-size-ui-sm);
  color: var(--tqw-text-muted);
  letter-spacing: var(--tqw-tracking-ui);
  padding: var(--tqw-space-7) var(--tqw-page-gutter);
  text-align: center;
}
.tqw-footer a {
  color: var(--tqw-text-muted);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color var(--tqw-dur-base) var(--tqw-ease-quiet);
}
.tqw-footer a:hover { color: var(--tqw-text-link); }
.tqw-footer a:focus-visible { outline: none; box-shadow: var(--tqw-focus-ring); border-radius: 2px; }

/* ---- Eyebrow — a small uppercase overline, generously letterspaced ---- */
.tqw-eyebrow {
  font-family: var(--tqw-font-ui);
  font-size: var(--tqw-size-ui-xs);
  font-weight: var(--tqw-weight-semibold);
  letter-spacing: var(--tqw-tracking-eyebrow);
  text-transform: uppercase;
  color: var(--tqw-text-muted);
  margin: 0;
}

/* ---- Hero heading (Cormorant, display lg, clamped for mobile) ---- */
.tqw-hero {
  font-family: var(--tqw-font-display);
  font-weight: var(--tqw-weight-display);
  font-size: clamp(2.25rem, 5vw, var(--tqw-size-display-lg));
  line-height: var(--tqw-leading-display);
  letter-spacing: var(--tqw-tracking-display);
  color: var(--tqw-text-strong);
  margin: 0;
  text-wrap: pretty;
}

/* ---- Section rhythm helpers ---- */
.tqw-section { width: 100%; }
.tqw-section + .tqw-section { margin-top: var(--tqw-space-9); }
.tqw-stack-4 { margin-top: var(--tqw-space-4); }
.tqw-stack-5 { margin-top: var(--tqw-space-5); }
.tqw-stack-6 { margin-top: var(--tqw-space-6); }
.tqw-stack-8 { margin-top: var(--tqw-space-8); }

/* ---- Divider — short centred Golden Light mark for section breaks ---- */
.tqw-divider--short {
  width: 48px;
  height: 2px;
  margin: var(--tqw-space-6) auto;
  background: var(--tqw-rule-hairline);
}
.tqw-divider--gold { background: var(--tqw-rule-gold); }

/* ---- Button — the single call to action ---- */
.tqw-button {
  font-family: var(--tqw-font-ui);
  font-weight: var(--tqw-weight-medium);
  font-size: var(--tqw-size-ui-md);
  letter-spacing: var(--tqw-tracking-ui);
  line-height: 1;
  padding: 0.75rem 1.5rem;
  border-radius: var(--tqw-radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: auto;
  text-decoration: none;
  -webkit-font-smoothing: antialiased;
  transition:
    background-color var(--tqw-dur-base) var(--tqw-ease-quiet),
    color var(--tqw-dur-base) var(--tqw-ease-quiet),
    border-color var(--tqw-dur-base) var(--tqw-ease-quiet);
}
.tqw-button:focus-visible { outline: none; box-shadow: var(--tqw-focus-ring); }
.tqw-button--sm { padding: 0.5rem 1rem; font-size: var(--tqw-size-ui-sm); }
.tqw-button--lg { padding: 0.9375rem 2rem; font-size: var(--tqw-size-ui-lg); }
.tqw-button--full { width: 100%; }
.tqw-button[disabled], .tqw-button[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; }

.tqw-button--primary { background: var(--tqw-accent); color: var(--tqw-text-on-water); }
.tqw-button--primary:hover:not([disabled]) { background: var(--tqw-accent-hover); }

.tqw-button--secondary {
  background: transparent;
  color: var(--tqw-ink);
  border-color: var(--tqw-rule-strong);
}
.tqw-button--secondary:hover:not([disabled]) {
  border-color: var(--tqw-ink);
  background: var(--tqw-bone-0);
}

.tqw-button--ghost { background: transparent; color: var(--tqw-text-link); padding: 0.5rem 0.25rem; }
.tqw-button--ghost:hover:not([disabled]) { color: var(--tqw-text-link-hover); }

/* ---- TextField — a single labelled input ---- */
.tqw-field { width: 100%; }
.tqw-field__label {
  display: block;
  font-family: var(--tqw-font-ui);
  font-size: var(--tqw-size-ui-sm);
  font-weight: var(--tqw-weight-medium);
  letter-spacing: var(--tqw-tracking-ui);
  color: var(--tqw-text-muted);
  margin-bottom: var(--tqw-space-2);
}
.tqw-field__req { color: var(--tqw-brown); }
.tqw-field__input {
  font-family: var(--tqw-font-ui);
  font-size: var(--tqw-size-ui-lg);
  color: var(--tqw-ink);
  background: var(--tqw-field-bg);
  border: var(--tqw-border-field);
  border-radius: var(--tqw-radius-md);
  padding: 0.8125rem 1rem;
  width: 100%;
  line-height: 1.3;
  outline: none;
  box-sizing: border-box;
  transition:
    border-color var(--tqw-dur-base) var(--tqw-ease-quiet),
    box-shadow var(--tqw-dur-base) var(--tqw-ease-quiet);
}
.tqw-field__input::placeholder { color: var(--tqw-field-placeholder); }
.tqw-field__input:focus {
  border-color: var(--tqw-field-border-focus);
  box-shadow: 0 0 0 3px var(--tqw-accent-wash);
}
.tqw-field__hint {
  font-family: var(--tqw-font-ui);
  font-size: var(--tqw-size-ui-sm);
  color: var(--tqw-text-muted);
  line-height: var(--tqw-leading-ui);
  margin-top: var(--tqw-space-2);
}
.tqw-field--error .tqw-field__input { border-color: #a6552f; }
.tqw-field--error .tqw-field__hint { color: #a6552f; }

/* ---- EmailSignup — the page's single form ---- */
.tqw-signup { display: flex; flex-direction: column; gap: var(--tqw-space-4); width: 100%; }
.tqw-signup__row { display: flex; flex-direction: column; align-items: stretch; gap: var(--tqw-space-3); }
.tqw-signup__field { flex: 1; }
.tqw-signup__note {
  font-family: var(--tqw-font-ui);
  font-size: var(--tqw-size-ui-sm);
  color: var(--tqw-text-muted);
  line-height: var(--tqw-leading-ui);
  margin: 0;
}
/* honeypot — kept far off-screen, never focusable */
.tqw-signup__hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
}
.tqw-signup__success {
  font-family: var(--tqw-font-body);
  font-size: var(--tqw-size-body-lg);
  line-height: var(--tqw-leading-body);
  color: var(--tqw-ink);
  border-left: 2px solid var(--tqw-water-deep);
  padding-left: var(--tqw-space-5);
}
[hidden] { display: none !important; }

/* ---- StoneImage — a matte photography block in one of three registers ---- */
.tqw-stone {
  position: relative;
  margin: 0;
  width: 100%;
  overflow: hidden;
  border-radius: var(--tqw-radius-lg);
  background: var(--tqw-sand);
}
.tqw-stone--flat { border-radius: 0; }
.tqw-stone img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* graceful with no photograph: the warm sand band stands in for the image */
.tqw-stone--empty img { display: none; }
.tqw-stone__wash {
  position: absolute;
  inset: 0;
  background: var(--tqw-wash-hero);
}
