/* ============================================================
   ARTE7 — Escuela de Cine · Sistema de diseño (legacy, sin RVOE)
   Paleta y tipografías canónicas. Voz: cinematográfica, lo-fi, comunitaria.
   ============================================================ */

:root{
  /* Marca */
  --ink:#0E0E0E;        /* fondo base, casi negro fílmico */
  --ink-2:#161616;      /* superficies */
  --ink-3:#1F1E1C;      /* cards */
  --negro:#1A1A1A;
  --crema:#FDF3E0;
  --crema-dim:rgba(253,243,224,.66);
  --crema-faint:rgba(253,243,224,.40);
  --line:rgba(253,243,224,.14);
  --coral:#FF492F;      /* acento principal / Online A7D */
  --teal:#038B96;       /* Querétaro */
  --naranja:#EE9628;    /* CDMX */
  --marron:#9D2F20;

  /* Tipografía */
  --display:'Bebas Neue', Impact, sans-serif;
  --body:'Space Grotesk', system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;

  /* Ritmo */
  --maxw:1240px;
  --gut:clamp(20px,5vw,64px);
  --r:4px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--ink);
  color:var(--crema);
  font-family:var(--body);
  font-weight:400;
  line-height:1.6;
  font-size:clamp(16px,1.05vw,18px);
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--coral);color:#fff}

/* Grano fílmico sutil (NO es cuadrícula) */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Tipografía / utilidades ---------- */
.display{font-family:var(--display);font-weight:400;line-height:.92;letter-spacing:.01em;text-transform:uppercase}
.kicker{
  font-family:var(--mono);font-size:clamp(11px,1.1vw,13px);font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--crema-dim);
}
.kicker .dot{color:var(--coral)}
.lead{font-size:clamp(18px,1.7vw,22px);line-height:1.5;color:var(--crema-dim);font-weight:300}
.section{padding:clamp(72px,11vw,150px) 0;position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--coral)}
.muted{color:var(--crema-dim)}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  padding:15px 26px;border:1px solid var(--coral);border-radius:var(--r);
  background:var(--coral);color:#fff;cursor:pointer;transition:.25s ease;
}
.btn:hover{background:transparent;color:var(--coral);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--crema);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--crema);color:var(--crema);background:rgba(253,243,224,.04)}
.btn .arr{transition:transform .25s ease}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- Header ---------- */
.site-head{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--gut);transition:.3s ease;
  border-bottom:1px solid transparent;
}
.site-head.scrolled{background:rgba(14,14,14,.86);backdrop-filter:blur(10px);border-bottom-color:var(--line);padding:11px var(--gut)}
.site-head .brand img{height:clamp(52px,4.2vw,74px);width:auto;transition:.3s ease}
.site-head.scrolled .brand img{height:clamp(44px,3.4vw,58px)}
.nav{display:flex;align-items:center;gap:30px}
.nav a:not(.btn){font-family:var(--mono);font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--crema-dim);transition:.2s}
.nav a:not(.btn):hover{color:var(--crema)}
.nav-toggle{display:none;background:none;border:0;color:var(--crema);cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.nav-toggle span{width:26px;height:2px;background:var(--crema);transition:.3s}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.25) contrast(1.05) brightness(.62)}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,14,14,.55) 0%,rgba(14,14,14,.25) 38%,rgba(14,14,14,.92) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut) clamp(54px,8vw,96px)}
.hero h1{font-family:var(--display);font-size:clamp(58px,12vw,168px);line-height:.86;letter-spacing:.012em;text-transform:uppercase;margin:18px 0 0}
.hero h1 .accent{color:var(--coral)}
.hero__sub{max-width:620px;margin:26px 0 34px;font-size:clamp(17px,1.7vw,21px);line-height:1.5;color:var(--crema-dim);font-weight:300}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}
.hero__scroll{position:absolute;right:var(--gut);bottom:34px;z-index:2;writing-mode:vertical-rl;
  font-family:var(--mono);font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--crema-faint)}
/* marco de cine (esquinas) */
.frame-corner{position:absolute;z-index:3;width:26px;height:26px;border:2px solid var(--crema-faint)}
.fc-tl{top:96px;left:var(--gut);border-right:0;border-bottom:0}
.fc-br{bottom:30px;right:calc(var(--gut) + 38px);border-left:0;border-top:0}

/* ---------- Strip aliados (marquee estático) ---------- */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink-2)}
.strip__row{display:flex;align-items:center;gap:clamp(34px,6vw,80px);flex-wrap:wrap;justify-content:center;padding:26px var(--gut)}
.strip__label{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--crema-faint)}
.strip img{width:auto;height:auto;max-height:30px;max-width:140px;object-fit:contain;opacity:.72;filter:grayscale(1) brightness(1.6);transition:.3s}
.strip img[alt="CinemaDaMare"]{max-height:34px;max-width:34px}
.strip img[alt="Mañana Film Festival"]{max-height:34px;max-width:74px}
/* ECAES tiene texto oscuro en fondo transparente → invertir para que quede blanco */
.strip img[alt="ECAES"]{filter:invert(1) grayscale(1) brightness(1.3)}
.strip img:hover{opacity:1;filter:none}
.strip img[alt="ECAES"]:hover{filter:invert(1) brightness(1.4);opacity:1}

/* ---------- Tarjetas de programa: imagen + título, hover revela info ---------- */
.pcard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px;margin-top:6px}
.pcard{position:relative;aspect-ratio:4/5;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--ink-2);isolation:isolate;cursor:pointer;outline:none}
.pcard:focus-visible{box-shadow:0 0 0 2px var(--coral)}
.pcard__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1),filter .45s;filter:grayscale(.25) brightness(.92)}
.pcard:hover .pcard__img,.pcard:focus-within .pcard__img{transform:scale(1.06);filter:grayscale(0) brightness(1)}
/* Licenciatura: foto siempre en blanco y negro (no recupera color en hover) */
.pcard--bn .pcard__img,.pcard--bn:hover .pcard__img,.pcard--bn:focus-within .pcard__img{filter:grayscale(1) brightness(.9)}
.pcard::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(11,11,12,.04) 26%,rgba(11,11,12,.5) 56%,rgba(11,11,12,.93));transition:background .45s}
.pcard:hover::after,.pcard:focus-within::after{background:linear-gradient(180deg,rgba(11,11,12,.45),rgba(11,11,12,.95))}
.pcard__overlay{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:22px}
.pcard__tag{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);margin-bottom:8px}
.pcard__title{font-family:var(--display);font-size:clamp(26px,3.3vw,40px);line-height:.92;text-transform:uppercase;color:var(--crema)}
.pcard__more{display:grid;grid-template-rows:0fr;opacity:0;transition:grid-template-rows .5s cubic-bezier(.2,.7,.2,1),opacity .4s,margin-top .4s;margin-top:0}
.pcard__more>div{overflow:hidden;min-height:0}
.pcard:hover .pcard__more,.pcard:focus-within .pcard__more{grid-template-rows:1fr;opacity:1;margin-top:14px}
.pcard__meta{display:flex;flex-direction:column;gap:5px;font-size:12.5px;color:rgba(253,243,224,.88);margin-bottom:11px}
.pcard__meta b{color:#fff;font-weight:600}
.pcard__desc{font-size:13px;line-height:1.5;color:rgba(253,243,224,.82);margin-bottom:9px}
.pcard__norvoe{display:none}
.pcard .btn{font-size:12px;padding:11px 18px;display:inline-block}
@media(hover:none){.pcard__more{grid-template-rows:1fr;opacity:1;margin-top:14px}.pcard::after{background:linear-gradient(180deg,rgba(11,11,12,.45),rgba(11,11,12,.95))}}

/* ---------- Secciones de título ---------- */
.sec-head{margin-bottom:clamp(40px,6vw,68px);max-width:760px}
.sec-head h2{font-family:var(--display);font-size:clamp(40px,6.5vw,92px);line-height:.92;text-transform:uppercase}
.sec-head .lead{margin-top:18px}

/* ---------- Pilares ---------- */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.pillar{background:var(--ink);padding:clamp(28px,3vw,40px)}
.pillar .num{font-family:var(--mono);font-size:12px;color:var(--coral);letter-spacing:.1em}
.pillar h3{font-family:var(--display);font-size:clamp(26px,2.4vw,34px);margin:16px 0 10px;text-transform:uppercase;letter-spacing:.02em}
.pillar p{font-size:15.5px;color:var(--crema-dim)}

/* ---------- Programas ---------- */
.progs{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:18px}
.prog{position:relative;background:var(--ink-3);border:1px solid var(--line);border-radius:var(--r);
  padding:30px;display:flex;flex-direction:column;min-height:280px;transition:.28s ease;overflow:hidden}
.prog::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--coral);transform:scaleY(0);transform-origin:top;transition:.3s ease}
.prog:hover{transform:translateY(-4px);border-color:rgba(253,243,224,.28);background:#23211e}
.prog:hover::before{transform:scaleY(1)}
.prog__meta{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--crema-faint);display:flex;justify-content:space-between;align-items:center}
.prog.star .prog__meta .tag{color:var(--coral)}
.prog h3{font-family:var(--display);font-size:clamp(28px,2.6vw,38px);margin:18px 0 12px;text-transform:uppercase;letter-spacing:.015em;line-height:.95}
.prog p{font-size:15px;color:var(--crema-dim);flex:1}
.prog__foot{margin-top:22px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.sedes-dots{display:flex;gap:7px;align-items:center}
.dot-sede{width:9px;height:9px;border-radius:50%}
.dot-cdmx{background:var(--naranja)} .dot-qro{background:var(--teal)} .dot-online{background:var(--coral)}
.prog__link{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--crema);border-bottom:1px solid var(--coral);padding-bottom:2px}
.norvoe{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--crema-faint);margin-top:14px}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:30px;text-align:center;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(44px,6vw,72px) 0}
.stat .n{font-family:var(--display);font-size:clamp(52px,7vw,96px);line-height:1;color:var(--crema)}
.stat .n .s{color:var(--coral)}
.stat .l{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--crema-dim);margin-top:8px}

/* ---------- Comunidad ---------- */
.comm{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.comm-card{border:1px solid var(--line);border-radius:var(--r);padding:34px;background:var(--ink-2);transition:.28s}
.comm-card:hover{background:var(--ink-3);transform:translateY(-4px)}
.comm-card .tag{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--coral)}
.comm-card h3{font-family:var(--display);font-size:clamp(30px,3vw,42px);margin:14px 0 12px;text-transform:uppercase}
.comm-card p{color:var(--crema-dim);font-size:15px}

/* ---------- Docentes teaser ---------- */
.teach{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.teach__faces{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.face{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:var(--r);border:1px solid var(--line)}
.face img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);transition:.4s}
.face:hover img{filter:none;transform:scale(1.04)}

/* ---------- Sedes ---------- */
.sedes{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.sede{position:relative;border:1px solid var(--line);border-radius:var(--r);padding:32px;background:var(--ink-2);overflow:hidden}
.sede::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}
.sede.cdmx::after{background:var(--naranja)} .sede.qro::after{background:var(--teal)} .sede.online::after{background:var(--coral)} .sede.mid::after{background:var(--marron)}
.sede.cdmx .badge{color:var(--naranja)} .sede.qro .badge{color:var(--teal)} .sede.online .badge{color:var(--coral)} .sede.mid .badge{color:var(--marron)}
.sede .city{font-family:var(--display);font-size:clamp(30px,3vw,44px);text-transform:uppercase;letter-spacing:.02em}
.sede .badge{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.sede.cdmx .badge{color:var(--naranja)} .sede.qro .badge{color:var(--teal)} .sede.online .badge{color:var(--coral)}
.sede address{font-style:normal;color:var(--crema-dim);font-size:15px;margin-top:12px;line-height:1.55}

/* ---------- CTA ---------- */
.cta{background:var(--coral);color:#120402;text-align:center}
.cta h2{font-family:var(--display);font-size:clamp(44px,8vw,120px);line-height:.9;text-transform:uppercase;color:#140402}
.cta p{max-width:560px;margin:18px auto 32px;color:#3a120c;font-size:18px}
.cta .btn{background:#140402;border-color:#140402;color:var(--crema)}
.cta .btn:hover{background:transparent;color:#140402}
.cta .btn--ghost{background:transparent;color:#140402;border-color:rgba(20,4,2,.4)}

/* ---------- Footer ---------- */
.foot{background:#0a0a0a;border-top:1px solid var(--line);padding:clamp(56px,7vw,88px) 0 30px}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:48px}
.foot__brand img{height:56px;margin-bottom:18px}
.foot__brand p{color:var(--crema-dim);font-size:14.5px;max-width:320px}
.foot h4{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--crema-faint);margin-bottom:16px}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot ul a{color:var(--crema-dim);font-size:14.5px;transition:.2s}
.foot ul a:hover{color:var(--coral)}
.pa7-bridge{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0;margin-bottom:24px;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px}
.pa7-bridge p{font-size:14px;color:var(--crema-dim);max-width:640px}
.pa7-bridge a{color:var(--crema);border-bottom:1px solid var(--coral);font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}
.foot__legal{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;align-items:center}
.foot__legal small{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--crema-faint);line-height:1.6}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:880px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(80vw,340px);background:var(--ink-2);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;padding:40px;
    transform:translateX(100%);transition:.35s ease;border-left:1px solid var(--line)}
  .nav.open{transform:none}
  /* la hamburguesa queda por encima del drawer abierto para poder cerrarlo */
  .nav-toggle{display:flex;position:relative;z-index:2}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .teach{grid-template-columns:1fr}
  .foot__top{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .foot__top{grid-template-columns:1fr}
  .hero__scroll,.frame-corner{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   SUB-PÁGINAS (docentes, programas)
   ============================================================ */
body.subpage .site-head{background:rgba(14,14,14,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.page-band{padding:calc(clamp(90px,14vw,140px) + 28px) 0 clamp(40px,6vw,68px);border-bottom:1px solid var(--line);background:var(--ink-2)}
.page-band h1{font-family:var(--display);font-size:clamp(54px,9vw,124px);line-height:.9;text-transform:uppercase}
.page-band .lead{max-width:660px;margin-top:14px}

/* Docentes */
.doc-group{margin-top:clamp(38px,6vw,60px)}
.doc-group__head{display:flex;align-items:baseline;gap:16px;margin-bottom:26px;border-bottom:1px solid var(--line);padding-bottom:14px}
.doc-group__head h2{font-family:var(--display);font-size:clamp(28px,3.4vw,46px);text-transform:uppercase;letter-spacing:.02em}
.doc-group__head .count{font-family:var(--mono);font-size:12px;color:var(--coral);letter-spacing:.1em}
.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(216px,1fr));gap:16px}
.doc-card{background:var(--ink-3);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:.28s}
.doc-card:hover{transform:translateY(-4px);border-color:rgba(253,243,224,.28)}
.doc-photo{aspect-ratio:3/4;overflow:hidden;background:var(--negro)}
.doc-photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.04);transition:.45s}
.doc-card:hover .doc-photo img{filter:none;transform:scale(1.04)}
.doc-initials{aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;background:linear-gradient(150deg,#231f1a,#141008);font-family:var(--display);font-size:clamp(44px,5vw,68px);color:var(--coral);letter-spacing:.04em}
.doc-body{padding:16px 16px 20px}
.doc-area{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--coral);line-height:1.4}
.doc-name{font-family:var(--body);font-weight:600;font-size:16.5px;margin:7px 0 8px;line-height:1.18}
.doc-bio{font-size:12.5px;color:var(--crema-dim);line-height:1.5;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}

/* Programa — detalle */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;padding:clamp(44px,6vw,78px) 0;border-bottom:1px solid var(--line)}
.pd:nth-child(even) .pd__media{order:2}
.pd__media{aspect-ratio:4/3;overflow:hidden;border-radius:var(--r);border:1px solid var(--line)}
.pd__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.25) brightness(.82)}
.pd .star-tag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--coral)}
.pd h2{font-family:var(--display);font-size:clamp(34px,4.6vw,66px);line-height:.94;text-transform:uppercase;margin-top:6px}
.pd__meta{display:flex;flex-wrap:wrap;gap:8px 24px;font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--crema-faint);margin:16px 0 18px}
.pd__meta b{color:var(--crema);font-weight:600}
.pd p:not(.norvoe){color:var(--crema-dim);font-size:16px}
.pd .norvoe{position:static;margin:16px 0 22px;display:block}
@media(max-width:820px){.pd{grid-template-columns:1fr;gap:22px}.pd:nth-child(even) .pd__media{order:0}}

/* ---------- Galería de pósters (Filmografía profesional) ---------- */
.poster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.poster{margin:0;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--ink-2);transition:.35s}
.poster:hover{transform:translateY(-3px);border-color:var(--coral)}
.poster img{width:100%;height:auto;aspect-ratio:2/3;object-fit:cover;display:block;filter:grayscale(.2) brightness(.95);transition:.4s}
.poster:hover img{filter:none}
.poster figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--crema-dim);padding:11px 13px}

/* ---------- Diplomados a detalle (plan de estudios) ---------- */
.dip-grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);margin-top:8px}
.dip{background:var(--ink);padding:clamp(24px,3.5vw,40px)}
.dip h3{font-family:var(--display);font-size:clamp(28px,3.6vw,46px);line-height:.95;text-transform:uppercase;color:var(--crema)}
.dip__meta{font-family:var(--mono);font-size:12px;letter-spacing:.07em;text-transform:uppercase;color:var(--coral);margin:9px 0 15px}
.dip__obj{font-size:15px;line-height:1.55;color:var(--crema-dim);max-width:74ch;margin-bottom:18px}
.dip__plan-label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--crema-faint)}
.dip__mats{display:flex;flex-wrap:wrap;gap:8px;margin-top:11px}
.dip__mats span{font-size:13px;padding:6px 13px;border:1px solid var(--line);border-radius:999px;color:var(--crema-dim)}
.dip__norvoe{margin-top:16px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--crema-faint)}

/* ---------- Micrositio de programa (detalle editorial) ---------- */
.prog-hero{position:relative;min-height:clamp(360px,50vw,600px);display:flex;align-items:flex-end;overflow:hidden;border-bottom:4px solid var(--coral)}
.prog-hero__bg{position:absolute;inset:0;z-index:-2}
.prog-hero__bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) brightness(.58)}
.prog-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,11,12,.2),rgba(11,11,12,.55) 55%,rgba(11,11,12,.96))}
.prog-hero__inner{max-width:var(--maxw);margin:0 auto;width:100%;padding:clamp(40px,7vw,96px) var(--gut)}
.prog-hero .k{font-family:var(--mono);font-size:clamp(12px,1.2vw,15px);letter-spacing:.24em;text-transform:uppercase;color:var(--coral);display:block;margin-bottom:16px}
.prog-hero h1{font-family:var(--display);font-size:clamp(50px,8.5vw,124px);line-height:.86;text-transform:uppercase;color:var(--crema);max-width:15ch}
.prog-datos{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.prog-datos .d{padding:clamp(18px,2.4vw,28px) clamp(16px,1.7vw,26px);border-left:1px solid var(--line);min-width:0}
.prog-datos .d:first-child{border-left:none}
.prog-datos .dl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--crema-faint);margin-bottom:10px}
.prog-datos .dv{font-family:var(--display);font-size:clamp(24px,2.5vw,36px);line-height:.95;text-transform:uppercase;color:var(--crema);overflow-wrap:break-word}
.prog-datos .dv small{display:block;font-family:var(--body);font-weight:400;font-size:12.5px;letter-spacing:0;text-transform:none;color:var(--crema-dim);margin-top:7px;line-height:1.35}
@media(max-width:560px){.prog-datos{grid-template-columns:1fr 1fr}.prog-datos .d:nth-child(2n+1){border-left:none}}
.prog-block{margin-top:clamp(52px,7vw,96px)}
.prog-block .k{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);display:flex;align-items:center;gap:14px;margin-bottom:24px}
.prog-block .k::before{content:"";width:36px;height:1px;background:var(--coral)}
.prog-obj-text{font-family:var(--body);font-weight:300;font-size:clamp(23px,2.9vw,38px);line-height:1.26;color:var(--crema);max-width:32ch}
.prog-plan{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:0 clamp(28px,4vw,64px);border-top:2px solid var(--coral)}
.prog-plan .it{display:flex;gap:18px;align-items:baseline;padding:clamp(15px,1.7vw,21px) 2px;border-bottom:1px solid var(--line)}
.prog-plan .it .no{font-family:var(--display);font-size:clamp(26px,2.6vw,38px);color:var(--coral);line-height:1;min-width:1.5em}
.prog-plan .it .ma{font-family:var(--body);font-weight:500;font-size:clamp(17px,1.7vw,22px);color:var(--crema);line-height:1.2}
.prog-foot{margin-top:clamp(40px,5vw,68px);display:flex;flex-direction:column;gap:22px}
.prog-foot .norvoe{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--crema-faint)}
.prog-cta{display:flex;gap:14px;flex-wrap:wrap}
.prog-cta .btn{font-size:clamp(14px,1.2vw,16px);padding:17px 34px}

/* ============================================================
   PUENTE → PROYECTO ARTE 7 (Licenciatura con RVOE · entidad independiente)
   ============================================================ */
/* Teaser compacto (después de Programas) */
.lic-teaser{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-top:30px;padding:24px 28px;border:1px solid rgba(255,73,47,.40);border-left:4px solid var(--coral);
  border-radius:var(--r);background:linear-gradient(100deg,rgba(255,73,47,.12),rgba(255,73,47,0) 62%);transition:.25s ease}
.lic-teaser:hover{background:linear-gradient(100deg,rgba(255,73,47,.20),rgba(255,73,47,.02) 62%);transform:translateY(-2px)}
.lic-teaser__txt .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--coral)}
.lic-teaser__txt h3{font-family:var(--display);font-size:clamp(24px,3vw,34px);letter-spacing:.015em;text-transform:uppercase;margin:7px 0 5px;color:var(--crema);line-height:.98}
.lic-teaser__txt p{font-size:14px;color:var(--crema-dim)}
.lic-teaser .go{font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--crema);border:1px solid var(--coral);border-radius:var(--r);padding:14px 24px;white-space:nowrap;transition:.25s}
.lic-teaser:hover .go{background:var(--coral);color:#fff}

/* Banda grande foto-botón (antes del footer) */
.licband{position:relative;display:block;min-height:clamp(440px,60vw,640px);overflow:hidden;border-top:3px solid var(--coral);isolation:isolate}
.licband__bg{position:absolute;inset:0;z-index:-2}
.licband__bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.5);transition:transform .6s ease,filter .6s ease}
.licband::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(105deg,rgba(10,10,10,.93) 0%,rgba(10,10,10,.72) 46%,rgba(10,10,10,.40) 100%)}
.licband:hover .licband__bg img{transform:scale(1.05);filter:grayscale(1) contrast(1.05) brightness(.58)}
.licband__inner{position:relative;max-width:var(--maxw);margin:0 auto;padding:clamp(56px,8vw,100px) var(--gut);display:flex;flex-direction:column;align-items:flex-start;gap:16px;min-height:inherit;justify-content:center}
.licband .k{font-family:var(--mono);font-size:clamp(11px,1.1vw,13px);letter-spacing:.2em;text-transform:uppercase;color:var(--coral)}
.licband h2{font-family:var(--display);font-size:clamp(46px,8.5vw,120px);line-height:.88;text-transform:uppercase;color:var(--crema);max-width:15ch}
.licband__by{display:flex;align-items:center;gap:14px;margin-top:4px;flex-wrap:wrap}
.licband__by img{height:clamp(32px,4vw,46px);width:auto}
.licband__by span{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--crema-dim)}
.licband p{max-width:570px;font-size:clamp(16px,1.6vw,19px);color:var(--crema-dim);font-weight:300}
.licband__cta{display:inline-flex;align-items:center;gap:12px;margin-top:10px;background:var(--coral);color:#fff;font-family:var(--mono);font-size:14px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:17px 30px;border-radius:var(--r);border:1px solid var(--coral);transition:.25s}
.licband:hover .licband__cta{background:transparent;color:var(--coral)}
.licband__cta .arr{transition:transform .25s ease}
.licband:hover .licband__cta .arr{transform:translateX(5px)}
.licband__micro{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--crema-faint)}
@media(max-width:560px){.lic-teaser{flex-direction:column;align-items:flex-start;gap:14px}.lic-teaser .go{width:100%;text-align:center}}

/* ===== Egresadxs ===== */
.egr-intro{max-width:700px}
.egr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.egr-card{background:var(--ink-3);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:.28s}
.egr-card:hover{transform:translateY(-4px);border-color:rgba(253,243,224,.28)}
.egr-photo{aspect-ratio:1/1;overflow:hidden;background:var(--negro)}
.egr-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:grayscale(1) contrast(1.03);transition:.45s}
.egr-card:hover .egr-photo img{filter:none;transform:scale(1.03)}
.egr-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.egr-role{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--coral)}
.egr-name{font-family:var(--display);font-size:clamp(24px,2.4vw,31px);letter-spacing:.02em;text-transform:uppercase;margin:7px 0 4px;line-height:.98}
.egr-proj{font-family:var(--mono);font-size:11.5px;color:var(--crema-dim);margin-bottom:13px}
.egr-quote{font-size:13.5px;line-height:1.55;color:var(--crema-dim);font-style:italic;border-left:2px solid var(--coral);padding-left:14px;margin-top:auto}
.egr-link{margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--crema);border-bottom:1px solid var(--coral);align-self:flex-start;padding-bottom:2px;transition:.2s}
.egr-link:hover{color:var(--coral)}

/* ============================================================
   OVERRIDES MOVIL (van al FINAL para ganar el orden de fuente;
   misma especificidad que reglas base pero declaradas despues)
   ============================================================ */
@media(max-width:880px){
  /* el backdrop-filter del header crea un containing-block para el .nav (position:fixed)
     y colapsa el drawer off-canvas a la altura del header (84px). Se anula en movil:
     el fondo del header ya es casi opaco (.86/.92), no se nota la perdida del blur. */
  .site-head,.site-head.scrolled,body.subpage .site-head{backdrop-filter:none;-webkit-backdrop-filter:none}
}
@media(max-width:560px){
  /* docentes: 2 columnas en telefono (en vez de 45 fichas en una sola columna) */
  .doc-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .doc-body{padding:13px 13px 16px}
  .doc-name{font-size:15px}
}
