.hero{background:radial-gradient(circle at 80% 10%,rgba(10,102,255,.22),transparent 28%),linear-gradient(180deg,#fff 0%,#f5f5f7 100%);padding:86px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
  .announcement-callout {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #eef4ff;
    border: 1px solid #dbe7ff;
    border-radius: 16px;
    padding: 12px 16px;
    margin-bottom: 16px;
    color: #174ea6;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    transition: all 0.2s ease;
  }
  .announcement-callout:hover {
    background: #dbe7ff;
    transform: translateY(-1px);
  }
  @keyframes pulse-badge {
    0% { box-shadow: 0 0 0 0 rgba(253, 224, 71, 0.4); }
    70% { box-shadow: 0 0 0 6px rgba(253, 224, 71, 0); }
    100% { box-shadow: 0 0 0 0 rgba(253, 224, 71, 0); }
  }
.eyebrow{display:inline-flex;gap:8px;align-items:center;background:#eef4ff;color:#174ea6;border:1px solid #dbe7ff;border-radius:999px;padding:8px 13px;font-weight:800;font-size:13px}
.hero h1{font-size:clamp(44px,7vw,78px);line-height:.96;letter-spacing:-.065em;margin:18px 0 18px}
.grad{background:linear-gradient(90deg,#0a66ff,#7c3aed);-webkit-background-clip:text;color:transparent}
.hero p{font-size:20px;color:#475467;max-width:680px;margin:0 0 26px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{background:#0a66ff;color:white;box-shadow:0 14px 35px rgba(10,102,255,.25)}
.btn-primary:hover{background:#004ecb;transform:translateY(-1px)}
.btn-secondary{background:white;border:1px solid #d0d5dd;color:#111827}
.btn-secondary:hover{border-color:#98a2b3;transform:translateY(-1px)}
.proof{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;color:#475467;font-size:14px}
.proof span{background:white;border:1px solid #e5e7eb;padding:8px 12px;border-radius:999px}
.hero-card{background:rgba(255,255,255,.84);border:1px solid rgba(255,255,255,.7);border-radius:36px;padding:22px;box-shadow:var(--shadow);backdrop-filter:blur(20px)}
.score-board{background:#050816;color:white;border-radius:28px;padding:26px;min-height:420px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.score-board:before{content:"";position:absolute;inset:auto -80px -120px auto;width:320px;height:320px;border-radius:50%;background:rgba(10,102,255,.38);filter:blur(10px)}
.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;position:relative}
.metric{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:18px}
.metric strong{display:block;font-size:34px;letter-spacing:-.04em}
.metric small{color:#cbd5e1}
.score-title h3,.score-title p{font-size:20px;margin:18px 0;font-weight:700;color:white}
.section{padding:72px 0}
.section-head{max-width:760px;margin-bottom:28px}
.section-head.center{text-align:center;margin-left:auto;margin-right:auto}
.section h2{font-size:clamp(34px,4.5vw,54px);line-height:1.02;letter-spacing:-.05em;margin:0 0 12px}
.section p.lead{font-size:18px;color:#667085;margin:0}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:white;border:1px solid #e5e7eb;border-radius:28px;padding:26px;box-shadow:0 16px 50px rgba(15,23,42,.06)}
.card h3{font-size:24px;margin:0 0 10px;letter-spacing:-.03em}
.card p{color:#667085;margin:0 0 18px}
.mini-list{list-style:none;margin:0;padding:0;display:grid;gap:10px;color:#344054}
.mini-list li:before{content:"✓";color:var(--green);font-weight:900;margin-right:8px}
.dark-band{background:#050816;color:white;border-radius:44px;padding:46px;box-shadow:var(--shadow)}
.dark-band p{color:#cbd5e1}
.journey{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.step{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10);border-radius:24px;padding:22px}
.step .num{color:#93c5fd;font-weight:900}
.step h3{margin:8px 0;font-size:20px}
.results{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.result-card{background:white;border-radius:30px;padding:28px;border:1px solid #e5e7eb}
.bar{height:10px;border-radius:999px;background:#e5e7eb;overflow:hidden;margin:12px 0 18px}
.bar span{display:block;height:100%;background:linear-gradient(90deg,#0a66ff,#7c3aed);border-radius:999px}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.quote{background:white;border:1px solid #e5e7eb;border-radius:28px;padding:24px}
.quote p{color:#344054}
.quote strong{display:block;margin-top:14px}
.programs{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}
.combo{background:linear-gradient(135deg,#111827,#0a66ff);color:white;border-radius:34px;padding:32px;box-shadow:var(--shadow)}
.combo p,.combo li{color:#dbeafe}
.side-cards{display:grid;gap:18px}
.form-wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:24px;align-items:start}
.form-card{background:white;border:1px solid #e5e7eb;border-radius:34px;padding:28px;box-shadow:var(--shadow)}
.fields{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-full{grid-column:1/-1}
label{display:block;font-size:13px;font-weight:800;color:#344054;margin-bottom:6px}
input,select,textarea{width:100%;border:1px solid #d0d5dd;border-radius:16px;padding:13px 14px;font:inherit;background:white}
textarea{min-height:108px;resize:vertical}
.alert{padding:14px 16px;border-radius:16px;margin-bottom:16px;font-weight:700}
.alert.success{background:#ecfdf3;color:#087443;border:1px solid #abefc6}
.alert.error{background:#fef3f2;color:#b42318;border:1px solid #fecdca}
.announcement-bar{background:linear-gradient(90deg,#0a66ff,#004ecb);color:white;padding:12px 0;position:relative;z-index:40}
.announcement-content{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.announcement-icon{font-size:20px}
.announcement-text{font-weight:600}
.announcement-cta{background:white;color:#0a66ff;padding:6px 12px;border-radius:999px;font-weight:bold;text-decoration:none}
.announcement-cta:hover{background:#f0f0f0}
.inside-gallery{margin-top:32px}
.inside-gallery h3{font-size:18px;font-weight:700;margin-bottom:4px;color:var(--text)}
.inside-gallery .gallery-sub{font-size:13px;color:var(--muted);margin-bottom:14px}
.gallery-scroll{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
.gallery-scroll::-webkit-scrollbar{height:4px}
.gallery-scroll::-webkit-scrollbar-track{background:#e5e7eb;border-radius:4px}
.gallery-scroll::-webkit-scrollbar-thumb{background:#0a66ff;border-radius:4px}
.gallery-item{min-width:180px;max-width:220px;border-radius:16px;overflow:hidden;border:1px solid #e5e7eb;background:white;cursor:pointer;transition:.2s;flex-shrink:0}
.gallery-item:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.gallery-item img{width:100%;height:120px;object-fit:cover;display:block}
.gallery-item .vid-overlay{position:relative}
.gallery-item .vid-overlay::after{content:"▶";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);color:#fff;font-size:28px;border-radius:16px}
.gallery-item .item-label{padding:8px 10px;font-size:13px;font-weight:600;color:var(--text)}
.gallery-item .item-meta{font-size:11px;color:var(--muted);padding:0 10px 8px}
.location-embed{margin-bottom:32px}
.location-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px}
.detail{text-align:center}
.detail h3{font-size:18px;font-weight:bold;margin-bottom:8px}
.detail p{color:#667085;line-height:1.5}
.media-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:9999;align-items:center;justify-content:center;padding:20px}
.media-modal.show{display:flex}
.media-modal .modal-inner{position:relative;max-width:900px;width:100%}
.media-modal .close-btn{position:absolute;top:-36px;right:0;background:#fff;color:#111;border:none;width:36px;height:36px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.15)}
.media-modal .close-btn:hover{background:#f3f3f3}
.media-modal .media-modal-img,.media-modal .media-modal-video{max-width:100%;max-height:80vh;border-radius:12px;display:block;margin:0 auto}
.media-modal .media-modal-video{background:#000;width:100%}
.media-caption{color:#fff;text-align:center;font-size:16px;font-weight:600;margin-top:12px}
@media(max-width:900px){.hero-grid,.programs,.form-wrap,.results{grid-template-columns:1fr}.pillars,.testimonials,.journey{grid-template-columns:1fr 1fr}.hero{padding-top:52px}.score-board{min-height:360px}}
@media(max-width:620px){.pillars,.testimonials,.journey,.fields{grid-template-columns:1fr}.hero h1{font-size:44px}.dark-band{padding:28px;border-radius:30px}.metric-grid{grid-template-columns:1fr}.section{padding:52px 0}}
.what-students-say{text-align:center;margin:24px 0 8px;padding:16px;background:linear-gradient(135deg,rgba(10,102,255,.08),rgba(124,58,237,.08));border-radius:20px;border:1px solid rgba(10,102,255,.15)}
.what-students-say a{color:#0a66ff;text-decoration:none;font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:white;border:2px solid #0a66ff;border-radius:50px;transition:all 0.3s ease;box-shadow:0 4px 12px rgba(10,102,255,.1)}
.what-students-say a:hover{background:linear-gradient(135deg,#0a66ff,#7c3aed);color:white;transform:translateY(-3px);box-shadow:0 8px 24px rgba(10,102,255,.35);border-color:transparent}
.what-students-say a::after{content:"→";font-size:18px;transition:transform 0.3s ease}
.what-students-say a:hover::after{transform:translateX(4px)}


.video-placeholder {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid #f0f0f0;
}

.video-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, #0a66ff, #7c3aed);
  color: white;
  border: none;
  border-radius: 12px;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(10, 102, 255, 0.25);
}

.video-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(10, 102, 255, 0.35);
}

.play-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: rgba(255, 255, 255, 0.25);
  border-radius: 50%;
  font-size: 10px;
  padding-left: 2px;
}

.video-btn:hover .play-icon {
  background: rgba(255, 255, 255, 0.35);
}

.media-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.9);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.media-modal.show {
  display: flex;
}

.media-modal .modal-inner {
  position: relative;
  max-width: 900px;
  width: 100%;
}

.media-modal .close-btn {
  position: absolute;
  top: -48px;
  right: 0;
  background: #fff;
  color: #111;
  border: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  transition: all 0.2s ease;
}

.media-modal .close-btn:hover {
  background: #f3f3f3;
  transform: rotate(90deg);
}

.media-modal .media-modal-video {
  max-width: 100%;
  max-height: 70vh;
  border-radius: 12px;
  display: block;
  margin: 0 auto;
  background: #000;
}

.media-caption {
  color: #fff;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  margin-top: 16px;
}

/* ==========================================
   VISUAL CASE STUDY STYLES
   ========================================== */
.visual-case-study {
  overflow: hidden;
}
.case-study-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.case-study-badge {
  background: #ecfdf3;
  color: #087443;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid #abefc6;
  white-space: nowrap;
}

/* SAT Graph Styles */
.score-graph-container {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 20px;
  margin-bottom: 20px;
  position: relative;
}
.blurred-report-card {
  position: relative;
}
.report-header {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
}
.blurred-line {
  height: 12px;
  background: #cbd5e1;
  border-radius: 6px;
  filter: blur(4px);
}
.blurred-line.short { width: 80px; }
.blurred-line.long { width: 140px; }
.graph-area {
  display: flex;
  height: 160px;
  gap: 16px;
}
.y-axis {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  font-size: 11px;
  color: #64748b;
  font-weight: 600;
  padding-top: 10px;
  padding-bottom: 10px;
}
.graph-line-wrapper {
  flex: 1;
  position: relative;
  border-bottom: 2px solid #e2e8f0;
  border-left: 2px solid #e2e8f0;
}
.graph-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.graph-label {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  transform: translateX(-50%);
}
.graph-label.start {
  bottom: -10px;
  left: 0;
}
.graph-label.end {
  bottom: -10px;
  right: 0;
  transform: translateX(50%);
}
.graph-label .score {
  font-size: 18px;
  font-weight: 900;
  color: #0f172a;
  line-height: 1;
}
.graph-label .time {
  font-size: 11px;
  color: #64748b;
  font-weight: 600;
}
.graph-label .growth {
  position: absolute;
  top: -32px;
  background: #16a34a;
  color: white;
  font-size: 12px;
  font-weight: 800;
  padding: 4px 8px;
  border-radius: 8px;
  white-space: nowrap;
  box-shadow: 0 4px 6px rgba(22, 163, 74, 0.2);
}
.graph-label .growth::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 50%;
  transform: translateX(-50%);
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid #16a34a;
}

/* AP Score Visual Styles */
.ap-score-visual {
  display: flex;
  align-items: center;
  gap: 24px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 20px;
  margin-bottom: 20px;
}
.ap-score-stack {
  display: flex;
  gap: 8px;
}
.ap-badge {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 900;
  color: white;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}
.ap-badge.score-5 { background: linear-gradient(135deg, #0a66ff, #7c3aed); }
.ap-badge.score-4 { background: linear-gradient(135deg, #16a34a, #059669); }
.ap-stat {
  display: flex;
  flex-direction: column;
}
.ap-stat-number {
  font-size: 28px;
  font-weight: 900;
  color: #0f172a;
  line-height: 1;
}
.ap-stat-label {
  font-size: 12px;
  color: #64748b;
  font-weight: 600;
  margin-top: 4px;
}

@media(max-width:620px) {
  .ap-score-visual {
    flex-direction: column;
    align-items: flex-start;
  }
  .graph-label .score {
    font-size: 16px;
  }
}

/* Announcement Bar Updates */
.limited-seats-badge {
  background: #fde047;
  color: #111827;
  padding: 4px 12px;
  border-radius: 99px;
  font-size: 13px;
  font-weight: 700;
  margin-left: 8px;
  text-decoration: none;
  display: inline-block;
  transition: all 0.2s ease;
  box-shadow: 0 2px 8px rgba(253, 224, 71, 0.3);
}

.limited-seats-badge:hover {
  background: #fbbf24;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(253, 224, 71, 0.4);
}

.coupon-badge {
  background: rgba(255, 255, 255, 0.2);
  padding: 4px 12px;
  border-radius: 8px;
  font-size: 13px;
  margin-left: 8px;
  display: inline-block;
}

.announcement-cta {
  background: white;
  color: #0a66ff;
  padding: 8px 16px;
  border-radius: 999px;
  font-weight: bold;
  text-decoration: none;
  transition: all 0.2s ease;
}

.announcement-cta:hover {
  background: #f0f0f0;
  transform: translateY(-1px);
}

/* QR Code Styles for Announcement Details */
.qr-code-section {
  background: #f9fafb;
  border-radius: 20px;
  padding: 32px;
  margin-top: 32px;
  text-align: center;
  border: 2px solid #e5e7eb;
}

.qr-code-section h4 {
  font-size: 20px;
  font-weight: 700;
  color: #111827;
  margin: 0 0 20px 0;
}

.qr-code-image {
  max-width: 280px;
  margin: 0 auto;
  padding: 16px;
  background: white;
  border-radius: 16px;
  border: 2px solid #e5e7eb;
  display: inline-block;
}

.qr-code-image img {
  width: 100%;
  height: auto;
  display: block;
}

.qr-code-label {
  margin-top: 16px;
  font-size: 16px;
  font-weight: 700;
  color: #dc2626;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.qr-code-label::before {
  content: "📱";
  font-size: 18px;
}

@media(max-width: 620px) {
  .limited-seats-badge {
    font-size: 12px;
    padding: 3px 10px;
  }
  
  .qr-code-image {
    max-width: 220px;
  }
  
  .announcement-content {
    flex-direction: column;
    gap: 10px;
  }
}

/* ==========================================
   ENLARGE GRAPH LINK STYLES
   ========================================== */
/* SAT Graph Click to Enlarge - Position below graph */
.enlarge-graph-text {
    text-align: center;
    margin-top: 16px;
    margin-bottom: 0;
    color: #0a66ff;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    transition: all 0.2s ease;
    user-select: none;
}

.enlarge-graph-text:hover {
    color: #004ecb;
    transform: translateY(-1px);
}

.enlarge-graph-text:hover svg {
    transform: scale(1.1);
    transition: transform 0.2s ease;
}

/* AP Header - Badge on left, title on right */
.case-study-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 12px;
}

.case-study-header h3 {
    margin: 0;
    flex: 1;
    text-align: right;
}

.case-study-header .case-study-badge {
    flex-shrink: 0;
}

@media(max-width: 620px) {
    .case-study-header {
        flex-direction: column !important;
        align-items: flex-start;
    }
    
    .case-study-header h3 {
        text-align: left;
        width: 100%;
    }
}

/* ==========================================
ANNOUNCEMENT BAR MULTI-ITEM SCROLL
========================================== */
.announcement-content {
    display: flex;
    align-items: flex-start; /* Align to top so scrolling works nicely */
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
}

.announcement-scroll-list-bar {
    max-height: 72px; /* Fits ~2 items comfortably */
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 8px;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.5) rgba(255, 255, 255, 0.1);
    flex: 1;
    max-width: 100%;
}

.announcement-scroll-list-bar::-webkit-scrollbar {
    width: 6px;
}

.announcement-scroll-list-bar::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 3px;
}

.announcement-scroll-list-bar::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.5);
    border-radius: 3px;
}

.announcement-item-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    padding: 6px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.announcement-item-bar:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.announcement-item-bar .announcement-text {
    font-weight: 600;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    flex: 1;
}

.announcement-item-bar .announcement-cta {
    background: white;
    color: #0a66ff;
    padding: 4px 12px;
    border-radius: 999px;
    font-weight: bold;
    text-decoration: none;
    font-size: 12px;
    flex-shrink: 0;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.announcement-item-bar .announcement-cta:hover {
    background: #f0f0f0;
    transform: translateY(-1px);
}

@media (max-width: 620px) {
    .announcement-content {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    
    .announcement-scroll-list-bar {
        width: 100%;
    }

    .announcement-item-bar {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        width: 100%;
    }
    
    .announcement-item-bar .announcement-cta {
        align-self: flex-start;
    }
}