:root {
  --etx-bg-1: #f3f7ff;
  --etx-bg-2: #ecf4ff;
  --etx-card: rgba(255, 255, 255, 0.94);
  --etx-text: #16233d;
  --etx-muted: #71819b;
  --etx-line: rgba(159, 178, 214, 0.28);
  --etx-primary-1: #7568ff;
  --etx-primary-2: #4f7cff;
  --etx-primary-3: #22c7f2;
  --etx-shadow: 0 30px 80px rgba(28, 50, 94, 0.16);
  --etx-radius-xl: 28px;
  --etx-radius-lg: 18px;
  --etx-radius-md: 14px;
}

body {
  background:
    radial-gradient(circle at 12% 18%, rgba(117,104,255,.14), transparent 22%),
    radial-gradient(circle at 82% 12%, rgba(34,199,242,.14), transparent 18%),
    linear-gradient(180deg, var(--etx-bg-1), var(--etx-bg-2)) !important;
}

.navbar {
  background: rgba(255,255,255,.78) !important;
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--etx-line) !important;
}

.navbar .navbar-brand,
.navbar .navbar-brand:hover {
  color: var(--etx-text) !important;
  font-weight: 700;
}

.etx-login-shell {
  max-width: 1280px;
  margin: 40px auto;
  border-radius: var(--etx-radius-xl);
  overflow: hidden;
  background: var(--etx-card);
  box-shadow: var(--etx-shadow);
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  min-height: 720px;
}

.etx-login-hero {
  padding: 36px 38px;
  background:
    radial-gradient(circle at 20% 20%, rgba(117,104,255,.18), transparent 24%),
    radial-gradient(circle at 80% 10%, rgba(34,199,242,.18), transparent 20%),
    linear-gradient(180deg, #edf5ff 0%, #f8fbff 100%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.etx-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  font-size: 24px;
  color: var(--etx-text);
}

.etx-brand-mark {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: linear-gradient(135deg, var(--etx-primary-1), var(--etx-primary-2), var(--etx-primary-3));
  box-shadow: 0 14px 28px rgba(79,124,255,.22);
  font-size: 24px;
  font-weight: 800;
}

.etx-hero-copy h1 {
  margin: 0 0 14px;
  font-size: 52px;
  line-height: 1.02;
  color: var(--etx-text);
}

.etx-hero-copy p {
  margin: 0;
  max-width: 560px;
  font-size: 18px;
  line-height: 1.7;
  color: var(--etx-muted);
}

.etx-visual {
  position: relative;
  min-height: 360px;
  margin-top: 36px;
}

.etx-card-float {
  position: absolute;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(210,220,238,.7);
  border-radius: 18px;
  box-shadow: 0 18px 40px rgba(24,49,94,.10);
  padding: 18px;
}

.etx-card-float.kpi {
  left: 20px;
  top: 8px;
  width: 220px;
}

.etx-card-float.kpi .label {
  color: var(--etx-muted);
  font-size: 14px;
}

.etx-card-float.kpi .value {
  margin-top: 8px;
  font-size: 30px;
  font-weight: 800;
  color: var(--etx-text);
}

.etx-card-float.chart {
  right: 20px;
  top: 48px;
  width: 360px;
}

.etx-chart-bars {
  height: 190px;
  margin-top: 16px;
  display: flex;
  align-items: flex-end;
  gap: 10px;
}

.etx-chart-bars span {
  flex: 1;
  border-radius: 14px 14px 6px 6px;
  background: linear-gradient(180deg, #8cc7ff, #4f7cff);
}

.etx-card-float.activity {
  left: 64px;
  bottom: 0;
  width: 280px;
}

.etx-list-line {
  height: 12px;
  margin-top: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, #eef4ff, #f8fbff);
  overflow: hidden;
  position: relative;
}

.etx-list-line::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 62%;
  border-radius: inherit;
  background: linear-gradient(90deg, #7568ff, #22c7f2);
}

.etx-login-panel {
  background: rgba(255,255,255,.96);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 50px 46px;
}

.etx-form-wrap {
  width: 100%;
  max-width: 470px;
}

.etx-form-wrap h2 {
  margin: 0 0 12px;
  font-size: 54px;
  line-height: 1;
  color: #111b30;
}

.etx-form-wrap .sub {
  margin: 0 0 28px;
  font-size: 18px;
  line-height: 1.6;
  color: var(--etx-muted);
}

.etx-login-btn {
  min-height: 58px !important;
  border-radius: 999px !important;
  border: none !important;
  background: linear-gradient(135deg, #7568ff, #4f7cff, #22c7f2) !important;
  box-shadow: 0 18px 32px rgba(79,124,255,.22) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  padding: 0 28px !important;
  text-decoration: none !important;
  color: #fff !important;
}

.login-footer {
  margin-top: 20px;
  color: var(--etx-muted);
  font-size: 14px;
}

.etx-powered {
  color: var(--etx-muted);
  font-size: 14px;
}

.etx-powered strong {
  color: #4f7cff;
}

@media (max-width: 1100px) {
  .etx-login-shell {
    grid-template-columns: 1fr;
  }

  .etx-login-panel {
    padding: 30px 20px;
  }

  .etx-hero-copy h1 {
    font-size: 38px;
  }
}
.etx-login-form .form-group {
  margin-bottom: 18px;
}
.etx-login-form .form-control {
  height: 70px !important;
  min-height: 70px !important;
  border-radius: 16px !important;
  font-size: 18px !important;
  padding: 0 20px !important;
}

.etx-login-actions {
  margin-top: 8px;
}

.etx-login-btn {
  width: 100%;
  min-height: 58px !important;
  border-radius: 999px !important;
  border: none !important;
  background: linear-gradient(135deg, #7568ff, #4f7cff, #22c7f2) !important;
  box-shadow: 0 18px 32px rgba(79,124,255,.22) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #fff !important;
}

.etx-login-btn:disabled {
  opacity: 0.75;
  cursor: not-allowed;
}

.etx-login-error {
  margin-top: 16px;
  padding: 12px 14px;
  border-radius: 14px;
  background: #fff1f2;
  border: 1px solid #fecdd3;
  color: #be123c;
  font-size: 14px;
  line-height: 1.5;
}
body[data-path="/erp_login"] footer,
body[data-path="/erp_login"] .web-footer {
  display: none !important;
}
/* =========================
   LOGIN MOBILE FIXES
   ========================= */
@media (max-width: 768px) {
  .etx-login-shell {
    display: block !important;
    width: calc(100vw - 20px) !important;
    max-width: calc(100vw - 20px) !important;
    margin: 10px auto !important;
    min-height: auto !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  .etx-login-hero {
    padding: 20px !important;
    min-height: auto !important;
  }

  .etx-brand {
    font-size: 18px !important;
  }

  .etx-brand-mark {
    width: 38px !important;
    height: 38px !important;
    font-size: 20px !important;
  }

  .etx-hero-copy h1 {
    font-size: 34px !important;
    line-height: 1.1 !important;
    margin-bottom: 10px !important;
  }

  .etx-hero-copy p {
    font-size: 16px !important;
    line-height: 1.6 !important;
  }

  .etx-visual {
    position: static !important;
    min-height: auto !important;
    margin-top: 20px !important;
    display: grid !important;
    gap: 14px !important;
  }

  .etx-card-float,
  .etx-card-float.kpi,
  .etx-card-float.chart,
  .etx-card-float.activity {
    position: static !important;
    width: 100% !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    margin: 0 !important;
  }

  .etx-chart-bars {
    height: 120px !important;
  }

  .etx-login-panel {
    padding: 22px 18px !important;
  }

  .etx-form-wrap {
    max-width: 100% !important;
  }

  .etx-form-wrap h2 {
    font-size: 32px !important;
    margin-bottom: 8px !important;
  }

  .etx-form-wrap .sub {
    font-size: 15px !important;
    margin-bottom: 18px !important;
  }

  .etx-login-form .form-control,
  .etx-login-form input[type="text"],
  .etx-login-form input[type="password"],
  .etx-login-form input[type="email"] {
    height: 60px !important;
    min-height: 60px !important;
    font-size: 16px !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .etx-login-btn {
    height: 58px !important;
    min-height: 58px !important;
    font-size: 18px !important;
  }

  .login-footer,
  .etx-powered {
    font-size: 13px !important;
  }
}
/* =========================
   LOGIN PAGE FINAL MOBILE FIX
   ========================= */

@media (max-width: 768px) {
  /* pull login form upward */
  .etx-login-shell {
    margin: 8px auto 20px auto !important;
  }

  .etx-login-hero {
    padding: 18px 18px 10px 18px !important;
  }

  /* add gap between logo row and heading */
  .etx-brand {
    margin-bottom: 18px !important;
  }

  .etx-hero-copy h1 {
    margin-top: 6px !important;
  }

  /* hide revenue / chart / activity blocks on mobile */
  .etx-visual,
  .etx-card-float,
  .etx-card-float.kpi,
  .etx-card-float.chart,
  .etx-card-float.activity,
  .etx-powered {
    display: none !important;
  }

  /* reduce hero bottom spacing after hiding cards */
  .etx-login-hero {
    min-height: auto !important;
  }

  /* bring login section up */
  .etx-login-panel {
    padding: 18px 18px 22px 18px !important;
    margin-top: 0 !important;
  }

  .etx-form-wrap {
    margin-top: 0 !important;
  }

  .etx-form-wrap h2 {
    margin-top: 0 !important;
  }

  /* improve field spacing */
  .etx-login-form .form-group {
    margin-bottom: 16px !important;
  }

  .etx-login-form .form-control,
  .etx-login-form input[type="text"],
  .etx-login-form input[type="password"],
  .etx-login-form input[type="email"] {
    min-height: 58px !important;
    height: 58px !important;
    line-height: 58px !important;
  }

  /* remove duplicate footer text at page bottom */
  footer,
  .web-footer,
  .page-footer,
  .footer-powered,
  .powered-by,
  .website-footer,
  .layout-footer,
  .copyright-container,
  .page-card-footer,
  .login-footer-extra {
    display: none !important;
  }

  /* remove any extra bottom gap */
  body,
  .page-content-wrapper,
  .page_content,
  .container.page_content {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
  }
}