/* ═══════════════════════════════════════════════
   JMCS — Clean Blue & White
   White backgrounds · Navy blue accents · No glass
   Fonts: Fraunces (display) · DM Sans (body) · DM Mono (labels)
═══════════════════════════════════════════════ */
/* Fonts: Playfair Display SC (display) + Lato (body) — loaded via <link> in HTML */

:root {
  --blue:        #1a3c6e;
  --blue-mid:    #2251a3;
  --blue-light:  #3b6fd4;
  --blue-pale:   #e8eef8;
  --blue-faint:  #f0f4fc;
  --white:       #ffffff;
  --off:         #f7f8fc;
  --gray-50:     #f2f4f8;
  --gray-50:     #f8faff;
  --gray-100:    #e4e8f0;
  --gray-200:    #c8d0e0;
  --gray-400:    #8896b0;
  --gray-600:    #4a5568;
  --text:        #0f1e35;
  --text-mid:    #2d3f58;
  --text-muted:  #6b7a94;
  --cta:         #c0392b;
  --cta-hover:   #a93226;

  /* compat aliases */
  --navy:           #1a3c6e;
  --navy-mid:       #2251a3;
  --navy-light:     #3b6fd4;
  --green:          #1a3c6e;
  --green-light:    #3b6fd4;
  --green-pale:     #e8eef8;
  --primary:        #1a3c6e;
  --primary-mid:    #2251a3;
  --primary-light:  #3b6fd4;
  --cream:          #f0f4fc;
  --surface:        #f0f4fc;
  --border:         #e4e8f0;
  --off-white:      #f7f8fc;
  --warm:           #f7f8fc;

  --fd: 'Montserrat', sans-serif;
  --fb: 'Roboto', sans-serif;
  --fm: 'Roboto Mono', 'Courier New', monospace;
  --font-display: 'Montserrat', sans-serif;
  --font-body:    'Roboto', sans-serif;
  --font-mono:    'Roboto Mono', 'Courier New', monospace;

  --radius:    6px;
  --radius-lg: 14px;
  --r:         6px;
  --rlg:       14px;

  --sh-xs: 0 1px 4px rgba(26,60,110,.06);
  --sh-sm: 0 2px 12px rgba(26,60,110,.08);
  --sh-md: 0 6px 28px rgba(26,60,110,.12);
  --sh-lg: 0 16px 52px rgba(26,60,110,.16);
  --sh-xl: 0 28px 72px rgba(26,60,110,.20);
  --shadow-sm:  0 2px 12px rgba(26,60,110,.08);
  --shadow-md:  0 6px 28px rgba(26,60,110,.12);
  --shadow-lg:  0 16px 52px rgba(26,60,110,.16);

  --tr: .25s ease;

  /* ── Modern accent palette ── */
  --accent-green:  #16a34a;
  --accent-teal:   #0891b2;
  --accent-purple: #7c3aed;
  --accent-amber:  #d97706;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--white);color:var(--text);overflow-x:hidden;line-height:1.65;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font-family:var(--fb);cursor:pointer}
.container{max-width:1280px;margin:0 auto;padding:0 5vw}
section{padding:104px 0}

/* ── Reveal ── */
.reveal,.reveal-l,.reveal-r{opacity:0;transition:opacity .65s ease,transform .65s ease}
.reveal  {transform:translateY(26px)}
.reveal-l{transform:translateX(-28px)}
.reveal-r{transform:translateX(28px)}
.reveal.up,.reveal-l.up,.reveal-r.up{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── Section tag ── */
.section-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--fm);font-size:10.5px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:#16a34a;margin-bottom:14px}
.section-tag::before{content:'';width:22px;height:2px;background:#16a34a;display:block}
.section-tag.light{color:rgba(255,255,255,.6)}
.section-tag.light::before{background:rgba(255,255,255,.4)}

/* ── Headings ── */
.section-title{font-family:var(--fd);font-size:clamp(26px,3.4vw,48px);font-weight:700;line-height:1.15;color:var(--text);letter-spacing:-.01em;margin-bottom:16px}
.section-title em{font-style:italic;font-weight:700;color:#0891b2}
.section-title.light{color:var(--white)}
.section-title.light em{color:rgba(255,255,255,.65)}
.section-sub{font-size:16px;line-height:1.8;color:var(--text-muted);max-width:520px}
.section-sub.light{color:rgba(255,255,255,.65)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;font-family:var(--fb);font-weight:500;font-size:14px;border-radius:var(--radius);border:none;cursor:pointer;transition:all var(--tr);text-decoration:none}
.btn-primary{background:var(--cta);color:#fff;box-shadow:0 2px 12px rgba(192,57,43,.25)}
.btn-primary:hover{background:var(--cta-hover);transform:translateY(-2px);box-shadow:0 6px 20px rgba(192,57,43,.35)}
.btn-blue,.btn-navy{background:var(--blue);color:#fff}
.btn-blue:hover,.btn-navy:hover{background:var(--blue-mid);transform:translateY(-2px)}
.btn-green,.btn-forest{background:var(--blue);color:#fff}
.btn-green:hover,.btn-forest:hover{background:var(--blue-mid);transform:translateY(-2px)}
.btn-light-blue{background:var(--blue-pale);color:var(--blue)}
.btn-light-blue:hover{background:var(--gray-100);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--gray-400)}
.btn-white{background:#fff;color:var(--blue);border:1.5px solid var(--gray-200)}
.btn-white:hover{background:var(--blue-faint);border-color:var(--blue);transform:translateY(-2px)}
.btn-outline:hover{background:var(--blue);border-color:var(--blue);color:#fff;transform:translateY(-2px)}
.btn-outline-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,.1);transform:translateY(-2px)}
.btn-outline-blue{background:transparent;color:var(--blue);border:1.5px solid var(--blue)}
.btn-outline-blue:hover{background:var(--blue);color:#fff;transform:translateY(-2px)}
.btn-lg{padding:14px 32px;font-size:15px}
.btn-full{width:100%;justify-content:center}

/* ════════ HEADER ════════ */
#site-header{position:fixed;top:0;left:0;right:0;z-index:500;height:68px;background:var(--white);border-bottom:1px solid var(--gray-100);transition:box-shadow .3s}
#site-header.scrolled{box-shadow:var(--sh-sm)}
#site-header.solid{background:var(--white)}
#site-header::before,#site-header::after{display:none}

.header-inner{height:68px;display:flex;align-items:center;justify-content:space-between}
.logo-wrap{display:flex;align-items:center;gap:10px}
.logo-wrap img{height:38px;width:38px;object-fit:contain}
.logo-text-wrap{display:flex;flex-direction:column;line-height:1.25}
.logo-name{font-family:var(--fd);font-size:14px;font-weight:800;color:var(--text);letter-spacing:-.01em}
.site-footer .logo-name{color:#ffffff}
.site-footer .logo-sub{color:rgba(255,255,255,.65)}
.logo-sub{font-family:var(--fm);font-size:8px;letter-spacing:.15em;text-transform:uppercase;color:var(--gray-400)}

.main-nav{display:flex;align-items:center;gap:4px}
.main-nav a{font-size:13.5px;font-weight:400;color:var(--text-mid);padding:7px 13px;border-radius:var(--radius);transition:color .2s,background .2s}
.main-nav a::after{display:none!important}
.main-nav a:hover{color:var(--blue);background:var(--blue-faint)}
.main-nav a.active{color:var(--blue);font-weight:600}
.main-nav a.nav-home{display:inline-flex;align-items:center;gap:5px}
.main-nav a.nav-home i{font-size:11px;color:var(--blue-light)}

/* Enroll Now */
.nav-enroll,.main-nav a.nav-enroll,.main-nav .nav-enroll{
  padding:9px 22px!important;background:var(--cta)!important;color:#ffffff!important;
  font-size:13.5px!important;font-weight:500!important;border-radius:var(--radius)!important;
  display:inline-flex!important;align-items:center!important;justify-content:center!important;
  position:relative;overflow:hidden;
  box-shadow:0 2px 10px rgba(192,57,43,.22)!important;
  transition:background .25s,transform .25s,box-shadow .25s!important;
}
.nav-enroll::before{content:'';position:absolute;top:0;left:-75%;width:50%;height:100%;background:rgba(255,255,255,.5);transform:skewX(-20deg);transition:left 0s;pointer-events:none;z-index:1}
.nav-enroll:hover,.main-nav a.nav-enroll:hover{background:var(--cta-hover)!important;color:#ffffff!important;transform:translateY(-1px)!important;box-shadow:0 5px 18px rgba(192,57,43,.35)!important}
.nav-enroll:hover::before{left:130%;transition:left .5s ease}
.nav-enroll::after{display:none!important}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;border:none;background:none}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--text);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;bottom:0;background:var(--white);z-index:499;flex-direction:column;align-items:center;justify-content:center;gap:28px;border-top:1px solid var(--gray-100)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--fd);font-size:30px;font-weight:700;color:var(--text);transition:color .2s}
.mobile-menu a:hover{color:var(--blue-mid)}
.mobile-menu a.nav-home{display:inline-flex;align-items:center;gap:10px}
.mobile-menu a.nav-home i{font-size:22px;color:var(--blue-light)}

/* ════════ PAGE HERO ════════ */
.page-hero{background:var(--blue);padding:136px 0 88px;position:relative;overflow:hidden;clip-path:polygon(0 0,100% 0,100% 88%,0 100%);margin-bottom:-2px}
.page-hero::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;border:48px solid rgba(255,255,255,.06);border-radius:50%}
.page-hero::after{display:none}
.page-hero-glow{position:absolute;width:500px;height:500px;border-radius:50%;background:rgba(59,111,212,.25);top:-120px;right:60px;pointer-events:none}
.page-hero-content{position:relative;z-index:1}
.page-hero-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:20px;font-family:var(--fm);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.page-hero-eyebrow span{width:28px;height:1px;background:rgba(255,255,255,.35);display:block}
.page-hero h1{font-family:var(--fd);font-size:clamp(40px,5vw,72px);font-weight:800;line-height:1.07;color:#fff;letter-spacing:-.02em;margin-bottom:20px}
.page-hero h1 em{font-style:italic;font-weight:600;color:rgba(255,255,255,.65)}
.page-hero p{font-size:17px;line-height:1.8;color:rgba(255,255,255,.65);max-width:560px}

/* ════════ MARQUEE ════════ */
.marquee-band{background:var(--blue);overflow:hidden}
.marquee-inner{display:flex;animation:marqueeScroll 34s linear infinite;width:max-content;padding:13px 0}
.marquee-inner:hover{animation-play-state:paused}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee-item{white-space:nowrap;padding:0 36px;font-family:var(--fm);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:36px}
.marquee-item::after{content:'◆';color:#16a34a;font-size:7px}

/* ════════ FOOTER ════════ */
.site-footer{background:var(--blue);color:#ffffff;padding:72px 0 0;border-top:4px solid #ffffff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.2)}
.foot-brand-desc{font-size:14px;line-height:1.75;max-width:260px;margin:16px 0 24px;color:#ffffff}
.foot-socials{display:flex;gap:10px}
.foot-social{width:40px;height:40px;border-radius:var(--radius);border:1px solid var(--gray-100);display:flex;align-items:center;justify-content:center;transition:transform .2s,border-color .2s,background .2s;overflow:hidden;background:var(--gray-50)}
.foot-social:hover{border-color:var(--blue-light);transform:translateY(-2px);background:var(--blue-faint)}
.foot-social svg{display:block;flex-shrink:0}
.foot-col h5{font-family:var(--fm);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#ffffff;margin-bottom:18px}
.foot-col a{display:block;font-size:14px;color:#ffffff;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:rgba(255,255,255,.7)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:22px 0;flex-wrap:wrap;gap:10px}
.footer-bottom p{font-size:12px;color:#ffffff}
.footer-bottom .mono{font-family:var(--fm);font-size:10px;letter-spacing:.15em}

/* ════════ CHATBOT ════════ */
#chatbot-wrap{position:fixed;bottom:0;right:24px;z-index:600}

#chatbot-toggle{
  width:88px;height:100px;
  border-radius:0;background:transparent;border:none;
  cursor:pointer;position:relative;
  display:flex;align-items:flex-end;justify-content:center;
  box-shadow:none;padding:0;
}

#chatbot-toggle::after{display:none}
#chatbot-toggle:hover{transform:none}

#chatbot-toggle .bot-icon{
  display:flex;flex-direction:column;align-items:center;
  justify-content:flex-end;pointer-events:none;
  position:relative;width:88px;height:100px;
}

#chat-avatar-img{
  width:88px;height:88px;
  object-fit:contain;object-position:bottom;
  display:block;
  filter:drop-shadow(0 6px 18px rgba(26,60,110,.45));
}

.chat-hi-bubble{
  position:absolute;
  top:2px;right:-8px;
  background:#e63946;color:#fff;
  font-family:var(--fb);font-size:11px;font-weight:700;
  padding:4px 9px;border-radius:12px 12px 12px 2px;
  white-space:nowrap;
  box-shadow:0 2px 8px rgba(230,57,70,.4);
  pointer-events:none;
  letter-spacing:.01em;
}

#chat-badge{position:absolute;top:6px;right:-4px;width:18px;height:18px;background:var(--cta);border-radius:50%;border:2px solid var(--white);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff}
#chat-badge.hidden{display:none}
#chatbot-window{position:absolute;bottom:68px;right:0;width:360px;background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--sh-xl);display:flex;flex-direction:column;overflow:hidden;transform:scale(.9) translateY(14px);opacity:0;transition:transform .3s ease,opacity .3s ease;pointer-events:none}
#chatbot-window.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}
.chat-header{background:var(--blue);padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:3px solid var(--blue-light)}
.chat-header-avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-header-avatar svg{width:22px;height:22px}
.chat-header-info{flex:1}
.chat-header-name{font-family:var(--fd);font-weight:700;color:#fff;font-size:14px}
.chat-header-status{font-size:11px;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:5px}
.status-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;animation:sPulse 2s ease-in-out infinite}
@keyframes sPulse{0%,100%{opacity:1}50%{opacity:.4}}
.chat-close{background:rgba(255,255,255,.12);border:none;color:rgba(255,255,255,.7);font-size:12px;cursor:pointer;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}
.chat-close:hover{background:rgba(255,255,255,.22);color:#fff}
.chat-quick{padding:10px 14px;background:var(--blue-faint);border-bottom:1px solid var(--gray-100);display:flex;gap:6px;overflow-x:auto;scrollbar-width:none}
.chat-quick::-webkit-scrollbar{display:none}
.quick-btn{white-space:nowrap;padding:5px 12px;background:var(--white);border:1px solid var(--gray-200);border-radius:40px;font-size:11px;color:var(--text);font-weight:400;cursor:pointer;transition:all .2s;flex-shrink:0}
.quick-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
#chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;max-height:320px;scroll-behavior:smooth}
#chat-messages::-webkit-scrollbar{width:3px}
#chat-messages::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:2px}
.msg{display:flex;gap:8px;max-width:88%}
.msg.bot{align-self:flex-start}
.msg.user{align-self:flex-end;flex-direction:row-reverse}
.msg-avatar{width:28px;height:28px;border-radius:50%;background:var(--blue-faint);border:1px solid var(--gray-100);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--blue);flex-shrink:0;margin-top:2px}
.msg-bubble{padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.6}
.msg.bot  .msg-bubble{background:var(--gray-50);color:var(--text);border-bottom-left-radius:3px}
.msg.user .msg-bubble{background:var(--blue);color:#fff;border-bottom-right-radius:3px}
.msg-time{font-size:10px;color:var(--gray-400);margin-top:3px;text-align:right}
.typing-dots{display:flex;gap:4px;padding:10px 14px;background:var(--gray-50);border-radius:12px;border-bottom-left-radius:3px;align-self:flex-start}
.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--gray-200);animation:typingB 1.2s infinite}
.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typingB{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}
.chat-input-row{padding:12px 14px;border-top:1px solid var(--gray-100);display:flex;gap:8px;align-items:center;background:var(--white)}
#chat-input{flex:1;padding:9px 14px;border:1.5px solid var(--gray-100);border-radius:20px;font-family:var(--fb);font-size:13px;color:var(--text);background:var(--gray-50);outline:none;resize:none;transition:border-color .2s}
#chat-input:focus{border-color:var(--blue-light);background:var(--white)}
#chat-input::placeholder{color:var(--gray-400)}
#chat-send{width:36px;height:36px;border-radius:50%;background:var(--blue);border:none;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;cursor:pointer;flex-shrink:0;transition:background .2s,transform .2s}
#chat-send:hover{background:var(--blue-mid);transform:scale(1.05)}


/* Hide Hi bubble when chat is open */
#chatbot-window.open ~ #chatbot-toggle .chat-hi-bubble,
.chatbot-open .chat-hi-bubble{display:none!important}

/* ════════ NAV DROPDOWNS ════════ */
.nav-item{position:relative;display:inline-flex}

/* Top-level link inside a dropdown parent */
.nav-item.has-dropdown > a{
  display:inline-flex;align-items:center;gap:5px;
  font-size:13.5px;font-weight:400;color:var(--text-mid);
  padding:7px 13px;border-radius:var(--radius);
  transition:color .2s,background .2s;cursor:pointer;
}
.nav-item.has-dropdown > a:hover,
.nav-item.has-dropdown:hover > a{
  color:var(--blue);background:var(--blue-faint);
}
.nav-item.has-dropdown > a.active{color:var(--blue);font-weight:600}

/* Caret rotates on hover */
.nav-caret{font-size:9px;opacity:.55;transition:transform .25s ease,opacity .2s}
.nav-item.has-dropdown:hover .nav-caret{transform:rotate(180deg);opacity:1}

/* Dropdown panel */
.nav-dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(-6px);
  min-width:210px;
  background:var(--white);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-lg);
  box-shadow:0 12px 40px rgba(26,60,110,.14);
  padding:8px;
  opacity:0;pointer-events:none;
  transition:opacity .2s ease,transform .2s ease;
  z-index:600;
}

/* Show on hover */
.nav-item.has-dropdown:hover .nav-dropdown{
  opacity:1;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}

/* Arrow tip on dropdown */
.nav-dropdown::before{
  content:'';position:absolute;top:-6px;left:50%;
  transform:translateX(-50%);
  border-left:6px solid transparent;
  border-right:6px solid transparent;
  border-bottom:6px solid var(--gray-100);
}
.nav-dropdown::after{
  content:'';position:absolute;top:-5px;left:50%;
  transform:translateX(-50%);
  border-left:6px solid transparent;
  border-right:6px solid transparent;
  border-bottom:6px solid var(--white);
}

/* Dropdown links */
.nav-dropdown a{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:0;
  font-size:13px;font-weight:400;color:var(--text-mid);
  transition:background .15s,color .15s;white-space:nowrap;
  border-bottom:1px solid var(--gray-100);
}
.nav-dropdown a:last-child{border-bottom:none}
.nav-dropdown a:hover{
  background:var(--blue-faint);color:var(--blue);
}
.nav-dropdown a i{
  width:16px;text-align:center;font-size:12px;
  color:var(--blue-light);flex-shrink:0;
}
.nav-dropdown a:hover i{color:var(--blue)}

/* Divider between groups */
.nav-dropdown .dd-divider{
  height:1px;background:var(--gray-100);margin:4px 0;
}

/* ════════ RESPONSIVE ════════ */
@media(max-width:960px){.main-nav{display:none}.hamburger{display:flex}.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:600px){section{padding:72px 0}.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}#chatbot-window{width:calc(100vw - 32px);right:-8px}.page-hero{padding:108px 0 76px;clip-path:polygon(0 0,100% 0,100% 93%,0 100%)}}
