/* ==============================================
   member-pages.css  — Shared styles for all 
   newly-built member-facing PHP pages
   login.php | join.php | join-success.php 
   member-dashboard.php | member-profile.php
   ============================================== */

/* ------ CSS Variables (mirror theme) ------ */
:root {
  --theme-color: #002F2F;
  --theme-dark:  #001f1f;
  --theme-light: rgba(0, 47, 47, 0.1);
  --title-color: #272e39;
  --body-color:  #565656;
  --smoke-color: #f6f6f6;
  --white-color: #ffffff;
  --yellow-color:#fec624;
  --error-color: #dc3545;
  --success-color:#28a745;
  --warning-color:#e6a817;
  --border-color:#ececec;
  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   20px;
  --shadow-sm:   0 2px 8px rgba(0,0,0,.06);
  --shadow-md:   0 4px 24px rgba(116,9,246,.08);
  --shadow-lg:   0 10px 40px rgba(116,9,246,.15);
  --transition:  all .25s ease;
}

/* ------ Alerts ------ */
.mp-alert {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 18px;
  border-radius: var(--radius-sm);
  margin-bottom: 20px;
  font-size: 14px;
  line-height: 1.5;
  animation: alertFadeIn .3s ease;
}
.mp-alert i { margin-top: 2px; flex-shrink: 0; }
.mp-alert-danger  { background: rgba(220,53,69,.08); color: #b02a37; border: 1px solid rgba(220,53,69,.25); }
.mp-alert-success { background: rgba(40,167,69,.08); color: #1a7a34; border: 1px solid rgba(40,167,69,.25); }
.mp-alert-warning { background: rgba(230,168,23,.1); color: #8a6000; border: 1px solid rgba(230,168,23,.35); }
.mp-alert-info    { background: rgba(116,9,246,.07); color: #5a00cc; border: 1px solid rgba(116,9,246,.2); }

@keyframes alertFadeIn {
  from { opacity:0; transform:translateY(-8px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ------ Form Elements ------ */
.mp-form-group {
  display: flex;
  flex-direction: column;
  margin-bottom: 20px;
}
.mp-label {
  color: var(--title-color);
  font-weight: 600;
  font-size: 13px;
  margin-bottom: 7px;
  display: flex;
  align-items: center;
  gap: 5px;
}
.mp-label .req { color: var(--error-color); }

.mp-input,
.mp-select,
.mp-textarea {
  width: 100%;
  padding: 11px 15px;
  border: 2px solid var(--border-color);
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-family: 'Inria Sans', sans-serif;
  color: var(--title-color);
  background: #fff;
  transition: var(--transition);
  outline: none;
  line-height: 1.5;
}
.mp-input:focus,
.mp-select:focus,
.mp-textarea:focus {
  border-color: var(--theme-color);
  box-shadow: 0 0 0 3px var(--theme-light);
}
.mp-input.is-error,
.mp-select.is-error,
.mp-textarea.is-error {
  border-color: var(--error-color);
  box-shadow: 0 0 0 3px rgba(220,53,69,.1);
}
.mp-input.is-valid,
.mp-select.is-valid,
.mp-textarea.is-valid {
  border-color: var(--success-color);
}
.mp-textarea { resize: vertical; min-height: 110px; }
.mp-field-error {
  color: var(--error-color);
  font-size: 12px;
  margin-top: 5px;
  display: none;
  animation: alertFadeIn .2s ease;
}
.mp-field-error.show { display: block; }

/* Password toggle wrapper */
.mp-input-wrapper {
  position: relative;
}
.mp-input-wrapper .mp-input { padding-right: 44px; }
.mp-toggle-pw {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--body-color);
  font-size: 15px;
  padding: 0;
  transition: color .2s;
}
.mp-toggle-pw:hover { color: var(--theme-color); }

/* ------ Buttons ------ */
.mp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: var(--radius-sm);
  font-size: 15px;
  font-weight: 600;
  font-family: 'Inria Sans', sans-serif;
  cursor: pointer;
  border: 2px solid transparent;
  transition: var(--transition);
  text-decoration: none;
  white-space: nowrap;
}
.mp-btn-primary {
  background: var(--theme-color);
  color: #fff;
  border-color: var(--theme-color);
}
.mp-btn-primary:hover:not(:disabled) {
  background: var(--theme-dark);
  border-color: var(--theme-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(116,9,246,.3);
  color: #fff;
}
.mp-btn-outline {
  background: transparent;
  color: var(--theme-color);
  border-color: var(--theme-color);
}
.mp-btn-outline:hover {
  background: var(--theme-color);
  color: #fff;
  transform: translateY(-2px);
}
.mp-btn-full { width: 100%; }
.mp-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}
/* Loading spinner in button */
.mp-btn .spinner {
  width: 16px; height: 16px;
  border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .6s linear infinite;
  display: none;
}
.mp-btn.loading .spinner { display: inline-block; }
.mp-btn.loading .btn-text { opacity: .7; }

@keyframes spin { to { transform: rotate(360deg); } }

/* ------ Cards ------ */
.mp-card {
  background: #fff;
  border-radius: var(--radius-md);
  padding: 32px;
  box-shadow: var(--shadow-md);
}
.mp-card-title {
  color: var(--title-color);
  font-size: 17px;
  font-weight: 700;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--border-color);
  display: flex;
  align-items: center;
  gap: 10px;
}
.mp-card-title i { color: var(--theme-color); }

/* Section heading inside form */
.mp-section-heading {
  color: var(--theme-color);
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  margin: 28px 0 16px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--border-color);
  display: flex;
  align-items: center;
  gap: 8px;
}
.mp-section-heading:first-child { margin-top: 0; }

/* Two-column grid inside forms */
.mp-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.mp-grid-2.full { grid-template-columns: 1fr; }

/* ------ Stat Cards ------ */
.mp-stat {
  background: #fff;
  border-radius: var(--radius-md);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  text-align: center;
  transition: var(--transition);
}
.mp-stat:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.mp-stat-icon { font-size: 30px; color: var(--theme-color); margin-bottom: 10px; }
.mp-stat-val  { font-size: 22px; font-weight: 700; color: var(--title-color); line-height: 1.1; }
.mp-stat-label{ font-size: 12px; color: var(--body-color); margin-top: 4px; }

/* ------ Quick-Link Tiles ------ */
.mp-quick-link {
  background: linear-gradient(135deg, var(--theme-color) 0%, #0066cc 100%);
  color: #fff;
  padding: 22px 16px;
  border-radius: var(--radius-md);
  text-align: center;
  text-decoration: none;
  transition: var(--transition);
  display: block;
}
.mp-quick-link:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(116,9,246,.3);
  color: #fff;
}
.mp-quick-link i { font-size: 28px; display: block; margin-bottom: 10px; }
.mp-quick-link-label { font-size: 13px; font-weight: 600; }
.mp-quick-link.danger {
  background: linear-gradient(135deg, #dc3545 0%, #c82333 100%);
}

/* ------ Badge ------ */
.mp-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
}
.mp-badge-success { background: rgba(40,167,69,.12); color: #1a7a34; }
.mp-badge-warning { background: rgba(230,168,23,.15); color: #8a6000; }
.mp-badge-primary { background: var(--theme-light); color: var(--theme-color); }

/* ------ Info Display (readonly field) ------ */
.mp-info-display {
  padding: 11px 15px;
  background: var(--smoke-color);
  border-radius: var(--radius-sm);
  font-size: 14px;
  color: var(--body-color);
  border: 2px solid var(--border-color);
}

/* ------ Toast Notifications ------ */
.mp-toast-container {
  position: fixed;
  top: 90px;
  right: 20px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
}
.mp-toast {
  background: #fff;
  border-radius: var(--radius-sm);
  padding: 14px 18px;
  box-shadow: 0 8px 30px rgba(0,0,0,.12);
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  font-weight: 600;
  max-width: 340px;
  pointer-events: auto;
  animation: toastIn .3s ease;
  border-left: 4px solid var(--theme-color);
}
.mp-toast.success { border-left-color: var(--success-color); color: #1a7a34; }
.mp-toast.error   { border-left-color: var(--error-color);   color: #b02a37; }
.mp-toast.fade-out { animation: toastOut .3s ease forwards; }
@keyframes toastIn  { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }
@keyframes toastOut { from { opacity:1; transform:translateX(0); } to { opacity:0; transform:translateX(20px); } }

/* ------ Skeleton Loader ------ */
.mp-skeleton {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 4px;
}
@keyframes shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* ------ Empty State ------ */
.mp-empty {
  text-align: center;
  padding: 60px 20px;
}
.mp-empty i { font-size: 48px; color: #d0d0d0; margin-bottom: 16px; display: block; }
.mp-empty h3 { color: var(--title-color); margin-bottom: 8px; }
.mp-empty p  { color: var(--body-color); font-size: 14px; }

/* ------ Fade animations ------ */
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:translateY(0); }
}
.fade-in-up { animation: fadeInUp .4s ease both; }
.delay-1 { animation-delay: .1s; }
.delay-2 { animation-delay: .2s; }
.delay-3 { animation-delay: .3s; }

/* ------ Responsive helpers ------ */
@media (max-width: 768px) {
  .mp-grid-2 { grid-template-columns: 1fr; }
  .mp-card { padding: 22px; }
}
