/* =====================================================
   SPECIAL OLYMPICS v2.0 — ESTILOS
   ===================================================== */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --azul:#1a5276;--azul-c:#2e86c1;--azul-s:#d6eaf8;
  --verde:#1e8449;--verde-c:#27ae60;--verde-s:#d5f5e3;
  --naranja:#d35400;--rojo:#c0392b;--morado:#6c3483;
  --amarillo:#f39c12;
  --gris:#f0f3f7;--gris-b:#dde1e7;--gris-c:#7f8c8d;
  --blanco:#fff;--texto:#2c3e50;
  --sombra:0 2px 12px rgba(0,0,0,.08);
  --sombra-lg:0 6px 24px rgba(0,0,0,.13);
  --radio:10px;
}
body{font-family:'Segoe UI',Arial,sans-serif;background:var(--gris);color:var(--texto);font-size:14px;line-height:1.6}

/* ── NAVBAR ── */
.navbar{background:var(--azul);color:#fff;display:flex;align-items:center;padding:0 1.5rem;height:58px;position:sticky;top:0;z-index:1000;box-shadow:0 2px 10px rgba(0,0,0,.2);gap:1rem}
.navbar.verde{background:var(--verde)}
.navbar-brand{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:800;white-space:nowrap;min-width:220px}
.navbar-brand i{color:#f9ca24;font-size:1.3rem}
.navbar-menu{display:flex;list-style:none;gap:2px;flex:1;flex-wrap:wrap}
.navbar-menu a{color:rgba(255,255,255,.85);text-decoration:none;padding:6px 11px;border-radius:6px;display:flex;align-items:center;gap:5px;font-size:13px;transition:.2s}
.navbar-menu a:hover,.navbar-menu a.activo{background:rgba(255,255,255,.15);color:#fff}
.navbar-user{display:flex;align-items:center;gap:8px;font-size:13px;white-space:nowrap;margin-left:auto}
.btn-logout{background:rgba(255,255,255,.15);color:#fff!important;padding:5px 10px!important;border-radius:6px;text-decoration:none;font-size:13px;transition:.2s}
.btn-logout:hover{background:rgba(200,0,0,.5)!important}

/* ── LAYOUT ── */
.container{max-width:1280px;margin:0 auto;padding:1.5rem}
.container-sm{max-width:750px;margin:0 auto;padding:1.5rem}

/* ── CARDS ── */
.card{background:var(--blanco);border-radius:var(--radio);box-shadow:var(--sombra);overflow:hidden;margin-bottom:1.5rem}
.card-header{padding:.9rem 1.4rem;background:var(--azul);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.card-header h2,.card-header h3{font-size:.95rem;display:flex;align-items:center;gap:7px}
.card-header.verde{background:var(--verde)}
.card-header.morado{background:var(--morado)}
.card-header.naranja{background:var(--naranja)}
.card-body{padding:1.4rem}

/* ── STATS ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{background:var(--blanco);border-radius:var(--radio);padding:1.1rem 1.3rem;box-shadow:var(--sombra);border-left:4px solid var(--azul-c);display:flex;align-items:center;gap:1rem;transition:.2s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sombra-lg)}
.stat-card.verde{border-color:var(--verde-c)}
.stat-card.naranja{border-color:var(--naranja)}
.stat-card.rojo{border-color:var(--rojo)}
.stat-card.morado{border-color:var(--morado)}
.stat-icon{font-size:1.9rem;opacity:.85}
.stat-icon.azul{color:var(--azul-c)}.stat-icon.verde{color:var(--verde-c)}.stat-icon.naranja{color:var(--naranja)}.stat-icon.rojo{color:var(--rojo)}.stat-icon.morado{color:var(--morado)}
.stat-num{font-size:1.9rem;font-weight:800;color:var(--texto);line-height:1}
.stat-label{font-size:11px;color:var(--gris-c);margin-top:2px}

/* ── FORMULARIOS ── */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-weight:600;margin-bottom:4px;font-size:12px;color:#555;text-transform:uppercase;letter-spacing:.3px}
.req{color:var(--rojo)}
.form-control{width:100%;padding:9px 12px;border:1.5px solid #ddd;border-radius:7px;font-size:13px;transition:.2s;font-family:inherit;background:#fff}
.form-control:focus{outline:none;border-color:var(--azul-c);box-shadow:0 0 0 3px rgba(46,134,193,.12)}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1rem}
.form-section{border:1.5px solid var(--gris-b);border-radius:var(--radio);padding:1.2rem;margin-bottom:1.2rem}
.form-section-title{font-size:12px;font-weight:800;text-transform:uppercase;color:var(--azul);margin-bottom:1rem;display:flex;align-items:center;gap:6px;border-bottom:2px solid var(--gris-b);padding-bottom:8px;letter-spacing:.5px}
.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:6px}
.check-item{display:flex;align-items:center;gap:7px;font-size:13px;padding:5px 8px;border-radius:5px;cursor:pointer}
.check-item:hover{background:var(--gris)}
.check-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--azul)}

/* ── FOTO UPLOAD ── */
.foto-upload-wrap{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.foto-preview{width:110px;height:130px;border:2px dashed #ccc;border-radius:var(--radio);display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--gris);flex-shrink:0;cursor:pointer}
.foto-preview img{width:100%;height:100%;object-fit:cover}
.foto-preview i{font-size:2.5rem;color:#ccc}

/* ── TABLAS ── */
.table-responsive{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:var(--azul);color:#fff;padding:10px 12px;text-align:left;font-weight:600;white-space:nowrap;font-size:12px;letter-spacing:.3px}
tbody tr{border-bottom:1px solid var(--gris-b);transition:.15s}
tbody tr:hover{background:#f0f5fb}
tbody td{padding:9px 12px;vertical-align:middle}
.foto-mini{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--gris-b)}
.foto-mini-wrap{width:38px;height:38px;border-radius:50%;background:#eee;display:flex;align-items:center;justify-content:center;border:2px solid var(--gris-b)}

/* ── BADGES ── */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.badge-pendiente {background:#fff3cd;color:#856404}
.badge-aprobado  {background:#d4edda;color:#155724}
.badge-observado {background:#d1ecf1;color:#0c5460}
.badge-rechazado {background:#f8d7da;color:#721c24}
.badge-cat       {background:var(--azul-s);color:var(--azul);font-size:10px}

/* ── BOTONES ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border:none;border-radius:7px;cursor:pointer;font-size:13px;font-weight:600;text-decoration:none;transition:.2s;white-space:nowrap;font-family:inherit}
.btn:hover{opacity:.88;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary {background:var(--azul);color:#fff}
.btn-success {background:var(--verde);color:#fff}
.btn-warning {background:var(--amarillo);color:#fff}
.btn-danger  {background:var(--rojo);color:#fff}
.btn-info    {background:#17a2b8;color:#fff}
.btn-morado  {background:var(--morado);color:#fff}
.btn-gris    {background:#95a5a6;color:#fff}
.btn-sm{padding:4px 10px;font-size:11px}
.btn-lg{padding:11px 22px;font-size:15px}
.btn-block{width:100%;justify-content:center}

/* ── ALERTS ── */
.alert{padding:11px 15px;border-radius:var(--radio);margin-bottom:1rem;display:flex;align-items:flex-start;gap:10px;font-size:13px}
.alert-success{background:#d4edda;color:#155724;border-left:4px solid #28a745}
.alert-danger {background:#f8d7da;color:#721c24;border-left:4px solid #dc3545}
.alert-warning{background:#fff3cd;color:#856404;border-left:4px solid #ffc107}
.alert-info   {background:#d1ecf1;color:#0c5460;border-left:4px solid #17a2b8}

/* ── FILTROS ── */
.filtros{background:var(--blanco);border-radius:var(--radio);padding:1rem 1.4rem;margin-bottom:1rem;box-shadow:var(--sombra);display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}
.filtros .form-group{margin-bottom:0;flex:1;min-width:140px}

/* ── PAGE HEADER ── */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.4rem;flex-wrap:wrap;gap:1rem}
.page-header h1{font-size:1.3rem;display:flex;align-items:center;gap:9px;color:var(--texto)}
.page-header h1 i{color:var(--azul)}

/* ── ACCIONES RAPIDAS ── */
.acciones-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}
.accion-card{background:var(--blanco);border-radius:var(--radio);padding:1.3rem;text-align:center;box-shadow:var(--sombra);text-decoration:none;color:var(--texto);transition:.2s;border:2px solid transparent}
.accion-card:hover{border-color:var(--azul-c);transform:translateY(-3px);box-shadow:var(--sombra-lg)}
.accion-card i{font-size:1.9rem;color:var(--azul);margin-bottom:8px;display:block}
.accion-card span{font-size:13px;font-weight:700}
.accion-card small{display:block;font-size:11px;color:var(--gris-c);margin-top:2px}

/* ── CRONOGRAMA ── */
.cronograma-item{border-left:4px solid var(--azul-c);padding:10px 14px;margin-bottom:8px;background:var(--blanco);border-radius:0 var(--radio) var(--radio) 0;box-shadow:var(--sombra)}
.cronograma-item.competencia{border-color:var(--naranja)}
.cronograma-item.evaluacion {border-color:var(--verde-c)}
.cronograma-item.inscripcion{border-color:var(--morado)}
.cronograma-fecha{font-size:11px;color:var(--gris-c)}
.cronograma-titulo{font-weight:700;font-size:14px}

/* ── LOGIN ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--azul) 0%,#2e86c1 100%);padding:2rem}
.login-wrap.verde{background:linear-gradient(135deg,var(--verde) 0%,#27ae60 100%)}
.login-card{background:#fff;border-radius:14px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 15px 50px rgba(0,0,0,.25)}
.login-logo{text-align:center;margin-bottom:1.5rem}
.login-logo i{font-size:3.2rem;color:var(--azul)}
.login-logo h1{font-size:1.2rem;color:var(--texto);margin-top:8px;font-weight:800}
.login-logo p{font-size:12px;color:var(--gris-c);margin-top:4px}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.55);z-index:9999;align-items:center;justify-content:center;padding:1rem;overflow-y:auto}
.modal-box{background:#fff;border-radius:14px;padding:2rem;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--sombra-lg)}
.modal-title{font-size:1.1rem;font-weight:800;color:var(--azul);margin-bottom:1.2rem;display:flex;align-items:center;gap:8px}

/* ── DOC UPLOAD ── */
.doc-upload-item{border:1.5px dashed #ccc;border-radius:8px;padding:10px 14px;display:flex;align-items:center;gap:10px;margin-bottom:8px;background:var(--gris)}
.doc-upload-item i{font-size:1.3rem;color:var(--azul)}
.doc-subido{border-color:var(--verde-c);background:var(--verde-s)}
.doc-subido i{color:var(--verde)}

/* ── REPORTES ── */
.reporte-header{background:var(--azul);color:#fff;padding:1rem 1.5rem;border-radius:var(--radio) var(--radio) 0 0;text-align:center}
.reporte-header h2{font-size:1rem}
.reporte-header p{font-size:12px;opacity:.85;margin-top:3px}

/* ── FOOTER ── */
.footer{text-align:center;padding:1.5rem;margin-top:2rem;color:var(--gris-c);font-size:12px;border-top:1px solid var(--gris-b)}

/* ── MOBILE ── */
@media(max-width:768px){
  .navbar{height:auto;padding:.8rem 1rem;flex-wrap:wrap}
  .navbar-menu{display:none}
  .form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .container{padding:1rem}
}

/* v6 additions */
.badge-corregido { background:#e8d5f5; color:#6c3483; }
.stat-card a { text-decoration:none; color:inherit; }
