
/* ═══════════════════════════════════════════════════════════
   ATN · Academia Tecnológica NEO — Epic v1.0
   Diseño: Geo-Editorial · Bricolage Grotesque + DM Sans
   Tema: Claro/Oscuro adaptable · Turquesa del Alba Premium
═══════════════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  --font-display: 'Bricolage Grotesque', Georgia, serif;
  --font-body: 'DM Sans', system-ui, -apple-system, sans-serif;

  /* Paleta ATN Premium */
  --cyan: #00b4d8;
  --cyan-deep: #0077b6;
  --cyan-light: #caf0f8;
  --navy: #03045e;
  --gold: #d4af37;
  --gold-light: #f5e68a;
  --violet: #6d28d9;
  --green: #059669;
  --coral: #e11d48;

  /* LIGHT MODE */
  --bg: #f0f4f8;
  --bg-2: #ffffff;
  --bg-3: #e8eef5;
  --surface: rgba(255,255,255,0.85);
  --surface-2: rgba(255,255,255,0.6);
  --text: #0c1a2e;
  --text-2: #3d5270;
  --text-3: #6b7f96;
  --border: rgba(0,119,182,0.12);
  --border-2: rgba(0,119,182,0.08);
  --shadow-sm: 0 2px 8px rgba(3,4,94,0.06);
  --shadow: 0 8px 32px rgba(3,4,94,0.10);
  --shadow-lg: 0 20px 60px rgba(3,4,94,0.14);
  --card-bg: rgba(255,255,255,0.9);
  --header-bg: rgba(240,244,248,0.92);
  --hero-grad-1: #dceefb;
  --hero-grad-2: #fdf6e3;

  /* Accents */
  --accent: var(--cyan-deep);
  --accent-2: var(--gold);
  --accent-3: var(--violet);

  /* Radius */
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
  --r-pill: 999px;

  /* Transition */
  --t: 0.22s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="dark"] {
  --bg: #060d1f;
  --bg-2: #0c1730;
  --bg-3: #091424;
  --surface: rgba(12,23,48,0.90);
  --surface-2: rgba(12,23,48,0.60);
  --text: #e8eef6;
  --text-2: #a8bdd4;
  --text-3: #6a88a6;
  --border: rgba(0,180,216,0.14);
  --border-2: rgba(0,180,216,0.07);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
  --shadow: 0 8px 32px rgba(0,0,0,0.4);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.5);
  --card-bg: rgba(12,23,48,0.85);
  --header-bg: rgba(6,13,31,0.95);
  --hero-grad-1: #0c1f3f;
  --hero-grad-2: #1a0e3d;
  --cyan: #22d3ee;
  --cyan-deep: #06b6d4;
  --cyan-light: rgba(34,211,238,0.12);
  --accent: var(--cyan-deep);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  transition:background var(--t), color var(--t);
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}
input,select,textarea{font:inherit}
:focus-visible{outline:2px solid var(--cyan-deep);outline-offset:3px;border-radius:4px}
::selection{background:var(--cyan-light);color:var(--navy)}

/* ── LAYOUT ── */
.wrap{max-width:1180px;margin:0 auto;padding:0 clamp(16px,4vw,40px)}
.section{padding:clamp(60px,8vw,100px) 0}
.section-sm{padding:clamp(40px,5vw,60px) 0}

/* ── TYPOGRAPHY ── */
.display{
  font-family:var(--font-display);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-0.03em;
  font-optical-sizing:auto;
}
.heading{font-family:var(--font-display);font-weight:700;line-height:1.15;letter-spacing:-0.02em}
.eyebrow{
  font-size:0.72rem;font-weight:600;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:6px;
}
.eyebrow::before{content:'';width:20px;height:2px;background:var(--accent);border-radius:2px;flex-shrink:0}
.section-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,3vw,2.6rem);letter-spacing:-0.03em;line-height:1.1;margin-bottom:0.5rem}
.section-lead{font-size:1.05rem;color:var(--text-2);max-width:640px;line-height:1.7}
.muted{color:var(--text-3)}

/* ── UTILITIES ── */
.u-bg-3{background:var(--bg-3)}
.u-text-center{text-align:center}
.u-center-auto{margin:0 auto}
.u-eyebrow-center{margin-bottom:12px;justify-content:center}
.u-flex-gap10-wrap{display:flex;gap:10px;flex-wrap:wrap}
.u-btn-full-center{width:100%;justify-content:center}
.u-link-block{text-decoration:none;display:block}
.u-h-12{height:12px}
.u-h-20{height:20px}
.u-ml-auto{margin-left:auto}
.u-card-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-radius:var(--r-md);
  border:1px solid var(--border);background:var(--bg);
}
.u-grid-auto-200{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.u-span-2{grid-column:span 2}
.u-soft-copy{color:var(--text-2);margin-bottom:12px;line-height:1.6}
.u-mb-10{margin-bottom:10px}
.u-hero-wrap-600{max-width:600px}
.u-hero-wrap-680{max-width:680px}
.u-center-auto-mb-28{margin:0 auto 28px}
.u-nav-link-clean{border:none;background:none;cursor:pointer}
.u-accent-strong{font-weight:700;color:var(--accent)}
.u-max-760-center{max-width:760px;margin:0 auto}
.u-flex-1{flex:1}
.u-flex-1-min0{flex:1;min-width:0}
.u-min0-flex1{min-width:0;flex:1}
.u-text-right{text-align:right}
.u-w-full{width:100%}
.u-panel-title{font-family:var(--font-display);font-weight:800;font-size:1.5rem;margin-bottom:6px}
.u-panel-title-lg{font-family:var(--font-display);font-weight:800;font-size:1.6rem;margin-bottom:4px}
.u-panel-sub-24{color:var(--text-2);font-size:.9rem;margin-bottom:24px}
.u-panel-sub-20{color:var(--text-2);font-size:.9rem;margin-bottom:20px}
.u-row-between-wrap-12-mb24{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px}
.u-flex-gap8-wrap{display:flex;gap:8px;flex-wrap:wrap}
.u-grid-2-gap20{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.u-card-xl-p20{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px}
.u-card-xl-p22-mb20{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:22px;margin-bottom:20px}
.u-card-xl-p18{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:18px}
.u-card-xl-p1820-mb12-flex16{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-xl);padding:18px 20px;margin-bottom:12px;display:flex;align-items:center;gap:16px}
.u-row-between-mb14{display:flex;justify-content:space-between;margin-bottom:14px}
.u-row-between-mb10{display:flex;justify-content:space-between;margin-bottom:10px}
.u-h2-card{font-family:var(--font-display);font-weight:700;font-size:1rem;margin:0}
.u-link-accent-sm{font-size:.8rem;color:var(--accent);font-weight:600}
.u-f82-w600-ellipsis{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u-f82-w500-ellipsis{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u-f80-w700{font-size:.8rem;font-weight:700}
.u-f80-w700-w36-right{font-size:.8rem;font-weight:700;width:36px;text-align:right}
.u-f78-muted-mt2{font-size:.78rem;color:var(--text-3);margin-top:2px}
.u-f78-muted-right-noshrink{font-size:.78rem;color:var(--text-3);text-align:right;flex-shrink:0}
.u-f75-muted-w28-right{font-size:.75rem;color:var(--text-3);width:28px;text-align:right}
.u-f72-muted{font-size:.72rem;color:var(--text-3)}
.u-f72-muted-mt6{font-size:.72rem;color:var(--text-3);margin-top:6px}
.u-f70-muted{font-size:.7rem;color:var(--text-3)}
.u-w120-f82-w500-ellipsis{width:120px;font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u-w60-mt3{width:60px;margin-top:3px}
.u-flex-aic-gap8-noshrink{display:flex;align-items:center;gap:8px;flex-shrink:0}
.u-flex-aic-gap10-mb10{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.u-flex-aic-gap10-mb12{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.u-flex-aic-gap12-noshrink{display:flex;align-items:center;gap:12px;flex-shrink:0}
.u-flex-aic-gap12-mb12{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.u-col-gap8-end-noshrink{display:flex;flex-direction:column;gap:8px;align-items:flex-end;flex-shrink:0}
.u-w700-f90{font-weight:700;font-size:.9rem}
.u-wrap-gap12-p1618-mb12{flex-wrap:wrap;gap:12px;padding:16px 18px;margin-bottom:12px}
.u-mt10-f82-accent{margin-top:10px;font-size:.82rem;color:var(--cyan-deep);font-weight:600}
.u-row-between-border-b-10{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:.86rem}
.u-check-mini{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;cursor:pointer}
.u-flex-aic-gap8-mb7-f82-muted{display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:.82rem;color:var(--text-2)}
.u-h3-f95{font-family:var(--font-display);font-weight:700;font-size:.95rem}
.u-list-row{padding:12px 14px;cursor:pointer;border-bottom:1px solid var(--border);background:transparent;display:flex;align-items:center;gap:10px;transition:all var(--t)}
.u-text-2{color:var(--text-2)}
.u-text-green{color:var(--green)}
.u-mb-28{margin-bottom:28px}
.u-link-resource{padding:8px 0;border-bottom:1px solid var(--border);font-size:.82rem;color:var(--accent);cursor:pointer}
.u-flex-1-min200{flex:1;min-width:200px}
.u-muted-400{color:var(--text-3);font-weight:400}
.u-display-13{font-family:var(--font-display);font-weight:700;font-size:1.3rem}
.u-input-score{width:65px;padding:6px 10px;font-size:.85rem;text-align:center}
.u-flex-gap6{display:flex;gap:6px}
.u-status-pill{font-size:.72rem;font-weight:700;padding:3px 9px;border-radius:999px;background:rgba(0,0,0,.04)}
.u-status-pill-green{color:var(--green)}
.u-row-card-bg{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--r-md);border:1px solid var(--border);margin-bottom:8px;background:var(--bg)}
.u-name-86-ellipsis{font-weight:600;font-size:.86rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u-f74-muted-mt2{font-size:.74rem;color:var(--text-3);margin-top:2px}
.u-score-cyan{font-size:.78rem;font-weight:700;color:var(--cyan-deep)}
.u-w-67{width:67%}
.u-w-56{width:56%}
.u-w-44{width:44%}
.u-w-33{width:33%}
.u-w-22{width:22%}
.u-w-78{width:78%}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:var(--r-pill);
  font-weight:600;font-size:0.9rem;
  transition:all var(--t);border:1.5px solid transparent;
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,var(--cyan-deep),var(--navy));
  color:#fff;
  box-shadow:0 4px 18px rgba(0,119,182,0.35);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,119,182,0.45)}
.btn-primary:active{transform:translateY(0)}
.btn-secondary{
  background:var(--surface);
  color:var(--text);
  border-color:var(--border);
  backdrop-filter:blur(10px);
}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.btn-ghost{color:var(--accent);padding:8px 14px}
.btn-ghost:hover{background:var(--cyan-light);border-radius:var(--r-md)}
.btn-gold{
  background:linear-gradient(135deg,var(--gold),#b8860b);
  color:#1a0a00;font-weight:700;
  box-shadow:0 4px 18px rgba(212,175,55,0.35);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(212,175,55,0.5)}
.btn-sm{padding:8px 16px;font-size:0.82rem}
.btn-lg{padding:14px 28px;font-size:1rem}
.btn-icon{padding:10px;border-radius:var(--r-md);width:42px;height:42px;justify-content:center}

/* ── BADGES / CHIPS ── */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:var(--r-pill);
  font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
}
.badge-cyan{background:rgba(0,180,216,0.15);color:var(--cyan-deep);border:1px solid rgba(0,180,216,0.3)}
.badge-gold{background:rgba(212,175,55,0.15);color:var(--gold);border:1px solid rgba(212,175,55,0.3)}
.badge-violet{background:rgba(109,40,217,0.12);color:var(--violet);border:1px solid rgba(109,40,217,0.25)}
.badge-green{background:rgba(5,150,105,0.12);color:var(--green);border:1px solid rgba(5,150,105,0.25)}
.badge-coral{background:rgba(225,29,72,0.1);color:var(--coral);border:1px solid rgba(225,29,72,0.25)}
.chip{
  display:inline-block;padding:4px 10px;border-radius:var(--r-pill);
  font-size:0.75rem;font-weight:500;
  background:var(--bg-3);color:var(--text-2);
  border:1px solid var(--border);
}

/* ── CARDS ── */
.card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow-sm);
  backdrop-filter:blur(12px);
  transition:all var(--t);
}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:rgba(0,180,216,0.2)}
.card-body{padding:clamp(20px,3vw,28px)}
.card-sm{border-radius:var(--r-lg)}
.card-sm:hover{transform:translateY(-2px)}

/* ── HEADER ── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:var(--header-bg);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:background var(--t),border-color var(--t);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:12px clamp(16px,4vw,40px);
  max-width:1280px;margin:0 auto;
}
.logo{display:flex;align-items:center;gap:10px}
.logo-mark{
  width:40px;height:40px;border-radius:10px;
  background:linear-gradient(135deg,var(--navy),var(--cyan-deep));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;font-size:0.95rem;
  color:#fff;letter-spacing:-0.04em;flex-shrink:0;
}
.logo-text{font-family:var(--font-display);font-weight:700;font-size:0.95rem;line-height:1.1;color:var(--text)}
.logo-text span{display:block;font-size:0.65rem;font-weight:500;color:var(--text-3);letter-spacing:0.05em;text-transform:uppercase;font-family:var(--font-body)}

.main-nav{display:flex;align-items:center;gap:4px}
.nav-link{padding:7px 12px;border-radius:var(--r-md);font-size:0.88rem;font-weight:500;color:var(--text-2);transition:all var(--t)}
.nav-link:hover{color:var(--accent);background:var(--border-2)}
.nav-link.active{color:var(--accent);background:rgba(0,180,216,0.08)}

/* Dropdown */
.nav-dropdown{
  position:relative;
  z-index:130;
  --dropdown-offset:46px;
}
.nav-dropdown::after{
  content:'';
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  width:260px;
  height:var(--dropdown-offset);
  display:none;
}
.nav-dropdown:hover::after,
.nav-dropdown:focus-within::after,
.nav-dropdown.open::after{
  display:block;
}
.nav-dropdown-menu{
  position:absolute;top:calc(100% + var(--dropdown-offset));left:50%;transform:translateX(-50%) translateY(-6px);
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  min-width:240px;padding:8px;
  z-index:140;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:all 0.18s cubic-bezier(0.4,0,0.2,1);
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu,
.nav-dropdown.open .nav-dropdown-menu{
  opacity:1;visibility:visible;pointer-events:all;transform:translateX(-50%) translateY(0)
}
.nav-dropdown-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-md);color:var(--text-2);font-size:0.87rem;transition:all var(--t)}
.nav-dropdown-item:hover{background:var(--border-2);color:var(--accent)}
.nav-dropdown-item .dd-icon{font-size:1.1rem;width:22px;text-align:center}

.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* Theme toggle */
.theme-toggle{
  width:44px;height:24px;border-radius:12px;
  background:var(--border);border:1px solid var(--border);
  position:relative;transition:background var(--t);
  cursor:pointer;
  flex-shrink:0;
}
.theme-toggle::after{
  content:'';position:absolute;top:2px;left:2px;
  width:18px;height:18px;border-radius:50%;
  background:var(--bg-2);box-shadow:var(--shadow-sm);
  transition:transform var(--t);
}
[data-theme="dark"] .theme-toggle{background:rgba(0,180,216,0.3);border-color:rgba(0,180,216,0.4)}
[data-theme="dark"] .theme-toggle::after{transform:translateX(20px);background:var(--cyan-deep)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;flex-shrink:0}
.hamburger span{display:block;height:2px;background:var(--text);border-radius:2px;transition:all var(--t)}
.hamburger span:nth-child(1){width:22px}
.hamburger span:nth-child(2){width:16px}
.hamburger span:nth-child(3){width:20px}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);width:22px}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);width:22px}

/* Campus subnav */
.campus-nav{
  border-top:1px solid var(--border);
  background:var(--surface-2);backdrop-filter:blur(12px);
}
.campus-nav-inner{
  display:flex;align-items:center;gap:0;
  padding:0 clamp(16px,4vw,40px);
  max-width:1280px;margin:0 auto;overflow-x:auto;
  scrollbar-width:none;
}
.campus-nav-inner::-webkit-scrollbar{display:none}
.campus-link{
  display:flex;align-items:center;gap:6px;
  padding:9px 16px;font-size:0.82rem;font-weight:600;
  color:var(--text-3);border-bottom:2px solid transparent;
  transition:all var(--t);white-space:nowrap;
}
.campus-link:hover,.campus-link.active{color:var(--accent);border-bottom-color:var(--accent)}
.campus-link .c-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.campus-link--tech .c-dot{background:#3c83a0}
.campus-link--autores .c-dot{background:#0077b6}
.campus-link--cursos .c-dot{background:#00b4d8}
.campus-sep{color:var(--border);margin:0 4px;font-size:0.75rem}

/* Mobile nav */
.mobile-nav{
  position:fixed;top:0;left:0;right:0;bottom:0;z-index:99;
  background:var(--bg-2);padding:80px 24px 40px;
  transform:translateX(-100%);transition:transform 0.28s cubic-bezier(0.4,0,0.2,1);
  overflow-y:auto;
}
.mobile-nav.open{transform:none}
.mobile-nav-link{display:block;padding:14px 0;font-size:1.1rem;font-weight:600;border-bottom:1px solid var(--border);color:var(--text)}

/* ── SPACER for sticky header ── */
.header-spacer{height:90px}

/* ── HERO ── */
.hero{
  min-height:92vh;display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:80px 0 60px;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 80% 70% at 15% -10%, var(--hero-grad-1), transparent 55%),
    radial-gradient(ellipse 60% 60% at 85% 110%, var(--hero-grad-2), transparent 55%),
    var(--bg);
}
[data-theme="dark"] .hero-bg{
  background:
    radial-gradient(ellipse 80% 70% at 15% -10%, rgba(0,119,182,0.2), transparent 55%),
    radial-gradient(ellipse 60% 60% at 85% 110%, rgba(109,40,217,0.2), transparent 55%),
    var(--bg);
}
.hero-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(32px,4vw,64px);align-items:center;
  position:relative;z-index:1;
}
.hero-eyebrow{margin-bottom:20px}
.hero-title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.4rem,5vw,4rem);
  line-height:1.05;letter-spacing:-0.04em;
  color:var(--text);margin-bottom:20px;
}
.hero-title em{
  font-style:normal;color:var(--cyan-deep);
  position:relative;display:inline-block;
}
.hero-title em::after{
  content:'';position:absolute;left:0;bottom:-2px;right:0;height:3px;
  background:linear-gradient(90deg,var(--cyan-deep),var(--gold));
  border-radius:2px;
}
.hero-sub{font-size:1.05rem;color:var(--text-2);line-height:1.7;margin-bottom:28px;max-width:520px}
.hero-highlights{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.hero-highlights li{
  display:flex;align-items:flex-start;gap:10px;
  font-size:0.92rem;color:var(--text-2);
}
.hero-highlights li::before{
  content:'✦';color:var(--gold);flex-shrink:0;margin-top:1px;font-size:0.8rem;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.hero-note{font-size:0.8rem;color:var(--text-3)}

/* Hero visual — mock dashboard */
.hero-visual{position:relative}
.hero-dashboard{
  background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--r-xl);box-shadow:var(--shadow-lg);
  overflow:hidden;backdrop-filter:blur(16px);
}
.hd-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;border-bottom:1px solid var(--border);
  background:rgba(0,119,182,0.04);
}
.hd-dots{display:flex;gap:6px}
.hd-dot{width:10px;height:10px;border-radius:50%}
.hd-dot:nth-child(1){background:#ff5f56}
.hd-dot:nth-child(2){background:#ffbd2e}
.hd-dot:nth-child(3){background:#27c93f}
.hd-title{font-size:0.78rem;font-weight:600;color:var(--text-2)}
.hd-body{padding:18px}
.hd-user{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.hd-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--cyan-deep),var(--navy));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:0.8rem;flex-shrink:0}
.hd-user-name{font-weight:600;font-size:0.9rem}
.hd-user-role{font-size:0.75rem;color:var(--text-3)}
.hd-progress-wrap{margin-bottom:16px}
.hd-progress-label{display:flex;justify-content:space-between;font-size:0.78rem;margin-bottom:6px}
.hd-progress-bar{height:6px;background:var(--bg-3);border-radius:99px;overflow:hidden}
.hd-progress-fill{height:100%;background:linear-gradient(90deg,var(--cyan-deep),var(--cyan));border-radius:99px;animation:fillBar 1.8s ease-out forwards}
@keyframes fillBar{from{width:0}to{width:67%}}
.hd-modules{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.hd-module{
  padding:10px 12px;border-radius:var(--r-md);border:1px solid var(--border);
  background:var(--bg);font-size:0.78rem;
}
.hd-module-n{font-weight:700;color:var(--accent);margin-bottom:2px}
.hd-module-status{display:flex;align-items:center;gap:4px;font-size:0.7rem}
.hd-module-status.done{color:var(--green)}
.hd-module-status.active{color:var(--cyan-deep)}
.hd-module-status.upcoming{color:var(--text-3)}
.hd-mentor{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:var(--r-md);
  background:linear-gradient(135deg,rgba(0,119,182,0.08),rgba(0,180,216,0.06));
  border:1px solid rgba(0,180,216,0.2);
}
.hd-mentor-icon{font-size:1.2rem}
.hd-mentor-text{font-size:0.78rem}
.hd-mentor-text strong{display:block;margin-bottom:1px}
.hero-badge-float{
  position:absolute;
  background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow);padding:12px 14px;
  min-width:240px;max-width:280px;
  backdrop-filter:blur(12px);
  animation:float 4s ease-in-out infinite;
}
.hero-badge-float--1{
  top:-20px;right:-20px;animation-delay:0s;
  min-width:0;max-width:none;width:fit-content;
  padding:8px 10px;
}
.hero-badge-float--2{bottom:20px;left:-30px;animation-delay:2s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hbf-label{
  display:flex;justify-content:center;flex-wrap:wrap;gap:6px;
  margin-bottom:8px;
}
.hbf-word{
  display:inline-block;
  font-size:0.74rem;font-weight:800;letter-spacing:0.04em;text-transform:uppercase;
}
.hbf-word--cyan{color:#005f8d}
.hbf-word--gold{color:#8c5c00}
.hbf-word--violet{color:#4c1d95}
.hbf-cta{
  display:block;text-align:center;
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(1.32rem,2vw,1.62rem);line-height:1.04;
  margin-bottom:8px;
  color:#001523;
  text-shadow:0 0 10px rgba(0,245,255,0.38),0 0 18px rgba(57,255,20,0.2);
}
.hbf-cta--alt{
  color:#022034;
  text-shadow:0 0 10px rgba(0,245,255,0.38),0 0 18px rgba(255,230,0,0.24);
}
.hbf-line{
  font-size:0.9rem;font-weight:800;line-height:1.2;text-align:center;
}
.hbf-line--1{color:#005f8d}
.hbf-line--2{color:#3f2da8}
[data-theme="dark"] .hero-badge-float{
  background:linear-gradient(135deg,rgba(7,20,42,0.95),rgba(10,34,59,0.92));
  border-color:rgba(0,245,255,0.28);
}
[data-theme="dark"] .hbf-word--cyan{color:#8ff4ff}
[data-theme="dark"] .hbf-word--gold{color:#fff3a4}
[data-theme="dark"] .hbf-word--violet{color:#d9c2ff}
[data-theme="dark"] .hbf-cta{color:#a9fff7;text-shadow:0 0 12px rgba(0,245,255,0.45),0 0 22px rgba(57,255,20,0.3)}
[data-theme="dark"] .hbf-cta--alt{color:#a8f5ff;text-shadow:0 0 12px rgba(0,245,255,0.45),0 0 22px rgba(255,230,0,0.28)}
[data-theme="dark"] .hbf-line--1{color:#9ff7ff}
[data-theme="dark"] .hbf-line--2{color:#fff6a8}

@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{display:none}
}

/* ── STATS STRIP ── */
.stats-strip{
  padding:24px 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:var(--surface-2);backdrop-filter:blur(10px);
}
.stats-inner{display:flex;gap:0;overflow-x:auto;scrollbar-width:none}
.stats-inner::-webkit-scrollbar{display:none}
.stat{flex:1;min-width:140px;padding:16px 24px;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-val{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--text);letter-spacing:-0.04em;line-height:1}
.stat-val em{font-style:normal;color:var(--cyan-deep)}
.stat-lbl{font-size:0.78rem;color:var(--text-3);margin-top:4px}

/* ── SECTION HEADER ── */
.sh{margin-bottom:clamp(32px,5vw,52px)}
.sh-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}

/* ── NEO STRIP ── */
.neo-strip{
  background:linear-gradient(135deg,var(--navy) 0%,var(--cyan-deep) 100%);
  color:#fff;padding:20px 0;
}
.neo-strip-inner{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.neo-strip-label{font-size:0.85rem;font-weight:600;opacity:0.8;flex-shrink:0}
.neo-tags{display:flex;gap:8px;flex-wrap:wrap}
.neo-tag{
  padding:6px 14px;border-radius:var(--r-pill);
  background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);
  font-size:0.8rem;font-weight:600;
  transition:all var(--t);
}
.neo-tag:hover{background:rgba(255,255,255,0.2)}

/* ── ABOUT GRID ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,72px);align-items:start}
.about-text p{font-size:1rem;color:var(--text-2);line-height:1.75;margin-bottom:16px}
.about-text p:last-child{margin-bottom:0}
.about-visual{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  align-items:stretch;
  grid-auto-rows:1fr;
}
.about-kpi{
  padding:24px 20px;border-radius:var(--r-lg);
  border:1px solid var(--border);
  background:var(--card-bg);backdrop-filter:blur(8px);
  text-align:center;transition:all var(--t);
  min-height:168px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.about-kpi:hover{border-color:rgba(0,180,216,0.3);transform:translateY(-3px)}
.about-kpi-val{font-family:var(--font-display);font-size:2.2rem;font-weight:800;color:var(--cyan-deep);letter-spacing:-0.04em;line-height:1}
.about-kpi-lbl{font-size:0.8rem;color:var(--text-3);margin-top:10px;line-height:1.45}
@media(max-width:768px){.about-grid{grid-template-columns:1fr}}
@media(max-width:560px){
  .about-visual{grid-template-columns:1fr}
  .about-kpi{min-height:auto}
}

/* ── HOW IT WORKS ── */
.steps-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.step-card{
  position:relative;padding:24px;
  border:1px solid var(--border);border-radius:var(--r-xl);
  background:var(--card-bg);backdrop-filter:blur(8px);
  transition:all var(--t);
}
.step-card:hover{border-color:rgba(0,180,216,0.3);box-shadow:var(--shadow);transform:translateY(-3px)}
.step-num{
  width:44px;height:44px;border-radius:var(--r-md);
  background:linear-gradient(135deg,var(--cyan-deep),var(--navy));
  color:#fff;font-family:var(--font-display);font-weight:800;font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;flex-shrink:0;
}
.step-title{font-family:var(--font-display);font-weight:700;font-size:1rem;margin-bottom:8px;color:var(--text)}
.step-text{font-size:0.88rem;color:var(--text-2);line-height:1.6}
@media(max-width:900px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.steps-grid{grid-template-columns:1fr}}

/* ── FOR WHOM ── */
.audience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.audience-card{
  padding:28px;border-radius:var(--r-xl);
  border:1px solid var(--border);
  background:var(--card-bg);backdrop-filter:blur(8px);
  transition:all var(--t);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.audience-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--cyan-deep),var(--gold));
  transform:scaleX(0);transform-origin:left;transition:transform 0.3s ease;
}
.audience-card:hover::before{transform:scaleX(1)}
.audience-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.audience-icon{font-size:2rem;margin-bottom:16px}
.audience-title{font-family:var(--font-display);font-weight:700;font-size:1.15rem;margin-bottom:10px;color:var(--text)}
.audience-text{font-size:0.88rem;color:var(--text-2);line-height:1.65;margin-bottom:14px}
.audience-list{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.audience-list li{display:flex;align-items:flex-start;gap:8px;font-size:0.85rem;color:var(--text-2)}
.audience-list li::before{content:'→';color:var(--cyan-deep);flex-shrink:0}
.audience-campus{
  font-size:0.8rem;font-weight:600;color:var(--accent);
  border-top:1px solid var(--border);padding-top:14px;
  margin-top:auto;text-align:center;
  display:flex;flex-direction:column;gap:4px;
}
.audience-campus-main{font-weight:700}
.audience-campus-sub{font-weight:600;color:var(--text-2)}
@media(max-width:900px){.audience-grid{grid-template-columns:1fr}}

/* ── DIFFERENTIALS (BENTO) ── */
.bento-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  align-items:stretch;
}
.pillar-card{
  padding:28px;border-radius:var(--r-xl);
  background:linear-gradient(135deg,rgba(0,119,182,0.08),rgba(0,180,216,0.04));
  border:1px solid var(--border);
  backdrop-filter:blur(8px);transition:all var(--t);
  display:flex;flex-direction:column;height:100%;
}
.pillar-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.pillar-icon{font-size:1.8rem;margin-bottom:14px}
.pillar-title{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin-bottom:8px;color:var(--text)}
.pillar-text{font-size:0.87rem;color:var(--text-2);line-height:1.65}
@media(max-width:900px){.bento-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.bento-grid{grid-template-columns:1fr}}

/* ── ROUTES ── */
.routes-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.filter-btn{
  padding:7px 16px;border-radius:var(--r-pill);font-size:0.83rem;font-weight:600;
  border:1.5px solid var(--border);background:var(--card-bg);color:var(--text-2);
  transition:all var(--t);cursor:pointer;
}
.filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.filter-btn.active{background:var(--cyan-deep);color:#fff;border-color:var(--cyan-deep)}

.routes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.route-card{
  background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  transition:all var(--t);backdrop-filter:blur(8px);
  position:relative;
  display:flex;
  flex-direction:column;
  height:100%;
}
.route-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent)}
.route-card[hidden]{display:none}
.route-card-stripe{height:4px;background:linear-gradient(90deg,var(--stripe-a),var(--stripe-b))}
.route-card-body{
  padding:20px 22px 18px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.route-campus-tag{font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.route-title{font-family:var(--font-display);font-weight:700;font-size:1.12rem;margin-bottom:8px;color:var(--text)}
.route-desc{font-size:0.85rem;color:var(--text-2);line-height:1.6;margin-bottom:14px}
.route-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.route-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:auto}
.route-status{
  position:absolute;top:20px;right:16px;
  padding:3px 8px;border-radius:var(--r-pill);font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;
}
.route-status--prod{background:rgba(5,150,105,0.15);color:var(--green);border:1px solid rgba(5,150,105,0.3)}
.route-status--soon{background:rgba(212,175,55,0.15);color:var(--gold);border:1px solid rgba(212,175,55,0.3)}

/* Route color themes */
.route--creadores{--stripe-a:#3c83a0;--stripe-b:#0d3b6e}
.route--negocio{--stripe-a:#5a189a;--stripe-b:#2d0a4e}
.route--tienda{--stripe-a:#4361ee;--stripe-b:#1a2a80}
.route--streaming{--stripe-a:#0ea5e9;--stripe-b:#023d5e}
.route--libro{--stripe-a:#0077b6;--stripe-b:#002d44}
.route--historias{--stripe-a:#3b28cc;--stripe-b:#1a0f5e}
.route--textos{--stripe-a:#1e88e5;--stripe-b:#0c3564}
.route--cursos{--stripe-a:#44a1b5;--stripe-b:#0d3d4d}
.route--edtech{--stripe-a:#3c096c;--stripe-b:#170329}
.route--mentores{--stripe-a:#00b4d8;--stripe-b:#003d52}

.routes-cta-wrap{text-align:center;max-width:600px}

/* ── CAMPUS ── */
.campus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.campus-card{
  border-radius:var(--r-xl);overflow:hidden;
  border:1px solid var(--border);
  background:var(--card-bg);backdrop-filter:blur(8px);
  transition:all var(--t);
  display:flex;
  flex-direction:column;
  height:100%;
}
.campus-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.campus-card-header{
  height:180px;display:flex;align-items:flex-end;padding:20px;
  position:relative;overflow:hidden;
}
.campus-card-header::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 20%,rgba(0,0,0,0.55) 100%);z-index:1;
}
.campus-card-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 0.4s ease;
}
.campus-card:hover .campus-card-img{transform:scale(1.05)}
.campus-card-label{position:relative;z-index:2;color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.2rem}
.campus-card-body{
  padding:20px 22px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.campus-routes{display:flex;flex-direction:column;gap:8px;margin:14px 0}
.campus-card-body .btn{margin-top:auto}
.campus-route-item{display:flex;align-items:center;gap:8px;font-size:0.85rem;color:var(--text-2)}
.campus-route-item::before{content:'◆';font-size:0.5rem;color:var(--accent)}

/* Campus catalog page */
.campus-catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.campus-catalog-card{
  border-radius:var(--r-xl);overflow:hidden;
  border:1px solid var(--border);
  background:var(--card-bg);
  transition:all var(--t);
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  height:100%;
}
.campus-catalog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.campus-catalog-hero{padding:36px 28px;position:relative;overflow:hidden}
.campus-catalog-hero--tech{background:linear-gradient(135deg,#0d2f4a,#3c83a0)}
.campus-catalog-hero--autores{background:linear-gradient(135deg,#002b44,#0077b6)}
.campus-catalog-hero--cursos{background:linear-gradient(135deg,#003d52,#00b4d8)}
.campus-catalog-icon-bg{position:absolute;right:-16px;bottom:-16px;font-size:100px;opacity:.1;line-height:1}
.campus-catalog-icon{font-size:2.5rem;margin-bottom:14px;position:relative}
.campus-catalog-title{
  font-family:var(--font-display);font-weight:800;font-size:1.5rem;
  color:#fff;letter-spacing:-.03em;margin-bottom:8px;position:relative;
}
.campus-catalog-pill{
  display:inline-flex;padding:4px 10px;border-radius:999px;
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);
  font-size:.75rem;font-weight:600;position:relative;
}
.campus-catalog-body{
  padding:22px 24px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.campus-catalog-desc{font-size:.9rem;color:var(--text-2);line-height:1.65;margin-bottom:16px}
.campus-catalog-routes{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.campus-catalog-route{display:flex;align-items:center;gap:7px;font-size:.82rem;color:var(--text-2)}
.campus-catalog-route-dot{font-size:.7rem}
.campus-catalog-route-dot--tech{color:#3c83a0}
.campus-catalog-route-dot--autores{color:#0077b6}
.campus-catalog-route-dot--cursos{color:#00b4d8}
.campus-catalog-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:700;margin-top:auto}
.campus-catalog-link--tech{color:#3c83a0}
.campus-catalog-link--autores{color:#0077b6}
.campus-catalog-link--cursos{color:#00b4d8}
.campus-overview-wrap{text-align:center}
.campus-overview-breadcrumb{
  display:flex;align-items:center;gap:8px;font-size:.82rem;
  color:rgba(255,255,255,.6);margin-bottom:18px;justify-content:center;
}
.campus-overview-breadcrumb-link{color:rgba(255,255,255,.6)}
.campus-overview-breadcrumb-sep{color:rgba(255,255,255,.3)}
.campus-overview-badge{
  display:inline-flex;align-items:center;gap:6px;padding:5px 14px;
  border-radius:999px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.9);
  font-size:.8rem;font-weight:600;margin-bottom:18px;
}
.campus-overview-title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2rem,5vw,3.5rem);color:#fff;
  letter-spacing:-.04em;margin-bottom:14px;
}
.campus-overview-sub{font-size:1.05rem;color:rgba(255,255,255,.8);line-height:1.7}
.campus-chooser-cta{
  margin-top:48px;padding:32px;border-radius:var(--r-xl);
  background:var(--bg-3);text-align:center;
}
.campus-chooser-eyebrow{justify-content:center;margin-bottom:10px}
.campus-chooser-title{font-family:var(--font-display);font-weight:700;font-size:1.4rem;margin-bottom:10px}
.campus-chooser-text{
  color:var(--text-2);max-width:500px;
  margin:0 auto 20px;line-height:1.65;font-size:.95rem;
}
@media(max-width:768px){.campus-grid{grid-template-columns:1fr}}

/* ── METHODOLOGY ── */
.method-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.method-item{
  display:flex;gap:16px;align-items:flex-start;
  padding:22px;border-radius:var(--r-xl);border:1px solid var(--border);
  background:var(--card-bg);backdrop-filter:blur(8px);transition:all var(--t);
}
.method-item:hover{border-color:rgba(0,180,216,0.3);transform:translateY(-2px)}
.method-icon{width:44px;height:44px;flex-shrink:0;border-radius:var(--r-md);background:rgba(0,180,216,0.1);display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.method-title{font-family:var(--font-display);font-weight:700;margin-bottom:6px;font-size:0.97rem;color:var(--text)}
.method-text{font-size:0.86rem;color:var(--text-2);line-height:1.6}
.method-list{display:flex;flex-direction:column;gap:9px;margin:2px 0 0}
.method-list li{display:flex;align-items:flex-start;gap:8px;font-size:0.85rem;color:var(--text-2);line-height:1.55}
.method-list li::before{content:'▸';color:var(--accent);flex-shrink:0;margin-top:1px}
.method-list strong{color:var(--text)}
@media(max-width:600px){.method-grid{grid-template-columns:1fr}}

/* ── NOX MENTOR DEMO ── */
.mentor-demo{
  background:linear-gradient(135deg,var(--navy) 0%,#091c45 50%,var(--cyan-deep) 100%);
  border-radius:var(--r-xl);padding:clamp(28px,4vw,48px);
  position:relative;overflow:hidden;
}
[data-theme="dark"] .mentor-demo{
  background:linear-gradient(135deg,#020820 0%,#061228 50%,#0c2040 100%);
  border:1px solid rgba(0,180,216,0.2);
}
.mentor-demo::before{
  content:'';position:absolute;top:-40%;right:-20%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(0,180,216,0.15),transparent 60%);
  pointer-events:none;
}
.mentor-demo-header{
  display:grid;grid-template-columns:1fr auto;gap:24px;align-items:start;
  margin-bottom:28px;position:relative;z-index:1;
}
.mentor-demo-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.6rem,3vw,2.2rem);color:#fff;margin-bottom:10px;letter-spacing:-0.03em}
.mentor-demo-sub{font-size:0.92rem;color:rgba(255,255,255,0.7);line-height:1.65;max-width:540px}
.mentor-tab-wrap{position:relative;z-index:1}
.mentor-tabs{display:flex;gap:4px;background:rgba(0,0,0,0.3);border-radius:var(--r-pill);padding:4px;margin-bottom:20px}
.mentor-tab{
  flex:1;padding:9px 16px;border-radius:var(--r-pill);
  font-size:0.85rem;font-weight:600;color:rgba(255,255,255,0.6);
  transition:all var(--t);cursor:pointer;text-align:center;
}
.mentor-tab.active{background:var(--cyan-deep);color:#fff;box-shadow:0 2px 12px rgba(0,180,216,0.4)}
.mentor-tab:hover:not(.active){color:#fff;background:rgba(255,255,255,0.08)}

.mentor-panel{display:none}
.mentor-panel.active{display:grid;gap:16px;grid-template-columns:1fr 1fr}
@media(max-width:768px){.mentor-panel.active{grid-template-columns:1fr}}

.m-card{
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-lg);padding:20px;backdrop-filter:blur(8px);
  transition:all var(--t);
}
.m-card:hover{background:rgba(255,255,255,0.09);border-color:rgba(0,180,216,0.4)}
.m-card-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.m-card-icon{font-size:1.4rem}
.m-card-title{font-weight:700;color:#fff;font-size:0.95rem}
.m-card-sub{font-size:0.75rem;color:rgba(255,255,255,0.6)}
.m-feature{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px;font-size:0.85rem;color:rgba(255,255,255,0.75)}
.m-feature::before{content:'▸';color:var(--cyan);flex-shrink:0;margin-top:1px}
.m-feature:last-child{margin-bottom:0}
#mentor-docentes .m-card{
  display:flex;
  flex-direction:column;
  height:100%;
}
#mentor-docentes .m-card > .btn{margin-top:auto}

/* Chat demo */
.m-chat{display:flex;flex-direction:column;gap:8px}
.m-chat-bubble{
  max-width:85%;padding:9px 13px;border-radius:12px;font-size:0.82rem;line-height:1.5;
}
.m-chat-bubble.ai{background:rgba(0,180,216,0.2);border:1px solid rgba(0,180,216,0.3);color:#e2f9fd;align-self:flex-start;border-radius:12px 12px 12px 4px}
.m-chat-bubble.user{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.9);align-self:flex-end;border-radius:12px 12px 4px 12px}
.m-chat-label{font-size:0.65rem;color:rgba(255,255,255,0.45);margin-bottom:3px}
.m-task{background:rgba(0,0,0,0.2);border:1px solid rgba(255,255,255,0.1);border-radius:var(--r-md);padding:12px;margin-bottom:8px}
.m-task-title{font-size:0.83rem;font-weight:600;color:#fff;margin-bottom:4px}
.m-task-desc{font-size:0.75rem;color:rgba(255,255,255,0.6);line-height:1.4}
.m-eval{display:flex;align-items:center;gap:8px;font-size:0.82rem;color:rgba(255,255,255,0.7);margin-bottom:8px}
.m-eval-score{
  width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:0.85rem;flex-shrink:0;
}
.m-eval-score.high{background:rgba(5,150,105,0.3);color:#4ade80;border:1px solid rgba(5,150,105,0.4)}
.m-eval-score.mid{background:rgba(212,175,55,0.3);color:var(--gold-light);border:1px solid rgba(212,175,55,0.4)}
@media(max-width:768px){.mentor-demo-header{grid-template-columns:1fr}}

/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.blog-featured{grid-column:span 2}
.blog-card{
  border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;
  background:var(--card-bg);backdrop-filter:blur(8px);transition:all var(--t);
  display:flex;flex-direction:column;height:100%;
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.blog-thumb{
  background:var(--bg-3);height:200px;display:flex;align-items:center;justify-content:center;
  font-size:3rem;transition:transform 0.3s ease;position:relative;overflow:hidden;
}
.blog-card:hover .blog-thumb img,.blog-card:hover .blog-thumb{transform:scale(1.03)}
.blog-featured .blog-thumb{height:260px}
.blog-body{padding:20px;display:flex;flex-direction:column;flex:1}
.blog-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.blog-date{font-size:0.75rem;color:var(--text-3)}
.blog-title{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin-bottom:8px;color:var(--text);line-height:1.3}
.blog-featured .blog-title{font-size:1.25rem}
.blog-excerpt{font-size:0.85rem;color:var(--text-2);line-height:1.6;margin-bottom:14px}
.blog-read-more{font-size:0.82rem;font-weight:600;color:var(--accent);margin-top:auto;display:inline-flex}
@media(max-width:768px){.blog-grid{grid-template-columns:1fr}.blog-featured{grid-column:span 1}}

/* ── FORUM ── */
.forum-preview{display:grid;grid-template-columns:1fr 280px;gap:20px}
.forum-threads{display:flex;flex-direction:column;gap:12px}
.forum-thread{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;border-radius:var(--r-lg);
  border:1px solid var(--border);background:var(--card-bg);
  backdrop-filter:blur(8px);transition:all var(--t);cursor:pointer;
}
.forum-thread:hover{border-color:rgba(0,180,216,0.3);transform:translateX(4px)}
.forum-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.85rem;color:#fff}
.forum-thread-main{flex:1;min-width:0}
.forum-thread-title{font-weight:600;font-size:0.9rem;color:var(--text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.forum-thread-meta{font-size:0.75rem;color:var(--text-3);display:flex;gap:12px}
.forum-thread-stats{display:flex;gap:12px;flex-shrink:0;font-size:0.78rem;color:var(--text-3)}
.forum-stat{display:flex;align-items:center;gap:4px}
.forum-sidebar{display:flex;flex-direction:column;gap:12px}
.forum-widget{
  padding:18px;border-radius:var(--r-xl);
  border:1px solid var(--border);background:var(--card-bg);backdrop-filter:blur(8px);
}
.forum-widget-title{font-family:var(--font-display);font-weight:700;font-size:0.9rem;margin-bottom:12px}
.forum-category{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:0.83rem;cursor:pointer}
.forum-category:last-child{border-bottom:none}
.forum-category:hover{color:var(--accent)}
.forum-cat-count{color:var(--text-3);font-size:0.75rem}
@media(max-width:768px){.forum-preview{grid-template-columns:1fr}}

/* ── COURSE CREATOR ── */
.creator-wrap{
  border:1px solid var(--border);border-radius:var(--r-xl);
  background:var(--card-bg);backdrop-filter:blur(8px);overflow:hidden;
}
.creator-topbar{
  display:flex;align-items:center;gap:12px;padding:14px 20px;
  border-bottom:1px solid var(--border);background:rgba(0,119,182,0.03);
}
.creator-tabs{display:flex;gap:2px}
.creator-tab{
  padding:7px 14px;border-radius:var(--r-md);font-size:0.83rem;font-weight:600;
  color:var(--text-3);transition:all var(--t);cursor:pointer;
}
.creator-tab.active{background:var(--cyan-deep);color:#fff}
.creator-tab:hover:not(.active){background:var(--border-2);color:var(--text)}
.creator-body{display:grid;grid-template-columns:260px 1fr;min-height:400px}
.creator-sidebar-panel{
  border-right:1px solid var(--border);padding:16px;
  background:rgba(0,0,0,0.02);
}
.creator-main-panel{padding:20px;display:none}
.creator-main-panel.active{display:block}
.creator-section-title{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-3);margin-bottom:10px;padding:0 4px}
.creator-module{
  display:flex;align-items:center;gap:8px;
  padding:9px 10px;border-radius:var(--r-md);font-size:0.84rem;color:var(--text-2);
  cursor:pointer;transition:all var(--t);margin-bottom:4px;
}
.creator-module:hover{background:var(--border-2);color:var(--text)}
.creator-module.active{background:rgba(0,180,216,0.1);color:var(--cyan-deep);font-weight:600}
.creator-module-icon{font-size:1rem;width:20px;text-align:center;flex-shrink:0}
.field-group{margin-bottom:18px}
.field-label{font-size:0.78rem;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:6px;display:block}
.field-input{
  width:100%;padding:9px 12px;border-radius:var(--r-md);
  border:1px solid var(--border);background:var(--bg);color:var(--text);
  font-size:0.88rem;transition:all var(--t);
}
.field-input:focus{outline:none;border-color:var(--cyan-deep);box-shadow:0 0 0 3px rgba(0,180,216,0.12)}
.field-textarea{min-height:90px;resize:vertical}
.field-select{cursor:pointer}
.ai-suggest{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 14px;border-radius:var(--r-md);
  background:linear-gradient(135deg,rgba(0,119,182,0.06),rgba(0,180,216,0.04));
  border:1px solid rgba(0,180,216,0.2);margin-bottom:10px;
}
.ai-suggest-icon{font-size:1.1rem;flex-shrink:0}
.ai-suggest-text{font-size:0.82rem;color:var(--text-2);line-height:1.5}
.ai-suggest-text strong{display:block;font-size:0.78rem;color:var(--accent);margin-bottom:3px}
@media(max-width:768px){.creator-body{grid-template-columns:1fr}.creator-sidebar-panel{border-right:none;border-bottom:1px solid var(--border)}}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{
  border:1px solid var(--border);border-radius:var(--r-xl);
  background:var(--card-bg);backdrop-filter:blur(8px);overflow:hidden;transition:border-color var(--t);
}
.faq-item:hover{border-color:rgba(0,180,216,0.2)}
.faq-item[open]{border-color:rgba(0,180,216,0.3)}
.faq-question{
  padding:18px 22px;cursor:pointer;font-weight:600;
  font-size:0.97rem;color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:12px;
  list-style:none;
}
.faq-question::after{content:'+';font-size:1.4rem;font-weight:300;color:var(--text-3);flex-shrink:0;transition:transform 0.2s ease}
.faq-item[open] .faq-question::after{content:'−';color:var(--cyan-deep)}
.faq-answer{padding:0 22px 18px;font-size:0.9rem;color:var(--text-2);line-height:1.7}

/* ── CTA FINAL ── */
.cta-final{
  background:linear-gradient(135deg,var(--navy),#0d3b6e,var(--cyan-deep));
  border-radius:var(--r-xl);padding:clamp(40px,6vw,72px);
  text-align:center;position:relative;overflow:hidden;
}
.cta-final::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='1' fill='rgba(255,255,255,0.06)'/%3E%3C/svg%3E") center/60px 60px;
}
.cta-final-content{position:relative;z-index:1;color:#fff}
.cta-final-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,4vw,3rem);letter-spacing:-0.04em;margin-bottom:16px}
.cta-final-text{font-size:1rem;opacity:0.82;max-width:520px;margin:0 auto 32px;line-height:1.7}
.cta-final-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta-final-note{font-size:0.8rem;opacity:0.6;margin-top:16px}

/* ── FOOTER ── */
.site-footer{
  border-top:1px solid var(--border);
  background:var(--surface-2);backdrop-filter:blur(10px);
  padding:32px 0 24px;
}
.footer-grid{display:grid;grid-template-columns:1fr auto auto auto;gap:32px;align-items:start;margin-bottom:28px}
.footer-brand{font-family:var(--font-display);font-weight:700;font-size:1.1rem;margin-bottom:8px}
.footer-brand-sub{font-size:0.82rem;color:var(--text-3);max-width:260px;line-height:1.5}
.footer-col-title{font-size:0.75rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:12px}
.footer-link{display:block;font-size:0.86rem;color:var(--text-2);margin-bottom:8px;transition:color var(--t)}
.footer-link:hover{color:var(--accent)}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding-top:20px;border-top:1px solid var(--border);
  font-size:0.8rem;color:var(--text-3);
}
.footer-legal{display:flex;gap:16px;flex-wrap:wrap}
.footer-legal button{color:var(--text-3);font-size:0.8rem;transition:color var(--t);cursor:pointer}
.footer-legal button:hover{color:var(--accent)}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr}}

/* ── WHATSAPP FAB ── */
.whatsapp-fab{
  position:fixed;bottom:24px;right:24px;z-index:80;
  width:54px;height:54px;border-radius:50%;
  background:#25d366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(37,211,102,0.4);
  transition:all var(--t);
}
.whatsapp-fab:hover{transform:scale(1.1);box-shadow:0 8px 28px rgba(37,211,102,0.55)}
.whatsapp-fab svg{width:26px;height:26px;fill:currentColor}

/* ── BACK TO TOP ── */
.back-top{
  position:fixed;bottom:90px;right:24px;z-index:80;
  width:42px;height:42px;border-radius:50%;
  background:var(--card-bg);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-2);box-shadow:var(--shadow);
  transition:all var(--t);opacity:0;pointer-events:none;
  font-size:1.1rem;
}
.back-top.visible{opacity:1;pointer-events:all}
.back-top:hover{background:var(--cyan-deep);color:#fff;border-color:var(--cyan-deep)}

/* ── MODAL ── */
.modal-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;pointer-events:none;transition:opacity 0.22s ease;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--r-xl);box-shadow:var(--shadow-lg);
  max-width:460px;width:100%;max-height:90vh;overflow-y:auto;
  transform:translateY(16px);transition:transform 0.22s ease;
}
.modal-overlay.open .modal{transform:none}
.modal-header{
  padding:22px 26px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.modal-title{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:var(--text)}
.modal-close{width:32px;height:32px;border-radius:50%;background:var(--bg-3);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all var(--t)}
.modal-close:hover{background:var(--bg);color:var(--text)}
.modal-body{padding:22px 26px 28px}
.modal-tabs{display:flex;gap:4px;background:var(--bg-3);border-radius:var(--r-pill);padding:4px;margin-bottom:22px}
.modal-tab{flex:1;padding:8px 12px;border-radius:var(--r-pill);font-size:0.85rem;font-weight:600;color:var(--text-3);transition:all var(--t);text-align:center;cursor:pointer}
.modal-tab.active{background:var(--cyan-deep);color:#fff}
.modal-panel{display:none}
.modal-panel.active{display:block}
.form-field{margin-bottom:14px}
.form-label{display:block;font-size:0.78rem;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:5px}
.form-input{
  width:100%;padding:10px 14px;border-radius:var(--r-md);
  border:1.5px solid var(--border);background:var(--bg);color:var(--text);
  font-size:0.9rem;transition:all var(--t);
}
.form-input:focus{outline:none;border-color:var(--cyan-deep);box-shadow:0 0 0 3px rgba(0,180,216,0.12)}
.form-hint{font-size:0.75rem;color:var(--text-3);margin-top:14px;text-align:center}
.form-divider{display:flex;align-items:center;gap:10px;margin:16px 0;color:var(--text-3);font-size:0.78rem}
.form-divider::before,.form-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.form-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(12px);z-index:300;
  background:var(--text);color:var(--bg);padding:11px 20px;border-radius:var(--r-pill);
  font-size:0.85rem;font-weight:600;
  box-shadow:var(--shadow-lg);
  opacity:0;pointer-events:none;transition:all 0.2s ease;white-space:nowrap;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── ANIMATED ENTRANCE ── */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity 0.5s ease,transform 0.5s ease}
.fade-in.visible{opacity:1;transform:none}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text-3)}

/* ── RESPONSIVE UTILS ── */
@media(max-width:900px){
  .main-nav,.campus-nav{display:none}
  .hamburger{display:flex}
  .header-actions .btn{display:none}
  .header-actions .theme-toggle,.header-actions .hamburger{display:flex}
  .logo-text{font-size:0.88rem}
  .logo-text span{display:none}
  .audience-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .header-inner{position:relative;padding:10px 12px;gap:8px}
  .logo-text{display:none}
  .header-actions{gap:6px}
  .header-actions .theme-toggle{display:none !important}
  .header-actions .hamburger{
    display:flex !important;
    position:fixed;
    top:10px;
    right:12px;
    z-index:130;
    padding:6px;
    border:1px solid var(--border);
    border-radius:10px;
    background:var(--bg-2);
    width:36px;
    height:34px;
    align-items:center;
    justify-content:center;
  }
  .header-actions .hamburger span{display:none}
  .header-actions .hamburger::before{content:'≡';font-size:22px;font-weight:700;line-height:1;color:var(--text)}
  .header-actions .hamburger.open::before{content:'×';font-size:24px}
  .cta-final-actions{flex-direction:column}
  .cta-final-actions .btn{justify-content:center}
}

/* ── ROUTE DETAIL PAGES ── */
.route-page{
  --route-hero-start:#0d3b6e;
  --route-hero-end:#3c83a0;
  --route-accent:#3c83a0;
  --route-accent-rgb:60,131,160;
}
.route-page .route-hero{
  padding:clamp(60px,8vw,110px) 0 clamp(40px,5vw,70px);
  background:linear-gradient(135deg,var(--route-hero-start) 0%,var(--route-hero-end) 100%);
  position:relative;
  overflow:hidden;
}
.route-page .route-hero::before{
  content:attr(data-route-icon);
  position:absolute;
  right:-30px;
  bottom:-40px;
  font-size:clamp(140px,20vw,220px);
  opacity:0.08;
  line-height:1;
  pointer-events:none;
}
.route-page .route-hero-content{position:relative;z-index:1}
.route-page .route-hero h1{font-family:var(--font-display);font-weight:800;font-size:clamp(2.2rem,5vw,3.8rem);color:#fff;letter-spacing:-0.04em;line-height:1.05;margin-bottom:16px}
.route-page .route-hero p{font-size:1.05rem;color:rgba(255,255,255,0.82);max-width:600px;line-height:1.7;margin-bottom:28px}
.route-page .route-hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.route-page .route-badge{display:inline-flex;align-items:center;gap:8px;margin-bottom:20px;padding:6px 14px;border-radius:var(--r-pill);background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.9);font-size:0.8rem;font-weight:600}
.route-page .route-meta-bar{
  background:rgba(0,0,0,0.25);
  border-top:1px solid rgba(255,255,255,0.1);
  padding:14px 0;
  margin-top:28px;
}
.route-page .route-meta-inner{display:flex;gap:28px;flex-wrap:wrap}
.route-page .route-meta-item{color:rgba(255,255,255,0.75);font-size:0.85rem}
.route-page .route-meta-item strong{display:block;color:#fff;font-weight:700}
.route-page .block-section{margin-bottom:48px}
.route-page .block-header{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.route-page .block-num{
  padding:5px 14px;
  border-radius:var(--r-pill);
  background:linear-gradient(135deg,var(--route-accent),var(--route-hero-start));
  color:#fff;
  font-size:0.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
  flex-shrink:0;
}
.route-page .block-title{font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--text);margin:0}
.route-page .modules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.route-page .module-card{
  padding:20px;
  border-radius:var(--r-xl);
  border:1px solid var(--border);
  background:var(--card-bg);
  backdrop-filter:blur(8px);
  transition:all var(--t);
}
.route-page .module-card:hover{
  border-color:rgba(var(--route-accent-rgb),0.33);
  box-shadow:0 8px 24px rgba(var(--route-accent-rgb),0.13);
  transform:translateY(-2px);
}
.route-page .module-num{font-size:0.7rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--route-accent);margin-bottom:6px}
.route-page .module-title{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--text);margin-bottom:8px}
.route-page .module-obj{font-size:0.85rem;color:var(--text-2);line-height:1.6;margin:0}
.route-page .for-list,.route-page .deliver-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.route-page .for-list li,.route-page .deliver-list li{display:flex;align-items:flex-start;gap:10px;font-size:0.95rem;color:var(--text-2);line-height:1.6}
.route-page .for-dot{color:var(--gold);flex-shrink:0;font-size:0.75rem;margin-top:3px}
.route-page .deliver-dot{color:var(--route-accent);flex-shrink:0;font-size:1rem}
.route-page .price-box{
  background:linear-gradient(135deg,var(--route-hero-start),var(--route-hero-end));
  border-radius:var(--r-xl);
  padding:clamp(28px,4vw,48px);
  color:#fff;
  text-align:center;
}
.route-page .price-box h3{font-family:var(--font-display);font-weight:800;font-size:1.8rem;margin-bottom:10px;letter-spacing:-0.03em}
.route-page .price-box p{opacity:0.82;margin-bottom:24px;font-size:0.95rem}
.route-page .breadcrumb{display:flex;align-items:center;gap:8px;font-size:0.82rem;color:rgba(255,255,255,0.65);margin-bottom:16px}
.route-page .breadcrumb a{color:rgba(255,255,255,0.65);transition:color var(--t)}
.route-page .breadcrumb a:hover{color:#fff}
.route-page .breadcrumb span{color:rgba(255,255,255,0.4)}
.route-page .route-highlight{
  background:linear-gradient(135deg,var(--route-hero-start),var(--route-hero-end));
  border-radius:var(--r-xl);
  padding:28px;
  color:#fff;
}
@media(max-width:768px){
  .route-page .modules-grid{grid-template-columns:1fr}
}

/* ── CAMPUS PAGES ── */
.campus-page{
  --campus-hero-start:#0d2f4a;
  --campus-hero-end:#3c83a0;
}
.campus-page .campus-hero{
  padding:clamp(60px,8vw,110px) 0 clamp(40px,5vw,70px);
  background:linear-gradient(135deg,var(--campus-hero-start),var(--campus-hero-end));
  position:relative;
  overflow:hidden;
}
.campus-page .campus-hero::before{
  content:attr(data-campus-icon);
  position:absolute;
  right:-20px;
  bottom:-20px;
  font-size:clamp(160px,22vw,280px);
  opacity:0.07;
  line-height:1;
  pointer-events:none;
}
.campus-page .campus-hero-content{position:relative;z-index:1}
.campus-page .campus-hero h1{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,5vw,3.5rem);color:#fff;letter-spacing:-0.04em;margin-bottom:14px}
.campus-page .campus-hero p{font-size:1.05rem;color:rgba(255,255,255,0.82);max-width:600px;line-height:1.7;margin-bottom:28px}
.campus-page .campus-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
.campus-page .campus-info-card{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:var(--r-xl);padding:22px;color:#fff;backdrop-filter:blur(8px)}
.campus-page .campus-info-card h3{font-family:var(--font-display);font-weight:700;font-size:1rem;margin-bottom:10px}
.campus-page .campus-info-card p{font-size:0.88rem;line-height:1.65;opacity:0.82}
.campus-page .breadcrumb{display:flex;align-items:center;gap:8px;font-size:0.82rem;color:rgba(255,255,255,0.6);margin-bottom:18px}
.campus-page .breadcrumb a{color:rgba(255,255,255,0.6);transition:color var(--t)}
.campus-page .breadcrumb a:hover{color:#fff}
.campus-page .breadcrumb span{color:rgba(255,255,255,0.35)}
@media(max-width:600px){
  .campus-page .campus-info-grid{grid-template-columns:1fr}
}
