:root {
  --login-primary: #1c8f67;
  --login-primary-dark: #0f6a4c;
  --login-primary-deep: #0b5238;
  --login-accent: #14b8a6;
  --login-surface: #f6fbf9;
  --login-border: rgba(15, 23, 42, .10);
  --login-muted: #64746e;
  --login-primary-rgb: 28, 143, 103;
  --login-shadow-accent: rgba(28, 143, 103, .27);
  --login-shadow-accent-hover: rgba(28, 143, 103, .34);
  --login-shadow-sm: 0 10px 30px rgba(15, 23, 42, .08);
  --login-shadow-md: 0 22px 58px rgba(15, 23, 42, .14);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body { min-height: 100%; }

body {
  font-family: 'Poppins', 'Segoe UI', sans-serif;
  color: #10231d;
  background:
    radial-gradient(circle at 0% 0%, rgba(20, 184, 166, .18), transparent 32%),
    radial-gradient(circle at 100% 100%, rgba(28, 143, 103, .13), transparent 30%),
    var(--login-surface);
}

.login-page {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(380px, .85fr);
  gap: clamp(1.2rem, 3vw, 2.2rem);
  padding: clamp(1rem, 4vw, 4rem);
  align-items: center;
}

.login-hero {
  color: #fff;
  min-height: 680px;
  border-radius: 36px;
  padding: clamp(2rem, 5vw, 5rem);
  background:
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.22), transparent 30%),
    linear-gradient(135deg, var(--login-primary-deep), var(--login-primary), var(--login-accent));
  box-shadow: var(--login-shadow-md);
  display: flex;
  align-items: flex-end;
  position: relative;
  overflow: hidden;
}

.login-hero::before {
  content: '';
  position: absolute;
  inset: 12%;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 48px;
  transform: rotate(-7deg);
}

.login-hero-content { position: relative; z-index: 1; }

.hero-badge,
.eyebrow {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: .45rem .75rem;
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.hero-badge { background: rgba(255,255,255,.18); color: #fff; }
.eyebrow { background: rgba(var(--login-primary-rgb), .12); color: var(--login-primary-dark); }

.login-hero h1 {
  font-size: clamp(2.7rem, 6vw, 5.8rem);
  line-height: .92;
  margin: 1rem 0;
  max-width: 850px;
  letter-spacing: -0.06em;
}

.login-hero p {
  max-width: 720px;
  font-size: 1.08rem;
  line-height: 1.6;
  color: rgba(255,255,255,.90);
}

.architecture-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 2rem;
}

.architecture-grid article {
  min-height: 92px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 22px;
  padding: 1rem;
  backdrop-filter: blur(12px);
}

.architecture-grid strong { display: block; font-size: .92rem; }
.architecture-grid span { display: block; color: rgba(255,255,255,.78); margin-top: .35rem; font-size: .86rem; line-height: 1.35; }

.login-panel { display: flex; align-items: center; justify-content: center; }

.login-card {
  width: min(100%, 620px);
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(20px);
  border: 1px solid var(--login-border);
  border-radius: 32px;
  padding: clamp(1.4rem, 3vw, 2.5rem);
  box-shadow: var(--login-shadow-md);
  display: grid;
  gap: .95rem;
}

.login-card-heading h2 {
  margin: .6rem 0 0;
  font-size: clamp(1.7rem, 3vw, 2.05rem);
  letter-spacing: -0.04em;
}

.input-group { display: grid; gap: .45rem; }

label {
  font-size: .88rem;
  font-weight: 800;
  color: #24342e;
}

.input-icon-wrapper { position: relative; }

.input-icon-wrapper select,
.input-icon-wrapper input {
  width: 100%;
  border: 1px solid var(--login-border);
  border-radius: 16px;
  background: #fff;
  padding: .92rem 3rem .92rem 1rem;
  outline: none;
  color: #17231e;
  font-size: .95rem;
  font-weight: 700;
  transition: border .2s ease, box-shadow .2s ease, background .2s ease;
}

.input-icon-wrapper select { appearance: none; cursor: pointer; }
.input-icon-wrapper input::placeholder { color: #94a3b8; }

.input-icon-wrapper i {
  position: absolute;
  top: 50%;
  right: 1rem;
  transform: translateY(-50%);
  color: #b5c3bd;
  pointer-events: none;
}

.input-icon-wrapper select:focus,
.input-icon-wrapper input:focus {
  border-color: var(--login-primary);
  box-shadow: 0 0 0 4px rgba(var(--login-primary-rgb), .16);
}

.selected-establishment {
  border-radius: 18px;
  background: rgba(var(--login-primary-rgb), .10);
  padding: .82rem 1rem;
  color: var(--login-primary-dark);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  font-size: .9rem;
}

.selected-establishment strong { text-transform: capitalize; }

.error-msg {
  display: block;
  min-height: 16px;
  color: #be123c;
  font-size: .78rem;
  font-weight: 700;
}

.btn-submit {
  border: 0;
  border-radius: 999px;
  padding: .9rem 1.1rem;
  font-weight: 900;
  cursor: pointer;
  color: #fff;
  background: linear-gradient(135deg, var(--login-primary), var(--login-primary-dark));
  box-shadow: 0 18px 34px var(--login-shadow-accent);
  transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}

.btn-submit:hover { transform: translateY(-1px); box-shadow: 0 20px 40px var(--login-shadow-accent-hover); }
.btn-submit:disabled { opacity: .7; cursor: not-allowed; transform: none; }

.login-footer-note {
  color: var(--login-muted);
  line-height: 1.45;
  font-size: .78rem;
}

@media (max-width: 1180px) {
  .login-page { grid-template-columns: 1fr; }
  .login-hero { min-height: 420px; }
}

@media (max-width: 760px) {
  .login-page { padding: 1rem; }
  .login-hero { border-radius: 28px; padding: 2rem; min-height: 360px; }
  .architecture-grid { grid-template-columns: 1fr; }
  .selected-establishment { flex-direction: column; align-items: flex-start; }
}

/* Ajuste compacto solicitado: el login debe verse completo al 100% del navegador,
   manteniendo una proporción similar a cuando el navegador estaba al 90%. */
@media (min-width: 1181px) {
  .login-page {
    min-height: 100svh;
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, .78fr);
    gap: clamp(1rem, 2.4vw, 1.75rem);
    padding: clamp(1rem, 2.7vw, 2.8rem);
  }

  .login-hero {
    min-height: min(590px, calc(100svh - 5.6rem));
    border-radius: 32px;
    padding: clamp(1.8rem, 4vw, 3.7rem);
  }

  .login-hero h1 {
    font-size: clamp(2.45rem, 5.25vw, 4.95rem);
    margin: .85rem 0;
  }

  .login-hero p {
    font-size: .98rem;
    line-height: 1.52;
    max-width: 680px;
  }

  .architecture-grid {
    gap: .85rem;
    margin-top: 1.55rem;
  }

  .architecture-grid article {
    min-height: 78px;
    border-radius: 18px;
    padding: .82rem;
  }

  .architecture-grid span {
    font-size: .79rem;
  }

  .login-card {
    width: min(100%, 560px);
    border-radius: 28px;
    padding: clamp(1.25rem, 2.25vw, 2rem);
    gap: .68rem;
  }

  .login-card-heading h2 {
    font-size: clamp(1.45rem, 2.4vw, 1.85rem);
    margin-top: .45rem;
  }

  .hero-badge,
  .eyebrow {
    padding: .36rem .62rem;
    font-size: .68rem;
  }

  .input-group {
    gap: .32rem;
  }

  label {
    font-size: .78rem;
  }

  .input-icon-wrapper select,
  .input-icon-wrapper input {
    border-radius: 14px;
    padding: .74rem 2.75rem .74rem .9rem;
    font-size: .86rem;
  }

  .selected-establishment {
    border-radius: 15px;
    padding: .68rem .9rem;
    font-size: .82rem;
  }

  .btn-submit {
    padding: .78rem 1rem;
    margin-top: .1rem;
  }
}

@media (min-width: 1181px) and (max-height: 760px) {
  .login-page { padding: 1rem 2rem; }
  .login-hero { min-height: calc(100svh - 2rem); }
  .login-card { gap: .48rem; padding: 1.35rem; }
  .login-hero h1 { font-size: clamp(2.2rem, 4.7vw, 4.35rem); }
  .architecture-grid article { min-height: 68px; }
}
