/* ============================================================
   shwetaparna.com — Main Stylesheet  (Mobile-First)
   All colors via CSS custom properties set dynamically by CMS
   ============================================================ */

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);line-height:1.6;font-size:16px;overflow-x:hidden}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--color-primary);text-decoration:none}
a:hover{text-decoration:underline}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-heading);line-height:1.3;font-weight:700}
button,input,select,textarea{font-family:inherit;font-size:inherit}
table{width:100%;border-collapse:collapse}

/* ── Layout Utilities ──────────────────────────────────────── */
.container{max-width:1200px;margin:0 auto;padding:0 1rem;width:100%;box-sizing:border-box}
.section{padding:3.5rem 0}
.section-sm{padding:2rem 0}
.section-title{font-size:clamp(1.6rem,4vw,2.25rem);margin-bottom:0.5rem;text-align:center}
.section-subtitle{text-align:center;color:#6B7280;margin-bottom:2rem;font-size:1rem}
.text-center{text-align:center}
.flex{display:flex}
.flex-center{display:flex;align-items:center;justify-content:center}
/* Mobile-first grids — stack by default, expand on larger screens */
.grid-2,.grid-3,.grid-4{display:grid;grid-template-columns:1fr;gap:1.25rem}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}

/* ── Navigation ─────────────────────────────────────────────── */
.site-header{background:var(--color-nav-bg);color:var(--color-nav-text);position:sticky;top:0;z-index:1000;box-shadow:0 1px 3px rgba(0,0,0,.08)}
.nav-container{max-width:1200px;margin:0 auto;padding:0 1.25rem;display:flex;align-items:center;gap:1rem;height:68px}
.site-logo{display:flex;align-items:center;flex-shrink:0;padding-top:3px}
.logo-text{font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--color-primary)}
.nav-menu{display:none;position:fixed;top:64px;left:0;width:100%;right:0;bottom:0;background:var(--color-nav-bg);flex-direction:column;padding:1.25rem 1.5rem;overflow-y:auto;gap:0.25rem;border-top:1px solid var(--color-border);z-index:9998;overflow-x:hidden}
.nav-menu.open{display:flex}
.nav-menu a{color:var(--color-nav-text);padding:0.75rem 1rem;border-radius:6px;font-size:1rem;font-weight:500;display:block;transition:background .15s}
.nav-menu a:hover,.nav-menu li.active>a{background:rgba(0,0,0,.05);text-decoration:none}
.nav-cta-btn{background:var(--color-btn-bg)!important;color:var(--color-btn-text)!important;border-radius:8px!important;padding:0.6rem 1.25rem!important;font-weight:600!important}
.has-dropdown{position:relative}
.dropdown-arrow{font-size:0.7rem;margin-left:4px}
.dropdown-menu{display:none;padding-left:1rem;background:transparent}
.has-dropdown.open .dropdown-menu{display:block}
.dropdown-menu a{color:var(--color-text);padding:0.5rem 1rem;font-size:0.9rem;display:block}
.nav-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;margin-left:auto;flex-shrink:0}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--color-nav-text);border-radius:2px;transition:transform .25s,opacity .25s}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.65rem 1.35rem;border-radius:8px;font-weight:600;font-size:0.925rem;border:2px solid transparent;cursor:pointer;transition:all .15s;text-decoration:none;touch-action:manipulation}
.btn:hover{text-decoration:none;opacity:.9}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.btn-secondary{background:var(--color-secondary);color:#fff;border-color:var(--color-secondary)}
.btn-outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn-outline:hover{background:var(--color-primary);color:#fff}
.btn-sm{padding:0.4rem 1rem;font-size:.85rem}
.btn-lg{padding:0.875rem 1.75rem;font-size:1rem}
.btn-block{width:100%;justify-content:center}

/* ── Cards ───────────────────────────────────────────────────── */
.card{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;transition:box-shadow .2s,transform .2s}
.card:hover{box-shadow:0 8px 30px rgba(0,0,0,.1);transform:translateY(-2px)}
.card-img{width:100%;aspect-ratio:16/9;object-fit:cover}
.card-body{padding:1.1rem}
.card-title{font-size:1.05rem;font-weight:600;margin-bottom:0.5rem;color:var(--color-heading)}
.card-text{color:#6B7280;font-size:.9rem;line-height:1.6}
.card-footer{padding:0.75rem 1.1rem;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}

/* ── Badges ──────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}
.badge-offline{background:#FEF3C7;color:#92400E}
.badge-online{background:#D1FAE5;color:#065F46}
.badge-abroad{background:#DBEAFE;color:#1E40AF}
.badge-primary{background:rgba(124,58,237,.12);color:var(--color-primary)}
.badge-success{background:#D1FAE5;color:#065F46}
.badge-warning{background:#FEF3C7;color:#92400E}
.badge-danger{background:#FEE2E2;color:#991B1B}
.badge-secondary{background:#E5E7EB;color:#374151}

/* ── Forms ───────────────────────────────────────────────────── */
.form-group{margin-bottom:1.1rem}
.form-label{display:block;font-weight:500;margin-bottom:.375rem;font-size:.9rem;color:var(--color-heading)}
.form-label .required{color:#EF4444;margin-left:2px}
.form-control{width:100%;padding:.65rem .875rem;border:1.5px solid var(--color-border);border-radius:8px;font-size:1rem;background:#fff;color:var(--color-text);transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;appearance:none}
.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(124,58,237,.12)}
.form-control::placeholder{color:#9CA3AF}
textarea.form-control{resize:vertical;min-height:110px}
/* form-row: stacked on mobile, 2-col on tablet+ */
.form-row{display:grid;grid-template-columns:1fr;gap:0}
.form-error{color:#EF4444;font-size:.82rem;margin-top:4px}
.form-help,.form-hint{color:#6B7280;font-size:.8rem;margin-top:4px}
.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}
.radio-group{display:flex;flex-wrap:wrap;gap:.625rem}
.radio-card{border:2px solid var(--color-border);border-radius:8px;padding:.65rem 1rem;cursor:pointer;transition:border-color .15s;display:flex;align-items:center;gap:.5rem;font-size:.9rem;touch-action:manipulation}
.radio-card:has(input:checked){border-color:var(--color-primary);background:rgba(124,58,237,.05)}

/* ── Alerts ──────────────────────────────────────────────────── */
.alert{display:flex;align-items:flex-start;justify-content:space-between;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;border-left:4px solid;gap:.5rem}
.alert button{background:none;border:none;cursor:pointer;font-size:1.2rem;line-height:1;color:inherit;opacity:.7;flex-shrink:0}
.alert-success{background:#D1FAE5;color:#065F46;border-color:#10B981}
.alert-error{background:#FEE2E2;color:#991B1B;border-color:#EF4444}
.alert-warning{background:#FEF3C7;color:#92400E;border-color:#F59E0B}
.alert-info{background:#DBEAFE;color:#1E40AF;border-color:#3B82F6}

/* ── Hero Section ────────────────────────────────────────────── */
.hero{padding:2.5rem 0 2rem;background:linear-gradient(135deg,var(--color-card-bg) 0%,var(--color-bg) 100%);overflow:hidden;max-width:100vw}
.hero-content{max-width:600px;width:100%}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(124,58,237,.1);color:var(--color-primary);padding:5px 14px;border-radius:20px;font-size:.82rem;font-weight:600;margin-bottom:1rem}
.hero h1{font-size:clamp(1.75rem,5vw,3rem);line-height:1.2;margin-bottom:1rem}
.hero p{font-size:1rem;color:#4B5563;margin-bottom:1.5rem;line-height:1.7}
.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center}
.hero-image{display:none;border-radius:16px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.15)}

/* ── Stats Bar ───────────────────────────────────────────────── */
.stats-bar{background:var(--color-primary);color:#fff;padding:1.75rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;text-align:center;width:100%}
.stat-item h3{font-size:1.75rem;font-weight:700;color:#fff}
.stat-item p{font-size:.82rem;opacity:.85;margin-top:3px}

/* ── Video Grid ──────────────────────────────────────────────── */
.video-card{background:var(--color-card-bg);border-radius:12px;overflow:hidden;border:1px solid var(--color-border);transition:transform .2s,box-shadow .2s}
.video-card:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.1)}
.video-thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.video-thumb img{width:100%;height:100%;object-fit:cover}
.video-play-btn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3)}
.video-play-btn svg{width:48px;height:48px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}
.video-info{padding:.875rem}
.video-meta{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.4rem}

/* ── Exam UI ─────────────────────────────────────────────────── */
.exam-container{max-width:720px;margin:0 auto}
.exam-header{background:var(--color-primary);color:#fff;padding:1.25rem;border-radius:12px;margin-bottom:1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.exam-timer{font-size:1.4rem;font-weight:700;font-family:var(--font-heading)}
.exam-timer.warning{color:#FCD34D}
.exam-timer.danger{color:#FCA5A5;animation:pulse 1s infinite}
.question-card{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin-bottom:.875rem}
.question-num{font-size:.82rem;color:#6B7280;margin-bottom:.5rem}
.question-text{font-size:1rem;font-weight:500;margin-bottom:1rem;color:var(--color-heading);line-height:1.6}
.option-label{display:flex;align-items:flex-start;gap:.65rem;padding:.75rem .875rem;border:2px solid var(--color-border);border-radius:8px;cursor:pointer;margin-bottom:.4rem;transition:border-color .15s;touch-action:manipulation;font-size:.9rem}
.option-label:has(input:checked){border-color:var(--color-primary);background:rgba(124,58,237,.06)}
.option-label input{margin-top:2px;accent-color:var(--color-primary);flex-shrink:0}
.option-correct{border-color:#10B981!important;background:#D1FAE5!important}
.option-wrong{border-color:#EF4444!important;background:#FEE2E2!important}
.exam-progress{height:6px;background:#E5E7EB;border-radius:3px;overflow:hidden;margin-bottom:.875rem}
.exam-progress-bar{height:100%;background:var(--color-primary);transition:width .3s}

/* ── Achievers ───────────────────────────────────────────────── */
.achiever-card{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:14px;padding:1.25rem;text-align:center}
.achiever-photo{width:72px;height:72px;border-radius:50%;object-fit:cover;margin:0 auto .875rem;border:3px solid var(--color-primary)}
.achiever-photo-placeholder{width:72px;height:72px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:700;margin:0 auto .875rem}
.achiever-name{font-weight:600;font-size:1rem;color:var(--color-heading)}
.achiever-score{font-size:1.4rem;font-weight:700;color:var(--color-primary);margin:.25rem 0}

/* ── Blog ────────────────────────────────────────────────────── */
.post-card{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;transition:box-shadow .2s,transform .2s}
.post-card:hover{box-shadow:0 8px 28px rgba(0,0,0,.1);transform:translateY(-2px)}
.post-meta{display:flex;gap:.75rem;color:#6B7280;font-size:.82rem;margin-bottom:.625rem;flex-wrap:wrap}
.post-tag{background:rgba(124,58,237,.1);color:var(--color-primary);padding:2px 10px;border-radius:20px;font-size:.78rem;font-weight:500}
.post-content h2,.post-content h3{margin:1.375rem 0 .625rem}
.post-content p{margin-bottom:.875rem;line-height:1.8}
.post-content ul,.post-content ol{padding-left:1.4rem;margin-bottom:.875rem}
.post-content li{margin-bottom:.35rem;line-height:1.7}
.post-content img{border-radius:10px;margin:1.25rem 0;max-width:100%;height:auto}
.post-content blockquote{border-left:4px solid var(--color-primary);padding:.875rem 1.25rem;background:var(--color-card-bg);border-radius:0 8px 8px 0;margin:1.25rem 0;font-style:italic}
.post-content code{background:#F3F4F6;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:.88em}
.post-content pre{background:#1F2937;color:#F9FAFB;padding:1rem;border-radius:10px;overflow-x:auto;margin:1.25rem 0;-webkit-overflow-scrolling:touch}
.post-content table{width:100%;border-collapse:collapse;margin:1.25rem 0;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
.post-content th,.post-content td{padding:.5rem .875rem;border:1px solid var(--color-border);text-align:left;white-space:nowrap}
.post-content th{background:var(--color-card-bg);font-weight:600}

/* ── Popup ───────────────────────────────────────────────────── */
.popup-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9999;align-items:center;justify-content:center;padding:1rem}
.popup-overlay.popup-active{display:flex;animation:fadeIn .25s}
.popup-box{background:#fff;border-radius:16px;width:100%;max-width:460px;padding:1.75rem 1.5rem;position:relative;animation:slideUp .3s;max-height:90vh;overflow-y:auto;box-shadow:0 25px 60px rgba(0,0,0,.3)}
.popup-close{position:absolute;top:.875rem;right:.875rem;background:#F1F5F9;border:none;font-size:1.1rem;cursor:pointer;color:#374151;line-height:1;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;touch-action:manipulation;font-weight:700;z-index:1}
.popup-close:hover{background:#E2E8F0}
.popup-image{width:100%;border-radius:10px;margin-bottom:1rem}
.popup-title{font-size:1.2rem;font-weight:700;margin-bottom:.75rem;color:var(--color-heading);padding-right:2rem;line-height:1.4}
.popup-content{color:#4B5563;line-height:1.75;margin-bottom:1.25rem;font-size:.925rem}
.popup-btn{width:100%;justify-content:center;margin-top:.25rem}

/* ── Ads ─────────────────────────────────────────────────────── */
.ad-zone{text-align:center;padding:.4rem 0;overflow:hidden}
.ad-zone img{max-width:100%;height:auto;border-radius:8px}

/* ── Pagination ──────────────────────────────────────────────── */
.pagination ul{display:flex;gap:.35rem;justify-content:center;flex-wrap:wrap;padding:.5rem 0}
.pagination li a,.pagination li.active a{display:flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 .5rem;border-radius:8px;border:1.5px solid var(--color-border);color:var(--color-text);font-size:.9rem;transition:all .15s}
.pagination li.active a{background:var(--color-primary);border-color:var(--color-primary);color:#fff}
.pagination li a:hover{border-color:var(--color-primary);color:var(--color-primary);text-decoration:none}

/* ── Breadcrumbs ─────────────────────────────────────────────── */
.breadcrumb{display:flex;flex-wrap:wrap;gap:.35rem;font-size:.82rem;color:#6B7280;margin-bottom:1.25rem}
.breadcrumb a{color:#6B7280}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb li:not(:last-child)::after{content:" /";margin-left:.35rem}

/* ── Content + Sidebar layout ────────────────────────────────── */
.content-sidebar-layout{display:grid;grid-template-columns:1fr;gap:1.5rem}
.sidebar-widget{background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:12px;padding:1.1rem;margin-bottom:1.1rem}
.sidebar-widget h4{font-size:.95rem;font-weight:600;margin-bottom:.875rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}

/* ── Filter Bar ──────────────────────────────────────────────── */
.filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;-webkit-overflow-scrolling:touch}
.filter-btn{padding:.4rem .875rem;border:1.5px solid var(--color-border);border-radius:20px;background:transparent;color:var(--color-text);font-size:.85rem;cursor:pointer;transition:all .15s;touch-action:manipulation;white-space:nowrap}
.filter-btn:hover,.filter-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}

/* ── Page Header ─────────────────────────────────────────────── */
.page-header{background:linear-gradient(135deg,var(--color-card-bg),var(--color-bg));padding:2rem 0 1.5rem;margin-bottom:1.75rem;border-bottom:1px solid var(--color-border)}
.page-header h1{font-size:clamp(1.5rem,4vw,2.25rem)}
.page-header p{color:#6B7280;margin-top:.4rem;font-size:.975rem}

/* ── Animations ──────────────────────────────────────────────── */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ══════════════════════════════════════════════════════════════ */

/* ── Tablet 600px+ ───────────────────────────────────────────── */
@media(min-width:600px){
  .grid-2{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr 1fr;gap:1rem}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .popup-overlay{align-items:center}
  .popup-box{border-radius:16px}
}

/* ── Tablet 768px+ ───────────────────────────────────────────── */
@media(min-width:768px){
  .container{padding:0 1.5rem}
  .section{padding:4rem 0}
  .section-sm{padding:2.5rem 0}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .hero{padding:3.5rem 0 3rem}
  .hero p{font-size:1.05rem}
  .hero-cta{gap:1rem}
  .content-sidebar-layout{grid-template-columns:1fr 280px}
  /* Nav: switch from mobile hamburger to desktop inline */
  .nav-toggle{display:none}
  .nav-menu{display:flex!important;position:static;background:transparent;flex-direction:row;padding:0;overflow:visible;border:none;gap:.25rem;flex:1;justify-content:center;align-items:center}
  .nav-menu a{padding:.45rem .825rem;font-size:.9rem}
  .has-dropdown:hover .dropdown-menu{display:block}
  .dropdown-menu{position:absolute;top:100%;left:0;background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;min-width:175px;box-shadow:0 8px 24px rgba(0,0,0,.12);padding:.4rem;z-index:200}
  .dropdown-menu a{padding:.45rem .875rem;border-radius:6px;font-size:.875rem}
  .dropdown-menu a:hover{background:var(--color-card-bg)}
}

/* ── Desktop 1024px+ ─────────────────────────────────────────── */
@media(min-width:1024px){
  .nav-container{height:72px}
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .hero-grid{grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
  .hero-image{display:block}
  .hero{padding:5rem 0 4rem}
}

/* ── Contact page grid ───────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr;gap:1.75rem}
@media(min-width:768px){
  .contact-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
}

/* ── Exam take page mobile tweaks ────────────────────────────── */
@media(max-width:599px){
  .exam-header{flex-direction:column;gap:.5rem;text-align:center}
  .exam-timer{font-size:1.75rem}
}

/* ── Hero CTA full width on small phones ─────────────────────── */
@media(max-width:420px){
  .hero-cta .btn{width:100%;justify-content:center}
  .btn-lg{font-size:.95rem;padding:.75rem 1.25rem}
}

/* ── Fix inline grids in views that use style= ───────────────── */
@media(max-width:599px){
  /* Stats in result page */
  div[style*="grid-template-columns:repeat(3,1fr)"]{
    grid-template-columns:1fr!important
  }
  /* Stats in exam show page */
  div[style*="grid-template-columns:repeat(3,1fr)"]{
    grid-template-columns:1fr 1fr!important
  }
}

/* ── Footer ──────────────────────────────────────────────────── */
.site-footer{background:var(--color-footer-bg);color:var(--color-footer-text);padding:2.5rem 0 0}
.footer-container{max-width:1200px;margin:0 auto;padding:0 1.1rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;padding-bottom:2rem}
.footer-brand .footer-logo{font-size:1.25rem;font-weight:700;color:#fff;display:block;margin-bottom:.5rem}
.footer-brand .footer-tagline{font-size:.875rem;opacity:.75;margin-bottom:1rem}
.social-links{display:flex;gap:.75rem;flex-wrap:wrap}
.social-links a{color:var(--color-footer-text);opacity:.8;transition:opacity .15s;display:flex;align-items:center}
.social-links a:hover{opacity:1;text-decoration:none}
.footer-links h4,.footer-classes h4,.footer-contact h4{font-size:.875rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.875rem}
.footer-links ul,.footer-classes ul{display:flex;flex-direction:column;gap:.4rem}
.footer-links a,.footer-classes a{color:var(--color-footer-text);font-size:.875rem;opacity:.8;transition:opacity .15s}
.footer-links a:hover,.footer-classes a:hover{opacity:1;text-decoration:none}
.footer-contact p{font-size:.875rem;opacity:.8;margin-bottom:.5rem}
.footer-contact a{color:var(--color-footer-text)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.25rem 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;font-size:.82rem;opacity:.7;word-break:break-word}
.footer-bottom a{color:var(--color-footer-text)}
@media(min-width:768px){
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:1024px){
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}
}

/* ── Video card title ────────────────────────────────────────── */
.video-card-title{font-weight:600;font-size:.9rem;color:var(--color-heading);line-height:1.4}

/* ── Global mobile overflow prevention ──────────────────────── */
img,svg,video,iframe{max-width:100%}

/* ── Fix inline grids on small phones ───────────────────────── */
@media(max-width:480px){
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:2fr 1fr"]{grid-template-columns:1fr!important}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%;justify-content:center}
  .about-cta{flex-direction:column}
  .about-cta .btn{width:100%;justify-content:center}
  .exam-header{flex-direction:column;text-align:center;gap:.5rem}
  .card-footer{flex-direction:column;align-items:stretch}
  .card-footer .btn{width:100%;justify-content:center;margin-top:.25rem}
}

/* ── Fix nav z-index stacking ────────────────────────────────── */
.site-header{isolation:isolate}

/* ── Logo responsive fix ─────────────────────────────────────── */
.site-logo img{height:52px;width:auto;max-width:220px;object-fit:contain}
@media(max-width:400px){
  .site-logo img{height:40px;max-width:170px}
}

/* ── Footer logo ─────────────────────────────────────────────── */
.footer-brand a img{height:40px;width:auto;max-width:200px}
.footer-brand{overflow:hidden;word-wrap:break-word}

/* ── Definitive overflow fix ─────────────────────────────────── */
html,body{overflow-x:hidden;width:100%}
.container,.nav-container,.footer-container{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));width:100%;box-sizing:border-box}

/* Stats bar - prevent overflow on 360px */
.stats-bar{overflow:hidden}
.stats-grid{overflow:hidden}
.stat-item h3{font-size:clamp(1.4rem,5vw,2rem)}
.stat-item p{font-size:clamp(.72rem,2.5vw,.9rem)}

/* Hero - prevent content overflow */
.hero{overflow:hidden;width:100%}
.hero-badge{font-size:clamp(.72rem,2.5vw,.82rem)}
.hero p{font-size:clamp(.875rem,2.5vw,1rem)}

/* Nav - strict width control */
.site-header{overflow:hidden}

/* Filter bar - horizontal scroll instead of overflow */
.filter-bar{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.25rem;-ms-overflow-style:none;scrollbar-width:none}
.filter-bar::-webkit-scrollbar{display:none}

/* Badges - prevent overflow */
.badge{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}

/* Cards - strict width */
.card,.video-card,.post-card,.achiever-card{width:100%;box-sizing:border-box}

/* Grid columns - never exceed viewport */
.grid-2,.grid-3,.grid-4{width:100%;box-sizing:border-box}

/* Section CTA purple - fix padding */
section[style*="color-primary"]{padding:3rem 1rem!important;box-sizing:border-box;overflow:hidden}
