/* /cullective/ root page — brand-styled member landing + account hub.
   Reuses brand tokens from cullective-brand.css (cc-* vars). */

.cr {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 24px;
  color: var(--cc-fg);
  font-family: var(--cc-font);
}
.cr * { box-sizing: border-box; }

/* ── Hero ───────────────────────────────────────── */
.cr-hero {
  text-align: center;
  padding: 80px 0 56px;
  position: relative;
}
.cr-hero-inner { max-width: 760px; margin: 0 auto; }

/* Split hero — pitch on the left, auth card on the right (modern landing pattern). */
.cr-hero--split {
  display: grid;
  grid-template-columns: 1fr 460px;
  gap: 56px;
  align-items: center;
  text-align: left;
  padding: 80px 0 56px;
}
.cr-hero-pitch { max-width: 540px; }
.cr-hero-pitch .cr-hero-tagline { margin-left: 0; max-width: 48ch; }
.cr-hero-pitch .cr-hero-actions { justify-content: flex-start; }
.cr-hero-pitch .cr-hero-ogham { text-align: left; margin-top: 28px; }
.cr-hero-auth { width: 100%; scroll-margin-top: 80px; }
@media (max-width: 980px) {
  .cr-hero--split {
    grid-template-columns: 1fr;
    gap: 36px;
    text-align: center;
  }
  .cr-hero-pitch .cr-hero-tagline { margin-left: auto; margin-right: auto; }
  .cr-hero-pitch .cr-hero-actions { justify-content: center; }
  .cr-hero-pitch .cr-hero-ogham { text-align: center; }
}
.cr-eyebrow {
  font-family: var(--cc-font);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cc-warm-deep);
  font-size: 0.78rem;
  font-weight: 700;
  margin-bottom: 14px;
}
.cr-hero-title {
  font-family: var(--cc-font-display);
  font-weight: 700;
  font-size: clamp(2.2rem, 6vw, 3.8rem);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cc-fg);
  margin: 0 0 18px;
  line-height: 1.05;
}
.cr-hero-tagline {
  font-family: var(--cc-font-slab);
  font-size: clamp(1rem, 1.6vw, 1.2rem);
  line-height: 1.55;
  color: var(--cc-body);
  max-width: 56ch;
  margin: 0 auto 28px;
}
.cr-hero-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}
.cr-hero-ogham {
  margin-top: 36px;
  font-family: serif;
  font-size: 1.6rem;
  letter-spacing: 0.6em;
  color: var(--cc-warm);
  opacity: 0.8;
}

/* ── Buttons (mirrors cs-btn variants) ──────────── */
.cr-btn {
  display: inline-block;
  padding: 13px 26px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.86rem;
  text-decoration: none;
  border-radius: 4px;
  transition: transform .15s ease, background-color .15s ease;
}
.cr-btn:hover { transform: translateY(-1px); }
.cr-btn-primary {
  background: var(--cc-accent);
  color: var(--cc-bg);
}
.cr-btn-primary:hover { background: var(--cc-warm); }
.cr-btn-ghost {
  background: transparent;
  color: var(--cc-fg);
  border: 1px solid color-mix(in srgb, var(--cc-fg) 25%, transparent);
}
.cr-btn-ghost:hover { border-color: var(--cc-warm); color: var(--cc-warm-deep); }

/* ── Stats strip ────────────────────────────────── */
.cr-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding: 32px 0;
  border-top: 1px solid color-mix(in srgb, var(--cc-fg) 12%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--cc-fg) 12%, transparent);
  margin-bottom: 64px;
}
.cr-stat { text-align: center; }
.cr-stat strong {
  display: block;
  font-family: var(--cc-font-display);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 700;
  color: var(--cc-warm-deep);
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}
.cr-stat span {
  font-family: var(--cc-font);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cc-muted);
}

/* ── Section primitives ─────────────────────────── */
.cr-section-eyebrow {
  font-family: var(--cc-font);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cc-warm-deep);
  font-size: 0.78rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.cr-section-title {
  font-family: var(--cc-font-slab);
  font-weight: 600;
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  margin: 0 0 28px;
  color: var(--cc-fg);
}

/* ── Benefits grid ──────────────────────────────── */
.cr-benefits { padding: 48px 0; }
.cr-benefit-grid {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
  padding: 0;
  margin: 0;
}
.cr-benefit {
  background: color-mix(in srgb, var(--cc-bg) 96%, var(--cc-fg) 4%);
  border-radius: var(--cc-radius);
  padding: 24px;
  border-left: 3px solid var(--cc-accent);
}
.cr-benefit-glyph {
  display: inline-block;
  font-family: serif;
  font-size: 1.5rem;
  color: var(--cc-warm);
  margin-bottom: 8px;
}
.cr-benefit h3 {
  font-family: var(--cc-font-slab);
  font-size: 1.05rem;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--cc-fg);
}
.cr-benefit p {
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.55;
  color: var(--cc-body);
}

/* ── Quotes grid ────────────────────────────────── */
.cr-quotes { padding: 48px 0; }
.cr-quote-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
}
.cr-quote {
  margin: 0;
  padding: 22px;
  background: color-mix(in srgb, var(--cc-bg) 96%, var(--cc-fg) 4%);
  border-left: 3px solid var(--cc-warm);
  border-radius: var(--cc-radius);
}
.cr-quote p {
  font-family: var(--cc-font-slab);
  font-style: italic;
  font-size: 0.98rem;
  line-height: 1.55;
  margin: 0 0 12px;
  color: var(--cc-fg);
}
.cr-quote footer {
  font-family: var(--cc-font);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cc-muted);
}

/* ── CTA cards ──────────────────────────────────── */
.cr-cta { padding: 56px 0 80px; text-align: center; }
.cr-cta-title {
  font-family: var(--cc-font-slab);
  font-weight: 600;
  font-size: clamp(1.5rem, 3vw, 2rem);
  margin: 0 0 28px;
  color: var(--cc-fg);
}
.cr-cta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 22px;
  text-align: left;
  max-width: 880px;
  margin: 0 auto;
}
.cr-cta-card {
  display: block;
  padding: 26px;
  border-radius: var(--cc-radius);
  background: color-mix(in srgb, var(--cc-bg) 96%, var(--cc-fg) 4%);
  border: 1px solid color-mix(in srgb, var(--cc-fg) 12%, transparent);
  color: var(--cc-fg);
  text-decoration: none;
  transition: transform .15s ease, border-color .15s ease;
}
.cr-cta-card:hover {
  transform: translateY(-2px);
  border-color: var(--cc-warm);
}
.cr-cta-card--primary {
  background: var(--cc-fg);
  color: var(--cc-bg);
  border-color: var(--cc-fg);
}
.cr-cta-card-eyebrow {
  font-family: var(--cc-font);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--cc-warm);
  margin: 0 0 6px;
}
.cr-cta-card h3 {
  font-family: var(--cc-font-slab);
  font-size: 1.4rem;
  margin: 0 0 10px;
}
.cr-cta-card-body {
  font-size: 0.94rem;
  line-height: 1.55;
  margin: 0 0 16px;
  color: inherit;
  opacity: 0.85;
}
.cr-cta-card-go {
  font-family: var(--cc-font);
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--cc-warm);
}
.cr-cta-card--primary .cr-cta-card-go { color: var(--cc-warm); }
.cr-cta-fine {
  margin-top: 28px;
  font-size: 0.88rem;
  color: var(--cc-muted);
}
.cr-cta-fine a { color: var(--cc-warm-deep); }

/* ── Auth flow — single-card tabbed login/register (modern UX) ─── */
.cr-auth {
  padding: 56px 0 96px;
  scroll-margin-top: 80px;
}
.cr-auth-card {
  max-width: 460px;
  margin: 0 auto;
  background: color-mix(in srgb, var(--cc-bg) 96%, var(--cc-fg) 4%);
  border: 1px solid color-mix(in srgb, var(--cc-fg) 12%, transparent);
  border-radius: var(--cc-radius);
  padding: 36px 32px;
  box-shadow: 0 8px 28px -12px rgba(15,24,21,0.18);
}
.cr-auth-head {
  text-align: center;
  margin-bottom: 24px;
}
.cr-auth-eyebrow {
  font-family: var(--cc-font);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cc-warm-deep);
  margin: 0 0 8px;
}
.cr-auth-title {
  font-family: var(--cc-font-slab);
  font-weight: 600;
  font-size: 1.6rem;
  color: var(--cc-fg);
  margin: 0 0 6px;
}
.cr-auth-sub {
  font-family: var(--cc-font);
  font-size: 0.95rem;
  color: var(--cc-body);
  line-height: 1.5;
  margin: 0;
}

/* Tabs */
.cr-auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-bottom: 24px;
  border-bottom: 1px solid color-mix(in srgb, var(--cc-fg) 14%, transparent);
}
/* Tab buttons — !important on color to defeat hello-elementor's red button:hover. */
button.cr-auth-tab {
  background: transparent !important;
  border: 0 !important;
  padding: 12px 8px !important;
  font-family: var(--cc-font) !important;
  font-size: 0.84rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--cc-muted) !important;
  cursor: pointer;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
  transition: color 160ms ease, border-color 160ms ease;
  margin-bottom: -1px;
}
button.cr-auth-tab[aria-selected="true"] {
  color: var(--cc-warm-deep) !important;
  border-bottom-color: var(--cc-warm) !important;
  background: transparent !important;
}
button.cr-auth-tab:hover {
  color: var(--cc-fg) !important;
  background: transparent !important;
}

/* Forms */
.cr-auth-form {
  display: none;
  flex-direction: column;
  gap: 14px;
}
.cr-auth-card[data-active-tab="login"]    .cr-auth-form--login    { display: flex; }
.cr-auth-card[data-active-tab="register"] .cr-auth-form--register { display: flex; }
.cr-auth-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: var(--cc-font);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--cc-body);
}
.cr-auth-field input {
  padding: 11px 14px;
  border: 1px solid rgba(15,76,92,0.28);
  border-radius: 4px;
  font-family: var(--cc-font);
  font-size: 1rem;
  font-weight: 400;
  background: var(--cc-bg);
  color: var(--cc-fg);
  transition: border-color 160ms ease, box-shadow 160ms ease;
}
.cr-auth-field input:focus {
  outline: 0;
  border-color: var(--cc-warm);
  box-shadow: 0 0 0 3px rgba(169,136,65,0.18);
}
.cr-auth-hint {
  font-size: 0.78rem;
  font-weight: 400;
  color: var(--cc-muted);
}
.cr-auth-remember {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.88rem;
  font-weight: 400;
  color: var(--cc-body);
  cursor: pointer;
}
.cr-auth-remember input { width: auto; margin: 0; }
.cr-auth-submit {
  background: var(--cc-warm-deep);
  color: var(--cc-bg);
  border: 0;
  padding: 13px 26px;
  border-radius: 4px;
  font-family: var(--cc-font);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 0.86rem;
  cursor: pointer;
  margin-top: 6px;
  transition: background 160ms ease, transform 120ms ease;
}
.cr-auth-submit:hover {
  background: var(--cc-warm);
  transform: translateY(-1px);
}
.cr-auth-foot {
  text-align: center;
  font-size: 0.85rem;
  color: var(--cc-muted);
  margin: 4px 0 0;
  line-height: 1.5;
}
.cr-auth-foot a { color: var(--cc-warm-deep) !important; text-decoration: none !important; }
.cr-auth-foot a:hover { color: var(--cc-warm) !important; text-decoration: underline !important; }
.cr-auth-foot small { font-size: 0.85rem; color: var(--cc-muted); }
@media (max-width: 480px) {
  .cr-auth-card { padding: 28px 22px; }
}

/* ── Logged-in account block ────────────────────── */
.cr-account {
  padding: 48px 0 80px;
}
.cr-account-frame {
  background: color-mix(in srgb, var(--cc-bg) 96%, var(--cc-fg) 4%);
  border-radius: var(--cc-radius);
  padding: 24px;
}

/* WC my-account inherits brand by way of the wrapper background;
   override the loud defaults so the dashboard nav fits the brand. */
.cr-account-frame .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  border-bottom: 1px solid color-mix(in srgb, var(--cc-fg) 14%, transparent);
}
.cr-account-frame .woocommerce-MyAccount-navigation li a {
  display: inline-block;
  padding: 8px 14px;
  font-family: var(--cc-font);
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--cc-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
}
.cr-account-frame .woocommerce-MyAccount-navigation li.is-active a,
.cr-account-frame .woocommerce-MyAccount-navigation li a:hover {
  color: var(--cc-warm-deep);
  border-bottom-color: var(--cc-warm);
}

@media (max-width: 720px) {
  .cr-stats { grid-template-columns: repeat(2, 1fr); }
}
