/* ===== OSC Mitgliederbereich ============================================== */

.osc-login-box {
  max-width: 420px;
  margin: 3rem auto;
  padding: 2.5rem 2rem;
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.osc-login-box--ok {
  background: #f0fdf4;
  border-color: #bbf7d0;
}

.osc-login-box__title {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 0.5rem;
  color: #111827;
}
.osc-login-box__hint {
  font-size: 0.85rem;
  color: #6b7280;
  margin: 0 0 1.5rem;
  line-height: 1.5;
}

.osc-login-msg {
  padding: 0.75rem 1rem;
  border-radius: 6px;
  font-size: 0.85rem;
  margin: 0 0 1.25rem;
}
.osc-login-msg--info {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  color: #1e40af;
}
.osc-login-msg--error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}

/* Form Styling — überschreibt wp_login_form Default */
.osc-login-box form p {
  margin: 0 0 1rem;
}
.osc-login-box label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0.4rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.osc-login-box input[type="text"],
.osc-login-box input[type="password"],
.osc-login-box input[type="email"] {
  width: 100%;
  padding: 0.7rem 0.9rem;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  font-size: 0.95rem;
  background: #fafafa;
  transition: border-color 150ms ease, background 150ms ease;
}
.osc-login-box input[type="text"]:focus,
.osc-login-box input[type="password"]:focus,
.osc-login-box input[type="email"]:focus {
  outline: none;
  border-color: var(--wp--preset--color--eiserne);
  background: white;
}
.osc-login-box input[type="submit"],
.osc-login-btn {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
}
.osc-login-box input[type="submit"],
.osc-login-btn--primary {
  background: var(--wp--preset--color--eiserne);
  color: white;
  border-color: var(--wp--preset--color--eiserne);
  width: 100%;
}
.osc-login-box input[type="submit"]:hover,
.osc-login-btn--primary:hover {
  background: #991B1B;
  border-color: #991B1B;
  color: white;
}
.osc-login-btn {
  background: white;
  color: #374151;
  border-color: #d1d5db;
}
.osc-login-btn:hover {
  background: #f9fafb;
  color: #111827;
}

.osc-login-box .login-remember {
  font-size: 0.8rem;
  color: #6b7280;
}
.osc-login-box .login-remember label {
  display: inline;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
}
.osc-login-box .login-remember input[type="checkbox"] {
  margin-right: 0.4rem;
}

.osc-login-box__lost {
  text-align: center;
  font-size: 0.8rem;
  margin: 1rem 0 0;
}
.osc-login-box__lost a {
  color: #6b7280;
  text-decoration: none;
}
.osc-login-box__lost a:hover {
  color: var(--wp--preset--color--eiserne);
  text-decoration: underline;
}

.osc-login-box__actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 1.5rem;
}

.osc-login-box__separator {
  margin: 1.75rem 0 1.25rem;
  border-top: 1px solid #e5e7eb;
}
.osc-login-box__request-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: #111827;
  margin: 0 0 0.5rem;
}
.osc-login-box__request {
  text-align: left;
}
.osc-login-btn--secondary {
  background: white;
  color: var(--wp--preset--color--eiserne);
  border-color: var(--wp--preset--color--eiserne);
  display: block;
  text-align: center;
  width: 100%;
}
.osc-login-btn--secondary:hover {
  background: #fef2f2;
  color: #991B1B;
  border-color: #991B1B;
}

/* Subnav für Mitgliederbereich — eigenständiger dunkler Balken, klar sichtbar
   auf weißem Seitengrund (Dept-Subnav liegt auf der Dept-Farbe und kann dezent
   sein; hier auf hellem Body brauchen wir vollen Kontrast). */
.osc-subnav--mitglieder {
  background: #1a1a1a;
  border-bottom: 1px solid rgba(255,255,255,.05);
  width: 100%;
  display: block;
  max-height: none;
  overflow: visible;
}
.osc-subnav--mitglieder .osc-subnav__inner {
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap;
  gap: 0.25rem;
  max-width: var(--max-full, 1400px); margin: 0 auto;
  padding: 0 1.25rem; min-height: 48px;
}
.osc-subnav--mitglieder a,
.osc-subnav--mitglieder .osc-subnav__link {
  position: relative;
  display: inline-block;
  padding: 12px 16px;
  font-size: 0.82rem; font-weight: 500;
  color: rgba(255,255,255,.85);
  text-decoration: none;
  background: transparent;
  transition: color 150ms ease;
}
.osc-subnav--mitglieder a::after {
  content: ''; position: absolute; left: 16px; right: 16px; bottom: 8px;
  height: 2px; background: transparent; border-radius: 2px;
  transition: background 150ms ease;
}
.osc-subnav--mitglieder a:hover { color: #fff; }
.osc-subnav--mitglieder a:hover::after { background: rgba(255,255,255,.5); }
.osc-subnav--mitglieder a.is-active { color: #fff; font-weight: 600; }
.osc-subnav--mitglieder a.is-active::after { background: #fff; }

/* Mobile: scrollbar horizontal, kein Wrap, voller Display über alle Auflösungen */
@media (max-width: 860px) {
  .osc-subnav--mitglieder { display: block !important; }
  .osc-subnav--mitglieder .osc-subnav__inner {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding: 0 var(--space-4, 1rem);
    -webkit-overflow-scrolling: touch;
  }
  .osc-subnav--mitglieder .osc-subnav__inner::-webkit-scrollbar { display: none; }
  .osc-subnav--mitglieder a { flex-shrink: 0; }
}

/* User-Menu im Header/Footer */
.osc-user-menu__login,
.osc-user-menu__name {
  text-decoration: none;
  color: inherit;
}
.osc-user-menu__logout {
  margin-left: 0.5rem;
  font-size: 0.8rem;
  opacity: 0.7;
}
.osc-user-menu__logout:hover {
  opacity: 1;
}
