/**
 * PlayGuitar v3 — Custom Login (wp-login.php)
 * Paired with the member dashboard. Ported from the login card in
 * design/od-dashboard/screens/desktop.html (2026-05-29).
 *
 * Standalone context (tokens.css is NOT loaded on wp-login), so the v3
 * palette is declared here, then referenced. Calm, sentence-case, age-aware.
 */

:root {
  --brand: #EC7C2A; --brand-hover: #D26B1F;
  --accent: #1F7A47; --accent-hover: #185E37;
  --paper: #FDFCFA; --paper-tint: #F4F2EC;
  --ink-heading: #1A1A1A; --ink-body: #2D2D2D; --ink-muted: #5C5C5C; --ink-light: #8A8A8A;
  --hairline: #E4E0D8;
  --font-heading: 'Literata', Georgia, 'Times New Roman', serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --radius-md: 8px; --radius-lg: 12px;
  --shadow-md: 0 4px 16px rgba(27,25,22,0.08);
}

body.login {
  background: var(--paper-tint);
  font-family: var(--font-body);
  color: var(--ink-body);
}

#login {
  width: 460px;
  max-width: calc(100vw - 32px);
  padding: 8% 0 0;
}

/* Logo */
.login h1 a {
  background-image: url('../images/logo-light.webp');
  background-size: contain;
  background-position: center;
  width: 220px;
  height: 56px;
  margin: 0 auto 20px;
}

/* The card */
#loginform,
#lostpasswordform,
#registerform {
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: 36px 36px 32px;
  margin-top: 0;
}

/* v3 greeting (injected by inc/login.php) */
.pg-login-greeting {
  width: 460px;
  max-width: calc(100vw - 32px);
  margin: 0 auto;
  padding: 36px 36px 18px;
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-bottom: 0;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  box-shadow: none;
}
.pg-login-greeting + #loginform {
  border-top: 0;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  margin-top: 0;
  padding-top: 14px;
}
.pg-login-kicker {
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--ink-muted); font-weight: 600; margin: 0 0 8px;
}
.pg-login-title {
  font-family: var(--font-heading); font-size: 30px; font-weight: 600;
  color: var(--ink-heading); letter-spacing: -0.02em; line-height: 1.2; margin: 0 0 12px;
}
.pg-login-intro {
  font-size: 16px; color: var(--ink-body); line-height: 1.5; margin: 0 0 4px;
}

/* Fields */
.login form label { color: var(--ink-heading); font-size: 14px; font-weight: 500; }
.login form .input,
.login input[type="text"],
.login input[type="password"],
.login input[type="email"] {
  font-size: 16px; color: var(--ink-body);
  padding: 11px 14px;
  background: #fff;
  border: 1px solid var(--ink-light);
  border-radius: var(--radius-md);
  box-shadow: inset 0 1px 2px rgba(27,25,22,0.05);
}
.login form .input:focus,
.login input[type="text"]:focus,
.login input[type="password"]:focus,
.login input[type="email"]:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(31,122,71,0.22);
  outline: none;
}

/* Submit — green */
.login .button-primary,
.wp-core-ui #login .button-primary {
  background: var(--accent) !important;
  border: 0 !important;
  border-radius: var(--radius-md) !important;
  box-shadow: none !important;
  text-shadow: none !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  font-size: 16px !important;
  padding: 11px 20px !important;
  height: auto !important;
  width: 100%;
  margin-top: 6px;
  transition: background 150ms ease;
}
.login .button-primary:hover { background: var(--accent-hover) !important; }

/* Remember-me */
.login .forgetmenot label { font-size: 14px; color: var(--ink-muted); }

/* Links below the card */
#login #nav,
#login #backtoblog {
  text-align: center;
  padding: 0 24px;
  margin-top: 16px;
}
#login #nav a,
#login #backtoblog a {
  color: var(--ink-muted);
  text-decoration: underline;
  text-decoration-color: var(--hairline);
  text-underline-offset: 3px;
  font-size: 14px;
}
#login #nav a:hover,
#login #backtoblog a:hover { color: var(--ink-heading); }

/* Messages */
.login .message,
.login #login_error {
  border-left-color: var(--accent);
  border-radius: var(--radius-md);
  background: var(--paper);
}
