/* CajaClara — Auth (Login/Logout)
   Objetivo: entrada limpia, premium y sin estrés.
   Regla: celeste como “luz”, dorado solo microdetalle.
*/

.cc-auth{
  min-height: 100vh;
  padding: 24px 16px;
  background-color: var(--cc-bg);

  /* Luz suave (no “gaming”) */
  background-image:
    radial-gradient(900px circle at 18% 18%,
      color-mix(in srgb, var(--cc-mod) 18%, transparent),
      transparent 62%),
    radial-gradient(900px circle at 92% 0%,
      rgba(242,178,27,.08),
      transparent 68%),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 56%);
}

html[data-bs-theme="light"] .cc-auth{
  background-color: var(--cc-bg);
  background-image:
    radial-gradient(900px circle at 18% 18%,
      color-mix(in srgb, var(--cc-mod) 14%, transparent),
      transparent 64%),
    radial-gradient(900px circle at 92% 0%,
      rgba(242,178,27,.06),
      transparent 70%),
    linear-gradient(180deg, rgba(11,18,32,.03), transparent 62%);
}

.cc-auth-wrap{
  min-height: calc(100vh - 48px);
  display: grid;
  place-items: center;
  padding-bottom: env(safe-area-inset-bottom);
}

/* Card principal */
.cc-auth-card{
  position: relative;
  width: min(440px, 100%);
  padding: 22px;

  background: var(--cc-surface);
  border: 1px solid var(--cc-border);
  border-radius: var(--cc-radius);

  box-shadow: 0 18px 55px rgba(0,0,0,.28);
  overflow: hidden;
}

/* Micro “bisel” premium */
.cc-auth-card::before{
  content:"";
  position: absolute;
  inset: 0;
  pointer-events: none;

  background:
    radial-gradient(700px circle at 20% 0%,
      color-mix(in srgb, var(--cc-mod) 16%, transparent),
      transparent 58%),
    radial-gradient(500px circle at 90% 0%,
      rgba(242,178,27,.10),
      transparent 64%);

  opacity: .9;
}

/* Separador superior sutil (industrial) */
.cc-auth-card::after{
  content:"";
  position: absolute;
  left: 14px;
  right: 14px;
  top: 0;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg,
    transparent,
    rgba(148,163,184,.18),
    transparent
  );
}

/* Header */
.cc-auth-head{
  position: relative;
  text-align: center;
  margin-bottom: 14px;
  z-index: 1;
}

.cc-auth-mark{
  display: block;
  margin: 0 auto 10px;
  width: min(240px, 72%);
  height: auto;

  /* No exagerar: solo “presencia” */
  filter: drop-shadow(0 14px 24px rgba(0,0,0,.18));
}

.cc-auth-title{
  margin: 0;
  font-size: 1.2rem;
  font-weight: 850;
  letter-spacing: -.01em;
  color: rgba(var(--cc-text-rgb), .94);
}

.cc-auth-subtitle{
  margin: 6px 0 0;
  color: rgba(var(--cc-text-rgb), .78);
  font-size: .95rem;
}

.cc-auth-note{
  position: relative;
  margin: 10px 0 0;
  color: rgba(var(--cc-text-rgb), .72);
  font-size: .9rem;
  z-index: 1;
}

/* Error (credencial inválida) */
.cc-auth-alert{
  position: relative;
  margin-top: 12px;
  padding: 10px 12px;

  border-radius: 14px;
  border: 1px solid rgba(220,38,38,.28);
  background: rgba(220,38,38,.10);
  color: rgba(var(--cc-text-rgb), .92);
  z-index: 1;
}

/* Form */
.cc-auth-form{
  position: relative;
  margin-top: 12px;
  z-index: 1;
}

.cc-auth-card .form-label{
  font-weight: 700;
  color: rgba(var(--cc-text-rgb), .88);
  font-size: .88rem;
}

/* Inputs: consistencia aunque Django no meta clases */
.cc-auth-card input,
.cc-auth-card select,
.cc-auth-card textarea{
  display: block;
  width: 100%;
}

.cc-auth-card input[type="text"],
.cc-auth-card input[type="password"],
.cc-auth-card input[type="email"]{
  min-height: 44px;
  line-height: 1.2;

  padding: .62rem .78rem;
  border-radius: 14px;

  border: 1px solid var(--cc-border);
  background: color-mix(in srgb, var(--cc-surface) 88%, transparent);
  color: var(--cc-text);
  font-size: .95rem;

  -webkit-appearance: none;
  appearance: none;
  transition: border-color .12s ease, box-shadow .12s ease, background-color .12s ease;
}

.cc-auth-card input::placeholder{
  color: rgba(var(--cc-text-rgb), .55);
}

.cc-auth-card input:focus{
  outline: none;
  border-color: color-mix(in srgb, var(--cc-mod) 46%, var(--cc-border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cc-mod) 22%, transparent);
  background: color-mix(in srgb, var(--cc-surface) 92%, transparent);
}

/* Si Django llega a inyectar form-control, lo dejamos igual */
.cc-auth-card .form-control{
  border-radius: 14px;
  border: 1px solid var(--cc-border);
  background: color-mix(in srgb, var(--cc-surface) 88%, transparent);
  color: var(--cc-text);
}

.cc-auth-card .form-control:focus{
  border-color: color-mix(in srgb, var(--cc-mod) 46%, var(--cc-border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cc-mod) 22%, transparent);
}

.cc-auth-help{
  margin-top: 10px;
  color: rgba(var(--cc-text-rgb), .70);
  font-size: .86rem;
}

/* Botón principal: acento por módulo + “joyita” dorada */
.cc-auth-btn{
  position: relative;

  border: 1px solid color-mix(in srgb, var(--cc-mod) 46%, var(--cc-border)) !important;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--cc-mod) 92%, #000),
    color-mix(in srgb, var(--cc-mod-2) 92%, #000)
  ) !important;

  color: rgba(231,238,248,.96) !important;
  border-radius: 16px !important;
  padding: .72rem .92rem !important;
  font-weight: 850;

  box-shadow: 0 18px 44px rgba(0,0,0,.28);
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}

.cc-auth-btn::after{
  content:"";
  position:absolute;
  top: 10px;
  right: 12px;
  width: 8px;
  height: 8px;
  border-radius: 999px;

  background: var(--cc-gold);
  box-shadow: 0 0 0 3px rgba(242,178,27,.16);
}

.cc-auth-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 56px rgba(0,0,0,.34);
}

.cc-auth-btn:active{
  transform: translateY(0);
}

.cc-auth-btn:focus-visible{
  outline: none;
  box-shadow:
    0 22px 56px rgba(0,0,0,.34),
    0 0 0 3px rgba(var(--cc-brand-rgb), .30);
}

/* Motion safe */
@media (prefers-reduced-motion: reduce){
  .cc-auth-card,
  .cc-auth-btn,
  .cc-auth-card input[type="text"],
  .cc-auth-card input[type="password"],
  .cc-auth-card input[type="email"]{
    transition: none !important;
  }
  .cc-auth-btn:hover{ transform: none; }
}

/* Un toque más aire en desktop */
@media (min-width: 768px){
  .cc-auth{ padding: 32px 20px; }
  .cc-auth-card{ padding: 26px; }
}

/* Login: password toggle + caps lock */
.cc-auth-pass{
  position: relative;
}

.cc-auth-pass input{
  padding-right: 44px; /* espacio para el ojo */
}

.cc-auth-eye{
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);

  width: 34px;
  height: 34px;
  border-radius: 12px;

  display: inline-grid;
  place-items: center;

  border: 1px solid rgba(148,163,184,.14);
  background: rgba(255,255,255,.03);
  color: rgba(var(--cc-text-rgb), .88);

  cursor: pointer;
}

.cc-auth-eye:hover{
  border-color: rgba(148,163,184,.22);
}

.cc-auth-eye:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cc-mod) 22%, transparent);
}

.cc-auth-caps{
  margin-top: 8px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(242,178,27,.22);
  background: rgba(242,178,27,.08);
  color: rgba(var(--cc-text-rgb), .92);
  font-size: .88rem;
}
