@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700&display=swap');
:root { --brand: #ffc107; --brand-dark: #e0a800; --accent: #e53935; --ink: #111111; --text: #212529; --muted: #6c757d; }
body { font-family: Poppins, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica Neue, Arial; color: var(--text); }
.card .card-title { color: var(--ink); }
.navbar-brand img { height: 64px; }
.brand-logo { height: 72px; }
.navbar-brand .brand-text { font-size: 1.4rem; }
@media (max-width: 576px) {
  .navbar-brand img, .brand-logo { height: 56px; }
  .navbar-brand .brand-text { font-size: 1.2rem; }
}
.navbar { transition: box-shadow .2s ease, background-color .2s ease; }
.navbar.nav-scrolled { box-shadow: 0 10px 30px rgba(0,0,0,.08); }
.navbar { position: sticky; top: 0; z-index: 1020; background: rgba(255,255,255,.92); backdrop-filter: saturate(180%) blur(6px); }
.nav-link { position: relative; }
.nav-link::after { content: ""; position: absolute; left: 0; bottom: -6px; height: 2px; width: 0; background: var(--accent); transition: width .2s ease; }
.nav-link:hover::after, .nav-link.active::after { width: 100%; }
.topbar { background: var(--brand); color: var(--ink); }
.topbar a { color: var(--ink); }
.topbar a.btn { border-color: rgba(0,0,0,.2); color: var(--ink); }
.brand-text { letter-spacing: .3px; }
.brand-subtitle { font-size: .8rem; color: var(--muted); }
.mega-dropdown .dropdown-menu { min-width: 680px; }
.mega-dropdown .dropdown-item { border-radius: 8px; }
.mega-dropdown .dropdown-item:hover { background-color: #fffbea; }
.navbar-actions .btn { border-radius: 999px; }
.navbar-actions .btn-primary { padding: .45rem .9rem; }
.navbar-actions .btn-outline-primary { padding: .45rem .9rem; }
.topbar .badge-admit { background: rgba(255,255,255,.15); color: #fff; border: 1px solid rgba(255,255,255,.3); }
.dropdown-menu { border-radius: 12px; box-shadow: 0 18px 36px rgba(16, 24, 40, 0.12); border: 1px solid #e9ecef; }
.dropdown-item { padding: .5rem 1rem; }
.dropdown-item:hover { background-color: #fff7db; color: var(--ink); }
.btn-outline-primary { border-color: var(--brand); color: var(--ink); background-color: #fff; }
.btn-outline-primary:hover { background-color: var(--brand); color: var(--ink); }
.home-banner .carousel-item { height: 75vh; min-height: 520px; }
.home-banner .carousel-item img { object-fit: cover; height: 100%; }
.home-banner .carousel-item::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.35), rgba(0,0,0,0.5)); }
.home-banner .carousel-caption { bottom: 22%; text-align: left; }
.home-banner .carousel-caption h1, .home-banner .carousel-caption h2 { color: #fff; }
.home-banner .carousel-caption p { color: #eef2f7; max-width: 720px; }
.home-banner .caption-actions { margin-top: 12px; }
.home-banner .caption-chips { margin-top: 10px; }
.home-banner .caption-chips .chip { background: #fffbea; border-color: #ffe08a; }
.home-banner { position: relative; }
.home-banner .scroll-down { position: absolute; left: 50%; transform: translateX(-50%); bottom: 16px; width: 48px; height: 48px; border-radius: 50%; border: 2px solid var(--brand); display: grid; place-items: center; background: rgba(255,255,255,.92); color: var(--brand); animation: bounceY 1.4s infinite; z-index: 1100; cursor: pointer; }
.btn-primary { background-color: var(--ink); border-color: var(--ink); }
.btn-primary:hover { background-color: #000; border-color: #000; }
.section-title { font-weight: 700; }
.section-title::after { content: ""; display: block; width: 56px; height: 3px; background: var(--accent); margin-top: 8px; border-radius: 2px; }
.list-check { list-style: none; padding-left: 0; }
.list-check li { position: relative; padding-left: 28px; margin-bottom: 10px; }
.list-check li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--accent); font-weight: 700; }
.stat { background: #f8f9fa; border: 1px solid #e9ecef; border-radius: 10px; padding: 20px; }
.stat .value { font-size: 28px; font-weight: 800; color: var(--brand); }
.stat .label { color: #6c757d; }
.avatar { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; }
.card { border: 1px solid #e9ecef; transition: transform .2s ease, box-shadow .2s ease; }
.card:hover { transform: translateY(-3px); box-shadow: 0 14px 24px rgba(255,193,7,.18); }
.cta-strip { background: linear-gradient(135deg, var(--brand) 0%, var(--brand-dark) 100%); }
.logos-strip { background: #fff; border-top: 1px solid #e9ecef; border-bottom: 1px solid #e9ecef; }
.logo-item { height: 48px; display: flex; align-items: center; justify-content: center; filter: grayscale(100%); opacity: .7; transition: opacity .2s, filter .2s; }
.logo-item:hover { filter: none; opacity: 1; }
.newsletter { background: #f8f9fa; border: 1px solid #e9ecef; border-radius: 12px; padding: 24px; }
.newsletter .form-control { height: 48px; }
.wave-divider { display: block; width: 100%; }
.floating-actions { position: fixed; bottom: 20px; right: 20px; display: grid; gap: 12px; z-index: 2000; }
.fab { width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center; box-shadow: 0 12px 24px rgba(16,24,40,.15); border: none; cursor: pointer; opacity: .95; transition: transform .2s ease, box-shadow .2s ease; }
.fab:hover { transform: translateY(-2px); box-shadow: 0 18px 36px rgba(16,24,40,.2); }
.fab-whatsapp { background: #25D366; color: #fff; }
.fab-top { background: var(--brand); color: #fff; display: none; }
.fab-top.show { display: grid; }
.blink { animation: blink 1.2s infinite; }
.dot-blink { width: 8px; height: 8px; border-radius: 50%; background: #25D366; display: inline-block; margin-right: 6px; animation: blink 1.2s infinite; }
.topbar .badge-admit { animation: pulse 2.4s infinite; }
@keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: .2; } }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(13,110,253,.4); } 70% { box-shadow: 0 0 0 12px rgba(13,110,253,0); } 100% { box-shadow: 0 0 0 0 rgba(13,110,253,0); } }
@keyframes bounceY { 0%, 100% { transform: translate(-50%, 0); } 50% { transform: translate(-50%, -6px); } }
/* New UI helpers */
.chip { display: inline-block; padding: .4rem .8rem; border: 1px solid #ffe08a; border-radius: 999px; background: #fffbea; color: var(--ink); font-weight: 600; font-size: .9rem; }
.timeline { position: relative; margin-left: 10px; }
.timeline::before { content: ""; position: absolute; left: 10px; top: 0; bottom: 0; width: 2px; background: #e9ecef; }
.timeline-step { position: relative; padding-left: 36px; margin-bottom: 16px; }
.timeline-step .dot { position: absolute; left: 2px; top: 4px; width: 16px; height: 16px; background: var(--brand); border-radius: 50%; box-shadow: 0 0 0 6px rgba(13,110,253,.1); }
.timeline-step .content { background: #fff; border: 1px solid #e9ecef; border-radius: 8px; padding: 12px; }
.resource-card .fw-semibold { color: var(--brand); }
.nav-pills .nav-link { border-radius: 999px; }
.nav-pills .nav-link.active { background-color: var(--brand); }
/* Footer */
.site-footer { background: #111; color: #fff; }
.site-footer a { color: #fff; text-decoration: none; }
.site-footer a:hover { color: var(--accent); }
.footer-title { color: var(--brand); font-weight: 700; }
.footer-logo { height: 56px; border-radius: 8px; }
.footer-links li { margin-bottom: 8px; }
.footer-bottom { background: #0f0f0f; border-top: 1px solid rgba(255,255,255,.08); }