
.prog-page { font-family: var(--vims-font, "Inter", system-ui, sans-serif); color: var(--vims-gray-900, #1a1a1a); }
.prog-page section { padding: 4rem 1rem; }
.prog-page .container { max-width: 1100px; margin: 0 auto; }

/* Hero */
.prog-hero { background: var(--vims-primary-gradient, linear-gradient(135deg, #1a3020 0%, #0f1d13 100%)); color: #fff; padding: 4rem 1rem 3rem; }
.prog-hero-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 3rem; align-items: start; }
.prog-hero-badge { display: inline-flex; align-items: center; gap: 0.4rem; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.25); padding: 0.4rem 1rem; border-radius: 999px; font-size: 0.8rem; margin-bottom: 1.25rem; }
.prog-hero-badge::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--vims-gold, #d4af37); }
.prog-hero h1 { font-size: clamp(1.85rem, 4vw, 2.75rem); margin: 0 0 0.75rem; line-height: 1.15; font-weight: 700; }
.prog-hero h1 .hl { color: var(--vims-gold, #d4af37); display: block; font-size: 0.7em; font-weight: 600; margin-top: 0.3rem; }
.prog-hero p.tagline { font-size: 1.05rem; opacity: 0.9; line-height: 1.6; margin: 0 0 1.5rem; }
.prog-hero-meta { display: flex; flex-wrap: wrap; gap: 1.25rem; font-size: 0.9rem; opacity: 0.92; margin-bottom: 1.5rem; }
.prog-hero-meta span::before { content: "✓ "; color: var(--vims-gold, #d4af37); font-weight: 700; }
.prog-hero-cta { display: flex; flex-wrap: wrap; gap: 0.6rem; }
.prog-hero-cta a { padding: 0.85rem 1.4rem; border-radius: 6px; text-decoration: none; font-weight: 600; font-size: 0.95rem; }
.prog-hero-cta a.cta-primary { background: var(--vims-bronze, #a97d5c); color: #fff; }
.prog-hero-cta a.cta-primary:hover { background: #8e6845; }
.prog-hero-cta a.cta-secondary { background: rgba(255,255,255,0.1); color: #fff; border: 1px solid rgba(255,255,255,0.3); }
.prog-hero-cta a.cta-secondary:hover { background: rgba(255,255,255,0.18); }
.prog-hero-form { background: #fff; border-radius: 12px; padding: 0; overflow: hidden; box-shadow: 0 12px 32px rgba(0,0,0,0.25); }
@media (max-width: 860px) { .prog-hero-grid { grid-template-columns: 1fr; } }

/* Trust strip */
.prog-trust { background: #f5f1e8; padding: 1.5rem 1rem; border-bottom: 1px solid #e0d8c8; }
.prog-trust-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 1rem; max-width: 1100px; margin: 0 auto; }
.prog-trust-item { text-align: center; }
.prog-trust-item .label { display: block; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--vims-bronze, #a97d5c); font-weight: 700; margin-bottom: 0.3rem; }
.prog-trust-item .value { display: block; font-size: 0.95rem; color: var(--vims-primary, #1a3020); font-weight: 600; line-height: 1.3; }

/* Section headers */
.section-eyebrow { text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.75rem; color: var(--vims-bronze, #a97d5c); font-weight: 700; margin-bottom: 0.5rem; display: block; }
.section-title { font-size: clamp(1.5rem, 3vw, 2.25rem); margin: 0 0 1rem; line-height: 1.2; color: var(--vims-primary, #1a3020); font-weight: 700; }
.section-subtitle { font-size: 1.05rem; color: var(--vims-gray-700, #555); max-width: 720px; margin: 0 0 2.5rem; line-height: 1.7; }

/* Daily work narrative */
.daily-work-section { background: #fff; }
.daily-work-narrative { background: #faf7f0; border-left: 4px solid var(--vims-bronze, #a97d5c); padding: 1.5rem 1.75rem; border-radius: 4px; font-size: 1.05rem; line-height: 1.8; color: #333; }

/* Curriculum */
.curr-section { background: #f5f1e8; }
.curr-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; margin-top: 1.5rem; }
.curr-card { background: #fff; border: 1px solid #e0d8c8; border-radius: 8px; padding: 1.5rem; }
.curr-card h3 { font-size: 1.05rem; margin: 0 0 1rem; color: var(--vims-primary, #1a3020); padding-bottom: 0.6rem; border-bottom: 2px solid var(--vims-bronze, #a97d5c); }
.curr-card ul { margin: 0; padding-left: 1.2rem; font-size: 0.93rem; line-height: 1.7; color: #444; }
.curr-card ul li { margin-bottom: 0.3rem; }

/* Employers logo grid */
.emp-section { background: #fff; }
.emp-summary { font-size: 1rem; line-height: 1.7; color: #444; margin: 0 0 2rem; }
.logo-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-bottom: 1.5rem; }
.logo-cell { background: #faf7f0; border: 1px solid #e0d8c8; border-radius: 6px; height: 110px; display: flex; align-items: center; justify-content: center; padding: 1rem; text-align: center; }
.logo-cell img { max-width: 100%; max-height: 70%; object-fit: contain; }
.logo-cell .logo-text { font-size: 0.9rem; font-weight: 600; color: var(--vims-bronze, #a97d5c); line-height: 1.3; }
.logo-cell .logo-cat { display: block; font-size: 0.68rem; color: #999; font-weight: 400; margin-top: 0.3rem; text-transform: uppercase; letter-spacing: 0.05em; }
@media (max-width: 720px) { .logo-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 380px) { .logo-grid { grid-template-columns: 1fr; } .logo-cell { height: 90px; } }
.emp-disclaimer { font-size: 0.82rem; color: #888; font-style: italic; }

/* Salary */
.salary-section { background: #f5f1e8; }
.salary-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-top: 1.5rem; }
.salary-card { background: #fff; border: 1px solid #e0d8c8; border-radius: 8px; padding: 1.5rem; text-align: center; }
.salary-card .label { display: block; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--vims-bronze, #a97d5c); font-weight: 700; margin-bottom: 0.5rem; }
.salary-card .amount { display: block; font-size: 1.6rem; color: var(--vims-primary, #1a3020); font-weight: 700; line-height: 1.2; margin-bottom: 0.4rem; }
.salary-card .amount-prefix { font-size: 0.8em; opacity: 0.7; }
.salary-card .experience { font-size: 0.85rem; color: #666; }
.salary-disclaimer { font-size: 0.82rem; color: #666; font-style: italic; margin-top: 1.5rem; line-height: 1.6; }
@media (max-width: 600px) { .salary-grid { grid-template-columns: 1fr; } }

/* Career pathway */
.career-section { background: #fff; }
.career-list { margin-top: 1.5rem; }
.career-item { background: #faf7f0; border-left: 4px solid var(--vims-bronze, #a97d5c); padding: 1rem 1.25rem; border-radius: 4px; margin-bottom: 0.75rem; }
.career-item strong { display: block; color: var(--vims-primary, #1a3020); font-size: 1.02rem; margin-bottom: 0.25rem; }
.career-item span { color: #555; font-size: 0.93rem; line-height: 1.6; }

/* Why this program */
.why-section { background: var(--vims-primary, #1a3020); color: #fff; }
.why-section .section-title, .why-section .section-eyebrow { color: #fff; }
.why-section .section-eyebrow { color: var(--vims-gold, #d4af37); }
.why-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.25rem; margin-top: 2rem; }
.why-item { background: rgba(255,255,255,0.05); padding: 1.5rem; border-radius: 8px; border-top: 3px solid var(--vims-gold, #d4af37); }
.why-item h4 { margin: 0 0 0.5rem; font-size: 1.05rem; color: var(--vims-gold, #d4af37); }
.why-item p { font-size: 0.92rem; line-height: 1.65; opacity: 0.92; margin: 0; }

/* Admission process */
.process-section { background: #f5f1e8; }
.process-list { counter-reset: step; padding: 0; list-style: none; max-width: 800px; margin: 1.5rem auto 0; }
.process-list li { counter-increment: step; padding: 1rem 1.5rem 1rem 4.5rem; position: relative; background: #fff; border-radius: 6px; margin-bottom: 0.75rem; border: 1px solid #e0d8c8; }
.process-list li::before { content: counter(step); position: absolute; left: 1rem; top: 1rem; width: 2.4rem; height: 2.4rem; background: var(--vims-bronze, #a97d5c); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1rem; }
.process-list li strong { color: var(--vims-primary, #1a3020); display: block; font-size: 1.05rem; margin-bottom: 0.2rem; }
.process-list li span { color: #555; font-size: 0.92rem; line-height: 1.6; }

/* FAQ */
.faq-section { background: #fff; }
.faq-item { background: #faf7f0; border: 1px solid #e0d8c8; border-radius: 6px; margin-bottom: 0.75rem; overflow: hidden; }
.faq-item summary { padding: 1rem 1.25rem; cursor: pointer; font-weight: 600; color: var(--vims-primary, #1a3020); list-style: none; position: relative; padding-right: 2.5rem; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; position: absolute; right: 1.25rem; top: 50%; transform: translateY(-50%); color: var(--vims-bronze, #a97d5c); font-size: 1.5rem; transition: transform 0.2s ease; }
.faq-item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq-item .faq-body { padding: 0 1.25rem 1rem; font-size: 0.95rem; line-height: 1.75; color: #444; }

/* Bottom apply form */
.apply-form-section { background: var(--vims-primary, #1a3020); color: #fff; padding: 4rem 1rem; }
.apply-form-section .container { max-width: 700px; }
.apply-form-section h2, .apply-form-section .section-title { color: #fff; text-align: center; }
.apply-form-section .section-eyebrow { color: var(--vims-gold, #d4af37); text-align: center; display: block; }
.apply-form-section p.intro { text-align: center; opacity: 0.9; margin: 0 0 2rem; line-height: 1.6; }
.apply-form-wrap { background: #fff; border-radius: 12px; padding: 2rem; }

/* Final CTA */
.final-cta-bar { background: #f5f1e8; padding: 2rem 1rem; text-align: center; }
.final-cta-bar p { margin: 0 0 1rem; font-size: 1rem; color: #444; }
.final-cta-bar .buttons { display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: center; }
.final-cta-bar a { background: var(--vims-bronze, #a97d5c); color: #fff; padding: 0.85rem 1.4rem; border-radius: 6px; text-decoration: none; font-weight: 600; font-size: 0.95rem; }
.final-cta-bar a.btn-out { background: transparent; color: var(--vims-primary, #1a3020); border: 2px solid var(--vims-primary, #1a3020); }

/* Related */
.related-pages { background: #fff; }
.related-pages ul { list-style: none; padding: 0; margin: 1rem 0 0; display: flex; flex-wrap: wrap; gap: 0.5rem 2rem; }
.related-pages a { color: var(--vims-primary, #1a3020); text-decoration: none; font-weight: 500; padding: 0.4rem 0; }
.related-pages a:hover { color: var(--vims-bronze, #a97d5c); }
.related-pages a::after { content: " →"; color: var(--vims-bronze, #a97d5c); }

