/**
 * HealFast — Admin theme (matches Bahmni branding.json: green + navy)
 */
@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;1,600&display=swap");

:root {
  --hf-green-950: #006633;
  --hf-green-900: #008a43;
  --hf-green-800: #00a651;
  --hf-green-500: #00c65f;
  --hf-navy-900: #1a252f;
  --hf-navy-800: #2c3e50;
  --hf-accent: #3498db;
  --hf-gold-500: #e8a838;
  --hf-slate-900: #0f172a;
  --hf-slate-600: #475569;
  --hf-slate-100: #f1f5f9;
  --hf-mint-50: #f0fdf4;
  --hf-white: #ffffff;
}

html[data-theme="light"],
:root {
  --primary: var(--hf-green-800) !important;
  --secondary: var(--hf-green-500) !important;
  --accent: var(--hf-gold-500) !important;
  --body-fg: var(--hf-slate-900) !important;
  --body-bg: #f6faf7 !important;
  --hairline-color: #d1ebe0 !important;
  --darkened-bg: #e8f5ee !important;
  --selected-bg: #d1f0e0 !important;
  --link-fg: var(--hf-green-900) !important;
  --link-hover-color: var(--hf-navy-800) !important;
  --header-color: #ffffff !important;
  --breadcrumbs-fg: #e8f5ed !important;
  --breadcrumbs-link-fg: #ffffff !important;
}

body {
  font-family: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif !important;
}

#header {
  background: linear-gradient(
    105deg,
    var(--hf-navy-800) 0%,
    var(--hf-navy-900) 45%,
    var(--hf-green-900) 100%
  ) !important;
  border-bottom: 3px solid var(--hf-green-800) !important;
  box-shadow: 0 4px 24px rgba(0, 102, 65, 0.18);
}

#header a:link,
#header a:visited,
#user-tools a:link,
#user-tools a:visited {
  color: #ecfeff !important;
}

#user-tools a:focus,
#user-tools a:hover {
  color: var(--hf-gold-500) !important;
  border-bottom-color: var(--hf-gold-500) !important;
}

#branding h1,
#site-name {
  font-weight: 700 !important;
  letter-spacing: -0.02em;
}

#site-name a:link,
#site-name a:visited {
  color: #fff !important;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
}

.healfast-logo-header {
  height: 40px;
  width: 40px;
  object-fit: contain;
  vertical-align: middle;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.12));
}

.healfast-login-product {
  color: var(--hf-green-800) !important;
  display: block;
  margin-bottom: 0.35rem;
}

.healfast-login-logo {
  display: block;
  max-width: 220px;
  height: auto;
  margin: 0 auto 1rem;
}

.healfast-login-tagline {
  text-align: center;
  font-size: 0.9rem;
  color: var(--hf-slate-600);
  margin-bottom: 1.25rem;
  font-weight: 500;
}

.module h2,
.module caption,
.inline-group h2 {
  background: linear-gradient(90deg, var(--hf-green-900), var(--hf-green-800)) !important;
  color: #fff !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em;
}

div.breadcrumbs {
  background: var(--hf-mint-50) !important;
  color: var(--hf-slate-900) !important;
  border-bottom: 1px solid #cff1ed !important;
}

div.breadcrumbs a {
  color: var(--hf-green-900) !important;
}

.button,
input[type="submit"],
input[type="button"],
.submit-row input,
a.button {
  background: var(--hf-green-800) !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
  border: none !important;
}

.button:active,
.button:focus,
.button:hover,
input[type="submit"]:hover {
  background: var(--hf-green-900) !important;
}

.button.default,
input[type="submit"].default,
.submit-row input.default {
  background: linear-gradient(135deg, var(--hf-green-800), var(--hf-green-900)) !important;
}

a:link,
a:visited {
  color: var(--hf-green-900);
}

#content {
  padding-top: 1.25rem;
}

#content-main {
  background: var(--hf-white);
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(10, 107, 110, 0.06);
}

.login #content-main,
.login #container {
  border-radius: 16px;
}

.login #header {
  justify-content: center;
}

.login #site-name .healfast-logo-header {
  height: 44px;
}

.login #content {
  padding-top: 2rem;
}

.login .healfast-login-banner {
  text-align: center;
  max-width: 22rem;
  margin: 0 auto 1.5rem;
  font-size: 0.9rem;
  color: var(--hf-slate-600);
  font-weight: 500;
  line-height: 1.45;
}

.login #branding h1 {
  margin: 0;
}

.object-tools a {
  background: var(--hf-green-800) !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
}

.object-tools a:hover {
  background: var(--hf-green-900) !important;
}

/* Jet / dark mode friendly */
html[data-theme="dark"] {
  --body-bg: #0c1210 !important;
  --body-fg: #e8f5f4 !important;
}

/* ----- Responsive login: centered card, full-width fields ----- */
body.login {
  min-height: 100vh !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(1rem, 4vw, 2rem) !important;
  box-sizing: border-box !important;
  background: linear-gradient(
    165deg,
    #e8f5ee 0%,
    #f6faf7 40%,
    #f0fdf6 100%
  ) !important;
}

body.login #container {
  width: 100% !important;
  max-width: 26rem !important;
  margin: 0 auto !important;
  float: none !important;
  box-shadow: 0 12px 48px rgba(15, 23, 42, 0.1) !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  border: 1px solid rgba(0, 166, 81, 0.12) !important;
}

body.login #header {
  width: 100% !important;
  padding: 1rem 1.25rem !important;
  box-sizing: border-box !important;
}

body.login #content {
  width: 100% !important;
  padding: 0 0 1.5rem !important;
  max-width: none !important;
  flex: 0 0 auto !important;
}

body.login #content-main {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 1.5rem 1.25rem !important;
  box-sizing: border-box !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body.login .healfast-login-card {
  width: 100%;
  box-sizing: border-box;
}

body.login .healfast-login-banner {
  max-width: none !important;
  width: 100% !important;
  padding: 0 1.5rem 1rem !important;
  margin: 0 auto 0.5rem !important;
  box-sizing: border-box !important;
}

body.login .healfast-login-tagline-inline {
  display: block;
  margin-top: 0.5rem;
  font-size: 0.88rem;
  line-height: 1.4;
  color: var(--hf-slate-600);
}

body.login .form-row {
  margin-bottom: 1rem !important;
}

body.login .form-row label {
  display: block !important;
  margin-bottom: 0.35rem !important;
  font-weight: 600 !important;
  font-size: 0.88rem !important;
}

body.login input[type="text"],
body.login input[type="password"] {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  padding: 0.65rem 0.85rem !important;
  border-radius: 10px !important;
  border: 1px solid #c5e6d8 !important;
  font-size: 1rem !important;
}

body.login .submit-row {
  margin-top: 1.25rem !important;
  padding: 0 !important;
  text-align: center !important;
}

body.login .submit-row input {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0.75rem 1rem !important;
  font-size: 1rem !important;
}

body.login .healfast-login-footer-link {
  margin: 1rem 1.5rem 0 !important;
  text-align: center !important;
  font-size: 0.88rem !important;
}

body.login .errornote {
  margin: 0 1.5rem 0.75rem !important;
  box-sizing: border-box !important;
}

@media (max-width: 380px) {
  body.login #container {
    max-width: 100% !important;
  }
}
