*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --azul:#0f3460;
  --azul-mid:#1a4f8a;
  --azul-claro:#1f66ff;
  --azul-light:#e8f0fe;
  --verde:#0d7a3e;
  --verde-bg:#e6f4ec;
  --rojo:#c62828;
  --rojo-bg:#fce8e6;
  --gris-bg:#f0f2f7;
  --gris-card:#fff;
  --gris-b:#d1d9e6;
  --gris-b2:#e8ecf4;
  --texto:#111827;
  --texto-mid:#374151;
  --texto-sub:#6b7280;
  --sombra:0 2px 12px rgba(15,52,96,.08);
  --sombra-md:0 6px 24px rgba(15,52,96,.12);
  --r:14px;
  --r-sm:10px;
  --r-lg:20px;
}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',system-ui,-apple-system,sans-serif;
  background:var(--gris-bg);
  color:var(--texto);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
.hidden{display:none!important}

.header{
  background:var(--azul);
  box-shadow:0 2px 20px rgba(0,0,0,.2);
  position:sticky;
  top:0;
  z-index:100;
}
.header-inner{
  max-width:1200px;
  margin:0 auto;
  padding:14px 24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:14px}
.brand-icon{
  width:48px;height:48px;
  background:rgba(255,255,255,.15);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;flex-shrink:0;
}
.brand-title{color:#fff;font-size:22px;font-weight:700;letter-spacing:-.3px}
.brand-sub{color:rgba(255,255,255,.65);font-size:12px;margin-top:2px}
.top-nav,.nav-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.btn{
  display:inline-flex;align-items:center;gap:6px;
  border:none;border-radius:var(--r-sm);
  padding:10px 18px;
  font-family:inherit;font-size:14px;font-weight:600;
  cursor:pointer;transition:all .18s ease;
  white-space:nowrap;text-decoration:none;
}
.btn:hover{transform:translateY(-1px);filter:brightness(1.08)}
.btn:active{transform:translateY(0);filter:brightness(.95)}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;filter:none}
.btn-primary{background:var(--azul-claro);color:#fff}
.btn-primary:hover{background:#1557e0}
.btn-primary-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-primary-outline:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-ghost{background:transparent;color:rgba(255,255,255,.85)}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-secondary{background:#e5e7eb;color:#111827}
.btn-secondary:hover{background:#d1d5db}
.btn-danger{background:var(--rojo);color:#fff}
.btn-danger:hover{background:#b71c1c}
.btn-outline{background:transparent;color:var(--azul);border:2px solid var(--azul)}
.btn-outline:hover{background:var(--azul-light)}
.btn-full{width:100%;justify-content:center;padding:13px;font-size:15px}
.btn-lg{padding:13px 28px;font-size:16px;border-radius:var(--r)}

.section{padding:40px 0}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.form-wrap{max-width:520px}

.hero-card{
  background:linear-gradient(135deg,var(--azul) 0%,var(--azul-mid) 100%);
  border-radius:var(--r-lg);
  padding:56px 48px;
  color:#fff;
  text-align:center;
  box-shadow:var(--sombra-md);
}
.hero-eyebrow{
  display:inline-block;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.2);
  border-radius:999px;
  padding:5px 16px;
  font-size:13px;font-weight:600;
  margin-bottom:20px;
}
.hero-title{
  font-size:clamp(28px,5vw,44px);
  font-weight:700;line-height:1.2;
  margin-bottom:18px;letter-spacing:-.5px;
}
.hero-desc{
  font-size:17px;
  color:rgba(255,255,255,.82);
  max-width:560px;
  margin:0 auto 32px;
  line-height:1.6;
}
.hero-actions{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:40px;
}
.hero-features{
  display:flex;gap:24px;justify-content:center;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.2);
  padding-top:28px;
}
.hfeat{display:flex;align-items:center;gap:8px;font-size:14px;color:rgba(255,255,255,.8);font-weight:500}
.hfeat-icon{font-size:18px}

.form-card{
  background:var(--gris-card);
  border-radius:var(--r-lg);
  box-shadow:var(--sombra-md);
  overflow:hidden;
}
.form-card-hdr{background:var(--azul);padding:28px 32px;color:#fff}
.form-card-hdr h2{font-size:22px;font-weight:700;margin-bottom:4px}
.form-card-hdr p{color:rgba(255,255,255,.7);font-size:14px}
.form-card form{padding:28px 32px 32px}
.form-foot{text-align:center;font-size:14px;color:var(--texto-sub);margin-top:16px}
.link-btn{
  background:none;border:none;color:var(--azul-claro);
  font-weight:600;cursor:pointer;font-size:inherit;padding:0;
  text-decoration:underline;font-family:inherit;
}
.link-btn:hover{opacity:.8}
.separator{
  display:flex;align-items:center;gap:12px;
  padding:0 32px;margin:4px 0 20px;
  color:var(--texto-sub);font-size:13px;
}
.separator::before,.separator::after{
  content:"";flex:1;height:1px;background:var(--gris-b);
}
.google-wrap{padding:0 32px 28px;display:flex;justify-content:center}
.google-wrap>div{width:100%;display:flex;justify-content:center}

.field{position:relative;margin-bottom:16px}
.field:last-of-type{margin-bottom:0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
label{display:block;font-size:13px;font-weight:600;color:var(--texto-mid);margin-bottom:6px}
.req{color:var(--rojo)}
input[type="text"],input[type="email"],input[type="password"],select{
  width:100%;padding:11px 14px;
  border:1.5px solid var(--gris-b);
  border-radius:var(--r-sm);
  font-family:inherit;font-size:14px;color:var(--texto);
  background:#fff;transition:border-color .15s,box-shadow .15s;
  appearance:none;
}
input:focus,select:focus{
  outline:none;border-color:var(--azul-claro);
  box-shadow:0 0 0 3px rgba(31,102,255,.13);
}
input::placeholder{color:#b0b7c3}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:44px}
.pw-toggle{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;font-size:16px;
  color:var(--texto-sub);padding:4px;opacity:.7;transition:opacity .15s;
}
.pw-toggle:hover{opacity:1}
.form-actions{margin-top:22px}

.msg{
  display:block;margin-top:14px;padding:10px 14px;border-radius:var(--r-sm);
  font-size:14px;font-weight:600;line-height:1.4;
}
.msg:empty{display:none}
.msg-info{background:var(--azul-light);color:var(--azul)}
.msg-ok{background:var(--verde-bg);color:var(--verde)}
.msg-error{background:var(--rojo-bg);color:var(--rojo)}

.panel-header{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;margin-bottom:24px;flex-wrap:wrap;
}
.panel-header h2{font-size:26px;font-weight:700;color:var(--azul);margin-bottom:4px}
.panel-sub{color:var(--texto-sub);font-size:14px}
.panel-actions{display:flex;gap:10px;flex-wrap:wrap}

.panel-loading{
  background:rgba(240,242,247,.92);
  border-radius:var(--r);
  padding:48px;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  font-weight:600;color:var(--azul);
  margin-bottom:24px;
}
.spinner{
  width:36px;height:36px;border:3px solid var(--gris-b);
  border-top-color:var(--azul-claro);
  border-radius:50%;animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.cards-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:18px;
  margin-bottom:18px;
}
.panel-card{
  background:var(--gris-card);
  border-radius:var(--r);
  padding:22px 24px;
  box-shadow:var(--sombra);
  border:1px solid var(--gris-b2);
}
.span-4{grid-column:span 4}
.span-8{grid-column:span 8}
.span-12{grid-column:span 12}
.prefs-card{margin-bottom:0}

.card-lbl{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  color:var(--texto-sub);margin-bottom:14px;
}
.card-lbl-row{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;gap:12px;flex-wrap:wrap;
}
.badge-num{
  background:var(--azul-claro);color:#fff;border-radius:999px;
  font-size:12px;font-weight:700;padding:2px 10px;min-width:24px;text-align:center;
}
.ph{color:var(--texto-sub);font-size:14px}

#panel-datos-docente p,#panel-preferencias-resumen p{
  font-size:13px;color:var(--texto-mid);margin-bottom:6px;line-height:1.4;
}
#panel-datos-docente strong,#panel-preferencias-resumen strong{color:var(--texto)}

.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.stat-box{
  background:var(--gris-bg);
  border-radius:var(--r-sm);
  padding:14px 10px;
  text-align:center;
}
.stat-n{display:block;font-size:28px;font-weight:700;color:var(--azul);line-height:1}
.stat-l{
  display:block;font-size:11px;font-weight:600;color:var(--texto-sub);
  margin-top:4px;text-transform:uppercase;letter-spacing:.4px;
}
.stat-acceso{font-size:12px;color:var(--texto-sub);margin-top:4px}

.empty-state{text-align:center;padding:32px 16px;color:var(--texto-sub)}
.empty-state p{margin-bottom:6px}
.empty-hint{font-size:13px;color:var(--texto-sub)}

.hist-list{list-style:none;padding:0}
.hist-list li{
  font-size:13px;color:var(--texto-mid);padding:7px 0;
  border-bottom:1px solid var(--gris-b2);line-height:1.4;
}
.hist-list li:last-child{border-bottom:none}

.sec-label{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;
  color:var(--texto-sub);margin:22px 0 12px;padding-bottom:8px;
  border-bottom:1px solid var(--gris-b2);
}
.hint-sm{
  font-size:11px;font-weight:400;color:var(--texto-sub);
  text-transform:none;letter-spacing:0;
}
.prefs-hint{font-size:13px;color:var(--texto-sub);margin-bottom:4px;line-height:1.5}
.sec-head{
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;margin:22px 0 12px;
}
.sec-head .sec-label{margin:0;padding:0;border:none}
.mini-btn{
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--gris-b);
  background:#fff;color:var(--texto-mid);
  border-radius:999px;padding:8px 12px;font-size:12px;
  font-weight:700;cursor:pointer;transition:all .15s ease;
}
.mini-btn:hover{
  border-color:var(--azul-claro);
  color:var(--azul);
  background:var(--azul-light);
}
.mini-group{display:flex;gap:8px;flex-wrap:wrap}

.checks-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:8px;margin-bottom:4px;
}
.chk-card{
  display:flex;align-items:center;gap:10px;
  background:var(--gris-bg);
  border:1.5px solid var(--gris-b);
  border-radius:var(--r-sm);
  padding:10px 14px;
  cursor:pointer;transition:border-color .15s,background .15s;
  user-select:none;
}
.chk-card:hover{border-color:var(--azul-claro);background:var(--azul-light)}
.chk-card:has(input:checked){background:var(--azul-light);border-color:var(--azul-claro)}
.chk-card input[type="checkbox"]{
  width:16px;height:16px;accent-color:var(--azul-claro);
  cursor:pointer;flex-shrink:0;
}
.chk-lbl{font-size:13px;font-weight:600;color:var(--texto)}
.chk-card:has(input:checked) .chk-lbl{color:var(--azul)}
.notif-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:4px}
.chk-notif{flex-direction:row;align-items:flex-start;padding:14px}
.chk-notif input{margin-top:2px}
.chk-notif>div{display:flex;flex-direction:column;gap:3px}
.chk-sub{font-size:11px;font-weight:400;color:var(--texto-sub)}

.ac-list{
  position:absolute;top:calc(100% + 4px);left:0;width:100%;
  background:#fff;border:1.5px solid var(--azul-claro);border-radius:var(--r-sm);
  box-shadow:0 8px 24px rgba(15,52,96,.12);
  max-height:260px;overflow-y:auto;display:none;z-index:200;
}
.ac-item{
  padding:10px 14px;cursor:pointer;font-size:14px;
  border-bottom:1px solid var(--gris-b2);
  color:var(--texto-mid);transition:background .1s;
}
.ac-item:last-child{border-bottom:none}
.ac-item:hover,.ac-item.is-active{background:var(--azul-light);color:var(--azul);font-weight:600}
.ac-status{
  padding:10px 14px;
  font-size:13px;
  color:var(--texto-sub);
}

#panel-alertas{overflow:visible}
.alerta-pid-card.alerta-pid-ok{border:1px solid #b7ebc6;background:#eefbf3}
.alerta-pid-card.alerta-pid-info{border:1px solid #bfdcff;background:#f2f8ff}
.alerta-pid-card.alerta-pid-warn{border:1px solid #f0d39a;background:#fff8e8}
.alerta-meta-note{margin-top:10px;font-size:13px;line-height:1.5;color:#243447}
.alerta-carousel-shell{position:relative}
.alerta-stage{position:relative;padding:0 86px}

.alerta-window-preview{
  position:absolute;
  top:34px;
  bottom:34px;
  width:170px;
  appearance:none;
  -webkit-appearance:none;
  border:none;
  border-radius:24px;
  padding:14px 14px 18px;
  text-align:left;
  font:inherit;
  color:inherit;
  cursor:pointer;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(241,246,255,.98) 100%);
  border:1px solid rgba(31,102,255,.10);
  box-shadow:0 14px 28px rgba(15,52,96,.12);
  overflow:hidden;
  transition:transform .18s ease,filter .18s ease,box-shadow .18s ease;
}
.alerta-window-preview:hover{
  filter:brightness(1.02);
  box-shadow:0 18px 34px rgba(15,52,96,.16);
}
.alerta-window-preview-left{
  left:-10px;
  z-index:1;
  transform:scale(.92) rotate(-2deg);
}
.alerta-window-preview-right{
  right:-10px;
  z-index:1;
  transform:scale(.92) rotate(2deg);
}
.alerta-windowbar{
  display:flex;
  align-items:center;
  gap:7px;
  margin-bottom:12px;
}
.alerta-windowbar-mini{margin-bottom:14px}
.alerta-windowdot{
  width:10px;
  height:10px;
  border-radius:999px;
  display:inline-block;
}
.win-red{background:#ff5f57}
.win-yellow{background:#ffbd2e}
.win-green{background:#28c840}
.alerta-window-preview-side{
  font-size:10px;
  font-weight:800;
  letter-spacing:.45px;
  text-transform:uppercase;
  color:var(--azul-claro);
  margin-bottom:8px;
}
.alerta-window-preview-title{
  font-size:15px;
  line-height:1.15;
  font-weight:700;
  color:var(--azul);
  margin-bottom:6px;
}
.alerta-window-preview-sub{
  font-size:12px;
  color:var(--texto-mid);
  margin-bottom:6px;
  line-height:1.3;
}
.alerta-window-preview-meta{
  font-size:11px;
  color:var(--texto-sub);
  line-height:1.35;
}
.alerta-main-card{
  position:relative;
  z-index:3;
  animation:alertaCardIn .28s cubic-bezier(.2,.8,.2,1);
}
@keyframes alertaCardIn{
  from{opacity:0;transform:translateY(10px) scale(.988)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.alerta-floating{
  background:
    radial-gradient(circle at top right, rgba(31,102,255,.15), transparent 34%),
    linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);
  border:1px solid var(--gris-b);
  border-left:4px solid var(--azul-claro);
  border-radius:24px;
  padding:18px;
  box-shadow:0 14px 34px rgba(15,52,96,.12);
}
.alerta-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:12px;
}
.alerta-nav{
  width:42px;
  height:42px;
  border-radius:999px;
  border:none;
  background:var(--azul);
  color:#fff;
  font-size:18px;
  font-weight:700;
  cursor:pointer;
  transition:transform .15s ease,opacity .15s ease;
}
.alerta-nav:hover{transform:translateY(-1px)}
.alerta-nav:disabled{opacity:.35;cursor:not-allowed;transform:none}
.alerta-counter{
  font-size:12px;
  font-weight:700;
  color:var(--texto-sub);
  text-transform:uppercase;
  letter-spacing:.5px;
}
.alerta-progress{
  height:8px;
  background:#e8eef9;
  border-radius:999px;
  overflow:hidden;
  margin-bottom:16px;
}
.alerta-progress-bar{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--azul),var(--azul-claro));
  box-shadow:0 4px 12px rgba(31,102,255,.25);
}
.alerta-tags{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.tag{
  padding:2px 10px;
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.3px;
}
.tag-turno{background:var(--azul);color:#fff}
.tag-nivel{background:var(--azul-light);color:var(--azul)}
.tag-estado{background:var(--verde-bg);color:var(--verde)}
.alerta-title{
  font-size:20px;
  line-height:1.2;
  font-weight:700;
  color:var(--azul);
  margin:10px 0 6px;
}
.alerta-subtitle{
  font-size:13px;
  color:var(--texto-sub);
  margin-bottom:14px;
}
.alerta-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px 14px;
}
.alerta-row{
  display:flex;
  flex-direction:column;
  gap:4px;
  background:#fff;
  border:1px solid var(--gris-b2);
  border-radius:14px;
  padding:10px 12px;
}
.alerta-key{
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.4px;
  color:var(--texto-sub);
}
.alerta-val{
  color:var(--texto);
  font-size:13px;
  line-height:1.35;
}
.alerta-dots{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:8px;
  margin-top:18px;
}
.alerta-dot{
  width:10px;
  height:10px;
  border:none;
  border-radius:999px;
  background:#c9d6eb;
  cursor:pointer;
  transition:all .18s ease;
}
.alerta-dot:hover{
  background:#9cb6e3;
  transform:scale(1.08);
}
.alerta-dot.is-active{
  width:28px;
  background:linear-gradient(90deg,var(--azul),var(--azul-claro));
  box-shadow:0 4px 12px rgba(31,102,255,.25);
}
.alerta-meta-card{
  margin-top:16px;
  background:linear-gradient(180deg,rgba(18,60,115,.05),rgba(18,60,115,.03));
  border:1px solid rgba(18,60,115,.10);
  border-radius:16px;
  padding:14px;
}
.alerta-meta-head{
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.5px;
  color:var(--texto-sub);
  margin-bottom:10px;
}
.alerta-meta-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.alerta-meta-item{
  background:#fff;
  border:1px solid var(--gris-b2);
  border-radius:12px;
  padding:10px 12px;
}
.alerta-meta-item-wide{grid-column:span 2}
.alerta-meta-k{
  display:block;
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.4px;
  color:var(--texto-sub);
  margin-bottom:4px;
}
.alerta-meta-v{
  display:block;
  font-size:14px;
  color:var(--texto);
  line-height:1.35;
}
.alerta-meta-loading,.alerta-meta-empty,.alerta-meta-error{
  font-size:13px;
  color:var(--texto-sub);
}
.alerta-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:16px;
}
.alerta-link{
  min-width:230px;
  justify-content:center;
}

.plan-stack{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.plan-title{
  font-size:20px;
  line-height:1.2;
  font-weight:700;
  color:var(--azul);
}
.plan-pill-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.plan-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
  font-weight:700;
  background:var(--azul-light);
  color:var(--azul);
}
.plan-pill-neutral{
  background:var(--gris-bg);
  color:var(--texto-mid);
}
.plan-note{
  font-size:13px;
  color:var(--texto-sub);
  line-height:1.5;
}

.historico-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:14px;
}
.historico-updated,.historico-note{
  font-size:12px;
  font-weight:600;
  color:var(--texto-sub);
}
.historico-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:10px;
  margin-bottom:14px;
}
.historico-stat{
  background:var(--gris-bg);
  border:1px solid var(--gris-b2);
  border-radius:14px;
  padding:14px;
}
.historico-stat-n{
  display:block;
  font-size:24px;
  line-height:1;
  font-weight:700;
  color:var(--azul);
}
.historico-stat-l{
  display:block;
  margin-top:6px;
  font-size:11px;
  font-weight:700;
  color:var(--texto-sub);
  text-transform:uppercase;
  letter-spacing:.4px;
}
.historico-columns{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-bottom:12px;
}
.historico-box{
  background:linear-gradient(180deg,#fff,#f8fbff);
  border:1px solid var(--gris-b2);
  border-radius:16px;
  padding:14px;
}
.historico-box h4{
  font-size:13px;
  font-weight:700;
  color:var(--azul);
  margin-bottom:10px;
}
.historico-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.historico-item{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.historico-item span{
  font-size:13px;
  line-height:1.35;
  color:var(--texto-mid);
}
.historico-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--azul-light);
  color:var(--azul);
  border-radius:999px;
  padding:2px 8px;
  font-size:12px;
  font-weight:700;
  white-space:nowrap;
}
.historico-competition{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.historico-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--gris-bg);
  border:1px solid var(--gris-b2);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
  color:var(--texto-mid);
}
.historico-box-latest{margin-top:12px}
.historico-latest{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}
.historico-latest .ph{grid-column:1/-1}
.historico-offer{
  background:#fff;
  border:1px solid var(--gris-b2);
  border-radius:14px;
  padding:12px;
}
.historico-offer-title{
  font-size:14px;
  font-weight:700;
  line-height:1.25;
  color:var(--azul);
  margin-bottom:6px;
}
.historico-offer-sub{
  font-size:12px;
  line-height:1.35;
  color:var(--texto-mid);
  margin-bottom:6px;
}
.historico-offer-meta{
  display:flex;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  font-size:11px;
  color:var(--texto-sub);
}
.historico-offer-aux{
  margin-top:8px;
  font-size:12px;
  font-weight:600;
  color:var(--texto);
}

.soft-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.soft-item{
  background:linear-gradient(180deg,#fff,#f7fbff);
  border:1px solid var(--gris-b2);
  border-radius:14px;
  padding:12px 14px;
}
.soft-title{
  font-size:14px;
  font-weight:700;
  color:var(--azul);
  margin-bottom:4px;
}
.soft-sub{
  font-size:13px;
  color:var(--texto-mid);
  line-height:1.4;
}
.soft-meta{
  font-size:12px;
  color:var(--texto-sub);
  line-height:1.4;
}
.soft-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}
.soft-action{
  width:100%;
  justify-content:center;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:10px;
  margin-bottom:14px;
}
.pill-row,.chip-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.pill,.chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:5px 10px;
  font-size:12px;
  font-weight:700;
}
.pill{
  background:var(--azul-light);
  color:var(--azul);
}
.chip{
  background:var(--gris-bg);
  border:1px solid var(--gris-b2);
  color:var(--texto-mid);
}

.banner-rotator{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-bottom:16px;
}
.banner-card{
  border-radius:18px;
  padding:18px;
  background:
    radial-gradient(circle at top right, rgba(31,102,255,.16), transparent 32%),
    linear-gradient(135deg,#f8fbff,#eef4ff);
  border:1px solid rgba(31,102,255,.14);
  min-height:116px;
}
.banner-title{
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.5px;
  color:var(--azul-claro);
  margin-bottom:8px;
}
.banner-text{
  font-size:18px;
  line-height:1.35;
  color:var(--azul);
  font-weight:700;
}

.progress-wrap{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.progress{
  height:10px;
  background:#e7edf8;
  border-radius:999px;
  overflow:hidden;
}
.progress-bar{
  height:100%;
  background:linear-gradient(90deg,var(--azul),var(--azul-claro));
  border-radius:999px;
}
.progress-legend{
  display:flex;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  font-size:12px;
  color:var(--texto-sub);
  font-weight:600;
}

.backfill-meta{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin-top:14px;
}
.backfill-box{
  background:var(--gris-bg);
  border:1px solid var(--gris-b2);
  border-radius:14px;
  padding:12px;
}
.backfill-k{
  display:block;
  font-size:10px;
  color:var(--texto-sub);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.4px;
  margin-bottom:4px;
}
.backfill-v{
  display:block;
  font-size:14px;
  color:var(--texto);
  font-weight:700;
  line-height:1.3;
}

.radar-columns{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.radar-box{
  background:linear-gradient(180deg,#fff,#f8fbff);
  border:1px solid var(--gris-b2);
  border-radius:16px;
  padding:14px;
}
.radar-box h4{
  font-size:13px;
  font-weight:700;
  color:var(--azul);
  margin-bottom:10px;
}

.footer{
  background:var(--azul);
  padding:20px 0;
  margin-top:40px;
}
.footer-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 24px;
  color:rgba(255,255,255,.5);
  font-size:13px;
  text-align:center;
}

@media (max-width:1024px){
  .span-4,.span-8{grid-column:span 6}
  .alerta-stage{padding:0 54px}
  .alerta-window-preview{width:126px}
  .alerta-window-preview-left{left:-4px}
  .alerta-window-preview-right{right:-4px}
  .radar-columns{grid-template-columns:1fr 1fr}
}

@media (max-width:768px){
  .header-inner{padding:12px 16px}
  .hero-card{padding:36px 24px}
  .cards-grid{grid-template-columns:1fr}
  .span-4,.span-8,.span-12{grid-column:span 1}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .notif-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(3,1fr)}
  .stats-grid,.radar-columns,.backfill-meta{grid-template-columns:1fr}
  .form-card form{padding:22px 20px 24px}
  .form-card-hdr{padding:22px 20px}
  .google-wrap{padding:0 20px 24px}
  .separator{padding:0 20px}
  .checks-grid{grid-template-columns:1fr}
  .sec-head{flex-direction:column;align-items:stretch}
  .mini-btn{width:100%}
  .mini-group{width:100%}
  .alerta-grid{grid-template-columns:1fr}
  .alerta-meta-grid{grid-template-columns:1fr}
  .alerta-meta-item-wide{grid-column:auto}
  .alerta-title{font-size:18px}
  .alerta-link{width:100%}
  .alerta-stage{padding:0}
  .alerta-window-preview{display:none}
  .historico-columns,.historico-latest{grid-template-columns:1fr}
}

@media (max-width:480px){
  .hero-title{font-size:26px}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%;justify-content:center}
  .panel-header{flex-direction:column}
  .stats-row{grid-template-columns:1fr}
}
.admin-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 12px;
  margin-bottom: 18px;
}

.admin-card {
  background: #ffffff;
  border: 1px solid #ddd;
  border-radius: 14px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.admin-card strong {
  font-size: 14px;
}

.admin-card span {
  font-size: 24px;
  font-weight: 700;
}

.admin-block {
  margin-top: 16px;
}

.admin-output {
  background: #111;
  color: #0f0;
  padding: 14px;
  border-radius: 12px;
  overflow: auto;
  min-height: 240px;
  white-space: pre-wrap;
  word-break: break-word;
}
.tag-escuela {
  background: #eef4ff;
  color: #1f4fa3;
  border: 1px solid #d7e5ff;
}

.tag-jornada {
  background: #f3f4f6;
  color: #374151;
  border: 1px solid #e5e7eb;
}

.tag-revista {
  background: #f3e8ff;
  color: #7c3aed;
  border: 1px solid #e9d5ff;
}
.alerta-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 12px;
}

.tag-escuela {
  background: #eef4ff;
  color: #1f4fa3;
  border: 1px solid #d7e5ff;
  font-weight: 700;
}

.tag-distrito {
  background: #fff4e5;
  color: #9a6700;
  border: 1px solid #fde7bf;
}

.tag-jornada {
  background: #f3f4f6;
  color: #374151;
  border: 1px solid #e5e7eb;
}

.tag-revista {
  background: #f3e8ff;
  color: #7c3aed;
  border: 1px solid #e9d5ff;
}

.alerta-grid-clean {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 8px;
}

.alerta-grid-clean > *:last-child:nth-child(odd) {
  grid-column: 1 / -1;
}

.alerta-title {
  margin: 6px 0 10px;
}

@media (max-width: 640px) {
  .alerta-grid-clean {
    grid-template-columns: 1fr;
  }
}
