/* ============================================================
   ICEPP · premium.css — Sistema de diseño "Premium minimalista"
   Elegante, mucho espacio en blanco, un solo acento, hairlines.
   ============================================================ */
:root{
  --ink:#0e1626;
  --body:#54627a;
  --muted:#9aa3b2;
  --bg:#ffffff;
  --bg-soft:#f6f7fa;
  --line:#e9ecf2;
  --accent:#1d4ed8;
  --accent-2:#2563eb;
  --accent-soft:#eef3ff;
  --gold:#b88a3e;
  --radius:18px;
  --radius-sm:12px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.7,.2,1);
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:'DM Sans','Poppins',system-ui,sans-serif;
  color:var(--body);
  background:var(--bg);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{ font-family:'Sora','Poppins',sans-serif; color:var(--ink); line-height:1.12; letter-spacing:-.02em; font-weight:800; }

.pm-wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 clamp(20px,5vw,40px); }
.pm-eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:'Sora',sans-serif; font-size:12px; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--accent);
}
.pm-eyebrow::before{ content:""; width:22px; height:1.5px; background:var(--accent); display:inline-block; }
.pm-section{ padding:clamp(64px,9vw,120px) 0; }
.pm-section--soft{ background:var(--bg-soft); }
.pm-head{ max-width:680px; }
.pm-head.center{ margin:0 auto; text-align:center; }
.pm-head h2{ font-size:clamp(30px,4vw,48px); margin:16px 0 0; }
.pm-head p{ margin-top:18px; font-size:17px; color:var(--body); }

/* ---- Botones ---- */
.pm-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:'Sora',sans-serif; font-weight:700; font-size:15px;
  padding:15px 28px; border-radius:999px; cursor:pointer; border:1px solid transparent;
  transition:transform .18s var(--ease), box-shadow .2s var(--ease), background .2s, color .2s, border-color .2s;
}
.pm-btn--primary{ background:var(--ink); color:#fff; }
.pm-btn--primary:hover{ transform:translateY(-2px); box-shadow:0 16px 34px rgba(14,22,38,.22); }
.pm-btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.pm-btn--ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
.pm-btn--accent{ background:var(--accent); color:#fff; }
.pm-btn--accent:hover{ transform:translateY(-2px); box-shadow:0 16px 34px rgba(29,78,216,.30); }

/* ============================================================
   HEADER
   ============================================================ */
.pm-header{
  position:sticky; top:0; z-index:1000;
  background:rgba(255,255,255,.82); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.pm-header-inner{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.pm-logo img{ height:46px; }
.pm-nav{ display:flex; align-items:center; gap:34px; }
.pm-nav a{ font-family:'Sora',sans-serif; font-size:14.5px; font-weight:600; color:var(--ink); position:relative; transition:color .2s; }
.pm-nav a::after{ content:""; position:absolute; left:0; bottom:-6px; width:0; height:1.5px; background:var(--accent); transition:width .25s var(--ease); }
.pm-nav a:hover{ color:var(--accent); } .pm-nav a:hover::after{ width:100%; }
.pm-nav a.active{ color:var(--accent); } .pm-nav a.active::after{ width:100%; }
.pm-header-cta{ display:flex; align-items:center; gap:14px; }

/* hamburguesa */
.pm-burger{ display:none; width:44px; height:44px; border:1px solid var(--line); border-radius:12px; background:#fff; cursor:pointer; position:relative; }
.pm-burger span{ position:absolute; left:11px; right:11px; height:2px; background:var(--ink); border-radius:2px; transition:.25s var(--ease); }
.pm-burger span:nth-child(1){ top:15px; } .pm-burger span:nth-child(2){ top:21px; } .pm-burger span:nth-child(3){ top:27px; }
#pm-menu{ display:none; }
#pm-menu:checked ~ .pm-header .pm-burger span:nth-child(1){ top:21px; transform:rotate(45deg); }
#pm-menu:checked ~ .pm-header .pm-burger span:nth-child(2){ opacity:0; }
#pm-menu:checked ~ .pm-header .pm-burger span:nth-child(3){ top:21px; transform:rotate(-45deg); }
.pm-drawer{ display:none; }

@media(max-width:900px){
  .pm-nav, .pm-header-cta .pm-btn{ display:none; }
  .pm-burger{ display:block; }
  #pm-menu:checked ~ .pm-drawer{
    display:block; position:fixed; top:74px; left:0; right:0; z-index:999;
    background:#fff; border-bottom:1px solid var(--line); box-shadow:0 24px 50px rgba(14,22,38,.12);
    padding:14px clamp(20px,5vw,40px) 24px;
  }
  .pm-drawer a{ display:block; font-family:'Sora',sans-serif; font-weight:600; color:var(--ink); padding:15px 4px; border-bottom:1px solid var(--line); }
  .pm-drawer .pm-btn{ width:100%; margin-top:16px; }
}

/* ============================================================
   HERO
   ============================================================ */
.pm-hero{ padding:clamp(54px,8vw,104px) 0 clamp(40px,6vw,80px); }
.pm-hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:center; }
.pm-hero h1{ font-size:clamp(38px,5.4vw,68px); margin:22px 0 0; }
.pm-hero h1 .accent{ color:var(--accent); }
.pm-hero .lead{ margin-top:22px; font-size:clamp(17px,1.4vw,19px); max-width:520px; }
.pm-hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:34px; }
.pm-hero-trust{ display:flex; gap:28px; margin-top:40px; padding-top:28px; border-top:1px solid var(--line); flex-wrap:wrap; }
.pm-hero-trust div b{ display:block; font-family:'Sora',sans-serif; font-size:24px; color:var(--ink); }
.pm-hero-trust div span{ font-size:13px; color:var(--muted); }

.pm-hero-media{ position:relative; }
.pm-hero-media .frame{
  position:relative; border-radius:26px; overflow:hidden;
  background:var(--bg-soft); border:1px solid var(--line);
  aspect-ratio:4/5; box-shadow:0 40px 90px rgba(14,22,38,.12);
}
.pm-hero-media .frame img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.pm-hero-media .tag{
  position:absolute; left:18px; bottom:18px; z-index:2;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  border:1px solid var(--line); border-radius:14px; padding:12px 16px;
  display:flex; align-items:center; gap:12px; box-shadow:0 12px 30px rgba(14,22,38,.14);
}
.pm-hero-media .tag .dot{ width:10px; height:10px; border-radius:50%; background:#16a34a; box-shadow:0 0 0 4px rgba(22,163,74,.16); }
.pm-hero-media .tag b{ font-family:'Sora',sans-serif; font-size:13px; color:var(--ink); display:block; }
.pm-hero-media .tag span{ font-size:12px; color:var(--muted); }
.pm-hero-media .blob{ position:absolute; inset:auto -30px -30px auto; width:160px; height:160px; border-radius:50%; background:var(--accent-soft); z-index:-1; }

@media(max-width:880px){
  .pm-hero-grid{ grid-template-columns:1fr; gap:40px; }
  .pm-hero-media .frame{ aspect-ratio:4/3; max-width:520px; margin:0 auto; }
}

/* ============================================================
   STATS STRIP
   ============================================================ */
.pm-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.pm-stats div{ padding:32px 24px; text-align:center; border-right:1px solid var(--line); }
.pm-stats div:last-child{ border-right:0; }
.pm-stats b{ font-family:'Sora',sans-serif; font-size:clamp(28px,3.4vw,40px); color:var(--ink); display:block; }
.pm-stats span{ font-size:13.5px; color:var(--muted); margin-top:6px; display:block; }
@media(max-width:680px){
  .pm-stats{ grid-template-columns:1fr 1fr; }
  .pm-stats div:nth-child(2){ border-right:0; }
  .pm-stats div:nth-child(1),.pm-stats div:nth-child(2){ border-bottom:1px solid var(--line); }
}

/* ============================================================
   PROGRAMAS (cards)
   ============================================================ */
.pm-grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
@media(max-width:980px){ .pm-grid-3{ grid-template-columns:1fr 1fr; } }
@media(max-width:640px){ .pm-grid-3{ grid-template-columns:1fr; } }

.pm-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  display:flex; flex-direction:column; transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.pm-card:hover{ transform:translateY(-6px); box-shadow:0 30px 60px rgba(14,22,38,.12); border-color:#dfe4ee; }
.pm-card-img{ aspect-ratio:16/11; overflow:hidden; background:var(--bg-soft); }
.pm-card-img img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.pm-card:hover .pm-card-img img{ transform:scale(1.05); }
.pm-card-body{ padding:26px; display:flex; flex-direction:column; gap:12px; flex:1; }
.pm-card .num{ font-family:'Sora',sans-serif; font-size:13px; font-weight:800; color:var(--accent); letter-spacing:.08em; }
.pm-card h3{ font-size:21px; }
.pm-card p{ font-size:14.5px; color:var(--body); flex:1; }
.pm-card .pm-card-link{ font-family:'Sora',sans-serif; font-weight:700; font-size:14px; color:var(--ink); display:inline-flex; align-items:center; gap:8px; margin-top:4px; transition:gap .2s var(--ease), color .2s; }
.pm-card .pm-card-link:hover{ gap:14px; color:var(--accent); }

/* ============================================================
   FEATURES (por qué)
   ============================================================ */
.pm-features{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-top:48px; }
@media(max-width:720px){ .pm-features{ grid-template-columns:1fr; } }
.pm-feature{ background:#fff; padding:34px; }
.pm-feature .ic{ width:48px; height:48px; border-radius:12px; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; font-size:22px; margin-bottom:16px; }
.pm-feature h4{ font-size:18px; margin-bottom:8px; }
.pm-feature p{ font-size:14.5px; }

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.pm-quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
@media(max-width:900px){ .pm-quotes{ grid-template-columns:1fr; } }
.pm-quote{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:30px; }
.pm-quote .mark{ font-family:'Sora',sans-serif; font-size:44px; line-height:.6; color:var(--accent-soft); }
.pm-quote p{ font-size:15px; color:var(--ink); margin:10px 0 20px; }
.pm-quote .who{ display:flex; align-items:center; gap:12px; padding-top:16px; border-top:1px solid var(--line); }
.pm-quote .av{ width:40px; height:40px; border-radius:50%; background:var(--ink); color:#fff; display:grid; place-items:center; font-family:'Sora',sans-serif; font-weight:700; }
.pm-quote .who b{ font-family:'Sora',sans-serif; color:var(--ink); font-size:14px; display:block; }
.pm-quote .who span{ font-size:12.5px; color:var(--muted); }

/* ============================================================
   FAQ
   ============================================================ */
.pm-faq{ max-width:780px; margin:40px auto 0; }
.pm-faq details{ border-bottom:1px solid var(--line); }
.pm-faq summary{ list-style:none; cursor:pointer; padding:24px 0; font-family:'Sora',sans-serif; font-weight:700; color:var(--ink); font-size:17px; display:flex; justify-content:space-between; gap:16px; }
.pm-faq summary::-webkit-details-marker{ display:none; }
.pm-faq summary::after{ content:"+"; color:var(--accent); font-size:24px; transition:transform .25s var(--ease); }
.pm-faq details[open] summary::after{ transform:rotate(45deg); }
.pm-faq p{ padding:0 0 24px; font-size:15px; max-width:680px; }

/* ============================================================
   CTA BAND
   ============================================================ */
.pm-cta{ background:var(--ink); border-radius:26px; padding:clamp(40px,6vw,72px); text-align:center; position:relative; overflow:hidden; }
.pm-cta h2{ color:#fff; font-size:clamp(28px,3.6vw,44px); }
.pm-cta p{ color:rgba(255,255,255,.7); margin:16px auto 0; max-width:520px; font-size:16px; }
.pm-cta .pm-hero-cta{ justify-content:center; }
.pm-cta::before{ content:""; position:absolute; width:340px; height:340px; border-radius:50%; background:rgba(37,99,235,.30); filter:blur(60px); top:-120px; right:-80px; }

/* ============================================================
   FOOTER
   ============================================================ */
.pm-footer{ border-top:1px solid var(--line); padding:clamp(48px,6vw,72px) 0 32px; }
.pm-footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:36px; }
@media(max-width:760px){ .pm-footer-grid{ grid-template-columns:1fr; gap:28px; text-align:center; } }
.pm-footer-logo{ height:46px; margin-bottom:16px; }
.pm-footer p{ font-size:14px; max-width:320px; }
@media(max-width:760px){ .pm-footer p{ margin:0 auto; } }
.pm-footer h5{ font-family:'Sora',sans-serif; color:var(--ink); font-size:13px; letter-spacing:.06em; text-transform:uppercase; margin-bottom:16px; }
.pm-footer a.fl{ display:block; font-size:14.5px; padding:6px 0; transition:color .2s; }
.pm-footer a.fl:hover{ color:var(--accent); }
.pm-foot-contact{ display:flex; flex-direction:column; gap:10px; font-size:14.5px; }
@media(max-width:760px){ .pm-foot-contact{ align-items:center; } }
.pm-copy{ margin-top:48px; padding-top:24px; border-top:1px solid var(--line); text-align:center; font-size:13px; color:var(--muted); }

/* reveal sutil */
.pm-reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.pm-reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .pm-reveal{ opacity:1; transform:none; } }

/* ---- Flotantes (WhatsApp + subir) ---- */
.pm-fab{ position:fixed; right:20px; bottom:20px; z-index:1200; width:56px; height:56px; border-radius:50%;
  background:#22c55e; display:grid; place-items:center; box-shadow:0 16px 38px rgba(34,197,94,.42); transition:transform .2s var(--ease); }
.pm-fab:hover{ transform:translateY(-3px) scale(1.04); }
.pm-fab svg{ width:28px; height:28px; fill:#fff; }
.pm-top{ position:fixed; right:20px; bottom:86px; z-index:1199; width:46px; height:46px; border-radius:50%;
  background:#fff; border:1px solid var(--line); color:var(--ink); display:grid; place-items:center; cursor:pointer;
  opacity:0; pointer-events:none; transform:translateY(8px); transition:.2s var(--ease); font-size:20px; }
.pm-top.show{ opacity:1; pointer-events:auto; transform:none; }

/* ---- Páginas internas: hero compacto ---- */
.pm-pagehero{ padding:clamp(56px,8vw,104px) 0 clamp(24px,4vw,48px); }
.pm-pagehero h1{ font-size:clamp(34px,4.6vw,58px); margin:18px 0 0; max-width:760px; }
.pm-pagehero h1 .accent{ color:var(--accent); }
.pm-pagehero p{ margin-top:18px; font-size:17px; max-width:600px; }

/* ---- Bloque 2 columnas (misión/visión) ---- */
.pm-duo{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
@media(max-width:760px){ .pm-duo{ grid-template-columns:1fr; } }
.pm-panel{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:34px; }
.pm-panel .ic{ width:48px; height:48px; border-radius:12px; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; font-size:22px; margin-bottom:16px; }
.pm-panel h3{ font-size:22px; margin-bottom:10px; }
.pm-panel p{ font-size:15px; }

/* ---- Formulario (certificado) ---- */
.pm-form{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:34px; }
.pm-field{ margin-bottom:18px; }
.pm-field label{ display:block; font-family:'Sora',sans-serif; font-weight:600; font-size:13.5px; color:var(--ink); margin-bottom:8px; }
.pm-field input{ width:100%; padding:15px 16px; font-size:15px; font-family:inherit; color:var(--ink);
  border:1px solid var(--line); border-radius:var(--radius-sm); outline:none; transition:border .15s, box-shadow .15s; background:#fff; }
.pm-field input:focus{ border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-soft); }
.pm-steps{ list-style:none; display:flex; flex-direction:column; gap:18px; }
.pm-steps li{ display:flex; gap:16px; }
.pm-steps .n{ width:34px; height:34px; flex-shrink:0; border-radius:50%; background:var(--ink); color:#fff;
  font-family:'Sora',sans-serif; font-weight:700; display:grid; place-items:center; font-size:14px; }
.pm-steps b{ font-family:'Sora',sans-serif; color:var(--ink); }
.pm-steps p{ font-size:14.5px; margin-top:2px; }
.pm-note{ margin-top:16px; font-size:13.5px; color:var(--body); background:var(--accent-soft); border:1px solid #dbe5ff; border-radius:var(--radius-sm); padding:14px 16px; }

/* ============================================================
   AJUSTES v2 — menos blanco, más densidad y vida
   ============================================================ */
:root{ --bg-soft:#eaeef6; }
body{ background:#eef1f7; }
.pm-section{ padding:clamp(42px,5.5vw,80px) 0; }
.pm-hero{ padding:clamp(36px,4.5vw,66px) 0 clamp(28px,4vw,52px);
  background:radial-gradient(1100px 460px at 82% -8%, #e3ecff 0%, transparent 58%), linear-gradient(180deg,#f3f6fc, #eef1f7); }
.pm-pagehero{ padding:clamp(40px,5vw,74px) 0 clamp(16px,2.5vw,30px);
  background:radial-gradient(900px 380px at 85% -10%, #e3ecff 0%, transparent 60%), linear-gradient(180deg,#f3f6fc, #eef1f7); }
.pm-section{ background:#ffffff; }
.pm-section--soft{ background:#e9edf6; }
/* línea de acento sutil arriba del header */
.pm-header{ box-shadow:inset 0 3px 0 0 var(--accent); }
/* tarjetas con un pelín más de color al hover */
.pm-card:hover, .pm-panel:hover{ border-color:#cdd7ea; }

/* Punto discreto de acceso al panel admin */
.pm-admin-dot{ display:inline-grid; place-items:center; width:20px; height:38px; margin-left:2px;
  color:var(--muted); opacity:.45; font-weight:900; font-size:22px; line-height:1; text-decoration:none; }
.pm-admin-dot:hover{ opacity:1; color:var(--accent); }

/* ============================================================
   WOW VISUAL · Aurora hero + Galería + Lightbox + Docentes
   ============================================================ */
/* Aurora animada detrás del hero */
.pm-hero{ position:relative; overflow:hidden; }
.pm-hero > .pm-wrap{ position:relative; z-index:1; }
.pm-aurora{ position:absolute; inset:0; z-index:0; pointer-events:none; filter:blur(64px); opacity:.75; }
.pm-aurora span{ position:absolute; border-radius:50%; mix-blend-mode:multiply; display:block; }
.pm-aurora span:nth-child(1){ width:420px;height:420px;background:#bcd2ff; top:-100px; left:-70px; animation:auroraA 16s ease-in-out infinite; }
.pm-aurora span:nth-child(2){ width:340px;height:340px;background:#c9ddff; top:10px; right:8%; animation:auroraB 22s ease-in-out infinite; }
.pm-aurora span:nth-child(3){ width:320px;height:320px;background:#d3f0e2; bottom:-110px; left:32%; animation:auroraC 19s ease-in-out infinite; }
@keyframes auroraA{ 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(40px,30px) scale(1.08)} }
@keyframes auroraB{ 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(-34px,42px) scale(1.05)} }
@keyframes auroraC{ 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(30px,-28px) scale(1.1)} }
@media (prefers-reduced-motion:reduce){ .pm-aurora span{ animation:none; } }

/* Galería */
.pm-gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:44px; }
@media(max-width:900px){ .pm-gallery{ grid-template-columns:repeat(2,1fr); } }
.pm-gitem{ position:relative; aspect-ratio:1/1; border-radius:14px; overflow:hidden; cursor:pointer; background:var(--bg-soft); border:1px solid var(--line); }
.pm-gitem img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); display:block; }
.pm-gitem:hover img{ transform:scale(1.08); }
.pm-gitem::after{ content:"⤢"; position:absolute; inset:0; display:grid; place-items:center; background:rgba(14,22,38,.32); color:#fff; opacity:0; transition:opacity .25s; font-size:26px; }
.pm-gitem:hover::after{ opacity:1; }
.pm-gempty{ grid-column:1/-1; text-align:center; color:var(--muted); padding:30px 0; }

/* Lightbox */
.pm-lb{ position:fixed; inset:0; z-index:3000; display:none; align-items:center; justify-content:center; background:rgba(8,14,26,.92); padding:20px; }
.pm-lb.open{ display:flex; }
.pm-lb img{ max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:0 30px 90px rgba(0,0,0,.55); }
.pm-lb button{ position:absolute; background:none; border:0; color:#fff; cursor:pointer; }
.pm-lb-x{ top:18px; right:24px; font-size:36px; line-height:1; }
.pm-lb-nav{ top:50%; transform:translateY(-50%); font-size:44px; padding:0 16px; opacity:.75; }
.pm-lb-nav:hover{ opacity:1; }
.pm-lb-prev{ left:6px; } .pm-lb-next{ right:6px; }

/* Docentes */
.pm-team{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; margin-top:44px; }
@media(max-width:900px){ .pm-team{ grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .pm-team{ grid-template-columns:1fr; } }
.pm-teacher{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px; text-align:center; transition:transform .25s var(--ease), box-shadow .25s var(--ease); }
.pm-teacher:hover{ transform:translateY(-6px); box-shadow:0 26px 60px rgba(14,22,38,.12); }
.pm-teacher .av{ width:84px;height:84px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:800;font-size:30px;color:#fff;background:linear-gradient(135deg,#1d4ed8,#22c55e); }
.pm-teacher h4{ font-size:17px; }
.pm-teacher .rol{ color:var(--accent); font-size:13px; font-weight:700; font-family:'Sora',sans-serif; margin-top:3px; }
.pm-teacher p{ font-size:13.5px; color:var(--body); margin-top:10px; }

/* ============================================================
   VIDEO INSTITUCIONAL + NOTICIAS
   ============================================================ */
.pm-video-band{ position:relative; border-radius:24px; overflow:hidden; min-height:340px; display:grid; place-items:center;
  background:linear-gradient(135deg,#0e1626,#1742b8); color:#fff; text-align:center; padding:64px 24px; }
.pm-video-band::before{ content:""; position:absolute; inset:0; background:url('../img/FOTO.png') center 18%/cover no-repeat; opacity:.16; }
.pm-video-band > *{ position:relative; z-index:1; }
.pm-video-band h2{ color:#fff; }
.pm-video-band p{ color:rgba(255,255,255,.82); max-width:540px; margin:12px auto 0; }
.pm-play{ width:76px; height:76px; border-radius:50%; background:#fff; color:#1d4ed8; display:grid; place-items:center;
  font-size:26px; cursor:pointer; border:0; margin:0 auto 20px; box-shadow:0 16px 44px rgba(0,0,0,.34); transition:transform .2s var(--ease); }
.pm-play::before{ content:"▶"; margin-left:5px; }
.pm-play:hover{ transform:scale(1.09); }
.pm-vmodal{ position:fixed; inset:0; z-index:3000; display:none; align-items:center; justify-content:center; background:rgba(8,14,26,.93); padding:20px; }
.pm-vmodal.open{ display:flex; }
.pm-vmodal video{ max-width:92vw; max-height:86vh; border-radius:12px; box-shadow:0 30px 90px rgba(0,0,0,.55); background:#000; }
.pm-vmodal .pm-lb-x{ position:absolute; top:18px; right:24px; color:#fff; font-size:36px; background:none; border:0; cursor:pointer; }

/* Noticias */
.pm-news{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:44px; }
@media(max-width:900px){ .pm-news{ grid-template-columns:1fr; } }
.pm-newscard{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; cursor:pointer; transition:transform .25s var(--ease), box-shadow .25s var(--ease); }
.pm-newscard:hover{ transform:translateY(-6px); box-shadow:0 26px 60px rgba(14,22,38,.12); }
.pm-newscard .img{ aspect-ratio:16/9; background:var(--bg-soft); overflow:hidden; }
.pm-newscard .img img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.pm-newscard:hover .img img{ transform:scale(1.06); }
.pm-newscard .body{ padding:22px; display:flex; flex-direction:column; gap:8px; flex:1; }
.pm-newscard .date{ font-size:12px; color:var(--accent); font-weight:700; font-family:'Sora',sans-serif; letter-spacing:.04em; }
.pm-newscard h3{ font-size:18px; }
.pm-newscard .ex{ font-size:14px; color:var(--body); flex:1; }
.pm-newscard .more{ font-family:'Sora',sans-serif; font-weight:700; font-size:13.5px; color:var(--ink); }
/* Modal noticia (reusa pm-modal) imagen arriba */
.pm-news-img{ width:100%; aspect-ratio:16/8; object-fit:cover; display:block; }
.pm-news-cont{ font-size:15px; color:var(--body); line-height:1.8; white-space:pre-line; }

/* ============================================================
   MODAL DE CURSO + MALLA CURRICULAR (interactivo)
   ============================================================ */
.pm-modal{ position:fixed; inset:0; z-index:2000; display:none; align-items:center; justify-content:center; padding:20px; }
.pm-modal.open{ display:flex; }
.pm-modal-backdrop{ position:absolute; inset:0; background:rgba(8,14,26,.55); backdrop-filter:blur(6px); }
.pm-modal-panel{ position:relative; z-index:1; width:min(760px,100%); max-height:90vh; overflow-y:auto;
  background:#fff; border-radius:22px; box-shadow:0 50px 120px rgba(8,14,26,.5); }
.pm-modal-hd{ position:sticky; top:0; z-index:2; background:linear-gradient(135deg,#0e1626,#16233d); color:#fff; padding:26px 28px; border-radius:22px 22px 0 0; }
.pm-modal-hd .tag{ font-family:'Sora',sans-serif; font-size:11px; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:#9db4ff; }
.pm-modal-hd h3{ color:#fff; font-size:clamp(22px,3vw,30px); margin-top:8px; }
.pm-modal-close{ position:absolute; top:18px; right:18px; width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.12); color:#fff; cursor:pointer; font-size:20px; display:grid; place-items:center; }
.pm-modal-body{ padding:24px 28px 28px; }
.pm-info-chips{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:18px; }
.pm-info-chips .chip{ display:inline-flex; flex-direction:column; padding:10px 16px; border-radius:12px; background:var(--accent-soft); border:1px solid #dbe5ff; }
.pm-info-chips .chip small{ font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); font-weight:800; font-family:'Sora',sans-serif; }
.pm-info-chips .chip b{ font-size:14px; color:var(--ink); font-family:'Sora',sans-serif; }
.pm-modal-desc{ font-size:15px; color:var(--body); margin-bottom:18px; }
.pm-badges2{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.pm-badges2 span{ font-size:12.5px; font-weight:600; color:var(--ink); background:#f1f4fa; border:1px solid var(--line); border-radius:999px; padding:7px 13px; }
.pm-malla-h{ font-family:'Sora',sans-serif; font-size:13px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); margin-bottom:6px; }
.pm-malla-sub{ font-size:14px; color:var(--body); margin-bottom:16px; }
.pm-malla details{ border:1px solid var(--line); border-radius:14px; margin-bottom:10px; overflow:hidden; background:#fff; transition:border-color .2s; }
.pm-malla details[open]{ border-color:#cdd7ea; }
.pm-malla summary{ list-style:none; cursor:pointer; display:flex; align-items:center; gap:14px; padding:16px 18px; font-family:'Sora',sans-serif; font-weight:700; font-size:14.5px; color:var(--ink); }
.pm-malla summary::-webkit-details-marker{ display:none; }
.pm-malla summary .nm{ width:30px; height:30px; flex-shrink:0; border-radius:9px; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; font-size:13px; font-weight:800; }
.pm-malla summary::after{ content:"+"; margin-left:auto; color:var(--accent); font-size:20px; transition:transform .2s; }
.pm-malla details[open] summary::after{ transform:rotate(45deg); }
.pm-malla ul{ list-style:none; padding:0 18px 18px 62px; margin:0; }
.pm-malla ul li{ position:relative; font-size:13.5px; color:var(--body); padding:5px 0 5px 16px; }
.pm-malla ul li::before{ content:""; position:absolute; left:0; top:13px; width:6px; height:6px; border-radius:50%; background:var(--accent); }
.pm-modal-cta{ margin-top:22px; display:flex; gap:12px; flex-wrap:wrap; }
.pm-modal-cta .pm-btn{ flex:1; min-width:180px; }
body.pm-lock{ overflow:hidden; }
@media(max-width:560px){
  .pm-modal{ padding:0; align-items:flex-end; }
  .pm-modal-panel{ max-height:94vh; border-radius:20px 20px 0 0; }
  .pm-modal-hd{ border-radius:20px 20px 0 0; }
  .pm-malla ul{ padding-left:18px; }
}
