/* ============================== */
/*     CSS RESET & NORMALIZATION   */
/* ============================== */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
    box-sizing: border-box;
}
html {
    scroll-behavior: smooth;
}
body {
    line-height: 1.5;
    background: #F4F7FB;
    color: #22315A;
    font-family: 'Open Sans', Arial, Helvetica, sans-serif;
    font-size: 16px;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
img {
    max-width: 100%;
    display: block;
    height: auto;
}
a {
    color: #22315A;
    text-decoration: none;
    transition: color 0.2s;
}
ul, ol {
    list-style: none;
}
button, input[type="button"], input[type="submit"] {
    font-family: inherit;
    font-size: inherit;
    background: none;
    border: none;
    outline: none;
    cursor: pointer;
}
:focus {
    outline: 2px solid #DAA03D;
    outline-offset: 2px;
}


/* ===================== */
/*   VARIABLE FALLBACKS  */
/* ===================== */
:root {
    --color-primary: #22315A;
    --color-secondary: #DAA03D;
    --color-accent: #F4F7FB;
    --font-display: 'Montserrat', Arial, Helvetica, sans-serif;
    --font-body: 'Open Sans', Arial, Helvetica, sans-serif;
    --radius-lg: 20px;
    --radius-md: 14px;
    --radius-sm: 8px;
    --shadow-card: 0 4px 32px rgba(34,49,90,0.10);
    --shadow-cta: 0 2px 12px 0 #DAA03D22;
}


/* ========================== */
/*   UTILITY CONTAINERS      */
/* ========================== */
.container {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding-left: 18px;
    padding-right: 18px;
    display: flex;
    flex-direction: column;
    gap: 0; /* Remove default gap unless overridden */
}

section {
    margin-bottom: 60px;
    padding: 40px 0;
    background: transparent;
}

.content-wrapper {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
}
.text-section {
    max-width: 700px;
    margin: 0 auto;
    align-items: flex-start;
}


/* ===================== */
/*      TYPOGRAPHY      */
/* ===================== */
h1, h2, h3, h4, h5 {
    font-family: var(--font-display);
    color: #22315A;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.14;
}
h1 { font-size: 2.9rem; margin-bottom: 18px;  }
h2 { font-size: 2rem; margin-bottom: 13px; margin-top: 12px; }
h3 { font-size: 1.32rem; margin-bottom: 8px; font-weight: bold; }
h4, h5, h6 { font-size: 1.1rem; font-weight: normal; }
p, li, span, a {
    font-family: var(--font-body);
    font-size: 1rem;
    color: #22315A;
}
p { margin-bottom: 12px; }
strong { font-weight: 600; }
blockquote {
    border-left: 4px solid #DAA03D;
    padding: 12px 22px;
    background: #fffbe9;
    color: #22315A;
    border-radius: var(--radius-md);
    font-style: italic;
    margin-bottom: 18px;
}


/* ========================= */
/*       HEADER & NAV        */
/* ========================= */
header {
    background: linear-gradient(90deg, #F4F7FB 70%, #DAA03D10 100%);
    box-shadow: 0 2px 12px rgba(34,49,90,0.033);
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 30;
}
.container > a > img {
    height: 52px;
    margin-right: 14px;
}
header .container {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding-top: 13px;
    padding-bottom: 13px;
}
.main-nav {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 18px;
}
.main-nav a {
    padding: 8px 14px;
    border-radius: var(--radius-sm);
    font-size: 1rem;
    font-weight: 500;
    transition: color .17s, background .17s;
    position: relative;
    color: #22315A;
    background: transparent;
}
.main-nav a:hover, .main-nav a:focus {
    color: #DAA03D;
    background: #22315A08;
}
.main-nav .cta-primary {
    background: #DAA03D;
    color: #22315A;
    padding: 9px 24px;
    border-radius: var(--radius-md);
    font-family: var(--font-display);
    font-size: 1.04rem;
    font-weight: bold;
    box-shadow: var(--shadow-cta);
    margin-left: 10px;
    transition: background .17s, color .15s, box-shadow .22s;
}
.main-nav .cta-primary:hover, .main-nav .cta-primary:focus {
    background: #f1c667;
    color: #1a2344;
    box-shadow: 0 6px 24px 0 #DAA03D33;
}


/* ====================== */
/*     MOBILE NAV MENU    */
/* ====================== */
.mobile-menu-toggle {
    display: none;
    background: #fff;
    color: #22315A;
    font-size: 2rem;
    padding: 7px 12px 6px 12px;
    border-radius: var(--radius-md);
    transition: background .18s;
    border: 1px solid #DAA03D22;
    z-index: 500;
    margin-left: 10px;
}
@media (max-width: 1100px) {
    .main-nav {
        display: none;
    }
    .mobile-menu-toggle {
        display: block;
    }
}
.mobile-menu {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: #22315AE8;
    z-index: 1000;
    transform: translateX(100%);
    transition: transform 0.43s cubic-bezier(.46,.03,.52,1.01);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding-top: 22px;
    opacity: 0;
    pointer-events: none;
}
.mobile-menu.active {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
}
.mobile-menu-close {
    position: absolute;
    top: 18px; right: 18px;
    background: none;
    color: #FFF;
    font-size: 2.4rem;
    border-radius: var(--radius-md);
    z-index: 1001;
    border: 1px solid #FFF1;
    padding: 6px 16px;
    transition: background .13s;
}
.mobile-menu-close:hover, .mobile-menu-close:focus {
    background: #DAA03D;
    color: #22315A;
}
.mobile-nav {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-top: 54px;
    width: 100%;
    align-items: flex-start;
    padding-left: 36px;
}
.mobile-nav a {
    color: #fff;
    font-size: 1.28rem;
    padding: 13px 12px 13px 0;
    border-radius: var(--radius-sm);
    font-weight: 600;
    transition: background .13s, color .13s;
}
.mobile-nav a:hover, .mobile-nav a:focus {
    background: #DAA03D;
    color: #22315A;
}
@media (min-width: 1101px) {
    .mobile-menu {
        display: none !important;
    }
}


/* =================== */
/*        HERO         */
/* =================== */
main > section:first-child {
    background: linear-gradient(135deg,#DAA03D18 0%, #F4F7FB 60%, #fff 100%);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 32px #22315A08;
}
main h1 {
    font-size: 2.5rem;
    font-weight: 800;
    margin-bottom: 8px;
    color: #22315A;
    /* Hero gradient text effect */
    background: linear-gradient(90deg, #22315A 50%, #DAA03D 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
@media (min-width: 640px) {
    main h1 {
        font-size: 3rem;
    }
}


/* ============================= */
/*       FEATURE GRIDS / LISTS   */
/* ============================= */
.feature-grid, .values-list, .team-member-cards, .course-list, .resource-list, .blog-post-cards, .testimonial-list, .skills-grid, .downloads-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    justify-content: flex-start;
    margin-bottom: 24px;
}
.feature-grid li, .values-list li, .team-member-card, .course-item, .resource-item, .blog-post-card, .download, .skill {
    background: #fff;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
    margin-bottom: 20px;
    padding: 28px 20px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
    min-width: 220px;
    flex: 1 1 240px;
    transition: box-shadow .19s, transform .19s;
    position: relative;
    border: 1px solid #F4F7FB;
}
.feature-grid li:hover, .values-list li:hover, .team-member-card:hover, .course-item:hover, .resource-item:hover, .blog-post-card:hover, .download:hover, .skill:hover {
    box-shadow: 0 6px 32px 0 #DAA03D1c;
    transform: translateY(-4px) scale(1.03);
}
.feature-grid img, .values-list img, .team-member-card img, .resource-item img, .download img {
    width: 48px;
    height: 48px;
    margin-bottom: 5px;
    object-fit: contain;
    border-radius: var(--radius-sm);
}

.course-item h3, .team-member-card h3, .resource-item strong, .blog-post-card h3 {
    color: #22315A;
    font-size: 1.17rem;
    font-weight: bold;
}
.course-highlights ul, .syllabus-overview ul, .recommended-books ul, .faq-list {
    padding-left: 18px;
    margin-bottom: 16px;
}
.recommended-books span {
    font-weight: 600;
    margin-bottom: 5px;
    display: block;
}
.skill {
    background: #DAA03D18;
    color: #22315A;
    font-weight: 600;
    text-align: center;
    min-width: 130px;
    min-height: 42px;
    justify-content: center;
    align-items: center;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    padding: 14px 0;
}

/* ========================== */
/*         TESTIMONIALS      */
/* ========================== */
.testimonial-list {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    justify-content: flex-start;
    margin-bottom: 24px;
}
.testimonial-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 20px 28px;
    background: #fff;
    border-radius: var(--radius-lg);
    box-shadow: 0 3px 18px 0 #22315A0C;
    color: #22315A;
    font-size: 1.08rem;
    line-height: 1.6;
    border-left: 7px solid #DAA03D;
    margin-bottom: 20px;
    max-width: 460px;
    min-width: 210px;
    font-weight: 500;
    transition: box-shadow .15s, background .1s;
}
.testimonial-card span {
    color: #22315A;
    font-size: .98rem;
    font-family: var(--font-display);
    opacity: 0.85;
}
.student-quotes blockquote {
    background: #fffbe9;
    color: #22315A;
    border-left: 4px solid #DAA03D;
}
@media (max-width:600px) {
    .testimonial-card, .blog-post-card, .team-member-card, .course-item, .resource-item, .skill {
        min-width: 0;
        width: 100%;
        border-radius: var(--radius-md);
        padding: 20px 10px;
    }
}

/**********************************/
/*          CTA Buttons           */
/**********************************/
.cta-primary {
    display: inline-block;
    background: linear-gradient(90deg, #F4F7FB 0%, #DAA03D 100%);
    color: #22315A !important;
    padding: 13px 34px;
    font-size: 1.14rem;
    font-family: var(--font-display);
    font-weight: 700;
    border-radius: var(--radius-md);
    border: none;
    box-shadow: var(--shadow-cta);
    text-align: center;
    transition: background .17s, color .17s, box-shadow .22s, transform .15s;
    margin-top: 12px;
}
.cta-primary:hover, .cta-primary:focus{
    background: linear-gradient(90deg,#DAA03D 0%, #F4F7FB 100%);
    color: #22315A;
    box-shadow: 0 5px 30px 0 #DAA03D33;
    transform: scale(1.03);
}

/**********************************/
/*          FOOTER                */
/**********************************/
footer {
    background: linear-gradient(90deg,#22315A 65%,#DAA03D33 100%);
    color: #fff;
    padding: 38px 0 10px 0;
    box-shadow: 0 -2px 16px 0 #22315A11;
}
footer .container {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 36px;
    margin-bottom: 0;
}
footer nav.footer-nav {
    display: flex;
    flex-direction: column;
    gap: 11px;
}
.footer-nav a {
    color: #fff;
    font-size: .97rem;
    opacity: 0.95;
    transition: color .12s, opacity .16s;
    margin-bottom: 3px;
}
.footer-nav a:hover, .footer-nav a:focus {
    color: #DAA03D;
    opacity: 1;
}
.contact-summary {
    display: flex;
    flex-direction: column;
    gap: 3px;
    align-items: flex-start;
    font-size: 0.98rem;
    color: #fff;
}
.contact-summary a {
    color: #F1C667;
    text-decoration: underline;
}
footer img {
    width: 48px;
    height: auto;
    margin-bottom: 18px;
}
footer .container:last-child {
    margin-top: 12px;
    margin-bottom: 0;
    justify-content: center;
}
footer .container:last-child span {
    font-size: 0.89rem;
    color: #fff;
    opacity: 0.65;
}
@media (max-width: 950px) {
    footer .container {
        flex-direction: column;
        align-items: flex-start;
        gap: 24px;
    }
    .footer-nav {
        flex-direction: row;
        gap: 18px;
    }
}


/**********************************/
/*          RESPONSIVE            */
/**********************************/
@media (max-width: 900px) {
    .feature-grid, .values-list, .team-member-cards, .course-list, .resource-list, .blog-post-cards, .testimonial-list, .skills-grid, .downloads-grid {
        flex-direction: column;
        gap: 20px;
    }
    .content-wrapper {
        gap: 18px;
    }
}
@media (max-width: 768px) {
    section {
        margin-bottom: 36px;
        padding: 30px 0;
    }
    .container {
        padding-left: 7px;
        padding-right: 7px;
    }
    .content-wrapper {
        gap: 13px;
    }
    .text-section {
        padding-left: 0;
        padding-right: 0;
    }
    .content-wrapper.text-section { align-items: flex-start; }
    .testimonial-list, .blog-post-cards, .feature-grid, .values-list, .course-list, .skills-grid, .downloads-grid {
        flex-direction: column;
        gap: 14px;
    }
    footer {
        padding: 30px 0 10px 0;
    }
}
@media (max-width:500px) {
    header .container {
        flex-direction: row;
        align-items: center;
        padding-top: 8px;
        padding-bottom: 8px;
    }
    .container > a > img {
        height: 36px;
    }
    main h1 { font-size: 1.58rem; }
    h2 { font-size: 1.16rem; }
    .content-wrapper {
        padding: 0;
        gap: 10px;
    }
    .card, .course-item, .team-member-card, .resource-item, .testimonial-card, .blog-post-card, .download, .skill {
        padding: 13px 8px;
    }
    .cta-primary {
        font-size: 1rem;
        padding: 10px 18px;
    }
}
.text-image-section {
    display: flex;
    align-items: center;
    gap: 30px;
    flex-wrap: wrap;
}
@media (max-width: 768px) {
    .text-image-section {
        flex-direction: column;
        gap: 16px;
        align-items: flex-start;
    }
}

/**********************************/
/*            MISC                */
/**********************************/
.card-container {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
}
.card {
    background: #fff;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    margin-bottom: 20px;
    position: relative;
    padding: 24px;
    min-width: 220px;
    transition: box-shadow .15s, transform .13s;
}
.card:hover {
    box-shadow: 0 5px 24px 0 #DAA03D22;
    transform: scale(1.025);
}
.content-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: space-between;
}
.testimonial-card {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 20px;
}
.feature-item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
}
.founder-bio p {
    font-style: italic;
    color: #22315A;
}
.category-tags {
    display: flex;
    flex-direction: row;
    gap: 11px;
    flex-wrap: wrap;
    margin-top: 8px;
    margin-bottom: 6px;
}
.category-tags span {
    padding: 5px 17px;
    border-radius: 18px;
    background: #DAA03D18;
    font-family: var(--font-display);
    font-size: .98rem;
    color: #22315A;
    font-weight: 600;
}
.map-location {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 8px;
}
.map-location img {
    width: 32px;
    height: 32px;
}

/**********************************/
/*        COOKIE CONSENT           */
/**********************************/
.cookie-banner {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    z-index: 2000;
    background: linear-gradient(90deg,#fff 80%, #DAA03D10 100%);
    padding: 20px 18px;
    box-shadow: 0 -2px 22px 0 #22315A22;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 24px;
    justify-content: space-between;
    font-size: 1.06rem;
    border-top: 2px solid #DAA03D22;
    animation: cookie-fade-in 1s cubic-bezier(0.03,0.85,0.3,1.01) 0.20s both;
}
@keyframes cookie-fade-in {
    from { opacity: 0; transform: translateY(80px); }
    to { opacity: 1; transform: translateY(0); }
}
.cookie-banner .cookie-actions {
    display: flex;
    flex-direction: row;
    gap: 14px;
    flex-wrap: wrap;
}
.cookie-banner button {
    padding: 8px 18px;
    border-radius: var(--radius-sm);
    border: none;
    font-family: var(--font-display);
    background: #DAA03D;
    color: #22315A;
    font-weight: bold;
    font-size: 1rem;
    transition: background .15s, color .12s;
}
.cookie-banner button:hover, .cookie-banner button:focus {
    background: #F1C667;
}
.cookie-banner .cookie-settings-btn {
    background: #22315A;
    color: #fff;
}
.cookie-banner .cookie-settings-btn:hover, .cookie-banner .cookie-settings-btn:focus {
    background: #1A2344;
    color: #F1C667;
}
@media (max-width: 600px) {
    .cookie-banner {
        flex-direction: column;
        gap: 15px;
        align-items: flex-start;
    }
    .cookie-banner .cookie-actions {
        gap: 7px;
    }
}

/* Cookie Modal */
.cookie-modal-overlay {
    position: fixed;
    top: 0; right: 0; left: 0; bottom:0;
    background: #22315A88;
    z-index: 3000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .37s;
}
.cookie-modal-overlay.active {
    opacity: 1;
    pointer-events: auto;
}
.cookie-modal {
    background: #fff;
    border-radius: var(--radius-lg);
    box-shadow: 0 8px 56px 0 #22315A33;
    max-width: 410px;
    width: 95%;
    padding: 34px 28px 23px 28px;
    display: flex;
    flex-direction: column;
    gap: 22px;
    animation: cookie-modal-in .58s cubic-bezier(.36,1.04,.2,1.07) both;
    position: relative;
}
@keyframes cookie-modal-in {
    from { opacity: 0; transform: scale(0.8) translateY(50px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}
.cookie-modal .modal-close {
    position: absolute;
    top: 12px; right: 15px;
    background: none;
    border: none;
    color: #22315A;
    font-size: 2.1rem;
    cursor: pointer;
    transition: color .16s;
}
.cookie-modal .modal-close:hover,
.cookie-modal .modal-close:focus {
    color: #DAA03D;
}
.cookie-modal h3 {
    margin-bottom: 7px;
    font-size: 1.24rem;
    font-weight: 700;
    color: #22315A;
}
.cookie-categories {
    display: flex;
    flex-direction: column;
    gap: 15px;
}
.cookie-category {
    display: flex;
    align-items: center;
    gap: 13px;
    font-size: 1.06rem;
}
.cookie-category label {
    font-weight: 600;
    color: #22315A;
}
.cookie-switch {
    appearance: none;
    width: 32px; height: 18px;
    background: #DAA03D33;
    border-radius: 9px;
    position: relative;
    outline: none;
    cursor: pointer;
    transition: background .13s;
}
.cookie-switch:checked {
    background: #DAA03D;
}
.cookie-switch::before {
    content: "";
    display: block;
    position: absolute;
    left: 2px; top: 2px;
    width: 14px; height: 14px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 1px 4px #22315A22;
    transition: left .19s;
}
.cookie-switch:checked::before {
    left: 16px;
}
.cookie-category input[disabled] {
    opacity: 0.55;
}
.cookie-actions-modal {
    display: flex;
    flex-direction: row;
    gap: 10px;
    margin-top: 5px;
    justify-content: flex-end;
}
.cookie-actions-modal button {
    padding: 8px 17px;
    border-radius: var(--radius-sm);
    font-family: var(--font-display);
    background: #DAA03D;
    color: #22315A;
    font-weight: bold;
    font-size: .99rem;
    border: none;
    transition: background .15s, color .12s;
}
.cookie-actions-modal button:hover {
    background: #22315A;
    color: #fff;
}

/**********************************/
/*        MISC - FAQ, UTIL        */
/**********************************/
.faq-list {
    display: flex;
    flex-direction: column;
    gap: 17px;
    margin-bottom: 20px;
}
.faq-list li {
    background: #fff;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    padding: 17px 15px;
    color: #22315A;
    font-size: 1.06rem;
    line-height: 1.5;
    margin-bottom: 6px;
}
.faq-list strong {
    color: #22315A;
    font-family: var(--font-display);
    font-size: 1.07rem;
}

/**********************************/
/*        FORMS (basic)           */
/**********************************/
input, textarea, select {
    border: 1px solid #DAA03D33;
    padding: 10px 13px;
    border-radius: var(--radius-sm);
    font-family: inherit;
    font-size: 1rem;
    margin-bottom: 10px;
    background: #fff;
    transition: border 0.12s;
}
input:focus, textarea:focus, select:focus {
    border: 1.5px solid #DAA03D;
}
label {
    font-family: var(--font-display);
    color: #22315A;
    font-size: 1em;
    font-weight: 500;
    margin-bottom: 7px;
    display: block;
}

/**********************************/
/*    TRANSITIONS, MICRO-ACTS     */
/**********************************/
a, button, .cta-primary, .card, .testimonial-card, .feature-grid li, .values-list li, .card, .team-member-card, .blog-post-card, .cookie-banner button, .cookie-actions-modal button {
    transition: box-shadow .15s, background .13s, color .11s, transform .16s;
}

/**********************************/
/*           PRINT                */
/**********************************/
@media print {
    *, *::before, *::after { box-shadow: none !important; background: none !important; color: #000 !important; }
    header, nav, .main-nav, .mobile-menu, footer, .cookie-banner, .cookie-modal-overlay { display: none !important; }
    section, .container { padding: 0 !important; margin: 0 !important; }
    main { margin: 0 !important; padding: 0 !important; }
}
