/**
 * Selfrag Login — full-screen branded login layout
 * (matches SGT-pattern across our Drupal sites).
 */

body.sf-page-login {
  background: var(--sf-red);
  margin: 0;
  min-height: 100vh;
}

/* Hide the regular header/footer on login pages (they shouldn't even render
   via page--user--login.html.twig, but kill them defensively in case). */
body.sf-page-login .sf-header,
body.sf-page-login .sf-footer,
body.sf-page-login .sf-main { display: none !important; }

.sf-login {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: var(--sf-red);
}

.sf-login__card {
  background: #fff;
  width: 100%;
  max-width: 480px;
  padding: 48px 56px 40px;
  border-radius: 6px;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.18);
  text-align: center;
}

.sf-login__logo {
  display: inline-block;
  margin: 0 auto 36px;
  text-decoration: none;
}

.sf-login__logo img {
  height: 44px;
  width: auto;
  display: block;
}

/* Form fields — uppercase labels, underline-only inputs */
.sf-login__card form { text-align: left; }

.sf-login__card .form-item,
.sf-login__card .js-form-item {
  margin-bottom: 24px;
}

.sf-login__card label {
  display: block !important;
  font-family: var(--sf-font-body);
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #555 !important;
  margin-bottom: 8px !important;
}

.sf-login__card label .form-required {
  color: var(--sf-red);
}

.sf-login__card input[type="text"],
.sf-login__card input[type="email"],
.sf-login__card input[type="password"] {
  width: 100% !important;
  display: block !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid #222 !important;
  border-radius: 0 !important;
  padding: 8px 0 !important;
  font-family: var(--sf-font-body);
  font-size: 16px !important;
  color: var(--sf-text) !important;
  transition: border-color 0.2s;
}

.sf-login__card input:focus {
  outline: none !important;
  border-bottom-color: var(--sf-red) !important;
}

/* Actions */
.sf-login__card .form-actions {
  margin-top: 32px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.sf-login__btn,
.sf-login__card input[type="submit"] {
  background: #111 !important;
  color: #fff !important;
  border: 0 !important;
  padding: 12px 36px !important;
  border-radius: 2px !important;
  font-family: var(--sf-font-body);
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.2s;
}

.sf-login__btn:hover,
.sf-login__card input[type="submit"]:hover {
  background: var(--sf-red) !important;
}

.sf-login__forgot {
  font-size: 13px;
  color: #555;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 0.2s, border-color 0.2s;
}
.sf-login__forgot:hover {
  color: var(--sf-red);
  border-color: var(--sf-red);
}

/* Drupal status / error messages — subtle inline above form */
.sf-login__card .messages {
  background: #fff5f5;
  border-left: 3px solid var(--sf-red);
  padding: 12px 16px;
  font-size: 14px;
  margin-bottom: 24px;
  text-align: left;
  color: #5a1a1a;
  border-radius: 2px;
}

/* Footer + monogram */
.sf-login__footer {
  margin-top: 32px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.85);
  text-align: center;
}
.sf-login__footer a {
  color: #fff;
  text-decoration: underline;
}

.sf-login__monogram {
  position: fixed;
  bottom: 32px;
  right: 40px;
  font-family: var(--sf-font-heading);
  font-size: 64px;
  font-weight: 300;
  line-height: 1;
  color: rgba(255, 255, 255, 0.95);
  text-decoration: none;
  letter-spacing: -0.04em;
  user-select: none;
}
.sf-login__monogram span { color: #fff; }

@media (max-width: 520px) {
  .sf-login__card { padding: 36px 28px 32px; }
  .sf-login__monogram { font-size: 48px; right: 24px; bottom: 20px; }
}
