/*
 * ScholarWizard – Expedia-inspired clean design
 * Light-first · Mobile-first · Dark mode supported
 */

/* ── Variables ─────────────────────────────────────────────── */
:root {
  /* Brand */
  --blue-deep:   #003580;
  --blue-mid:    #0071C2;
  --blue-light:  #E8F1FB;
  --orange:      #FF6900;
  --orange-lt:   #FFF4EE;
  --green:       #008009;
  --green-lt:    #EAF7EA;
  --yellow:      #FFC72C;

  /* Surfaces */
  --bg-body:     #F2F5FA;
  --bg-surface:  #FFFFFF;
  --bg-card:     #FFFFFF;
  --bg-input:    #FFFFFF;
  --border:      #DCDFE8;
  --border-dark: #B2B8CC;

  /* Text */
  --txt:         #1A2340;
  --txt-secondary:#4A5568;
  --txt-muted:   #718096;
  --txt-light:   #A0AEC0;

  /* Shadows */
  --shadow-sm:   0 1px 4px rgba(0,0,0,0.08);
  --shadow:      0 2px 12px rgba(0,0,0,0.10);
  --shadow-lg:   0 4px 24px rgba(0,0,0,0.13);

  /* Misc */
  --radius-sm:   6px;
  --radius:      10px;
  --radius-lg:   14px;
  --radius-pill: 99px;
  --transition:  all 0.2s ease;
  --nav-h:       64px;
}

/* Dark mode overrides */
html[data-bs-theme="dark"] {
  --bg-body:     #0E1521;
  --bg-surface:  #162033;
  --bg-card:     #1C2A44;
  --bg-input:    #1C2A44;
  --border:      rgba(255,255,255,0.09);
  --border-dark: rgba(255,255,255,0.18);
  --txt:         #E8EDF5;
  --txt-secondary:#B0BAD0;
  --txt-muted:   #7D8FA8;
  --txt-light:   #506070;
  --shadow-sm:   0 1px 4px rgba(0,0,0,0.3);
  --shadow:      0 2px 16px rgba(0,0,0,0.4);
  --shadow-lg:   0 6px 32px rgba(0,0,0,0.5);
  --blue-light:  rgba(0,113,194,0.15);
  --orange-lt:   rgba(255,105,0,0.12);
  --green-lt:    rgba(0,128,9,0.12);
}

/* ── Reset & Base ──────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:1rem;
  line-height:1.6;
  background:var(--bg-body);
  color:var(--txt);
  overflow-x:hidden;
  min-height:100vh;
  transition:background .25s,color .25s;
}
img{max-width:100%;display:block;}
a{color:var(--blue-mid);text-decoration:none;}
a:hover{color:var(--blue-deep);text-decoration:underline;}

/* ── Scrollbar ─────────────────────────────────────────────── */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--bg-body);}
::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:99px;}

/* ── Scholarship Ticker ────────────────────────────────────── */
.scholarship-ticker{
  background:var(--blue-deep);
  overflow:hidden;
  position:fixed;
  top:var(--nav-h);
  left:0;right:0;
  z-index:1000;
  height:30px;
  display:flex;
  align-items:center;
}
.ticker-track{
  display:flex;
  gap:2rem;
  white-space:nowrap;
  animation:ticker-scroll 50s linear infinite;
  width:max-content;
}
.ticker-track:hover{animation-play-state:paused;}
.ticker-item{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.3px;
  color:rgba(255,255,255,.7);
}
.ticker-item .t-name{color:#fff;}
.ticker-item .t-val{color:var(--yellow);}
.ticker-sep{color:rgba(255,255,255,.3);}

@keyframes ticker-scroll{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

/* ── Navbar ────────────────────────────────────────────────── */
.navbar{
  background:var(--bg-surface);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  height:var(--nav-h);
  position:fixed;
  top:0;left:0;right:0;
  z-index:1050;
  padding:0;
}
.navbar>.container{height:100%;display:flex;align-items:center;}
.navbar-brand{
  font-size:1.35rem;
  font-weight:800;
  color:var(--blue-deep) !important;
  text-decoration:none;
  display:flex;align-items:center;gap:.4rem;
  letter-spacing:-.5px;
  flex-shrink:0;
}
html[data-bs-theme="dark"] .navbar-brand{color:#5B9FE8 !important;}
.brand-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--orange);
  display:inline-block;
  margin-bottom:8px;
}
.nav-link{
  color:var(--txt-secondary) !important;
  font-weight:500;
  font-size:.875rem;
  padding:.45rem .8rem !important;
  border-radius:var(--radius-sm);
  transition:var(--transition);
}
.nav-link:hover,.nav-link.active{
  color:var(--blue-mid) !important;
  background:var(--blue-light);
  text-decoration:none;
}
.nav-cta{
  background:var(--orange) !important;
  color:#fff !important;
  border-radius:var(--radius-pill) !important;
  padding:.45rem 1.2rem !important;
  font-weight:700;
  font-size:.875rem;
}
.nav-cta:hover{
  background:#E05800 !important;
  color:#fff !important;
  text-decoration:none;
  transform:translateY(-1px);
  box-shadow:0 3px 10px rgba(255,105,0,.3);
}

/* Theme toggle */
.theme-toggle-btn{
  width:36px;height:36px;
  border-radius:50%;
  border:1px solid var(--border);
  background:var(--bg-body);
  color:var(--txt-secondary);
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;
  transition:var(--transition);
  cursor:pointer;
  flex-shrink:0;
}
.theme-toggle-btn:hover{
  background:var(--blue-light);
  border-color:var(--blue-mid);
  color:var(--blue-mid);
}

/* ── Spacing ───────────────────────────────────────────────── */
.main-content{padding-top:calc(var(--nav-h) + 30px);}

/* ── Cards ─────────────────────────────────────────────────── */
.card{
  background:var(--bg-card) !important;
  border:1px solid var(--border) !important;
  border-radius:var(--radius) !important;
  box-shadow:var(--shadow) !important;
  transition:box-shadow .2s ease,transform .2s ease;
}
.card:hover{
  box-shadow:var(--shadow-lg) !important;
  transform:translateY(-2px);
}
.card-flat{box-shadow:var(--shadow-sm) !important;overflow:hidden;min-width:0;}
.card-flat:hover{box-shadow:var(--shadow) !important;transform:translateY(-1px);}

/* ── Buttons ───────────────────────────────────────────────── */
.btn{
  border-radius:var(--radius-pill);
  padding:.6rem 1.5rem;
  font-weight:600;
  font-size:.9rem;
  transition:var(--transition);
  min-height:44px;
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  border:none;
}
.btn-primary{
  background:var(--orange);
  color:#fff;
  box-shadow:0 2px 8px rgba(255,105,0,.25);
}
.btn-primary:hover{
  background:#E05800;
  color:#fff;
  box-shadow:0 4px 14px rgba(255,105,0,.35);
  transform:translateY(-1px);
  text-decoration:none;
}
.btn-secondary-brand{
  background:var(--blue-mid);
  color:#fff;
}
.btn-secondary-brand:hover{
  background:var(--blue-deep);
  color:#fff;
  transform:translateY(-1px);
}
.btn-outline-brand{
  border:1.5px solid var(--blue-mid);
  color:var(--blue-mid);
  background:transparent;
}
.btn-outline-brand:hover{
  background:var(--blue-light);
  color:var(--blue-deep);
  border-color:var(--blue-deep);
  text-decoration:none;
}
.btn-outline-secondary{
  border:1.5px solid var(--border-dark);
  color:var(--txt-secondary);
  background:transparent;
}
.btn-outline-secondary:hover{
  background:var(--bg-body);
  color:var(--txt);
  border-color:var(--border-dark);
}
.btn-sm{min-height:36px;padding:.4rem 1rem;font-size:.82rem;}
.btn-lg{min-height:52px;padding:.75rem 2rem;font-size:1rem;}
.btn-xl{min-height:56px;padding:.85rem 2.5rem;font-size:1.05rem;}

/* ── Forms ─────────────────────────────────────────────────── */
.form-control,.form-select{
  background:var(--bg-input) !important;
  border:1.5px solid var(--border) !important;
  border-radius:var(--radius-sm) !important;
  color:var(--txt) !important;
  padding:.65rem 1rem;
  font-size:.95rem;
  min-height:46px;
  transition:border-color .2s,box-shadow .2s;
}
.form-control:focus,.form-select:focus{
  border-color:var(--blue-mid) !important;
  box-shadow:0 0 0 3px rgba(0,113,194,.15) !important;
  outline:none;
}
.form-control::placeholder{color:var(--txt-light);}
.input-group-text{
  background:var(--bg-body) !important;
  border:1.5px solid var(--border) !important;
  border-right:none !important;
  color:var(--txt-muted) !important;
  border-radius:var(--radius-sm) 0 0 var(--radius-sm) !important;
}
.form-label{
  font-weight:600;font-size:.875rem;
  color:var(--txt);margin-bottom:.4rem;display:block;
}
.form-text{color:var(--txt-muted);font-size:.8rem;}

/* ── Option Cards (quiz answers) ───────────────────────────── */
.option-wrap{position:relative;margin-bottom:.5rem;}
.option-wrap input{position:absolute;opacity:0;width:0;height:0;}
.option-card{
  display:block;
  padding:.8rem 1rem .8rem 2.75rem;
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  cursor:pointer;
  color:var(--txt-secondary);
  background:var(--bg-card);
  font-size:.9rem;font-weight:500;
  transition:var(--transition);
  position:relative;
  line-height:1.4;
}
.option-card::before{
  content:'';
  position:absolute;left:1rem;top:50%;
  transform:translateY(-50%);
  width:16px;height:16px;border-radius:50%;
  border:2px solid var(--border-dark);
  background:var(--bg-card);
  transition:var(--transition);
}
.option-card.checkbox-option::before{border-radius:3px;}
.option-card:hover{
  border-color:var(--blue-mid);
  background:var(--blue-light);
  color:var(--blue-deep);
}
input[type="radio"]:checked+.option-card,
input[type="checkbox"]:checked+.option-card{
  border-color:var(--blue-mid);
  background:var(--blue-light);
  color:var(--blue-deep);
  font-weight:600;
}
input[type="radio"]:checked+.option-card::before,
input[type="checkbox"]:checked+.option-card::before{
  background:var(--blue-mid);
  border-color:var(--blue-mid);
  box-shadow:inset 0 0 0 3px #fff;
}

/* ── Progress ──────────────────────────────────────────────── */
.progress{
  background:var(--border);
  border-radius:99px;
  height:6px;
  overflow:hidden;
}
.progress-bar{
  background:var(--blue-mid);
  border-radius:99px;
  transition:width .5s ease;
}

/* ── Badges ────────────────────────────────────────────────── */
.badge{font-weight:600;font-size:.72rem;letter-spacing:.2px;padding:.3em .75em;border-radius:99px;}
.badge-blue{background:var(--blue-light);color:var(--blue-deep);}
.badge-orange{background:var(--orange-lt);color:var(--orange);}
.badge-green{background:var(--green-lt);color:var(--green);}

/* ── Hero ──────────────────────────────────────────────────── */
.hero-section{
  background:var(--blue-deep);
  padding:3.5rem 0 2.5rem;
  position:relative;
  overflow:hidden;
}
.hero-section::after{
  content:'';
  position:absolute;
  bottom:-2px;left:0;right:0;
  height:40px;
  background:var(--bg-body);
  clip-path:ellipse(55% 100% at 50% 100%);
}
html[data-bs-theme="dark"] .hero-section::after{background:var(--bg-body);}
.hero-title{
  font-size:clamp(1.8rem,5vw,2.8rem);
  font-weight:800;
  color:#fff;
  line-height:1.15;
  letter-spacing:-.5px;
  margin-bottom:.75rem;
}
.hero-sub{
  color:rgba(255,255,255,.75);
  font-size:1rem;
  max-width:500px;
  line-height:1.65;
  margin-bottom:1.75rem;
}

/* Hero search box */
.hero-search-box{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:0 4px 24px rgba(0,0,0,.25);
  padding:1.25rem 1.5rem;
  max-width:700px;
}
html[data-bs-theme="dark"] .hero-search-box{
  background:var(--bg-card);
  border:1px solid var(--border);
}
.hero-search-box label{
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.8px;color:var(--txt-muted);margin-bottom:.35rem;
}
.hero-search-box .form-control{
  border:none !important;
  padding:.5rem .75rem;
  font-size:.95rem;
  min-height:40px;
}
.hero-search-box .form-control:focus{box-shadow:none !important;}
.search-divider{width:1px;background:var(--border);align-self:stretch;margin:0 .25rem;}

/* Stat bar */
.stat-bar{
  display:flex;flex-wrap:wrap;
  gap:1.5rem;
  margin-top:1.5rem;
}
.stat-item .stat-num{
  font-size:1.4rem;font-weight:800;color:#fff;line-height:1;
}
.stat-item .stat-label{font-size:.78rem;color:rgba(255,255,255,.6);}

/* ── Section headers ───────────────────────────────────────── */
.section-eyebrow{
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;color:var(--orange);margin-bottom:.35rem;
}
.section-title{
  font-size:1.5rem;font-weight:800;color:var(--txt);
  letter-spacing:-.3px;margin-bottom:.4rem;
}
.section-sub{color:var(--txt-muted);font-size:.925rem;margin-bottom:0;}

/* ── Category chips ────────────────────────────────────────── */
.category-scroll{
  display:flex;gap:.75rem;
  overflow-x:auto;padding-bottom:4px;
  scrollbar-width:none;
}
.category-scroll::-webkit-scrollbar{display:none;}
.cat-chip{
  flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  padding:.9rem 1.25rem;
  background:var(--bg-card);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  cursor:pointer;
  transition:var(--transition);
  text-decoration:none;
}
.cat-chip:hover,.cat-chip.active{
  border-color:var(--blue-mid);
  background:var(--blue-light);
  text-decoration:none;
  box-shadow:var(--shadow);
}
.cat-chip .cat-icon{font-size:1.4rem;line-height:1;}
.cat-chip .cat-label{font-size:.78rem;font-weight:700;color:var(--txt);white-space:nowrap;}
.cat-chip .cat-count{font-size:.68rem;color:var(--txt-muted);}

/* ── Scholarship cards (Expedia hotel style) ───────────────── */
.schol-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  transition:box-shadow .2s,transform .2s;
  display:flex;flex-direction:column;
  height:100%;
  overflow:hidden;
  min-width:0;
}
.schol-card:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-3px);
}
.schol-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column;min-width:0;}
.schol-card-footer{
  padding:.875rem 1.25rem;
  border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  gap:.75rem;flex-wrap:wrap;
}
.schol-amount{
  font-size:1.4rem;font-weight:800;
  color:var(--blue-deep);line-height:1.1;
  word-break:break-word;
}
html[data-bs-theme="dark"] .schol-amount{color:#5B9FE8;}
.schol-name{
  font-size:.975rem;font-weight:700;color:var(--txt);
  margin:.35rem 0 .2rem;line-height:1.3;
  word-break:break-word;overflow-wrap:break-word;
}
.schol-provider{font-size:.8rem;color:var(--txt-muted);word-break:break-word;}
.schol-desc{
  font-size:.82rem;color:var(--txt-secondary);line-height:1.5;
  flex:1;margin:.75rem 0;
  word-break:break-word;overflow-wrap:break-word;
}
.schol-deadline{
  display:flex;align-items:center;gap:.35rem;
  font-size:.75rem;font-weight:600;color:var(--txt-muted);
}
.schol-deadline.urgent{color:#D32F2F;}

/* Match indicator (results page) */
.match-badge{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.3rem .75rem;
  border-radius:99px;
  font-size:.75rem;font-weight:700;
  background:var(--green-lt);
  color:var(--green);
}

/* ── Quiz / Questionnaire ──────────────────────────────────── */
.quiz-shell{min-height:calc(100vh - var(--nav-h) - 30px);}

/* Step progress bar at top */
.quiz-progress-bar-wrap{
  background:var(--bg-surface);
  border-bottom:1px solid var(--border);
  padding:.875rem 0;
  position:sticky;
  top:calc(var(--nav-h) + 30px);
  z-index:90;
}
.quiz-step-label{
  font-size:.75rem;font-weight:700;
  color:var(--txt-muted);
  text-transform:uppercase;letter-spacing:.8px;
}
.quiz-step-title{
  font-size:.95rem;font-weight:700;color:var(--txt);
}

/* Step list (sidebar) */
.step-list{display:flex;flex-direction:column;gap:0;}
.step-list-item{
  display:flex;align-items:center;gap:.75rem;
  padding:.65rem .75rem;
  border-radius:var(--radius-sm);
  border-left:3px solid transparent;
  margin-bottom:2px;
  transition:var(--transition);
}
.step-list-item.done{border-left-color:var(--green);}
.step-list-item.active{border-left-color:var(--blue-mid);background:var(--blue-light);}
.step-number{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:700;
  border:2px solid var(--border-dark);
  color:var(--txt-muted);flex-shrink:0;
  background:var(--bg-card);
  transition:var(--transition);
}
.step-list-item.done .step-number{background:var(--green);border-color:var(--green);color:#fff;}
.step-list-item.active .step-number{background:var(--blue-mid);border-color:var(--blue-mid);color:#fff;}
.step-text{font-size:.85rem;font-weight:600;color:var(--txt-secondary);}
.step-list-item.active .step-text{color:var(--blue-deep);font-weight:700;}
.step-list-item.done .step-text{color:var(--green);}

/* Main question card */
.quiz-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:2rem;
  box-shadow:var(--shadow);
}
.quiz-section-label{
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.8px;color:var(--blue-mid);margin-bottom:.5rem;
}
.quiz-question{
  font-size:clamp(1.05rem,2.5vw,1.25rem);
  font-weight:700;color:var(--txt);
  line-height:1.35;margin-bottom:1.25rem;
}

/* ── Results page ──────────────────────────────────────────── */
.results-banner{
  background:var(--blue-deep);
  padding:2.5rem 0;
}
.results-banner h1{color:#fff;font-weight:800;font-size:clamp(1.5rem,4vw,2.2rem);}
.results-banner p{color:rgba(255,255,255,.75);}
.potential-amount{
  font-size:clamp(2rem,6vw,3.5rem);font-weight:900;color:#fff;
  line-height:1;letter-spacing:-1px;
}
.potential-label{font-size:.8rem;color:rgba(255,255,255,.55);}

/* Sort/filter bar */
.results-toolbar{
  background:var(--bg-surface);
  border-bottom:1px solid var(--border);
  padding:.75rem 0;
  position:sticky;top:calc(var(--nav-h)+30px);z-index:80;
}

/* ── Browse page ───────────────────────────────────────────── */
.browse-banner{
  background:var(--blue-deep);
  padding:2rem 0 3.5rem;
  position:relative;
}
.browse-banner::after{
  content:'';
  position:absolute;
  bottom:-1px;left:0;right:0;
  height:36px;background:var(--bg-body);
  clip-path:ellipse(55% 100% at 50% 100%);
}
html[data-bs-theme="dark"] .browse-banner::after{background:var(--bg-body);}
.browse-search-wrap{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:0 4px 20px rgba(0,0,0,.25);
  padding:.5rem;
  display:flex;align-items:stretch;gap:.5rem;flex-wrap:wrap;
}
html[data-bs-theme="dark"] .browse-search-wrap{background:var(--bg-card);border:1px solid var(--border);}
.browse-search-wrap input{
  flex:1;min-width:180px;
  border:none !important;
  background:transparent !important;
  color:var(--txt) !important;
  padding:.5rem .75rem;font-size:.95rem;min-height:40px;
}
.browse-search-wrap input:focus{box-shadow:none !important;}
.browse-search-wrap select{
  border:none !important;
  border-left:1px solid var(--border) !important;
  background:transparent !important;
  color:var(--txt) !important;
  padding:.4rem .75rem;font-size:.875rem;min-height:40px;
  border-radius:0 !important;
}
.browse-search-wrap .btn{border-radius:var(--radius-sm) !important;min-height:40px;flex-shrink:0;}

/* Filter pills */
.filter-pills{display:flex;gap:.4rem;flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;}
.filter-pills::-webkit-scrollbar{display:none;}
.filter-pill{
  padding:.35rem 1rem;border-radius:99px;
  border:1.5px solid var(--border);
  font-size:.78rem;font-weight:600;
  color:var(--txt-secondary);background:var(--bg-card);
  cursor:pointer;transition:var(--transition);
  white-space:nowrap;display:inline-block;text-decoration:none;
}
.filter-pill:hover{border-color:var(--blue-mid);color:var(--blue-mid);background:var(--blue-light);}
.filter-pill.active{background:var(--blue-mid);border-color:var(--blue-mid);color:#fff;}

/* ── Pagination ────────────────────────────────────────────── */
.page-link{
  background:var(--bg-card) !important;
  border-color:var(--border) !important;
  color:var(--txt) !important;
  border-radius:var(--radius-sm) !important;
  margin:0 2px;min-width:40px;min-height:40px;
  display:flex;align-items:center;justify-content:center;
  font-weight:600;transition:var(--transition);
}
.page-item.active .page-link{
  background:var(--blue-mid) !important;
  border-color:var(--blue-mid) !important;
  color:#fff !important;
}
.page-link:hover{background:var(--blue-light) !important;color:var(--blue-mid) !important;}

/* ── Footer ────────────────────────────────────────────────── */
.footer-modern{
  background:var(--blue-deep);
  color:rgba(255,255,255,.8);
}
.footer-brand{font-size:1.1rem;font-weight:800;color:#fff;}
.footer-tagline{color:rgba(255,255,255,.5);font-size:.875rem;}
.footer-heading{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.35);margin-bottom:.9rem;}
.footer-links{list-style:none;padding:0;margin:0;}
.footer-link{color:rgba(255,255,255,.6);font-size:.875rem;display:block;padding:.25rem 0;transition:color .2s;}
.footer-link:hover{color:#fff;text-decoration:none;}
.social-links{display:flex;gap:.5rem;}
.social-link{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);color:rgba(255,255,255,.65);display:flex;align-items:center;justify-content:center;transition:var(--transition);font-size:.8rem;}
.social-link:hover{background:var(--orange);color:#fff;}
.footer-divider{border-color:rgba(255,255,255,.08);}
.copyright{color:rgba(255,255,255,.3);font-size:.8rem;}

/* ── Alerts ────────────────────────────────────────────────── */
.alert{border-radius:var(--radius-sm);border-width:1px;}
.alert-success{background:var(--green-lt);border-color:rgba(0,128,9,.2);color:#006400;}
.alert-warning{background:#FFF8E1;border-color:#FFD54F;color:#6D4C00;}
.alert-danger{background:#FEF2F2;border-color:#FECACA;color:#991B1B;}
.alert-info{background:var(--blue-light);border-color:rgba(0,113,194,.2);color:var(--blue-deep);}
html[data-bs-theme="dark"] .alert-warning{background:rgba(255,213,79,.1);border-color:rgba(255,213,79,.2);color:#FFD54F;}
html[data-bs-theme="dark"] .alert-success{background:var(--green-lt);color:#4CAF50;}

/* ── Misc helpers ──────────────────────────────────────────── */
.text-orange{color:var(--orange);}
.text-blue{color:var(--blue-mid);}
.bg-blue-lt{background:var(--blue-light);}
.divider{height:1px;background:var(--border);margin:1.5rem 0;}
.empty-state{padding:4rem 1rem;text-align:center;}
.empty-icon{width:72px;height:72px;border-radius:50%;background:var(--bg-body);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 1rem;}

/* ── Advice/timeline ───────────────────────────────────────── */
.advice-title{position:relative;padding-bottom:.5rem;margin-bottom:1.25rem;}
.advice-title::after{content:'';position:absolute;bottom:0;left:0;width:36px;height:3px;background:var(--blue-mid);border-radius:99px;}
.timeline{position:relative;padding-left:1.5rem;}
.timeline::before{content:'';position:absolute;left:0;top:0;height:100%;width:2px;background:var(--border);}
.timeline .card{position:relative;}
.timeline .card::before{content:'';position:absolute;left:-1.85rem;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--blue-mid);}

/* ── Animations ────────────────────────────────────────────── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
.animate-on-scroll{opacity:0;}
.animate-on-scroll.visible{animation:fadeInUp .5s ease forwards;}

/* ── Print ─────────────────────────────────────────────────── */
@media print{
  .navbar,.scholarship-ticker,footer,.no-print{display:none !important;}
  .main-content{padding-top:0;}
  body{background:#fff;color:#000;}
}

/* ── Reduced motion ────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important;}
  .ticker-track{animation:none;}
}

/* ── Responsive ────────────────────────────────────────────── */
@media(max-width:575.98px){
  .quiz-card{padding:1.25rem 1rem;}
  .hero-title{font-size:1.65rem;}
  .btn{font-size:.875rem;}
  .main-content{padding-top:calc(var(--nav-h) + 30px);}
}
