/* Patch mínimo: botón Login + modal de acceso al panel */
.panel-login-trigger,
.drawer-login-trigger,
.footer-login-trigger{
  cursor:pointer;
}

.panel-login-trigger{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-width:110px;
}

.footer-login-trigger{
  display:inline-block;
  margin-top:8px;
  font-weight:700;
}

.panel-login-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:rgba(6,10,20,.58);
  backdrop-filter:blur(6px);
  z-index:260;
}

.panel-login-modal.show{ display:flex; }

.panel-login-box{
  width:min(460px, 100%);
  max-height:min(90vh, 740px);
  background:linear-gradient(180deg, rgba(18,26,46,.98), rgba(10,14,24,.98));
  color:#fff;
  border:1px solid rgba(199,155,58,.25);
  border-radius:24px;
  box-shadow:0 30px 80px rgba(0,0,0,.35);
  overflow:hidden;
}

.panel-login-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:20px 22px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.panel-login-head h3{
  margin:8px 0 6px;
  font-size:1.55rem;
  line-height:1.1;
  color:#fff;
}

.panel-login-head p{
  margin:0;
  color:rgba(255,255,255,.72);
}

.panel-login-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 11px;
  border-radius:999px;
  background:rgba(199,155,58,.14);
  color:#f7d98f;
  font-size:.77rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:700;
}

.panel-login-close{
  width:42px;
  height:42px;
  border:none;
  border-radius:14px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:1.35rem;
  cursor:pointer;
  flex:0 0 auto;
}

.panel-login-close:hover{ filter:brightness(1.06); }

.panel-login-body{
  padding:18px 22px 22px;
}

.panel-login-form{
  display:grid;
  gap:14px;
}

.panel-login-form label{
  display:grid;
  gap:8px;
  color:#fff;
  font-weight:600;
}

.panel-login-form input{
  width:100%;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#fff;
}

.panel-login-form input::placeholder{
  color:rgba(255,255,255,.48);
}

.panel-login-form input:focus{
  outline:none;
  border-color:rgba(199,155,58,.5);
  box-shadow:0 0 0 4px rgba(199,155,58,.12);
}

.panel-login-submit{
  width:100%;
}

.panel-login-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.panel-login-note{
  color:rgba(255,255,255,.64);
  font-size:.92rem;
}

.panel-login-link{
  color:#f6d57d;
  font-weight:700;
}

.panel-login-alert{
  display:none;
  padding:12px 14px;
  border-radius:14px;
  font-size:.95rem;
  line-height:1.45;
}

.panel-login-alert.show{ display:block; }
.panel-login-alert.error{
  background:rgba(239,68,68,.16);
  border:1px solid rgba(239,68,68,.36);
  color:#fecaca;
}
.panel-login-alert.success{
  background:rgba(34,197,94,.14);
  border:1px solid rgba(34,197,94,.28);
  color:#bbf7d0;
}

body.panel-login-open{
  overflow:hidden;
}

@media (max-width: 860px){
  .panel-login-trigger{ display:none; }
  .drawer-login-trigger{
    width:100%;
    margin-top:12px;
  }
}

@media (max-width: 640px){
  .panel-login-head{ padding:18px 18px 10px; }
  .panel-login-body{ padding:16px 18px 18px; }
}
.panel-login-mode{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:2px}
.panel-login-mode-option{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);cursor:pointer;font-weight:700}
.panel-login-mode-option input{width:auto;accent-color:#c79b3a}.panel-login-mode-option span{color:#fff}@media (max-width:640px){.panel-login-mode{grid-template-columns:1fr}}
