/* Skynext PM — estilos */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,800&family=Instrument+Sans:wght@400;500;600&display=swap');

:root{
  --fondo:#EDF0EE; --tinta:#1E2A28; --tinta2:#5B6B66;
  --petrol:#14595A; --petrol-osc:#0E4344;
  --ambar:#E5743A; --ok:#2F7D55; --rojo:#B23A3A;
  --card:#FFFFFF; --borde:#D7DDD9; --suave:#E4E9E6;
  --radio:10px;
  --display:'Bricolage Grotesque',sans-serif; --cuerpo:'Instrument Sans',sans-serif;
}
*{box-sizing:border-box;margin:0}
body{background:var(--fondo);color:var(--tinta);font-family:var(--cuerpo);font-size:15.5px;line-height:1.55}
a{color:var(--petrol)}
h1,h2,h3{font-family:var(--display);line-height:1.15}
h1{font-size:clamp(1.5rem,4vw,2.1rem);font-weight:800}
h2{font-size:1.25rem;font-weight:600}
h3{font-size:1.05rem;font-weight:600}

.wrap{max-width:1040px;margin:0 auto;padding:0 16px 64px}
.eyebrow{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--tinta2);font-weight:600}

/* Barra superior */
header.top{background:var(--petrol);color:#fff;padding:10px 0;margin-bottom:24px}
header.top .wrap{display:flex;align-items:center;gap:16px;padding-bottom:0}
header.top .logo{font-family:var(--display);font-weight:800;font-size:1.15rem;color:#fff;text-decoration:none}
header.top .logo span{color:#9FD0C4}
header.top nav{margin-left:auto;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
header.top nav a{color:#D9E8E2;text-decoration:none;font-size:.9rem}
header.top nav a:hover{color:#fff}
.chip-user{background:rgba(255,255,255,.14);border-radius:99px;padding:3px 12px;font-size:.82rem}

/* Tarjetas y grillas */
.card{background:var(--card);border:1px solid var(--borde);border-radius:var(--radio);padding:18px 20px;margin-bottom:16px}
.grid{display:grid;gap:14px}
.grid.proyectos{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.proy{display:block;text-decoration:none;color:inherit;transition:transform .12s ease,box-shadow .12s ease}
.proy:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(20,89,90,.12)}
.proy .obj{color:var(--tinta2);font-size:.9rem;margin-top:6px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.proy .meta{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap;font-size:.78rem;color:var(--tinta2)}

/* Estados */
.badge{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.04em;border-radius:99px;padding:3px 10px}
.st-pend{background:var(--suave);color:var(--tinta2)}
.st-curso{background:#DCEBE8;color:var(--petrol-osc)}
.st-rev{background:#FBE4D4;color:#9C4A17}
.st-ok{background:#DCEFE2;color:#1F5C3C}

/* La ruta: etapas como hitos numerados */
.ruta{position:relative;padding-left:46px}
.ruta::before{content:'';position:absolute;left:17px;top:8px;bottom:8px;width:2px;background:var(--borde)}
.etapa{position:relative;margin-bottom:22px}
.etapa .hito{position:absolute;left:-46px;top:0;width:36px;height:36px;border-radius:50%;
  background:var(--petrol);color:#fff;font-family:var(--display);font-weight:800;
  display:flex;align-items:center;justify-content:center;font-size:.95rem;border:3px solid var(--fondo)}
.etapa.lista .hito{background:var(--ok)}
.etapa .fecha-obj{font-size:.8rem;color:var(--tinta2)}

/* Tareas */
.tarea{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-top:1px solid var(--suave)}
.tarea:first-of-type{border-top:none}
.tarea .info{flex:1;min-width:0}
.tarea .info a{color:inherit;text-decoration:none;font-weight:600}
.tarea .info a:hover{color:var(--petrol);text-decoration:underline}
.tarea .sub{font-size:.82rem;color:var(--tinta2);margin-top:2px}

/* Formularios */
label{display:block;font-size:.82rem;font-weight:600;margin:12px 0 4px;color:var(--tinta)}
input[type=text],input[type=email],input[type=password],input[type=date],input[type=url],input[type=number],textarea,select{
  width:100%;padding:9px 12px;border:1px solid var(--borde);border-radius:8px;
  font-family:var(--cuerpo);font-size:.95rem;background:#fff;color:var(--tinta)}
textarea{min-height:90px;resize:vertical}
input:focus,textarea:focus,select:focus{outline:2px solid var(--petrol);outline-offset:1px;border-color:var(--petrol)}
.btn{display:inline-block;border:none;border-radius:8px;padding:9px 18px;font-family:var(--cuerpo);
  font-weight:600;font-size:.92rem;cursor:pointer;text-decoration:none;background:var(--petrol);color:#fff}
.btn:hover{background:var(--petrol-osc)}
.btn.sec{background:#fff;color:var(--petrol);border:1px solid var(--petrol)}
.btn.sec:hover{background:#EDF4F2}
.btn.peq{padding:5px 12px;font-size:.82rem}
.btn.ok{background:var(--ok)}
.btn.alerta{background:var(--ambar)}
.btn:focus-visible{outline:3px solid #9FD0C4;outline-offset:2px}
.fila{display:flex;gap:12px;flex-wrap:wrap}
.fila>*{flex:1;min-width:180px}

/* Comentarios */
.coment{padding:10px 0;border-top:1px solid var(--suave)}
.coment .quien{font-weight:600;font-size:.86rem}
.coment .cuando{color:var(--tinta2);font-size:.76rem;margin-left:6px}
.coment p{margin-top:3px;font-size:.93rem}

/* Evidencia */
.evid{display:flex;gap:8px;align-items:center;padding:7px 0;border-top:1px solid var(--suave);font-size:.92rem;word-break:break-all}
.evid .tipo{font-size:.7rem;background:var(--suave);border-radius:4px;padding:2px 7px;color:var(--tinta2);flex-shrink:0}

/* Historial */
.hist li{font-size:.86rem;color:var(--tinta2);padding:6px 0;border-top:1px solid var(--suave);list-style:none}
.hist b{color:var(--tinta)}

/* PM virtual */
.pm-caja{background:linear-gradient(135deg,#10484A,#14595A);color:#E7F2EE;border-radius:var(--radio);padding:20px;margin-bottom:16px}
.pm-caja h2{color:#fff}
.pm-caja .eyebrow{color:#9FD0C4}
.pm-resp{background:#fff;color:var(--tinta);border-radius:8px;padding:14px 16px;margin-top:12px;white-space:pre-wrap;font-size:.93rem}

.aviso{background:#FBF3E2;border:1px solid #E8D9AE;border-radius:8px;padding:10px 14px;font-size:.88rem;margin-bottom:14px}
.exito{background:#DCEFE2;border:1px solid #B5DCC4;border-radius:8px;padding:10px 14px;font-size:.88rem;margin-bottom:14px;color:#1F5C3C}
.error{background:#F7E2E2;border:1px solid #E0B4B4;border-radius:8px;padding:10px 14px;font-size:.88rem;margin-bottom:14px;color:var(--rojo)}

table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;color:var(--tinta2);padding:8px 10px;border-bottom:2px solid var(--borde)}
td{padding:9px 10px;border-bottom:1px solid var(--suave);font-size:.92rem}

/* Login */
.login-cuerpo{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(1100px 500px at 70% -10%,#1B6E6F 0%,var(--petrol-osc) 55%,#0A3132 100%)}
.login-caja{background:#fff;border-radius:14px;padding:34px 30px;width:100%;max-width:400px}
.login-caja .logo{font-family:var(--display);font-weight:800;font-size:1.6rem}
.login-caja .logo span{color:var(--petrol)}

details summary{cursor:pointer;font-weight:600;color:var(--petrol)}
.muted{color:var(--tinta2);font-size:.88rem}

@media (max-width:640px){
  .wrap{padding:0 12px 48px}
  .card{padding:14px}
  .ruta{padding-left:38px}
  .etapa .hito{left:-38px;width:30px;height:30px;font-size:.85rem}
  .ruta::before{left:14px}
  header.top nav{gap:10px;font-size:.85rem}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important}
}
