/* ============================================================
   City Law College — Modern design system
   Navy #0B2A4A · White · Gold #C8A14B · mobile-first
   ============================================================ */

:root{
  --navy:#0B2A4A; --navy-2:#0F3A66; --navy-3:#15497e;
  --gold:#C8A14B; --gold-2:#b8902f;
  --ink:#16202b; --muted:#5b6b7b; --line:#e6ebf1;
  --bg:#ffffff; --bg-soft:#f5f8fc; --bg-soft-2:#eef3f9;
  --white:#fff;
  --radius:14px; --radius-sm:10px;
  --shadow:0 10px 30px rgba(11,42,74,.10);
  --shadow-lg:0 24px 60px rgba(11,42,74,.18);
  --container:1180px;
  --t:.25s cubic-bezier(.4,0,.2,1);
  --h-font:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --b-font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--b-font);color:var(--ink);background:var(--bg);
  line-height:1.65;font-size:16.5px;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy-3);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--gold-2)}
h1,h2,h3,h4{font-family:var(--h-font);color:var(--navy);line-height:1.18;margin:0 0 .5em;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
ul{margin:0 0 1rem;padding-left:1.2rem}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 22px}
.section{padding:clamp(48px,7vw,96px) 0}
.section--soft{background:var(--bg-soft)}
.center{text-align:center}
.eyebrow{display:inline-block;font-family:var(--h-font);font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;font-size:.75rem;color:var(--gold-2);margin-bottom:.6rem}
.section-head{max-width:720px;margin:0 auto clamp(30px,4vw,52px)}
.section-head p{color:var(--muted);font-size:1.05rem}
.lead{font-size:1.12rem;color:var(--muted)}
.gold-rule{width:64px;height:4px;border-radius:4px;background:var(--gold);margin:.9rem auto 0}
.section-head.left{margin-left:0;text-align:left}
.section-head.left .gold-rule{margin-left:0}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--h-font);font-weight:600;
  font-size:.98rem;padding:.85rem 1.6rem;border-radius:50px;border:2px solid transparent;
  cursor:pointer;transition:all var(--t);text-align:center;line-height:1}
.btn-gold{background:var(--gold);color:#1a1407;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-2);border-color:var(--gold-2);color:#1a1407;transform:translateY(-2px);box-shadow:0 12px 26px rgba(200,161,75,.4)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-2);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--line)}
.btn-outline:hover{border-color:var(--navy);color:var(--navy)}

/* ============================================================
   Header / navigation
   ============================================================ */
.topbar{background:var(--navy);color:#cdd9e6;font-size:.85rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:14px;min-height:42px;flex-wrap:wrap}
.topbar a{color:#cdd9e6}.topbar a:hover{color:var(--gold)}
.topbar-info{display:flex;gap:20px;flex-wrap:wrap}
.topbar-info span{display:inline-flex;align-items:center;gap:6px}
.topbar-social{display:flex;gap:14px}

.site-header{position:sticky;top:0;z-index:1000;background:#fff;box-shadow:0 2px 18px rgba(11,42,74,.07);transition:box-shadow var(--t)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--h-font);font-weight:700;color:var(--navy);font-size:1.05rem;line-height:1.1}
.brand img{height:48px;width:auto}
.brand small{display:block;font-weight:500;font-size:.72rem;color:var(--muted);letter-spacing:.02em}
.menu{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.menu>li{position:relative}
.menu>li>a{display:block;padding:.7rem .95rem;font-family:var(--h-font);font-weight:500;font-size:.95rem;color:var(--ink);border-radius:8px}
.menu>li>a:hover,.menu>li.active>a{color:var(--navy);background:var(--bg-soft)}
.menu>li.has>a::after{content:"▾";font-size:.7rem;margin-left:5px;color:var(--muted)}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:248px;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow-lg);padding:8px;list-style:none;margin:0;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:all var(--t);z-index:30}
.menu>li:hover .dropdown,.menu>li:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li a{display:block;padding:.6rem .8rem;border-radius:8px;font-size:.92rem;color:var(--ink)}
.dropdown li a:hover{background:var(--bg-soft);color:var(--navy);padding-left:1.05rem}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:46px;height:46px;border-radius:10px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px auto;transition:all var(--t)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   Hero
   ============================================================ */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.1s ease}
.hero-slide.active{opacity:1}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(8,28,49,.93) 0%,rgba(8,28,49,.78) 45%,rgba(8,28,49,.45) 100%);z-index:1}
.hero-inner{position:relative;z-index:2;padding:clamp(70px,11vw,140px) 0}
.hero-inner .container{max-width:860px;margin-left:auto;margin-right:auto}
.hero h1{color:#fff;margin-bottom:.4em}
.hero h1 .hl{color:var(--gold)}
.hero p{font-size:1.18rem;color:#dbe6f2;max-width:620px;margin-bottom:1.8rem}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-dots{position:absolute;bottom:24px;left:0;right:0;z-index:3;display:flex;gap:10px;justify-content:center}
.hero-dots button{width:11px;height:11px;border-radius:50%;border:0;background:rgba(255,255,255,.4);cursor:pointer;transition:all var(--t)}
.hero-dots button.active{background:var(--gold);width:30px;border-radius:6px}

/* quick links bar */
.quicklinks{background:var(--navy-2);position:relative;z-index:5}
.quicklinks .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.08)}
.quicklinks a{display:flex;align-items:center;gap:12px;padding:22px 20px;background:var(--navy-2);color:#dbe6f2;transition:background var(--t)}
.quicklinks a:hover{background:var(--navy-3);color:#fff}
.quicklinks .ic{font-size:1.5rem;color:var(--gold)}
.quicklinks b{display:block;color:#fff;font-family:var(--h-font);font-size:.98rem}
.quicklinks small{color:#9fb4ca}

/* ============================================================
   Stats
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .num{font-family:var(--h-font);font-weight:800;font-size:clamp(2.2rem,5vw,3.2rem);color:var(--navy);line-height:1}
.stat .num .plus{color:var(--gold)}
.stat .lbl{color:var(--muted);font-weight:500;margin-top:.3rem}

/* ============================================================
   Cards / grids
   ============================================================ */
.grid{display:grid;gap:26px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card-media{aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-media img{transform:scale(1.06)}
.card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.card-body h3{margin-bottom:.5rem}
.card-body p{color:var(--muted);font-size:.96rem}
.card-link{margin-top:auto;font-family:var(--h-font);font-weight:600;color:var(--navy);font-size:.92rem;display:inline-flex;gap:6px;align-items:center}
.card-link:hover{color:var(--gold-2);gap:10px}

/* program card with icon */
.prog{padding:30px 26px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);transition:all var(--t);position:relative}
.prog:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.prog .ic{width:58px;height:58px;border-radius:14px;display:grid;place-items:center;background:var(--bg-soft);color:var(--navy);font-size:1.5rem;margin-bottom:16px}
.prog:hover .ic{background:var(--gold);color:#1a1407}

/* ============================================================
   Principal / about split
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.split-media{position:relative}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%}
.split-media .badge{position:absolute;bottom:-22px;right:-10px;background:var(--gold);color:#1a1407;
  font-family:var(--h-font);font-weight:700;padding:18px 24px;border-radius:14px;box-shadow:var(--shadow);line-height:1.1}
.split-media .badge small{display:block;font-weight:500;font-size:.7rem}
.quote{border-left:4px solid var(--gold);padding-left:20px;color:var(--muted);font-style:italic;margin:1.2rem 0}
.signoff{font-family:var(--h-font);font-weight:700;color:var(--navy);margin-top:1rem}
.signoff small{display:block;font-weight:500;color:var(--muted)}

/* ============================================================
   News / notices
   ============================================================ */
.notice-list{list-style:none;margin:0;padding:0}
.notice-list li{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--line)}
.notice-list li:last-child{border-bottom:0}
.notice-date{flex:0 0 auto;background:var(--navy);color:#fff;border-radius:10px;text-align:center;padding:8px 12px;font-family:var(--h-font);line-height:1}
.notice-date b{font-size:1.3rem;display:block}
.notice-date small{font-size:.68rem;color:var(--gold)}
.notice-list a{font-family:var(--h-font);font-weight:600;color:var(--navy)}
.notice-list a:hover{color:var(--gold-2)}

/* ============================================================
   CTA band
   ============================================================ */
.cta{background:linear-gradient(120deg,var(--navy) 0%,var(--navy-3) 100%);color:#fff;border-radius:var(--radius);
  padding:clamp(34px,5vw,60px);text-align:center;position:relative;overflow:hidden}
.cta::before{content:"⚖";position:absolute;right:-10px;top:-30px;font-size:200px;opacity:.06}
.cta h2{color:#fff}
.cta p{color:#cfe;opacity:.9;max-width:620px;margin:0 auto 1.5rem;color:#dbe6f2}
.cta .hero-actions{justify-content:center}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--navy);color:#aebfd1;padding-top:clamp(48px,6vw,72px)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:1.1rem;position:relative;padding-bottom:.6rem}
.site-footer h4::after{content:"";position:absolute;left:0;bottom:0;width:36px;height:3px;background:var(--gold);border-radius:3px}
.site-footer a{color:#aebfd1;display:inline-block}
.site-footer a:hover{color:var(--gold)}
.foot-brand img{height:60px;width:auto;margin-bottom:14px;background:#fff;padding:6px;border-radius:10px}
.foot-links{list-style:none;margin:0;padding:0}
.foot-links li{margin-bottom:.6rem}
.foot-contact li{display:flex;gap:10px;margin-bottom:.9rem;align-items:flex-start}
.foot-contact .ic{color:var(--gold);flex:0 0 auto}
.foot-social{display:flex;gap:10px;margin-top:14px}
.foot-social a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff}
.foot-social a:hover{background:var(--gold);color:#1a1407}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:clamp(34px,5vw,54px);padding:22px 0;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.88rem}

/* page hero (interior pages) */
.page-hero{background:var(--navy);color:#fff;padding:clamp(48px,7vw,86px) 0;position:relative;overflow:hidden}
.page-hero::after{content:"⚖";position:absolute;right:4%;top:50%;transform:translateY(-50%);font-size:160px;opacity:.07}
.page-hero h1{color:#fff;margin:0}
.breadcrumb{display:flex;gap:8px;align-items:center;list-style:none;padding:0;margin:0 0 .8rem;color:#9fb4ca;font-size:.9rem;flex-wrap:wrap}
.breadcrumb a{color:#cdd9e6}.breadcrumb a:hover{color:var(--gold)}
.prose{max-width:880px}
.prose img{border-radius:10px;margin:1rem 0}
.prose h2,.prose h3{margin-top:1.6rem}
.prose a{color:var(--navy-3);text-decoration:underline}

/* ============================================================
   Forms + simple 12-col grid (for the admission form etc.)
   ============================================================ */
.form-wrap{max-width:880px;margin:clamp(28px,5vw,56px) auto;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(22px,4vw,44px)}
.form-wrap h2,.form-wrap h3{color:var(--navy)}
.form-control,select.form-control,textarea.form-control{
  width:100%;padding:.7rem .9rem;font-size:1rem;font-family:var(--b-font);color:var(--ink);
  background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-sm);transition:border-color var(--t),box-shadow var(--t);margin-bottom:2px}
.form-control:focus{outline:0;border-color:var(--navy-3);box-shadow:0 0 0 3px rgba(15,58,102,.12)}
label{font-family:var(--h-font);font-weight:500;color:var(--ink);font-size:.92rem}
.form-wrap .row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:0 0 14px}
.form-wrap .row > [class*="col-"]{padding:0}
.col-md-1{flex:0 0 7%}.col-md-2{flex:0 0 14%}.col-md-3{flex:0 0 22%}
.col-md-4{flex:0 0 30%;min-width:130px}.col-md-6{flex:1 1 46%;min-width:200px}
.col-md-8{flex:1 1 64%;min-width:220px}.col-md-12{flex:0 0 100%}
input[type=submit],button[type=submit],.btn-submit{
  background:var(--gold);color:#1a1407;font-family:var(--h-font);font-weight:600;border:0;
  padding:.85rem 2rem;border-radius:50px;cursor:pointer;font-size:1rem;transition:all var(--t)}
input[type=submit]:hover,button[type=submit]:hover,.btn-submit:hover{background:var(--gold-2);transform:translateY(-2px);box-shadow:0 10px 24px rgba(200,161,75,.35)}
.form-brandbar{background:var(--navy);color:#fff;padding:14px 0}
.form-brandbar .container{display:flex;align-items:center;gap:14px}
.form-brandbar img{height:46px;background:#fff;border-radius:8px;padding:4px}
.form-brandbar b{font-family:var(--h-font);font-size:1.1rem;display:block}
.form-brandbar small{color:#cdd9e6}
@media(max-width:640px){.form-wrap .row > [class*="col-"]{flex:1 1 100%}}

/* ============================================================
   E-lecture lists (legacy groupdata() button markup, modernized)
   ============================================================ */
.elec-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;list-style:none;padding:0;margin:0}
.elec-list>li{list-style:none}
.btn-theme-colored2{display:block;width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 24px;text-align:left;cursor:pointer;transition:all var(--t);font-family:var(--h-font);font-weight:600;font-size:1rem;
  position:relative;box-shadow:0 4px 14px rgba(11,42,74,.05)}
.btn-theme-colored2::before{content:"⚖️";margin-right:10px}
.btn-theme-colored2:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--gold)}
.btn-theme-colored2 a,.btn-theme-colored2 span{color:var(--navy)!important;text-decoration:none}
.btn-theme-colored2:hover a{color:var(--gold-2)!important}

/* responsive video embed */
.video-wrap{position:relative;width:100%;padding-top:56.25%;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-lg);background:#000;margin-bottom:24px}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.lecture-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .quicklinks .grid{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
  .split-media{order:-1}
}
@media(max-width:768px){
  .nav-toggle{display:block}
  .nav-cta .btn-text{display:none}
  .menu{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:#fff;padding:10px 16px 24px;box-shadow:var(--shadow-lg);max-height:calc(100vh - 74px);
    overflow-y:auto;transform:translateY(-120%);transition:transform var(--t);border-top:1px solid var(--line)}
  .menu.open{transform:none}
  .menu>li>a{padding:.9rem .4rem;border-bottom:1px solid var(--line);border-radius:0}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;
    padding:0 0 8px 12px;min-width:0;display:none}
  .menu>li.open .dropdown{display:block}
  .menu>li.has>a::after{float:right}
}
@media(max-width:600px){
  .grid-3,.grid-2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .topbar-info{gap:12px;font-size:.78rem}
  .foot-bottom{justify-content:center;text-align:center}
}
