:root {
        --color-primary: #2c4a3e;
        --color-primary-dark: #1e332b;
        --color-accent: #c97c3a;
        --color-accent-hover: #b06a2e;
        --color-bg: #f9f7f2;
        --color-surface: #ffffff;
        --color-text: #2d2d2d;
        --color-text-light: #666666;
        --color-border: #d8cfc4;
        --color-schedule-home: #eef0f8;
        --color-curriculum: #e8f0e8;
        --color-faq: #fff8f0;
        --max-width: 900px;
    }
    * { box-sizing: border-box; margin: 0; padding: 0; }
    body { background: var(--color-bg); font-family: sans-serif; color: var(--color-text); }
    a { color: var(--color-accent); text-decoration: none; }
    a:hover { text-decoration: underline; }

    nav { background: var(--color-primary); padding: 0 24px; height: 56px; display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; z-index: 1000; }
    nav .brand { font-weight: bold; font-size: 1.1rem; color: white; }
    nav .nav-links { display: flex; gap: 24px; }
    nav .nav-links a { color: #a8c4b8; font-size: 0.9rem; }
    nav .nav-links a:hover { color: white; }
    nav .btn-nav { background: var(--color-accent); color: white !important; padding: 6px 16px; border-radius: 4px; font-size: 0.9rem; }
    nav .btn-nav:hover { background: var(--color-accent-hover); text-decoration: none; }

    .page-wrap { max-width: var(--max-width); margin: 0 auto; background: var(--color-surface); }

    .hero { background: var(--color-primary); padding: 80px 48px 60px; }
    .hero .eyebrow { font-size: 0.85rem; color: #a8c4b8; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 12px; }
    .hero .sub-eyebrow { font-size: 0.8rem; color: var(--color-accent); text-transform: uppercase; letter-spacing: 0.1em; font-weight: bold; margin-bottom: 8px; }
    .hero h1 { font-size: 2.8rem; color: white; line-height: 1.15; margin-bottom: 16px; }
    .hero .sub { font-size: 1.1rem; color: #a8c4b8; margin-bottom: 32px; }
    .hero .ctas { display: flex; gap: 16px; flex-wrap: wrap; }
    .btn-primary { background: var(--color-accent); color: white; padding: 12px 28px; border-radius: 4px; font-weight: bold; font-size: 1rem; display: inline-block; }
    .btn-primary:hover { background: var(--color-accent-hover); text-decoration: none; }
    .btn-secondary { color: #a8c4b8; padding: 12px 24px; font-size: 1rem; display: inline-block; border: 1px solid #4a6a5e; border-radius: 4px; }
    .btn-secondary:hover { color: white; text-decoration: none; }

    .section { padding: 48px 48px; border-bottom: 1px solid var(--color-border); }
    .section-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; color: white; background: var(--color-accent); display: inline-block; padding: 4px 12px; border-radius: 2px; margin-bottom: 20px; }

    .schedule { background: var(--color-schedule-home); }
    .schedule-table { border-collapse: collapse; width: 100%; max-width: 680px; }
    .schedule-table th { text-align: left; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.08em; padding: 6px 12px; border-bottom: 2px solid var(--color-border); color: var(--color-text-light); }
    .schedule-table td { padding: 10px 12px; border-bottom: 1px solid var(--color-border); }
    .schedule-table tr:last-child td { border-bottom: none; }
    .badge { display: inline-block; padding: 3px 10px; border-radius: 12px; font-size: 0.8rem; font-weight: bold; }
    .badge-inperson { background: var(--color-primary); color: white; }
    .badge-home { background: #5a7a5a; color: white; }
    .badge-elective { background: #8b5a2b; color: white; }

    .curriculum { background: var(--color-curriculum); }
    .curriculum ul { list-style: none; }
    .curriculum li { padding: 8px 0; font-size: 1rem; border-bottom: 1px solid rgba(0,0,0,0.06); display: flex; align-items: center; gap: 10px; }
    .curriculum li:last-child { border-bottom: none; }
    .curriculum li::before { content: "✓"; color: var(--color-accent); font-weight: bold; }

    .faq { background: var(--color-faq); }
    .faq-item { margin-bottom: 24px; }
    .faq-item:last-child { margin-bottom: 0; }
    .faq-item .q { font-weight: bold; font-size: 1rem; margin-bottom: 6px; }
    .faq-item .a { color: var(--color-text-light); line-height: 1.6; font-size: 0.95rem; }

    footer { background: var(--color-primary-dark); color: #a8c4b8; padding: 40px 48px; }
    footer .brand { font-size: 1rem; color: white; font-weight: bold; margin-bottom: 8px; }
    footer p { font-size: 0.85rem; line-height: 1.6; }
