/* Cyberismo Keycloak Login Theme
 * Brand: cyberismo.com
 * Font: Plus Jakarta Sans (Google Fonts)
 * Palette: Orange #FF530F, Amber #FFB022, Dark #2A2A2A, Warm Gray #F2EDE4
 */

/* ── Google Font import ──────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ── CSS Custom Properties ───────────────────────────────────── */
:root {
  --cyberismo-orange: #FF530F;
  --cyberismo-amber: #FFB022;
  --cyberismo-dark: #2A2A2A;
  --cyberismo-black: #000000;
  --cyberismo-warm-gray: #F2EDE4;
  --cyberismo-white: #FFFFFF;
}

/* ── Typography ──────────────────────────────────────────────── */
body,
input,
button,
select,
textarea,
.login-pf body,
#kc-header-wrapper,
#kc-page-title,
.kc-login-tooltip,
label {
  font-family: 'Plus Jakarta Sans', Helvetica, Arial, Lucida, sans-serif !important;
}

/* ── Page background ─────────────────────────────────────────── */
.login-pf body,
body.kc-login {
  background: var(--cyberismo-white) !important;
}

.login-pf-page {
  padding-top: 0 !important;
}

/* ── Header / Logo area ──────────────────────────────────────── */
#kc-header {
  background: var(--cyberismo-dark);
  padding: 2rem 0;
}

#kc-header-wrapper {
  color: var(--cyberismo-white);
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
  padding: 0 2rem;
}

/* Replace text header with logo image */
#kc-header-wrapper {
  font-size: 0;
  background: url('../img/cyberismo-logo-negative.png') center center no-repeat;
  background-size: contain;
  height: 40px;
  min-height: 40px;
}

/* ── Login card ──────────────────────────────────────────────── */
#kc-form-login,
.card-pf,
#kc-content-wrapper,
#kc-form-wrapper {
  font-family: 'Plus Jakarta Sans', Helvetica, Arial, Lucida, sans-serif;
}

.card-pf {
  background: var(--cyberismo-warm-gray) !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Login title */
#kc-page-title,
.kc-page-title {
  color: var(--cyberismo-dark);
  font-weight: 700;
  font-size: 1.5rem;
}

/* ── Form elements ───────────────────────────────────────────── */
.login-pf .form-control,
input[type="text"],
input[type="password"],
input[type="email"] {
  border: 1px solid #ccc;
  border-radius: 0 !important;
  font-family: 'Plus Jakarta Sans', Helvetica, Arial, Lucida, sans-serif;
  font-size: 0.95rem;
  padding: 0.6rem 0.75rem;
  color: var(--cyberismo-dark);
  background: var(--cyberismo-white);
}

.login-pf .form-control:focus,
input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus {
  border-color: var(--cyberismo-orange) !important;
  box-shadow: 0 0 0 2px rgba(255, 83, 15, 0.15) !important;
  outline: none;
}

label {
  color: var(--cyberismo-dark);
  font-weight: 500;
  font-size: 0.875rem;
}

/* ── Primary button (Sign In) ────────────────────────────────── */
#kc-login,
.btn-primary,
input[type="submit"].btn-primary {
  background-color: var(--cyberismo-black) !important;
  border: 2px solid var(--cyberismo-amber) !important;
  color: var(--cyberismo-amber) !important;
  border-radius: 0 !important;
  font-family: 'Plus Jakarta Sans', Helvetica, Arial, Lucida, sans-serif;
  font-weight: 600;
  font-size: 0.95rem;
  padding: 0.6rem 1.5rem;
  text-transform: none;
  letter-spacing: 0;
  transition: background-color 0.15s ease, color 0.15s ease;
}

#kc-login:hover,
.btn-primary:hover,
input[type="submit"].btn-primary:hover {
  background-color: var(--cyberismo-dark) !important;
  border-color: var(--cyberismo-amber) !important;
  color: var(--cyberismo-white) !important;
}

#kc-login:focus,
.btn-primary:focus {
  box-shadow: 0 0 0 2px rgba(255, 176, 34, 0.4) !important;
}

/* ── Secondary / cancel buttons ──────────────────────────────── */
.btn-default {
  background-color: transparent !important;
  border: 1px solid var(--cyberismo-dark) !important;
  color: var(--cyberismo-dark) !important;
  border-radius: 0 !important;
  font-family: 'Plus Jakarta Sans', Helvetica, Arial, Lucida, sans-serif;
  font-weight: 500;
}

.btn-default:hover {
  background-color: var(--cyberismo-warm-gray) !important;
}

/* ── Links ───────────────────────────────────────────────────── */
a,
.login-pf a,
#kc-registration a,
#kc-form-options a {
  color: var(--cyberismo-orange) !important;
  text-decoration: none;
}

a:hover,
.login-pf a:hover {
  color: var(--cyberismo-dark) !important;
  text-decoration: underline;
}

/* ── Alerts / messages ───────────────────────────────────────── */
.alert-error,
.alert-warning {
  border-radius: 0 !important;
  border-left: 4px solid var(--cyberismo-orange);
}

.alert-success {
  border-radius: 0 !important;
  border-left: 4px solid #4caf50;
}

/* ── "Remember me" checkbox ──────────────────────────────────── */
.checkbox label {
  font-size: 0.85rem;
  color: #666;
}

/* ── Footer ──────────────────────────────────────────────────── */
#kc-info-wrapper {
  font-size: 0.85rem;
}

/* ── Responsive adjustments ──────────────────────────────────── */
@media (max-width: 767px) {
  #kc-header-wrapper {
    height: 32px;
    background-size: auto 32px;
  }
}
