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

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  line-height: 1.6;
  color: #1a1a1a;
  background: #fff;
  overflow-x: hidden;
}

.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }

/* ========== HEADER ========== */
.site-header { background: #1a1a2e; }
.header-inner { display: flex; justify-content: space-between; align-items: center; padding-top: 18px; padding-bottom: 18px; }

/* Logo */
.header-logo { text-decoration: none; display: flex; flex-direction: column; }
.header-logo-name { color: #fff; font-size: 1.3rem; font-weight: 700; line-height: 1.2; }
.header-logo-tagline { color: #8b8ba3; font-size: 0.55rem; text-transform: uppercase; letter-spacing: 0.5px; }

/* Header action buttons */
.header-actions { display: flex; align-items: center; gap: 8px; }
.header-icon-btn { background: none; border: 1px solid #2a2a4a; color: #999; cursor: pointer; width: 40px; height: 40px; border-radius: 8px; display: flex; align-items: center; justify-content: center; position: relative; transition: all 0.2s; }
.header-icon-btn:hover { color: #fff; border-color: #4a4a6a; background: #2a2a4a; }

/* Gift badge (blinking) */
.header-badge { position: absolute; top: 4px; right: 4px; width: 8px; height: 8px; background: #ef4444; border-radius: 50%; animation: badge-pulse 2s infinite; }
@keyframes badge-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(0.8); }
}

/* Burger menu */
.header-burger { background: none; border: 1px solid #2a2a4a; cursor: pointer; width: 40px; height: 40px; border-radius: 8px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; transition: all 0.2s; }
.header-burger:hover { border-color: #4a4a6a; background: #2a2a4a; }
.header-burger span { display: block; width: 18px; height: 2px; background: #999; border-radius: 1px; transition: all 0.3s; }
.header-burger:hover span { background: #fff; }
.burger-open span:nth-child(1) { transform: rotate(45deg) translate(4px, 4px); }
.burger-open span:nth-child(2) { opacity: 0; }
.burger-open span:nth-child(3) { transform: rotate(-45deg) translate(4px, -4px); }

/* Navigation */
.header-nav { background: #12122a; overflow: hidden; max-height: 0; transition: max-height 0.3s ease; }
.header-nav.nav-open { max-height: 300px; }
.header-nav .container { display: flex; flex-direction: column; padding-top: 8px; padding-bottom: 8px; }
.header-nav a { color: #ccc; text-decoration: none; padding: 10px 0; font-size: 0.95rem; border-bottom: 1px solid #1a1a3a; }
.header-nav a:last-child { border-bottom: none; }
.header-nav a:hover { color: #fff; }

/* Desktop nav */
@media (min-width: 769px) {
  .header-burger { display: none; }
  .header-nav { max-height: none; background: #12122a; }
  .header-nav .container { flex-direction: row; gap: 0; padding-top: 0; padding-bottom: 0; }
  .header-nav a { padding: 10px 16px; border-bottom: none; font-size: 0.9rem; }
  .header-nav a:first-child { padding-left: 0; }
  .header-nav a:hover { background: #1a1a3a; }
}

/* Mobile header extra */
@media (max-width: 768px) {
  .header-inner { padding-top: 14px; padding-bottom: 14px; }
  .header-logo-name { font-size: 1.15rem; }
}

/* ========== HERO (homepage) ========== */
.hero { background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%); color: #fff; padding: 60px 0; text-align: center; }
.hero h1 { font-size: 2.2rem; margin-bottom: 16px; }
.hero p { font-size: 1.1rem; color: #b0b0c0; max-width: 600px; margin: 0 auto; }

/* ========== GRID ========== */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; margin-top: 20px; }

/* ========== CARDS (generic) ========== */
.school-card, .rating-card, .card {
  display: block; padding: 24px; border: 1px solid #e0e0e0; border-radius: 8px;
  text-decoration: none; color: inherit; transition: box-shadow 0.2s;
}
.school-card:hover, .rating-card:hover, .card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.school-card h3, .rating-card h3, .card h3 { margin-bottom: 8px; color: #1a1a2e; }

/* ========== CONTENT PAGES ========== */
.content-page { padding: 40px 0; }
.content-page h1 { font-size: 1.8rem; margin-bottom: 10px; line-height: 1.3; }
.content-page h2 { font-size: 1.35rem; margin-top: 36px; margin-bottom: 14px; padding-bottom: 8px; border-bottom: 2px solid #f0f0f0; }
.content-page p { margin-bottom: 16px; }
.content-page ul, .content-page ol { margin-bottom: 16px; padding-left: 24px; }
.content-page li { margin-bottom: 6px; }

/* Tables — responsive */
.content-page table { width: 100%; border-collapse: collapse; margin-bottom: 20px; display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.content-page th, .content-page td { padding: 10px 12px; border: 1px solid #e0e0e0; text-align: left; white-space: nowrap; }
.content-page th { background: #f5f5f5; font-size: 0.9rem; }

/* ========== BREADCRUMBS ========== */
.breadcrumbs { font-size: 0.8rem; color: #aaa; margin-bottom: 20px; margin-top: 12px; }
.breadcrumbs a { color: #aaa; text-decoration: none; }
.breadcrumbs a:hover { color: #888; }
.bc-sep { margin: 0 4px; color: #ccc; }

/* ========== EEAT BLOCK ========== */
.eeat-block { display: flex; justify-content: space-between; align-items: center; padding: 16px 0; border-bottom: 1px solid #f0f0f0; margin-bottom: 24px; gap: 12px; flex-wrap: wrap; }
.eeat-author { display: flex; align-items: center; gap: 10px; }
.eeat-avatar { width: 36px; height: 36px; background: #1a1a2e; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.8rem; flex-shrink: 0; }
.eeat-name { font-weight: 600; font-size: 0.9rem; display: block; }
.eeat-role { font-size: 0.8rem; color: #999; }
.eeat-meta { font-size: 0.8rem; color: #999; display: flex; gap: 12px; }
.eeat-bottom { border-bottom: none; border-top: 1px solid #f0f0f0; margin-top: 40px; padding-top: 20px; }
.eeat-bio { font-size: 0.85rem; color: #666; margin: 4px 0 0; max-width: 600px; }

/* ========== SCHOOL HERO ========== */
.school-hero { margin-bottom: 24px; }
.school-hero-title-row { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 8px; }
.school-hero-title-row h1 { margin: 0; padding-top: 2px; }
.school-logo-placeholder { flex-shrink: 0; }
.logo-stub { width: 56px; height: 56px; background: #e5e7eb; border-radius: 12px; }
.school-logo-placeholder img { width: 56px; height: 56px; border-radius: 12px; object-fit: cover; }
.school-tagline { font-size: 1rem; color: #666; margin-bottom: 16px; }
.cta-button-full { display: block; width: 100%; text-align: center; padding: 16px; font-size: 1.05rem; margin-top: 12px; }

/* ========== RATING BLOCK ========== */
.rating, .rating-badge { color: #f59e0b; font-weight: 600; margin-bottom: 8px; }
.rating-block { display: flex; align-items: center; gap: 16px; padding: 16px 20px; background: #fefce8; border: 1px solid #fde68a; border-radius: 10px; margin-bottom: 16px; }
.rating-score { display: flex; align-items: baseline; }
.rating-number { font-size: 2.4rem; font-weight: 800; color: #1a1a2e; line-height: 1; }
.rating-max { font-size: 1.2rem; color: #999; font-weight: 600; }
.rating-stars { color: #f59e0b; font-size: 1.1rem; letter-spacing: 2px; }
.rating-source { font-size: 0.75rem; color: #999; display: block; margin-top: 2px; }
.school-hero-cta { margin-top: 8px; }

/* ========== QUICK VERDICT (pros/cons) ========== */
.quick-verdict { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 24px; }
.qv-pros, .qv-cons { padding: 16px 20px; border-radius: 10px; }
.qv-pros { background: #f0fdf4; border: 1px solid #bbf7d0; }
.qv-cons { background: #fef2f2; border: 1px solid #fecaca; }
.qv-title { font-size: 0.9rem; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.5px; }
.qv-title-pro { color: #16a34a; }
.qv-title-con { color: #dc2626; }
.qv-pros ul, .qv-cons ul { list-style: none; padding: 0; margin: 0; }
.qv-pros li, .qv-cons li { font-size: 0.9rem; padding: 3px 0; }
.qv-pros li::before { content: "✓ "; color: #16a34a; font-weight: 700; }
.qv-cons li::before { content: "✗ "; color: #dc2626; font-weight: 700; }

/* ========== QUICK FACTS ========== */
.quick-facts { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px; }
.fact { background: #f5f7fa; border-radius: 8px; padding: 10px 16px; }
.fact-label { display: block; font-size: 0.7rem; color: #888; text-transform: uppercase; letter-spacing: 0.5px; }
.fact-value { font-weight: 600; font-size: 0.9rem; }

/* ========== TOC ========== */
.toc-block { background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 8px; padding: 16px 20px; margin-bottom: 32px; }
.toc-block ul { list-style: none; padding: 0; margin: 8px 0 0; columns: 2; }
.toc-block li { margin-bottom: 4px; }
.toc-block a { color: #2563eb; text-decoration: none; font-size: 0.9rem; }
.toc-block a:hover { text-decoration: underline; }

/* ========== PROGRAMS GRID ========== */
.programs-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; margin: 16px 0; }
.program-card { padding: 16px; background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 8px; }
.program-card h4 { font-size: 1rem; margin-bottom: 4px; }
.program-age { font-size: 0.8rem; color: #16a34a; font-weight: 600; display: inline-block; background: #f0fdf4; padding: 2px 8px; border-radius: 4px; margin-bottom: 6px; }
.program-card p { font-size: 0.9rem; color: #555; margin: 0; }

/* ========== DETAILED PROS/CONS ========== */
.detailed-pros-cons { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin: 16px 0; }
.dpc-column { padding: 20px; border-radius: 10px; }
.dpc-column h3 { font-size: 1rem; margin-bottom: 14px; padding-bottom: 8px; border-bottom: 2px solid; }
.dpc-pros { background: #f0fdf4; border: 1px solid #bbf7d0; }
.dpc-pros h3 { color: #16a34a; border-color: #bbf7d0; }
.dpc-cons { background: #fef2f2; border: 1px solid #fecaca; }
.dpc-cons h3 { color: #dc2626; border-color: #fecaca; }
.dpc-item { display: flex; gap: 10px; margin-bottom: 12px; }
.dpc-item:last-child { margin-bottom: 0; }
.dpc-icon { width: 24px; height: 24px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.75rem; font-weight: 700; flex-shrink: 0; margin-top: 2px; }
.dpc-icon-pro { background: #dcfce7; color: #16a34a; }
.dpc-icon-con { background: #fee2e2; color: #dc2626; }
.dpc-item strong { font-size: 0.9rem; display: block; }
.dpc-item p { font-size: 0.85rem; color: #666; margin: 2px 0 0; }

@media (max-width: 768px) {
  .detailed-pros-cons { grid-template-columns: 1fr; }
}

/* ========== STEPS ========== */
.steps-block { margin: 16px 0; }
.step { display: flex; align-items: flex-start; gap: 16px; padding: 14px 0; border-bottom: 1px solid #f0f0f0; }
.step:last-child { border-bottom: none; }
.step-num { width: 36px; height: 36px; background: #1a1a2e; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.9rem; flex-shrink: 0; }
.step p { margin: 4px 0 0; font-size: 0.9rem; color: #555; }

/* ========== REVIEWS ========== */
.reviews-list { display: grid; gap: 12px; margin: 16px 0; }
.review-card { padding: 20px; background: #fafafa; border: 1px solid #e5e7eb; border-radius: 10px; border-left: 4px solid #f59e0b; }
.review-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.review-author { font-weight: 700; font-size: 0.95rem; }
.review-stars { color: #f59e0b; letter-spacing: 1px; }
.review-text { font-style: italic; color: #333; margin-bottom: 10px; font-size: 0.95rem; }
.review-footer { display: flex; justify-content: space-between; font-size: 0.8rem; color: #999; flex-wrap: wrap; gap: 8px; }
.review-source { background: #f0f0f0; padding: 2px 8px; border-radius: 4px; }
.reviews-link { font-size: 0.9rem; text-align: center; margin-top: 8px; }
.reviews-link a { color: #2563eb; }

/* ========== FAQ ACCORDION ========== */
.faq-accordion { margin: 16px 0; }
.faq-accordion .faq-item { border: 1px solid #e5e7eb; border-radius: 8px; margin-bottom: 8px; overflow: hidden; }
.faq-accordion summary { padding: 14px 20px; font-weight: 600; font-size: 0.95rem; cursor: pointer; background: #f9fafb; list-style: none; display: flex; justify-content: space-between; align-items: center; }
.faq-accordion summary::-webkit-details-marker { display: none; }
.faq-accordion summary::after { content: "+"; font-size: 1.3rem; color: #888; font-weight: 400; }
.faq-accordion details[open] summary::after { content: "−"; }
.faq-accordion details[open] summary { border-bottom: 1px solid #e5e7eb; }
.faq-accordion .faq-item p { padding: 14px 20px; margin: 0; font-size: 0.95rem; color: #555; }

/* ========== VERDICT ========== */
.verdict-block { display: flex; gap: 24px; align-items: flex-start; padding: 24px; background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%); color: #fff; border-radius: 12px; margin: 20px 0; }
.verdict-rating { font-size: 3rem; font-weight: 800; line-height: 1; flex-shrink: 0; }
.verdict-rating span { font-size: 1.4rem; font-weight: 400; opacity: 0.6; }
.verdict-text strong { font-size: 1.1rem; display: block; margin-bottom: 8px; }
.verdict-text p { color: #b0b0c0; margin-bottom: 8px; font-size: 0.95rem; }
.verdict-text a { color: #93c5fd; }

/* ========== CTA ========== */
.cta-box { margin: 32px 0; padding: 24px; background: #f0fdf4; border-radius: 10px; text-align: center; }
.cta-box h3 { margin-bottom: 8px; font-size: 1.2rem; }
.cta-box p { color: #666; margin-bottom: 16px; }
.cta-button {
  display: inline-block; padding: 14px 32px; background: #16a34a; color: #fff;
  text-decoration: none; border-radius: 6px; font-size: 1rem; font-weight: 600;
}
.cta-button:hover { background: #15803d; }

/* ========== INTERLINKS ========== */
.interlink-box { display: flex; align-items: center; gap: 16px; padding: 16px 20px; border: 1px solid #e0e0e0; border-radius: 8px; margin: 28px 0; flex-wrap: wrap; }
.interlink-promo { border-color: #fbbf24; background: #fffbeb; }
.interlink-box-content { flex: 1; min-width: 200px; }
.interlink-box-content p { margin: 2px 0 0; color: #666; font-size: 0.85rem; }
.interlink-section { margin: 36px 0; }
.interlink-section h2 { border-bottom: none; }
.interlink-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 10px; }
.interlink-card { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border: 1px solid #e0e0e0; border-radius: 8px; text-decoration: none; color: #1a1a2e; transition: all 0.2s; font-size: 0.9rem; }
.interlink-card:hover { border-color: #16a34a; box-shadow: 0 2px 8px rgba(0,0,0,0.06); }
.interlink-arrow { color: #16a34a; font-weight: 700; font-size: 1.1rem; }
.interlink-position { background: #1a1a2e; color: #fff; border-radius: 50%; width: 26px; height: 26px; display: inline-flex; align-items: center; justify-content: center; font-size: 0.8rem; font-weight: 700; margin-right: 8px; flex-shrink: 0; }

.btn-outline { display: inline-block; padding: 8px 18px; border: 2px solid #1a1a2e; color: #1a1a2e; text-decoration: none; border-radius: 6px; text-align: center; font-weight: 600; font-size: 0.85rem; white-space: nowrap; }
.btn-outline:hover { background: #1a1a2e; color: #fff; }

/* ========== COMPARE ========== */
.compare-subtitle { font-size: 1.1rem; color: #666; margin-bottom: 24px; }
.compare-table-wrap { overflow-x: auto; margin-bottom: 32px; }
.compare-table { width: 100%; border-collapse: collapse; }
.compare-table th, .compare-table td { padding: 14px 16px; border: 1px solid #e0e0e0; text-align: center; }
.compare-table th { background: #1a1a2e; color: #fff; font-size: 1rem; }
.compare-table td:first-child { text-align: left; font-weight: 600; background: #f9f9f9; }
.school-col { min-width: 180px; }
.compare-cta { display: flex; gap: 16px; justify-content: center; margin: 32px 0; flex-wrap: wrap; }
.cta-button-alt { background: #2563eb; }
.cta-button-alt:hover { background: #1d4ed8; }

/* ========== RATINGS PAGE ========== */
.rating-intro { font-size: 1.05rem; color: #666; margin-bottom: 28px; }

/* Methodology */
.methodology-block { background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 10px; padding: 20px; margin-bottom: 28px; }
.methodology-header { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.methodology-icon { font-size: 1.2rem; }
.methodology-criteria { display: flex; flex-direction: column; gap: 8px; }
.methodology-item { display: flex; align-items: center; gap: 10px; }
.methodology-label { font-size: 0.85rem; font-weight: 600; min-width: 140px; }
.methodology-bar-bg { flex: 1; height: 8px; background: #e5e7eb; border-radius: 4px; overflow: hidden; }
.methodology-bar { height: 100%; background: #16a34a; border-radius: 4px; }
.methodology-pct { font-size: 0.8rem; color: #888; min-width: 32px; text-align: right; }

/* Quick navigation */
.rating-quicknav { background: #fefce8; border: 1px solid #fde68a; border-radius: 10px; padding: 16px 20px; margin-bottom: 28px; }
.rating-quicknav strong { font-size: 0.9rem; display: block; margin-bottom: 8px; }
.rating-quicknav-list { display: flex; flex-wrap: wrap; gap: 8px; }
.rating-quicknav-item { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: #fff; border: 1px solid #fde68a; border-radius: 6px; text-decoration: none; color: #1a1a2e; font-size: 0.85rem; font-weight: 500; transition: all 0.2s; }
.rating-quicknav-item:hover { border-color: #f59e0b; background: #fffbeb; }
.rating-quicknav-pos { background: #1a1a2e; color: #fff; width: 20px; height: 20px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 0.7rem; font-weight: 700; }

/* School cards in rating */
.rating-schools-list { margin: 28px 0; }
.rating-school-card { border: 1px solid #e0e0e0; border-radius: 12px; padding: 24px; margin-bottom: 16px; transition: box-shadow 0.2s; }
.rating-school-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.07); }
.rating-school-card:first-child { border: 2px solid #f59e0b; background: #fffdf7; }

.rsc-header { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.rsc-position { position: relative; min-width: 44px; text-align: center; }
.rsc-pos-num { font-size: 1.8rem; font-weight: 800; color: #1a1a2e; }
.rsc-crown { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); font-size: 1.1rem; color: #f59e0b; }
.rsc-logo-stub { width: 48px; height: 48px; background: #e5e7eb; border-radius: 10px; flex-shrink: 0; }
.rsc-title h3 { font-size: 1.1rem; margin: 0; }
.rsc-rating { color: #f59e0b; font-weight: 600; font-size: 0.9rem; }

.rsc-description { font-size: 0.95rem; color: #555; margin-bottom: 12px; }

.rsc-highlights { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.rsc-highlight { font-size: 0.8rem; padding: 4px 10px; background: #f0fdf4; color: #16a34a; border-radius: 20px; font-weight: 500; }

.rsc-footer { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; padding-top: 14px; border-top: 1px solid #f0f0f0; }
.rsc-price { display: flex; align-items: center; gap: 10px; }
.price-tag { display: inline-block; background: #f0fdf4; color: #16a34a; padding: 4px 12px; border-radius: 4px; font-weight: 600; font-size: 0.85rem; }
.rsc-trial { font-size: 0.8rem; color: #888; }
.rsc-actions { display: flex; gap: 8px; }

/* Expandable details */
.rsc-details { margin-top: 14px; border-top: 1px solid #f0f0f0; }
.rsc-expand-btn { padding: 12px 0; font-weight: 600; font-size: 0.9rem; color: #2563eb; cursor: pointer; list-style: none; display: flex; align-items: center; gap: 6px; }
.rsc-expand-btn::-webkit-details-marker { display: none; }
.rsc-expand-btn::after { content: "▾"; font-size: 0.8rem; transition: transform 0.2s; }
.rsc-details[open] .rsc-expand-btn::after { transform: rotate(180deg); }
.rsc-details-content { padding: 4px 0 8px; }

/* Scores by criteria */
.rsc-scores { margin-bottom: 16px; }
.rsc-scores h4 { font-size: 0.9rem; margin-bottom: 10px; color: #555; }
.rsc-score-row { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.rsc-score-label { font-size: 0.8rem; min-width: 130px; color: #555; }
.rsc-score-bar-bg { flex: 1; height: 6px; background: #e5e7eb; border-radius: 3px; overflow: hidden; }
.rsc-score-bar { height: 100%; background: #f59e0b; border-radius: 3px; }
.rsc-score-val { font-size: 0.8rem; font-weight: 600; min-width: 36px; text-align: right; color: #1a1a2e; }

/* Mini pros/cons */
.rsc-mini-verdict { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.rsc-mini-pros ul, .rsc-mini-cons ul { list-style: none; padding: 0; margin: 6px 0 0; }
.rsc-mini-pros strong { color: #16a34a; font-size: 0.85rem; }
.rsc-mini-cons strong { color: #dc2626; font-size: 0.85rem; }
.rsc-mini-pros li { font-size: 0.85rem; padding: 2px 0; }
.rsc-mini-pros li::before { content: "✓ "; color: #16a34a; font-weight: 700; }
.rsc-mini-cons li { font-size: 0.85rem; padding: 2px 0; }
.rsc-mini-cons li::before { content: "✗ "; color: #dc2626; font-weight: 700; }

/* Internal links */
.rsc-links { display: flex; flex-wrap: wrap; gap: 8px; }
.rsc-links a { font-size: 0.85rem; color: #2563eb; text-decoration: none; padding: 6px 12px; border: 1px solid #dbeafe; border-radius: 6px; transition: all 0.2s; }
.rsc-links a:hover { background: #eff6ff; border-color: #93c5fd; }

@media (max-width: 768px) {
  .rsc-mini-verdict { grid-template-columns: 1fr; }
  .rsc-score-label { min-width: 90px; }
  .rsc-links { flex-direction: column; }
  .rsc-links a { text-align: center; }
}

/* Summary table */
.rating-compare-section { margin-top: 36px; }
.rating-summary-table td:first-child { text-align: center; font-weight: 700; }
.rating-summary-table a { color: #2563eb; text-decoration: none; font-weight: 600; }
.rating-summary-table a:hover { text-decoration: underline; }

/* ========== PROMOCODES ========== */
.promo-list { margin-top: 24px; }
.promo-card { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; border: 2px dashed #e0e0e0; border-radius: 8px; margin-bottom: 12px; flex-wrap: wrap; gap: 12px; }
.promo-discount { font-size: 1.4rem; font-weight: 700; color: #dc2626; }
.promo-desc { margin-top: 2px; color: #666; font-size: 0.9rem; }
.promo-expires { font-size: 0.8rem; color: #999; }
.promo-action { text-align: center; }
.promo-code { background: #f5f5f5; border: 2px dashed #ccc; padding: 8px 16px; font-family: monospace; font-size: 1.1rem; font-weight: 700; letter-spacing: 2px; margin-bottom: 8px; border-radius: 4px; }

/* ========== SECTIONS (homepage) ========== */
.schools-grid, .ratings-section, .blog-section { padding: 48px 0; }
.schools-grid h2, .ratings-section h2, .blog-section h2 { font-size: 1.5rem; }

/* ========== BLOG ========== */
.blog-preview { margin-bottom: 24px; padding-bottom: 24px; border-bottom: 1px solid #eee; }
.blog-preview h3 a { color: #1a1a2e; text-decoration: none; }
.blog-preview h3 a:hover { color: #16a34a; }
.blog-preview time { color: #888; font-size: 0.9rem; }

/* ========== FOOTER ========== */
.site-footer { background: #f5f5f5; padding: 24px 0; margin-top: 48px; text-align: center; color: #888; font-size: 0.9rem; }

/* ========== MOBILE ========== */
@media (max-width: 768px) {
  .container { padding: 0 16px; }
  .hero h1 { font-size: 1.5rem; }
  .hero p { font-size: 1rem; }
  .content-page h1 { font-size: 1.4rem; }
  .content-page h2 { font-size: 1.15rem; }

  /* Grid single column */
  .grid, .programs-grid { grid-template-columns: 1fr; }

  /* School hero stacked */
  .school-hero-top { flex-direction: row; align-items: center; }
  .logo-stub { width: 56px; height: 56px; }

  /* Rating block */
  .rating-block { flex-direction: column; align-items: flex-start; gap: 8px; }
  .rating-number { font-size: 2rem; }

  /* Quick verdict */
  .quick-verdict { grid-template-columns: 1fr; }

  /* Quick facts */
  .quick-facts { gap: 8px; }
  .fact { padding: 8px 12px; }

  /* TOC single column */
  .toc-block ul { columns: 1; }

  /* Tables scroll */
  .content-page table { font-size: 0.85rem; }
  .content-page th, .content-page td { padding: 8px 10px; }

  /* Ratings */
  .rsc-header { flex-wrap: wrap; }
  .rsc-footer { flex-direction: column; align-items: stretch; }
  .rsc-actions { width: 100%; }
  .rsc-actions .cta-button, .rsc-actions .btn-outline { flex: 1; text-align: center; font-size: 0.85rem; padding: 10px; }
  .methodology-label { min-width: 100px; font-size: 0.8rem; }
  .rating-quicknav-list { gap: 6px; }

  /* Verdict stacked */
  .verdict-block { flex-direction: column; align-items: center; text-align: center; }
  .verdict-rating { font-size: 2.5rem; }

  /* Promo cards */
  .promo-card { flex-direction: column; text-align: center; }

  /* Interlinks */
  .interlink-box { flex-direction: column; text-align: center; }
  .interlink-grid { grid-template-columns: 1fr; }

  /* EEAT */
  .eeat-block { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 400px) {
  .container { padding: 0 12px; }
  .content-page h1 { font-size: 1.25rem; }
  .school-hero-top { gap: 12px; }
}
