/* ============================================================
   IDPE — equipo-docente specific styles
   ============================================================ */

a{text-decoration:none;color:inherit}

ul,ol{list-style:none}

.skip-link:focus{top:1rem}

.page-hero__shapes{position:absolute;inset:0;pointer-events:none;overflow:hidden}

.page-hero__shape{position:absolute;border-radius:50%;animation:float-shape 20s ease-in-out infinite}

.page-hero__shape--1{width:350px;height:350px;top:-80px;right:-50px;background:radial-gradient(circle,rgba(42,191,191,.1) 0%,transparent 65%);border:1.5px solid rgba(42,191,191,.15);animation-duration:12s}

.page-hero__shape--2{width:200px;height:200px;bottom:10%;left:-40px;background:rgba(42,191,191,.06);border:1.5px solid rgba(42,191,191,.12);animation-duration:9s;animation-delay:-3s}

.page-hero__shape--3{width:150px;height:150px;top:30%;left:15%;background:rgba(42,191,191,.05);border:1px solid rgba(42,191,191,.1);animation-duration:14s;animation-delay:-5s;animation-name:float-shape-alt}

.page-hero__grid{position:absolute;inset:0;pointer-events:none;opacity:.04;background-image:linear-gradient(rgba(42,191,191,1) 1px,transparent 1px),linear-gradient(90deg,rgba(42,191,191,1) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 70%)}

/* ===== FILOSOFIA / PILLARS ===== */
.pillars-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}

@media(min-width:768px){.pillars-grid{grid-template-columns:repeat(3,1fr)}}

.pillar-card{background:var(--color-bg-pure);border-radius:var(--radius-lg);padding:2.25rem 1.75rem;border:1px solid var(--color-border-light);transition:all var(--duration-normal) var(--ease-out-expo);position:relative;overflow:hidden;text-align:center}

.pillar-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));transform:scaleX(0);transition:transform var(--duration-normal) var(--ease-out-expo)}

.pillar-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card-hover)}

.pillar-card:hover::after{transform:scaleX(1)}

.pillar-card__icon{width:60px;height:60px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary-glass-md),var(--color-primary-glass));display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:var(--color-primary-dark);transition:all var(--duration-normal) var(--ease-out-expo)}

.pillar-card:hover .pillar-card__icon{background:linear-gradient(135deg,rgba(42,191,191,.25),rgba(42,191,191,.12));box-shadow:0 0 20px rgba(42,191,191,.15);transform:translateY(-2px)}

.pillar-card__title{font-family:var(--font-heading);font-size:var(--font-size-base);font-weight:900;margin-bottom:.5rem}

.pillar-card__text{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.65}

/* ===== STATS (dark section) ===== */
.team-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}

@media(min-width:768px){.team-stats{grid-template-columns:repeat(4,1fr)}}

.team-stat{text-align:center;padding:2.25rem 1rem;background:rgba(255,255,255,.04);border-radius:var(--radius-lg);backdrop-filter:blur(12px);border:1px solid rgba(42,191,191,.1);transition:all var(--duration-normal) var(--ease-out-expo)}

.team-stat:hover{background:rgba(42,191,191,.06);border-color:rgba(42,191,191,.2);transform:translateY(-3px)}

.team-stat__number{font-family:var(--font-heading);font-size:var(--font-size-2xl);font-weight:800;color:var(--color-primary-light);letter-spacing:-.02em}

.team-stat__label{font-size:var(--font-size-sm);color:rgba(255,255,255,.5);margin-top:.35rem;font-weight:500}

/* ===== DIRECTOR ===== */
.director-card{display:grid;grid-template-columns:1fr;gap:var(--space-md);align-items:center;background:var(--color-bg-pure);border-radius:var(--radius-xl);padding:3rem;border:1px solid var(--color-border-light);box-shadow:var(--shadow-md)}

@media(min-width:768px){.director-card{grid-template-columns:auto 1fr}}

.director-card__photo{width:180px;height:180px;border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--color-primary-glass-md),var(--color-primary-glass));display:flex;align-items:center;justify-content:center;margin:0 auto;border:2px solid rgba(42,191,191,.15);overflow:hidden;color:var(--color-primary-dark);transition:all var(--duration-normal) var(--ease-out-expo)}

.director-card__photo:hover{border-color:rgba(42,191,191,.3);box-shadow:0 12px 40px rgba(42,191,191,.15);transform:translateY(-3px)}

.director-card__photo img{width:100%;height:100%;object-fit:cover}

@media(min-width:768px){.director-card__photo{margin:0}}

.director-card__name{font-family:var(--font-heading);font-size:var(--font-size-xl);font-weight:900}

.director-card__role{font-size:var(--font-size-sm);color:var(--color-primary-dark);font-weight:700;margin-bottom:1rem;display:flex;align-items:center;gap:.4rem}

.director-card__bio{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.8;margin-bottom:1.25rem}

.director-card__linkedin{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-heading);font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary);transition:all var(--duration-fast)}

.director-card__linkedin:hover{color:var(--color-primary-dark);gap:.7rem}

/* ===== TEAM GRID ===== */
.team-filter{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:var(--space-md)}

.team-filter__btn{padding:.5rem 1.25rem;font-family:var(--font-heading);font-size:var(--font-size-xs);font-weight:700;border-radius:var(--radius-full);border:1.5px solid var(--color-border);background:var(--color-bg-pure);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-out-expo)}

.team-filter__btn:hover{border-color:var(--color-primary);color:var(--color-primary)}

.team-filter__btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}

.docentes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}

@media(min-width:1024px){.docentes-grid{grid-template-columns:repeat(4,1fr)}}

.docente-card{background:var(--color-bg-pure);border-radius:var(--radius-lg);padding:2rem 1.5rem;border:1px solid var(--color-border-light);transition:all var(--duration-normal) var(--ease-out-expo);text-align:center;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center}

.docente-card::before{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);padding:1.5px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light),transparent 60%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity var(--duration-normal);pointer-events:none}

.docente-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover);border-color:transparent}

.docente-card:hover::before{opacity:1}

.docente-card__photo{width:110px;height:110px;border-radius:50%;background:linear-gradient(135deg,var(--color-surface),var(--color-border-light));display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;overflow:hidden;border:3px solid var(--color-bg);box-shadow:0 4px 16px rgba(0,0,0,.08);transition:all var(--duration-normal) var(--ease-out-expo);color:var(--color-text-muted);position:relative}

.docente-card:hover .docente-card__photo{border-color:var(--color-primary-light);box-shadow:var(--shadow-glow);transform:scale(1.05)}

.docente-card__photo img{width:100%;height:100%;object-fit:cover}

.docente-card__initials{font-family:var(--font-heading);font-size:1.6rem;font-weight:800;color:var(--color-primary-dark);letter-spacing:-.02em}

.docente-card__name{font-family:var(--font-heading);font-size:var(--font-size-base);font-weight:800;margin-bottom:.2rem;line-height:1.2}

.docente-card__title{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:.3rem;line-height:1.5;min-height:2.5em}

.docente-card__area{display:inline-flex;align-items:center;gap:.35rem;font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary-dark);background:var(--color-primary-pale);padding:.2rem .7rem;border-radius:var(--radius-full);margin-bottom:.85rem}

.docente-card__linkedin{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-heading);font-size:var(--font-size-xs);font-weight:700;color:var(--color-primary);transition:all var(--duration-fast);padding:.35rem .8rem;border-radius:var(--radius-full);border:1.5px solid rgba(42,191,191,.2);background:rgba(42,191,191,.03);position:relative;z-index:2;cursor:pointer}

.docente-card__linkedin:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-1px)}

.docente-card__linkedin svg{width:14px;height:14px}

/* Placeholder notice */
.placeholder-notice{background:linear-gradient(135deg,rgba(42,191,191,.05),rgba(42,191,191,.02));border:1px dashed rgba(42,191,191,.2);border-radius:var(--radius-lg);padding:1.5rem 2rem;text-align:center;margin-top:var(--space-md)}

.placeholder-notice__text{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.6}

.placeholder-notice__text strong{color:var(--color-primary-dark);font-weight:700}

/* ===== CTA BANNER ===== */
.cta-banner{padding:var(--space-xl) 0;position:relative;overflow:hidden}

.cta-banner--photo{background-size:cover;background-position:center;background-repeat:no-repeat}

.cta-banner--photo::before{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,26,26,.92),rgba(13,79,79,.88))}

.cta-banner__title{font-family:var(--font-heading);font-size:var(--font-size-2xl);color:#fff;margin-bottom:var(--space-sm);position:relative;z-index:1}

.cta-banner__text{font-size:var(--font-size-lg);color:rgba(255,255,255,.6);max-width:550px;margin:0 auto var(--space-md);line-height:1.65;position:relative;z-index:1}