*, *::before, *::after { box-sizing: border-box; }
html { color-scheme: dark; scroll-behavior: smooth; }
body { margin: 0; font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; background: radial-gradient(1200px 800px at 20% 10%, rgba(59,130,246,0.18), transparent 50%), radial-gradient(900px 700px at 80% 30%, rgba(34,211,238,0.10), transparent 55%), #070A12; color: rgba(255,255,255,0.88); line-height: 1.55; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; }

:root {
  --bg: #070A12;
  --panel: rgba(255,255,255,0.06);
  --panel-2: rgba(255,255,255,0.04);
  --stroke: rgba(255,255,255,0.10);
  --stroke-2: rgba(255,255,255,0.14);
  --text: rgba(255,255,255,0.90);
  --muted: rgba(255,255,255,0.70);
  --muted-2: rgba(255,255,255,0.62);
  --blue: #3B82F6;
  --blue-2: #2563EB;
  --cyan: #22D3EE;
  --green: #10B981;
  --shadow: 0 18px 60px rgba(0,0,0,0.55);
  --shadow-soft: 0 12px 40px rgba(0,0,0,0.38);
  --radius: 18px;
  --radius-lg: 26px;
  --radius-sm: 14px;
  --container: 1120px;
}

.container { width: min(var(--container), calc(100% - 2rem)); margin-inline: auto; }

.skip-link { position: absolute; left: 12px; top: 12px; padding: 10px 12px; border-radius: 12px; background: rgba(0,0,0,0.85); border: 1px solid var(--stroke); transform: translateY(-160%); transition: transform 180ms ease; z-index: 100; }
.skip-link:focus { transform: translateY(0); outline: none; }

.site-header { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(14px); background: linear-gradient(90deg, rgba(255,255,255,0.78), rgba(255,255,255,0.58)); border-bottom: 1px solid rgba(255,255,255,0.30); transition: background 200ms ease, border-color 200ms ease, box-shadow 200ms ease; }
.site-header.is-scrolled { background: linear-gradient(90deg, rgba(255,255,255,0.88), rgba(255,255,255,0.72)); border-bottom-color: rgba(255,255,255,0.38); box-shadow: 0 10px 40px rgba(0,0,0,0.18); }
.header-inner { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 14px; padding: 14px 0; }

.brand { display: inline-flex; align-items: center; gap: 12px; min-width: 220px; }
.brand-logo { width: 58px; height: 58px; object-fit: contain; filter: drop-shadow(0 10px 18px rgba(0,0,0,0.55)); }
.brand-text { display: grid; line-height: 1.1; padding: 8px 10px; border-radius: 14px; background: rgba(255,255,255,0.52); border: 1px solid rgba(15,23,42,0.10); backdrop-filter: blur(10px); }
.brand-name { font-family: "Space Grotesk", Inter, system-ui, sans-serif; font-weight: 700; letter-spacing: 0.2px; color: rgba(15,23,42,0.96); text-shadow: 0 1px 0 rgba(255,255,255,0.40); }
.brand-tag { font-size: 0.92rem; color: rgba(15,23,42,0.72); font-weight: 600; text-shadow: 0 1px 0 rgba(255,255,255,0.35); }

.site-nav { display: inline-flex; align-items: center; gap: 12px; }
.nav-link { padding: 10px 12px; border-radius: 12px; color: rgba(15,23,42,0.76); transition: background 160ms ease, color 160ms ease, transform 160ms ease; }
.nav-link:hover { background: rgba(15,23,42,0.06); color: rgba(15,23,42,0.92); transform: translateY(-1px); }
.nav-link[aria-current="page"] { background: rgba(59,130,246,0.16); color: rgba(15,23,42,0.94); border: 1px solid rgba(37,99,235,0.26); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; border-radius: 16px; padding: 12px 14px; border: 1px solid transparent; cursor: pointer; user-select: none; transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease, border-color 160ms ease; }
.btn i { font-size: 0.95em; }
.btn:active { transform: translateY(0); }

.btn-primary { background: linear-gradient(135deg, rgba(59,130,246,0.95), rgba(34,211,238,0.55)); border-color: rgba(255,255,255,0.10); box-shadow: 0 18px 50px rgba(37,99,235,0.25); }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 18px 70px rgba(37,99,235,0.35); }
.btn-primary:focus-visible { outline: 2px solid rgba(34,211,238,0.65); outline-offset: 3px; }

.btn-ghost { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.10); color: rgba(255,255,255,0.86); }
.btn-ghost:hover { transform: translateY(-1px); background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.16); }

.btn-campus { background: rgba(255,255,255,0.62); color: rgba(15,23,42,0.92); border-color: rgba(37,99,235,0.26); box-shadow: inset 0 0 0 1px rgba(37,99,235,0.10); }
.btn-campus:hover { transform: translateY(-1px); background: rgba(59,130,246,0.14); border-color: rgba(37,99,235,0.34); }

.nav-toggle { display: none; width: 44px; height: 44px; border-radius: 14px; border: 1px solid rgba(15,23,42,0.14); background: rgba(255,255,255,0.62); cursor: pointer; transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; }
.nav-toggle:hover { transform: translateY(-1px); background: rgba(255,255,255,0.74); border-color: rgba(15,23,42,0.18); }
.nav-toggle:focus-visible { outline: 2px solid rgba(34,211,238,0.65); outline-offset: 3px; }
.nav-toggle-lines { position: relative; display: block; width: 18px; height: 2px; background: rgba(15,23,42,0.86); margin: 0 auto; border-radius: 999px; transition: transform 180ms ease, background 180ms ease; }
.nav-toggle-lines::before, .nav-toggle-lines::after { content: ""; position: absolute; left: 0; width: 18px; height: 2px; background: rgba(15,23,42,0.86); border-radius: 999px; transition: transform 180ms ease, top 180ms ease, opacity 160ms ease; }
.nav-toggle-lines::before { top: -6px; }
.nav-toggle-lines::after { top: 6px; }
.nav-toggle.is-open .nav-toggle-lines { background: transparent; }
.nav-toggle.is-open .nav-toggle-lines::before { top: 0; transform: rotate(45deg); }
.nav-toggle.is-open .nav-toggle-lines::after { top: 0; transform: rotate(-45deg); }

.hero { position: relative; padding: 42px 0 26px; overflow: clip; }
.hero-backdrop { position: absolute; inset: 0; pointer-events: none; }
.hero-grid { position: absolute; inset: -20% -10%; background-image: linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px); background-size: 62px 62px; transform: rotate(-8deg); mask-image: radial-gradient(closest-side, rgba(0,0,0,0.90), transparent 80%); opacity: 0.20; }
.hero-glow { position: absolute; width: 520px; height: 520px; border-radius: 50%; filter: blur(28px); opacity: 0.70; }
.hero-glow-a { left: -120px; top: -140px; background: radial-gradient(circle at 30% 30%, rgba(59,130,246,0.85), transparent 55%); }
.hero-glow-b { right: -120px; bottom: -180px; background: radial-gradient(circle at 30% 30%, rgba(34,211,238,0.65), transparent 58%); }

.hero-layout { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 34px; align-items: center; }
.hero-copy h1 { font-family: "Space Grotesk", Inter, system-ui, sans-serif; font-size: clamp(2.1rem, 3.1vw, 3.3rem); line-height: 1.05; margin: 10px 0 14px; letter-spacing: -0.5px; }
.lead { margin: 0; color: var(--muted); font-size: 1.02rem; max-width: 58ch; }

.kicker { display: inline-flex; align-items: center; gap: 10px; margin: 0; padding: 8px 12px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.03); color: rgba(255,255,255,0.78); font-weight: 600; font-size: 0.92rem; }
.kicker-dot { width: 10px; height: 10px; border-radius: 50%; background: radial-gradient(circle at 30% 30%, var(--cyan), var(--blue)); box-shadow: 0 0 0 5px rgba(34,211,238,0.10); }

.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin: 18px 0 18px; }
.hero-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.chip { display: inline-flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 999px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); color: rgba(255,255,255,0.80); font-size: 0.92rem; transition: transform 160ms ease, border-color 160ms ease, background 160ms ease; }
.chip:hover { transform: translateY(-1px); background: rgba(255,255,255,0.05); border-color: rgba(59,130,246,0.22); }
.chip i { color: rgba(34,211,238,0.92); }

.hero-visual { position: relative; }
.visual-stage { position: relative; border-radius: var(--radius-lg); padding: 22px; background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)); border: 1px solid rgba(255,255,255,0.10); box-shadow: var(--shadow); overflow: hidden; }
.visual-stage::before { content: ""; position: absolute; inset: 0; background: radial-gradient(520px 320px at 60% 25%, rgba(59,130,246,0.18), transparent 60%), radial-gradient(480px 320px at 30% 80%, rgba(34,211,238,0.12), transparent 65%); opacity: 0.9; }
.abstract-orbit { position: relative; width: 100%; height: auto; display: block; transform-origin: center; animation: orbit 16s linear infinite; }
@keyframes orbit { from { transform: rotate(0deg) scale(1); } to { transform: rotate(360deg) scale(1); } }

.float-card { position: absolute; right: 18px; bottom: 18px; width: min(260px, 78%); border-radius: 18px; padding: 14px 14px 12px; background: rgba(7,10,18,0.70); border: 1px solid rgba(255,255,255,0.14); backdrop-filter: blur(14px); box-shadow: var(--shadow-soft); transform: translateY(0); transition: transform 220ms ease, border-color 220ms ease; }
.visual-stage:hover .float-card { transform: translateY(-4px); border-color: rgba(34,211,238,0.26); }
.float-card-top { display: flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: 0.2px; }
.float-label { font-family: "Space Grotesk", Inter, system-ui, sans-serif; }
.pulse { width: 10px; height: 10px; border-radius: 50%; background: rgba(34,211,238,0.95); box-shadow: 0 0 0 0 rgba(34,211,238,0.40); animation: pulse 2.2s ease-out infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(34,211,238,0.42); } 70% { box-shadow: 0 0 0 14px rgba(34,211,238,0); } 100% { box-shadow: 0 0 0 0 rgba(34,211,238,0); } }
.float-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 12px; }
.metric { padding: 10px 10px; border-radius: 14px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); }
.metric-k { display: block; color: rgba(255,255,255,0.64); font-weight: 600; font-size: 0.85rem; }
.metric-v { display: block; font-weight: 700; }

.section { padding: 54px 0; }
.section-head { display: grid; gap: 10px; margin-bottom: 26px; }
.section-head h2 { font-family: "Space Grotesk", Inter, system-ui, sans-serif; font-size: clamp(1.5rem, 2.0vw, 2.1rem); margin: 0; letter-spacing: -0.3px; }
.section-head p { margin: 0; color: var(--muted); max-width: 80ch; }

.section-academia { position: relative; }
.academy-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start; }
.academy-panel .panel-surface { position: relative; border-radius: var(--radius-lg); padding: 22px; background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)); border: 1px solid rgba(255,255,255,0.10); box-shadow: var(--shadow-soft); overflow: hidden; }
.panel-line { position: absolute; inset: -40% -25%; background: linear-gradient(90deg, transparent, rgba(34,211,238,0.25), transparent); transform: rotate(18deg); opacity: 0.35; }
.academy-panel h3 { margin: 0 0 10px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.academy-panel p { margin: 0; color: var(--muted); }
.panel-cta { margin-top: 14px; }
.text-link { display: inline-flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 14px; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.03); transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; }
.text-link:hover { transform: translateY(-1px); background: rgba(59,130,246,0.10); border-color: rgba(34,211,238,0.26); }

.academy-cards { display: grid; gap: 12px; }
.h-card { display: grid; grid-template-columns: auto 1fr; gap: 14px; padding: 16px; border-radius: 22px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); transition: transform 160ms ease, border-color 160ms ease, background 160ms ease; }
.h-card:hover { transform: translateY(-2px); background: rgba(255,255,255,0.05); border-color: rgba(59,130,246,0.22); }
.h-card-icon { width: 44px; height: 44px; border-radius: 16px; display: grid; place-items: center; background: linear-gradient(135deg, rgba(59,130,246,0.22), rgba(34,211,238,0.12)); border: 1px solid rgba(59,130,246,0.22); box-shadow: 0 18px 40px rgba(0,0,0,0.25); }
.h-card-icon i { color: rgba(34,211,238,0.95); }
.h-card-body h4 { margin: 0 0 6px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.h-card-body p { margin: 0; color: var(--muted); }

.section-experiencia { position: relative; }
.experience-grid { display: grid; gap: 14px; position: relative; }
.experience-grid::before { content: ""; position: absolute; left: 22px; top: 18px; bottom: 18px; width: 1px; background: linear-gradient(180deg, rgba(34,211,238,0.0), rgba(34,211,238,0.35), rgba(59,130,246,0.35), rgba(34,211,238,0.0)); opacity: 0.9; }
.exp-block { position: relative; display: grid; grid-template-columns: 44px 1fr; gap: 14px; padding: 18px; border-radius: 26px; background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 50px rgba(0,0,0,0.22); }
.exp-block:hover { border-color: rgba(34,211,238,0.26); }
.exp-alt { background: linear-gradient(180deg, rgba(59,130,246,0.08), rgba(255,255,255,0.02)); }
.exp-knot { width: 44px; height: 44px; border-radius: 18px; background: radial-gradient(circle at 35% 35%, rgba(34,211,238,0.55), rgba(59,130,246,0.10)); border: 1px solid rgba(34,211,238,0.22); box-shadow: 0 18px 50px rgba(37,99,235,0.20); position: relative; }
.exp-knot::after { content: ""; position: absolute; inset: 11px; border-radius: 12px; background: rgba(7,10,18,0.55); border: 1px solid rgba(255,255,255,0.10); }
.exp-content h3 { margin: 0 0 8px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.exp-content p { margin: 0; color: var(--muted); }

.section-campus { padding-top: 8px; }
.campus-callout { display: grid; grid-template-columns: 1fr auto; gap: 18px; align-items: center; padding: 22px; border-radius: 30px; background: radial-gradient(1000px 220px at 15% 20%, rgba(59,130,246,0.30), transparent 55%), radial-gradient(800px 260px at 90% 80%, rgba(34,211,238,0.18), transparent 60%), rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.10); box-shadow: var(--shadow); overflow: hidden; }
.campus-left h2 { margin: 0 0 10px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.3px; }
.campus-left p { margin: 0; color: var(--muted); }
.campus-right { display: grid; justify-items: end; gap: 10px; }
.mini-note { font-size: 0.92rem; color: rgba(255,255,255,0.70); padding: 8px 10px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.10); background: rgba(7,10,18,0.35); }

.site-footer { padding: 26px 0; border-top: 1px solid rgba(255,255,255,0.08); background: rgba(0,0,0,0.15); }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.footer-title { font-weight: 700; font-family: "Space Grotesk", Inter, system-ui, sans-serif; }
.footer-sub { color: var(--muted); }
.footer-link { display: inline-flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 14px; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.03); transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; }
.footer-link:hover { transform: translateY(-1px); background: rgba(59,130,246,0.10); border-color: rgba(34,211,238,0.26); }

.page-hero { position: relative; padding: 40px 0 10px; overflow: clip; }
.page-hero-back { position: absolute; inset: 0; pointer-events: none; }
.page-hero-inner { padding: 10px 0 26px; }
.page-hero-copy h1 { font-family: "Space Grotesk", Inter, system-ui, sans-serif; font-size: clamp(2.0rem, 3vw, 3.0rem); line-height: 1.05; margin: 10px 0 12px; letter-spacing: -0.4px; }

.contact-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 12px; }
.contact-card { grid-column: span 4; display: grid; grid-template-columns: 54px 1fr; gap: 14px; padding: 18px; border-radius: 26px; background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 50px rgba(0,0,0,0.20); transition: transform 160ms ease, border-color 160ms ease; }
.contact-card:hover { transform: translateY(-2px); border-color: rgba(34,211,238,0.26); }
.contact-card-wide { grid-column: span 12; }
.contact-icon { width: 54px; height: 54px; border-radius: 20px; display: grid; place-items: center; background: linear-gradient(135deg, rgba(59,130,246,0.20), rgba(34,211,238,0.10)); border: 1px solid rgba(59,130,246,0.22); }
.contact-icon i { color: rgba(34,211,238,0.95); font-size: 1.1rem; }
.contact-body h2 { margin: 0 0 8px; font-size: 1.05rem; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.contact-text { margin: 0; color: var(--muted); }
.contact-link { display: inline-flex; align-items: center; gap: 10px; color: rgba(255,255,255,0.86); padding: 8px 10px; border-radius: 14px; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.03); transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; word-break: break-word; }
.contact-link:hover { transform: translateY(-1px); background: rgba(59,130,246,0.10); border-color: rgba(34,211,238,0.26); }
.contact-actions { margin-top: 12px; }

.contact-card-wide { grid-template-columns: 54px 1fr; align-items: start; }
.contact-lines { display: grid; gap: 6px; margin-top: 8px; }
.contact-lines .contact-text { color: rgba(255,255,255,0.78); }
.contact-lines strong { color: rgba(255,255,255,0.92); font-weight: 700; }
.inline-link { color: rgba(255,255,255,0.90); text-decoration: underline; text-decoration-color: rgba(34,211,238,0.55); text-underline-offset: 3px; transition: color 160ms ease, text-decoration-color 160ms ease; }
.inline-link:hover { color: rgba(34,211,238,0.95); text-decoration-color: rgba(34,211,238,0.95); }

.reveal { opacity: 0; transform: translateY(14px); filter: blur(6px); transition: opacity 520ms ease, transform 520ms ease, filter 520ms ease; transition-delay: var(--reveal-delay, 0ms); }
.reveal.is-visible { opacity: 1; transform: translateY(0); filter: blur(0); }

.course-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 12px; }
.course-card { grid-column: span 12; padding: 20px; border-radius: 30px; background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 60px rgba(0,0,0,0.25); }
.course-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 10px; }
.course-badge { display: inline-flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 999px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.10); }
.course-badge i { color: rgba(34,211,238,0.95); }
.course-meta { color: var(--muted); font-weight: 600; font-size: 0.92rem; }
.course-card h2 { margin: 0 0 10px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.course-sub { margin: 0 0 16px; color: var(--muted); font-size: 1.02rem; }
.course-actions { display: flex; flex-wrap: wrap; gap: 12px; }

.modal { position: fixed; inset: 0; display: grid; place-items: center; padding: 1rem; opacity: 0; pointer-events: none; transition: opacity 200ms ease; z-index: 80; }
.modal.is-open { opacity: 1; pointer-events: auto; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.58); backdrop-filter: blur(6px); }
.modal-panel { position: relative; width: min(940px, 100%); max-height: min(78vh, 820px); overflow: auto; border-radius: 30px; background: linear-gradient(180deg, rgba(12,16,28,0.94), rgba(7,10,18,0.92)); border: 1px solid rgba(255,255,255,0.12); box-shadow: 0 30px 120px rgba(0,0,0,0.60); }
.modal-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 18px 18px 10px; border-bottom: 1px solid rgba(255,255,255,0.08); }
.modal-kicker { color: rgba(34,211,238,0.86); font-weight: 700; font-size: 0.92rem; letter-spacing: 0.2px; }
.modal-title { margin: 6px 0 0; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; font-size: 1.35rem; }
.modal-close { width: 44px; height: 44px; border-radius: 16px; border: 1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.04); cursor: pointer; transition: transform 160ms ease, background 160ms ease, border-color 160ms ease; }
.modal-close:hover { transform: translateY(-1px); background: rgba(255,255,255,0.06); border-color: rgba(34,211,238,0.22); }
.modal-body { padding: 16px 18px 18px; }
.modal-lead { color: rgba(255,255,255,0.78); font-weight: 600; margin-bottom: 14px; }
.modal-section { margin-top: 18px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.08); }
.modal-section h3 { margin: 0 0 10px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.modal-section p { margin: 0; color: rgba(255,255,255,0.78); }
.rich-block p { margin: 0 0 10px; color: rgba(255,255,255,0.78); }
.steps { margin: 12px 0 0; padding-left: 1.2rem; color: rgba(255,255,255,0.78); }
.steps li { margin: 10px 0; }
.steps strong { color: rgba(255,255,255,0.92); }
.modal-foot { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; justify-content: flex-end; margin-top: 18px; }

.identity-layout { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: 14px; align-items: start; }
.identity-card { border-radius: 30px; padding: 22px; background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 60px rgba(0,0,0,0.22); }
.identity-card h2 { margin: 0 0 10px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.identity-card p { margin: 0 0 10px; color: var(--muted); }
.identity-stack { display: grid; gap: 12px; }
.mini-panel { border-radius: 26px; padding: 18px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 18px 50px rgba(0,0,0,0.18); }
.mini-panel h3 { margin: 0 0 8px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.mini-panel p { margin: 0; color: var(--muted); }
.checklist { margin: 10px 0 0; padding-left: 1.2rem; color: var(--muted); }
.checklist li { margin: 8px 0; }

.section-alt { background: radial-gradient(900px 280px at 20% 20%, rgba(59,130,246,0.12), transparent 60%), rgba(255,255,255,0.01); border-top: 1px solid rgba(255,255,255,0.06); border-bottom: 1px solid rgba(255,255,255,0.06); }
.long-card { border-radius: 30px; padding: 22px; background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); border: 1px solid rgba(255,255,255,0.10); box-shadow: 0 18px 60px rgba(0,0,0,0.22); }
.long-card p { margin: 0 0 10px; color: var(--muted); }
.split-panels { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.values-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 12px; }
.value-tile { grid-column: span 6; border-radius: 26px; padding: 18px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 18px 50px rgba(0,0,0,0.18); }
.value-tile h3 { margin: 0 0 8px; font-family: "Space Grotesk", Inter, system-ui, sans-serif; letter-spacing: -0.2px; }
.value-tile p { margin: 0; color: var(--muted); }
.section-spacer { height: 18px; }

@media (max-width: 940px) {
  .identity-layout { grid-template-columns: 1fr; }
  .split-panels { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .value-tile { grid-column: span 12; }
  .modal-panel { max-height: 82vh; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .abstract-orbit { animation: none; }
  .pulse { animation: none; }
  .reveal { transition: none; opacity: 1; transform: none; filter: none; }
  .btn, .nav-link, .chip, .footer-link, .contact-card, .h-card { transition: none; }
}

@media (max-width: 940px) {
  .header-inner { grid-template-columns: 1fr auto; }
  .nav-toggle { display: inline-grid; place-items: center; }
  .site-nav { position: fixed; left: 1rem; right: 1rem; top: 74px; display: grid; gap: 10px; padding: 14px; border-radius: 22px; background: linear-gradient(180deg, rgba(255,255,255,0.86), rgba(255,255,255,0.66)); border: 1px solid rgba(15,23,42,0.12); box-shadow: var(--shadow); transform: translateY(-10px); opacity: 0; pointer-events: none; transition: opacity 180ms ease, transform 180ms ease; }
  .site-nav.is-open { opacity: 1; transform: translateY(0); pointer-events: auto; }
  .btn-campus { justify-content: center; }
  .hero-layout { grid-template-columns: 1fr; }
  .hero { padding-top: 26px; }
  .academy-layout { grid-template-columns: 1fr; }
  .campus-callout { grid-template-columns: 1fr; }
  .campus-right { justify-items: start; }
}

@media (max-width: 720px) {
  .contact-card { grid-column: span 12; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
  .brand { min-width: unset; }
  .brand-logo { width: 50px; height: 50px; }
}
