/* ============================================================
   ACADEMYBRIDGE — stylesheet
   Navy/gold academic theme, light by default
   ============================================================ */

:root{
  --navy:        #1a2a4f;
  --navy-deep:   #0e1a35;
  --navy-soft:   #2a3a5f;
  --gold:        #c08a3e;
  --gold-light:  #e2b769;
  --gold-pale:   #f5ebd3;
  --cream:       #fbf8f1;
  --bg:          #f7f6ef;
  --panel:       #ffffff;
  --text:        #14213d;
  --muted:       #5a6780;
  --line:        #e1e5ee;
  --line-soft:   #eef1f7;
  --danger:      #c0392b;
  --success:     #2f7d52;
  --shadow-sm:   0 2px 6px rgba(20, 33, 61, 0.06);
  --shadow:      0 10px 30px rgba(20, 33, 61, 0.10);
  --shadow-lg:   0 24px 60px rgba(20, 33, 61, 0.16);
  --radius:      18px;
  --radius-sm:   10px;
}
body.dark{
  --bg:          #0d162d;
  --panel:       #152039;
  --cream:       #152039;
  --text:        #eaeefb;
  --muted:       #9eadc8;
  --line:        #233153;
  --line-soft:   #1d294a;
  --gold-pale:   #2a2416;
  --shadow-sm:   0 2px 6px rgba(0,0,0,.35);
  --shadow:      0 10px 30px rgba(0,0,0,.45);
  --shadow-lg:   0 24px 60px rgba(0,0,0,.55);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.container{width:min(1200px, calc(100% - 28px)); margin:0 auto}
h1,h2,h3,h4{font-family:"Playfair Display",Georgia,"Times New Roman",serif; line-height:1.2; margin:0; color:var(--text); letter-spacing:-0.01em}
h1{font-size:clamp(2rem, 4.5vw, 3.6rem); font-weight:800}
h2{font-size:clamp(1.65rem, 2.8vw, 2.5rem); font-weight:700}
h3{font-size:1.25rem; font-weight:700}
p{margin:0 0 1em}

/* ---------- TOPBAR / NAV ---------- */
.topbar{
  position:sticky; top:0; z-index:60;
  background:var(--panel);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(10px);
}
.nav{
  display:flex; align-items:center; gap:18px;
  min-height:72px;
  justify-content:space-between;
}
.brand{display:inline-flex; align-items:center}
.brand-logo{height:44px; width:auto; display:block}
.nav-links{display:flex; gap:6px; flex-wrap:wrap; align-items:center}
.nav-links a{
  padding:10px 14px; border-radius:10px;
  font-weight:600; font-size:.95rem; color:var(--text);
  transition:background .15s ease, color .15s ease;
}
.nav-links a:hover{background:var(--gold-pale); color:var(--navy)}
body.dark .nav-links a:hover{background:rgba(192,138,62,.18); color:var(--gold-light)}
.nav-actions{display:flex; gap:10px; align-items:center}

.menu-toggle{
  display:none; background:transparent; border:1px solid var(--line);
  padding:8px 12px; border-radius:10px; cursor:pointer; font:inherit; font-weight:700;
  color:var(--text);
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 20px; border-radius:12px; font-weight:700; cursor:pointer;
  border:1px solid transparent; font-size:.95rem;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--navy); color:#fff}
.btn-primary:hover{background:var(--navy-deep); box-shadow:var(--shadow-sm)}
.btn-gold{background:var(--gold); color:#fff}
.btn-gold:hover{background:#a87730; box-shadow:var(--shadow-sm)}
.btn-outline{background:transparent; border-color:var(--line); color:var(--text)}
.btn-outline:hover{border-color:var(--navy); color:var(--navy)}
body.dark .btn-outline:hover{border-color:var(--gold); color:var(--gold-light)}
.btn-ghost{background:transparent; color:var(--text)}
.btn-ghost:hover{background:var(--line-soft)}
.btn-sm{padding:9px 14px; font-size:.88rem}
.btn-lg{padding:16px 28px; font-size:1.05rem}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding:48px 0 60px;
  background:
    radial-gradient(ellipse at top right, rgba(192,138,62,.10), transparent 45%),
    radial-gradient(ellipse at bottom left, rgba(26,42,79,.08), transparent 45%),
    var(--cream);
  border-bottom:1px solid var(--line);
}
.hero-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:40px; align-items:center}
.hero-copy .eyebrow{color:var(--gold); letter-spacing:.18em; text-transform:uppercase; font-weight:800; font-size:.78rem; margin-bottom:14px; display:inline-block}
.hero-copy h1{margin-bottom:18px}
.hero-copy h1 .accent{color:var(--gold); font-style:italic}
.hero-copy .lead{font-size:1.1rem; color:var(--muted); max-width:58ch; margin-bottom:28px}
.hero-actions{display:flex; flex-wrap:wrap; gap:12px; margin-bottom:34px}
.hero-trust{display:flex; gap:24px; flex-wrap:wrap; color:var(--muted); font-size:.9rem}
.hero-trust strong{color:var(--text); display:block; font-size:1.25rem; font-family:"Playfair Display",serif}
.hero-visual{
  position:relative; display:grid; place-items:center;
  padding:30px;
  background:var(--panel); border:1px solid var(--line); border-radius:24px;
  box-shadow:var(--shadow-lg);
}
.hero-visual::before{
  content:""; position:absolute; inset:-2px; z-index:-1;
  background:linear-gradient(135deg, var(--gold), var(--navy));
  border-radius:26px; opacity:.15; filter:blur(20px);
}
.hero-visual img{max-width:100%; height:auto}

/* ---------- QUICK ACCESS TILES ---------- */
.quick-tiles{display:grid; grid-template-columns:repeat(4, 1fr); gap:16px; margin-top:30px}
.quick-tile{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:22px; display:block; color:var(--text);
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  position:relative;
}
.quick-tile:hover{transform:translateY(-3px); border-color:var(--gold); box-shadow:var(--shadow)}
.quick-tile .tile-icon{
  width:48px; height:48px; border-radius:12px;
  background:var(--gold-pale); color:var(--gold);
  display:grid; place-items:center; font-size:1.5rem; margin-bottom:14px;
}
.quick-tile h3{font-size:1.1rem; margin-bottom:6px}
.quick-tile p{color:var(--muted); font-size:.9rem; margin:0}
.quick-tile .arrow{position:absolute; top:22px; right:22px; color:var(--muted); font-size:1.1rem}

/* ---------- SECTIONS ---------- */
.section{padding:60px 0}
.section-alt{background:var(--panel); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-head{margin-bottom:36px; max-width:720px}
.section-head .eyebrow{color:var(--gold); letter-spacing:.18em; text-transform:uppercase; font-weight:800; font-size:.78rem; margin-bottom:10px; display:inline-block}
.section-head p{color:var(--muted); font-size:1.05rem; margin-top:10px}
.section-head-row{display:flex; justify-content:space-between; align-items:flex-end; gap:20px; margin-bottom:30px; flex-wrap:wrap}
.divider-line{
  height:3px; width:60px; background:var(--gold); margin-bottom:16px; border-radius:2px;
}

/* ---------- CARDS ---------- */
.card{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:22px; box-shadow:var(--shadow-sm);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.card-hover:hover{transform:translateY(-2px); box-shadow:var(--shadow); border-color:#d3d9e6}

/* university cards */
.uni-grid{display:grid; grid-template-columns:repeat(auto-fill, minmax(300px, 1fr)); gap:20px}
.uni-card{display:flex; flex-direction:column; gap:12px}
.uni-card-top{display:flex; justify-content:space-between; align-items:flex-start; gap:12px}
.uni-flag{font-size:1.6rem; line-height:1}
.uni-card h3{font-size:1.15rem; font-family:"Playfair Display",serif; color:var(--navy)}
body.dark .uni-card h3{color:var(--gold-light)}
.uni-meta{display:flex; flex-wrap:wrap; gap:6px; margin:4px 0}
.uni-rank{
  display:inline-flex; align-items:center; gap:4px;
  background:var(--gold-pale); color:var(--gold);
  padding:4px 10px; border-radius:999px; font-size:.75rem; font-weight:800;
}
.uni-tag{
  display:inline-flex; background:var(--line-soft); color:var(--muted);
  padding:4px 10px; border-radius:999px; font-size:.75rem; font-weight:600;
}
.uni-stats{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:6px}
.uni-stat{background:var(--line-soft); border-radius:10px; padding:10px 12px}
.uni-stat .label{font-size:.7rem; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; font-weight:700}
.uni-stat .value{font-weight:800; color:var(--text); font-size:.95rem; margin-top:2px}
.uni-actions{margin-top:auto; display:flex; gap:8px; padding-top:10px}

/* scholarship cards */
.schol-grid{display:grid; grid-template-columns:repeat(auto-fill, minmax(300px, 1fr)); gap:20px}
.schol-card{display:flex; flex-direction:column; gap:10px; position:relative}
.schol-award{
  display:inline-flex; align-self:flex-start; align-items:center; gap:6px;
  background:var(--navy); color:#fff; padding:6px 12px; border-radius:999px;
  font-size:.78rem; font-weight:800;
}
.schol-card h3{font-size:1.1rem; font-family:"Playfair Display",serif}
.schol-card .schol-note{color:var(--muted); font-size:.92rem; flex:1}
.schol-meta{display:flex; flex-wrap:wrap; gap:6px; margin-top:6px}
.schol-deadline{
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 12px; background:var(--line-soft); border-radius:10px; font-size:.85rem;
}
.schol-deadline strong{color:var(--navy)}
body.dark .schol-deadline strong{color:var(--gold-light)}
.schol-actions{margin-top:auto; display:flex; gap:8px; padding-top:8px}

/* ---------- FILTER BAR ---------- */
.filter-bar{
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:12px;
  padding:18px; background:var(--panel); border:1px solid var(--line);
  border-radius:var(--radius); margin-bottom:26px; box-shadow:var(--shadow-sm);
}
.filter-bar.cols-3{grid-template-columns:2fr 1fr 1fr}
.input-with-icon{
  position:relative; display:flex; align-items:center;
  background:var(--bg); border:1px solid var(--line); border-radius:10px;
  padding:0 14px;
}
.input-with-icon span{color:var(--muted); margin-right:8px}
.input-with-icon input{
  flex:1; background:transparent; border:none; outline:none; color:var(--text);
  padding:12px 0; font:inherit;
}
.select-box{
  background:var(--bg); border:1px solid var(--line); border-radius:10px;
  padding:12px 14px; font:inherit; color:var(--text); cursor:pointer; outline:none;
}
.select-box:focus{border-color:var(--gold)}
.filter-stats{margin-bottom:16px; color:var(--muted); font-size:.9rem}
.filter-stats strong{color:var(--text)}

/* ---------- FORMS ---------- */
.form-grid{display:grid; gap:16px}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.form-field label{font-weight:700; font-size:.9rem; margin-bottom:6px; display:block; color:var(--text)}
.form-field small{color:var(--muted); font-size:.82rem; font-weight:500; margin-left:6px}
.form-field input, .form-field select, .form-field textarea{
  width:100%; background:var(--bg); color:var(--text);
  border:1px solid var(--line); border-radius:10px;
  padding:12px 14px; font:inherit; outline:none;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus{
  border-color:var(--gold); box-shadow:0 0 0 3px rgba(192,138,62,.15);
}
.form-field textarea{min-height:120px; resize:vertical; font-family:inherit}
.form-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:6px}
.form-note{font-size:.85rem; color:var(--muted); background:var(--gold-pale); padding:12px 14px; border-radius:10px; border-left:3px solid var(--gold)}
body.dark .form-note{background:rgba(192,138,62,.1)}

/* ---------- CHECKLISTS ---------- */
.checklist{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.checklist li{
  display:flex; gap:12px; align-items:flex-start;
  padding:14px 16px; background:var(--panel); border:1px solid var(--line);
  border-radius:12px;
}
.check-icon{
  flex-shrink:0; width:24px; height:24px; border-radius:50%;
  background:var(--gold-pale); color:var(--gold);
  display:grid; place-items:center; font-weight:800; font-size:.85rem;
}
.checklist li strong{display:block; color:var(--text)}
.checklist li span{color:var(--muted); font-size:.92rem}

/* ---------- STEPS ---------- */
.steps{display:grid; grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)); gap:20px}
.step-card{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:24px; position:relative;
}
.step-number{
  position:absolute; top:-14px; left:22px;
  background:var(--gold); color:#fff;
  width:36px; height:36px; border-radius:50%;
  display:grid; place-items:center; font-weight:800;
  box-shadow:var(--shadow-sm);
  font-family:"Playfair Display",serif;
}
.step-card h3{margin:10px 0 8px; color:var(--navy)}
body.dark .step-card h3{color:var(--gold-light)}
.step-card p{color:var(--muted); margin:0; font-size:.95rem}

/* ---------- AI ADVISOR ---------- */
.ai-layout{display:grid; grid-template-columns:minmax(0, 2fr) minmax(0, 3fr); gap:28px}
.ai-form-panel{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:28px; box-shadow:var(--shadow-sm);
  position:sticky; top:90px; align-self:flex-start;
}
.ai-results-panel{min-height:400px}
.ai-results-empty{
  padding:50px 30px; text-align:center; color:var(--muted);
  background:var(--panel); border:2px dashed var(--line); border-radius:var(--radius);
}
.ai-results-empty .big-icon{font-size:3rem; margin-bottom:14px; display:block}
.match-card{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:20px; margin-bottom:16px; box-shadow:var(--shadow-sm);
  display:grid; grid-template-columns:auto 1fr auto; gap:18px; align-items:center;
}
.match-score{
  text-align:center; padding:10px 14px;
  background:var(--gold-pale); border-radius:14px;
  min-width:90px;
}
.match-score .pct{font-size:1.8rem; font-weight:800; color:var(--gold); font-family:"Playfair Display",serif; line-height:1}
.match-score .lbl{font-size:.7rem; color:var(--muted); text-transform:uppercase; font-weight:700; letter-spacing:.06em; margin-top:4px}
.match-body h3{color:var(--navy); font-size:1.1rem; margin-bottom:4px}
body.dark .match-body h3{color:var(--gold-light)}
.match-body .match-meta{color:var(--muted); font-size:.9rem; margin-bottom:6px}
.match-reasons{display:flex; flex-wrap:wrap; gap:6px; margin-top:6px}
.match-reason{
  display:inline-flex; padding:4px 10px;
  background:var(--line-soft); color:var(--text);
  border-radius:999px; font-size:.75rem; font-weight:600;
}
.match-reason.pos{background:rgba(47,125,82,.12); color:var(--success)}
.match-reason.warn{background:rgba(192,57,43,.1); color:var(--danger)}
.match-actions{display:flex; flex-direction:column; gap:8px}
.ai-disclaimer{
  background:var(--gold-pale); border-left:3px solid var(--gold); padding:14px 16px;
  border-radius:10px; font-size:.88rem; color:var(--text); margin-bottom:20px;
}
body.dark .ai-disclaimer{background:rgba(192,138,62,.1)}

/* ---------- DONATE ---------- */
.donate-panel{
  max-width:640px; margin:0 auto;
  background:var(--panel); border:1px solid var(--line); border-radius:24px;
  padding:40px 34px; box-shadow:var(--shadow-lg);
}
.donate-panel h1{text-align:center}
.donate-tabs{
  display:grid; grid-template-columns:1fr 1fr; gap:6px;
  background:var(--line-soft); padding:6px; border-radius:999px; margin:24px 0;
}
.donate-tab{
  border:none; background:transparent; padding:14px; border-radius:999px;
  font:inherit; font-weight:700; cursor:pointer; color:var(--text);
}
.donate-tab.active{background:var(--navy); color:#fff; box-shadow:var(--shadow-sm)}
.amount-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:10px; margin:18px 0}
.amount-btn{
  padding:18px 12px; border-radius:12px; background:var(--line-soft);
  color:var(--text); border:2px solid transparent; font:inherit;
  font-weight:800; font-size:1.15rem; cursor:pointer;
}
.amount-btn.active{background:var(--navy); color:#fff; border-color:var(--navy)}
.donate-summary{
  display:flex; justify-content:space-between; align-items:center;
  padding:18px; background:var(--line-soft); border-radius:12px; margin:18px 0;
}
.donate-summary strong{font-size:1.3rem; font-family:"Playfair Display",serif}
.donate-cta{
  display:flex; align-items:center; justify-content:center;
  width:100%; padding:20px; border-radius:14px;
  background:var(--navy); color:#fff; font-weight:800; font-size:1.1rem;
  margin-top:8px;
}
.donate-cta:hover{background:var(--navy-deep)}

/* ---------- ADMIN ---------- */
.admin-tabs{display:flex; gap:6px; border-bottom:1px solid var(--line); margin-bottom:26px; flex-wrap:wrap}
.admin-tab{
  padding:12px 18px; background:transparent; border:none;
  border-bottom:3px solid transparent; font:inherit; font-weight:700;
  color:var(--muted); cursor:pointer; margin-bottom:-1px;
}
.admin-tab.active{color:var(--navy); border-bottom-color:var(--gold)}
body.dark .admin-tab.active{color:var(--gold-light)}
.admin-table{
  width:100%; border-collapse:collapse; background:var(--panel);
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
}
.admin-table th, .admin-table td{
  padding:12px 14px; text-align:left; font-size:.92rem;
  border-bottom:1px solid var(--line);
}
.admin-table th{background:var(--line-soft); font-weight:700; color:var(--text)}
.admin-table tr:last-child td{border-bottom:none}
.admin-table .row-actions{display:flex; gap:6px}
.admin-banner{
  background:var(--gold-pale); border-left:4px solid var(--gold); padding:16px 18px;
  border-radius:10px; margin-bottom:22px;
}
body.dark .admin-banner{background:rgba(192,138,62,.12)}

/* ---------- FOOTER ---------- */
.site-footer{
  background:var(--navy-deep); color:#eaeefb; margin-top:60px;
  padding:50px 0 24px;
}
.footer-grid{display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:30px; margin-bottom:30px}
.footer-brand img{height:56px; filter:brightness(0) invert(1) opacity(.9); margin-bottom:14px}
.footer-brand p{color:#a8b5d5; font-size:.92rem; max-width:30ch}
.footer-col h4{color:#fff; font-size:.95rem; font-family:"Inter",sans-serif; font-weight:800; text-transform:uppercase; letter-spacing:.1em; margin-bottom:14px}
.footer-col ul{list-style:none; padding:0; margin:0}
.footer-col li{margin-bottom:10px}
.footer-col a{color:#a8b5d5; font-size:.92rem}
.footer-col a:hover{color:var(--gold-light)}
.footer-bottom{
  padding-top:22px; border-top:1px solid rgba(255,255,255,.1);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  color:#8898b8; font-size:.85rem;
}
.footer-bottom a{color:#a8b5d5}

/* ---------- UTILITY ---------- */
.hidden{display:none !important}
.text-center{text-align:center}
.mb-0{margin-bottom:0}
.mt-0{margin-top:0}
.stack{display:grid; gap:16px}
.inline-chips{display:flex; flex-wrap:wrap; gap:8px}
.chip{
  display:inline-flex; padding:6px 12px; border-radius:999px;
  background:var(--line-soft); color:var(--text); font-size:.78rem; font-weight:700;
}
.chip.gold{background:var(--gold-pale); color:var(--gold)}
.chip.navy{background:var(--navy); color:#fff}
.empty-state{
  padding:40px 30px; text-align:center;
  background:var(--panel); border:2px dashed var(--line); border-radius:var(--radius);
  color:var(--muted);
}
.prose p{color:var(--muted); line-height:1.75}
.prose h3{color:var(--navy); margin:24px 0 10px}
body.dark .prose h3{color:var(--gold-light)}
.prose ul{padding-left:22px; color:var(--muted); line-height:1.8}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1000px){
  .hero-grid{grid-template-columns:1fr; gap:28px}
  .quick-tiles{grid-template-columns:repeat(2, 1fr)}
  .filter-bar{grid-template-columns:1fr 1fr; gap:10px}
  .filter-bar.cols-3{grid-template-columns:1fr 1fr}
  .filter-bar .input-with-icon{grid-column:1 / -1}
  .ai-layout{grid-template-columns:1fr}
  .ai-form-panel{position:static}
  .footer-grid{grid-template-columns:1fr 1fr; gap:24px}
}
@media (max-width: 720px){
  .nav-links{display:none}
  .nav-links.open{
    display:flex; flex-direction:column; align-items:stretch;
    position:absolute; left:0; right:0; top:72px;
    background:var(--panel); border-bottom:1px solid var(--line);
    padding:14px; gap:4px;
    box-shadow:var(--shadow);
  }
  .nav-links.open a{padding:12px 14px}
  .menu-toggle{display:inline-flex}
  .topbar{position:relative}
  .hero{padding:32px 0 40px}
  .quick-tiles{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .match-card{grid-template-columns:1fr; text-align:left}
  .match-score{justify-self:start}
  .match-actions{flex-direction:row; flex-wrap:wrap}
  .amount-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .admin-table{font-size:.82rem}
  .admin-table th:nth-child(n+4),
  .admin-table td:nth-child(n+4){display:none}
}


/* --- V3 additions --- */
.filter-bar.cols-4{grid-template-columns:2fr repeat(3, minmax(0,1fr))}
.directory-stats{display:flex; gap:12px; flex-wrap:wrap; margin:16px 0 20px}
.stat-pill{background:var(--panel); border:1px solid var(--line); border-radius:999px; padding:10px 14px; font-weight:700; box-shadow:var(--shadow-sm)}
.uni-chip-row,.school-chip-row{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px}
.uni-tag,.school-tag{display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; background:var(--gold-pale); color:var(--navy); font-size:.82rem; font-weight:700}
.directory-grid{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:18px}
.school-card .school-top,.uni-card .uni-card-top{display:flex; justify-content:space-between; gap:14px; align-items:flex-start}
.school-card h3,.uni-card h3{margin:10px 0 8px}
.school-meta,.uni-meta{display:flex; gap:8px; flex-wrap:wrap; color:var(--muted); font-size:.9rem}
.school-badge,.uni-rank{display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; background:var(--line-soft); font-weight:700; color:var(--navy)}
.school-type{display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; background:rgba(192,138,62,.14); color:var(--navy); font-weight:700}
.school-summary,.uni-summary{color:var(--muted); margin-top:12px}
.school-actions,.uni-actions{display:flex; gap:10px; flex-wrap:wrap; margin-top:18px}
.directory-note{background:var(--panel); border:1px solid var(--line); border-left:4px solid var(--gold); border-radius:16px; padding:18px 20px; color:var(--muted); margin:16px 0 22px}
.kpi-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:28px}
.kpi-card{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow-sm)}
.kpi-card strong{display:block; font-size:1.8rem; font-family:"Playfair Display",serif; color:var(--navy)}
.section-mini{font-size:.95rem; color:var(--muted)}
.list-compact{margin:0; padding-left:18px}
.list-compact li{margin:0 0 8px}
@media (max-width: 1024px){
  .directory-grid,.kpi-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .filter-bar.cols-4{grid-template-columns:1fr 1fr}
}
@media (max-width: 700px){
  .directory-grid,.kpi-grid,.filter-bar.cols-4{grid-template-columns:1fr}
}


/* --- V4 additions --- */
.upload-callout{
  background:var(--gold-pale);
  border:1px solid rgba(192,138,62,.35);
  color:var(--text);
  border-radius:16px;
  padding:16px 18px;
  margin:16px 0 22px;
}
.load-more-wrap{text-align:center; margin-top:24px}


/* ---------- V6 resource hubs ---------- */
.resource-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:20px;
}
.resource-two-col{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:24px;
}
.resource-card{padding:28px}
.resource-head{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin-bottom:18px;
}
.muted-tight{
  color:var(--muted);
  margin:.35rem 0 0;
}
.small-muted{
  color:var(--muted);
  font-size:.85rem;
  margin:.15rem 0 .35rem;
}
.resource-list{
  margin:0;
  padding:0;
  list-style:none;
}
.resource-list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:14px 0;
  border-bottom:1px solid var(--line-soft);
}
.resource-list li:last-child{border-bottom:none}
.resource-list li div{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.resource-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.text-link{
  display:inline-flex;
  margin-top:8px;
  color:var(--navy);
  font-weight:700;
}
body.dark .text-link{color:var(--gold-light)}
.transport-list{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:16px;
}
.transport-item{
  display:flex;
  gap:14px;
  justify-content:space-between;
  align-items:flex-start;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--panel);
}
.school-card .btn,
.transport-item .btn{flex-shrink:0}
.is-disabled-link{
  opacity:.6;
  pointer-events:none;
}
@media (max-width: 900px){
  .resource-grid,
  .resource-two-col{
    grid-template-columns:1fr;
  }
  .transport-item{
    flex-direction:column;
  }
}
