@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=DM+Sans:wght@300;400;500;600&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy:       #0B1D3A;
  --blue:       #1E56E8;
  --blue-mid:   #1A44C2;
  --blue-dark:  #0D2B6B;
  --blue-light: #EBF4FF;
  --blue-glow:  rgba(30,86,232,0.13);
  --gold:       #D97706;
  --gold-light: #FEF3C7;
  --text:       #0F172A;
  --muted:      #64748B;
  --border:     rgba(0,0,0,0.09);
  --white:      #fff;
  --bg:         #F6F9FF;
  --red:        #DC2626;
  --card-shadow: 0 4px 24px rgba(11,29,58,0.08);
}

html { scroll-behavior: smooth; font-family: 'DM Sans', sans-serif; color: var(--text); background: var(--bg); }
body { min-height: 100vh; display: flex; flex-direction: column; }
main, section, .page-content { flex: 1; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; height: auto; }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeUp    { from { opacity:0; transform:translateY(32px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn    { from { opacity:0; } to { opacity:1; } }
@keyframes slideLeft { from { opacity:0; transform:translateX(-40px); } to { opacity:1; transform:translateX(0); } }
@keyframes slideRight{ from { opacity:0; transform:translateX(40px);  } to { opacity:1; transform:translateX(0); } }
@keyframes scaleIn   { from { opacity:0; transform:scale(0.88); } to { opacity:1; transform:scale(1); } }
@keyframes popIn     { from { transform:scale(0.82); opacity:0; } to { transform:scale(1); opacity:1; } }
@keyframes pulse     { 0%,100%{transform:scale(1);}50%{transform:scale(1.05);} }
@keyframes shimmer   { 0%{background-position:-200% 0;}100%{background-position:200% 0;} }
@keyframes slideDown { from { opacity:0; transform:translateY(-16px); } to { opacity:1; transform:translateY(0); } }

/* Data-anim scroll reveal system */
[data-anim] { opacity: 0; }
[data-anim].revealed[data-anim="fade-up"]    { animation: fadeUp    0.65s ease forwards; }
[data-anim].revealed[data-anim="fade-in"]    { animation: fadeIn    0.6s  ease forwards; }
[data-anim].revealed[data-anim="slide-left"] { animation: slideLeft 0.65s ease forwards; }
[data-anim].revealed[data-anim="slide-right"]{ animation: slideRight 0.65s ease forwards; }
[data-anim].revealed[data-anim="scale-in"]  { animation: scaleIn   0.6s  ease forwards; }

[data-delay="100"]  { animation-delay: 0.1s !important; }
[data-delay="150"]  { animation-delay: 0.15s !important; }
[data-delay="200"]  { animation-delay: 0.2s !important; }
[data-delay="250"]  { animation-delay: 0.25s !important; }
[data-delay="300"]  { animation-delay: 0.3s !important; }
[data-delay="400"]  { animation-delay: 0.4s !important; }
[data-delay="500"]  { animation-delay: 0.5s !important; }
[data-delay="600"]  { animation-delay: 0.6s !important; }
[data-delay="700"]  { animation-delay: 0.7s !important; }
[data-delay="800"]  { animation-delay: 0.8s !important; }

/* ============================================================
   NAV
   ============================================================ */
nav {
  position: sticky; top: 0; z-index: 200;
  background: rgba(255,255,255,0.97); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 4rem;
  min-height: 68px;
  transition: box-shadow 0.3s;
}
nav.scrolled { box-shadow: 0 2px 20px rgba(11,29,58,0.1); }
.logo {
  font-family: 'Playfair Display', serif; font-size: 1.3rem;
  font-weight: 700; color: var(--navy); letter-spacing: -0.5px;
  white-space: nowrap; flex-shrink: 0;
}
.logo span { color: var(--blue); }
.nav-links { display: flex; gap: 1.5rem; align-items: center; flex-wrap: wrap; }
.nav-links a { font-size: 0.87rem; color: var(--muted); transition: color 0.2s; white-space: nowrap; }
.nav-links a:hover, .nav-links a.active { color: var(--blue); }
.nav-cta {
  background: var(--blue) !important; color: #fff !important;
  padding: 0.52rem 1.3rem; border-radius: 50px;
  font-weight: 500 !important; transition: background 0.2s, transform 0.15s !important;
  font-size: 0.87rem !important;
}
.nav-cta:hover { background: var(--blue-mid) !important; transform: translateY(-1px); }

/* Hamburger */
.hamburger {
  display: none; background: none; border: none;
  cursor: pointer; padding: 6px; flex-direction: column; gap: 5px;
}
.hamburger span { display: block; width: 24px; height: 2px; background: var(--text); border-radius: 2px; transition: all 0.3s; }
.mobile-nav {
  display: none; position: fixed; inset: 68px 0 0 0;
  background: #fff; z-index: 199; flex-direction: column;
  padding: 2rem; gap: 1.2rem; border-top: 1px solid var(--border);
  overflow-y: auto;
}
.mobile-nav.open { display: flex; animation: slideDown 0.25s ease; }
.mobile-nav a { font-size: 1rem; color: var(--text); padding: 0.6rem 0; border-bottom: 1px solid var(--border); }
.mobile-nav .nav-cta { border: none; text-align: center; border-radius: 50px; padding: 0.85rem; margin-top: 0.5rem; }

/* ============================================================
   PAGE BANNER
   ============================================================ */
.page-banner {
  background: linear-gradient(135deg, #060F24 0%, #0D2B6B 55%, #1E56E8 100%);
  color: #fff; padding: 4.5rem 4rem 4rem; text-align: center;
  position: relative; overflow: hidden;
}
.page-banner::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse at 70% 50%, rgba(30,86,232,0.35) 0%, transparent 65%);
  pointer-events:none;
}
.page-banner .tag {
  display: inline-block; background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2); color: #BFD7FF;
  font-size: 0.72rem; padding: 0.3rem 1rem; border-radius: 50px;
  letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 1rem;
}
.page-banner h1 { font-family: 'Playfair Display', serif; font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 700; margin-bottom: 0.9rem; line-height: 1.15; }
.page-banner h1 em { font-style: normal; color: #7BB8FF; }
.page-banner p { font-size: 0.97rem; color: rgba(255,255,255,0.72); max-width: 560px; margin: 0 auto; line-height: 1.75; }

/* ============================================================
   FOOTER
   ============================================================ */
footer {
  background: var(--navy);
  color: rgba(255,255,255,0.65);
  padding: 3.5rem 4rem 2rem;
  margin-top: auto;
}
.footer-top {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 2.5rem;
  margin-bottom: 2.5rem; padding-bottom: 2rem; border-bottom: 1px solid rgba(255,255,255,0.1);
}
.footer-brand .logo { color: #fff; display: block; margin-bottom: 0.8rem; font-size: 1.2rem; }
.footer-brand p { font-size: 0.82rem; color: rgba(255,255,255,0.45); line-height: 1.7; max-width: 230px; margin-bottom: 1rem; }
.footer-social { display: flex; gap: 0.6rem; }
.footer-social a {
  width: 34px; height: 34px; border-radius: 50%;
  background: rgba(255,255,255,0.08); display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem; transition: background 0.2s;
}
.footer-social a:hover { background: var(--blue); }
.footer-col h5 { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 1.5px; color: #fff; font-weight: 600; margin-bottom: 1rem; }
.footer-col a { display: block; font-size: 0.83rem; color: rgba(255,255,255,0.5); margin-bottom: 0.55rem; transition: color 0.2s; }
.footer-col a:hover { color: #7BB8FF; }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.77rem; color: rgba(255,255,255,0.3);
}

/* ============================================================
   COMMON ELEMENTS
   ============================================================ */
.section-tag { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 2px; color: var(--blue); font-weight: 600; margin-bottom: 0.6rem; }
.section-title { font-family: 'Playfair Display', serif; font-size: clamp(1.7rem, 4vw, 2.5rem); font-weight: 700; color: var(--text); line-height: 1.2; }
.section-sub { font-size: 0.97rem; color: var(--muted); line-height: 1.75; margin-top: 0.8rem; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 2rem; }

/* Buttons */
.btn-primary {
  display: inline-flex; align-items: center; gap: 0.4rem;
  background: var(--blue); color: #fff;
  padding: 0.85rem 2rem; border-radius: 50px; font-weight: 500; font-size: 0.95rem;
  transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
  border: none; cursor: pointer; font-family: 'DM Sans', sans-serif;
}
.btn-primary:hover { background: var(--blue-mid); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(30,86,232,0.3); color: #fff; }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 0.4rem;
  border: 1.5px solid rgba(255,255,255,0.35); color: #fff;
  padding: 0.83rem 2rem; border-radius: 50px; font-weight: 500; font-size: 0.95rem;
  transition: background 0.2s, border-color 0.2s;
  background: transparent;
}
.btn-ghost:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.6); color: #fff; }
.btn-outline {
  display: inline-flex; align-items: center; gap: 0.4rem;
  border: 1.5px solid var(--blue); color: var(--blue);
  padding: 0.75rem 1.8rem; border-radius: 50px; font-weight: 500; font-size: 0.9rem;
  transition: background 0.2s, color 0.2s;
}
.btn-outline:hover { background: var(--blue); color: #fff; }

/* Alerts */
.alert { padding: 0.9rem 1.2rem; border-radius: 10px; margin-bottom: 1.5rem; font-size: 0.85rem; }
.alert-error   { background: #FEF2F2; color: #991B1B; border: 1px solid #FECACA; }
.alert-success { background: var(--blue-light); color: var(--blue-dark); border: 1px solid rgba(30,86,232,0.25); }

/* Popup */
.popup-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.55); z-index:9999; align-items:center; justify-content:center; padding:1rem; }
.popup-overlay.active { display:flex; }
.popup-box { background:#fff; border-radius:20px; padding:2.5rem 2rem; max-width:440px; width:100%; text-align:center; animation:popIn 0.3s ease; }
.popup-icon { width:64px; height:64px; background:var(--blue-light); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 1.2rem; font-size:1.8rem; }
.popup-box h2 { font-family:'Playfair Display',serif; font-size:1.5rem; color:var(--navy); margin-bottom:0.8rem; }
.popup-box p { font-size:0.88rem; color:var(--muted); line-height:1.7; margin-bottom:1.5rem; }
.popup-btn { background:var(--blue); color:#fff; border:none; padding:0.8rem 2.5rem; border-radius:50px; font-size:0.9rem; font-family:'DM Sans',sans-serif; cursor:pointer; transition:background 0.2s; }
.popup-btn:hover { background:var(--blue-mid); }

/* ============================================================
   HERO (INDEX)
   ============================================================ */
.hero {
  background: linear-gradient(135deg, #060F24 0%, #0D2B6B 50%, #1E56E8 100%);
  color: #fff; padding: 6rem 4rem 5rem; position: relative; overflow: hidden;
}
.hero::before {
  content:''; position:absolute; top:-60px; right:-80px;
  width:550px; height:550px; border-radius:50%;
  background: radial-gradient(circle, rgba(30,86,232,0.4) 0%, transparent 70%);
  pointer-events:none;
}
.hero::after {
  content:''; position:absolute; bottom:-100px; left:-50px;
  width:400px; height:400px; border-radius:50%;
  background: radial-gradient(circle, rgba(123,184,255,0.15) 0%, transparent 70%);
  pointer-events:none;
}
.hero-inner { max-width: 820px; position: relative; z-index: 1; }
.hero-tag {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2);
  color: #BFD7FF; font-size: 0.8rem; padding: 0.4rem 1.1rem; border-radius: 50px;
  margin-bottom: 1.5rem; letter-spacing: 0.5px;
  animation: fadeIn 0.8s ease forwards;
}
.hero h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.4rem, 6vw, 4rem); font-weight: 700; line-height: 1.1;
  margin-bottom: 1.3rem;
  animation: fadeUp 0.8s ease 0.15s both;
}
.hero h1 em { font-style: normal; color: #7BB8FF; }
.hero p {
  font-size: 1.07rem; color: rgba(255,255,255,0.78); line-height: 1.75;
  max-width: 580px; margin-bottom: 2.2rem;
  animation: fadeUp 0.8s ease 0.25s both;
}
.hero-btns { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 3.5rem; animation: fadeUp 0.8s ease 0.35s both; }
.hero-stats {
  display: flex; gap: 2.5rem; flex-wrap: wrap;
  animation: fadeUp 0.8s ease 0.45s both;
}
.stat-item { text-align: left; }
.stat-item .num { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; line-height: 1; }
.stat-item .lbl { font-size: 0.78rem; color: rgba(255,255,255,0.55); margin-top: 0.2rem; }

/* ============================================================
   ABOUT SECTION (INDEX)
   ============================================================ */
.about { padding: 5.5rem 4rem; }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; margin-top: 3rem; }
.about-features { display: flex; flex-direction: column; gap: 1.8rem; }
.feat { display: flex; gap: 1.1rem; align-items: flex-start; }
.feat-icon { width: 44px; height: 44px; min-width: 44px; border-radius: 12px; background: var(--blue-light); display: flex; align-items: center; justify-content: center; }
.feat-icon svg { width: 20px; height: 20px; }
.feat h4 { font-size: 0.97rem; font-weight: 600; margin-bottom: 0.3rem; color: var(--text); }
.feat p  { font-size: 0.84rem; color: var(--muted); line-height: 1.65; }

.about-visual { background: linear-gradient(145deg, #060F24, #0D2B6B); border-radius: 24px; padding: 2.2rem; }
.visual-label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 2px; color: rgba(255,255,255,0.45); margin-bottom: 1.2rem; }
.grant-types { display: flex; flex-direction: column; gap: 0.8rem; }
.grant-card {
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px; padding: 1rem 1.2rem;
  display: flex; justify-content: space-between; align-items: center;
  transition: background 0.2s, border-color 0.2s;
}
.grant-card:hover { background: rgba(255,255,255,0.12); border-color: rgba(123,184,255,0.4); }
.grant-card.highlight { border-color: rgba(123,184,255,0.5); background: rgba(30,86,232,0.25); }
.gc-title { font-size: 0.9rem; font-weight: 500; color: #fff; }
.gc-sub   { font-size: 0.75rem; color: rgba(255,255,255,0.5); margin-top: 0.1rem; }
.gc-amt   { font-family: 'Playfair Display', serif; font-size: 1.2rem; font-weight: 700; color: #7BB8FF; }
.see-all-btn {
  display: block; text-align: center; margin-top: 1.3rem;
  color: #7BB8FF; font-size: 0.85rem; font-weight: 500;
  padding: 0.6rem; border-radius: 8px; border: 1px solid rgba(123,184,255,0.3);
  transition: background 0.2s, border-color 0.2s;
}
.see-all-btn:hover { background: rgba(123,184,255,0.1); border-color: rgba(123,184,255,0.6); }

/* ============================================================
   HOW IT WORKS SECTION (INDEX)
   ============================================================ */
.how { background: var(--blue-light); padding: 5.5rem 4rem; }
.steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 2rem; margin-top: 3.5rem; position: relative; }
.steps::before {
  content:''; position:absolute; top:28px; left:calc(12.5% + 16px); right:calc(12.5% + 16px);
  height:2px; background:linear-gradient(90deg,var(--blue),var(--blue-light)); z-index:0;
}
.step { text-align: center; position: relative; z-index: 1; }
.step-num {
  width: 56px; height: 56px; border-radius: 50%; background: var(--blue); color: #fff;
  font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; margin: 0 auto 1.2rem;
  box-shadow: 0 4px 16px rgba(30,86,232,0.35);
}
.step h4 { font-size: 1rem; font-weight: 600; margin-bottom: 0.5rem; }
.step p  { font-size: 0.84rem; color: var(--muted); line-height: 1.65; }

/* ============================================================
   STATS BAND (INDEX)
   ============================================================ */
.stats-band { background: var(--navy); padding: 4rem 4rem; }
.stats-band-inner { max-width: 1000px; margin: 0 auto; display: grid; grid-template-columns: repeat(4,1fr); gap: 2rem; text-align: center; }
.sb-num { font-family: 'Playfair Display', serif; font-size: 2.5rem; font-weight: 700; color: #7BB8FF; }
.sb-lbl { font-size: 0.82rem; color: rgba(255,255,255,0.5); margin-top: 0.3rem; text-transform: uppercase; letter-spacing: 1px; }

/* ============================================================
   GRANT TYPES PREVIEW (INDEX)
   ============================================================ */
.grants-preview { padding: 5.5rem 4rem; }
.cards-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-top: 2.5rem; }
.preview-card {
  background: #fff; border: 1.5px solid var(--border); border-radius: 18px;
  padding: 1.8rem 1.6rem; transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.preview-card:hover { transform: translateY(-5px); box-shadow: 0 12px 32px var(--blue-glow); border-color: var(--blue); }
.preview-card-icon { font-size: 2.2rem; margin-bottom: 0.9rem; }
.preview-card h4 { font-size: 1rem; font-weight: 600; margin-bottom: 0.4rem; }
.preview-card p  { font-size: 0.82rem; color: var(--muted); line-height: 1.6; }
.preview-card-link { display: inline-block; margin-top: 1rem; font-size: 0.82rem; color: var(--blue); font-weight: 500; }

/* ============================================================
   FAQ (INDEX)
   ============================================================ */
.faq { padding: 5.5rem 4rem; background: #fff; }
.faq-grid { max-width: 800px; margin: 3rem auto 0; display: flex; flex-direction: column; gap: 0.8rem; }
.faq-item { border: 1.5px solid var(--border); border-radius: 14px; overflow: hidden; }
.faq-q {
  padding: 1.1rem 1.4rem; cursor: pointer; font-size: 0.95rem; font-weight: 500;
  display: flex; justify-content: space-between; align-items: center;
  transition: background 0.2s;
}
.faq-q:hover { background: var(--bg); }
.faq-item.open .faq-q { background: var(--blue-light); color: var(--blue-dark); }
.faq-icon { font-size: 1.3rem; color: var(--blue); transition: transform 0.3s; flex-shrink:0; }
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-a { padding: 0 1.4rem; max-height: 0; overflow: hidden; transition: max-height 0.35s ease, padding 0.3s ease; font-size: 0.88rem; color: var(--muted); line-height: 1.75; }
.faq-item.open .faq-a { max-height: 200px; padding: 0.8rem 1.4rem 1.2rem; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band {
  background: linear-gradient(135deg, #0D2B6B 0%, #1E56E8 100%);
  padding: 5rem 4rem; text-align: center; color: #fff;
  position: relative; overflow: hidden;
}
.cta-band::before {
  content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:600px; height:600px; border-radius:50%;
  background: radial-gradient(circle, rgba(255,255,255,0.05) 0%, transparent 70%);
  pointer-events:none;
}
.cta-band h2 { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,4vw,2.8rem); margin-bottom:0.8rem; position:relative; }
.cta-band p  { font-size:0.97rem; color:rgba(255,255,255,0.72); margin-bottom:2rem; position:relative; }
.cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; position:relative; }

/* ============================================================
   GRANT TYPES PAGE
   ============================================================ */
.gt-section { padding: 3.5rem 4rem 5rem; }
.search-wrap { max-width: 520px; margin: 0 auto 3rem; position: relative; }
.search-wrap input {
  width: 100%; padding: 0.9rem 1.2rem 0.9rem 3rem;
  border: 1.5px solid #ddd; border-radius: 50px;
  font-size: 0.95rem; font-family: 'DM Sans', sans-serif;
  outline: none; transition: border 0.2s, box-shadow 0.2s;
}
.search-wrap input:focus { border-color: var(--blue); box-shadow: 0 0 0 3px var(--blue-glow); }
.search-icon { position: absolute; left: 1.1rem; top: 50%; transform: translateY(-50%); color: var(--muted); pointer-events: none; }
.gt-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1.2rem;
}
.gt-card {
  background: #fff; border: 1.5px solid var(--border); border-radius: 16px;
  padding: 1.6rem 1.4rem; cursor: pointer;
  transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
  display: flex; flex-direction: column; gap: 0.7rem; position: relative; overflow: hidden;
}
.gt-card:hover { transform: translateY(-4px); box-shadow: 0 10px 28px var(--blue-glow); border-color: var(--blue); }
.gt-card-icon { font-size: 2rem; line-height: 1; }
.gt-card-num { position: absolute; top: 1rem; right: 1.1rem; font-size: 0.68rem; color: #ccc; font-weight: 600; letter-spacing: 1px; }
.gt-card h3  { font-size: 0.95rem; font-weight: 500; color: var(--text); line-height: 1.35; }
.gt-card p   { font-size: 0.78rem; color: var(--muted); line-height: 1.55; }
.gt-card .gt-btn {
  margin-top: auto; display: inline-block; background: var(--blue-light);
  color: var(--blue-dark); font-size: 0.78rem; font-weight: 500;
  padding: 0.35rem 0.9rem; border-radius: 50px; width: fit-content;
  transition: background 0.2s, color 0.2s;
}
.gt-card:hover .gt-btn { background: var(--blue); color: #fff; }
.gt-card.hidden { display: none; }

/* Pricing Modal */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:9000; align-items:center; justify-content:center; padding:1rem; }
.modal-overlay.active { display:flex; }
.modal-box { background:#fff; border-radius:24px; max-width:980px; width:100%; max-height:90vh; overflow-y:auto; padding:2.5rem 2rem; animation:scaleIn 0.3s ease; }
.modal-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:0.5rem; }
.modal-header h2 { font-family:'Playfair Display',serif; font-size:1.7rem; color:var(--text); }
.modal-header .selected-type { font-size:0.82rem; color:var(--blue); font-weight:500; margin-top:0.3rem; }
.modal-close { background:#f0f0f0; border:none; width:36px; height:36px; border-radius:50%; font-size:1.2rem; cursor:pointer; flex-shrink:0; transition:background 0.2s; }
.modal-close:hover { background:#e0e0e0; }
.modal-sub { font-size:0.85rem; color:var(--muted); margin-bottom:2rem; }
.plans-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1rem; }
.plan-card {
  background:#fff; border:1.5px solid var(--border); border-radius:16px;
  padding:1.5rem 1.4rem; display:flex; flex-direction:column; gap:0.8rem;
  transition:transform 0.2s,box-shadow 0.2s; position:relative; overflow:hidden;
}
.plan-card:hover { transform:translateY(-3px); box-shadow:0 8px 24px var(--blue-glow); border-color:var(--blue); }
.plan-card.featured { border:2px solid var(--blue); background:linear-gradient(160deg,#EBF4FF,#fff); }
.plan-card.featured::before { content:'POPULAR'; position:absolute; top:14px; right:-22px; background:var(--blue); color:#fff; font-size:0.6rem; font-weight:700; padding:0.25rem 2rem; transform:rotate(35deg); letter-spacing:1px; }
.plan-name { font-size:0.68rem; text-transform:uppercase; letter-spacing:2px; color:var(--blue); font-weight:600; }
.plan-pay-label { font-size:0.72rem; color:var(--muted); }
.plan-pay-val { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:700; line-height:1; color:var(--text); }
.plan-sep { border:none; border-top:1px dashed var(--border); }
.plan-get-label { font-size:0.68rem; text-transform:uppercase; letter-spacing:1px; color:var(--muted); }
.plan-get-val { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:700; color:var(--blue-dark); }
.plan-ratio { background:var(--blue-light); color:var(--blue-dark); font-size:0.7rem; font-weight:500; padding:0.2rem 0.7rem; border-radius:50px; width:fit-content; }
.plan-apply-btn { margin-top:auto; display:block; text-align:center; background:var(--blue-dark); color:#fff; padding:0.7rem 1rem; border-radius:50px; font-size:0.85rem; font-weight:500; transition:background 0.2s; }
.plan-apply-btn:hover { background:var(--blue); color:#fff; }
.plan-card.featured .plan-apply-btn { background:var(--blue); }

/* ============================================================
   APPLY PAGE
   ============================================================ */
.apply-layout { max-width:1120px; margin:0 auto; padding:3rem 2rem 5rem; display:grid; grid-template-columns:1fr 2.4fr; gap:3rem; align-items:start; }
.plan-sidebar { position:sticky; top:90px; }
.plan-summary-card { background:linear-gradient(145deg,#060F24,#0D2B6B); color:#fff; border-radius:20px; padding:2rem 1.8rem; }
.ps-tag  { font-size:0.68rem; letter-spacing:2px; text-transform:uppercase; color:#7BB8FF; margin-bottom:0.8rem; }
.ps-name { font-family:'Playfair Display',serif; font-size:1.7rem; font-weight:700; margin-bottom:1.5rem; }
.ps-type { font-size:0.78rem; color:rgba(255,255,255,0.55); margin-top:-1.2rem; margin-bottom:1.2rem; }
.ps-row  { display:flex; justify-content:space-between; align-items:center; padding:0.7rem 0; border-bottom:1px solid rgba(255,255,255,0.1); }
.ps-row:last-of-type { border-bottom:none; }
.ps-label { font-size:0.78rem; color:rgba(255,255,255,0.55); }
.ps-val   { font-size:0.95rem; font-weight:500; }
.ps-val.big { font-family:'Playfair Display',serif; font-size:1.4rem; color:#7BB8FF; }
.ps-note  { margin-top:1.5rem; font-size:0.76rem; color:rgba(255,255,255,0.4); line-height:1.6; }
.back-link { display:inline-flex; align-items:center; gap:0.4rem; font-size:0.84rem; color:var(--muted); margin-bottom:1.5rem; transition:color 0.2s; }
.back-link:hover { color:var(--blue); }
.form-card { background:#fff; border:1px solid var(--border); border-radius:24px; padding:2.5rem; box-shadow:var(--card-shadow); }
.form-card h2 { font-family:'Playfair Display',serif; font-size:1.7rem; margin-bottom:0.3rem; }
.form-card .sub { font-size:0.84rem; color:var(--muted); margin-bottom:2rem; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem 1.8rem; }
.fg { display:flex; flex-direction:column; gap:0.35rem; }
.fg.full { grid-column:1/-1; }
.fg label { font-size:0.8rem; font-weight:500; color:var(--text); }
.fg label .req { color:var(--red); margin-left:2px; }
.fg input,.fg select {
  width:100%; padding:0.65rem 0.95rem; font-size:0.88rem; font-family:'DM Sans',sans-serif;
  border:1.5px solid #e0e0e0; border-radius:10px; outline:none;
  transition:border 0.2s,box-shadow 0.2s; background:#fff; color:var(--text);
}
.fg input:focus,.fg select:focus { border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-glow); }
.fg input.err,.fg select.err,.upload-area.err { border-color:var(--red)!important; }
.fg .err-msg { font-size:0.75rem; color:var(--red); }
.sec-hdr { grid-column:1/-1; padding:0.5rem 0 0.2rem; border-bottom:1.5px solid var(--blue-light); margin-bottom:0.2rem; }
.sec-hdr span { font-size:0.68rem; text-transform:uppercase; letter-spacing:2px; color:var(--blue); font-weight:600; }
.upload-area { border:2px dashed #ddd; border-radius:12px; padding:1.5rem 1rem; text-align:center; cursor:pointer; transition:border-color 0.2s,background 0.2s; position:relative; }
.upload-area:hover { border-color:var(--blue); background:var(--blue-light); }
.upload-area input[type=file] { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }
.upload-area .ua-icon { font-size:2rem; margin-bottom:0.5rem; display:block; }
.upload-area .ua-title { font-size:0.9rem; font-weight:500; color:var(--text); }
.upload-area .ua-sub   { font-size:0.76rem; color:var(--muted); margin-top:0.2rem; }
.upload-preview { display:none; align-items:center; gap:0.8rem; background:var(--blue-light); border-radius:10px; padding:0.75rem 1rem; margin-top:0.8rem; }
.upload-preview span { font-size:0.82rem; color:var(--blue-dark); word-break:break-all; }
.submit-wrap { margin-top:2rem; text-align:center; }
.submit-btn { background:var(--blue); color:#fff; border:none; padding:1rem 3.5rem; border-radius:50px; font-size:1rem; font-weight:500; font-family:'DM Sans',sans-serif; cursor:pointer; transition:background 0.2s,transform 0.15s; }
.submit-btn:hover { background:var(--blue-mid); }
.submit-btn:active { transform:scale(0.98); }
.submit-note { font-size:0.76rem; color:var(--muted); margin-top:0.8rem; }

/* ============================================================
   ADMIN PAGE
   ============================================================ */
.admin-login-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--bg); padding:2rem; }
.admin-login-box { background:#fff; border-radius:20px; padding:2.5rem 2rem; max-width:400px; width:100%; box-shadow:var(--card-shadow); }
.admin-login-box .logo { display:block; margin-bottom:1.5rem; font-size:1.5rem; }
.admin-login-box h2 { font-family:'Playfair Display',serif; font-size:1.6rem; margin-bottom:0.3rem; }
.admin-login-box p  { font-size:0.84rem; color:var(--muted); margin-bottom:1.8rem; }
.admin-wrap { max-width:1300px; margin:0 auto; padding:2rem 2rem 4rem; }
.admin-hdr  { display:flex; justify-content:space-between; align-items:center; margin-bottom:2rem; gap:1rem; flex-wrap:wrap; }
.admin-title { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:700; }
.logout-btn { background:transparent; border:1.5px solid var(--border); color:var(--muted); padding:0.5rem 1.2rem; border-radius:50px; font-size:0.84rem; cursor:pointer; transition:all 0.2s; font-family:'DM Sans',sans-serif; }
.logout-btn:hover { border-color:var(--red); color:var(--red); }
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; margin-bottom:2rem; }
.stat-card { background:#fff; border-radius:16px; padding:1.4rem 1.6rem; box-shadow:var(--card-shadow); border:1px solid var(--border); }
.stat-card .sc-num { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; color:var(--blue); }
.stat-card .sc-lbl { font-size:0.78rem; color:var(--muted); margin-top:0.2rem; }
.tab-bar { display:flex; gap:0.5rem; flex-wrap:wrap; margin-bottom:1.5rem; }
.tab-btn { background:transparent; border:1.5px solid var(--border); padding:0.55rem 1.2rem; border-radius:50px; font-size:0.84rem; cursor:pointer; font-family:'DM Sans',sans-serif; color:var(--muted); transition:all 0.2s; }
.tab-btn.active { background:var(--blue); border-color:var(--blue); color:#fff; }
.tab-btn:hover:not(.active) { border-color:var(--blue); color:var(--blue); }
.filter-bar { display:flex; gap:0.8rem; flex-wrap:wrap; margin-bottom:1.2rem; }
.filter-bar input,.filter-bar select { padding:0.55rem 1rem; border:1.5px solid var(--border); border-radius:50px; font-size:0.84rem; font-family:'DM Sans',sans-serif; outline:none; }
.filter-bar input:focus,.filter-bar select:focus { border-color:var(--blue); }
.table-wrap { background:#fff; border-radius:16px; box-shadow:var(--card-shadow); overflow:hidden; }
.app-table { width:100%; border-collapse:collapse; }
.app-table th { background:var(--bg); font-size:0.75rem; text-transform:uppercase; letter-spacing:1px; color:var(--muted); padding:0.9rem 1rem; text-align:left; }
.app-table td { padding:0.85rem 1rem; border-top:1px solid var(--border); font-size:0.84rem; vertical-align:top; }
.app-table tr:hover td { background:var(--bg); }
.status-badge { display:inline-block; padding:0.25rem 0.7rem; border-radius:50px; font-size:0.72rem; font-weight:600; }
.status-Pending      { background:#FEF3C7; color:#92400E; }
.status-Under-Review { background:var(--blue-light); color:var(--blue-dark); }
.status-Approved     { background:#D1FAE5; color:#065F46; }
.status-Rejected     { background:#FEE2E2; color:#991B1B; }
.detail-toggle { background:none; border:none; color:var(--blue); cursor:pointer; font-size:0.82rem; font-family:'DM Sans',sans-serif; padding:0; }
.detail-row { display:none; }
.detail-row td { background:var(--blue-light)!important; }
.detail-row.open { display:table-row; }
.detail-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:0.5rem 1rem; padding:0.5rem; }
.detail-item label { font-size:0.7rem; color:var(--muted); text-transform:uppercase; letter-spacing:0.5px; }
.detail-item span  { display:block; font-size:0.85rem; font-weight:500; color:var(--text); }
.settings-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.settings-card { background:#fff; border-radius:16px; padding:1.8rem; box-shadow:var(--card-shadow); }
.settings-card h3 { font-size:1rem; font-weight:600; margin-bottom:1.2rem; color:var(--text); }
.settings-card .fg { margin-bottom:0.8rem; }
.save-btn { background:var(--blue); color:#fff; border:none; padding:0.65rem 2rem; border-radius:50px; font-size:0.88rem; cursor:pointer; font-family:'DM Sans',sans-serif; transition:background 0.2s; margin-top:0.5rem; }
.save-btn:hover { background:var(--blue-mid); }
.admin-nav { background:var(--navy); }
.admin-nav-inner { max-width:1300px; margin:0 auto; padding:0 2rem; display:flex; align-items:center; justify-content:space-between; min-height:56px; }
.admin-nav .logo { color:#fff; font-size:1.1rem; }
.admin-badge { background:var(--blue); color:#fff; font-size:0.7rem; padding:0.2rem 0.7rem; border-radius:50px; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-page { padding: 5rem 4rem; }
.mission-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; margin-bottom:5rem; }
.mission-img-box { background:linear-gradient(145deg,#060F24,#1E56E8); border-radius:24px; padding:3rem 2.5rem; color:#fff; }
.mission-img-box h3 { font-family:'Playfair Display',serif; font-size:2rem; margin-bottom:1rem; }
.mission-img-box p  { font-size:0.88rem; color:rgba(255,255,255,0.7); line-height:1.75; }
.mission-stat-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-top:2rem; }
.mission-stat { background:rgba(255,255,255,0.1); border-radius:12px; padding:1rem; text-align:center; }
.mission-stat .num { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:700; color:#7BB8FF; }
.mission-stat .lbl { font-size:0.75rem; color:rgba(255,255,255,0.6); margin-top:0.2rem; }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.value-card { background:#fff; border:1.5px solid var(--border); border-radius:18px; padding:2rem 1.8rem; transition:transform 0.2s,box-shadow 0.2s,border-color 0.2s; }
.value-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px var(--blue-glow); border-color:var(--blue); }
.value-icon { width:48px; height:48px; border-radius:14px; background:var(--blue-light); display:flex; align-items:center; justify-content:center; font-size:1.5rem; margin-bottom:1rem; }
.value-card h4 { font-size:1rem; font-weight:600; margin-bottom:0.4rem; }
.value-card p  { font-size:0.84rem; color:var(--muted); line-height:1.65; }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; margin-top:2.5rem; }
.team-card { text-align:center; }
.team-avatar { width:90px; height:90px; border-radius:50%; margin:0 auto 1rem; display:flex; align-items:center; justify-content:center; font-size:2.5rem; }
.team-card h4 { font-size:0.97rem; font-weight:600; }
.team-card p  { font-size:0.8rem; color:var(--muted); margin-top:0.2rem; }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-layout { max-width:1100px; margin:0 auto; padding:4rem 2rem 5rem; display:grid; grid-template-columns:1fr 1.6fr; gap:3.5rem; align-items:start; }
.contact-info h2 { font-family:'Playfair Display',serif; font-size:1.8rem; margin-bottom:0.8rem; }
.contact-info p  { font-size:0.88rem; color:var(--muted); line-height:1.75; margin-bottom:2rem; }
.contact-items { display:flex; flex-direction:column; gap:1.2rem; }
.contact-item { display:flex; gap:1rem; align-items:flex-start; }
.ci-icon { width:44px; height:44px; min-width:44px; border-radius:12px; background:var(--blue-light); display:flex; align-items:center; justify-content:center; font-size:1.2rem; }
.ci-label { font-size:0.75rem; text-transform:uppercase; letter-spacing:1px; color:var(--muted); margin-bottom:0.2rem; }
.ci-val   { font-size:0.9rem; font-weight:500; color:var(--text); }
.contact-form-card { background:#fff; border:1px solid var(--border); border-radius:24px; padding:2.5rem; box-shadow:var(--card-shadow); }
.contact-form-card h3 { font-family:'Playfair Display',serif; font-size:1.5rem; margin-bottom:0.4rem; }
.contact-form-card .sub { font-size:0.84rem; color:var(--muted); margin-bottom:2rem; }
.contact-form-card textarea { width:100%; padding:0.65rem 0.95rem; font-size:0.88rem; font-family:'DM Sans',sans-serif; border:1.5px solid #e0e0e0; border-radius:10px; outline:none; resize:vertical; min-height:120px; transition:border 0.2s,box-shadow 0.2s; }
.contact-form-card textarea:focus { border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-glow); }

/* ============================================================
   TESTIMONIALS PAGE
   ============================================================ */
.testi-section { padding:4.5rem 4rem 5.5rem; }
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.testi-card { background:#fff; border:1.5px solid var(--border); border-radius:20px; padding:2rem 1.8rem; transition:transform 0.2s,box-shadow 0.2s,border-color 0.2s; }
.testi-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px var(--blue-glow); border-color:var(--blue); }
.testi-stars { color:#F59E0B; font-size:1rem; margin-bottom:1rem; letter-spacing:2px; }
.testi-quote { font-size:0.9rem; color:var(--text); line-height:1.75; margin-bottom:1.5rem; font-style:italic; }
.testi-author { display:flex; align-items:center; gap:0.9rem; }
.testi-avatar { width:44px; height:44px; border-radius:50%; background:var(--blue-light); display:flex; align-items:center; justify-content:center; font-size:1.3rem; }
.testi-name { font-size:0.88rem; font-weight:600; }
.testi-plan { font-size:0.76rem; color:var(--blue); margin-top:0.1rem; }
.testi-featured { background:linear-gradient(145deg,#060F24,#0D2B6B); color:#fff; border-color:transparent; }
.testi-featured .testi-quote { color:rgba(255,255,255,0.8); }
.testi-featured .testi-name  { color:#fff; }
.testi-featured .testi-plan  { color:#7BB8FF; }
.testi-featured .testi-avatar { background:rgba(255,255,255,0.15); }

/* ============================================================
   BLOG PAGE
   ============================================================ */
.blog-section { padding:4.5rem 4rem 5.5rem; }
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; margin-top:2.5rem; }
.blog-card { background:#fff; border:1.5px solid var(--border); border-radius:20px; overflow:hidden; transition:transform 0.2s,box-shadow 0.2s,border-color 0.2s; }
.blog-card:hover { transform:translateY(-5px); box-shadow:0 12px 32px var(--blue-glow); border-color:var(--blue); }
.blog-img { height:180px; display:flex; align-items:center; justify-content:center; font-size:3.5rem; }
.blog-body { padding:1.6rem 1.8rem 2rem; }
.blog-tag  { display:inline-block; background:var(--blue-light); color:var(--blue-dark); font-size:0.68rem; font-weight:600; padding:0.2rem 0.7rem; border-radius:50px; text-transform:uppercase; letter-spacing:1px; margin-bottom:0.8rem; }
.blog-card h3 { font-size:1.02rem; font-weight:600; line-height:1.4; margin-bottom:0.5rem; }
.blog-card p  { font-size:0.82rem; color:var(--muted); line-height:1.65; margin-bottom:1rem; }
.blog-meta { display:flex; align-items:center; gap:1rem; font-size:0.76rem; color:var(--muted); }
.blog-read-link { color:var(--blue); font-weight:500; font-size:0.82rem; }

/* ============================================================
   FAQ PAGE
   ============================================================ */
.faq-page { padding:4.5rem 4rem 5.5rem; }
.faq-cats { display:flex; gap:0.7rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.faq-cat-btn { background:#fff; border:1.5px solid var(--border); padding:0.5rem 1.2rem; border-radius:50px; font-size:0.84rem; cursor:pointer; font-family:'DM Sans',sans-serif; color:var(--muted); transition:all 0.2s; }
.faq-cat-btn.active { background:var(--blue); border-color:var(--blue); color:#fff; }
.faq-cat-btn:hover:not(.active) { border-color:var(--blue); color:var(--blue); }
.faq-page .faq-grid { max-width:800px; display:flex; flex-direction:column; gap:0.8rem; }
.faq-cta-box { margin-top:4rem; background:var(--blue-light); border-radius:20px; padding:3rem; text-align:center; }
.faq-cta-box h3 { font-family:'Playfair Display',serif; font-size:1.6rem; margin-bottom:0.6rem; }
.faq-cta-box p  { font-size:0.9rem; color:var(--muted); margin-bottom:1.5rem; }

/* ============================================================
   HOW IT WORKS PAGE
   ============================================================ */
.hiw-page { padding:4.5rem 4rem 5.5rem; }
.hiw-steps { display:flex; flex-direction:column; gap:3rem; max-width:800px; margin:3rem auto 0; }
.hiw-step { display:flex; gap:2rem; align-items:flex-start; }
.hiw-step-num {
  width:64px; height:64px; min-width:64px; border-radius:50%;
  background:linear-gradient(135deg,#0D2B6B,#1E56E8); color:#fff;
  font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(30,86,232,0.4);
}
.hiw-step-body h3 { font-size:1.15rem; font-weight:600; margin-bottom:0.5rem; }
.hiw-step-body p  { font-size:0.9rem; color:var(--muted); line-height:1.75; }
.hiw-step-body .hiw-tip { display:inline-block; margin-top:0.8rem; background:var(--blue-light); color:var(--blue-dark); font-size:0.78rem; padding:0.3rem 0.9rem; border-radius:50px; }
.hiw-doc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.hiw-doc-card { background:#fff; border:1.5px solid var(--border); border-radius:16px; padding:1.6rem 1.4rem; text-align:center; }
.hiw-doc-icon { font-size:2rem; margin-bottom:0.8rem; }
.hiw-doc-card h4 { font-size:0.95rem; font-weight:600; margin-bottom:0.3rem; }
.hiw-doc-card p  { font-size:0.82rem; color:var(--muted); line-height:1.6; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  nav { padding: 0 2rem; }
  .hero, .about, .how, .stats-band, .grants-preview, .faq, .cta-band { padding-left: 2rem; padding-right: 2rem; }
  .about-page, .contact-layout, .testi-section, .blog-section, .faq-page, .hiw-page, .gt-section { padding-left: 2rem; padding-right: 2rem; }
  footer { padding: 3rem 2rem 2rem; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .team-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 900px) {
  .about-grid, .mission-grid { grid-template-columns: 1fr; gap: 2rem; }
  .steps { grid-template-columns: 1fr 1fr; }
  .steps::before { display: none; }
  .stats-band-inner { grid-template-columns: 1fr 1fr; }
  .cards-grid { grid-template-columns: 1fr 1fr; }
  .testi-grid, .blog-grid { grid-template-columns: 1fr 1fr; }
  .values-grid { grid-template-columns: 1fr 1fr; }
  .hiw-doc-grid { grid-template-columns: 1fr 1fr; }
  .apply-layout { grid-template-columns: 1fr; }
  .plan-sidebar { position: relative; top: 0; }
  .contact-layout { grid-template-columns: 1fr; }
  .settings-grid { grid-template-columns: 1fr; }
  .stats-row { grid-template-columns: 1fr 1fr; }
  .admin-wrap { padding: 1.5rem 1rem 3rem; }
}

@media (max-width: 768px) {
  nav { padding: 0 1.2rem; }
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .hero { padding: 4rem 1.2rem 3rem; }
  .hero h1 { font-size: clamp(1.9rem, 8vw, 2.6rem); }
  .hero-stats { gap: 1.5rem; }
  .about, .how { padding: 3.5rem 1.2rem; }
  .grants-preview, .faq { padding: 3.5rem 1.2rem; }
  .cta-band { padding: 3.5rem 1.2rem; }
  .stats-band { padding: 3rem 1.2rem; }
  .page-banner { padding: 3rem 1.2rem 2.5rem; }
  .testi-grid, .blog-grid, .cards-grid { grid-template-columns: 1fr; }
  .testi-section, .blog-section, .faq-page, .hiw-page, .about-page { padding: 3rem 1.2rem; }
  .values-grid { grid-template-columns: 1fr; }
  .hiw-doc-grid { grid-template-columns: 1fr; }
  .gt-section { padding: 2rem 1.2rem 3rem; }
  .gt-grid { grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); }
  .plans-grid { grid-template-columns: 1fr 1fr; }
  .apply-layout { padding: 2rem 1rem 3rem; }
  .form-grid { grid-template-columns: 1fr; }
  .fg.full { grid-column: 1; }
  .sec-hdr { grid-column: 1; }
  .form-card { padding: 1.5rem 1rem; }
  .submit-btn { width: 100%; }
  footer { padding: 2.5rem 1.2rem 1.5rem; }
  .footer-top { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; gap: 0.5rem; text-align: center; }
  .steps { grid-template-columns: 1fr; }
  .stats-band-inner { grid-template-columns: 1fr 1fr; }
  .team-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 480px) {
  .hero-stats { flex-wrap: wrap; }
  .stat-item { min-width: 120px; }
  .modal-box { padding: 1.5rem 1rem; border-radius: 16px; }
  .plans-grid { grid-template-columns: 1fr; }
  .stats-row { grid-template-columns: 1fr 1fr; gap: 0.7rem; }
  .logo { font-size: 1.1rem; }
  .hiw-step { flex-direction: column; gap: 1rem; }
  .hiw-step-num { width:50px; height:50px; min-width:50px; font-size:1.2rem; }
}
