/* Login page layout. Brand values come from design/tokens.css — this file only
   composes them; it never hardcodes a brand color or font. */

* { box-sizing: border-box; }

.auth {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
  padding: var(--space-5) var(--space-3);
  /* The club's hero backdrop, kept subtle behind the card. */
  background-color: var(--color-bg);
  background-image: url("/design/brand/taust-background.svg");
  background-size: cover;
  background-position: center;
}

.auth__logo {
  width: 200px;
  max-width: 70vw;
  height: auto;
}

.card {
  width: 100%;
  max-width: 420px;
  background-color: var(--color-surface);
  border-radius: 18px;
  padding: var(--space-6) var(--space-4) var(--space-5);
  text-align: center;
  box-shadow: 0 24px 60px rgba(72, 34, 76, 0.18);
}

.auth__title {
  margin: 0 0 var(--space-2);
  font-size: var(--fs-2xl);
  color: var(--color-text);
}

.auth__lead {
  margin: 0 0 var(--space-4);
  color: var(--color-text);
  opacity: 0.85;
}

.auth__form { display: flex; flex-direction: column; gap: var(--space-3); text-align: left; }

.auth__label {
  font-size: var(--fs-sm);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text);
}

.input {
  width: 100%;
  padding: 16px 18px;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--color-text);
  background: var(--hearth-white);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-pill);
  outline: none;
}
.input:focus { border-color: var(--color-accent); }
.input[aria-invalid="true"] { border-color: var(--color-danger); color: var(--color-danger); }

/* .btn / .btn--filled come from tokens.css; here we just make them full-width. */
.btn { width: 100%; padding: 18px 28px; font-size: var(--fs-md); }

.auth__hint {
  margin: var(--space-3) 0 0;
  font-size: var(--fs-sm);
  color: var(--color-text);
  opacity: 0.7;
}

/* ===== App pages (profile, directory, admin) ============================ */
.app { background-color: var(--color-bg); min-height: 100dvh; }

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-3);
  padding: var(--space-2) var(--space-4);
  background-color: var(--color-header-bg);
}
.nav__brand img { height: 28px; width: auto; display: block; }
.nav__links { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.nav__link {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--hearth-pink);
  background: none;
  border: 0;
  cursor: pointer;
  text-decoration: none;
  opacity: 0.85;
}
.nav__link:hover, .nav__link.is-active { opacity: 1; text-decoration: underline; text-underline-offset: 4px; }
.nav__link.is-active { text-decoration-thickness: 2px; }
/* Logout reads as a quieter action but must stay legible on purple. */
.nav__logout { opacity: 0.7; }
.nav__logout:hover { opacity: 1; }

@media (max-width: 420px) {
  .nav { padding: var(--space-2) var(--space-3); }
  .nav__links { gap: var(--space-2); width: 100%; justify-content: flex-start; }
}

.page {
  max-width: 720px;
  margin: 0 auto;
  padding: var(--space-5) var(--space-3) var(--space-7);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.page__head { text-align: left; position: relative; }
/* Brand square-motif accent, quiet, top-right of the page header. Hidden on
   the narrowest screens so it never crowds the title. */
.page__head::after {
  content: "";
  position: absolute;
  top: -8px; right: 0;
  width: 110px; height: 80px;
  opacity: 0.9;
  background-image: url("/design/brand/motif.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: top right;
  pointer-events: none;
}
.page__title { margin: 0; font-size: var(--fs-2xl); color: var(--color-text); position: relative; }
.page__sub { margin: var(--space-1) 0 0; color: var(--color-text); opacity: 0.75; max-width: 46ch; position: relative; }

@media (max-width: 520px) {
  .page__head::after { display: none; }
}

.card--wide { max-width: none; text-align: left; padding: var(--space-4); }
.card__title { margin: 0 0 var(--space-3); font-size: var(--fs-lg); color: var(--color-text); }
.card__lead { margin: 0 0 var(--space-3); color: var(--color-text); opacity: 0.8; }

.form { display: flex; flex-direction: column; gap: var(--space-3); }
.field { display: flex; flex-direction: column; gap: var(--space-1); }
.field > span { font-size: var(--fs-sm); color: var(--color-text); opacity: 0.85; }
.form .input { border-radius: 12px; } /* less pill, more form-like for text fields */
.form .btn { width: auto; align-self: flex-start; padding: 14px 28px; font-size: var(--fs-base); }
.form__status { font-size: var(--fs-sm); color: var(--color-text); opacity: 0.8; min-height: 1.2em; }

.toggle { display: flex; align-items: flex-start; gap: var(--space-2); cursor: pointer; }
.toggle input { margin-top: 4px; width: 18px; height: 18px; accent-color: var(--color-primary); }
.toggle > span { color: var(--color-text); }

/* Directory */
.directory__search { border-radius: var(--radius-pill); }
.directory { display: flex; flex-direction: column; gap: var(--space-2); }
.directory__empty { color: var(--color-text); opacity: 0.7; }
.member {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  background-color: var(--color-surface);
  border-radius: 14px;
}
.member__avatar {
  flex: 0 0 auto;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background-color: var(--color-primary);
  color: var(--hearth-pink);
  font-family: var(--font-display);
  font-size: var(--fs-base);
}
.member__body { flex: 1 1 auto; min-width: 0; }
.member__name { color: var(--color-text); font-size: var(--fs-md); }
.member__meta { color: var(--color-text); opacity: 0.7; font-size: var(--fs-sm); }
.member__club { color: var(--color-text); opacity: 0.7; font-size: var(--fs-sm); white-space: nowrap; }

/* Calendar / agenda */
.agenda { display: flex; flex-direction: column; gap: var(--space-4); }
.agenda__month { display: flex; flex-direction: column; gap: var(--space-2); }
.agenda__heading {
  margin: 0 0 var(--space-1);
  font-size: var(--fs-lg);
  color: var(--color-text);
  position: sticky; top: 0;
  background: var(--color-bg);
  padding: var(--space-1) 0;
}
.event {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background-color: var(--color-surface);
  border-radius: 14px;
}
.event__date {
  flex: 0 0 auto;
  width: 52px; height: 52px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  border-radius: 12px;
  background-color: var(--color-primary);
  color: var(--hearth-pink);
}
.event__wd { font-size: var(--fs-xs); opacity: 0.85; }
.event__day { font-family: var(--font-display); font-size: var(--fs-lg); line-height: 1; }
.event__body { flex: 1 1 auto; min-width: 0; }
/* Event titles carry the brand's event-cover voice: the display serif. */
.event__title { color: var(--color-text); font-family: var(--font-display); font-size: var(--fs-md); line-height: 1.2; }
.event__clubs { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.tag {
  font-size: var(--fs-xs);
  color: var(--color-primary);
  background: var(--hearth-lavender);
  border-radius: 50em;
  padding: 2px 10px;
}

/* Admin */
.admin__bar { display: flex; flex-direction: column; gap: var(--space-1); margin-bottom: var(--space-3); }
.admin__note { font-size: var(--fs-sm); color: var(--color-text); opacity: 0.7; }
.member .admin__invite { width: auto; padding: 10px 18px; font-size: var(--fs-sm); flex: 0 0 auto; }

/* ===== Phase 2b: RSVP, who's-coming, depth, matching, onboarding ======== */

/* The event row now stacks a little taller to hold RSVP controls. */
.event { align-items: flex-start; }
.event__count {
  font-size: var(--fs-xs);
  color: var(--color-primary);
  background: var(--hearth-pink);
  border: 1px solid var(--color-primary);
  border-radius: 50em;
  padding: 2px 10px;
}
.event__rsvp { display: flex; flex-wrap: wrap; gap: var(--space-1); margin-top: var(--space-2); }
.rsvp-btn {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--color-primary);
  background: var(--hearth-white);
  border: 1px solid var(--color-primary);
  border-radius: 50em;
  padding: 7px 16px;
  cursor: pointer;
}
.rsvp-btn:hover { border-color: var(--color-accent); color: var(--color-accent); }
.rsvp-btn:disabled { opacity: 0.5; cursor: default; }
.rsvp-btn.is-on { background: var(--color-primary); color: var(--hearth-pink); }
.rsvp-btn--ghost { border-style: dashed; opacity: 0.85; }

.attendees {
  margin-top: var(--space-2);
  display: flex; flex-wrap: wrap; gap: 6px;
  padding-top: var(--space-2);
  border-top: 1px solid var(--hearth-gray);
}
.attendees__title { flex: 0 0 100%; font-size: var(--fs-sm); color: var(--color-text); opacity: 0.85; }
.attendees__person {
  font-size: var(--fs-xs);
  color: var(--color-text);
  background: var(--hearth-lavender);
  border-radius: 50em;
  padding: 3px 10px;
}
.attendees__empty { font-size: var(--fs-sm); color: var(--color-text); opacity: 0.7; }

/* Substitution picker */
.subpanel {
  margin-top: var(--space-2);
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px dashed var(--hearth-gray);
}
.subpanel__select { border-radius: 12px; padding: 10px 14px; flex: 1 1 220px; }

/* Directory: depth snippet + interest tags under a member */
.member { align-items: flex-start; }
.member__bio { color: var(--color-text); opacity: 0.85; font-size: var(--fs-sm); margin-top: 4px; }
.member__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }

/* Textareas for depth fields (reuse .input look but taller). */
.textarea {
  width: 100%;
  min-height: 84px;
  resize: vertical;
  padding: 14px 16px;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--color-text);
  background: var(--hearth-white);
  border: 1px solid var(--color-primary);
  border-radius: 12px;
  outline: none;
}
.textarea:focus { border-color: var(--color-accent); }

/* Onboarding wizard */
.wizard { display: flex; flex-direction: column; gap: var(--space-3); }
.wizard__progress { font-size: var(--fs-sm); color: var(--color-text); opacity: 0.7; }
.wizard__q { font-family: var(--font-display); font-size: var(--fs-lg); color: var(--color-text); margin: 0; }
.wizard__hint { font-size: var(--fs-sm); color: var(--color-text); opacity: 0.75; margin: 0; }
.wizard__nav { display: flex; gap: var(--space-2); margin-top: var(--space-2); }
.wizard__nav .btn { width: auto; }
.btn--ghost { background: transparent; border: 1px solid var(--color-primary); color: var(--color-primary); }

/* Match card */
.match {
  padding: var(--space-3);
  background: var(--color-surface);
  border-radius: 14px;
  display: flex; flex-direction: column; gap: 4px;
}
.match__name { font-family: var(--font-display); font-size: var(--fs-md); color: var(--color-text); }
.match__meta { font-size: var(--fs-sm); color: var(--color-text); opacity: 0.75; }
