/* =============================================================
   LOGIN — Corporate Clean · SAMICHAY ZRE · Tracking Portal
   Compatible con: PHP5 / CI2 · jQuery 1.7.1
   Fondos en: /tracking/images/
   ============================================================= */

/* ── Google Fonts ─────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:wght@300;400;600;700&display=swap');

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --lg-bg-desktop: url("/tracking/images/samichay_tracking_desktop.jpg");
  --lg-bg-tablet:  url("/tracking/images/samichay_tracking_tablet.jpg");
  --lg-bg-mobile:  url("/tracking/images/samichay_tracking_mobile.jpg");

  --navy:        #03244a;
  --accent:      #0099d8;
  --card-bg:     #ffffff;
  --header-bg:   #ffffff;
  --body-bg:     #f5f7fa;
  --border:      #e2e6ed;
  --label:       #6b7a90;
  --text:        #1a2533;
  --text-light:  #8a97a8;
  --shadow:      0 24px 64px rgba(0,0,0,0.40), 0 2px 8px rgba(0,0,0,0.18);
}

/* ── Base ──────────────────────────────────────────────────── */
html, body, body.login-page { min-height: 100%; }

body.login-page {
  margin: 0 !important;
  min-height: 100vh !important;
  font-family: 'Nunito Sans', Arial, sans-serif !important;

  background-image: var(--lg-bg-desktop) !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-attachment: fixed !important;
  background-color: var(--navy) !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;

  position: relative !important;
  overflow: hidden !important;
}

/* Overlay oscuro suave */
body.login-page::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(10, 18, 30, 0.52);
  z-index: 0;
}

/* ── Wrapper ───────────────────────────────────────────────── */
.login-wrap {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1;
}

/* ── Tarjeta principal — blanca y sólida ─────────────────── */
.login-card,
.login-form,
.login-box,
.form-login,
.login-content,
.login-panel {
  width: min(420px, 92vw);
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow);
  overflow: hidden;
  color: var(--text);

  animation: cardIn 0.45s cubic-bezier(0.22,1,0.36,1) both;
}

@keyframes cardIn {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Zona logo — blanca con borde inferior ──────────────────── */
.login-logo,
.brand-logo,
.img-logo,
.logo-login {
  width: 100%;
  background: var(--header-bg);
  text-align: center;
  padding: 32px 28px 26px;
  margin: 0;
  border-bottom: 1px solid var(--border);
  box-sizing: border-box;
  position: relative;
}

/* Franja navy fina en el tope de la tarjeta */
.login-logo::before,
.brand-logo::before,
.img-logo::before,
.logo-login::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--navy);
}

.login-logo img,
.brand-logo img,
.img-logo img,
.logo-login img {
  display: inline-block;
  margin: 0 auto;
  max-width: 200px;
  max-height: 80px;
  width: auto;
  height: auto;
  object-fit: contain;
}

/* ── Cuerpo del formulario ─────────────────────────────────── */
#formulario {
  border: none !important;
  margin: 0 !important;
  padding: 28px 32px 28px !important;
  background: var(--body-bg);
}

/* ── Grid de campos ────────────────────────────────────────── */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 16px;
}

.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-group-full { grid-column: 1 / -1; }

/* ── Labels ────────────────────────────────────────────────── */
.form-group label,
.form-grid > label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--label);
}

/* ── Inputs y Selects ──────────────────────────────────────── */
.login-card input[type="text"],
.login-card input[type="password"],
.login-card select {
  width: 100%;
  box-sizing: border-box;
  background: #ffffff !important;
  border: 1px solid var(--border) !important;
  border-radius: 7px !important;
  outline: none !important;
  box-shadow: none !important;
  color: var(--text) !important;
  font-family: 'Nunito Sans', Arial, sans-serif;
  font-size: 13.5px;
  font-weight: 400;
  padding: 9px 12px !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.login-card input[type="text"]:focus,
.login-card input[type="password"]:focus,
.login-card select:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(0,153,216,0.12) !important;
}

/* Flecha del select */
.login-card select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%236b7a90' d='M5 6L0 0h10z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  background-size: 9px 6px !important;
  padding-right: 28px !important;
}

.login-card select:disabled {
  background-color: #f0f2f5 !important;
  color: #9aa3b0 !important;
  cursor: not-allowed;
}

/* ── Captcha ───────────────────────────────────────────────── */
.captcha-group { gap: 6px; }

.captcha-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.captcha-img {
  flex-shrink: 0;
  background: #e8ecf0;
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 6px 10px;
  line-height: 0;
}

.captcha-input { flex: 1; }

img#captcha {
  display: block;
  width: 110px !important;
  height: auto !important;
  margin: 0 !important;
  border-radius: 3px;
  filter: contrast(2) brightness(0.6) saturate(0);
  -webkit-filter: contrast(2) brightness(0.6) saturate(0);
}

/* ── Errores ───────────────────────────────────────────────── */
.form-submit p,
.form-submit .error {
  color: #d93025;
  font-size: 12px;
  margin: 0;
  text-align: center;
}

/* ── Botón Ingresar ────────────────────────────────────────── */
.login-card input[type="submit"],
.login-card .uno {
  width: 100%;
  padding: 12px 0 !important;
  background: var(--navy) !important;
  border: none !important;
  border-radius: 8px !important;
  color: #ffffff !important;
  font-family: 'Nunito Sans', Arial, sans-serif !important;
  font-size: 13.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  box-shadow: 0 2px 10px rgba(3,36,74,0.22) !important;
  transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease !important;
}

.login-card input[type="submit"]:hover,
.login-card .uno:hover {
  background: #054b8e !important;
  box-shadow: 0 6px 20px rgba(3,36,74,0.32) !important;
  transform: translateY(-1px) !important;
}

.login-card input[type="submit"]:active,
.login-card .uno:active {
  transform: translateY(0) !important;
  background: var(--navy) !important;
}

/* ── Footer copyright ──────────────────────────────────────── */
.form-grid > label:last-child,
.login-card label[for="txtoficina"]:last-of-type {
  grid-column: 1 / -1;
  text-align: center;
  font-size: 11px;
  color: var(--text-light);
  letter-spacing: 0.04em;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  font-weight: 400;
  text-transform: none;
}

/* ── Banner interior: Seguro · Rápido · Global ─────────────── */
.login-banner {
  background: var(--navy);
  border-radius: 10px;
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0;
  padding: 16px 18px;
  box-sizing: border-box;
  margin-bottom: 2px;
  text-align: left !important;
}

.login-banner * {
  text-align: left !important;
}

.login-banner-item {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 10px;
  flex: 1;
  padding: 0 12px;
  border-right: 1px solid rgba(255,255,255,0.12);
}

.login-banner-item:first-child { padding-left: 0; }
.login-banner-item:last-child  { padding-right: 0; border-right: none; }

.login-banner-icon {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border: 1.5px solid rgba(0,153,216,0.55);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}

.login-banner-icon svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: #0099d8;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.login-banner-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.login-banner-title {
  font-size: 11.5px;
  font-weight: 700;
  color: #ffffff;
  white-space: nowrap;
}

.login-banner-desc {
  font-size: 10px;
  color: rgba(255,255,255,0.58);
  line-height: 1.4;
}


/* ── Responsive tablet ─────────────────────────────────────── */
@media (max-width: 1024px) {
  body.login-page {
    background-image: var(--lg-bg-tablet) !important;
  }
}

/* ── Responsive móvil ──────────────────────────────────────── */
@media (max-width: 600px) {
  body.login-page {
    background-image: var(--lg-bg-mobile) !important;
    padding: 14px !important;
  }

  .login-card,
  .login-form,
  .login-box,
  .form-login,
  .login-content,
  .login-panel {
    width: min(420px, 96vw);
    border-radius: 14px;
  }

  #formulario {
    padding: 22px 20px 22px !important;
  }

  .form-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .login-logo img,
  .brand-logo img,
  .img-logo img,
  .logo-login img {
    max-width: 170px;
    max-height: 68px;
  }

  .captcha-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .captcha-input { width: 100%; }

  .login-card input[type="text"],
  .login-card select {
    font-size: 16px;
  }
}