/* ==========================================================================
   moovi · Área de Cliente — estilos del plugin
   Tokens según guía de marca (extraídos de moovitelecom.com).
   Scope: .moovi-login (login) y .moovi-app (panel privado)
   ========================================================================== */
:root{
  --moovi-blue:#001EE4;
  --moovi-blue-deep:#1D1550;
  --moovi-violet:#302485;
  --moovi-mint:#29E4C1;
  --moovi-lavender:#D9D3FF;
  --moovi-lavender-bg:#F4F5FF;
  --moovi-pink:#CC3366;
  --moovi-black:#000000;
  --moovi-white:#FFFFFF;
  --neutral-50:#F8F9FA;
  --neutral-100:#F0F2F3;
  --neutral-150:#F3F3F3;
  --neutral-300:#D5D8DC;
  --neutral-500:#8A929B;
  --neutral-700:#424242;
  --error:#CC3366;
  --warning:#F4A300;
  --success:#1FB385;
  --moovi-font:'Poppins','Helvetica Neue',Arial,sans-serif;
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-pill:9999px;
  --shadow-card:0 8px 32px rgba(0,30,228,.06), 0 2px 8px rgba(0,0,0,.03);
  --sidebar-w:248px;
}
.moovi-login *,.moovi-app *,.moovi-login,.moovi-app{box-sizing:border-box}

/* ===================  LOGIN  =================== */
.moovi-login{font-family:var(--moovi-font);font-weight:300;color:var(--moovi-black);-webkit-font-smoothing:antialiased}
.moovi-login:not(.moovi-login--embedded){background:var(--neutral-100);min-height:100vh}
.moovi-login--embedded{background:transparent}
.moovi-login--embedded .moovi-main{padding:16px 0;max-width:880px;gap:24px;align-items:center;grid-template-columns:1fr 1.1fr}
.moovi-login--embedded .moovi-title{font-size:22px !important;letter-spacing:-.5px !important;margin:0 0 4px !important;font-weight:600 !important}
.moovi-login--embedded .moovi-subtitle{margin:0 0 14px !important;font-size:13px !important;line-height:1.45 !important}
.moovi-login--embedded .moovi-card{padding:18px}
.moovi-login--embedded .moovi-visual{max-width:180px}
.moovi-login--embedded .moovi-help{margin-top:10px;font-size:11px}
.moovi-login--embedded .moovi-form-wrap{max-width:380px;width:100%}
.moovi-login--embedded .moovi-field{margin-bottom:10px}
.moovi-login--embedded .moovi-field--float{margin-bottom:10px}
.moovi-login--embedded .moovi-field--float .moovi-input{padding:10px 14px !important;font-size:13px !important;border-radius:12px !important}
.moovi-login--embedded .moovi-field--float label{font-size:11px !important}
.moovi-login--embedded .moovi-tabs{margin:0 0 14px !important;padding:3px !important}
.moovi-login--embedded .moovi-tabs button{font-size:12px !important;padding:7px 12px !important}
.moovi-login--embedded .moovi-row{margin:2px 0 14px}
.moovi-login--embedded .moovi-row,
.moovi-login--embedded .moovi-link{font-size:12px}
/* Botón estilo moovitelecom.com — pill compacta como las del nav (padding 7-8, font 13) */
.moovi-login--embedded .moovi-btn{
  width:auto !important;
  padding:8px 20px !important;
  font-size:13px !important;
  font-weight:500 !important;
  gap:6px !important;
  border-radius:9999px !important;
  align-self:center !important;
  margin:6px auto 0 !important;
  box-shadow:none !important;
  letter-spacing:0 !important;
}
.moovi-login--embedded .moovi-btn .arrow{width:18px !important;height:18px !important;background:rgba(255,255,255,.18) !important}
.moovi-login--embedded .moovi-btn .arrow svg{width:9px !important;height:9px !important}
.moovi-login--embedded .moovi-btn:hover{box-shadow:0 4px 12px rgba(0,30,228,.18) !important}
.moovi-login--embedded .moovi-divider{margin:14px 0 10px;font-size:10px}
.moovi-login--embedded .moovi-cert{padding:9px 12px;font-size:12px}
.moovi-login--embedded .moovi-cert .ico{width:32px;height:32px}
.moovi-login--embedded .moovi-cert .ico svg{width:16px;height:16px}
@media (max-width:980px){
  .moovi-login--embedded .moovi-main{padding:14px 0;gap:14px;grid-template-columns:1fr}
  .moovi-login--embedded .moovi-visual{max-width:120px;margin:0 auto}
  .moovi-login--embedded .moovi-form-wrap{margin:0 auto}
}
@media (max-width:680px){
  .moovi-login--embedded{padding:0 8px}
  .moovi-login--embedded .moovi-title{font-size:20px !important}
  .moovi-login--embedded .moovi-visual{max-width:54px}
  .moovi-login--embedded .moovi-visual .hashtag{font-size:10px;padding:3px 7px;top:-3px;letter-spacing:0}
  .moovi-login--embedded .moovi-card{padding:16px}
}
@media (max-width:480px){
  .moovi-login--embedded{padding:0 12px}
  .moovi-login--embedded .moovi-visual{max-width:42px}
  .moovi-login--embedded .moovi-visual .hashtag{font-size:9px;padding:2px 6px;top:-2px}
}

/* === FOTO LIFESTYLE: usa imagen real de moovitelecom.com (telco/Gen-Z) === */
.moovi-login .moovi-visual .photo{
  background-image:linear-gradient(135deg, rgba(0,30,228,.08), rgba(217,211,255,.18)),
                   url('https://moovitelecom.com/wp-content/uploads/2024/08/take-photos-for-instagram-2023-11-27-05-22-42-utc-scaled.jpg') !important;
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
}

/* === TARJETA con efecto glass moderno === */
.moovi-login .moovi-card{
  background:rgba(255,255,255,.92) !important;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.6) !important;
  border-radius:24px !important;
  box-shadow:0 24px 48px -12px rgba(0,30,228,.12), 0 8px 16px rgba(0,0,0,.04), inset 0 1px 0 rgba(255,255,255,.7) !important;
}

/* === TABS estilo segmented control con glider animado === */
.moovi-login .moovi-tabs{
  position:relative;
  display:flex !important;
  gap:0 !important;
  padding:4px !important;
  margin:0 0 22px !important;
  background:var(--neutral-100) !important;
  border:0 !important;
  border-radius:var(--r-pill) !important;
  overflow:hidden;
}
.moovi-login .moovi-tabs-glider{
  position:absolute;
  top:4px; left:4px;
  width:calc(50% - 4px); height:calc(100% - 8px);
  background:#fff !important;
  border-radius:var(--r-pill) !important;
  box-shadow:0 2px 8px rgba(0,30,228,.12), 0 1px 2px rgba(0,0,0,.06) !important;
  transition:transform .25s cubic-bezier(.4,0,.2,1);
  z-index:0;
  pointer-events:none;
}
.moovi-login .moovi-tabs[data-active="1"] .moovi-tabs-glider{transform:translateX(100%)}
.moovi-login .moovi-tabs button{
  position:relative !important;
  flex:1 !important;
  z-index:1;
  background:transparent !important;
  border:0 !important;
  border-radius:var(--r-pill) !important;
  font-family:inherit !important;
  font-size:13px !important;
  font-weight:600 !important;
  color:var(--neutral-500) !important;
  padding:10px 14px !important;
  margin:0 !important;
  cursor:pointer;
  text-shadow:none !important;
  text-transform:none !important;
  letter-spacing:0 !important;
  line-height:1.2 !important;
  transition:color .2s ease;
  width:auto !important;
  height:auto !important;
  min-width:0 !important;
  min-height:0 !important;
  box-shadow:none !important;
}
.moovi-login .moovi-tabs button:hover{color:var(--moovi-blue) !important;background:transparent !important;transform:none !important}
.moovi-login .moovi-tabs button.is-active{color:var(--moovi-blue) !important;background:transparent !important}
.moovi-login .moovi-tabs button > span{position:relative;z-index:2}

/* === FIELDS con FLOATING LABEL — eliminamos label encima === */
.moovi-login .moovi-field{margin-bottom:16px;position:relative}
.moovi-login .moovi-field--float{margin-bottom:14px}
.moovi-login .moovi-field--float > label{display:none} /* ocultamos los labels antiguos arriba */
.moovi-login .moovi-field--float .moovi-input-wrap{position:relative}
.moovi-login .moovi-field--float .moovi-input,
.moovi-login .moovi-field--float input.moovi-input{
  width:100% !important;
  font-family:var(--moovi-font) !important;
  font-size:15px !important;
  font-weight:400 !important;
  color:var(--moovi-black) !important;
  background:#fff !important;
  border:1.5px solid var(--neutral-300) !important;
  border-radius:16px !important;
  padding:22px 16px 8px !important;
  height:auto !important;
  line-height:1.4 !important;
  box-shadow:none !important;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
  margin:0 !important;
  appearance:none !important;
  -webkit-appearance:none !important;
}
.moovi-login .moovi-field--float .moovi-input.has-icon{padding-right:48px !important}
.moovi-login .moovi-field--float .moovi-input::placeholder{color:transparent}
.moovi-login .moovi-field--float .moovi-input + label,
.moovi-login .moovi-field--float .moovi-input-wrap > label{
  display:block !important;
  position:absolute !important;
  left:16px;
  top:50%;
  transform:translateY(-50%);
  font-size:14px !important;
  font-weight:400 !important;
  color:var(--neutral-500) !important;
  pointer-events:none;
  margin:0 !important;
  background:transparent !important;
  transition:transform .18s ease, font-size .18s ease, color .18s ease;
  letter-spacing:0;
}
/* Estado focus o relleno: la label flota arriba con fondo blanco para no chocar con el borde */
.moovi-login .moovi-field--float .moovi-input:focus + label,
.moovi-login .moovi-field--float .moovi-input:not(:placeholder-shown) + label,
.moovi-login .moovi-field--float .moovi-input:-webkit-autofill + label,
.moovi-login .moovi-field--float .moovi-input-wrap:focus-within > label,
.moovi-login .moovi-field--float .moovi-input-wrap > input:not(:placeholder-shown) ~ label{
  top:0 !important;
  transform:translateY(-50%) !important;
  font-size:11px !important;
  font-weight:600 !important;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:var(--moovi-blue) !important;
  background:#fff !important;
  padding:0 6px !important;
  line-height:1 !important;
}
.moovi-login .moovi-field--float .moovi-input:focus,
.moovi-login .moovi-field--float .moovi-input:focus-visible{
  outline:none !important;
  border-color:var(--moovi-blue) !important;
  box-shadow:0 0 0 4px rgba(0,30,228,.12) !important;
}
.moovi-login .moovi-field--float .moovi-input:hover:not(:focus){border-color:#9aa1a8 !important}

/* Override del autofill amarillo/azul de Chrome */
.moovi-login .moovi-input:-webkit-autofill,
.moovi-login .moovi-input:-webkit-autofill:hover,
.moovi-login .moovi-input:-webkit-autofill:focus{
  -webkit-text-fill-color:var(--moovi-black) !important;
  -webkit-box-shadow:0 0 0 1000px #fff inset !important;
  box-shadow:0 0 0 1000px #fff inset, 0 0 0 4px rgba(0,30,228,.12) !important;
  caret-color:var(--moovi-black) !important;
  border-color:var(--moovi-blue) !important;
  transition:background-color 5000s ease-in-out 0s;
}

/* === Toggle ojo de contraseña realineado para floating label === */
.moovi-login .moovi-toggle-pass{
  position:absolute !important;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  background:transparent !important;
  border:0 !important;
  cursor:pointer;
  width:36px; height:36px;
  border-radius:50% !important;
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  color:var(--neutral-500) !important;
  padding:0 !important;
  box-shadow:none !important;
}
.moovi-login .moovi-toggle-pass:hover{background:var(--moovi-lavender-bg) !important;color:var(--moovi-blue) !important;transform:translateY(-50%) !important}
.moovi-login .moovi-toggle-pass svg{width:18px;height:18px}

/* === Row remember / forgot === */
.moovi-login .moovi-row{display:flex;justify-content:space-between;align-items:center;margin:6px 0 22px;flex-wrap:wrap;gap:12px}
.moovi-login .moovi-check{display:inline-flex !important;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--neutral-700);background:transparent !important;padding:0 !important;border:0 !important}
.moovi-login .moovi-check input[type="checkbox"]{
  appearance:none !important; -webkit-appearance:none !important;
  width:18px; height:18px;
  border:1.5px solid var(--neutral-300) !important;
  border-radius:6px !important;
  cursor:pointer;
  background:#fff !important;
  margin:0 !important;
  display:inline-flex !important;
  align-items:center; justify-content:center;
  transition:all .15s ease;
  flex:none;
}
.moovi-login .moovi-check input[type="checkbox"]:checked{background:var(--moovi-blue) !important;border-color:var(--moovi-blue) !important}
.moovi-login .moovi-check input[type="checkbox"]:checked::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}
.moovi-login .moovi-check > span{line-height:1}
.moovi-login .moovi-link{color:var(--moovi-blue) !important;text-decoration:none !important;font-size:13px;font-weight:500;background:transparent !important;border:0 !important;padding:0 !important}
.moovi-login .moovi-link:hover{text-decoration:underline !important;background:transparent !important}

/* === BOTÓN principal — pill negra moovi con flecha que se desliza === */
.moovi-login .moovi-btn{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100% !important;
  font-family:var(--moovi-font) !important;
  font-weight:600 !important;
  font-size:15px !important;
  line-height:1 !important;
  background:var(--moovi-black) !important;
  color:#fff !important;
  border:0 !important;
  cursor:pointer;
  padding:16px 24px !important;
  border-radius:var(--r-pill) !important;
  text-shadow:none !important;
  text-transform:none !important;
  letter-spacing:0 !important;
  box-shadow:0 4px 12px rgba(0,0,0,.12) !important;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
  position:relative;
  overflow:hidden;
}
.moovi-login .moovi-btn::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(135deg, var(--moovi-blue) 0%, var(--moovi-blue) 55%, var(--moovi-black) 100%);
  opacity:0;
  transition:opacity .25s ease;
}
.moovi-login .moovi-btn:hover{transform:translateY(-1px) !important;box-shadow:0 12px 28px rgba(0,30,228,.32) !important}
.moovi-login .moovi-btn:hover::before{opacity:1}
.moovi-login .moovi-btn > *{position:relative;z-index:1}
.moovi-login .moovi-btn .arrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px; height:24px;
  border-radius:50%;
  background:rgba(255,255,255,.2);
  transition:transform .2s ease;
}
.moovi-login .moovi-btn:hover .arrow{transform:translateX(3px)}
.moovi-login .moovi-btn .arrow svg{width:12px;height:12px}
.moovi-login .moovi-btn:disabled{opacity:.7;cursor:wait}

/* === Mensaje de error === */
.moovi-login .moovi-error{margin:14px 0 0;padding:12px 14px;background:#FCE6EE !important;color:var(--error) !important;border-radius:var(--r-md);font-size:13px;font-weight:500;border:1px solid rgba(204,51,102,.18)}
.moovi-login .moovi-help-text{margin:0 0 16px;font-size:13px;color:var(--neutral-700);line-height:1.5}
/* === Bloque demo === */
.moovi-login .moovi-demo-block{margin-top:18px}
.moovi-login .moovi-divider{display:flex;align-items:center;gap:12px;margin:18px 0 14px;color:var(--neutral-500);font-size:11px;text-transform:uppercase;letter-spacing:1.4px;font-weight:600}
.moovi-login .moovi-divider::before,.moovi-login .moovi-divider::after{content:"";flex:1;height:1px;background:var(--neutral-300)}
.moovi-login .moovi-divider span{flex:0 0 auto}
.moovi-login .moovi-btn--demo{
  background:transparent !important;
  color:var(--moovi-blue) !important;
  border:1.5px dashed var(--moovi-blue) !important;
  box-shadow:none !important;
}
.moovi-login .moovi-btn--demo::before{display:none}
.moovi-login .moovi-btn--demo:hover{
  background:var(--moovi-lavender-bg) !important;
  color:var(--moovi-blue) !important;
  border-style:solid !important;
  box-shadow:0 6px 16px rgba(0,30,228,.12) !important;
}
.moovi-login .moovi-demo-hint{margin:8px 0 0;font-size:12px;color:var(--neutral-500);text-align:center;line-height:1.45}
.moovi-login .moovi-help{text-align:center;margin-top:18px;font-size:13px;color:var(--neutral-700)}
.moovi-login .moovi-help a{color:var(--moovi-blue) !important;text-decoration:none;font-weight:500}
.moovi-login .moovi-help a:hover{text-decoration:underline}
.moovi-login .moovi-topbar{background:var(--moovi-black);color:#fff;font-size:13px;padding:10px 24px;display:flex;justify-content:space-between;align-items:center}
.moovi-login .moovi-topbar a{color:inherit;text-decoration:none;opacity:.85}
.moovi-login .moovi-topbar a:hover{opacity:1}
.moovi-login .moovi-topbar .back{display:inline-flex;align-items:center;gap:8px;font-weight:500}
.moovi-login .moovi-topbar .back svg{width:14px;height:14px}
.moovi-login .moovi-topbar .lang{display:inline-flex;align-items:center;gap:6px}
.moovi-login .moovi-topbar .lang button{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;font-family:inherit;font-size:12px;font-weight:500;padding:4px 10px;border-radius:var(--r-pill);cursor:pointer;transition:all .15s ease}
.moovi-login .moovi-topbar .lang button:hover,.moovi-login .moovi-topbar .lang button.is-active{background:#fff;color:#000}

.moovi-login .moovi-brandband{background:var(--moovi-black);padding:24px 24px 64px;display:flex;justify-content:center;align-items:center;position:relative}
.moovi-login .moovi-brandband .logo{height:64px;width:auto}
.moovi-login .moovi-brandband::after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:32px;background:var(--neutral-100);border-radius:32px 32px 0 0}

.moovi-login .moovi-strip{background:var(--moovi-blue);color:#fff;padding:10px 24px;font-size:13px;text-align:center;font-weight:400}
.moovi-login .moovi-strip strong{font-weight:600}

.moovi-login .moovi-main{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;max-width:1120px;margin:0 auto;padding:64px 32px 96px;align-items:center}
@media (max-width:880px){.moovi-login .moovi-main{grid-template-columns:1fr;padding:32px 16px 64px;gap:24px}}

.moovi-login .moovi-visual{position:relative;aspect-ratio:1/1;max-width:480px;width:100%;margin:0 auto}
.moovi-login .moovi-visual .blob{position:absolute;background:var(--moovi-blue);border-radius:50% 40% 50% 40% / 40% 50% 40% 50%}
.moovi-login .moovi-visual .blob-1{top:0;left:8%;width:55%;height:55%;background:var(--moovi-lavender)}
.moovi-login .moovi-visual .blob-2{bottom:8%;right:6%;width:45%;height:45%;background:var(--moovi-mint)}
.moovi-login .moovi-visual .blob-3{top:30%;right:12%;width:30%;height:30%;background:var(--moovi-blue)}
.moovi-login .moovi-visual .photo{position:absolute;inset:8% 12% 8% 12%;border-radius:50% 45% 50% 45% / 45% 50% 45% 50%;overflow:hidden;background:#ddd center/cover no-repeat;background-image:linear-gradient(135deg, rgba(0,30,228,.15), rgba(217,211,255,.4)), url('https://images.unsplash.com/photo-1573497019940-1c28c88b4f3e?w=900&auto=format&fit=crop&q=70');box-shadow:0 24px 48px rgba(0,30,228,.18)}
.moovi-login .moovi-visual .hashtag{position:absolute;top:-8px;right:0;font-size:18px;font-weight:600;color:var(--moovi-blue);letter-spacing:-.5px;background:#fff;padding:8px 16px;border-radius:var(--r-pill);box-shadow:var(--shadow-card);transform:rotate(4deg)}

.moovi-login .moovi-form-wrap{width:100%;max-width:480px;margin:0 auto}
.moovi-login .moovi-eyebrow{display:inline-block;font-size:12px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--moovi-blue);background:var(--moovi-lavender-bg);padding:6px 14px;border-radius:var(--r-pill);margin-bottom:16px}
.moovi-login .moovi-title{font-size:48px;font-weight:600;letter-spacing:-2px;line-height:1;color:var(--moovi-blue);margin:0 0 12px}
.moovi-login .moovi-subtitle{font-size:15px;font-weight:300;color:var(--neutral-700);line-height:1.6;margin:0 0 32px}
.moovi-login .moovi-card{background:#fff;border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-card);border:1px solid var(--neutral-300)}

.moovi-login .moovi-tabs{display:flex;gap:6px;margin-bottom:18px;border-bottom:1px solid var(--neutral-150)}
.moovi-login .moovi-tabs button{background:transparent;border:0;border-bottom:2px solid transparent;color:var(--neutral-700);font-family:inherit;font-size:14px;font-weight:500;padding:10px 4px;cursor:pointer;margin-bottom:-1px}
.moovi-login .moovi-tabs button.is-active{color:var(--moovi-blue);border-bottom-color:var(--moovi-blue)}

.moovi-login .moovi-field{margin-bottom:18px}
.moovi-login .moovi-field label{display:block;font-size:13px;font-weight:500;color:var(--neutral-700);margin-bottom:6px}
.moovi-login .moovi-input-wrap{position:relative}
.moovi-login .moovi-input{width:100%;font-family:inherit;font-size:15px;font-weight:400;color:var(--moovi-black);background:#fff;border:1.5px solid var(--neutral-300);border-radius:14px;padding:14px 16px;transition:border-color .15s ease, box-shadow .15s ease}
.moovi-login .moovi-input::placeholder{color:#9aa1a8;font-weight:300}
.moovi-login .moovi-input:focus{outline:none;border-color:var(--moovi-blue);box-shadow:0 0 0 4px rgba(0,30,228,.12)}
.moovi-login .moovi-input.has-icon{padding-right:48px}
.moovi-login .moovi-toggle-pass{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:0;cursor:pointer;width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--neutral-700)}
.moovi-login .moovi-toggle-pass:hover{background:var(--neutral-100);color:var(--moovi-blue)}
.moovi-login .moovi-toggle-pass svg{width:18px;height:18px}

.moovi-login .moovi-row{display:flex;justify-content:space-between;align-items:center;margin:8px 0 24px;flex-wrap:wrap;gap:12px}
.moovi-login .moovi-check{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--neutral-700)}
.moovi-login .moovi-check input{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:1.5px solid var(--neutral-300);border-radius:5px;cursor:pointer;background:#fff;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}
.moovi-login .moovi-check input:checked{background:var(--moovi-blue);border-color:var(--moovi-blue)}
.moovi-login .moovi-check input:checked::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}
.moovi-login .moovi-link{color:var(--moovi-blue);text-decoration:none;font-size:13px;font-weight:500}
.moovi-login .moovi-link:hover{text-decoration:underline}

.moovi-login .moovi-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;font-family:inherit;font-weight:500;font-size:15px;background:var(--moovi-black);color:#fff;border:0;cursor:pointer;padding:16px 24px;border-radius:var(--r-pill);transition:transform .15s ease, background .15s ease, box-shadow .15s ease}
.moovi-login .moovi-btn:hover{background:var(--moovi-blue);transform:translateY(-1px);box-shadow:0 12px 24px rgba(0,30,228,.25)}
.moovi-login .moovi-btn .arrow{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.18)}
.moovi-login .moovi-btn .arrow svg{width:12px;height:12px}
.moovi-login .moovi-btn:disabled{opacity:.7;cursor:wait}

.moovi-login .moovi-error{margin:12px 0 0;padding:10px 14px;background:#FCE6EE;color:var(--error);border-radius:var(--r-md);font-size:13px}
.moovi-login .moovi-help-text{margin:0 0 16px;font-size:13px;color:var(--neutral-700);line-height:1.5}

.moovi-login .moovi-divider{display:flex;align-items:center;gap:12px;color:var(--neutral-300);font-size:12px;margin:28px 0 20px;text-transform:uppercase;letter-spacing:1px}
.moovi-login .moovi-divider::before,.moovi-login .moovi-divider::after{content:"";flex:1;height:1px;background:var(--neutral-300)}

.moovi-login .moovi-cert{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1.5px dashed var(--neutral-300);border-radius:14px;text-decoration:none;color:var(--moovi-black);font-size:13px;transition:all .15s ease}
.moovi-login .moovi-cert:hover{border-color:var(--moovi-blue);background:var(--moovi-lavender-bg)}
.moovi-login .moovi-cert .ico{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--moovi-lavender-bg);color:var(--moovi-blue);flex:none}
.moovi-login .moovi-cert .ico svg{width:20px;height:20px}
.moovi-login .moovi-cert .label{font-weight:500;color:var(--moovi-blue);display:block;margin-bottom:2px}
.moovi-login .moovi-cert .help{color:var(--neutral-700)}

.moovi-login .moovi-help{text-align:center;margin-top:24px;font-size:13px;color:var(--neutral-700)}
.moovi-login .moovi-help a{color:var(--moovi-blue);text-decoration:none;font-weight:500}
.moovi-login .moovi-help a:hover{text-decoration:underline}

.moovi-login .moovi-footer{background:var(--moovi-black);color:#fff;padding:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:12px}
.moovi-login .moovi-footer a{color:#fff;text-decoration:none;opacity:.7;margin-left:18px}
.moovi-login .moovi-footer a:hover{opacity:1}
@media (max-width:600px){.moovi-login .moovi-title{font-size:36px}}

/* ===================  ÁREA PRIVADA  =================== */
.moovi-app{font-family:var(--moovi-font);font-weight:300;color:var(--moovi-black);background:transparent;-webkit-font-smoothing:antialiased;display:grid;grid-template-columns:var(--sidebar-w, 248px) 1fr;gap:16px;padding:16px;min-height:auto}

/* SIDEBAR — vertical flotante en desktop */
.moovi-app .sidebar{
  background:var(--moovi-black);
  color:#fff;
  display:flex;
  flex-direction:column;
  position:sticky;
  top:16px;
  height:auto;
  max-height:calc(100vh - 32px);
  border-radius:24px;
  box-shadow:0 16px 40px rgba(0,0,0,.18), 0 4px 12px rgba(0,0,0,.06);
  overflow:hidden;
}
/* Brand "Mi moovi" en la cabecera del sidebar */
.moovi-app .moovi-sidebar-brand{display:flex;align-items:center;padding:18px 20px 14px;color:#fff;border-bottom:1px solid #1a1a1a;flex:none}
.moovi-app .moovi-sidebar-brand-text{font-size:15px;font-weight:600;letter-spacing:.2px;color:#fff}

.moovi-app .sidebar .menu{display:flex;flex-direction:column;gap:2px;padding:18px 12px 12px;flex:1 1 auto;overflow-y:auto}
.moovi-app .sidebar .menu a{
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
  padding:11px 14px !important;
  color:#fff !important;
  text-decoration:none !important;
  font-family:var(--moovi-font) !important;
  font-size:13px !important;
  font-weight:500 !important;
  line-height:1 !important;
  border-radius:14px !important;
  background:transparent !important;
  text-shadow:none !important;
  transition:all .15s ease;
}
.moovi-app .sidebar .menu a svg{width:18px !important;height:18px !important;flex:none;opacity:.85}
.moovi-app .sidebar .menu a:hover{background:#171717 !important}
.moovi-app .sidebar .menu a.is-active{background:#F3F3F3 !important;color:var(--moovi-blue) !important;box-shadow:none !important}
.moovi-app .sidebar .menu a.is-active svg{opacity:1;color:var(--moovi-blue) !important}
.moovi-app .sidebar .footer{padding:14px;border-top:1px solid #1a1a1a;display:flex;flex-direction:column;gap:8px}
.moovi-app .sidebar .user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:14px}
.moovi-app .sidebar .footer button{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  background:transparent !important;
  color:#fff !important;
  border:1px solid #1f2024 !important;
  font-family:var(--moovi-font) !important;
  font-size:13px !important;
  font-weight:500 !important;
  padding:10px 14px !important;
  border-radius:9999px !important;
  cursor:pointer;
  text-shadow:none !important;
  box-shadow:none !important;
  transition:all .15s ease;
}
.moovi-app .sidebar .footer button:hover{background:#171717 !important;border-color:#33363c !important}
.moovi-app .sidebar .footer button svg{width:14px !important;height:14px !important;flex:none}
.moovi-app .sidebar .footer button .lbl{display:inline}

/* MÓVIL: sidebar se vuelve un topnav horizontal sticky negro (en flujo, sticky al scrollear) */
@media (max-width:760px){
  /* padding lateral 22px en móvil para tener un poco más de aire respecto a los bordes */
  .moovi-app{display:block !important;padding:0 22px !important;gap:0 !important;grid-template-columns:none !important}
  /* En mobile la barra es horizontal: brand a la izquierda compacto */
  .moovi-app .moovi-sidebar-brand{
    display:flex !important;
    border-bottom:0 !important;
    border-right:1px solid rgba(255,255,255,.08) !important;
    padding:0 12px 0 14px !important;
    margin-right:4px !important;
    flex:none !important;
  }
  .moovi-app .moovi-sidebar-brand-text{font-size:13px !important;white-space:nowrap}
  .moovi-app .sidebar{
    position:sticky !important;
    top:12px;
    left:auto !important;
    right:auto !important;
    bottom:auto !important;
    width:auto !important;
    height:auto !important;
    max-height:none !important;
    flex-direction:row !important;
    align-items:center;
    gap:8px;
    padding:6px;
    border-radius:20px;
    margin:18px 0 18px !important;  /* sin margen horizontal: el padding de .moovi-app ya da el inset */
    z-index:50;
    box-shadow:0 8px 24px rgba(0,0,0,.25), 0 2px 6px rgba(0,0,0,.12);
  }
  .moovi-app .sidebar .menu{
    flex-direction:row !important;
    flex:1 1 auto;
    padding:4px !important;
    gap:4px;
    overflow-x:auto !important;
    overflow-y:hidden !important;
    justify-content:flex-start !important;
    scroll-snap-type:x proximity;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    mask-image:linear-gradient(90deg, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
    -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
  }
  .moovi-app .sidebar .menu::-webkit-scrollbar{display:none !important}

  /* Icono compacto por defecto en mobile (no activos) */
  .moovi-app .sidebar .menu a{
    flex:0 0 auto !important;
    border-radius:9999px !important;
    padding:9px 11px !important;
    font-size:13px !important;
    font-weight:500 !important;
    justify-content:center !important;
    align-items:center !important;
    gap:7px !important;
    min-width:0;
    color:#fff !important;
    transition:background .2s ease, color .2s ease, padding .2s ease, max-width .25s ease !important;
    scroll-snap-align:center;
    white-space:nowrap;
    max-width:42px; /* solo cabe el icono */
    overflow:hidden;
  }
  .moovi-app .sidebar .menu a span{
    display:inline-block !important;
    opacity:0;
    max-width:0;
    overflow:hidden;
    transition:opacity .2s ease, max-width .25s ease;
    color:inherit !important;
  }
  .moovi-app .sidebar .menu a svg{width:18px !important;height:18px !important;opacity:.95;flex:none}

  /* Item activo: pill con icono + texto, fondo claro */
  .moovi-app .sidebar .menu a.is-active{
    background:#F3F3F3 !important;
    color:var(--moovi-blue) !important;
    box-shadow:none !important;
    padding:9px 16px !important;
    max-width:260px !important;
  }
  .moovi-app .sidebar .menu a.is-active span{
    opacity:1 !important;
    max-width:200px !important;
    margin-left:0 !important;
  }
  .moovi-app .sidebar .menu a.is-active svg{color:var(--moovi-blue) !important;opacity:1}
  .moovi-app .sidebar .footer{
    flex-direction:row !important;
    align-items:center;
    border-top:0 !important;
    border-left:0 !important;
    padding:0 4px 0 6px !important;
    gap:0;
    flex:0 0 auto;
  }
  /* En mobile escondemos avatar/nombre — la barra tiene poco espacio. El NIF ya
     no aporta y el avatar es decorativo. Dejamos solo el botón de logout. */
  .moovi-app .sidebar .footer .user{display:none !important}
  .moovi-app .sidebar .footer button{
    width:38px !important; height:38px !important;
    min-width:0 !important; max-width:38px !important;
    padding:0 !important;
    border-radius:50% !important;
    border-color:#2a2a2a !important;
    justify-content:center;
    flex:none;
  }
  .moovi-app .sidebar .footer button .lbl{display:none}
}

.moovi-app .mobile-header{display:none;position:sticky;top:0;z-index:40;background:var(--moovi-black);color:#fff;padding:12px 16px;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid #1a1a1a}
.moovi-app .mobile-header img{height:28px;width:auto;display:block}
.moovi-app .mobile-header .icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:transparent;border:1px solid #2a2a2a;color:#fff;cursor:pointer}
.moovi-app .mobile-header .icon-btn:active{background:#171717}
.moovi-app .mobile-header .icon-btn svg{width:20px;height:20px}
.moovi-app .mobile-header .right{display:flex;gap:8px}

.moovi-app .drawer-backdrop{display:none;position:fixed;inset:0;z-index:55;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);animation:mvfadein .2s ease}
.moovi-app.is-menu-open .drawer-backdrop{display:block}
@keyframes mvfadein{from{opacity:0}to{opacity:1}}

.moovi-app .bottom-tab{display:none;position:fixed;left:0;right:0;bottom:0;z-index:45;background:var(--moovi-black);color:#fff;padding:8px 8px calc(8px + env(safe-area-inset-bottom));justify-content:space-around;border-top:1px solid #1a1a1a}
.moovi-app .bottom-tab a{flex:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:3px;color:#fff;text-decoration:none;font-size:10px;font-weight:500;letter-spacing:.3px;padding:8px 4px;border-radius:var(--r-md);transition:all .15s ease;position:relative;opacity:.7}
.moovi-app .bottom-tab a svg{width:22px;height:22px}
.moovi-app .bottom-tab a.is-active{opacity:1;color:#fff}
.moovi-app .bottom-tab a.is-active::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:32px;height:3px;border-radius:0 0 4px 4px;background:var(--moovi-blue)}

.moovi-app .sidebar{
  background:var(--moovi-black);
  color:#fff;
  display:flex;
  flex-direction:column;
  position:sticky;
  top:16px;
  height:auto;
  max-height:calc(100vh - 32px);
  border:0;
  border-right:0 !important;
  border-radius:24px;
  box-shadow:0 16px 40px rgba(0,0,0,.18), 0 4px 12px rgba(0,0,0,.06);
  overflow:hidden;
}
.moovi-app .sidebar .brand{display:none} /* sin logo: el header del tema ya lo trae */
.moovi-app .sidebar .brand img{height:32px;width:auto;display:block}
.moovi-app .sidebar .menu{display:flex;flex-direction:column;gap:2px;padding:18px 12px 12px;flex:1 1 auto;overflow-y:auto}
.moovi-app .sidebar .menu a{display:flex;align-items:center;gap:12px;padding:11px 14px;color:#fff;text-decoration:none;font-size:13px;font-weight:500;border-radius:var(--r-md);transition:all .15s ease}
.moovi-app .sidebar .menu a svg{width:18px;height:18px;flex:none;opacity:.85}
.moovi-app .sidebar .menu a:hover{background:#171717}
.moovi-app .sidebar .menu a.is-active{background:var(--moovi-blue);color:#fff}
.moovi-app .sidebar .footer{padding:14px;border-top:1px solid #1a1a1a;display:flex;flex-direction:column;gap:8px}
.moovi-app .sidebar .user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-md)}
.moovi-app .sidebar .user .avatar{width:32px;height:32px;border-radius:50%;background:var(--moovi-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex:none}
.moovi-app .sidebar .user .who{font-size:12px;line-height:1.3}
.moovi-app .sidebar .user .who strong{font-weight:600;font-size:13px;display:block}
.moovi-app .sidebar .user .who span{color:#8a929b}
.moovi-app .sidebar .footer button{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;border:1px solid #1f2024;font-family:inherit;font-size:13px;font-weight:500;padding:10px 14px;border-radius:var(--r-pill);cursor:pointer;transition:all .15s ease}
.moovi-app .sidebar .footer button:hover{background:#171717;border-color:#33363c}
.moovi-app .sidebar .footer button svg{width:14px;height:14px}

.moovi-app .main{background:transparent;padding:0 8px 32px;min-width:0}
.moovi-app .topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:12px;flex-wrap:wrap}
.moovi-app .topbar .breadcrumb{display:flex;align-items:center;gap:8px;color:var(--neutral-500);font-size:13px;font-weight:400}
.moovi-app .topbar .breadcrumb strong{color:var(--moovi-black);font-weight:600}
.moovi-app .topbar .actions{display:flex;align-items:center;gap:10px}
.moovi-app .topbar .lang{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--neutral-300);border-radius:var(--r-pill);padding:6px 14px;font-size:13px;cursor:pointer;font-family:inherit}
.moovi-app .topbar .lang svg{width:12px;height:12px}
.moovi-app .topbar .help{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1.5px solid var(--moovi-blue);color:var(--moovi-blue);border-radius:var(--r-pill);padding:8px 16px;font-size:13px;font-weight:500;text-decoration:none}
.moovi-app .topbar .help:hover{background:var(--moovi-blue);color:#fff}

.moovi-app .page-hero{background:linear-gradient(135deg, var(--moovi-blue) 0%, var(--moovi-blue) 55%, var(--moovi-black) 100%) !important;color:#fff !important;border-radius:var(--r-lg) !important;padding:32px !important;margin:0 !important;position:relative;overflow:hidden}
.moovi-app .page-hero::after{display:none}
.moovi-app .page-hero h1,
.moovi-app .page-hero h2{margin:0 0 8px !important;font-size:36px !important;font-weight:600 !important;letter-spacing:-1.5px !important;line-height:1.05 !important;color:#fff !important;text-shadow:none !important}
.moovi-app .page-hero p{margin:0 !important;font-size:15px !important;font-weight:300 !important;opacity:.9 !important;color:#fff !important;line-height:1.5 !important}
.moovi-app .page-hero .hashtag{display:inline-block !important;font-size:13px !important;font-weight:600 !important;background:rgba(255,255,255,.18) !important;color:#fff !important;padding:4px 12px !important;border-radius:var(--r-pill) !important;margin:0 0 14px !important;letter-spacing:0 !important;text-transform:none !important}

.moovi-app .page-title{display:flex;align-items:center;justify-content:space-between;margin:8px 0 24px;gap:12px;flex-wrap:wrap}
.moovi-app .page-title h1,
.moovi-app .page-title h2{margin:0 !important;font-size:32px !important;font-weight:600 !important;letter-spacing:-1px !important;color:var(--moovi-blue) !important;line-height:1.1 !important}
.moovi-app .page-title .meta{font-size:13px;color:var(--neutral-700)}

.moovi-app .card{background:#fff;border:1px solid var(--neutral-300);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-card)}
.moovi-app .card .card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.moovi-app .card .card-header h2{margin:0;font-size:14px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--moovi-blue)}
.moovi-app .pill{display:inline-block;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:var(--r-pill);background:var(--moovi-lavender-bg);color:var(--moovi-blue)}

.moovi-app .grid{display:grid;gap:16px}
.moovi-app .grid-2{grid-template-columns:repeat(2,1fr)}
.moovi-app .grid-3{grid-template-columns:repeat(3,1fr)}
.moovi-app .grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:880px){.moovi-app .grid-3,.moovi-app .grid-4{grid-template-columns:repeat(2,1fr)}}

.moovi-app .kpi{background:#fff !important;border:1px solid var(--neutral-300) !important;border-radius:var(--r-lg) !important;padding:20px !important;box-shadow:var(--shadow-card);position:relative;overflow:hidden;color:var(--moovi-black) !important;margin:0 !important;display:block !important}
.moovi-app a.kpi,
.moovi-app .kpi-link{text-decoration:none !important;color:var(--moovi-black) !important;cursor:pointer !important;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease}
.moovi-app a.kpi:hover,
.moovi-app .kpi-link:hover{transform:translateY(-2px) !important;box-shadow:0 10px 24px rgba(0,30,228,.10) !important;border-color:var(--moovi-blue) !important}
.moovi-app a.kpi:focus-visible,
.moovi-app .kpi-link:focus-visible{outline:none !important;box-shadow:0 0 0 3px rgba(0,30,228,.18) !important;border-color:var(--moovi-blue) !important}
.moovi-app .kpi .label{font-size:11px !important;font-weight:600 !important;letter-spacing:1.2px !important;text-transform:uppercase !important;opacity:.85 !important;margin:0 0 8px !important;color:inherit !important;line-height:1.2 !important}
.moovi-app .kpi .value{font-size:32px !important;font-weight:600 !important;letter-spacing:-1px !important;line-height:1.05 !important;margin:0 0 8px !important;color:inherit !important;font-family:var(--moovi-font) !important}
.moovi-app .kpi .meta{font-size:12px !important;opacity:.8 !important;color:inherit !important;line-height:1.4 !important}
.moovi-app .kpi .progress{height:6px;background:var(--neutral-150);border-radius:var(--r-pill);margin-top:12px;overflow:hidden}
.moovi-app .kpi .progress > span{display:block;height:100%;background:var(--moovi-blue);border-radius:var(--r-pill)}

.moovi-app .field-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media (max-width:680px){.moovi-app .field-grid{grid-template-columns:1fr}}

/* Tag pequeño dentro de la label del KPI (p.ej. "estimada") */
.moovi-app .kpi .moovi-kpi-tag{display:inline-block;margin-left:6px;padding:1px 7px;background:var(--moovi-lavender-bg);color:var(--moovi-blue);border-radius:9999px;font-size:9px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;vertical-align:middle}

/* Bloque "Tus líneas" en el dashboard */
.moovi-app .moovi-lines-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media (max-width:680px){.moovi-app .moovi-lines-list{grid-template-columns:1fr}}
.moovi-app .moovi-line-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--neutral-300);border-radius:14px;background:#fff;transition:border-color .15s ease, box-shadow .15s ease}
.moovi-app .moovi-line-item:hover{border-color:var(--moovi-blue);box-shadow:0 4px 14px rgba(0,30,228,.08)}
.moovi-app .moovi-line-icon{width:36px;height:36px;border-radius:50%;background:var(--moovi-lavender-bg);color:var(--moovi-blue);display:flex;align-items:center;justify-content:center;flex:none}
.moovi-app .moovi-line-icon svg{width:16px;height:16px}
.moovi-app .moovi-line-body{display:flex;flex-direction:column;line-height:1.3;flex:1;min-width:0}
.moovi-app .moovi-line-body strong{font-size:13px;color:var(--moovi-black);font-weight:600}
.moovi-app .moovi-line-tel{font-size:14px;color:var(--moovi-blue);font-weight:600;letter-spacing:.3px}
.moovi-app .moovi-line-tarifa{font-size:11px;color:var(--neutral-500);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Precio en tabla de Contratos: precio actual + tachado original + IVA + descuento */
.moovi-app .moovi-precio-tachado{display:inline-block;font-size:11px;color:var(--neutral-500);text-decoration:line-through;margin-right:6px;font-weight:400}
.moovi-app .moovi-precio-final{font-weight:600;color:var(--moovi-black);font-size:14px}
.moovi-app .moovi-precio-desc{display:inline-block;margin-left:6px;padding:2px 7px;background:#FFF4DC;color:#9A6500;border-radius:9999px;font-size:10px;font-weight:600;letter-spacing:.4px;vertical-align:middle}
.moovi-app .moovi-precio-iva{display:block;font-size:10px;color:var(--neutral-500);font-weight:400;letter-spacing:.4px;margin-top:1px}
/* Badge "Pack" junto a la tarifa */
.moovi-app .moovi-pack-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:var(--moovi-lavender-bg);color:var(--moovi-blue);border-radius:9999px;font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;vertical-align:middle}
.moovi-app .field{display:flex;flex-direction:column;gap:4px}
.moovi-app .field label{font-size:12px;font-weight:500;color:var(--neutral-700)}
.moovi-app .field .v{font-size:14px;font-weight:500;color:var(--moovi-black);background:var(--neutral-50);border:1px solid var(--neutral-300);border-radius:var(--r-sm);padding:10px 12px}
.moovi-app .field input,.moovi-app .field select{font-family:inherit;font-size:14px;font-weight:400;color:var(--moovi-black);background:#fff;border:1.5px solid var(--neutral-300);border-radius:var(--r-sm);padding:10px 12px;transition:all .15s ease}
.moovi-app .field input:focus,.moovi-app .field select:focus{outline:none;border-color:var(--moovi-blue);box-shadow:0 0 0 3px rgba(0,30,228,.12)}

.moovi-app .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-weight:500;font-size:14px;background:var(--moovi-black);color:#fff;border:0;cursor:pointer;padding:11px 20px;border-radius:var(--r-pill);text-decoration:none;transition:all .15s ease}
.moovi-app .btn:hover{background:var(--moovi-blue);transform:translateY(-1px);box-shadow:0 8px 20px rgba(0,30,228,.2)}
.moovi-app .btn .arrow{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.18)}
.moovi-app .btn .arrow svg{width:10px;height:10px}
.moovi-app .btn-secondary{background:#fff;color:var(--moovi-blue);border:1.5px solid var(--moovi-blue)}
.moovi-app .btn-secondary:hover{background:var(--moovi-blue);color:#fff}
.moovi-app .btn-ghost{background:transparent;color:var(--moovi-blue);padding:8px 14px;font-weight:500}
.moovi-app .btn-ghost:hover{background:var(--moovi-lavender-bg);transform:none;box-shadow:none}
.moovi-app .btn-sm{padding:8px 14px;font-size:13px}

.moovi-app .table-wrap{overflow-x:auto}
.moovi-app .tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
.moovi-app .tbl thead th{text-align:left;font-weight:600;color:var(--neutral-700);font-size:11px;letter-spacing:1.2px;text-transform:uppercase;background:var(--neutral-50);padding:12px 14px;border-bottom:1px solid var(--neutral-300);white-space:nowrap}
.moovi-app .tbl tbody td{padding:14px;border-bottom:1px solid var(--neutral-150);color:var(--moovi-black);font-weight:400;vertical-align:middle}
.moovi-app .tbl tbody tr:hover{background:var(--moovi-lavender-bg)}
.moovi-app .tbl tbody tr:last-child td{border-bottom:0}
.moovi-app .tbl .num{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}
.moovi-app .tbl .actions-cell{text-align:right;white-space:nowrap}
.moovi-app .tbl .icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--neutral-50);color:var(--moovi-blue);border:0;cursor:pointer;margin-left:4px;transition:all .15s ease}
.moovi-app .tbl .icon-btn:hover{background:var(--moovi-blue);color:#fff}
.moovi-app .tbl .icon-btn svg{width:14px;height:14px}
.moovi-app .tbl .moovi-dl{display:inline-flex !important;align-items:center !important;gap:6px !important;padding:6px 12px !important;font-size:12px !important;font-weight:500 !important;line-height:1 !important;border-radius:9999px !important;height:auto !important}
.moovi-app .tbl .moovi-dl svg{width:13px !important;height:13px !important;flex:none !important}

.moovi-app .badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;border-radius:var(--r-pill)}
.moovi-app .badge-success{background:#E6F6F0;color:var(--success)}
.moovi-app .badge-warning{background:#FFF4DC;color:#9A6500}
.moovi-app .badge-error{background:#FCE6EE;color:var(--error)}
.moovi-app .badge-blue{background:var(--moovi-lavender-bg);color:var(--moovi-blue)}
.moovi-app .badge-neutral{background:var(--neutral-50);color:var(--neutral-700);border:1px solid var(--neutral-300)}

.moovi-app .filterbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}
.moovi-app .filterbar .pill-select{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--neutral-300);padding:8px 14px;border-radius:var(--r-pill);font-size:13px;cursor:pointer;position:relative;transition:border-color .15s ease, box-shadow .15s ease}
.moovi-app .filterbar .pill-select:hover{border-color:var(--moovi-blue)}
.moovi-app .filterbar .pill-select:focus-within{border-color:var(--moovi-blue);box-shadow:0 0 0 3px rgba(0,30,228,.12)}
.moovi-app .filterbar .pill-select .pill-label{color:var(--neutral-700);font-weight:400;pointer-events:none}
.moovi-app .filterbar .pill-select select{
  border:0 !important;
  background:transparent !important;
  font-family:inherit !important;
  font-size:13px !important;
  font-weight:500 !important;
  color:var(--moovi-blue) !important;
  cursor:pointer !important;
  outline:none !important;
  appearance:none !important;
  -webkit-appearance:none !important;
  -moz-appearance:none !important;
  padding:0 4px !important;
  margin:0 !important;
  background-image:none !important; /* anula el chevron nativo */
  text-shadow:none !important;
  box-shadow:none !important;
  height:auto !important;
  line-height:1.2 !important;
  min-width:90px !important;
}
.moovi-app .filterbar .pill-select svg{
  width:12px !important;
  height:12px !important;
  color:var(--moovi-blue) !important;
  flex:none !important;
  pointer-events:none;
  opacity:.7;
}

.moovi-app .view{display:none}
.moovi-app .view.is-visible{
  display:flex !important;
  flex-direction:column !important;
  gap:20px !important;
  animation:mvfade .25s ease;
}
@keyframes mvfade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

.moovi-app .alert{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border-radius:var(--r-md);margin-bottom:16px}
.moovi-app .alert .ico{width:32px;height:32px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center}
.moovi-app .alert .ico svg{width:16px;height:16px}
.moovi-app .alert h4{margin:0 0 4px;font-size:14px;font-weight:600}
.moovi-app .alert p{margin:0;font-size:13px;color:var(--neutral-700)}
.moovi-app .alert-blue{background:var(--moovi-lavender-bg);color:var(--moovi-blue)}
.moovi-app .alert-blue .ico{background:var(--moovi-blue);color:#fff}
.moovi-app .alert-warning{background:#FFF7E6}
.moovi-app .alert-warning .ico{background:var(--warning);color:#fff}

.moovi-app .invoice-feature{background:linear-gradient(135deg, var(--moovi-blue) 0%, var(--moovi-blue) 55%, var(--moovi-black) 100%);color:#fff;border-radius:var(--r-lg);padding:24px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px;margin-bottom:16px}
@media (max-width:600px){.moovi-app .invoice-feature{grid-template-columns:1fr}}
.moovi-app .invoice-feature .label{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;opacity:.85}
.moovi-app .invoice-feature .amount{font-size:42px;font-weight:600;letter-spacing:-1.5px;line-height:1;margin-top:4px}
.moovi-app .invoice-feature .meta{font-size:13px;opacity:.85;margin-top:4px}
.moovi-app .invoice-feature .actions{display:flex;gap:10px;flex-wrap:wrap}
.moovi-app .invoice-feature .btn{background:#fff;color:var(--moovi-blue)}
.moovi-app .invoice-feature .btn:hover{background:var(--moovi-black);color:#fff}

.moovi-app .usage-card{background:#fff;border:1px solid var(--neutral-300);border-radius:var(--r-lg);padding:20px}
.moovi-app .usage-card .head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.moovi-app .usage-card .head h3{margin:0;font-size:13px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--moovi-blue)}
.moovi-app .usage-card .head .total{font-size:22px;font-weight:600;letter-spacing:-1px;color:var(--moovi-black)}
.moovi-app .usage-bar{height:14px;border-radius:var(--r-pill);background:var(--neutral-150);overflow:hidden;margin-bottom:8px}
.moovi-app .usage-bar > span{display:block;height:100%;background:linear-gradient(90deg, var(--moovi-blue), var(--moovi-violet));border-radius:var(--r-pill)}
.moovi-app .usage-card.unlimited .usage-bar > span,
.moovi-app .usage-card.is-unlimited .usage-bar > span,
.moovi-app .usage-bar--ilim > span{background:linear-gradient(90deg, var(--moovi-mint), var(--moovi-blue), var(--moovi-violet)) !important;background-size:200% 100% !important;animation:moovi-bar-flow 4s linear infinite}
@keyframes moovi-bar-flow{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.moovi-app .usage-card .legend{display:flex;justify-content:space-between;font-size:12px;color:var(--neutral-700)}

.moovi-app .demo-banner{background:#FFF4DC;color:#9A6500;border-radius:var(--r-md);padding:8px 14px;font-size:12px;margin-bottom:14px;border:1px solid #f0d597}
.moovi-app .skeleton{display:block;background:linear-gradient(90deg,#eee 0%,#f6f6f6 50%,#eee 100%);background-size:200% 100%;animation:mvskel 1.4s infinite;border-radius:var(--r-sm);height:14px;margin:6px 0}
@keyframes mvskel{0%{background-position:200% 0}100%{background-position:-200% 0}}

.moovi-app .app-footer{text-align:center;font-size:12px;color:var(--neutral-500);padding:24px 16px}

/* MOBILE area privada (rules complementarias al bloque mobile principal — ya no hay drawer ni bottom-tab) */
@media (max-width:760px){
  .moovi-app .topbar{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:16px}
  .moovi-app .topbar .actions{width:100%;justify-content:space-between}
  .moovi-app .page-hero{padding:24px;border-radius:var(--r-md)}
  .moovi-app .page-hero h1{font-size:28px;letter-spacing:-1px}
  .moovi-app .page-hero p{font-size:14px}
  .moovi-app .page-title h1{font-size:24px}
  .moovi-app .main{padding:16px 16px calc(96px + env(safe-area-inset-bottom))}
  .moovi-app .card{padding:18px;border-radius:var(--r-md)}
  .moovi-app .grid-2,.moovi-app .grid-3,.moovi-app .grid-4{grid-template-columns:1fr !important;gap:12px}
  .moovi-app .page-title{flex-direction:column;align-items:stretch;gap:8px}
  .moovi-app .filterbar{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .moovi-app .filterbar::-webkit-scrollbar{display:none}
  .moovi-app .filterbar .pill-select{flex:0 0 auto}
  .moovi-app .invoice-feature{padding:20px;grid-template-columns:1fr}
  .moovi-app .invoice-feature .amount{font-size:36px}
  .moovi-app .invoice-feature .actions{flex-direction:column}
  .moovi-app .invoice-feature .actions .btn{width:100%}
  .moovi-app .tbl,.moovi-app .tbl thead,.moovi-app .tbl tbody,.moovi-app .tbl tr,.moovi-app .tbl th,.moovi-app .tbl td{display:block}
  .moovi-app .tbl thead{display:none}
  .moovi-app .tbl tbody tr{border:1px solid var(--neutral-300);border-radius:var(--r-md);padding:12px 14px;margin-bottom:10px;background:#fff}
  .moovi-app .tbl tbody tr:hover{background:#fff}
  .moovi-app .tbl tbody td{padding:6px 0;border-bottom:0;display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:13px}
  .moovi-app .tbl tbody td::before{content:attr(data-label);font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--neutral-500);flex:0 0 auto}
  .moovi-app .tbl .num{text-align:right}
  .moovi-app .tbl .actions-cell{justify-content:flex-end !important;margin-top:4px;padding-top:10px;border-top:1px dashed var(--neutral-150) !important}
  .moovi-app .tbl .actions-cell::before{display:none}
}
@media (max-width:1100px) and (min-width:761px){
  .moovi-app{--sidebar-w:72px}
  .moovi-app .sidebar .brand{padding:18px 12px 12px;display:flex;justify-content:center}
  .moovi-app .sidebar .brand img{height:24px}
  .moovi-app .sidebar .menu{padding:8px}
  .moovi-app .sidebar .menu a{justify-content:center;padding:12px}
  .moovi-app .sidebar .menu a span{display:none}
  .moovi-app .sidebar .footer .who,.moovi-app .sidebar .footer button .lbl{display:none}
  .moovi-app .sidebar .footer .user{justify-content:center}
  .moovi-app .sidebar .footer button{justify-content:center;padding:10px;border-radius:50%;width:40px;height:40px;align-self:center}
}

/* Mensajes informativos genéricos */
.moovi-info{padding:24px;background:var(--moovi-lavender-bg);border:1px solid var(--moovi-lavender);border-radius:var(--r-lg);text-align:center;font-family:var(--moovi-font);color:var(--moovi-blue);font-weight:500}
.moovi-info a{color:var(--moovi-blue);font-weight:600;text-decoration:underline}

/* ===================================================
   OVERRIDES AGRESIVOS contra Elementor + tema moovi
   =================================================== */
.moovi-app, .moovi-app *{font-family:var(--moovi-font) !important}
.moovi-app .card{background:#fff !important;border:1px solid var(--neutral-300) !important;border-radius:var(--r-lg) !important;padding:24px !important;box-shadow:var(--shadow-card) !important;color:var(--moovi-black) !important;margin:0 !important}
.moovi-app .card h1, .moovi-app .card h2, .moovi-app .card h3, .moovi-app .card h4{margin:0 !important;font-family:var(--moovi-font) !important;text-shadow:none !important}
.moovi-app .card .card-header{display:flex !important;align-items:center !important;justify-content:space-between !important;margin:0 0 18px !important;gap:12px;flex-wrap:wrap}
.moovi-app .card .card-header h2{font-size:14px !important;font-weight:600 !important;letter-spacing:1.2px !important;text-transform:uppercase !important;color:var(--moovi-blue) !important;line-height:1.2 !important}
.moovi-app .pill{display:inline-block !important;font-size:11px !important;font-weight:600 !important;letter-spacing:1px !important;text-transform:uppercase !important;padding:4px 10px !important;border-radius:var(--r-pill) !important;background:var(--moovi-lavender-bg) !important;color:var(--moovi-blue) !important;line-height:1.2 !important;border:0 !important}

/* Hero "Hola, …" — refuerza override */
.moovi-app .page-hero,
.moovi-app section .page-hero{background:linear-gradient(135deg, var(--moovi-blue) 0%, var(--moovi-blue) 55%, var(--moovi-black) 100%) !important;padding:24px !important;margin:0 !important}
.moovi-app .page-hero h1{font-size:30px !important}
.moovi-app .page-hero, .moovi-app .page-hero *{color:#fff !important}
.moovi-app .page-hero .hashtag{background:rgba(255,255,255,.2) !important;color:#fff !important}
.moovi-app .grid{gap:14px !important;margin:0 !important}
/* === Hijos directos del .view sin margins propios — los gestiona el flex gap === */
.moovi-app .view.is-visible > *{margin:0 !important}
.moovi-app .card{padding:20px !important;margin:0 !important}
.moovi-app .card .card-header{margin:0 0 14px !important}
.moovi-app .kpi{padding:18px !important}
.moovi-app .kpi .value{font-size:28px !important}

/* Invoice feature destacada */
.moovi-app .invoice-feature{background:linear-gradient(135deg, var(--moovi-blue) 0%, var(--moovi-blue) 55%, var(--moovi-black) 100%) !important;color:#fff !important;border-radius:var(--r-lg) !important;padding:24px !important;margin:0 !important;display:grid !important;grid-template-columns:1fr auto !important;align-items:center;gap:16px}
.moovi-app .invoice-feature, .moovi-app .invoice-feature *{color:#fff !important}
.moovi-app .invoice-feature .label{font-size:12px !important;font-weight:600 !important;letter-spacing:1px !important;text-transform:uppercase !important;opacity:.85 !important;margin:0 !important}
.moovi-app .invoice-feature .amount{font-size:42px !important;font-weight:600 !important;letter-spacing:-1.5px !important;line-height:1 !important;margin:4px 0 !important}
.moovi-app .invoice-feature .meta{font-size:13px !important;opacity:.85 !important;margin:0 !important;font-weight:400 !important}
.moovi-app .invoice-feature .btn{background:#fff !important;color:var(--moovi-blue) !important}
.moovi-app .invoice-feature .btn:hover{background:var(--moovi-black) !important;color:#fff !important}

/* Botones del área — neutralizamos el botón global del tema */
.moovi-app .btn{display:inline-flex !important;align-items:center !important;justify-content:center !important;gap:8px !important;font-family:var(--moovi-font) !important;font-weight:500 !important;font-size:14px !important;line-height:1 !important;background:var(--moovi-black) !important;color:#fff !important;border:0 !important;cursor:pointer !important;padding:11px 20px !important;border-radius:var(--r-pill) !important;text-decoration:none !important;text-shadow:none !important;text-transform:none !important;letter-spacing:0 !important;box-shadow:0 4px 12px rgba(0,0,0,.08) !important;transition:all .15s ease !important;width:auto}
.moovi-app .btn:hover{background:var(--moovi-blue) !important;transform:translateY(-1px) !important;box-shadow:0 8px 20px rgba(0,30,228,.2) !important;color:#fff !important}
.moovi-app .btn .arrow{display:inline-flex !important;align-items:center !important;justify-content:center !important;width:20px !important;height:20px !important;border-radius:50% !important;background:rgba(255,255,255,.2) !important}
.moovi-app .btn .arrow svg{width:10px;height:10px}
.moovi-app .btn-secondary{background:#fff !important;color:var(--moovi-blue) !important;border:1.5px solid var(--moovi-blue) !important;box-shadow:none !important}
.moovi-app .btn-secondary:hover{background:var(--moovi-blue) !important;color:#fff !important}

/* Tablas — algunos temas las pintan agresivamente */
.moovi-app .tbl, .moovi-app .tbl tbody, .moovi-app .tbl thead, .moovi-app .tbl tr, .moovi-app .tbl td, .moovi-app .tbl th{background:transparent;border:0;font-family:var(--moovi-font) !important}
.moovi-app .tbl{width:100% !important;border-collapse:separate !important;border-spacing:0 !important;font-size:13px !important}
.moovi-app .tbl thead th{text-align:left !important;font-weight:600 !important;color:var(--neutral-700) !important;font-size:11px !important;letter-spacing:1.2px !important;text-transform:uppercase !important;background:var(--neutral-50) !important;padding:12px 14px !important;border-bottom:1px solid var(--neutral-300) !important;white-space:nowrap}
.moovi-app .tbl tbody td{padding:14px !important;border-bottom:1px solid var(--neutral-150) !important;color:var(--moovi-black) !important;font-weight:400 !important;vertical-align:middle}

/* Badges del listado — algunos temas redondean inputs/spans */
.moovi-app .badge{display:inline-block !important;font-size:11px !important;font-weight:600 !important;letter-spacing:.5px !important;padding:4px 10px !important;border-radius:var(--r-pill) !important;line-height:1.2 !important;border:0 !important;text-transform:none !important}
.moovi-app .badge-success{background:#E6F6F0 !important;color:var(--success) !important}
.moovi-app .badge-warning{background:#FFF4DC !important;color:#9A6500 !important}
.moovi-app .badge-error{background:#FCE6EE !important;color:var(--error) !important}
.moovi-app .badge-blue{background:var(--moovi-lavender-bg) !important;color:var(--moovi-blue) !important}
.moovi-app .badge-neutral{background:var(--neutral-50) !important;color:var(--neutral-700) !important;border:1px solid var(--neutral-300) !important}

/* Alerts */
.moovi-app .alert{display:flex !important;gap:12px !important;align-items:flex-start !important;padding:14px 16px !important;border-radius:var(--r-md) !important;margin:0 !important}
.moovi-app .alert h4{margin:0 0 4px !important;font-size:14px !important;font-weight:600 !important;color:inherit !important}
.moovi-app .alert p{margin:0 !important;font-size:13px !important;color:var(--neutral-700) !important}
.moovi-app .alert-blue{background:var(--moovi-lavender-bg) !important;color:var(--moovi-blue) !important}
.moovi-app .alert-blue h4{color:var(--moovi-blue) !important}
.moovi-app .alert-blue .ico{background:var(--moovi-blue) !important;color:#fff !important}
.moovi-app .alert-warning{background:#FFF7E6 !important}
.moovi-app .alert-warning .ico{background:var(--warning) !important;color:#fff !important}

/* Topbar interna */
.moovi-app .topbar .help{display:inline-flex !important;align-items:center !important;gap:6px !important;background:#fff !important;border:1.5px solid var(--moovi-blue) !important;color:var(--moovi-blue) !important;border-radius:var(--r-pill) !important;padding:8px 16px !important;font-size:13px !important;font-weight:500 !important;text-decoration:none !important}
.moovi-app .topbar .help:hover{background:var(--moovi-blue) !important;color:#fff !important}
.moovi-app .breadcrumb, .moovi-app .breadcrumb *{color:var(--neutral-500) !important;font-size:13px !important}
.moovi-app .breadcrumb strong{color:var(--moovi-black) !important;font-weight:600 !important}

/* Field grid en Mis datos */
.moovi-app .field label{font-size:12px !important;font-weight:500 !important;color:var(--neutral-700) !important;margin:0 !important}
.moovi-app .field .v{font-size:14px !important;font-weight:500 !important;color:var(--moovi-black) !important;background:var(--neutral-50) !important;border:1px solid var(--neutral-300) !important;border-radius:var(--r-sm) !important;padding:10px 12px !important;line-height:1.4 !important}

/* Usage cards */
.moovi-app .usage-card{background:#fff !important;border:1px solid var(--neutral-300) !important;border-radius:var(--r-lg) !important;padding:20px !important;margin:0 !important}
.moovi-app .usage-card h3{margin:0 !important;font-size:13px !important;font-weight:600 !important;letter-spacing:1.2px !important;text-transform:uppercase !important;color:var(--moovi-blue) !important}
.moovi-app .usage-card .total{font-size:22px !important;font-weight:600 !important;letter-spacing:-1px !important;color:var(--moovi-black) !important;line-height:1.2 !important}
.moovi-app .usage-card .legend{font-size:12px !important;color:var(--neutral-700) !important}

/* App footer (zona contenido del plugin) */
.moovi-app .app-footer{text-align:center !important;font-size:12px !important;color:var(--neutral-500) !important;padding:24px 16px !important;background:transparent !important}
.moovi-app .app-footer a{color:inherit !important}

/* Demo banner */
.moovi-app .demo-banner{background:#FFF4DC !important;color:#9A6500 !important;border-radius:var(--r-md) !important;padding:8px 14px !important;font-size:12px !important;margin:0 !important;border:1px solid #f0d597 !important}

/* Gráfica mensual de consumo — compacta */
.moovi-app .moovi-chart{display:block}
.moovi-app .moovi-chart-head{display:flex;justify-content:space-between;align-items:center;margin:0 0 10px;flex-wrap:wrap;gap:8px}
.moovi-app .moovi-chart-tabs{display:inline-flex;gap:2px;background:var(--neutral-100);padding:3px;border-radius:9999px}
.moovi-app .moovi-chart-tabs button{
  background:transparent !important;
  border:0 !important;
  padding:5px 12px !important;
  border-radius:9999px !important;
  font-family:var(--moovi-font) !important;
  font-size:11px !important;
  font-weight:600 !important;
  color:var(--neutral-700) !important;
  cursor:pointer !important;
  text-shadow:none !important;
  box-shadow:none !important;
  line-height:1 !important;
  width:auto !important; min-width:0 !important;
}
.moovi-app .moovi-chart-tabs button:hover{color:var(--moovi-blue) !important}
.moovi-app .moovi-chart-tabs button.is-active{background:#fff !important;color:var(--moovi-blue) !important;box-shadow:0 2px 6px rgba(0,30,228,.12) !important}
.moovi-app .moovi-chart-max{font-size:11px;color:var(--neutral-700);letter-spacing:.3px}
.moovi-app .moovi-chart-max strong{font-weight:600;color:var(--moovi-blue);margin-left:4px}
.moovi-app .moovi-chart-svg{width:100%;max-height:140px;height:auto;display:block}
.moovi-app .moovi-chart-svg rect{transition:opacity .15s ease}
.moovi-app .moovi-chart-svg rect:hover{opacity:.85;cursor:pointer}
/* La card que contiene la gráfica con padding más justo */
.moovi-app .card:has(.moovi-chart){padding:16px !important}
@media (max-width:760px){
  .moovi-app .moovi-chart-svg{max-height:120px}
  .moovi-app .moovi-chart-tabs button{padding:4px 10px !important;font-size:10px !important}
}

/* Vista de Solicitudes — botones tipo card */
.moovi-app .moovi-sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
@media (max-width:980px){.moovi-app .moovi-sol-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.moovi-app .moovi-sol-grid{grid-template-columns:1fr}}

.moovi-app .moovi-sol-card{
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
  text-align:left !important;
  padding:14px !important;
  padding-right:40px !important;        /* hueco para que la flecha no choque con el texto */
  border:1.5px solid var(--neutral-300) !important;
  border-radius:var(--r-md) !important;
  background:#fff !important;
  cursor:pointer !important;
  font-family:var(--moovi-font) !important;
  color:var(--moovi-black) !important;
  transition:all .18s ease !important;
  width:100% !important;min-width:0;
  box-shadow:none !important;
  text-shadow:none !important;
  position:relative;
  overflow:hidden;
}
.moovi-app .moovi-sol-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;overflow:hidden}
.moovi-app .moovi-sol-card-body strong,
.moovi-app .moovi-sol-card-body span{
  display:block !important;
  white-space:normal !important;
  overflow-wrap:anywhere !important;
  word-break:break-word !important;
}
.moovi-app .moovi-sol-card-body strong{font-size:13px !important;font-weight:600 !important;color:var(--moovi-black) !important;line-height:1.25 !important}
.moovi-app .moovi-sol-card-body span{font-size:11.5px !important;color:var(--neutral-700) !important;line-height:1.35 !important}
.moovi-app .moovi-sol-card-arrow{
  position:absolute !important;
  right:10px;top:50%;transform:translateY(-50%);
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:var(--neutral-50);color:var(--moovi-blue);
  flex:none;transition:all .18s ease;
}
.moovi-app .moovi-sol-card:hover .moovi-sol-card-arrow{background:var(--moovi-blue);color:#fff;transform:translateY(-50%) translateX(2px)}
.moovi-app .moovi-sol-card-arrow svg{width:9px;height:9px}
.moovi-app .moovi-sol-card:hover{
  border-color:var(--moovi-blue) !important;
  background:var(--moovi-lavender-bg) !important;
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(0,30,228,.12) !important;
}
.moovi-app .moovi-sol-card[disabled]{opacity:.5;cursor:not-allowed}
.moovi-app .moovi-sol-card-ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  background:var(--moovi-lavender-bg);color:var(--moovi-blue);
  flex:none;
  transition:all .18s ease;
}
.moovi-app .moovi-sol-card:hover .moovi-sol-card-ico{background:var(--moovi-blue);color:#fff}
.moovi-app .moovi-sol-card-ico svg{width:18px;height:18px}

/* Estado: enviando */
.moovi-app .moovi-sol-card.is-sending{background:var(--moovi-blue) !important;border-color:var(--moovi-blue) !important;justify-content:center !important;color:#fff !important}
.moovi-app .moovi-sol-card-loader{
  display:inline-block;width:14px;height:14px;border-radius:50%;
  border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  animation:mvspin .7s linear infinite;
}
@keyframes mvspin{to{transform:rotate(360deg)}}
/* Estado: enviado OK */
.moovi-app .moovi-sol-card.is-success{background:var(--success) !important;border-color:var(--success) !important;justify-content:center !important;color:#fff !important}
.moovi-app .moovi-sol-card-ok{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.25);color:#fff;font-weight:700;font-size:12px}

/* Comentario opcional debajo del grid */
.moovi-app .moovi-sol-extra{margin-top:6px}
.moovi-app .moovi-sol-extra label{display:block;font-size:12px;font-weight:500;color:var(--neutral-700);margin-bottom:6px}
.moovi-app .moovi-sol-extra textarea{
  width:100%;font-family:var(--moovi-font);font-size:13px;color:var(--moovi-black);
  background:#fff;border:1.5px solid var(--neutral-300);border-radius:var(--r-sm);
  padding:10px 12px;line-height:1.45;transition:all .15s ease;resize:vertical;min-height:70px;
}
.moovi-app .moovi-sol-extra textarea:focus{outline:none;border-color:var(--moovi-blue);box-shadow:0 0 0 3px rgba(0,30,228,.12)}

/* ===========================================================
   Modal contextual estilo moovitelecom.com — blue gradient frame +
   inner white panel. Estilos auto-suficientes (no dependen de
   .moovi-app) y blindados con !important contra el tema.
   =========================================================== */
.moovi-modal,.moovi-modal *{box-sizing:border-box;font-family:var(--moovi-font) !important;text-shadow:none !important}
.moovi-modal{position:fixed !important;inset:0 !important;z-index:99999 !important;display:flex !important;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .2s ease}
.moovi-modal.is-open{opacity:1;pointer-events:auto}
.moovi-modal-backdrop{position:absolute !important;inset:0 !important;background:rgba(15,23,40,.62) !important;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}

/* Outer card: gradiente azul moovi como en el modal "¿Qué incluye?" */
.moovi-modal-card{
  position:relative !important;
  background:linear-gradient(135deg, var(--moovi-blue) 0%, var(--moovi-blue) 55%, var(--moovi-black) 100%) !important;
  border-radius:28px !important;
  width:100% !important;
  max-width:540px !important;
  max-height:calc(100vh - 32px) !important;
  overflow:hidden !important;
  box-shadow:0 30px 80px rgba(0,0,0,.4), 0 8px 24px rgba(0,30,228,.3) !important;
  transform:translateY(12px) scale(.96);
  transition:transform .25s cubic-bezier(.4,0,.2,1);
  padding:0 !important;
  margin:0 !important;
  display:flex;flex-direction:column;
}
.moovi-modal.is-open .moovi-modal-card{transform:translateY(0) scale(1)}

/* Cabecera azul con título centrado y X arriba a la derecha */
.moovi-modal-head{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  position:relative;
  padding:22px 56px 18px !important;
  background:transparent !important;
  flex:none;
}
.moovi-modal-head h3{
  margin:0 !important;
  font-size:22px !important;
  font-weight:600 !important;
  color:#fff !important;
  letter-spacing:-.5px !important;
  line-height:1.2 !important;
  text-align:center !important;
  text-transform:none !important;
  font-family:var(--moovi-font) !important;
}
.moovi-modal-close{
  position:absolute !important;
  top:16px !important; right:16px !important;
  background:transparent !important;
  border:0 !important;
  color:#fff !important;
  width:32px !important; height:32px !important;
  min-width:0 !important; max-width:32px !important;
  border-radius:50% !important;
  cursor:pointer !important;
  display:inline-flex !important;
  align-items:center !important; justify-content:center !important;
  padding:0 !important;
  font-size:0 !important;
  flex:none !important;
  transition:background .15s ease !important;
  box-shadow:none !important;
  text-shadow:none !important;
}
.moovi-modal-close:hover{background:rgba(255,255,255,.18) !important}
.moovi-modal-close svg{width:16px !important;height:16px !important}

/* Panel interior blanco que contiene el formulario */
.moovi-modal-form{
  background:#fff !important;
  margin:4px 14px 14px !important;
  border-radius:22px !important;
  padding:24px !important;
  display:flex !important; flex-direction:column !important;
  gap:16px !important;
  overflow-y:auto;
  flex:1 1 auto;
}
/* Field con notched label (estilo moderno consistente con el login) */
.moovi-modal-field{display:block !important;position:relative !important}
.moovi-modal-field + .moovi-modal-field{margin-top:14px !important}
.moovi-modal-field label{
  position:absolute !important;
  top:0 !important;
  left:14px !important;
  transform:translateY(-50%) !important;
  background:#fff !important;
  padding:0 6px !important;
  font-size:11px !important;
  font-weight:600 !important;
  letter-spacing:.5px !important;
  text-transform:uppercase !important;
  color:var(--moovi-blue) !important;
  z-index:1;
  margin:0 !important;
  pointer-events:none;
  line-height:1 !important;
  font-family:var(--moovi-font) !important;
}
.moovi-modal-field input,
.moovi-modal-field select,
.moovi-modal-field textarea{
  font-family:var(--moovi-font) !important;
  font-size:14px !important;
  font-weight:400 !important;
  color:var(--moovi-black) !important;
  background:#fff !important;
  border:1.5px solid var(--neutral-300) !important;
  border-radius:14px !important;
  padding:14px 16px !important;
  line-height:1.4 !important;
  transition:all .15s ease !important;
  width:100% !important;
  appearance:none !important;
  -webkit-appearance:none !important;
  -moz-appearance:none !important;
  margin:0 !important;
  box-shadow:none !important;
  background-image:none !important;
}
.moovi-modal-field select{
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%23001EE4" stroke-width="2.5"><polyline points="6 9 12 15 18 9"/></svg>') !important;
  background-repeat:no-repeat !important;
  background-position:right 14px center !important;
  background-size:14px !important;
  padding-right:42px !important;
  cursor:pointer;
}
.moovi-modal-field textarea{resize:vertical;min-height:84px;background-image:none !important;padding-right:16px !important;font-family:var(--moovi-font) !important}
.moovi-modal-field input:hover:not(:focus),
.moovi-modal-field select:hover:not(:focus),
.moovi-modal-field textarea:hover:not(:focus){border-color:#9aa1a8 !important}
.moovi-modal-field input:focus,
.moovi-modal-field select:focus,
.moovi-modal-field textarea:focus{outline:none !important;border-color:var(--moovi-blue) !important;box-shadow:0 0 0 4px rgba(0,30,228,.12) !important}
.moovi-modal-field input::placeholder,
.moovi-modal-field textarea::placeholder{color:#9aa1a8;font-weight:300}
/* Anula el azul-claro de Chrome cuando autorrellena */
.moovi-modal-field input:-webkit-autofill,
.moovi-modal-field input:-webkit-autofill:hover,
.moovi-modal-field input:-webkit-autofill:focus{
  -webkit-text-fill-color:var(--moovi-black) !important;
  -webkit-box-shadow:0 0 0 1000px #fff inset !important;
  border-color:var(--moovi-blue) !important;
  caret-color:var(--moovi-black) !important;
  transition:background-color 5000s ease-in-out 0s;
}

.moovi-modal-error{
  margin:0 !important;
  padding:10px 12px !important;
  background:#FCE6EE !important;
  color:var(--error) !important;
  border-radius:12px !important;
  font-size:13px !important;
  font-weight:500 !important;
  border:1px solid rgba(204,51,102,.18) !important;
}

.moovi-recover-help{
  margin:0 0 4px !important;
  padding:0 !important;
  font-size:13px !important;
  line-height:1.5 !important;
  color:#3a4254 !important;
  background:transparent !important;
  border:0 !important;
  font-weight:400 !important;
}

.moovi-login.moovi-passwd .moovi-passwd-state{padding:8px 0;text-align:center}
.moovi-login.moovi-passwd .moovi-passwd-iframe-card{padding:0 !important;overflow:hidden;border-radius:18px}
.moovi-login.moovi-passwd .moovi-passwd-iframe{display:block;width:100%;min-height:360px;border:0;background:#fff}
@media (max-width:680px){.moovi-login.moovi-passwd .moovi-passwd-iframe{min-height:420px}}
.moovi-login.moovi-passwd .moovi-passwd-foot{margin:14px 0 0;font-size:12px;color:var(--neutral-500);text-align:center}
.moovi-login.moovi-passwd .moovi-passwd-foot a{color:var(--moovi-blue);text-decoration:none;font-weight:500}
.moovi-login.moovi-passwd .moovi-passwd-foot a:hover{text-decoration:underline}
.moovi-login.moovi-passwd .moovi-passwd-user{
  margin:0 0 14px !important;
  padding:8px 12px !important;
  font-size:12px !important;
  text-align:center;
  background:rgba(0,30,228,.06) !important;
  color:var(--moovi-blue) !important;
  border-radius:9999px !important;
  font-weight:500 !important;
}
.moovi-login.moovi-passwd .moovi-passwd-rules{
  margin:0 0 14px !important;
  padding:10px 12px !important;
  font-size:12px !important;
  line-height:1.45 !important;
  background:#f3f4f6 !important;
  color:#3a4254 !important;
  border-radius:12px !important;
  font-weight:400 !important;
}

.moovi-login .moovi-activate-cta{
  margin:14px 0 0 !important;
  padding:0 !important;
  text-align:center !important;
  font-size:13px !important;
  color:var(--neutral-700) !important;
  background:transparent !important;
  border:0 !important;
}
.moovi-login .moovi-activate-cta .moovi-link{
  margin-left:6px !important;
  font-weight:600 !important;
}

.moovi-login .moovi-success,
.moovi-modal-success{
  margin:8px 0 0 !important;
  padding:10px 12px !important;
  background:#E6F6F0 !important;
  color:#0a7e4a !important;
  border-radius:12px !important;
  font-size:13px !important;
  font-weight:500 !important;
  border:1px solid rgba(10,126,74,.18) !important;
  line-height:1.4 !important;
}

.moovi-login .moovi-activate-help{
  margin:0 0 14px !important;
  padding:10px 12px !important;
  font-size:13px !important;
  line-height:1.5 !important;
  color:#3a4254 !important;
  background:rgba(0,30,228,.04) !important;
  border:1px solid rgba(0,30,228,.12) !important;
  border-radius:12px !important;
  font-weight:400 !important;
}

.moovi-modal-actions{
  display:flex !important;
  justify-content:flex-end !important;
  gap:10px !important;
  margin:8px 0 0 !important;
  flex-wrap:wrap !important;
}

/* Botones del modal con estilos auto-suficientes (no usan .moovi-app .btn) */
.moovi-modal .btn,
.moovi-modal button[type="submit"],
.moovi-modal button.btn-secondary,
.moovi-modal button.moovi-modal-cancel{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  font-family:var(--moovi-font) !important;
  font-weight:500 !important;
  font-size:14px !important;
  line-height:1 !important;
  padding:12px 22px !important;
  border-radius:9999px !important;
  cursor:pointer !important;
  text-decoration:none !important;
  text-shadow:none !important;
  text-transform:none !important;
  letter-spacing:0 !important;
  width:auto !important;
  min-width:0 !important;
  height:auto !important;
  min-height:0 !important;
  transition:all .15s ease !important;
}
.moovi-modal .btn,
.moovi-modal button[type="submit"]{
  background:var(--moovi-black) !important;
  color:#fff !important;
  border:0 !important;
  box-shadow:0 4px 12px rgba(0,0,0,.12) !important;
}
.moovi-modal .btn:hover,
.moovi-modal button[type="submit"]:hover{background:var(--moovi-blue) !important;transform:translateY(-1px) !important;box-shadow:0 8px 20px rgba(0,30,228,.25) !important}
.moovi-modal .btn .arrow,
.moovi-modal button[type="submit"] .arrow{
  display:inline-flex !important;align-items:center !important;justify-content:center !important;
  width:20px !important;height:20px !important;border-radius:50% !important;
  background:rgba(255,255,255,.2) !important;flex:none !important;
}
.moovi-modal .btn .arrow svg,
.moovi-modal button[type="submit"] .arrow svg{width:10px !important;height:10px !important}
.moovi-modal .btn-secondary,
.moovi-modal button.moovi-modal-cancel{
  background:#fff !important;
  color:var(--moovi-blue) !important;
  border:1.5px solid var(--moovi-blue) !important;
  box-shadow:none !important;
}
.moovi-modal .btn-secondary:hover,
.moovi-modal button.moovi-modal-cancel:hover{background:var(--moovi-blue) !important;color:#fff !important}

@media (max-width:520px){
  .moovi-modal-card{max-width:100% !important;border-radius:24px !important}
  .moovi-modal-head{padding:18px 50px 14px !important}
  .moovi-modal-head h3{font-size:18px !important}
  .moovi-modal-form{padding:18px !important;margin:4px 10px 10px !important;border-radius:18px !important}
  .moovi-modal-actions{flex-direction:column-reverse !important;gap:8px !important}
  .moovi-modal-actions .btn,
  .moovi-modal-actions button{width:100% !important}
}

/* Listado de mis solicitudes */
.moovi-app .moovi-sol-list{display:flex;flex-direction:column;gap:10px}
.moovi-app .moovi-sol-item{padding:14px;border:1px solid var(--neutral-300);border-radius:var(--r-md);background:#fff}
.moovi-app .moovi-sol-item-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:6px}
.moovi-app .moovi-sol-item-info{flex:1;min-width:0}
.moovi-app .moovi-sol-item-head strong{display:block;font-size:14px;font-weight:600;color:var(--moovi-black);margin:0 0 4px}
.moovi-app .moovi-sol-item-meta{font-size:11px;color:var(--neutral-500);letter-spacing:.3px}
.moovi-app .moovi-sol-item-msg{margin:6px 0 0;font-size:13px;color:var(--neutral-700);line-height:1.5;white-space:pre-wrap}
.moovi-app .moovi-sol-item-actions{display:flex;justify-content:flex-end;margin-top:10px;padding-top:10px;border-top:1px dashed var(--neutral-300)}
.moovi-app .moovi-sol-cancel{
  background:transparent !important;
  color:var(--error) !important;
  border:1px solid var(--error) !important;
  border-radius:var(--r-pill) !important;
  padding:6px 14px !important;
  font-family:var(--moovi-font) !important;
  font-size:12px !important;
  font-weight:500 !important;
  cursor:pointer !important;
  transition:all .15s ease;
  text-shadow:none !important;box-shadow:none !important;
}
.moovi-app .moovi-sol-cancel:hover{background:var(--error) !important;color:#fff !important}
.moovi-app .moovi-sol-cancel:disabled{opacity:.6;cursor:wait}
.moovi-app .moovi-sol-loadmore{display:flex;justify-content:center;margin-top:14px}

/* Celda de línea con alias editable en Contratos */
.moovi-app .moovi-linea-cell{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}
.moovi-app .moovi-linea-info{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.moovi-app .moovi-linea-info strong{font-size:13px;font-weight:600;color:var(--moovi-blue);margin:0 !important}
.moovi-app .moovi-linea-tel{font-size:12px;color:var(--neutral-700);font-variant-numeric:tabular-nums}
.moovi-app .moovi-linea-edit{
  display:inline-flex !important;align-items:center !important;justify-content:center !important;
  width:28px !important;height:28px !important;min-width:0 !important;max-width:28px !important;
  background:var(--moovi-lavender-bg) !important;color:var(--moovi-blue) !important;
  border:0 !important;border-radius:50% !important;
  cursor:pointer !important;padding:0 !important;
  transition:all .15s ease;flex:none;
  box-shadow:none !important;
}
.moovi-app .moovi-linea-edit:hover{background:var(--moovi-blue) !important;color:#fff !important}
.moovi-app .moovi-linea-edit svg{width:13px !important;height:13px !important}
.moovi-app .moovi-sol-loadmore .btn{padding:10px 20px !important;font-size:13px !important}

/* LOPD y comunicaciones */
.moovi-app .moovi-lopd-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:680px){.moovi-app .moovi-lopd-grid{grid-template-columns:1fr}}
.moovi-app .moovi-lopd-row{display:flex !important;align-items:flex-start !important;gap:12px;background:var(--neutral-50) !important;padding:14px !important;border-radius:var(--r-sm) !important;cursor:pointer;border:1px solid var(--neutral-300)}
.moovi-app .moovi-lopd-row input[type="checkbox"]{appearance:none !important;-webkit-appearance:none !important;width:20px !important;height:20px !important;min-width:0 !important;border:1.5px solid var(--neutral-300) !important;border-radius:6px !important;cursor:pointer !important;background:#fff !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;flex:none !important;margin:2px 0 0 !important;padding:0 !important;transition:all .15s ease}
.moovi-app .moovi-lopd-row input[type="checkbox"]:checked{background:var(--moovi-blue) !important;border-color:var(--moovi-blue) !important}
.moovi-app .moovi-lopd-row input[type="checkbox"]:checked::after{content:"";width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);margin-bottom:2px}
.moovi-app .moovi-lopd-row strong{display:block;font-size:13px;font-weight:600;color:var(--moovi-black);margin:0 0 2px}
.moovi-app .moovi-lopd-row span{display:block;font-size:12px;color:var(--neutral-700);line-height:1.45}
.moovi-app .moovi-lopd-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;flex-wrap:wrap}
.moovi-app .moovi-lopd-feedback{margin:12px 0 0;padding:10px 14px;border-radius:var(--r-md);font-size:13px;font-weight:500}
.moovi-app .moovi-lopd-feedback.is-ok{background:#E6F6F0 !important;color:var(--success) !important}
.moovi-app .moovi-lopd-feedback.is-err{background:#FCE6EE !important;color:var(--error) !important}

/* Ajustes finos para móvil — espaciado más ceñido + ocultar ayuda */
@media (max-width:760px){
  .moovi-app .main{padding:0 !important}
  .moovi-app .topbar{margin:0 0 12px !important;gap:6px !important}
  .moovi-app .topbar .actions{display:none !important} /* "¿Necesitas ayuda?" fuera en móvil */
  .moovi-app .topbar .breadcrumb{font-size:12px !important}
  .moovi-app .page-hero{padding:20px !important;border-radius:16px !important;margin:0 0 12px !important}
  .moovi-app .page-hero h1{font-size:24px !important;letter-spacing:-.8px !important}
  .moovi-app .page-hero p{font-size:13px !important}
  .moovi-app .page-hero .hashtag{font-size:11px !important;padding:3px 10px !important;margin:0 0 10px !important}
  .moovi-app .page-title{margin:4px 0 12px !important;gap:6px !important}
  .moovi-app .page-title h1, .moovi-app .page-title h2{font-size:22px !important}
  .moovi-app .card{padding:14px !important;border-radius:16px !important}
  .moovi-app .grid{gap:10px !important}
  /* Cualquier grid con columnas inline también colapsa a 1 col */
  .moovi-app .grid[style*="grid-template-columns"]{grid-template-columns:1fr !important}
  .moovi-app [style*="grid-template-columns:1.6fr"],
  .moovi-app [style*="grid-template-columns: 1.6fr"]{grid-template-columns:1fr !important}
  .moovi-app .kpi{padding:14px !important;border-radius:16px !important}
  .moovi-app .kpi .value{font-size:22px !important;line-height:1.1 !important}
  .moovi-app .kpi .label{font-size:10px !important;letter-spacing:1px !important}
  /* Sidebar footer compacto en mobile */
  .moovi-app .sidebar .footer{padding:0 4px 0 8px !important;gap:6px !important}
  .moovi-app .sidebar .footer button{width:32px !important;height:32px !important;border-radius:50% !important}
  .moovi-app .sidebar .user .avatar{width:32px !important;height:32px !important;font-size:11px !important}
}
/* Móvil estrecho ≤ 380px — esconde avatar, deja logout suelto */
@media (max-width:380px){
  .moovi-app .sidebar .user{display:none !important}
  .moovi-app .sidebar .footer{border-left:1px solid rgba(255,255,255,.08) !important}
  .moovi-app .sidebar .menu a{padding:10px 2px !important}
  .moovi-app .sidebar .menu a svg{width:18px !important;height:18px !important}
}

/* Icon-buttons en las tablas — Elementor les pone min-width: 110px y los oval-iza */
.moovi-app .tbl .icon-btn,
.moovi-app .icon-btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:36px !important; height:36px !important;
  min-width:0 !important; max-width:36px !important;
  min-height:0 !important; max-height:36px !important;
  flex:none !important;
  padding:0 !important; margin:0 0 0 4px !important;
  background:var(--moovi-lavender-bg) !important;
  color:var(--moovi-blue) !important;
  border:0 !important; border-radius:50% !important;
  cursor:pointer !important;
  text-shadow:none !important; box-shadow:none !important;
  line-height:1 !important;
  font-size:0 !important;
  transition:all .15s ease !important;
}
.moovi-app .tbl .icon-btn:hover,
.moovi-app .icon-btn:hover{background:var(--moovi-blue) !important;color:#fff !important;transform:none !important}
.moovi-app .tbl .icon-btn svg,
.moovi-app .icon-btn svg{width:16px !important; height:16px !important; display:inline-block !important; flex:none}

/* Mapa real — iframe que ocupa toda la card-map */
.moovi-app .map-card{height:280px !important;background:transparent !important;padding:0 !important;display:block !important;border:1px solid var(--neutral-300) !important;border-radius:var(--r-md) !important;overflow:hidden}
.moovi-app .map-card iframe{display:block;width:100%;height:100%;border:0;background:var(--moovi-lavender-bg)}

/* Sidebar avatar/usuario: forzar layout aunque el tema meta margins en .who span / strong */
.moovi-app .sidebar .user .who strong{font-weight:600 !important;font-size:13px !important;display:block !important;margin:0 !important;color:#fff !important;line-height:1.2 !important}
.moovi-app .sidebar .user .who span{color:#8a929b !important;font-size:11px !important;display:block !important;margin:0 !important;line-height:1.2 !important}
.moovi-app .sidebar .user .avatar{width:32px !important;height:32px !important;min-width:0 !important;max-width:32px !important;border-radius:50% !important;background:var(--moovi-blue) !important;color:#fff !important;display:flex !important;align-items:center !important;justify-content:center !important;font-size:13px !important;font-weight:600 !important;flex:none !important;padding:0 !important;line-height:1 !important}
