/* ═══════════════════════════════════════════════════════════════════════════
   bgpdx.com — Member Kit Design System
   Maps Bamboo Grove PDX brand tokens (coral/cream/dark) to --mk-* contract.
   Spec: member-kit/docs/design-system.md
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  /* Upstream brand tokens — mirrored from @theme in style.css; style.css is not
     loaded on /members to avoid Tailwind preflight conflicts with member-kit styles.
     Hex is allowed here as token definitions (E13 rule: hex only in :root token blocks). */
  --color-brand: #af4535;
  --color-accent: #c8853a;
  --color-white: #ffffff;
  --color-provider-google: #4285F4;
  --color-provider-linkedin: #0A66C2;
  --color-provider-discord: #5865F2;

  /* Site identity contract — 12 required --site-* vars */
  --site-hue: 10;
  --site-primary: var(--color-brand);
  --site-accent: var(--color-accent);
  --site-bg: #fdf6f0;
  --site-text: #1a1a1a;
  --site-dark: #333333;
  --site-muted: #6b7280;
  --site-border: #e5e0d8;
  --site-radius: 0.375rem;
  --site-font-body: 'Inter', sans-serif;
  --site-font-heading: 'Playfair Display', Georgia, serif;
  --site-transition: 0.2s ease;
  --site-surface: #ffffff;
  --site-text-muted: #7a6a62;
  --site-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  --site-dark-bg: #36454f;
  --site-gold: #d4a047;
  --site-nav-link-muted: #e0e0e0;
  --site-dark-red: #660000;
  --site-btn: #8e2516;
  --site-text-dark: #4a3a32;
  --mk-active-bg: #fdf0ec;
  --mk-border-light: #f4f0ec;
  --mk-success-text: #166534;
  --mk-error-text: #991b1b;
  --mk-warning-text: #92400e;
  --mk-info-text: #1e40af;
  --hhw-warning-bg: #fef3c7;
  --hhw-warning-text: #92400e;

  /* Status colours — spec requires --hhw-* namespace */
  --hhw-success-bg: #d1fae5;
  --hhw-success-text: #065f46;
  --hhw-error-bg: #fee2e2;
  --hhw-error-text: #991b1b;

  /* Map --mk-* to --site-* (spec E14: kit vars must reference site vars) */
  --mk-accent: var(--site-accent);
  --mk-primary: var(--site-primary);
  --mk-font: var(--site-font-body);
  --mk-radius: var(--site-radius);
  --mk-transition: var(--site-transition);

  /* Backgrounds — cream/light brand palette */
  --mk-bg:          var(--color-cream, #f4f4f4);
  --mk-surface:     #ffffff;
  --mk-surface-alt: #f9f4f0;
  --mk-border:      #ddd4cc;

  /* Text */
  --mk-text:           var(--color-dark, #1a1a1a);
  --mk-text-muted:     #7a6a62;
  --mk-text-on-accent: #ffffff;

  /* Accent — references site-primary (coral brand) via bridge defined above */
  --mk-accent-hover: var(--color-accent);

  /* Status */
  --mk-error:      #dc2626;
  --mk-success:    #16a34a;
  --mk-warning:    #d97706;
  --mk-info:       #2563eb;
  --mk-error-bg:   #fef2f2;
  --mk-success-bg: #f0fdf4;
  --mk-warning-bg: #fffbeb;
  --mk-info-bg:    #eff6ff;

  /* Typography */
  --mk-font:      var(--font-body, 'Lato', 'Open Sans', Arial, sans-serif);
  --mk-font-mono: ui-monospace, 'Courier New', monospace;
  --mk-text-sm:   0.875rem;
  --mk-text-base: 1rem;
  --mk-text-lg:   1.125rem;

  /* Shape & Motion */
  --mk-radius-sm:  0.25rem;
  --mk-radius:     0.375rem;
  --mk-radius-lg:  0.625rem;
  --mk-transition: 150ms ease;

  /* Layout */
  --mk-max-width: 480px;
  --mk-spacing:   1rem;
}

/* ── Badge components — spec E7/E8 ───────────────────────────────────────── */

.hhw-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.125rem 0.5rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
}
.hhw-badge--ok { background: var(--hhw-success-bg); color: var(--hhw-success-text); }
.hhw-badge--warn { background: var(--hhw-warning-bg, #fef3c7); color: var(--hhw-warning-text, #92400e); }
.hhw-badge--error { background: var(--hhw-error-bg); color: var(--hhw-error-text); }

/* ── 2FA input — spec E10 ─────────────────────────────────────────────────── */

.hhw-2fa-input {
  font-size: 1rem;
  letter-spacing: 0.25em;
  text-align: center;
  width: 2.5rem;
  padding: 0.5rem;
}

/* ── Touch targets — min 44px per spec F1/F13 ────────────────────────────── */

.site-nav a,
header nav a,
.sidebar-link,
.mk-tab-btn {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

/* ── Admin sidebar breakpoint — spec F11 ─────────────────────────────────── */

@media (max-width: 768px) {
  .admin-sidebar,
  [class*="sidebar"] {
    transform: translateX(-100%);
  }
}
@media (min-width: 769px) {
  .admin-sidebar,
  [class*="sidebar"] {
    transform: translateX(0);
  }
}

/* ── E15 — Banner/footer section classes (mirrors style.css; needed on /members) ── */
/* style.css is NOT loaded on /members — define here so members-footer.php can use
   the same CSS class names as the main templates/footer.php. */
.banner-section { background-color: var(--color-banner-bg, #36454f); color: var(--color-white); }
.banner-text  { font-size: 16px; font-weight: bold; color: var(--color-white); }
.banner-tel   { font-size: 18px; font-weight: bold; color: var(--color-white); }
.banner-line  { margin-top: 8px; color: var(--color-white); }
.banner-link  { color: var(--color-white); }
.footer-section { background-color: var(--site-dark-red, #660000); color: var(--color-white); padding: 15px 0; text-align: center; font-size: 0.9em; }
.footer-link  { color: var(--color-white); padding: 0 2px; font-weight: normal; font-size: 0.95em; }
.admin-console-link { color: var(--site-accent); }

/* ── Site Nav (injected via nav_include on /members) ─────────────────────── */

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

#bgpdx-panel { background: var(--site-surface, #fff); min-height: 100vh; }

.main-header { position: relative; padding: 6px 20px; max-width: 1140px; margin: 0 auto; }
.header-block { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.header-block .col-logo { flex: 1; }
.header-block .col-logo img { max-height: 90px; }
.header-block .col-phones { flex: 1; text-align: right; font-size: 0.875rem; color: var(--site-dark, #333); }
.header-block .col-phones p { margin-bottom: 2px; }
.header-block .col-phones a { color: var(--site-primary, #af4535); font-weight: bold; }

.toggle-button { display: none; color: var(--color-white); background: var(--mk-accent); border: none; padding: 8px 14px; font-size: 1.125rem; cursor: pointer; font-family: inherit; font-weight: bold; border-radius: 4px; margin: 4px auto; }
.toggle-button span { font-size: 0.875rem; text-transform: uppercase; letter-spacing: 1px; }

#nav-main { position: relative; margin: 0; padding: 0; min-height: 30px; background-color: var(--site-primary, #af4535); border-top-left-radius: 6px; border-top-right-radius: 6px; text-align: center; z-index: 1000; }
#nav-main-inner { max-width: 1140px; margin: 0 auto; }
#nav-main-inner > ul { display: block; }
#nav-main-inner > ul > li { display: inline-block; text-align: left; position: relative; }
#nav-main-inner > ul > li > a { display: block; padding: 12px 16px; font-weight: bold; color: var(--color-white); font-size: 0.875rem; transition: all 0.3s; }
#nav-main-inner > ul > li:hover { background-color: var(--site-dark-red, #660000); }
#nav-main-inner > ul > li > a:hover { color: var(--color-white); }
#nav-main-inner > ul > li.current > a { background-color: rgba(0,0,0,0.15); }
ul.nav-minor { display: none; position: absolute; top: 100%; left: 0; background-color: var(--site-dark-red, #660000); min-width: 280px; z-index: 1001; }
#nav-main-inner > ul > li:hover > ul.nav-minor { display: block; }
ul.nav-minor li { display: block; border-bottom: 1px dotted var(--color-white); }
ul.nav-minor li a { display: block; padding: 10px 16px; font-size: 0.8125rem; color: var(--site-nav-link-muted, #e0e0e0); transition: all 0.3s; }
ul.nav-minor li a:hover { padding-left: 22px; border-left: 4px solid var(--color-white); color: var(--color-white); }

#slideout-menu { display: none; position: fixed; top: 0; right: 0; bottom: 0; width: 256px; max-width: 85vw; min-height: 100vh; background: var(--mk-accent); overflow-y: auto; z-index: 2000; padding: 30px; transform: translateX(100%); transition: transform 0.3s ease; }
@media (prefers-reduced-motion: reduce) { #slideout-menu { transition: none; } }
#slideout-menu.open { transform: translateX(0); display: block; }
#slideout-menu ul li { margin-bottom: 16px; line-height: 2em; }
#slideout-menu ul li a { color: var(--site-nav-link-muted, #e0e0e0); font-size: 0.9375rem; font-weight: 400; }
#slideout-menu ul li a:hover { color: var(--color-white); }
#slideout-menu ul li ul { margin-left: 20px; margin-top: 8px; }
#slideout-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); z-index: 1999; }
#slideout-overlay.open { display: block; }

@media (min-width: 901px) {
    #nav-main { display: block; }
    .toggle-button { display: none !important; }
}
@media (max-width: 900px) {
    #nav-main { display: none; }
    .toggle-button { display: block; }
    .header-block { flex-direction: column; text-align: center; }
    .header-block .col-phones { text-align: center; }
}
@media (max-width: 767px) {
    .header-block .col-logo, .header-block .col-phones { width: 100%; }
}

/* ── Auth two-column layout — override member-kit grid ───────────────────── */

/* Fix #1: Cancel member-kit's CSS grid on .mk-auth-card, use flex column */
@media (min-width: 640px) {
    .mk-auth-card {
        display: flex !important;
        flex-direction: column;
        align-items: center;
    }

    /* Full-width columns container, no gap (border separates instead) */
    .mk-auth-cols {
        width: 100%;
        display: flex;
        gap: 0;
        align-items: flex-start;
    }

    /* Each column gets horizontal padding */
    .mk-auth-col {
        flex: 1;
        padding: 0 2rem;
    }

    /* Left col: no left pad, right border as divider */
    .mk-auth-col:first-child {
        padding-left: 0;
        border-right: 1px solid var(--site-border, #ddd4cc);
    }

    /* Right col: no right pad */
    .mk-auth-col:last-child {
        padding-right: 0;
    }

    /* Note: .mk-auth-card > .mk-social-btns and .mk-divider are hidden via
       JS (style.display='none') once columns are built. No CSS rule needed here
       — a CSS-only hide would break social login at 640-768px before JS fires. */
}

/* Fix #2: Column header titles */
.mk-auth-col-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--site-primary, #af4535);
    margin: 0 0 1.25rem;
    padding-bottom: 0.625rem;
    border-bottom: 2px solid var(--site-primary, #af4535);
    letter-spacing: 0.02em;
}

/* Fix #3: Per-column "or" dividers added by JS */
.mk-col-divider {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 1rem 0;
    font-size: 0.8125rem;
    color: var(--site-text-muted, #7a6a62);
}
.mk-col-divider::before,
.mk-col-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--site-border, #ddd4cc);
}

/* Fix #4: Social buttons inside columns — full width */
.mk-auth-col .mk-social-btns {
    width: 100%;
}
.mk-auth-col .mk-social-btn {
    width: 100%;
}

/* Fix #7: Max-width card at 640px breakpoint (matches grid override) */
@media (min-width: 640px) {
    .mk-auth-card {
        max-width: 860px !important;
        width: 100%;
    }
}

/* ── Site utility button (used in footer banner, matches header.php) ─────── */

.btn {
  display: inline-block;
  padding: 7px 16px;
  background: var(--site-btn, #8e2516);
  color: var(--color-white) !important;
  font-family: inherit;
  font-weight: 500;
  border-radius: 3px;
  border: none;
  letter-spacing: 1px;
  cursor: pointer;
  transition: all 0.3s;
  text-decoration: none;
}
.btn:hover { background: var(--mk-accent); color: var(--color-white) !important; text-decoration: none; }

/* ── Core Components ──────────────────────────────────────────────────────── */

.mk-btn--primary {
  background: var(--mk-accent);
  color: var(--mk-text-on-accent);
  border: none;
  border-radius: var(--mk-radius);
  padding: 0.625rem 1.5rem;
  font-size: var(--mk-text-base);
  font-family: var(--mk-font);
  font-weight: 600;
  cursor: pointer;
  transition: background var(--mk-transition), transform var(--mk-transition);
}
.mk-btn--primary:hover { background: var(--mk-accent-hover); transform: translateY(-1px); }

.mk-btn--ghost {
  background: transparent;
  color: var(--mk-accent);
  border: 1px solid var(--mk-accent);
  border-radius: var(--mk-radius);
  padding: 0.625rem 1.5rem;
  font-size: var(--mk-text-base);
  font-weight: 600;
  cursor: pointer;
  transition: background var(--mk-transition), color var(--mk-transition);
}
.mk-btn--ghost:hover { background: var(--mk-accent); color: var(--mk-text-on-accent); }

.mk-btn--danger {
  background: var(--mk-error);
  color: var(--color-white);
  border: none;
  border-radius: var(--mk-radius);
  padding: 0.625rem 1.5rem;
  font-size: var(--mk-text-base);
  font-weight: 600;
  cursor: pointer;
}

.mk-input {
  background: var(--site-surface, #fff);
  border: 1px solid var(--mk-border);
  border-radius: var(--mk-radius-sm);
  color: var(--mk-text);
  padding: 0.5rem 0.75rem;
  font-size: 1rem;
  font-family: var(--mk-font);
  width: 100%;
  transition: border-color var(--mk-transition);
}
.mk-input:focus { outline: 2px solid var(--mk-accent); outline-offset: -1px; border-color: var(--mk-accent); }

.mk-status { padding: 0.75rem 1rem; border-radius: var(--mk-radius); font-size: var(--mk-text-sm); }
.mk-status[data-type="error"]   { background: var(--mk-error-bg);   color: var(--mk-error); }
.mk-status[data-type="success"] { background: var(--mk-success-bg); color: var(--mk-success); }
.mk-status[data-type="warning"] { background: var(--mk-warning-bg); color: var(--mk-warning); }
.mk-status[data-type="info"]    { background: var(--mk-info-bg);    color: var(--mk-info); }

/* ── Body + root overrides (dashboard renders its own <body>) ─────────────── */

body {
  margin: 0;
  padding: 0;
  background-color: var(--mk-bg, #f4f4f4);
  font-family: 'Lato', 'Open Sans', Arial, Helvetica, sans-serif;
  color: var(--site-text, #1a1a1a);
  line-height: 1.5;
}

body a { color: var(--site-primary, #af4535); text-decoration: none; }
body a:hover { text-decoration: underline; }
body img { max-width: 100%; height: auto; display: block; }
body p { margin: 0; }
body ul, body ol { margin: 0; padding: 0; list-style: none; }

/* Override kit's min-height:100vh — nav is above .mk-root so the viewport calc is off */
.mk-root { min-height: auto !important; }

/* Auth section: warm site background, comfortable vertical padding (Fix #6) */
.mk-auth {
  background: var(--site-bg, #fdf6f0);
  min-height: auto !important;
  padding: 3rem 1rem;
}

/* Auth card: white surface, subtle shadow, coral top accent */
.mk-auth-card {
  background: var(--site-surface, #fff);
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
  padding: 2rem 2rem 2rem;
  border-top: 3px solid var(--site-primary, #af4535);
}

/* Auth logo: slightly larger on desktop */
.mk-auth-logo img { max-height: 64px; }

/* Auth tabs (mobile fallback — on desktop replaced by columns JS) */
.mk-auth-tab {
  background: var(--mk-bg, #f4f4f4);
  color: var(--site-text-muted, #7a6a62);
  border-bottom: 2px solid transparent;
  font-family: 'Lato', 'Open Sans', Arial, sans-serif;
  font-size: 0.9375rem;
  transition: color 150ms ease, background 150ms ease;
}
.mk-auth-tab--active {
  background: var(--site-surface, #fff);
  color: var(--site-primary, #af4535);
  font-weight: 700;
  border-bottom-color: var(--site-primary, #af4535);
}
.mk-auth-tab:hover { color: var(--site-primary, #af4535); }

/* ── Touch targets — 44px minimum ────────────────────────────────────────── */

.mk-input,
.mk-textarea,
.mk-select {
  min-height: 44px;
  font-size: 1rem; /* prevents iOS zoom */
  padding: 0.625rem 0.875rem;
}

.mk-btn {
  min-height: 44px;
  font-family: 'Lato', 'Open Sans', Arial, sans-serif;
  letter-spacing: 0.02em;
}

/* Labels: slightly larger for readability */
.mk-label {
  font-family: 'Lato', 'Open Sans', Arial, sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--site-text-dark, #4a3a32);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ── Social buttons — brand colors ───────────────────────────────────────── */

.mk-social-btn {
  font-family: 'Lato', 'Open Sans', Arial, sans-serif;
  font-size: 0.9375rem;
  font-weight: 500;
  min-height: 44px;
  border: 1px solid var(--site-border, #ddd4cc);
  background: var(--site-surface, #fff);
  color: var(--site-text, #1a1a1a);
  transition: background 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
}
.mk-social-btn:hover { background: var(--mk-surface-alt, #f9f4f0); border-color: var(--site-primary, #af4535); box-shadow: 0 1px 4px rgba(0,0,0,0.1); }
.mk-social-btn[data-provider="google"]:hover  { border-color: var(--color-provider-google); }
.mk-social-btn[data-provider="linkedin"]:hover { border-color: var(--color-provider-linkedin); }
.mk-social-btn[data-provider="discord"]:hover  { border-color: var(--color-provider-discord); }

/* Divider text */
.mk-divider { color: var(--site-text-muted, #7a6a62); font-size: 0.8125rem; }
.mk-divider::before, .mk-divider::after { background: var(--site-border, #ddd4cc); }

/* ── Status messages (toast area) ────────────────────────────────────────── */

.mk-status-msg { font-family: 'Lato', 'Open Sans', Arial, sans-serif; }
.mk-status-msg[data-type="success"] { background: var(--mk-success-bg, #f0fdf4); color: var(--mk-success-text, #166534); border-left: 3px solid var(--mk-success, #16a34a); }
.mk-status-msg[data-type="error"]   { background: var(--mk-error-bg, #fef2f2);   color: var(--mk-error-text, #991b1b);   border-left: 3px solid var(--mk-error, #dc2626); }
.mk-status-msg[data-type="warning"] { background: var(--mk-warning-bg, #fffbeb); color: var(--mk-warning-text, #92400e); border-left: 3px solid var(--mk-warning, #d97706); }
.mk-status-msg[data-type="info"]    { background: var(--mk-info-bg, #eff6ff);    color: var(--mk-info-text, #1e40af);    border-left: 3px solid var(--mk-info, #2563eb); }

/* ── Dashboard (logged-in): sidebar + content ────────────────────────────── */

.mk-dashboard { min-height: calc(100vh - 160px); }

.mk-sidebar {
  background: var(--site-surface, #fff);
  border-right: 1px solid var(--site-border, #ddd4cc);
}

.mk-dashboard-site-name {
  font-family: 'Lato', 'Open Sans', Arial, sans-serif;
  color: var(--site-primary, #af4535);
}

.mk-tab {
  font-family: 'Lato', 'Open Sans', Arial, sans-serif;
  color: var(--site-text-dark, #4a3a32);
  transition: background 150ms ease, color 150ms ease;
}
.mk-tab:hover { background: var(--mk-surface-alt, #f9f4f0); color: var(--site-primary, #af4535); }
.mk-tab--active { background: var(--mk-active-bg, #fdf0ec); color: var(--site-primary, #af4535); font-weight: 700; }

.mk-panel-title {
  color: var(--site-primary, #af4535);
  font-family: 'Lato', 'Open Sans', Arial, sans-serif;
  border-bottom: 1px solid var(--site-border, #ddd4cc);
  padding-bottom: 0.75rem;
}

.mk-section-title { color: var(--site-text-muted, #7a6a62); font-family: 'Lato', 'Open Sans', Arial, sans-serif; }

.mk-avatar { background: var(--mk-accent); color: var(--color-white); font-family: 'Lato', 'Open Sans', Arial, sans-serif; }
.mk-display-name { color: var(--site-text, #1a1a1a); font-family: 'Lato', 'Open Sans', Arial, sans-serif; }
.mk-user-email { color: var(--site-text-muted, #7a6a62); font-family: 'Lato', 'Open Sans', Arial, sans-serif; }

.mk-connection-row { border-bottom: 1px solid var(--mk-border-light, #f4f0ec); }
.mk-connection-label { color: var(--site-text, #1a1a1a); font-family: 'Lato', 'Open Sans', Arial, sans-serif; }
.mk-connection-detail { color: var(--site-text-muted, #7a6a62); font-family: 'Lato', 'Open Sans', Arial, sans-serif; }

/* ── Two-column auth: mobile collapse (Fix #5) ───────────────────────────── */

@media (max-width: 639px) {
  .mk-auth-card { padding: 1.5rem 1rem; }
  .mk-auth { padding: 1.5rem 0.75rem 2rem; }
  .mk-auth-col-title { font-size: 1rem; }

  /* Stack columns vertically with a top-border separator */
  .mk-auth-cols {
    flex-direction: column;
    gap: 2rem;
  }
  .mk-auth-col {
    padding: 0;
    border-right: none !important;
    border-top: 1px solid var(--site-border, #ddd4cc);
    padding-top: 2rem;
  }
  .mk-auth-col:first-child {
    border-top: none;
    padding-top: 0;
  }
}

/* ── Two-column auth: desktop card padding ───────────────────────────────── */

@media (min-width: 640px) {
  .mk-auth { padding: 3rem 2rem; }
  .mk-auth-card { padding: 2.5rem; }
}
