/* ============================================================
   USA Uni Gateway — site.css
   ============================================================ */
:root{
  --navy-deep:#0a1e3f; --navy:#13294b;
  --gold:#c8a64b; --gold-2:#b8932f;
  --cream:#f7f3ea; --muted:#6b7280;
  --line:#e6e3dc; --bg-soft:#faf7f0;
}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:#1a1a1a;background:#fff}
.container-page{max-width:1240px;margin:0 auto;padding:0 28px}
@media(max-width:640px){.container-page{padding:0 18px}}

/* Section spacing safety */
main > section, main > div { padding-left:0; padding-right:0; }

main section.container-page, main .container-page {
    padding-top: 60px;
    padding-bottom: 60px;
}

/* =================== TOP BAR =================== */
.topbar{background:var(--navy-deep);color:var(--cream);font-size:13px}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;min-height:38px;flex-wrap:wrap;gap:8px;padding-top:6px;padding-bottom:6px}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.tb-link{color:var(--cream);text-decoration:none;display:inline-flex;align-items:center;gap:6px}
.tb-link:hover{color:var(--gold)}
.tb-ico{color:var(--gold)}
.tb-hours{opacity:.7}.tb-sep{opacity:.4}
@media(max-width:760px){.tb-hours{display:none}.topbar-left,.topbar-right{gap:12px;font-size:12px}}

/* =================== HEADER =================== */
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:60;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:92px;gap:24px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--navy)}
.brand-logo{height:56px;width:auto;display:block}
.brand-name{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--navy)}
.header-right{display:flex;align-items:center;gap:22px}
.main-nav{display:flex;align-items:center;gap:4px}
.main-nav>a,.main-nav>.nav-dd>button{
  display:inline-flex;align-items:center;gap:4px;
  padding:10px 13px;border-radius:8px;text-decoration:none;
  font-size:15px;font-weight:500;color:#1a2a44;background:transparent;border:0;cursor:pointer;
  font-family:inherit;
}
.main-nav>a:hover,.main-nav>.nav-dd>button:hover{background:var(--bg-soft);color:var(--navy-deep)}
.main-nav>a.active{color:var(--gold-2)}

/* Dropdown — HOVER-ACTIVATED on desktop */
.nav-dd{position:relative}
.nav-dd-menu{
  position:absolute;top:100%;left:0;
  min-width:220px;background:#fff;border:1px solid var(--line);
  border-radius:10px;box-shadow:0 12px 32px rgba(10,30,63,.15);
  padding:8px;z-index:80;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s;
  display:block !important; /* override .hidden */
}
.nav-dd:hover .nav-dd-menu,
.nav-dd:focus-within .nav-dd-menu,
.nav-dd-menu.is-open{opacity:1;visibility:visible;transform:translateY(0)}
/* invisible bridge so hover doesn't break in the gap */
.nav-dd::after{content:"";position:absolute;left:0;right:0;top:100%;height:10px}
.nav-dd-menu a{display:block;padding:9px 12px;border-radius:6px;color:#1a2a44;text-decoration:none;font-size:14px}
.nav-dd-menu a:hover{background:var(--bg-soft);color:var(--navy-deep)}

.apply-btn{display:inline-block;background:var(--gold);color:#1a1300;padding:11px 22px;border-radius:8px;font-weight:600;text-decoration:none;font-size:14px;box-shadow:0 4px 10px rgba(200,166,75,.3)}
.apply-btn:hover{background:var(--gold-2);color:#fff}
.mob-burger{display:none;background:none;border:0;color:var(--navy);cursor:pointer;padding:8px}
@media(max-width:980px){
  .main-nav,.apply-btn{display:none}
  .mob-burger{display:inline-flex}
  .header-inner{height:74px}
  .brand-logo{height:46px}
  .brand-name{font-size:18px}
}
.mob-menu{background:#fff;border-bottom:1px solid var(--line);box-shadow:0 8px 18px rgba(0,0,0,.06);display:none}
.mob-menu.is-open{display:block !important;}
.mob-menu-inner{padding:12px 22px 18px;display:flex;flex-direction:column;gap:2px}
.mob-menu-inner a,.mob-menu-inner summary{padding:12px 8px;text-decoration:none;color:#1a2a44;font-weight:500;border-radius:6px;cursor:pointer;list-style:none;font-size:15px}
.mob-menu-inner a:hover,.mob-menu-inner summary:hover{background:var(--bg-soft)}
.mob-menu-inner details summary::-webkit-details-marker{display:none}
.mob-menu-inner details summary::after{content:" ▾";color:var(--gold-2)}
.mob-sub{display:flex;flex-direction:column;padding-left:14px;border-left:2px solid var(--line);margin:4px 0 8px}
.mob-sub a{padding:9px 8px;font-size:14px}

/* =================== HERO SLIDER =================== */
section.relative > div.overflow-hidden > div.flex > div[class*="h-[640px]"]{height:520px !important}
@media(min-width:768px){
  section.relative > div.overflow-hidden > div.flex > div[class*="h-[640px]"],
  section.relative > div.overflow-hidden > div.flex > div[class*="md:h-[720px]"]{height:580px !important}
}
section.relative > div.absolute.bottom-6{display:none !important}
.hero-dots{position:absolute;bottom:22px;left:0;right:0;display:flex;justify-content:center;gap:10px;z-index:10}
.hero-dots button{width:11px;height:11px;border-radius:50%;border:0;cursor:pointer;background:rgba(255,255,255,.45);transition:all .25s;padding:0}
.hero-dots button.is-active{background:var(--gold);transform:scale(1.25)}
.hero-dots button:hover{background:rgba(255,255,255,.8)}

/* =================== STUDENT VOICES =================== */
.voices-rail{display:flex !important;gap:20px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;padding:4px 4px 14px;-webkit-overflow-scrolling:touch}
.voices-rail::-webkit-scrollbar{display:none}
.voices-rail > *{scroll-snap-align:start;flex:0 0 320px !important;max-width:340px;width:320px}
@media(min-width:768px){.voices-rail > *{flex:0 0 360px !important;width:360px;max-width:380px}}
.voices-dots{display:flex;justify-content:center;gap:8px;margin-top:22px}
.voices-dots button{width:10px;height:10px;border-radius:50%;border:0;cursor:pointer;background:#d6d2c9;transition:all .25s;padding:0}
.voices-dots button.is-active{background:var(--gold);transform:scale(1.3)}

/* =================== TOC =================== */
aside a[href^="#"]{transition:background .2s,color .2s,border-left-color .2s,padding-left .2s;border-left:3px solid transparent}
/* When JS marks active, override Tailwind bg-primary which is SSR-set */
aside a[href^="#"].toc-active{
  background:linear-gradient(90deg,rgba(200,166,75,.22),rgba(200,166,75,0)) !important;
  color:var(--navy-deep) !important;
  border-left:3px solid var(--gold) !important;
  padding-left:11px !important;
  font-weight:600 !important;
  box-shadow:none !important;
}
aside a[href^="#"].toc-active span{color:var(--gold-2) !important}
/* neutralize SSR-active styling on first item once JS runs */
body.js-ready aside a[href^="#"]:not(.toc-active){
  background:transparent !important;color:#374151 !important;box-shadow:none !important;
}
body.js-ready aside a[href^="#"]:not(.toc-active) span.text-gold,
body.js-ready aside a[href^="#"]:not(.toc-active) span.font-semibold{color:#9ca3af !important;font-weight:500 !important}

/* =================== FAQ =================== */
.faq-card{border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden;margin-bottom:10px;transition:box-shadow .2s}
.faq-card.is-open{box-shadow:0 8px 20px rgba(10,30,63,.06)}
.faq-card > button{width:100%;background:none;border:0;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;font:inherit}
.faq-card > button span.font-semibold{font-size:15.5px;color:var(--navy-deep)}
.faq-card .faq-body{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 20px;color:#374151;line-height:1.65;font-size:14.5px}
.faq-card.is-open .faq-body{max-height:600px;padding:0 20px 18px}
.faq-card .faq-ico{width:22px;height:22px;color:var(--gold-2);transition:transform .25s;flex-shrink:0}
.faq-card.is-open .faq-ico{transform:rotate(45deg)}

/* =================== FORMS =================== */
.form-card,form.cta-form{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;box-shadow:0 12px 30px rgba(10,30,63,.06)}
.field{position:relative;margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}
.field input,.field select,.field textarea,
form input[type=text],form input[type=email],form input[type=tel],form select,form textarea{
  width:100%;box-sizing:border-box;padding:11px 14px 11px 40px;
  border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;background:#fff;color:#1a1a1a;
  transition:border-color .2s,box-shadow .2s;
}
.field textarea,form textarea{padding-left:14px;min-height:110px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus,
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,166,75,.18)}
.field .fi-ico{position:absolute;left:13px;top:35px;width:18px;height:18px;color:var(--gold-2);pointer-events:none;z-index:1}
.field.no-icon input,.field.no-icon select,.field.no-icon textarea{padding-left:14px}
.btn-primary,button[type=submit]{display:inline-block;background:var(--gold);color:#1a1300;padding:12px 26px;border:0;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;font-family:inherit;transition:background .2s}
.btn-primary:hover,button[type=submit]:hover{background:var(--gold-2);color:#fff}

/* =================== FOOTER =================== */
.site-footer{background:var(--navy-deep);color:var(--cream);margin-top:60px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding:60px 28px 40px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px;padding:50px 22px 30px}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.footer-logo{height:42px;width:auto;background:#fff;padding:4px;border-radius:6px}
.footer-name{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:#fff}
.footer-tag{color:rgba(247,243,234,.75);line-height:1.65;font-size:14px;margin:0 0 18px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-weight:700;font-size:13px;transition:background .2s}
.footer-social a:hover{background:var(--gold);color:#1a1300}
.footer-col h4{color:#fff;font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin:0 0 16px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.footer-col ul a{color:rgba(247,243,234,.78);text-decoration:none;font-size:14px}
.footer-col ul a:hover{color:var(--gold)}
.footer-contact li{color:rgba(247,243,234,.85);font-size:14px;display:flex;align-items:center;gap:8px}
.footer-contact .fi{color:var(--gold)}
.footer-cta{display:inline-block;margin-top:14px;background:var(--gold);color:#1a1300;padding:10px 18px;border-radius:8px;font-weight:600;font-size:13px;text-decoration:none}
.footer-cta:hover{background:#fff}
.footer-bottom{background:rgba(0,0,0,.25);padding:18px 0;font-size:13px;color:rgba(247,243,234,.6)}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.footer-bottom a{color:rgba(247,243,234,.7);text-decoration:none}
.footer-bottom a:hover{color:var(--gold)}

/* =================== BANNERS =================== */
.page-banner{background:linear-gradient(120deg,var(--navy-deep) 0%,var(--navy) 60%,#1d3b6f 100%);color:#fff;position:relative;overflow:hidden}
.page-banner::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 30%,rgba(200,166,75,.22),transparent 55%);pointer-events:none}
.page-banner .crumb{display:inline-block;background:rgba(200,166,75,.18);color:var(--gold);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:99px;border:1px solid rgba(200,166,75,.3)}
.page-banner h1{font-family:'Playfair Display',serif;font-size:44px;line-height:1.1;margin:18px 0 12px;font-weight:700;max-width:780px}
.page-banner p{font-size:17px;color:rgba(247,243,234,.85);max-width:680px;line-height:1.6;margin:0 0 18px}
.page-banner .breadcrumbs{font-size:13px;color:rgba(247,243,234,.7)}
.page-banner .breadcrumbs a{color:var(--gold);text-decoration:none}
@media(max-width:680px){.page-banner h1{font-size:30px}.page-banner{padding:46px 0 50px}}

/* About extras */
.about-values,.about-team{padding:0 0;background:#fff}
.about-team{background:var(--bg-soft)}
.about-values h2,.about-team h2{font-family:'Playfair Display',serif;font-size:34px;color:var(--navy-deep);margin:0 0 10px;text-align:center}
.about-values .lead,.about-team .lead{text-align:center;color:var(--muted);max-width:680px;margin:0 auto 36px;line-height:1.6}
.v-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:980px){.v-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.v-grid{grid-template-columns:1fr}}
.v-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:26px;transition:transform .25s,box-shadow .25s}
.v-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(10,30,63,.08)}
.v-ico{width:46px;height:46px;border-radius:12px;background:var(--gold);color:#1a1300;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px}
.v-card h3{margin:0 0 8px;font-size:18px;color:var(--navy-deep)}
.v-card p{margin:0;color:#4b5563;font-size:14px;line-height:1.6}
.t-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:30px}
@media(max-width:980px){.t-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.t-grid{grid-template-columns:1fr}}
.t-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;text-align:center;transition:transform .25s,box-shadow .25s}
.t-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(10,30,63,.08)}
.t-avatar{width:86px;height:86px;border-radius:50%;margin:0 auto 14px;background:linear-gradient(135deg,var(--navy-deep),var(--gold));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:26px;font-family:'Playfair Display',serif}
.t-name{font-weight:700;color:var(--navy-deep);font-size:16px}
.t-role{color:var(--muted);font-size:13px;margin-top:4px}

/* =================== UNIVERSITIES FILTER =================== */
/* Override Tailwind sticky top-[72px] so it sits below our 92px header */
.bg-secondary\/50.border-b.border-border.sticky,
div[class*="sticky"][class*="top-[72px]"]{
  position:sticky !important;
  top:92px !important;
  background:#faf7f0 !important;
  border-bottom:1px solid var(--line) !important;
  z-index:30 !important;
  box-shadow:0 4px 12px rgba(10,30,63,.04);
}
@media(max-width:980px){
  .bg-secondary\/50.border-b.border-border.sticky,
  div[class*="sticky"][class*="top-[72px]"]{top:74px !important}
}
.uni-hidden{display:none !important}

/* =================== FLOATING WHATSAPP =================== */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:9990;
  display:inline-flex;align-items:center;gap:10px;
  background:#25d366;color:#fff;text-decoration:none;
  padding:12px 18px 12px 14px;border-radius:50px;
  box-shadow:0 10px 28px rgba(37,211,102,.45),0 4px 10px rgba(0,0,0,.2);
  font-weight:600;font-size:14px;font-family:inherit;
  transition:transform .25s,box-shadow .25s,background .25s;
}
.wa-float:hover{background:#1ebe5d;transform:translateY(-3px);box-shadow:0 14px 34px rgba(37,211,102,.55)}
.wa-float svg{flex-shrink:0}
.wa-pulse{position:absolute;inset:0;border-radius:50px;background:#25d366;opacity:.55;animation:wapulse 2s ease-out infinite;z-index:-1}
@keyframes wapulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(1.35);opacity:0}}
@media(max-width:560px){
  .wa-float{right:14px;bottom:14px;padding:11px 14px 11px 12px}
  .wa-label{display:none}
  .wa-float{border-radius:50%;width:56px;height:56px;padding:0;justify-content:center}
}

/* =================== HELP POPUP =================== */
.help-pop{
  position:fixed;inset:0;background:rgba(15,20,40,.55);
  z-index:10000;display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;visibility:hidden;
  transition:opacity .3s,visibility .3s;
}
.help-pop.is-open{opacity:1;visibility:visible}
.help-pop-card{
  position:relative;display:flex;width:100%;max-width:760px;
  background:#fff;border-radius:18px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
  transform:translateY(20px) scale(.96);transition:transform .35s cubic-bezier(.2,.9,.3,1.2);
}
.help-pop.is-open .help-pop-card{transform:translateY(0) scale(1)}
.help-pop-close{
  position:absolute;top:10px;right:14px;background:none;border:0;
  font-size:28px;color:#5b3aa8;cursor:pointer;z-index:5;line-height:1;
  width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
}
.help-pop-close:hover{background:rgba(91,58,168,.1)}
.help-pop-left{
  flex:1;background:linear-gradient(160deg,#8b5cf6 0%,#a855f7 45%,#c084fc 100%);
  padding:24px 22px 22px;position:relative;color:#fff;overflow:hidden;min-height:440px;
}
.help-pop-right{
  flex:1.05;background:#f5edff;padding:30px 26px;display:flex;flex-direction:column;
}
@media(max-width:680px){
  .help-pop-card{flex-direction:column;max-width:380px}
  .help-pop-left{min-height:320px}
}
.hp-bubble{
  position:relative;background:#ec4899;color:#fff;border-radius:18px;
  padding:14px 16px;margin-bottom:14px;box-shadow:0 6px 18px rgba(236,72,153,.4);
}
.hp-bubble-top{font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:#fde68a;margin-bottom:4px;text-align:center}
.hp-bubble-main{font-weight:700;font-size:16px;line-height:1.3;text-align:center}
.hp-bubble-tail{position:absolute;left:30px;bottom:-10px;width:0;height:0;border:10px solid transparent;border-top-color:#ec4899;border-bottom:0}
.hp-avatar{display:flex;justify-content:center;margin:4px 0 8px}
.hp-sparkle{position:absolute;color:#fff;font-size:22px;opacity:.9;animation:hpfloat 3s ease-in-out infinite}
.hp-s1{top:60px;left:14px}
.hp-s2{top:140px;right:18px;animation-delay:.6s}
.hp-s3{bottom:90px;left:20px;font-size:18px;animation-delay:1.2s}
@keyframes hpfloat{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-6px) rotate(15deg)}}
.hp-contact-label{text-align:center;font-size:13px;font-weight:600;margin:10px 0 10px;color:#fff}
.hp-contact-row{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.hp-ic{
  width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  text-decoration:none;font-size:18px;background:#fff;color:#5b3aa8;
  box-shadow:0 4px 10px rgba(0,0,0,.15);transition:transform .2s;
}
.hp-ic:hover{transform:translateY(-3px) scale(1.08)}
.hp-ic-call{background:#fbbf24}.hp-ic-mail{background:#ef4444;color:#fff}
.hp-ic-sms{background:#10b981;color:#fff}.hp-ic-wa{background:#25d366;color:#fff}
.hp-ic-wc{background:#22c55e;color:#fff}.hp-ic-vid{background:#3b82f6;color:#fff}

.help-pop-right h3{
  font-family:'Playfair Display',serif;font-size:26px;color:#5b21b6;
  margin:0 0 16px;font-weight:700;
}
.hp-list{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:10px}
.hp-list li{display:flex;align-items:center;gap:10px;color:#1f2937;font-weight:500;font-size:15px}
.hp-list li span{font-size:18px}
.hp-cta{
  display:inline-block;background:#8b5cf6;color:#fff;text-align:center;
  padding:13px 20px;border-radius:10px;text-decoration:none;font-weight:600;font-size:15px;
  box-shadow:0 8px 20px rgba(139,92,246,.4);transition:background .2s,transform .2s;
}
.hp-cta:hover{background:#7c3aed;transform:translateY(-2px)}
.hp-wa-link{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  margin-top:18px;color:#2563eb;text-decoration:underline;font-weight:600;font-size:14px;
}
.hp-arrow{background:#3b82f6;color:#fff;width:18px;height:18px;border-radius:3px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;text-decoration:none}
.hp-qr{margin:14px auto 0;background:#fff;padding:8px;border-radius:8px;width:fit-content;box-shadow:0 4px 10px rgba(0,0,0,.08)}

.mob-menu{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    width:100%;
    background:#fff;
    z-index:9999;
    box-shadow:0 10px 30px rgba(0,0,0,.15);
}

.mob-menu.is-open{
    display:block !important;
}