/*
Theme Name: Messiah Types
Template: messiah-core
Description: Types and assessment child theme for Messiah Mindset.
Version: 0.2.1
Text Domain: messiah-types
*/

:root {
    --mm-bg: #f2f0f0;
    --mm-bg-soft: #efefef;
    --mm-surface: #ffffff;
    --mm-surface-soft: #f7f7f7;
    --mm-text: #131313;
    --mm-text-soft: #616161;
    --mm-border: #e2e2e2;
    --mm-accent: #52b2cb;
    --mm-eagle: #52b2cb;
    --mm-lion: #f8c22c;
    --mm-ox: #df1c50;
    --mm-man: #05a77d;
    --mm-shadow: 0 16px 38px rgba(0,0,0,0.08);
}

body { background: linear-gradient(180deg, #f2f0f0 0%, #ffffff 28rem, #ffffff 100%); }
.mm-main-header { background: rgba(242, 240, 240, 0.78); border-bottom-color: rgba(0,0,0,0.06); }
.mm-home-hero {
    padding-top: 5rem;
    background:
        radial-gradient(circle at top left, rgba(82,178,203,0.24), transparent 28%),
        radial-gradient(circle at top right, rgba(248,194,44,0.18), transparent 24%),
        linear-gradient(180deg, #f2f0f0 0%, #ffffff 78%);
}
.mm-home-hero::after {
    content: "";
    display: block;
    height: 48px;
    margin-top: 2rem;
    background: linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,1));
}
.mm-utility-bar { background: #15252d; }
.mm-button, .wp-block-button__link, button, input[type="submit"] { background: var(--mm-accent); }
.mm-feature-card, .mm-placeholder-card, .mm-article-card {
    background: rgba(255,255,255,0.88); backdrop-filter: blur(8px);
}
.mm-archetype-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.mm-archetype-card {
    padding: 1.35rem; border-radius: 24px; background: #fff;
    border: 1px solid rgba(0,0,0,0.06); box-shadow: var(--mm-shadow);
}
.mm-archetype-card--eagle { border-top: 4px solid var(--mm-eagle); }
.mm-archetype-card--lion { border-top: 4px solid var(--mm-lion); }
.mm-archetype-card--ox { border-top: 4px solid var(--mm-ox); }
.mm-archetype-card--man { border-top: 4px solid var(--mm-man); }

.mm-stat-pills { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 1rem; }
.mm-stat-pill {
    padding: 0.85rem 1rem; border-radius: 999px; background: rgba(255,255,255,0.85);
    border: 1px solid rgba(0,0,0,0.06); box-shadow: var(--mm-shadow);
    font-family: var(--mm-font-ui); text-transform: uppercase; letter-spacing: 0.05em; font-size: 0.84rem;
}
@media (max-width: 960px) { .mm-archetype-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 640px) { .mm-archetype-grid { grid-template-columns: 1fr; } }

/* Types header refinements */
.custom-logo-link img,
.custom-logo {
    max-height: 108px;
    width: auto;
}

.mm-types-header-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.mm-types-login {
    font-family: var(--mm-font-ui);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.84rem;
}

.mm-types-header-actions .mm-button {
    padding: 0.8rem 1.15rem;
}

.mm-types-nav-wrap {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
    justify-content: flex-end;
}

.mm-types-main-nav {
    margin-right: 0.5rem;
}

.mm-types-main-nav .mm-primary-menu {
    justify-content: flex-end;
}

.mm-hero-visual {
    min-height: 360px;
    display: grid;
    place-items: center;
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 20% 20%, rgba(82,178,203,0.18), transparent 24%),
        radial-gradient(circle at 82% 20%, rgba(248,194,44,0.18), transparent 24%),
        radial-gradient(circle at 50% 75%, rgba(5,167,125,0.16), transparent 22%),
        linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.84));
}

.mm-hero-visual::before,
.mm-hero-visual::after {
    content: "";
    position: absolute;
    inset: auto;
    border-radius: 999px;
    filter: blur(8px);
}

.mm-hero-visual::before {
    width: 220px;
    height: 220px;
    right: -30px;
    top: -20px;
    background: rgba(82,178,203,0.15);
}

.mm-hero-visual::after {
    width: 180px;
    height: 180px;
    left: -20px;
    bottom: -30px;
    background: rgba(223,28,80,0.12);
}

.mm-hero-stack {
    position: relative;
    z-index: 2;
    display: grid;
    gap: 0.8rem;
    width: min(100%, 360px);
}

.mm-hero-badge {
    padding: 1rem 1.1rem;
    border-radius: 18px;
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(0,0,0,0.05);
    box-shadow: var(--mm-shadow);
}

.mm-hero-badge strong {
    display: block;
    font-family: var(--mm-font-ui);
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 0.4rem;
}

.mm-hero-badge--eagle { border-left: 5px solid var(--mm-eagle); }
.mm-hero-badge--lion { border-left: 5px solid var(--mm-lion); }
.mm-hero-badge--ox { border-left: 5px solid var(--mm-ox); }
.mm-hero-badge--man { border-left: 5px solid var(--mm-man); }

.mm-section-heading {
    max-width: 720px;
    margin-bottom: 1.5rem;
}

.mm-framework-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.mm-framework-card {
    padding: 1.35rem;
    border-radius: 24px;
    background: rgba(255,255,255,0.9);
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: var(--mm-shadow);
}

.mm-cta-band {
    margin-top: 1rem;
    padding: 2rem;
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(82,178,203,0.14), rgba(248,194,44,0.12));
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: var(--mm-shadow);
}

.mm-profile-shell {
    background: var(--mm-surface);
}

.mm-profile-hero {
    padding: 5rem 0 2rem;
    color: #131313;
    position: relative;
    overflow: hidden;
}

.mm-profile-hero .mm-container {
    position: relative;
    z-index: 2;
}

.mm-profile-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.18;
    pointer-events: none;
    background:
        radial-gradient(circle at top right, rgba(255,255,255,0.9), transparent 28%),
        radial-gradient(circle at bottom left, rgba(255,255,255,0.85), transparent 22%);
}

.mm-profile-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 1.5rem;
    align-items: end;
}

.mm-profile-kicker {
    font-family: var(--mm-font-ui);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.84rem;
    opacity: 0.92;
}

.mm-profile-subtitle {
    font-size: 1.15rem;
    max-width: 52ch;
}

.mm-profile-statbox {
    background: rgba(255,255,255,0.92);
    border-radius: 24px;
    padding: 1.35rem;
    box-shadow: var(--mm-shadow);
    border: 1px solid rgba(0,0,0,0.06);
}

.mm-profile-main {
    padding: 2rem 0 4rem;
}

.mm-profile-sections {
    display: grid;
    gap: 1rem;
}

.mm-profile-card {
    background: #fff;
    border-radius: 24px;
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: var(--mm-shadow);
    padding: 1.5rem;
}

.mm-profile-card h2 {
    font-size: clamp(1.3rem, 2vw, 1.9rem);
    margin-bottom: 0.75rem;
}

.mm-profile-card ul {
    margin: 0;
    padding-left: 1.2rem;
}

.mm-profile-quote {
    font-family: var(--mm-font-display);
    font-size: clamp(1.3rem, 2.1vw, 1.9rem);
    line-height: 1.2;
    margin: 0;
}

.mm-profile-sidebar {
    display: grid;
    gap: 1rem;
}

.mm-profile-tag {
    display: inline-flex;
    padding: 0.5rem 0.85rem;
    border-radius: 999px;
    background: rgba(255,255,255,0.86);
    font-family: var(--mm-font-ui);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.8rem;
    margin: 0 0.4rem 0.4rem 0;
}

.mm-theme-eagle .mm-profile-hero { background: linear-gradient(135deg, rgba(82,178,203,0.34), rgba(82,178,203,0.18)); }
.mm-theme-lion .mm-profile-hero { background: linear-gradient(135deg, rgba(248,194,44,0.44), rgba(248,194,44,0.18)); }
.mm-theme-ox .mm-profile-hero { background: linear-gradient(135deg, rgba(223,28,80,0.28), rgba(223,28,80,0.14)); }
.mm-theme-man .mm-profile-hero { background: linear-gradient(135deg, rgba(5,167,125,0.28), rgba(5,167,125,0.14)); }

.mm-theme-eagle .mm-profile-card--accent,
.mm-theme-eagle .mm-profile-statbox { border-top: 4px solid var(--mm-eagle); }
.mm-theme-lion .mm-profile-card--accent,
.mm-theme-lion .mm-profile-statbox { border-top: 4px solid var(--mm-lion); }
.mm-theme-ox .mm-profile-card--accent,
.mm-theme-ox .mm-profile-statbox { border-top: 4px solid var(--mm-ox); }
.mm-theme-man .mm-profile-card--accent,
.mm-theme-man .mm-profile-statbox { border-top: 4px solid var(--mm-man); }

@media (max-width: 1100px) {
    .mm-framework-grid { grid-template-columns: 1fr; }
    .mm-profile-grid { grid-template-columns: 1fr; }
}

@media (max-width: 960px) {
    .mm-types-nav-wrap {
        width: 100%;
        justify-content: space-between;
        flex-wrap: wrap;
    }
    .mm-types-main-nav {
        width: 100%;
        margin-right: 0;
    }
    .mm-types-main-nav .mm-primary-menu {
        justify-content: flex-start;
    }
}

@media (max-width: 640px) {
    .custom-logo-link img,
    .custom-logo {
        max-height: 82px;
    }
    .mm-types-header-actions {
        width: 100%;
        justify-content: flex-start;
    }
}


/* Remove awkward boxed feel for profile layouts */
.mm-profile-shell.alignfull,
.wp-block-group.alignfull.mm-profile-shell {
    width: 100%;
    max-width: 100%;
    margin: 0;
}

.mm-profile-hero,
.wp-block-group.mm-profile-hero {
    width: 100%;
    max-width: 100%;
}

.mm-profile-main,
.wp-block-group.mm-profile-main {
    width: 100%;
    max-width: 100%;
}

.mm-profile-hero .mm-container,
.mm-profile-main .mm-container,
.wp-block-group.mm-profile-hero .mm-container,
.wp-block-group.mm-profile-main .mm-container {
    width: min(1440px, calc(100vw - 48px));
    max-width: 1440px;
    margin-inline: auto;
}

/* Allow a much wider layout on the front end */
.mm-profile-shell .wp-block-columns {
    gap: 1.5rem;
}

/* Make Gutenberg color shells visible in the editor too */
.editor-styles-wrapper .mm-profile-hero,
.editor-styles-wrapper .wp-block-group.mm-profile-hero {
    padding-top: 5rem;
    padding-bottom: 2rem;
}

.editor-styles-wrapper .mm-theme-eagle .mm-profile-hero,
.editor-styles-wrapper .mm-theme-eagle.wp-block-group .mm-profile-hero,
.editor-styles-wrapper .wp-block-group.mm-theme-eagle .mm-profile-hero {
    background: linear-gradient(135deg, rgba(82,178,203,0.34), rgba(82,178,203,0.18)) !important;
}
.editor-styles-wrapper .mm-theme-lion .mm-profile-hero,
.editor-styles-wrapper .wp-block-group.mm-theme-lion .mm-profile-hero {
    background: linear-gradient(135deg, rgba(248,194,44,0.44), rgba(248,194,44,0.18)) !important;
}
.editor-styles-wrapper .mm-theme-ox .mm-profile-hero,
.editor-styles-wrapper .wp-block-group.mm-theme-ox .mm-profile-hero {
    background: linear-gradient(135deg, rgba(223,28,80,0.28), rgba(223,28,80,0.14)) !important;
}
.editor-styles-wrapper .mm-theme-man .mm-profile-hero,
.editor-styles-wrapper .wp-block-group.mm-theme-man .mm-profile-hero {
    background: linear-gradient(135deg, rgba(5,167,125,0.28), rgba(5,167,125,0.14)) !important;
}

/* Make archetype cards keep their color accents in editor view */
.editor-styles-wrapper .mm-archetype-card--eagle,
.editor-styles-wrapper .mm-profile-card--accent.mm-archetype-card--eagle { border-top: 4px solid var(--mm-eagle) !important; }
.editor-styles-wrapper .mm-archetype-card--lion,
.editor-styles-wrapper .mm-profile-card--accent.mm-archetype-card--lion { border-top: 4px solid var(--mm-lion) !important; }
.editor-styles-wrapper .mm-archetype-card--ox,
.editor-styles-wrapper .mm-profile-card--accent.mm-archetype-card--ox { border-top: 4px solid var(--mm-ox) !important; }
.editor-styles-wrapper .mm-archetype-card--man,
.editor-styles-wrapper .mm-profile-card--accent.mm-archetype-card--man { border-top: 4px solid var(--mm-man) !important; }

.editor-styles-wrapper .mm-profile-card,
.editor-styles-wrapper .mm-profile-statbox,
.editor-styles-wrapper .mm-archetype-card {
    background: #fff !important;
    border-radius: 24px !important;
    border: 1px solid rgba(0,0,0,0.06) !important;
    box-shadow: 0 16px 38px rgba(0,0,0,0.08) !important;
}

/* Hide default page title on the front end for pages */
.page .entry-title,
.page .wp-block-post-title,
.page-title {
    display: none;
}

/* Better spacing when no default title is shown */
.page .entry-content {
    padding-top: 0;
}



/* True full-bleed hero treatment for Types pages */
.mm-profile-hero,
.wp-block-group.mm-profile-hero {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    max-width: 100vw;
    padding-left: 0;
    padding-right: 0;
}

.mm-profile-hero .mm-profile-grid,
.wp-block-group.mm-profile-hero .mm-profile-grid {
    width: min(1440px, calc(100vw - 48px));
    max-width: 1440px;
    margin-inline: auto;
    padding-inline: 0;
}

.editor-styles-wrapper .mm-profile-hero,
.editor-styles-wrapper .wp-block-group.mm-profile-hero {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    max-width: 100vw;
}

.editor-styles-wrapper .mm-profile-hero .mm-profile-grid,
.editor-styles-wrapper .wp-block-group.mm-profile-hero .mm-profile-grid {
    width: min(1440px, calc(100vw - 48px));
    max-width: 1440px;
    margin-inline: auto;
}



/* Safety for editable Eagle pattern full-bleed hero */
.wp-block-group.alignfull.has-eagle-background-color {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    max-width: 100vw;
}



/* Remove the awkward top gap on Types pages */
.page .mm-page-wrap {
    padding-top: 0 !important;
}

.page .entry-content > .wp-block-group.alignfull:first-child,
.page .entry-content > .alignfull:first-child,
.page .entry-content > *:first-child {
    margin-top: 0 !important;
}

/* Keep the first full-width hero flush with the header */
.page .entry-content > .wp-block-group.alignfull.has-eagle-background-color:first-child,
.page .entry-content > .wp-block-group.alignfull.has-lion-background-color:first-child,
.page .entry-content > .wp-block-group.alignfull.has-ox-background-color:first-child,
.page .entry-content > .wp-block-group.alignfull.has-man-background-color:first-child {
    margin-top: 0 !important;
}

/* Slightly tighter content start for full-width profile pages */
.page .entry-content {
    padding-top: 0 !important;
}

/* ========================================
   TYPES NAV DROPDOWN FIX
   ======================================== */

/* Main menu base */
.mm-primary-menu,
.mm-primary-menu ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.mm-primary-menu {
    display: flex;
    align-items: center;
    gap: 1.25rem;
}

.mm-primary-menu > li {
    position: relative;
}

.mm-primary-menu > li > a {
    display: inline-flex;
    align-items: center;
    padding: 0.75rem 0.2rem;
    text-decoration: none;
}

/* Hide submenus by default */
.mm-primary-menu .sub-menu {
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    min-width: 250px;
    background: #ffffff;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 16px;
    box-shadow: 0 18px 40px rgba(0,0,0,0.12);
    padding: 0.5rem 0;
    z-index: 9999;
}

/* Show dropdown on hover */
.mm-primary-menu li:hover > .sub-menu,
.mm-primary-menu li:focus-within > .sub-menu {
    display: block;
}

/* Dropdown items */
.mm-primary-menu .sub-menu li {
    position: relative;
}

.mm-primary-menu .sub-menu a {
    display: block;
    padding: 0.75rem 1rem;
    color: var(--mm-text);
    text-decoration: none;
    white-space: nowrap;
}

/* Hover state */
.mm-primary-menu .sub-menu a:hover,
.mm-primary-menu .sub-menu a:focus {
    background: rgba(82,178,203,0.08);
}

/* Second-level dropdowns */
.mm-primary-menu .sub-menu .sub-menu {
    top: 0;
    left: calc(100% + 10px);
}

/* Optional little arrow for parent items */
.mm-primary-menu > .menu-item-has-children > a::after,
.mm-primary-menu .sub-menu > .menu-item-has-children > a::after {
    content: "▾";
    font-size: 0.7em;
    margin-left: 0.5rem;
    opacity: 0.7;
}

.mm-primary-menu .sub-menu > .menu-item-has-children > a::after {
    content: "▸";
    float: right;
    margin-left: 0.75rem;
}

/* Mobile / tablet fallback */
@media (max-width: 960px) {
    .mm-primary-menu {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
    }

    .mm-primary-menu .sub-menu {
        position: static;
        display: block;
        min-width: 100%;
        border: 0;
        box-shadow: none;
        background: transparent;
        padding: 0.25rem 0 0.25rem 1rem;
    }

    .mm-primary-menu .sub-menu .sub-menu {
        left: 0;
        top: 0;
        padding-left: 1rem;
    }

    .mm-primary-menu .sub-menu a {
        padding: 0.45rem 0;
        white-space: normal;
    }
}