/* ============================================================
   ISPNE — Instituto Superior Privado Nzenzu Estrela
   Global Stylesheet — UI/UX Pro Max Enhanced v2
   ============================================================ */

/* === RESET === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* === DESIGN TOKENS === */
:root{
  --g900:#0f3d1a;--g800:#1a5c2a;--g700:#236e33;--g600:#2d8c3e;
  --g500:#3da852;--g400:#5ec26e;--g300:#8dd49a;--g200:#b8e5c0;
  --g100:#dff2e3;--g50:#f0f9f1;
  --n900:#111;--n800:#1e1e1e;--n700:#333;--n600:#555;--n500:#777;
  --n400:#999;--n300:#bbb;--n200:#ddd;--n100:#eee;--n50:#f7f7f7;
  --white:#fff;
  --gold:#b8941f;--gold-light:#d4b44a;--gold-dark:#8c6f15;
  --color-primary:var(--g600);
  --color-primary-hover:var(--g700);
  --color-primary-active:var(--g800);
  --color-accent:var(--gold);
  --color-background:var(--white);
  --color-foreground:var(--n700);
  --color-heading:var(--n800);
  --color-muted:var(--n500);
  --color-border:var(--n100);
  --color-surface:var(--n50);
  --color-error:#dc2626;
  --color-success:var(--g600);
  --color-focus:var(--g400);
  --ff-display:'Cormorant Garamond',Georgia,serif;
  --ff-body:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --text-xs:.75rem;--text-sm:.84rem;--text-base:1rem;--text-md:1.05rem;
  --text-lg:1.15rem;--text-xl:1.35rem;--text-2xl:1.6rem;
  --text-3xl:clamp(1.8rem,3.8vw,2.8rem);--text-4xl:clamp(2.4rem,5vw,3.6rem);
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;
  --space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;
  --space-16:64px;--space-20:80px;--space-24:96px;
  --shadow-xs:0 1px 2px rgba(0,0,0,.04);
  --shadow-sm:0 2px 8px rgba(0,0,0,.06);
  --shadow-md:0 4px 16px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.04);
  --shadow-xl:0 20px 60px rgba(0,0,0,.12),0 4px 12px rgba(0,0,0,.06);
  --shadow-glow:0 8px 24px rgba(45,140,62,.25);
  --radius:10px;--radius-sm:6px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;
  --ease:cubic-bezier(.16,1,.3,1);--ease-spring:cubic-bezier(.34,1.56,.64,1);
  --ease-out:cubic-bezier(0,0,.2,1);
  --duration-fast:150ms;--duration-base:250ms;--duration-slow:400ms;
  --header-h:72px;--container-max:1180px;
  --z-dropdown:100;--z-sticky:200;--z-header:1000;--z-overlay:1100;--z-float:998;
}

/* === BASE === */
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + var(--space-6))}
body{font-family:var(--ff-body);font-size:var(--text-base);color:var(--color-foreground);background:var(--color-background);overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;transition:color var(--duration-fast) var(--ease)}
ul{list-style:none}
:focus-visible{outline:2px solid var(--color-focus);outline-offset:3px;border-radius:var(--radius-sm)}
:focus:not(:focus-visible){outline:none}

/* === SKIP LINK === */
.skip-link{position:absolute;top:-100%;left:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-primary);color:var(--white);border-radius:0 0 var(--radius) var(--radius);font-size:var(--text-sm);font-weight:600;z-index:9999;transition:top var(--duration-fast) var(--ease)}
.skip-link:focus{top:0}

/* === LAYOUT === */
.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--space-6)}
.page-section{padding:var(--space-24) 0}
.section-eyebrow{font-family:var(--ff-body);font-size:.7rem;font-weight:600;letter-spacing:3.5px;text-transform:uppercase;color:var(--color-primary);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-3)}
.section-eyebrow::before{content:'';width:28px;height:2px;background:var(--color-primary);border-radius:var(--radius-full);display:inline-block}
.text-center .section-eyebrow{justify-content:center}
.text-center .section-eyebrow::before{display:none}
.section-heading{font-family:var(--ff-display);font-size:var(--text-3xl);font-weight:700;color:var(--color-heading);line-height:1.15;margin-bottom:var(--space-4)}
.section-desc{font-size:var(--text-base);color:var(--color-muted);line-height:1.75;max-width:580px}
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}
.section-divider{width:60px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--g400));border-radius:var(--radius-full);margin:var(--space-4) 0 var(--space-8)}
.text-center .section-divider{margin-left:auto;margin-right:auto}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:13px 30px;border-radius:var(--radius-sm);font-family:var(--ff-body);font-size:var(--text-sm);font-weight:600;border:none;cursor:pointer;transition:all var(--duration-base) var(--ease);position:relative;overflow:hidden;min-height:44px}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.12),transparent);opacity:0;transition:opacity var(--duration-fast)}
.btn:hover::after{opacity:1}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--color-primary);color:var(--white)}
.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-glow)}
.btn-primary:active{background:var(--color-primary-active);transform:translateY(0) scale(.98)}
.btn-outline-dark{background:transparent;color:var(--color-foreground);border:1.5px solid var(--n200)}
.btn-outline-dark:hover{border-color:var(--color-primary);color:var(--color-primary)}
.btn-outline-light{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.3)}
.btn-outline-light:hover{border-color:var(--g400);color:var(--g400)}
.btn-white{background:var(--white);color:var(--g800)}
.btn-white:hover{background:var(--g50);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-sm{padding:9px 20px;font-size:.82rem;min-height:38px}
.btn-icon{width:44px;height:44px;padding:0;justify-content:center;border-radius:var(--radius)}

/* === HEADER === */
.header{position:fixed;top:0;left:0;width:100%;z-index:var(--z-header);transition:all var(--duration-slow) var(--ease);background:transparent}
.header.scrolled{background:rgba(255,255,255,.94);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);box-shadow:0 1px 0 rgba(0,0,0,.06),var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);max-width:var(--container-max);margin:0 auto;padding:0 var(--space-6)}
.logo{display:flex;align-items:center;gap:var(--space-3)}
.logo-img{width:42px;height:42px;border-radius:50%;object-fit:cover;transition:transform var(--duration-base) var(--ease-spring)}
.logo:hover .logo-img{transform:scale(1.05)}
.logo-text{font-family:var(--ff-display);font-weight:700;font-size:1.25rem;color:var(--white);transition:color var(--duration-base)}
.header.scrolled .logo-text{color:var(--color-heading)}
.nav-links{display:flex;align-items:center;gap:var(--space-1)}
.nav-link{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:500;color:rgba(255,255,255,.8);border-radius:var(--radius-sm);transition:all var(--duration-base) var(--ease);cursor:pointer;position:relative}
.header.scrolled .nav-link{color:var(--n600)}
.nav-link:hover,.nav-link.active{color:var(--white);background:rgba(255,255,255,.1)}
.header.scrolled .nav-link:hover,.header.scrolled .nav-link.active{color:var(--color-primary-hover);background:var(--g50)}
.nav-link.active::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:20px;height:2px;background:currentColor;border-radius:var(--radius-full)}
.nav-cta{margin-left:var(--space-3)}
.nav-item{position:relative}
.nav-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;min-width:220px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:var(--space-2);z-index:var(--z-dropdown);border:1px solid var(--color-border);animation:dropIn var(--duration-base) var(--ease)}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.nav-item:hover .nav-dropdown,.nav-item:focus-within .nav-dropdown{display:block}
.nav-dropdown a{display:block;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--n600);border-radius:var(--radius-sm);transition:all var(--duration-fast)}
.nav-dropdown a:hover{background:var(--g50);color:var(--color-primary-hover);padding-left:var(--space-5)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--space-2);min-width:44px;min-height:44px;align-items:center;justify-content:center}
.hamburger span{width:22px;height:2px;background:var(--white);transition:all var(--duration-base) var(--ease);border-radius:2px}
.header.scrolled .hamburger span{background:var(--color-foreground)}
.mobile-menu{display:none;position:fixed;inset:0;top:var(--header-h);background:var(--white);z-index:var(--z-overlay);padding:var(--space-6);flex-direction:column;gap:var(--space-1);overflow-y:auto;overscroll-behavior:contain;animation:slideIn var(--duration-base) var(--ease)}
@keyframes slideIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.mobile-menu.open{display:flex}
.mobile-menu a{display:flex;align-items:center;padding:14px var(--space-4);font-size:var(--text-base);color:var(--color-foreground);border-radius:var(--radius);transition:all var(--duration-fast);min-height:44px}
.mobile-menu a:hover{background:var(--g50);color:var(--color-primary-hover)}
.mobile-menu .mobile-section-title{font-size:var(--text-xs);font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--n400);padding:var(--space-5) var(--space-4) var(--space-1);pointer-events:none}

/* === PAGE HERO === */
.page-hero{padding:calc(var(--header-h) + 60px) 0 60px;background:linear-gradient(155deg,var(--g900),var(--n800));color:var(--white);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 80%,rgba(61,168,82,.1),transparent 60%)}
.page-hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:64px 64px}
.page-hero .container{position:relative;z-index:2}
.breadcrumb{font-size:var(--text-xs);color:rgba(255,255,255,.4);margin-bottom:var(--space-4);display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.5);transition:color var(--duration-fast)}
.breadcrumb a:hover{color:var(--g400)}
.breadcrumb-sep{opacity:.3}
.page-hero h1{font-family:var(--ff-display);font-size:clamp(2rem,4vw,3rem);font-weight:700}
.page-hero .hero-desc{font-size:var(--text-base);color:rgba(255,255,255,.55);margin-top:var(--space-3);max-width:560px;line-height:1.7}

/* === CTA BANNER === */
.cta-banner{background:linear-gradient(135deg,var(--g900) 0%,var(--g700) 50%,#0d2e14 100%);padding:var(--space-20) 0;text-align:center;color:var(--white);position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;top:-50%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.04),transparent);border-radius:50%}
.cta-banner h2{font-family:var(--ff-display);font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:700;margin-bottom:var(--space-4);position:relative}
.cta-banner p{font-size:var(--text-base);opacity:.7;margin-bottom:var(--space-8);position:relative}

/* === WHATSAPP FLOAT === */
.wa-float{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:var(--z-float);width:58px;height:58px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(37,211,102,.4);transition:all var(--duration-base) var(--ease-spring);color:var(--white)}
.wa-float:hover{transform:scale(1.1);box-shadow:0 8px 28px rgba(37,211,102,.5)}
.wa-float::before{content:'';position:absolute;inset:-6px;border:2px solid rgba(37,211,102,.3);border-radius:50%;animation:waPulse 2.5s ease-out infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:1}100%{transform:scale(1.4);opacity:0}}

/* === BACK TO TOP === */
.back-top{position:fixed;bottom:var(--space-6);left:var(--space-6);z-index:var(--z-float);width:44px;height:44px;border-radius:50%;background:var(--color-heading);color:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;opacity:0;transform:translateY(20px);pointer-events:none;transition:all var(--duration-base) var(--ease);box-shadow:var(--shadow-md)}
.back-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.back-top:hover{background:var(--color-primary);transform:translateY(-3px)}

/* === FOOTER === */
.footer{background:linear-gradient(180deg,var(--n800) 0%,#161616 100%);padding:var(--space-20) 0 var(--space-8);color:rgba(255,255,255,.5)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-12);margin-bottom:var(--space-12)}
.footer-brand img{width:50px;height:50px;border-radius:50%;margin-bottom:var(--space-4)}
.footer-brand p{font-size:var(--text-sm);line-height:1.7;max-width:280px}
.footer h4{color:var(--white);font-weight:600;font-size:.82rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:var(--space-5);position:relative;padding-bottom:var(--space-3)}
.footer h4::after{content:'';position:absolute;bottom:0;left:0;width:24px;height:2px;background:var(--color-primary);border-radius:var(--radius-full)}
.footer-links li{margin-bottom:var(--space-3)}
.footer-links a{font-size:var(--text-sm);color:rgba(255,255,255,.45);transition:all var(--duration-fast) var(--ease);display:inline-flex;align-items:center;gap:var(--space-2)}
.footer-links a:hover{color:var(--g400);transform:translateX(4px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:var(--space-6);display:flex;justify-content:space-between;align-items:center;font-size:var(--text-xs)}
.social-row{display:flex;gap:var(--space-3)}
.social-row a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.07);color:rgba(255,255,255,.5);transition:all var(--duration-base) var(--ease-spring)}
.social-row a:hover{background:var(--color-primary);color:var(--white);transform:translateY(-3px)}

/* === CARDS === */
.val-card{padding:var(--space-6);background:var(--g50);border-radius:var(--radius);border:1px solid var(--g100);transition:all var(--duration-base) var(--ease)}
.val-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--g200)}
.val-card .vi{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--g600),var(--g500));color:var(--white);border-radius:var(--radius);margin-bottom:var(--space-3);transition:transform var(--duration-base) var(--ease-spring)}
.val-card:hover .vi{transform:scale(1.08) rotate(-2deg)}
.val-card h4{font-family:var(--ff-display);font-weight:600;font-size:var(--text-md);margin-bottom:var(--space-1);color:var(--color-heading)}
.val-card p{font-size:var(--text-sm);color:var(--color-muted);line-height:1.6}

/* Department cards */
.dept-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:var(--space-6);margin-top:var(--space-12)}
.dept-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);border:1px solid var(--color-border);transition:all var(--duration-base) var(--ease);position:relative;overflow:hidden}
.dept-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--g600),var(--g400));transform:scaleY(0);transform-origin:top;transition:transform var(--duration-slow) var(--ease)}
.dept-card::after{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--g600),var(--g400));transform:scaleX(0);transform-origin:left;transition:transform var(--duration-slow) var(--ease)}
.dept-card:hover::before{transform:scaleY(1)}
.dept-card:hover::after{transform:scaleX(1)}
.dept-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg),0 0 0 1px rgba(45,140,62,.1)}
.dept-card .di{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--g50);color:var(--color-primary);border-radius:var(--radius);margin-bottom:var(--space-5);transition:all var(--duration-base) var(--ease-spring)}
.dept-card:hover .di{background:var(--color-primary);color:var(--white);transform:scale(1.06)}
.dept-card h3{font-family:var(--ff-display);font-size:var(--text-lg);font-weight:600;color:var(--color-heading);margin-bottom:var(--space-4)}
.course-list li{padding:var(--space-3) 0;border-bottom:1px solid var(--color-border);font-size:var(--text-sm);color:var(--n600);display:flex;align-items:center;gap:var(--space-2);transition:padding-left var(--duration-fast) var(--ease)}
.course-list li:last-child{border:none}
.course-list li::before{content:'→';color:var(--color-primary);font-weight:700}
.dept-card:hover .course-list li{padding-left:var(--space-1)}

/* News cards */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-top:var(--space-12)}
.news-card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border);transition:all var(--duration-base) var(--ease)}
.news-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg),0 0 0 1px rgba(45,140,62,.08)}
.news-thumb{width:100%;height:200px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.news-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.15))}
.news-thumb.t1{background:linear-gradient(135deg,var(--g800),var(--g500))}
.news-thumb.t2{background:linear-gradient(135deg,#0d2e14,var(--g700))}
.news-thumb.t3{background:linear-gradient(135deg,var(--g600),var(--g300))}
.news-thumb.t4{background:linear-gradient(135deg,var(--gold-dark),var(--gold-light))}
.news-body{padding:var(--space-6)}
.news-tag{display:inline-block;padding:var(--space-1) var(--space-3);background:var(--g50);color:var(--color-primary-hover);font-size:.7rem;font-weight:600;border-radius:var(--radius-sm);letter-spacing:.5px;text-transform:uppercase;margin-bottom:var(--space-3)}
.news-card h3{font-family:var(--ff-display);font-size:var(--text-md);font-weight:600;color:var(--color-heading);margin-bottom:var(--space-2);line-height:1.35}
.news-card p{font-size:var(--text-sm);color:var(--color-muted);line-height:1.6}
.news-date{margin-top:var(--space-4);font-size:var(--text-xs);color:var(--n300);display:flex;align-items:center;gap:var(--space-2)}
.news-date::before{content:'';width:12px;height:1px;background:var(--n300)}

/* === SCROLL REVEAL === */
.reveal{opacity:0;transform:translateY(28px);transition:all .7s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.page-enter{animation:pageIn .45s var(--ease) forwards}
@keyframes pageIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* === REDUCED MOTION === */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* === FORM COMPONENTS === */
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:.78rem;font-weight:600;color:var(--n600);letter-spacing:.3px}
.form-group input,.form-group select,.form-group textarea{padding:13px 16px;border:1.5px solid var(--n200);border-radius:8px;font-family:var(--ff-body);font-size:.88rem;color:var(--n700);transition:all .35s var(--ease);outline:none;background:var(--white)}
.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--n300)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(45,140,62,.12)}
.form-group textarea{resize:vertical;min-height:110px}
.field-error{font-size:.75rem;color:var(--color-error);margin-top:3px;display:block;min-height:16px}
.form-group input.invalid,.form-group textarea.invalid,.form-group select.invalid{border-color:var(--color-error);box-shadow:0 0 0 3px rgba(220,38,38,.1)}
.form-feedback{padding:14px 18px;border-radius:var(--radius);font-size:.88rem;font-weight:500;margin-bottom:var(--space-4)}
.form-feedback.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}
.form-feedback.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* === CONTACT PAGE === */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.contact-form{display:flex;flex-direction:column;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ci-list{display:flex;flex-direction:column;gap:20px}
.ci-card{display:flex;gap:16px;align-items:flex-start;padding:22px;background:var(--g50);border-radius:var(--radius);border:1px solid var(--g100);transition:all var(--duration-base) var(--ease)}
.ci-card:hover{border-color:var(--g200);box-shadow:var(--shadow-sm)}
.ci-icon{width:44px;height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;background:var(--g600);color:var(--white);border-radius:10px}
.ci-card h4{font-weight:600;font-size:.9rem;color:var(--n800);margin-bottom:3px}
.ci-card p{font-size:.84rem;color:var(--n500);line-height:1.5}
.map-box{border-radius:var(--radius-lg);overflow:hidden;height:240px;border:1px solid var(--n100)}
.map-box iframe{width:100%;height:100%;border:0}

/* === ADMISSIONS PAGE === */
.adm-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.steps{display:flex;flex-direction:column;gap:24px}
.step{display:flex;gap:18px;align-items:flex-start;position:relative}
.step:not(:last-child)::after{content:'';position:absolute;left:21px;top:48px;width:2px;height:calc(100% - 20px);background:var(--g200)}
.step-n{width:44px;height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;background:var(--g600);color:var(--white);border-radius:50%;font-family:var(--ff-display);font-weight:700;position:relative;z-index:1;transition:all var(--duration-base) var(--ease-spring)}
.step:hover .step-n{transform:scale(1.1);box-shadow:var(--shadow-glow)}
.step h4{font-weight:600;font-size:.95rem;color:var(--n800);margin-bottom:4px}
.step p{font-size:.85rem;color:var(--n500);line-height:1.6}
.docs-box{background:var(--g50);border-radius:var(--radius-lg);padding:36px;border:1px solid var(--g100)}
.docs-box h3{font-family:var(--ff-display);font-size:1.2rem;font-weight:700;color:var(--n800);margin-bottom:24px}
.doc-row{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--g100)}
.doc-row:last-child{border:none}
.doc-chk{width:26px;height:26px;min-width:26px;display:flex;align-items:center;justify-content:center;background:var(--g600);color:var(--white);border-radius:50%;font-size:.7rem;font-weight:700}
.doc-row span{font-size:.9rem;color:var(--n600)}
.propinas-table{width:100%;border-collapse:collapse;margin-top:24px;background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.propinas-table thead{background:var(--g600);color:var(--white)}
.propinas-table th{padding:16px 20px;text-align:left;font-size:.82rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.propinas-table td{padding:14px 20px;font-size:.9rem;color:var(--n600);border-bottom:1px solid var(--n100)}
.propinas-table tbody tr:hover{background:var(--g50)}

/* === EVENTS PAGE === */
.eventos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-6);margin-top:var(--space-12)}
.evento-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid var(--color-border);display:flex;gap:var(--space-5);transition:all var(--duration-base) var(--ease)}
.evento-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.evento-date-box{min-width:64px;height:72px;background:var(--g50);border:2px solid var(--g200);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all var(--duration-base) var(--ease-spring)}
.evento-card:hover .evento-date-box{background:var(--color-primary);border-color:var(--color-primary)}
.evento-date-box .month{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--color-primary);transition:color var(--duration-base)}
.evento-date-box .day{font-family:var(--ff-display);font-size:1.6rem;font-weight:700;color:var(--n800);line-height:1;transition:color var(--duration-base)}
.evento-date-box .year{font-size:.65rem;color:var(--n400);transition:color var(--duration-base)}
.evento-card:hover .evento-date-box .month{color:var(--g200)}
.evento-card:hover .evento-date-box .day{color:var(--white)}
.evento-card:hover .evento-date-box .year{color:rgba(255,255,255,.7)}
.evento-info h3{font-family:var(--ff-display);font-size:var(--text-lg);font-weight:600;color:var(--color-heading);margin-bottom:var(--space-2)}
.evento-meta{font-size:var(--text-xs);color:var(--n400);display:flex;gap:var(--space-3);flex-wrap:wrap;margin-top:var(--space-3)}

/* === COMMUNICATIONS PAGE === */
.com-filters{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-8)}
.com-filter-btn{padding:7px 16px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;letter-spacing:.5px;text-transform:uppercase;border:1.5px solid var(--color-border);color:var(--n500);cursor:pointer;transition:all var(--duration-fast)}
.com-filter-btn:hover,.com-filter-btn.active{background:var(--color-primary);color:var(--white);border-color:var(--color-primary)}
.com-list{display:flex;flex-direction:column;gap:var(--space-4)}
.com-card{background:var(--white);border-radius:var(--radius);padding:var(--space-5) var(--space-6);border:1px solid var(--color-border);display:flex;gap:var(--space-4);align-items:flex-start;transition:all var(--duration-base) var(--ease);position:relative;overflow:hidden}
.com-card::before{content:'';position:absolute;left:0;top:0;width:3px;height:100%;background:var(--color-primary);transform:scaleY(0);transition:transform var(--duration-base) var(--ease)}
.com-card:hover::before{transform:scaleY(1)}
.com-card:hover{border-color:var(--g200);box-shadow:var(--shadow-md);transform:translateX(4px)}
.com-badge{display:inline-block;padding:4px 12px;border-radius:var(--radius-sm);font-size:.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;background:var(--g50);color:var(--color-primary);white-space:nowrap}
.com-card h3{font-family:var(--ff-display);font-size:var(--text-md);font-weight:600;color:var(--color-heading);margin-bottom:var(--space-2)}
.com-card p{font-size:var(--text-sm);color:var(--color-muted);line-height:1.6}
.com-date{font-size:var(--text-xs);color:var(--n400);margin-top:var(--space-2)}

/* === ARTICLE DETAIL === */
.article-hero{background:linear-gradient(135deg,var(--g900),var(--g700));padding:calc(var(--header-h) + 80px) 0 60px;color:var(--white);position:relative;overflow:hidden}
.article-body{max-width:760px;margin:0 auto;line-height:1.85;font-size:var(--text-md)}
.article-body h2{font-family:var(--ff-display);font-size:var(--text-2xl);font-weight:700;color:var(--color-heading);margin:var(--space-10) 0 var(--space-4)}
.article-body h3{font-family:var(--ff-display);font-size:var(--text-xl);font-weight:600;color:var(--color-heading);margin:var(--space-8) 0 var(--space-3)}
.article-body p{margin-bottom:var(--space-5);color:var(--n700)}
.article-body blockquote{border-left:3px solid var(--color-primary);padding:var(--space-4) var(--space-6);margin:var(--space-8) 0;background:var(--g50);border-radius:0 var(--radius) var(--radius) 0;font-family:var(--ff-display);font-size:var(--text-lg);font-style:italic;color:var(--color-heading)}

/* === COURSE DETAIL === */
.course-hero{background:linear-gradient(155deg,var(--g900),var(--g700));padding:calc(var(--header-h) + 60px) 0 60px;color:var(--white)}
.course-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);padding:6px 16px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--g300);margin-bottom:var(--space-4)}
.course-meta-row{display:flex;gap:var(--space-6);flex-wrap:wrap;margin-top:var(--space-6)}
.course-meta-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:rgba(255,255,255,.65)}
.course-meta-item strong{color:var(--white)}
.course-content-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-12)}

/* === TESTIMONIALS === */
.testimonial-section{background:linear-gradient(135deg,var(--g900),#0d2e14);padding:var(--space-24) 0;color:var(--white);position:relative;overflow:hidden}
.testimonial-section::before{content:'';position:absolute;top:-40%;right:-15%;width:500px;height:500px;background:radial-gradient(circle,rgba(94,194,110,.08),transparent);border-radius:50%}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8);margin-top:var(--space-12)}
.testimonial-card{background:rgba(255,255,255,.06);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:var(--space-8);transition:all var(--duration-base) var(--ease)}
.testimonial-card:hover{background:rgba(255,255,255,.1);transform:translateY(-4px)}
.quote-mark{font-family:var(--ff-display);font-size:3rem;color:var(--g400);line-height:1;margin-bottom:var(--space-3);opacity:.5}
.testimonial-card p{font-size:var(--text-sm);color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:var(--space-5)}
.testimonial-author{display:flex;align-items:center;gap:var(--space-3)}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--g600),var(--g400));display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-weight:700;font-size:var(--text-lg);color:var(--white)}
.testimonial-author-info .name{font-weight:600;font-size:var(--text-sm);color:var(--white)}
.testimonial-author-info .role{font-size:var(--text-xs);color:rgba(255,255,255,.5)}

/* === INSTITUTIONAL === */
.inst-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center;margin-top:var(--space-12)}
.inst-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-top:var(--space-12)}
.inst-stat{text-align:center;padding:var(--space-8);background:var(--g50);border-radius:var(--radius-lg);border:1px solid var(--g100)}
.inst-stat .val{font-family:var(--ff-display);font-size:var(--text-3xl);font-weight:700;color:var(--color-primary)}
.inst-stat .lbl{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:1.5px;color:var(--color-muted);font-weight:600;margin-top:var(--space-1)}
.org-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4);margin-top:var(--space-8)}
.org-card{background:linear-gradient(135deg,var(--g50),var(--white));border:1px solid var(--g100);border-radius:var(--radius);padding:var(--space-5) var(--space-6);text-align:center}
.org-card h4{font-family:var(--ff-display);font-weight:700;font-size:var(--text-md);color:var(--color-heading);margin-bottom:var(--space-1)}
.org-card p{font-size:var(--text-xs);color:var(--color-muted);text-transform:uppercase;letter-spacing:1px}

/* === EMPTY STATE === */
.empty-state{text-align:center;padding:var(--space-20) var(--space-6);color:var(--color-muted)}
.empty-state svg{margin:0 auto var(--space-4);opacity:.3}
.empty-state p{font-size:var(--text-md)}

/* === BADGES/TAGS === */
.tag{display:inline-block;padding:4px 12px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.tag-green{background:var(--g50);color:var(--color-primary-hover);border:1px solid var(--g200)}
.tag-gold{background:#fdf8ed;color:var(--gold-dark);border:1px solid #f0d99a}

/* === SMOOTH IMAGE LOADING === */
img[loading="lazy"]{opacity:0;transition:opacity .4s var(--ease)}
img[loading="lazy"].loaded,img[loading="lazy"]:not([data-src]){opacity:1}

/* === RESPONSIVE === */
@media(min-width:1440px){.container{padding:0 var(--space-10)}}
@media(max-width:968px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .news-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .page-section{padding:var(--space-16) 0}
  .contact-grid,.adm-grid,.inst-hero-grid,.course-content-grid{grid-template-columns:1fr}
  .testimonial-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:var(--space-8)}
  .dept-grid{grid-template-columns:1fr 1fr}
  .inst-stat-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .dept-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .container{padding:0 var(--space-4)}
  .page-section{padding:var(--space-16) 0}
  .footer-bottom{flex-direction:column;gap:var(--space-4);text-align:center}
  .form-row{grid-template-columns:1fr}
  .inst-stat-grid{grid-template-columns:1fr}
}
@media(max-width:375px){
  :root{--header-h:64px}
  .btn{padding:12px 24px;font-size:.82rem}
}

/* === DARK MODE === */
@media(prefers-color-scheme:dark){
  :root{
    --color-background:#0f1710;--color-foreground:#d4e8d6;--color-heading:#f0f7f1;
    --color-muted:#8aaa8d;--color-border:#1e3522;--color-surface:#131f15;
    --white:#111e13;--n50:#0f1710;--n100:#1a2b1c;--n200:#243827;
    --n300:#3a5c3e;--n400:#517555;--n500:#6e9873;--n600:#90bb94;
    --n700:#b4d4b7;--n800:#d4e8d6;--n900:#edf5ee;
  }
  .header.scrolled{background:rgba(13,23,14,.96);box-shadow:0 1px 0 rgba(0,0,0,.3)}
  .nav-dropdown{background:#192b1b;border-color:var(--color-border)}
  .nav-dropdown a{color:var(--n600)}
  .mobile-menu{background:#0f1710}
  .dept-card,.news-card{background:#192b1b;border-color:var(--color-border)}
  .val-card,.ci-card,.docs-box{background:rgba(45,140,62,.07);border-color:var(--color-border)}
  .form-group input,.form-group select,.form-group textarea{background:#131f15;border-color:var(--color-border);color:var(--color-foreground)}
  .propinas-table{background:#192b1b}
  .propinas-table td{border-color:var(--color-border)}
  .back-top{background:#192b1b}
  .org-card{background:rgba(45,140,62,.06);border-color:var(--color-border)}
  .com-card,.evento-card{background:#192b1b;border-color:var(--color-border)}
  .inst-stat{background:rgba(45,140,62,.07);border-color:var(--color-border)}
}

@media print{
  .header,.wa-float,.back-top,.mobile-menu{display:none!important}
  body{color:#000;background:#fff}
}
