/* academics.ng — global stylesheet (extracted 1:1 from homepage v2 template, with additions) */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --pri:#0A3D5C;--pri-l:#0E5A82;--sec:#0D7377;--sec-l:#E6F4F4;
  --acc:#C4552D;--acc-l:#FAEFEB;--acc-h:#A84424;
  --bg:#FFFFFF;--bg2:#F3F5F7;--bg3:#FAFBFC;--bgw:#F9F8F6;
  --bdr:#D8DEE4;--bdr-l:#E8ECF0;
  --t1:#111928;--t2:#4B556A;--t3:#6C7689;--t4:#9BA3B2;
  --ok:#0C6B37;--ok-bg:#E7F5ED;--warn:#8B6914;--warn-bg:#FDF6E3;--err:#B42020;--err-bg:#FEF2F2;
  --sh-s:0 1px 3px rgba(0,0,0,.04);--sh-m:0 2px 10px rgba(0,0,0,.06);--sh-l:0 4px 20px rgba(0,0,0,.08);
  --r-s:6px;--r-m:10px;--r-l:14px;
  --ff-d:'Newsreader',Georgia,serif;--ff-b:'Outfit','Segoe UI',sans-serif;
  --mw:1400px;--hdr:60px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--ff-b);color:var(--t1);background:var(--bg);line-height:1.6;font-size:15px;-webkit-font-smoothing:antialiased}
a{color:var(--pri-l);text-decoration:none;transition:color .15s}a:hover{color:var(--acc)}
img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}
button,input,select,textarea{font-family:inherit;font-size:inherit}button{cursor:pointer;border:none;background:none}
.container{max-width:var(--mw);margin:0 auto;padding:0 24px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* === HEADER === */
.site-header{background:var(--bg);border-bottom:1px solid var(--bdr);position:sticky;top:0;z-index:1000}
.site-header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--hdr)}
.logo{display:flex;align-items:center;gap:2px;text-decoration:none;flex-shrink:0}
.logo-mark{width:30px;height:30px;background:var(--sec);border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--ff-d);font-size:17px;font-weight:700}
.logo-text{font-family:var(--ff-d);font-size:19px;color:var(--pri);letter-spacing:-.3px}.logo-text b{color:var(--acc)}

.main-nav{display:flex;align-items:center;gap:1px}
.main-nav>li{position:relative}
.nav-link{display:flex;align-items:center;gap:3px;padding:6px 11px;font-size:13.5px;font-weight:500;color:var(--t2);border-radius:var(--r-s);transition:all .15s;white-space:nowrap}
.nav-link:hover,.nav-link.act{color:var(--pri);background:var(--bg2)}
.nav-link svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .2s}
.main-nav>li:hover .nav-link svg{transform:rotate(180deg)}

/* Mega */
.mega-dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);box-shadow:var(--sh-l);padding:16px;min-width:480px;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility 0s linear .25s;pointer-events:none;margin-top:6px}
/* Invisible hover-bridge spans the 6px visual gap so the mouse can cross from the nav-link to the dropdown without losing :hover */
.mega-dropdown::before, .simple-dropdown::before{content:'';position:absolute;top:-8px;left:0;right:0;height:8px;background:transparent}
.main-nav>li:hover .mega-dropdown{opacity:1;visibility:visible;pointer-events:all;transition:opacity .15s ease,visibility 0s linear 0s}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.mega-link{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--r-s);font-size:13px;color:var(--t1);transition:background .1s}
.mega-link:hover{background:var(--bg2);color:var(--pri)}
.mega-link-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.mega-link-text strong{display:block;font-size:13px;font-weight:600}.mega-link-text span{font-size:11.5px;color:var(--t3);display:block;margin-top:1px}

.simple-dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);box-shadow:var(--sh-l);padding:6px;min-width:200px;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility 0s linear .25s;pointer-events:none;margin-top:6px}
.main-nav>li:hover .simple-dropdown{opacity:1;visibility:visible;pointer-events:all;transition:opacity .15s ease,visibility 0s linear 0s}
.simple-dropdown a{display:block;padding:8px 12px;font-size:13px;color:var(--t1);border-radius:var(--r-s)}.simple-dropdown a:hover{background:var(--bg2);color:var(--pri)}
.simple-dropdown hr{margin:6px 8px}

.site-header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.btn-search{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-s);color:var(--t3);transition:all .15s;border:1px solid transparent}
.btn-search:hover{background:var(--bg2);color:var(--pri);border-color:var(--bdr)}.btn-search svg{width:18px;height:18px}
.btn-header-cta{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;background:var(--acc);color:#fff;font-size:12.5px;font-weight:600;border-radius:var(--r-s);transition:background .15s}.btn-header-cta:hover{background:var(--acc-h);color:#fff}
.hamburger{display:none;width:36px;height:36px;align-items:center;justify-content:center;border-radius:var(--r-s);color:var(--t1)}.hamburger svg{width:20px;height:20px}

/* Search Overlay */
.search-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:2000;display:flex;align-items:flex-start;justify-content:center;padding-top:72px;opacity:0;visibility:hidden;transition:all .2s}
.search-overlay.on{opacity:1;visibility:visible}
.search-box{background:var(--bg);border-radius:var(--r-l);padding:6px;width:92%;max-width:640px;box-shadow:var(--sh-l);transform:translateY(-8px);transition:transform .2s}
.search-overlay.on .search-box{transform:translateY(0)}
.search-box input{width:100%;padding:14px 18px;border:none;outline:none;font-size:16px;background:transparent}.search-box input::placeholder{color:var(--t4)}
.search-hints{padding:6px 18px 12px;border-top:1px solid var(--bdr-l);display:flex;flex-wrap:wrap;gap:5px}
.search-hints a{padding:4px 10px;background:var(--bg2);border-radius:16px;font-size:11.5px;color:var(--t3);transition:all .1s}.search-hints a:hover{background:var(--sec-l);color:var(--sec)}

/* Mobile Menu */
.mobile-menu{position:fixed;inset:0;background:var(--bg);z-index:3000;overflow-y:auto;transform:translateX(100%);transition:transform .3s ease}
.mobile-menu.on{transform:translateX(0)}
.mobile-menu-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--bdr)}
.mobile-menu-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--t1)}.mobile-menu-close svg{width:20px;height:20px}
.mobile-menu-body{padding:10px 20px 40px}
.mobile-nav-group{margin-bottom:4px;border-bottom:1px solid var(--bdr-l)}
.mobile-nav-title{display:flex;align-items:center;justify-content:space-between;width:100%;padding:13px 0;font-size:14.5px;font-weight:600;color:var(--t1)}
.mobile-nav-title svg{width:14px;height:14px;color:var(--t3);transition:transform .2s}.mobile-nav-group.op .mobile-nav-title svg{transform:rotate(180deg)}
.mobile-nav-sub{display:none;padding-bottom:6px}.mobile-nav-group.op .mobile-nav-sub{display:block}
.mobile-nav-sub a{display:block;padding:9px 0 9px 12px;font-size:13.5px;color:var(--t2);border-left:2px solid var(--bdr-l);margin-left:4px}.mobile-nav-sub a:hover{color:var(--pri);border-color:var(--pri)}
.mobile-menu-cta{display:block;margin-top:14px;padding:13px;background:var(--acc);color:#fff;text-align:center;border-radius:var(--r-m);font-weight:600;font-size:14px}

/* === TICKER === */
.ticker{background:var(--warn-bg);border-bottom:1px solid #E8D9A8;padding:10px 0}
.ticker-inner{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--warn)}.ticker-inner strong{font-weight:700}
.ticker a{color:var(--pri-l);font-weight:600;margin-left:auto;white-space:nowrap;font-size:13px}

/* === HERO === */
.hero{background:var(--bg2);padding:40px 0 36px;border-bottom:1px solid var(--bdr)}
.hero-row{display:flex;gap:40px;align-items:flex-start}
.hero-content{flex:1;min-width:0}
.hero-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px 3px 5px;background:var(--ok-bg);border-radius:16px;font-size:11.5px;font-weight:600;color:var(--ok);margin-bottom:12px}
.hero-dot{width:7px;height:7px;background:var(--ok);border-radius:50%;animation:pls 2s infinite}
@keyframes pls{0%,100%{opacity:1}50%{opacity:.35}}
.hero h1{font-family:var(--ff-d);font-size:34px;line-height:1.15;color:var(--pri);margin-bottom:10px;letter-spacing:-.4px}
.hero h1 em{font-style:italic;color:var(--acc)}
.hero-text{font-size:15px;color:var(--t2);max-width:520px;line-height:1.55;margin-bottom:20px}
.hero-search{position:relative;max-width:520px}
.hero-search input{width:100%;padding:13px 120px 13px 42px;border:2px solid var(--bdr);border-radius:var(--r-m);font-size:14.5px;background:var(--bg);outline:none;transition:border .15s}
.hero-search input:focus{border-color:var(--sec)}.hero-search input::placeholder{color:var(--t4)}
.hero-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--t4)}
.hero-search-btn{position:absolute;right:5px;top:50%;transform:translateY(-50%);padding:9px 16px;background:var(--pri);color:#fff;border-radius:var(--r-s);font-size:13px;font-weight:600;transition:background .15s}.hero-search-btn:hover{background:var(--pri-l)}
.hero-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.hero-tags a{padding:3px 9px;background:var(--bg);border:1px solid var(--bdr);border-radius:16px;font-size:11.5px;color:var(--t3);transition:all .1s}.hero-tags a:hover{border-color:var(--sec);color:var(--sec);background:var(--sec-l)}

.hero-stats{flex-shrink:0;display:grid;grid-template-columns:1fr 1fr;gap:10px;width:290px}
.stat-card{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:14px;text-align:center}
.stat-card-num{font-family:var(--ff-d);font-size:26px;color:var(--pri)}.stat-card-label{font-size:11.5px;color:var(--t3);margin-top:1px;font-weight:500}
.stat-card.ac{border-color:var(--acc)}.stat-card.ac .stat-card-num{color:var(--acc)}
.stat-card.sc{border-color:var(--sec)}.stat-card.sc .stat-card-num{color:var(--sec)}

/* === SHARED === */
.section{padding:0}.section-alt{background:var(--bg2)}.section-warm{background:var(--bgw)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin:44px 0 24px;gap:12px}
.section > .container > :last-child{padding-bottom:44px}
.section-title{font-family:var(--ff-d);font-size:24px;color:var(--pri);letter-spacing:-.2px}
.section-subtitle{font-size:13.5px;color:var(--t3);margin-top:3px}
.section-link{font-size:13px;font-weight:600;color:var(--sec);display:flex;align-items:center;gap:3px;white-space:nowrap;flex-shrink:0}
.section-link:hover{color:var(--acc)}.section-link svg{width:14px;height:14px}
.arr{fill:none;stroke:currentColor;stroke-width:2}

/* === BROWSE CARDS === */
.tile-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.tile{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:16px 12px;text-align:center;transition:all .15s}
.tile:hover{border-color:var(--sec);box-shadow:var(--sh-m);transform:translateY(-2px)}
.tile-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin:0 auto 8px;font-size:19px}
.tile h3{font-size:13px;font-weight:600;color:var(--t1);margin-bottom:2px}.tile p{font-size:11.5px;color:var(--t3)}

/* === TRACKER TABLE === */
.table-wrap{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);overflow:hidden}
.data-table{width:100%;border-collapse:collapse}
.data-table th{background:var(--bg2);padding:10px 14px;text-align:left;font-size:11.5px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--bdr)}
.data-table td{padding:11px 14px;border-bottom:1px solid var(--bdr-l);font-size:13.5px;color:var(--t1)}.data-table tr:last-child td{border:none}.data-table tr:hover td{background:var(--bg3)}
.data-table a{color:var(--pri-l);font-weight:500}
.badge{display:inline-flex;padding:2px 9px;border-radius:16px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-open{background:var(--ok-bg);color:var(--ok)}.badge-closed{background:#F0F1F3;color:var(--t3)}.badge-warn{background:var(--warn-bg);color:var(--warn)}.badge-info{background:var(--acc-l);color:var(--acc)}
.badge-error{background:var(--err-bg);color:var(--err)}

/* === PRACTICE + SUBJECTS (Combined) === */
.duo-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.duo-card{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:24px;display:flex;flex-direction:column}
.duo-card h3{font-family:var(--ff-d);font-size:20px;color:var(--pri);margin-bottom:6px}
.duo-card>p{font-size:13.5px;color:var(--t2);margin-bottom:16px;line-height:1.5}
.duo-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.duo-tags a{padding:5px 11px;background:var(--bg2);border-radius:var(--r-s);font-size:12.5px;color:var(--t2);font-weight:500;transition:all .1s;border:1px solid transparent}
.duo-tags a:hover{border-color:var(--sec);color:var(--sec);background:var(--sec-l)}
.duo-cta{margin-top:auto;display:inline-flex;align-items:center;gap:5px;padding:10px 20px;background:var(--pri);color:#fff;border-radius:var(--r-s);font-size:13.5px;font-weight:600;transition:background .15s;align-self:flex-start}
.duo-cta:hover{background:var(--pri-l);color:#fff}
.duo-cta.sec-c{background:var(--sec)}.duo-cta.sec-c:hover{background:var(--sec);opacity:.9;color:#fff}

/* === CUTOFF CARDS === */
.cutoff-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.cutoff-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:12px 16px;transition:all .15s;gap:10px}
.cutoff-card:hover{border-color:var(--sec);box-shadow:var(--sh-s)}
.cutoff-info h4{font-size:13.5px;font-weight:600;color:var(--t1)}.cutoff-info p{font-size:11.5px;color:var(--t3);margin-top:1px}
.cutoff-score{text-align:center;flex-shrink:0}.cutoff-score .n{font-family:var(--ff-d);font-size:22px;color:var(--pri);display:block;line-height:1}.cutoff-score .m{font-size:10px;color:var(--t4)}

/* === SCHOLARSHIP SPOTLIGHT === */
.scholarship-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.scholarship-card{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:18px;transition:all .15s;display:flex;flex-direction:column}
.scholarship-card:hover{box-shadow:var(--sh-m)}
.scholarship-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.scholarship-top .badge{font-size:10.5px}
.scholarship-card h4{font-size:14px;font-weight:600;color:var(--t1);margin-bottom:4px;line-height:1.3}
.scholarship-card .scholarship-text{font-size:12.5px;color:var(--t3);margin-bottom:10px;flex:1}
.scholarship-meta{display:flex;gap:12px;font-size:12px;color:var(--t2);border-top:1px solid var(--bdr-l);padding-top:10px;margin-top:auto}
.scholarship-meta strong{color:var(--pri);font-weight:600}

/* === TOOLS === */
.tools-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tool-card{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:20px;transition:all .15s;display:flex;flex-direction:column}
.tool-card:hover{border-color:var(--sec);box-shadow:var(--sh-m)}
.tool-card-icon{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:12px}
.tool-card h3{font-size:14.5px;font-weight:700;color:var(--t1);margin-bottom:4px}
.tool-card p{font-size:12.5px;color:var(--t3);line-height:1.45;flex:1}
.tool-card .tool-card-cta{display:inline-flex;align-items:center;gap:3px;margin-top:12px;font-size:12.5px;font-weight:600;color:var(--sec)}.tool-card:hover .tool-card-cta{color:var(--acc)}

/* === RANKINGS === */
.ranking-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ranking-block{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);overflow:hidden}
.ranking-block-head{padding:12px 16px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between}
.ranking-block-head h3{font-size:13.5px;font-weight:700;color:var(--t1)}
.ranking-list{padding:4px 0}
.ranking-item{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:13px}.ranking-item:hover{background:var(--bg3)}
.ranking-number{width:22px;height:22px;border-radius:5px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--t3);flex-shrink:0}
.ranking-item:nth-child(1) .ranking-number{background:var(--pri);color:#fff}.ranking-item:nth-child(2) .ranking-number{background:var(--pri-l);color:#fff}.ranking-item:nth-child(3) .ranking-number{background:var(--sec);color:#fff}
.ranking-name{color:var(--t1);font-weight:500}.ranking-meta{font-size:11px;color:var(--t4);margin-left:auto;white-space:nowrap}

/* === COURSE TAGS === */
.course-tag-group{display:flex;flex-wrap:wrap;gap:8px}
.course-tag{display:flex;align-items:center;gap:7px;padding:10px 15px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);font-size:13px;font-weight:500;color:var(--t1);transition:all .15s}
.course-tag:hover{border-color:var(--sec);box-shadow:var(--sh-s);color:var(--pri)}
.course-tag-count{background:var(--bg2);padding:1px 7px;border-radius:10px;font-size:11px;color:var(--t3);font-weight:600}

/* === NYSC + STUDY ABROAD + FUNDING (compact row sections) === */
.trio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.trio-card{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:20px}
.trio-card h3{font-family:var(--ff-d);font-size:17px;color:var(--pri);margin-bottom:6px}
.trio-card p{font-size:13px;color:var(--t2);margin-bottom:12px;line-height:1.5}
.trio-links{display:flex;flex-direction:column;gap:4px}
.trio-links a{font-size:13px;color:var(--pri-l);font-weight:500;padding:4px 0;display:flex;align-items:center;gap:4px}
.trio-links a:hover{color:var(--acc)}
.trio-links a::before{content:'\2192';font-size:11px;color:var(--t4)}

/* === COMPARE CTA === */
.cta-banner{background:var(--pri);border-radius:var(--r-l);padding:32px 40px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.cta-banner h2{font-family:var(--ff-d);font-size:24px;color:#fff}.cta-banner p{font-size:14px;color:rgba(255,255,255,.7);margin-top:4px;max-width:480px}
.cta-banner-actions{display:flex;gap:10px;flex-shrink:0}
.bw{padding:10px 20px;background:#fff;color:var(--pri);font-weight:600;font-size:13.5px;border-radius:var(--r-s);transition:all .15s}.bw:hover{background:var(--bg2);color:var(--pri)}
.bow{padding:10px 20px;border:2px solid rgba(255,255,255,.3);color:#fff;font-weight:600;font-size:13.5px;border-radius:var(--r-s);transition:all .15s}.bow:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}

/* === UPDATES === */
.updates-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.update-card{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:16px;transition:all .15s}.update-card:hover{box-shadow:var(--sh-m)}
.update-tag{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.update-card h4{font-size:13.5px;font-weight:600;color:var(--t1);line-height:1.35;margin-bottom:6px}
.update-card p{font-size:12.5px;color:var(--t3);line-height:1.45}
.update-date{font-size:11px;color:var(--t4);margin-top:8px}

/* === NEWSLETTER === */
.newsletter-box{background:var(--sec-l);border:1px solid #B8DFE1;border-radius:var(--r-l);padding:30px 36px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.newsletter-box h3{font-family:var(--ff-d);font-size:20px;color:var(--pri)}.newsletter-box p{font-size:13.5px;color:var(--t2);margin-top:3px}
.newsletter-form{display:flex;gap:7px;flex-shrink:0}
.newsletter-form input{padding:10px 16px;border:2px solid var(--bdr);border-radius:var(--r-s);font-size:13.5px;width:260px;background:var(--bg);outline:none}.newsletter-form input:focus{border-color:var(--sec)}
.newsletter-form button{padding:10px 20px;background:var(--pri);color:#fff;font-weight:600;font-size:13.5px;border-radius:var(--r-s);white-space:nowrap;transition:background .15s}.newsletter-form button:hover{background:var(--pri-l)}
.newsletter-msg{padding:10px 14px;border-radius:var(--r-s);font-size:13px;margin-top:8px}
.newsletter-msg.ok{background:var(--ok-bg);color:var(--ok)}
.newsletter-msg.err{background:var(--err-bg);color:var(--err)}

/* === FOOTER === */
.site-footer{background:var(--bg2);border-top:1px solid var(--bdr);padding:44px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(5,1fr);gap:28px}
.footer-brand p{font-size:12.5px;color:var(--t3);line-height:1.55;margin:10px 0 14px;max-width:260px}
.footer-social{display:flex;gap:6px}
.footer-social a{width:32px;height:32px;border:1px solid var(--bdr);border-radius:var(--r-s);display:flex;align-items:center;justify-content:center;color:var(--t3);transition:all .15s}
.footer-social a:hover{border-color:var(--sec);color:var(--sec);background:var(--sec-l)}.footer-social svg{width:14px;height:14px}
.footer-col h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--t1);margin-bottom:12px}
.footer-col a{display:block;padding:4px 0;font-size:12.5px;color:var(--t3);transition:color .1s}.footer-col a:hover{color:var(--pri)}
.footer-bottom{margin-top:36px;padding:18px 0;border-top:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--t4)}
.footer-bottom-links{display:flex;gap:16px}.footer-bottom-links a{color:var(--t4)}.footer-bottom-links a:hover{color:var(--t1)}

/* ===== EXTRA PAGE COMPONENTS (added beyond template) ===== */

/* Page headers (now live INSIDE .main-col, no background) */
.page-header{padding:6px 0 14px;border-bottom:1px solid var(--bdr-l);margin-bottom:22px}
.page-breadcrumb{font-size:12.5px;color:var(--t3);margin-bottom:8px;display:flex;flex-wrap:wrap;gap:6px}
.page-breadcrumb a{color:var(--t3)}.page-breadcrumb a:hover{color:var(--pri)}
.page-breadcrumb span{color:var(--t4)}
.page-header h1{font-family:var(--ff-d);font-size:28px;color:var(--pri);letter-spacing:-.3px;line-height:1.15;margin-bottom:6px}
.page-header .page-subtitle{font-size:14.5px;color:var(--t2);max-width:none;line-height:1.55}
.page-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.page-tags a,.page-tags span{padding:4px 11px;background:var(--bg2);border:1px solid var(--bdr-l);border-radius:16px;font-size:11.5px;color:var(--t2);font-weight:500}
.page-tags a:hover{border-color:var(--sec);color:var(--sec)}
.page-tags a.act,.page-tags .act{background:var(--pri);color:#fff;border-color:var(--pri)}

/* Filter bar */
.filter-bar{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:14px;margin-bottom:18px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.filter-bar input,.filter-bar select{padding:9px 12px;border:1px solid var(--bdr);border-radius:var(--r-s);font-size:13.5px;background:var(--bg);outline:none;transition:border .15s}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--sec)}
.filter-bar input[type=search]{flex:1;min-width:200px}
.filter-bar .filter-bar-btn{padding:9px 18px;background:var(--pri);color:#fff;border-radius:var(--r-s);font-size:13px;font-weight:600}.filter-bar .filter-bar-btn:hover{background:var(--pri-l)}
.filter-bar .filter-bar-result{margin-left:auto;font-size:12.5px;color:var(--t3)}

/* Card grid (institution / course listing) */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.card{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:18px;transition:all .15s;display:flex;flex-direction:column}
.card:hover{border-color:var(--sec);box-shadow:var(--sh-m);transform:translateY(-2px)}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:8px}
.card-top h3{font-size:15px;font-weight:700;color:var(--t1);line-height:1.3}
.card-meta{font-size:12px;color:var(--t3);margin-bottom:8px}
.card-meta strong{color:var(--t2);font-weight:600}
.card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:auto;padding-top:12px;border-top:1px solid var(--bdr-l)}
.card-stat{text-align:center}
.card-stat-num{font-family:var(--ff-d);font-size:16px;color:var(--pri);font-weight:600}
.card-stat-label{font-size:10.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.3px}

/* Pagination */
.pagination{display:flex;justify-content:center;align-items:center;gap:4px;margin:28px 0 8px;flex-wrap:wrap;list-style:none;padding:0}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 12px;border:1px solid var(--bdr);border-radius:var(--r-s);font-size:13.5px;font-weight:500;color:var(--t2);background:var(--bg);transition:all .12s;line-height:1;text-decoration:none}
.pagination a:hover{border-color:var(--sec);color:var(--sec);background:var(--sec-l);transform:translateY(-1px)}
.pagination .act{background:var(--pri);color:#fff;border-color:var(--pri);font-weight:700;cursor:default}
.pagination .act:hover{background:var(--pri);color:#fff;border-color:var(--pri);transform:none}
.pagination .dis{color:var(--t4);background:var(--bg2);border-color:var(--bdr-l);pointer-events:none;opacity:.7}
@media(max-width:640px){
  .pagination a,.pagination span{min-width:34px;height:34px;padding:0 8px;font-size:12.5px}
}

/* Generic section content (article-like) */
.prose{font-size:15.5px;color:var(--t1);line-height:1.7}
.prose p{margin-bottom:14px}
.prose h2{font-family:var(--ff-d);font-size:22px;color:var(--pri);margin:28px 0 10px;letter-spacing:-.2px}
.prose h3{font-family:var(--ff-d);font-size:18px;color:var(--pri);margin:22px 0 8px}
.prose ul,.prose ol{margin:0 0 14px 22px}
.prose ul li,.prose ol li{list-style:initial;margin-bottom:6px}
.prose ol li{list-style:decimal}
.prose strong{font-weight:600}
.prose a{color:var(--pri-l);text-decoration:underline}
.prose blockquote{border-left:3px solid var(--sec);padding:8px 16px;color:var(--t2);font-style:italic;background:var(--sec-l);border-radius:var(--r-s);margin:14px 0}
.prose table{width:100%;border-collapse:collapse;margin:14px 0}
.prose th,.prose td{border:1px solid var(--bdr-l);padding:8px 12px;font-size:14px;text-align:left}
.prose th{background:var(--bg2);font-weight:600;color:var(--t2);font-size:12px;text-transform:uppercase;letter-spacing:.3px}

/* Two-column page (sidebar + main) */
.two-col{display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:start}
.main-col{min-width:0}
.sidebar{display:flex;flex-direction:column;gap:14px;position:sticky;top:calc(var(--hdr) + 16px)}
.side-card{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:16px}
.side-card h4{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);margin-bottom:10px}
.side-card a{display:block;padding:6px 0;font-size:13px;color:var(--t1);border-bottom:1px solid var(--bdr-l)}
.side-card a:last-child{border:none}
.side-card a:hover{color:var(--pri)}

/* Profile header (now lives INSIDE .main-col, no gradient background) */
.profile-header{padding:6px 0 14px;border-bottom:1px solid var(--bdr-l);margin-bottom:18px}
.profile-breadcrumb{font-size:12.5px;color:var(--t3);margin-bottom:8px;display:flex;flex-wrap:wrap;gap:6px}
.profile-breadcrumb a{color:var(--t3)}.profile-breadcrumb a:hover{color:var(--pri)}
.profile-breadcrumb span{color:var(--t4)}
.profile-header h1{font-family:var(--ff-d);font-size:30px;color:var(--pri);letter-spacing:-.4px;margin-bottom:6px;line-height:1.15}
.profile-header .profile-subtitle{font-size:15px;color:var(--t2);max-width:none;line-height:1.55}
.profile-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.profile-badge{padding:4px 11px;background:var(--bg2);border:1px solid var(--bdr-l);border-radius:16px;font-size:11.5px;font-weight:500;color:var(--t2)}
.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px}
.profile-stat{padding:12px 14px;background:var(--bg2);border:1px solid var(--bdr-l);border-radius:var(--r-m)}
.profile-stat-num{font-family:var(--ff-d);font-size:20px;color:var(--pri);font-weight:600;line-height:1.1}
.profile-stat-label{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.3px;margin-top:2px}

/* Sub-nav (now lives INSIDE .main-col, no background, no sticky) */
.subnav{border-bottom:1px solid var(--bdr-l);overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:22px}
.subnav-inner{display:flex;gap:4px;padding:0 0 6px}
.subnav a{padding:9px 14px;font-size:13px;color:var(--t2);font-weight:500;border-radius:var(--r-s);white-space:nowrap}
.subnav a:hover{background:var(--bg2);color:var(--pri)}
.subnav a.act{background:var(--pri);color:#fff}

/* Practice interface */
.question-box{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:24px;max-width:780px;margin:0 auto}
.question-progress{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;font-size:13px;color:var(--t3)}
.question-progress-bar{flex:1;height:6px;background:var(--bg2);border-radius:3px;margin:0 14px;overflow:hidden}
.question-progress-fill{height:100%;background:var(--sec);transition:width .25s}
.question-timer{font-family:var(--ff-d);font-size:15px;color:var(--acc);font-weight:600}
.question-text{font-size:16.5px;color:var(--t1);line-height:1.55;margin-bottom:18px}
.question-options{display:flex;flex-direction:column;gap:8px}
.question-option{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:var(--bg);border:2px solid var(--bdr);border-radius:var(--r-m);font-size:14px;color:var(--t1);text-align:left;cursor:pointer;transition:all .12s;min-height:44px}
.question-option:hover{border-color:var(--sec);background:var(--sec-l)}
.question-option.sel{border-color:var(--sec);background:var(--sec-l);color:var(--pri)}
.question-option.ok{border-color:var(--ok);background:var(--ok-bg);color:var(--ok)}
.question-option.bad{border-color:var(--err);background:var(--err-bg);color:var(--err)}
.question-option-letter{width:24px;height:24px;border-radius:50%;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11.5px;flex-shrink:0;color:var(--t2)}
.question-option.sel .question-option-letter{background:var(--sec);color:#fff}
.question-option.ok .question-option-letter{background:var(--ok);color:#fff}
.question-option.bad .question-option-letter{background:var(--err);color:#fff}
.question-controls{display:flex;gap:8px;margin-top:20px;justify-content:space-between}
.btn-primary{padding:10px 22px;background:var(--pri);color:#fff;border-radius:var(--r-s);font-size:13.5px;font-weight:600;transition:background .15s;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.btn-primary:hover{background:var(--pri-l);color:#fff}
.btn-secondary{padding:10px 22px;background:var(--bg);border:1px solid var(--bdr);color:var(--t2);border-radius:var(--r-s);font-size:13.5px;font-weight:600;cursor:pointer;transition:all .15s}
.btn-secondary:hover{border-color:var(--sec);color:var(--sec)}
.btn-accent{padding:10px 22px;background:var(--acc);color:#fff;border-radius:var(--r-s);font-size:13.5px;font-weight:600;cursor:pointer;transition:background .15s;display:inline-flex;align-items:center;gap:5px}
.btn-accent:hover{background:var(--acc-h);color:#fff}
.question-explanation{padding:14px;background:var(--bg2);border-radius:var(--r-s);margin-top:14px;font-size:13.5px;color:var(--t2)}
.question-explanation strong{color:var(--t1);display:block;margin-bottom:4px;font-weight:700}

/* Question navigation grid */
.question-nav{display:grid;grid-template-columns:repeat(auto-fill,minmax(36px,1fr));gap:6px;margin-top:18px;padding-top:16px;border-top:1px solid var(--bdr-l)}
.question-nav button{width:36px;height:36px;border:1px solid var(--bdr);border-radius:var(--r-s);background:var(--bg);color:var(--t3);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}
.question-nav button.cur{background:var(--pri);color:#fff;border-color:var(--pri)}
.question-nav button.ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok)}
.question-nav button.bad{background:var(--err-bg);color:var(--err);border-color:var(--err)}
.question-nav button.ans{background:var(--sec-l);color:var(--sec);border-color:var(--sec)}

/* Tool form */
.tool-form{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-l);padding:24px}
.tool-form label{display:block;font-size:12.5px;font-weight:600;color:var(--t2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}
.tool-form input,.tool-form select,.tool-form textarea{width:100%;padding:11px 14px;border:1px solid var(--bdr);border-radius:var(--r-s);font-size:14px;background:var(--bg);outline:none;transition:border .15s;margin-bottom:14px}
.tool-form input:focus,.tool-form select:focus,.tool-form textarea:focus{border-color:var(--sec)}
.tool-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.tool-form .form-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tool-form .form-row label{grid-column:span 1}
.tool-form button[type=submit]{padding:12px 24px;background:var(--pri);color:#fff;border-radius:var(--r-s);font-weight:600;font-size:14px;cursor:pointer;transition:background .15s}.tool-form button[type=submit]:hover{background:var(--pri-l)}

/* Callout */
.callout{background:var(--sec-l);border-left:3px solid var(--sec);padding:14px 18px;border-radius:var(--r-s);margin:14px 0;color:var(--t2);font-size:14px}
.callout.warn{background:var(--warn-bg);border-color:var(--warn);color:var(--warn)}
.callout.acc{background:var(--acc-l);border-color:var(--acc);color:var(--acc)}
.callout.ok{background:var(--ok-bg);border-color:var(--ok);color:var(--ok)}
.callout strong{display:block;margin-bottom:3px;color:inherit;font-weight:700}

/* FAQ accordion */
.faq{display:flex;flex-direction:column;gap:8px}
.faq details{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:14px 18px;transition:border .15s}
.faq details[open]{border-color:var(--sec)}
.faq summary{font-size:14.5px;font-weight:600;color:var(--t1);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:20px;color:var(--t3);transition:transform .2s}
.faq details[open] summary::after{content:'\2212'}
.faq details > div{padding-top:10px;color:var(--t2);font-size:14px;line-height:1.65}

/* Subject combination card */
.subject-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}
.subject-card{background:var(--bg);border:2px solid var(--bdr);border-radius:var(--r-m);padding:14px;text-align:center}
.subject-card.req{border-color:var(--acc);background:var(--acc-l)}
.subject-card-number{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:4px}
.subject-card-name{font-family:var(--ff-d);font-size:16px;color:var(--pri);font-weight:600;line-height:1.2}
.subject-card.req .subject-card-name{color:var(--acc)}

/* Empty state */
.empty-state{padding:60px 24px;text-align:center;background:var(--bg);border:1px dashed var(--bdr);border-radius:var(--r-m)}
.empty-icon{font-size:46px;margin-bottom:12px}
.empty-state h3{font-family:var(--ff-d);font-size:20px;color:var(--pri);margin-bottom:6px}
.empty-state p{font-size:14px;color:var(--t3);max-width:420px;margin:0 auto}

/* Score summary */
.score-circle{width:140px;height:140px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column;margin:0 auto 20px;border:6px solid var(--bg2)}
.score-circle.ok{border-color:var(--ok)}
.score-circle.warn{border-color:var(--warn)}
.score-circle.bad{border-color:var(--err)}
.score-circle .score-n{font-family:var(--ff-d);font-size:34px;font-weight:700;color:var(--pri);line-height:1}
.score-circle .score-l{font-size:12px;color:var(--t3);margin-top:2px}

/* Tools home grid */
.tools-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:16px 0}
.tools-meta{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r-m);padding:14px;font-size:13.5px;color:var(--t2)}
.tools-meta strong{color:var(--t1);display:block;margin-bottom:3px}

/* === RESPONSIVE === */
@media(max-width:1100px){
  .site-header-actions .main-nav{display:none}.site-header-actions .hamburger{display:flex}.site-header-actions .btn-header-cta{display:none}
  .hero h1{font-size:28px}.hero-stats{width:240px}
  .tile-grid{grid-template-columns:repeat(3,1fr)}
  .ranking-grid{grid-template-columns:1fr 1fr}.ranking-grid>:nth-child(3){grid-column:span 2}
  .cta-banner{flex-direction:column;text-align:center;padding:28px 24px}.cta-banner-actions{justify-content:center}
  .footer-grid{grid-template-columns:repeat(3,1fr)}.footer-brand{grid-column:span 3}
  .trio-grid{grid-template-columns:1fr 1fr}.trio-grid>:nth-child(3){grid-column:span 2}
  .two-col{grid-template-columns:1fr}.sidebar{position:static}.side-card{position:static}
  .card-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .hero-row{flex-direction:column;gap:24px}.hero-stats{width:100%;grid-template-columns:repeat(4,1fr)}
  .duo-grid{grid-template-columns:1fr}.tools-grid{grid-template-columns:1fr 1fr}.cutoff-grid{grid-template-columns:1fr}
  .scholarship-grid{grid-template-columns:1fr 1fr}.scholarship-grid>:nth-child(3){grid-column:span 2}
  .updates-grid{grid-template-columns:1fr 1fr}
  .newsletter-box{flex-direction:column;text-align:center}.newsletter-form{width:100%;max-width:380px}.newsletter-form input{flex:1;width:auto}
  .trio-grid{grid-template-columns:1fr}
  .trio-grid>:nth-child(3){grid-column:auto}
  .profile-stats{grid-template-columns:repeat(2,1fr)}
  .subject-row{grid-template-columns:repeat(2,1fr)}
  .tool-form .form-row,.tool-form .form-row-3{grid-template-columns:1fr}
}
@media(max-width:640px){
  :root{--hdr:52px}.container{padding:0 16px}.section-title{font-size:21px}
  .hero{padding:28px 0 24px}.hero h1{font-size:24px}.hero-text{font-size:14px}
  .hero-search input{padding:12px 14px 12px 38px;font-size:14px}.hero-search-btn{display:none}.hero-search input{padding-right:14px}
  .hero-stats{grid-template-columns:1fr 1fr}.stat-card-num{font-size:20px}
  .tile-grid{grid-template-columns:repeat(3,1fr);gap:8px}.tile{padding:12px 8px}.tile-icon{width:36px;height:36px;font-size:16px;margin-bottom:6px}.tile h3{font-size:11.5px}.tile p{font-size:10px}
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{min-width:560px}
  .tools-grid{grid-template-columns:1fr}.ranking-grid{grid-template-columns:1fr}.ranking-grid>:nth-child(3){grid-column:auto}
  .scholarship-grid{grid-template-columns:1fr}.scholarship-grid>:nth-child(3){grid-column:auto}
  .updates-grid{grid-template-columns:1fr}
  .cta-banner{padding:24px 18px}.cta-banner h2{font-size:20px}.cta-banner-actions{flex-direction:column;width:100%}.cta-banner-actions a{text-align:center}
  .section-head{flex-direction:column;align-items:flex-start;gap:3px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:20px}.footer-brand{grid-column:span 2}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .newsletter-box{padding:24px 18px}.newsletter-box h3{font-size:18px}.newsletter-form{flex-direction:column}.newsletter-form input{width:100%}
  .course-tag-group{gap:6px}.course-tag{padding:8px 12px;font-size:12px}
  .page-header h1{font-size:24px}.profile-header h1{font-size:26px}
  .card-grid{grid-template-columns:1fr}
  .tools-meta-grid{grid-template-columns:1fr}
}
@media(max-width:420px){
  .hero h1{font-size:21px}.tile-grid{grid-template-columns:repeat(2,1fr)}
  .hero-tags{gap:3px}.hero-tags a{font-size:10.5px;padding:2px 7px}
  .ticker-inner{flex-direction:column;gap:4px;font-size:12px;text-align:center}.ticker a{margin-left:0}
  .profile-stats{grid-template-columns:1fr 1fr}
  .subject-row{grid-template-columns:1fr 1fr}
}
@media(max-width:340px){.container{padding:0 12px}.hero h1{font-size:19px}.stat-card{padding:10px 6px}.stat-card-num{font-size:18px}.stat-card-label{font-size:10px}}
