/* =========================
   BASE
========================= */
html, body{
overflow-x:hidden;
background:#f5f7f9;
}

/* =========================
   MENÚ SUPERIOR (perfil)
========================= */
.spu-menu{
display:flex;
gap:10px;
overflow-x:auto;
padding:10px;
background:#fff;
}

.spu-menu button{
padding:10px;
border:none;
background:#eee;
border-radius:8px;
cursor:pointer;
}

.spu-menu button.activo{
background:#000;
color:#fff;
}

.spu-contenido{
padding:15px;
}

/* =========================
   BOTTOM NAV (APP)
========================= */

.spu-bottom-nav{
position:fixed;
bottom:0;
left:0;
width:100%;
height:100px;
background:#fff;
border-top:1px solid #ddd;
display:none;
justify-content:space-around;
align-items:center;
z-index:999999;
}

body.modo-pwa .spu-bottom-nav{
display:flex !important;
}

.spu-bottom-nav a{
text-decoration:none;
color:#999;
font-size:11px;
display:flex;
flex-direction:column;
align-items:center;
position:relative;
transition: all 0.2s ease;
padding:6px 10px;
border-radius:12px;
}

.spu-bottom-nav a.activo{
color:#000;
font-weight:600;
background:#eef6f8;
transform:scale(1.05);
box-shadow:0 2px 6px rgba(0,0,0,0.08);
}

.spu-bottom-nav span{
font-size:24px;
transition:transform 0.2s;
}

.spu-bottom-nav a.activo span{
transform:scale(1.2);
}

.spu-bottom-nav small{
font-size:9px;
}

/* espacio inferior SOLO en app */
body.modo-pwa{
padding-bottom:90px;
}

/* =========================
   TOP BAR APP
========================= */

.spu-top-bar{
position:fixed;
top:0;
left:0;
width:100%;
height:55px;
background:#fff;
display:none;
justify-content:flex-end;
align-items:center;
padding:0 15px;
border-bottom:1px solid #ddd;
z-index:999999;
}

body.modo-pwa .spu-top-bar{
display:flex !important;
}

body.modo-pwa{
padding-top:60px;
}

/* =========================
   OCULTAR HEADER EN APP
========================= */

body.modo-pwa header,
body.modo-pwa #masthead,
body.modo-pwa .site-header,
body.modo-pwa .ast-header-wrap,
body.modo-pwa .ast-desktop-header,
body.modo-pwa .ast-mobile-header,
body.modo-pwa nav,
body.modo-pwa .main-navigation{
display:none !important;
visibility:hidden !important;
height:0 !important;
overflow:hidden !important;
}

body.modo-pwa #wpadminbar{
display:none !important;
}

body.modo-pwa .site,
body.modo-pwa #page{
margin-top:0 !important;
padding-top:0 !important;
}

/* =========================
   HOME HEADER PRO
========================= */

.spu-home-header.simple{
background:linear-gradient(135deg, #519cab, #3d7f8c);
padding:40px 20px 30px;
text-align:center;
border-bottom-left-radius:30px;
border-bottom-right-radius:30px;
color:#fff;
box-shadow:0 8px 25px rgba(0,0,0,0.2);
position:relative;
overflow:hidden;
}

.spu-home-header.simple::before{
content:'';
position:absolute;
top:-50%;
left:-50%;
width:200%;
height:200%;
background:radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 60%);
transform:rotate(25deg);
}

.spu-home-header.simple h1{
font-size:34px;
font-weight:900;
margin:0;
letter-spacing:0.5px;
color:#e3a750;
}

.spu-home-header.simple p{
font-size:13px;
margin-top:8px;
opacity:0.9;
}

/* =========================
   GRID INICIO
========================= */

.spu-inicio{
display:grid;
grid-template-columns: 1fr 1fr;
gap:14px;
padding:15px;
}

/* =========================
   CARDS PRO
========================= */

.spu-card{
background:#fff;
border-radius:16px;
padding:16px;
box-shadow:0 6px 18px rgba(0,0,0,0.08);
transition:all 0.2s ease;
position:relative;
overflow:hidden;
}

.spu-card.full{
grid-column:1 / -1;
}

.spu-card:active{
transform:scale(0.98);
}

.spu-card::after{
content:'';
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:linear-gradient(120deg, transparent, rgba(255,255,255,0.3), transparent);
opacity:0;
transition:0.3s;
}

.spu-card:active::after{
opacity:1;
}

/* listas */
.spu-card ul{
list-style:none;
padding:0;
margin:0;
}

.spu-card li{
padding:10px 0;
border-bottom:1px solid #f0f0f0;
}

.spu-card li:last-child{
border-bottom:none;
}

.spu-card li a{
text-decoration:none;
color:#333;
display:block;
}

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

/* estados */
.spu-tag{
display:inline-block;
margin-top:4px;
font-size:11px;
}

.spu-carrera.abierta .spu-tag{
background:#34c759;
color:#fff;
padding:3px 8px;
border-radius:6px;
}

.spu-carrera.curso .spu-tag{
background:#ffcc00;
color:#000;
padding:3px 8px;
border-radius:6px;
}

/* botones */
.spu-btn{
display:inline-block;
margin-top:6px;
padding:8px 12px;
background:#519cab;
color:#fff;
border-radius:8px;
text-decoration:none;
font-size:12px;
transition:0.2s;
}

.spu-btn:active{
transform:scale(0.95);
}

/* =========================
   LOGIN APP PRO
========================= */

.spu-login-app{
height:100vh;
display:flex;
align-items:center;
justify-content:center;
background:linear-gradient(135deg, #519cab, #3d7f8c);
padding:20px;
}

.spu-login-box{
width:100%;
max-width:380px;
background:#fff;
border-radius:20px;
padding:30px 25px;
text-align:center;
box-shadow:0 10px 30px rgba(0,0,0,0.2);
animation:fadeInUp 0.4s ease;
backdrop-filter: blur(10px);
}

.spu-login-logo{
font-size:40px;
margin-bottom:10px;
}

.spu-login-box h1{
margin:5px 0;
font-size:26px;
font-weight:800;
color:#333;
}

.spu-login-sub{
font-size:13px;
color:#777;
margin-bottom:20px;
}

.spu-login-form input{
width:100%;
padding:14px;
margin-bottom:12px;
border-radius:10px;
border:1px solid #ddd;
font-size:16px;
-webkit-appearance:none;
appearance:none;
}

.spu-login-form input:focus{
outline:none;
border-color:#519cab;
box-shadow:0 0 0 2px rgba(81,156,171,0.2);
}

.spu-login-form button{
width:100%;
padding:14px;
background:#519cab;
color:#fff;
border:none;
border-radius:10px;
font-weight:600;
font-size:15px;
cursor:pointer;
transition:0.2s;
}

.spu-login-form button:hover{
background:#3d7f8c;
}

.spu-login-form button:active{
transform:scale(0.97);
}

.spu-login-form button:disabled{
opacity:0.6;
}

/* password */
.spu-password-wrap{
position:relative;
}

.spu-password-wrap input{
padding-right:40px;
}

.spu-eye{
position:absolute;
right:12px;
top:50%;
transform:translateY(-50%);
cursor:pointer;
font-size:16px;
opacity:0.6;
}

/* loader */
.spu-loader{
display:none;
margin:15px auto 0;
width:24px;
height:24px;
border:3px solid #ccc;
border-top:3px solid #519cab;
border-radius:50%;
animation:spin 0.8s linear infinite;
}

@keyframes spin{
to{ transform:rotate(360deg); }
}

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

/* =========================
   LOGOUT BOTÓN PRO
========================= */

.spu-logout-btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:8px;
margin-top:20px;
padding:14px 20px;
background:#ff3b30;
color:#fff;
border-radius:12px;
text-decoration:none;
font-size:18px;
font-weight:600;
transition:0.2s;
}

.spu-logout-btn::before{
content:"🚪";
font-size:28px;
}

.spu-logout-btn:active{
transform:scale(0.96);
}

/* =========================
   SOLO LOGIN LIMPIO
========================= */

.page-id-3970 header,
.page-id-3970 nav,
.page-id-3970 footer{
display:none !important;
}

.page-id-3970 .site,
.page-id-3970 #page,
.page-id-3970 .ast-container,
.page-id-3970 .site-content{
margin:0 !important;
padding:0 !important;
}

.page-id-3970 .entry-header,
.page-id-3970 .entry-title{
display:none !important;
}
.spu-card::after{
pointer-events:none;
}
.panel-notificaciones{
position:fixed;
top:60px;
right:10px;
width:300px;
max-height:400px;
background:#fff;
border-radius:12px;
box-shadow:0 5px 20px rgba(0,0,0,0.2);
overflow:auto;
z-index:999999;
padding:15px;
}

.spu-notif{
position:relative;
font-size:22px;
cursor:pointer;
}

.spu-notif #badge-notificaciones{
position:absolute;
top:-5px;
right:-8px;
background:red;
color:#fff;
border-radius:50%;
font-size:9px;
padding:2px 5px;
}

.spu-top-bar{
    justify-content:center; /* 🔥 CENTRADO */
}

.spu-notif{
    position:relative;
    font-size:34px; /* 🔥 más grande */
    cursor:pointer;
}

.spu-notif #badge-notificaciones{
    position:absolute;
    top:-4px;
    right:-6px;
    background:red;
    color:#fff;
    border-radius:50%;
    font-size:8px; /* 🔥 más pequeño */
    padding:1px 4px; /* 🔥 más compacto */
    min-width:14px;
    text-align:center;
}

.spu-register-box{
    margin-top:20px;
    text-align:center;
}

.spu-register-box p{
    font-size:14px;
    color:#666;
    margin-bottom:8px;
}

.spu-register-btn{
    display:block;
    padding:10px;
    border-radius:8px;
    background:#333;
    color:#fff;
    text-decoration:none;
    font-weight:bold;
    transition:0.2s;
}

.spu-register-btn:hover{
    background:#000;
}
.spu-tag.pendiente{
    background:#ffe082;
    color:#333;
}
.spu-tag.pendiente{
    background: #ffe5e5;
    color: #c40000;
    border: 1px solid #ffb3b3;
}
.spu-top5-wrapper table tr:nth-child(n+7){
    display:none;
}
/* CONTENEDOR */
.spu-carrera {
    padding: 12px;
    border-radius: 12px;
    margin-bottom: 10px;
    background: #f5f5f5;
    transition: all 0.2s ease;
}

/* HOVER */
.spu-carrera:hover {
    transform: translateY(-2px);
}


/* ⚪ RESTO (lista inferior) */
.spu-card.full ul li {
    background: #ffffff;
    border: 1px solid #eee;
}

/* TAG */
.spu-tag {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 20px;
    font-size: 12px;
    margin-top: 5px;
    background: rgba(0,0,0,0.1);
}

/* BOTÓN */
.spu-btn {
    display: inline-block;
    margin-top: 6px;
    padding: 6px 10px;
    border-radius: 8px;
    background: #000;
    color: #fff;
    text-decoration: none;
    font-size: 12px;
}

/* DESTACADA (TOP) */
.spu-carrera.destacada {
    font-size: 16px;
    padding: 16px;
    border-radius: 16px;
}
.spu-carrera.curso small,
.spu-carrera.abierta small {
    opacity: 0.9;
}

.spu-carrera.curso a,
.spu-carrera.abierta a {
    background: rgba(255,255,255,0.2);
    padding: 4px 8px;
    border-radius: 6px;
}
.spu-login-box {
    max-width: 400px;
    margin: auto;
    padding: 20px;
}

.spu-login-box input {
    width: 100%;
    margin-bottom: 10px;
    padding: 10px;
    border-radius: 8px;
    border: 1px solid #ddd;
}

.spu-login-box button {
    width: 100%;
    padding: 10px;
    background: #000;
    color: #fff;
    border: none;
    border-radius: 8px;
}

.spu-error {
    color: red;
    margin-bottom: 10px;
}
.spu-cierre{
    display:block;
    margin-top:4px;
    font-size:14px;
    font-weight:600;
    color:#000;
}