/* ============================================================
   FlipAll5 – Members Area CSS
   Dark navy + gold theme for members area
   Blue gradient branding for auth pages
   ============================================================ */

/* ── CSS Variables ─────────────────────────────────────────── */

:root {
  --members-dark:       #f0f6fa;
  --members-mid:        #ffffff;
  --members-border:     #c5dce8;
  --members-gold:       #d4900a;
  --members-gold-light: #e8a800;
  --members-text:       #1a2e3a;
  --members-muted:      #5a7a8a;
  --brand-blue:         #3498db;
  --brand-dark-blue:    #2c5f7c;
  --brand-orange:       #ff6b35;
}

/* ============================================================
   AUTH PAGES – Split Layout (Login / Register)
   ============================================================ */

.auth-page {
  min-height: calc(100vh - 120px);
  display: flex;
  align-items: stretch;
}

.auth-split {
  display: flex;
  width: 100%;
  min-height: 600px;
}

/* ── Left: Brand Panel ──────────────────────────────────────── */
.auth-brand-panel {
  flex: 1;
  background: linear-gradient(145deg, #2c5f7c 0%, #1a3a52 50%, #1a2e3a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 2.5rem;
  position: relative;
  overflow: hidden;
}

/* Decorative background shapes */
.auth-brand-panel::before {
  content: '';
  position: absolute;
  top: -80px;
  right: -80px;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: rgba(52, 152, 219, 0.15);
}

.auth-brand-panel::after {
  content: '';
  position: absolute;
  bottom: -60px;
  left: -60px;
  width: 250px;
  height: 250px;
  border-radius: 50%;
  background: rgba(240, 165, 0, 0.1);
}

.auth-brand-inner {
  position: relative;
  z-index: 1;
  max-width: 360px;
}

.auth-logo-lockup {
  font-size: 3rem;
  font-weight: 900;
  letter-spacing: -1.5px;
  margin-bottom: 1rem;
  line-height: 1;
}

.logo-flip { color: #ffffff; }
.logo-all  { color: #ffffff; }
.logo-five { color: var(--members-gold); }

.auth-brand-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: rgba(240, 165, 0, 0.2);
  border: 1px solid rgba(240, 165, 0, 0.4);
  color: var(--members-gold);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.35rem 0.8rem;
  border-radius: 20px;
  margin-bottom: 1.5rem;
}

.auth-brand-headline {
  font-size: 2rem;
  font-weight: 800;
  color: #ffffff;
  line-height: 1.2;
  margin-bottom: 0.75rem;
}

.auth-brand-sub {
  color: #8aabbd;
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 2rem;
}

.auth-brand-features {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.auth-feature {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: #c5dce8;
  font-size: 0.9rem;
}

.auth-feature-icon {
  font-size: 1.1rem;
  width: 28px;
  text-align: center;
}

/* ── Right: Form Panel ──────────────────────────────────────── */
.auth-form-panel {
  flex: 1;
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 2.5rem;
}

.auth-form-inner {
  width: 100%;
  max-width: 400px;
}

.auth-form-title {
  font-size: 1.75rem;
  font-weight: 800;
  color: #2c5f7c;
  margin-bottom: 0.3rem;
  font-family: Georgia, serif;
}

.auth-form-subtitle {
  color: #2c5f7c;
  font-size: 0.9rem;
  margin-bottom: 1.75rem;
  opacity: 0.8;
}

/* ── Alerts ─────────────────────────────────────────────────── */
.alert {
  padding: 0.75rem 1rem;
  border-radius: 8px;
  margin-bottom: 1rem;
  font-size: 0.875rem;
}
.alert-success { background: #edfdf4; border-left: 4px solid #2ecc71; color: #1a6b3a; }
.alert-error   { background: #fdf0ee; border-left: 4px solid #e74c3c; color: #8b2020; }
.alert-warning { background: #fdf8ee; border-left: 4px solid var(--members-gold); color: #7a5a0a; }
.alert-info    { background: #eef6fd; border-left: 4px solid var(--brand-blue); color: #1a4a7a; }

/* ── Social Buttons ─────────────────────────────────────────── */
.social-buttons {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-bottom: 0.5rem;
}

/* Google - full width prominent button */
.social-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 0.75rem 1.25rem;
  border-radius: 10px;
  border: 2px solid #e0eaf0;
  background: white;
  color: #1a2e3a;
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.18s ease;
  cursor: pointer;
}

.social-btn:hover {
  border-color: var(--brand-blue);
  background: #f5f9fd;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(52, 152, 219, 0.15);
}

/* Row of secondary social buttons (Facebook + X) */
.social-row {
  display: flex;
  gap: 0.65rem;
}

.social-btn--secondary {
  flex: 1;
  padding: 0.7rem 1rem;
  font-size: 0.875rem;
}

.social-facebook {
  border-color: #dce8f8;
  background: #f8fbff;
}
.social-facebook:hover {
  border-color: #1877F2;
  background: #f0f6ff;
  box-shadow: 0 4px 12px rgba(24, 119, 242, 0.15);
}

.social-twitter {
  border-color: #e8e8e8;
  background: #fafafa;
}
.social-twitter:hover {
  border-color: #000;
  background: #f5f5f5;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* ── Divider ────────────────────────────────────────────────── */
.auth-divider {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 1.25rem 0;
  color: #aac4d4;
  font-size: 0.8rem;
}
.auth-divider::before,
.auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #dce8f0;
}

/* ── Form Fields ────────────────────────────────────────────── */
.auth-form .form-group {
  margin-bottom: 1rem;
}

.auth-form label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--members-dark);
  margin-bottom: 0.35rem;
}

.auth-form .optional {
  font-weight: 400;
  color: #8aabbd;
}

.auth-form input[type="email"],
.auth-form input[type="password"],
.auth-form input[type="text"] {
  width: 100%;
  padding: 0.7rem 0.9rem;
  border: 2px solid #dce8f0;
  border-radius: 8px;
  font-size: 0.9rem;
  color: #1a2e3a;
  background: #f9fbfc;
  transition: border-color 0.2s, box-shadow 0.2s;
  box-sizing: border-box;
}

.auth-form input:focus {
  outline: none;
  border-color: var(--brand-blue);
  background: white;
  box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.12);
}

.auth-form input:disabled {
  background: #eef4f8;
  color: #8aabbd;
  cursor: not-allowed;
}

.form-hint {
  display: block;
  font-size: 0.78rem;
  color: #8aabbd;
  margin-top: 0.3rem;
}

/* ── Primary Button ─────────────────────────────────────────── */
.btn-members-primary {
  width: 100%;
  padding: 0.8rem 1.5rem;
  background: linear-gradient(135deg, var(--brand-dark-blue) 0%, var(--brand-blue) 100%);
  color: white;
  border: none;
  border-radius: 10px;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  margin-top: 0.5rem;
  transition: opacity 0.2s, transform 0.15s, box-shadow 0.2s;
  letter-spacing: 0.02em;
  box-shadow: 0 4px 14px rgba(52, 152, 219, 0.3);
}
.btn-members-primary:hover {
  opacity: 0.93;
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(52, 152, 219, 0.4);
}

/* ── Footer Links ───────────────────────────────────────────── */
.auth-footer-links {
  text-align: center;
  margin-top: 1.5rem;
  font-size: 0.875rem;
  color: #6b8fa3;
}
.auth-footer-links a {
  color: var(--brand-blue);
  font-weight: 600;
  text-decoration: none;
}
.auth-footer-links a:hover { text-decoration: underline; }

.terms-note {
  font-size: 0.78rem;
  color: #8aabbd;
  text-align: center;
  margin-top: 0.75rem;
  line-height: 1.5;
}
.terms-note a { color: var(--brand-blue); text-decoration: none; }
.terms-note a:hover { text-decoration: underline; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 820px) {
  .auth-split { flex-direction: column; }

  .auth-brand-panel {
    padding: 2rem 1.5rem;
    min-height: auto;
  }

  .auth-brand-headline { font-size: 1.5rem; }
  .auth-brand-features { display: none; }

  .auth-form-panel { padding: 2rem 1.5rem; }
  .auth-form-inner { max-width: 100%; }
}

/* ============================================================
   MEMBERS AREA – Dark navy/gold theme
   ============================================================ */

.members-body {
  background-color: #e8f2f8;
  color: var(--members-text);
}

/* ── Header / Nav ───────────────────────────────────────────── */
.members-header {
  background-color: #2c5f7c;
  border-bottom: 2px solid var(--members-gold);
  box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}

.members-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.75rem 1.5rem;
  max-width: 1100px;
  margin: 0 auto;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.nav-brand { display: flex; align-items: center; gap: 0.75rem; }

.brand-logo {
  font-size: 1.5rem;
  font-weight: 900;
  text-decoration: none;
  letter-spacing: -0.5px;
}
.logo-flip { color: var(--members-text); }
.logo-all  { color: var(--members-gold); }
.logo-five { color: var(--members-gold-light); }

.members-area-badge {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  background: var(--members-gold);
  color: var(--members-dark);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.25rem 0.6rem;
  border-radius: 20px;
}

.nav-links { display: flex; gap: 1.5rem; }

.nav-link { color: #c5dce8; text-decoration: none; font-size: 0.9rem; transition: color 0.2s; }
.nav-link:hover, .nav-link.active { color: #ffffff; }

.nav-user { display: flex; align-items: center; gap: 1rem; }

.user-pill {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  background: rgba(240,165,0,0.15);
  border: 1px solid rgba(240,165,0,0.3);
  color: var(--members-gold);
  padding: 0.3rem 0.75rem;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 600;
}

.nav-logout { font-size: 0.85rem; }

/* ── Indicator Bar ──────────────────────────────────────────── */
.members-indicator-bar {
  background: linear-gradient(90deg, var(--members-gold) 0%, #e09400 100%);
  color: var(--members-dark);
  text-align: center;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  padding: 0.4rem 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}

/* ── Flash (members area) ───────────────────────────────────── */
.flash-container { max-width: 1100px; margin: 1rem auto 0; padding: 0 1.5rem; }

/* ── Main / Container ───────────────────────────────────────── */
.members-main { min-height: calc(100vh - 200px); padding: 2rem 0; }

.members-container { max-width: 1100px; margin: 0 auto; padding: 0 1.5rem; }
.members-container--narrow { max-width: 680px; }

/* ── Welcome Banner ─────────────────────────────────────────── */
.members-welcome {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, var(--members-mid) 0%, #1e3d50 100%);
  border: 1px solid var(--members-border);
  border-left: 5px solid var(--members-gold);
  border-radius: 12px;
  padding: 2rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
  gap: 1rem;
}

.members-welcome h1 { font-size: 1.8rem; font-weight: 800; color: var(--members-text); margin: 0 0 0.5rem; }
.welcome-star { color: var(--members-gold); }
.members-welcome p { color: var(--members-muted); margin: 0; }

.welcome-badge-large {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  color: var(--members-gold);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.8;
}

/* ── Members Grid ───────────────────────────────────────────── */
.members-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1.25rem;
  margin-bottom: 2.5rem;
}

.members-card {
  background: var(--members-mid);
  border: 1px solid var(--members-border);
  border-radius: 12px;
  padding: 1.5rem;
  position: relative;
  transition: border-color 0.2s, transform 0.2s;
}
.members-card:hover { border-color: var(--members-gold); transform: translateY(-2px); }

.card-icon { font-size: 2rem; margin-bottom: 0.75rem; }
.members-card h3 { font-size: 1rem; font-weight: 700; color: var(--members-text); margin: 0 0 0.5rem; }
.members-card p { font-size: 0.875rem; color: var(--members-muted); line-height: 1.5; margin: 0; }

.coming-soon-tag {
  display: inline-block;
  margin-top: 1rem;
  background: rgba(240,165,0,0.15);
  border: 1px solid rgba(240,165,0,0.3);
  color: var(--members-gold);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 0.2rem 0.6rem;
  border-radius: 12px;
}

/* ── Quick Links ────────────────────────────────────────────── */
.members-quick-links { margin-bottom: 2rem; }
.members-quick-links h2 { font-size: 1.1rem; font-weight: 700; color: var(--members-muted); margin-bottom: 1rem; text-transform: uppercase; letter-spacing: 0.05em; }

.quick-links-row { display: flex; gap: 1rem; flex-wrap: wrap; }

.quick-link-card {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: var(--members-mid);
  border: 1px solid var(--members-border);
  border-radius: 10px;
  padding: 1rem 1.25rem;
  text-decoration: none;
  color: var(--members-text);
  font-size: 0.9rem;
  transition: border-color 0.2s, background 0.2s;
  flex: 1;
  min-width: 180px;
}
.quick-link-card:hover { border-color: var(--members-gold); background: rgba(240,165,0,0.08); color: var(--members-gold); }
.link-arrow { margin-left: auto; color: var(--members-gold); }

/* ── Footer ─────────────────────────────────────────────────── */
.members-footer { background: var(--members-mid); border-top: 1px solid var(--members-border); padding: 1.5rem; text-align: center; }
.footer-inner a { color: var(--members-muted); text-decoration: none; font-size: 0.85rem; }
.footer-inner a:hover { color: var(--members-gold); }
.footer-copy { color: var(--members-border); font-size: 0.8rem; margin-top: 0.5rem; }

/* ── Page Header ────────────────────────────────────────────── */
.page-header { margin-bottom: 2rem; }
.page-header h1 { font-size: 1.75rem; font-weight: 800; color: var(--members-text); margin: 0 0 0.4rem; }
.page-header p { color: var(--members-muted); margin: 0; }

/* ── Profile / Danger zone ──────────────────────────────────── */
.danger-zone { margin-top: 1.5rem; }
.danger-zone h3 { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--members-muted); margin-bottom: 0.5rem; }
.danger-zone p { color: var(--members-text); margin-bottom: 1rem; }

.btn-members-secondary {
  display: inline-block;
  padding: 0.6rem 1.25rem;
  background: transparent;
  border: 1.5px solid var(--members-border);
  color: var(--members-muted);
  border-radius: 8px;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s;
}
.btn-members-secondary:hover { border-color: #e74c3c; color: #e74c3c; }

/* ── Public nav: Members pill ───────────────────────────────── */
.nav-members-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  background: var(--members-dark);
  color: var(--members-gold);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.3rem 0.7rem;
  border-radius: 20px;
  text-decoration: none;
  transition: background 0.2s;
}
.nav-members-pill:hover { background: var(--members-mid); }

/* ── Members form (profile) ─────────────────────────────────── */
.form-group--readonly input { background: #1e3a4a; }
