/*
Theme Name: The Mills Mirror
Description: TMM design system — single source of truth.
Version: 4.5.0
*/

/* ╔══════════════════════════════════════════════════════════════╗
   ║  TMM CONTROL PANEL                                          ║
   ╚══════════════════════════════════════════════════════════════╝ */

:root {
    --tmm-navy:          #1A365D;
    --tmm-blue:          #2B6CB0;
    --tmm-green:         #38A169;
    --tmm-yellow:        #D69E2E;
    --tmm-red:           #C53030;
    --tmm-text:          #1A202C;
    --tmm-muted:         #718096;
    --tmm-subtle:        #4A5568;
    --tmm-bg:            #FFFFFF;
    --tmm-light:         #F7FAFC;
    --tmm-border:        #E2E8F0;
    --tmm-amber:         #D69E2E;
    --tmm-amber-bg:      #FFFAF0;
    --tmm-red-light:     #FFF5F5;
    --tmm-red-border:    #FEB2B2;
    --tmm-green-bg:      #E6FFFA;
    --tmm-yellow-bg:     #FFFBEB;

    --tmm-font:          'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    --tmm-weight-body:   500;
    --tmm-weight-semi:   600;
    --tmm-weight-bold:   700;
    --tmm-weight-black:  800;

    --tmm-max-width:     1100px;
    --tmm-radius:        8px;
    --tmm-radius-sm:     4px;

    --tmm-space-xs:      0.5rem;
    --tmm-space-sm:      1rem;
    --tmm-space-md:      2rem;
    --tmm-space-lg:      4rem;
}


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 1: GLOBAL BRAND & TYPOGRAPHY                       ║
   ╚══════════════════════════════════════════════════════════════╝ */

*, *::before, *::after { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--tmm-font);
    font-weight: var(--tmm-weight-body);
    color: var(--tmm-text);
    line-height: 1.6;
    background-color: var(--tmm-bg);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.tmm-main { flex: 1; }

h1, h2, h3, h4, h5, h6 {
    color: var(--tmm-navy);
    font-weight: var(--tmm-weight-bold);
    line-height: 1.25;
    margin-top: 0;
}

h3, h4, h5, h6 { font-weight: var(--tmm-weight-semi); }

p, li, td, dd, dt { color: var(--tmm-text); font-weight: var(--tmm-weight-body); }

a { color: var(--tmm-blue); text-decoration: none; font-weight: var(--tmm-weight-semi); }
a:hover { color: var(--tmm-navy); }

em { color: var(--tmm-subtle); }

hr { border: none; border-top: 1px solid var(--tmm-border); margin: 24px 0; }

@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Buttons */
.btn-primary {
    background: var(--tmm-navy);
    color: #FFFFFF;
    padding: 12px 24px;
    border-radius: var(--tmm-radius);
    font-weight: var(--tmm-weight-semi);
    font-size: 0.92rem;
    text-decoration: none;
    display: inline-block;
    border: none;
    cursor: pointer;
    transition: background 0.2s ease;
    white-space: nowrap;
}
.btn-primary:hover { background: var(--tmm-blue); color: #FFFFFF; text-decoration: none; }

.btn-secondary {
    background: transparent;
    color: var(--tmm-navy);
    border: 2px solid var(--tmm-navy);
    padding: 10px 20px;
    border-radius: var(--tmm-radius);
    font-weight: var(--tmm-weight-semi);
    font-size: 0.9rem;
    text-decoration: none;
    display: inline-block;
    cursor: pointer;
}
.btn-secondary:hover { background: var(--tmm-navy); color: #FFFFFF; text-decoration: none; }


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 2: NAV BAR                                         ║
   ╚══════════════════════════════════════════════════════════════╝ */

.tmm-site-nav {
    background: var(--tmm-bg);
    border-bottom: 1px solid var(--tmm-border);
    position: sticky;
    top: 0;
    z-index: 100;
}
.tmm-nav-inner {
    max-width: 1060px;
    margin: 0 auto;
    padding: 0 3%;
    display: flex;
    align-items: center;
    gap: 4px;
    height: 44px;
}
.tmm-nav-link {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--tmm-navy);
    text-decoration: none;
    padding: 6px 12px;
    border-radius: var(--tmm-radius-sm);
    white-space: nowrap;
    transition: background 0.15s ease;
}
.tmm-nav-link:hover {
    background: var(--tmm-light);
    color: var(--tmm-navy);
}
.tmm-nav-link.active {
    background: var(--tmm-navy);
    color: #ffffff;
}
.tmm-nav-link.active:hover {
    background: var(--tmm-navy);
    color: #ffffff;
}

@media (max-width: 600px) {
    .tmm-nav-inner { gap: 0; }
    .tmm-nav-link { font-size: 0.72rem; padding: 5px 8px; }
}


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 3: SITE FOOTER                                     ║
   ╚══════════════════════════════════════════════════════════════╝ */

.tmm-site-footer {
    background: var(--tmm-light);
    border-top: 1px solid var(--tmm-border);
    padding: 24px 20px;
    text-align: center;
}
.tmm-footer-links {
    font-size: 0.82rem;
    margin-bottom: 8px;
}
.tmm-footer-links a {
    color: var(--tmm-navy);
    text-decoration: none;
    font-weight: 600;
}
.tmm-footer-links a:hover { color: var(--tmm-blue); }
.tmm-footer-copyright {
    font-size: 0.75rem;
    color: var(--tmm-muted);
}


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 4: REALIGN PAGE                                    ║
   ╚══════════════════════════════════════════════════════════════╝ */

.tmm-desc { font-size: 1rem; color: var(--tmm-subtle); line-height: 1.6; max-width: 600px; margin: 0 auto 20px; }

.tmm-realign-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
    align-items: stretch !important;
    max-width: var(--tmm-max-width);
    margin: 0 auto 60px !important;
}
.tmm-realign-card-navy,
.tmm-realign-card-light,
[class*="tmm-realign-card"] {
    padding: 30px 20px !important;
    border-radius: var(--tmm-radius);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    height: 100%;
}
.tmm-realign-card-navy { background: var(--tmm-navy); color: #FFFFFF !important; }
.tmm-realign-card-light { background: var(--tmm-light) !important; color: var(--tmm-text) !important; }
.tmm-realign-card-light h3 { color: var(--tmm-navy) !important; }
.tmm-realign-card-light .tmm-card-desc { color: var(--tmm-subtle) !important; }
.tmm-card-label {
    font-size: 0.7rem;
    font-weight: var(--tmm-weight-black);
    text-transform: uppercase;
    color: rgba(113, 128, 150, 0.8);
    margin-bottom: 10px;
}
.tmm-realign-card-navy .tmm-card-label { color: rgba(255, 255, 255, 0.5); }
.tmm-realign-card-light .tmm-card-label { color: var(--tmm-muted); }
.tmm-card-desc { font-size: 0.88rem; line-height: 1.5; flex-grow: 1; }
.tmm-realign-card-navy .tmm-card-desc { color: rgba(255, 255, 255, 0.75); }
.tmm-price { font-size: 1.4rem; font-weight: var(--tmm-weight-bold); margin: 8px 0 2px; }
.tmm-realign-card-navy .tmm-price { color: #FFFFFF; }
.tmm-realign-card-light .tmm-price { font-size: 1.2rem; color: var(--tmm-navy); }
.tmm-price-note { font-size: 0.78rem; color: rgba(255, 255, 255, 0.5); margin-bottom: 8px; }

/* Realign tabs */
.tmm-tabs { max-width: var(--tmm-max-width); margin: 0 auto 40px; padding: 0 20px; }
.tmm-tab-nav { display: flex; border-bottom: 1px solid var(--tmm-border); margin-bottom: 28px; }
.tmm-tab-panel { display: none; }
.tmm-tab-panel.active { display: block; }
.tmm-preview-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    max-width: 900px;
    margin: 0 auto;
}
.tmm-preview-img { width: 100%; height: auto; border-radius: var(--tmm-radius); border: 1px solid var(--tmm-border); display: block; }
.tmm-preview-caption { font-size: 0.82rem; color: var(--tmm-muted); text-align: center; margin-top: 16px; max-width: 600px; margin-left: auto; margin-right: auto; }
.tmm-preview-label { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--tmm-navy); }
.tmm-inside-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; max-width: 900px; margin: 0 auto; }
.tmm-inside-item { background: var(--tmm-light); border-radius: var(--tmm-radius); padding: 18px 20px; }
.tmm-inside-item-title { font-size: 0.88rem; font-weight: 700; color: var(--tmm-navy); margin-bottom: 4px; }
.tmm-inside-item-desc { font-size: 0.82rem; color: var(--tmm-subtle); line-height: 1.6; margin: 0; }

/* Amber bar */
.tmm-realign-amber {
    background: var(--tmm-amber-bg);
    border-radius: 6px;
    padding: 14px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1000px;
    margin: 0 auto 16px;
}
.tmm-realign-amber .tmm-amber-title { font-size: 1rem; font-weight: var(--tmm-weight-bold); color: var(--tmm-amber); }
.tmm-realign-amber .tmm-amber-desc { font-size: 0.88rem; color: var(--tmm-amber); }
.tmm-realign-amber a { color: var(--tmm-amber); font-weight: var(--tmm-weight-bold); }
.tmm-amber-link { color: var(--tmm-amber); font-weight: var(--tmm-weight-semi); font-size: 0.9rem; text-decoration: none; white-space: nowrap; }
.tmm-amber-link:hover { text-decoration: underline; }

/* Arrow links */
.tmm-arrow-link { font-size: 0.9rem; font-weight: var(--tmm-weight-bold); color: var(--tmm-blue); text-decoration: none; display: inline-flex; align-items: center; gap: 4px; }
.tmm-arrow-link:hover { color: var(--tmm-navy); }
.tmm-arrow-link-light { font-size: 0.9rem; font-weight: var(--tmm-weight-bold); color: rgba(255,255,255,0.9); text-decoration: none; display: inline-flex; align-items: center; gap: 4px; }
.tmm-arrow-link-light:hover { color: #FFFFFF; }


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 5: BADGES & STANDALONE BUTTONS                     ║
   ╚══════════════════════════════════════════════════════════════╝ */

.badge { display: inline-block; padding: 0.2rem 0.65rem; border-radius: 6px; font-size: 0.7rem; font-weight: var(--tmm-weight-black); text-transform: uppercase; letter-spacing: 0.5px; }
.badge-orange  { background: #f59e0b; color: #fff; }
.badge-blue    { background: var(--tmm-blue); color: #fff; }
.badge-green   { background: var(--tmm-green); color: #fff; }
.badge-grey    { background: #6b7280; color: #fff; }


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 6: FORM WRAPPER                                    ║
   ╚══════════════════════════════════════════════════════════════╝ */

.tmm-form-navy-wrapper { background: var(--tmm-navy); padding: 60px 20px; margin: auto 80px; border-radius: 12px; max-width: var(--tmm-max-width); }
.tmm-form-inner { background: #FFFFFF; border-radius: var(--tmm-radius); overflow: hidden; max-width: 900px; margin: 0 auto; }
.tmm-form-inner iframe { display: block; width: 100%; border: none; }

/* Diagnostic page form wrap — FIX 24 */
.tmm-form-wrap { max-width: 100%; margin: 0 auto 12px; border: 0.5px solid var(--tmm-border); border-radius: var(--tmm-radius); overflow: hidden; background: var(--tmm-navy); }
.tmm-form-wrap iframe { display: block; width: 100%; height: 600px !important; max-height: 600px !important; border: none; }


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 7: ABOUT PAGE                                      ║
   ╚══════════════════════════════════════════════════════════════╝ */

.tmm-about-split { display: flex; max-width: var(--tmm-max-width); margin: 0 auto 100px; gap: 80px; padding: 0 20px; }
.tmm-about-visual { flex: 0 0 40%; }
.tmm-video-card { background: var(--tmm-navy); aspect-ratio: 4/5; border-radius: 12px; position: sticky; top: 120px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #FFFFFF; padding: 40px; text-align: center; }
.tmm-play-icon { font-size: 4rem; opacity: 0.9; margin-bottom: 20px; }
.tmm-video-title { font-weight: var(--tmm-weight-bold); font-size: 1.2rem; margin: 0; }
.tmm-video-meta { font-size: 0.85rem; opacity: 0.6; margin-top: 10px; }
.tmm-about-text { flex: 1; }
.tmm-about-text h2 { font-size: 2.8rem; margin-top: 0; margin-bottom: 30px; }
.tmm-about-text p { font-size: 1.15rem; line-height: 1.8; color: var(--tmm-subtle); margin-bottom: 25px; }
.tmm-foundation-box { margin: 40px 0; padding: 30px 0; border-top: 1px solid var(--tmm-border); border-bottom: 1px solid var(--tmm-border); }
.tmm-foundation-box h4 { text-transform: uppercase; font-size: 0.75rem; letter-spacing: 2px; color: var(--tmm-muted); margin-bottom: 20px; }
.tmm-foundation-box ul { list-style: none; padding: 0; }
.tmm-foundation-box li { font-weight: var(--tmm-weight-body); color: var(--tmm-navy); margin-bottom: 12px; display: flex; gap: 10px; }
.tmm-foundation-box li::before { content: "▪"; color: #CBD5E0; }
.tmm-section-title { margin: 60px 0 30px; }
.tmm-evolution-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px 30px; margin-bottom: 50px; }
.tmm-evo-item h4 { font-size: 1rem; margin-bottom: 10px; color: var(--tmm-navy); }
.tmm-evo-item p { font-size: 0.95rem; line-height: 1.6; margin: 0; }


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 8: EXPLORE PAGE                                    ║
   ╚══════════════════════════════════════════════════════════════╝ */

/* FIX 21: max-width 860px → 1060px */
.tmm-explore-wrap { font-family: var(--tmm-font); max-width: 1060px; margin: 0 auto; padding: 2rem 3% 3rem; }

/* Tab bar */
.tmm-tab-bar { display: flex; border-bottom: 1px solid var(--tmm-border); margin-bottom: 1.5rem; overflow-x: auto; gap: 0; }
body .tmm-page-wrap .tmm-tab-bar { width: 100%; }
body .tmm-page-wrap .tmm-tab-content { width: 100%; }
body .tmm-page-wrap .tmm-tab-panel { width: 100%; }
.tmm-tab-btn { font-size: 0.7rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: #a0aec0; padding: 0.75rem 1rem; cursor: pointer; border: none; border-bottom: 2px solid transparent; margin-bottom: -1px; white-space: nowrap; background: none; min-height: unset; min-width: unset; }
.tmm-tab-btn:hover { color: var(--tmm-navy); }
.tmm-tab-btn.active { color: var(--tmm-navy); border-bottom-color: var(--tmm-navy); }
.tmm-tab-content { display: none; }
.tmm-tab-content.active { display: block; }

/* Milestone hero */
.tmm-milestone-hero { background: var(--tmm-navy); border-radius: 8px; padding: 1rem 1.25rem; margin-bottom: 0.75rem; text-align: center; }
.tmm-milestone-hero h2 { font-size: 1rem; font-weight: 600; color: #f8f6f1; margin-bottom: 0.35rem; line-height: 1.3; }
body .tmm-milestone-hero p { color: #a8c0d6 !important; font-size: 0.78rem; line-height: 1.5; max-width: 420px; margin: 0 auto 0.875rem; }
.tmm-milestone-form { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15); border-radius: 6px; padding: 0.75rem; display: flex; flex-direction: column; gap: 0.45rem; max-width: 400px; margin: 0 auto; }

/* Milestone accordions */
.tmm-accordion-list { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 0.75rem; }
.tmm-accordion-item { background: #fff; border: 1px solid var(--tmm-border); border-radius: 8px; overflow: hidden; }
.tmm-accordion-trigger { width: 100%; display: flex; align-items: center; justify-content: space-between; padding: 0.875rem 1.25rem; background: none; border: none; cursor: pointer; text-align: left; min-height: unset; min-width: unset; }
.tmm-accordion-left { display: flex; align-items: center; gap: 0.875rem; }
.tmm-accordion-eyebrow { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--tmm-navy); }
.tmm-accordion-sub { font-size: 0.72rem; color: var(--tmm-muted); }
.tmm-accordion-chev { font-size: 1.1rem; color: var(--tmm-muted); transition: transform 0.2s ease; flex-shrink: 0; display: inline-block; }
.tmm-accordion-body { display: none; padding: 0.75rem 1.25rem 0.875rem; border-top: 1px solid #f0f4f8; }
.tmm-accordion-body.open { display: block; }
.tmm-accordion-point { font-size: 0.78rem; color: #2d3748; line-height: 1.6; padding-left: 1rem; position: relative; margin-bottom: 0.35rem; }
.tmm-accordion-point::before { content: '→'; position: absolute; left: 0; color: #a0aec0; font-size: 0.7rem; }

/* Archetypes */
.tmm-archetype-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin-bottom: 0.75rem; }
.tmm-archetype-card { background: #fff; border: 1px solid var(--tmm-border); border-radius: 8px; overflow: hidden; display: grid; grid-template-rows: auto 1fr auto auto; }
.tmm-archetype-top { background: var(--tmm-navy); padding: 0.875rem 1.25rem; display: flex; align-items: center; gap: 0.75rem; }
.tmm-archetype-letter { font-size: 1rem; font-weight: 700; color: rgba(255,255,255,0.25); width: 28px; flex-shrink: 0; }
.tmm-archetype-name { font-size: 0.875rem; font-weight: 600; color: #f8f6f1; }
.tmm-archetype-section { padding: 0.75rem 1.25rem; border-bottom: 1px solid #f0f4f8; }
.tmm-archetype-section:last-child { border-bottom: none; }
.tmm-archetype-label { font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--tmm-muted); margin-bottom: 0.25rem; }
.tmm-archetype-text { font-size: 0.72rem; color: #2d3748; line-height: 1.5; }
.tmm-archetype-text strong { color: var(--tmm-navy); font-weight: 600; }
.tmm-archetype-complement { font-size: 0.65rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--tmm-blue); }
.tmm-archetype-note { background: var(--tmm-light); border: 1px solid var(--tmm-border); border-radius: 6px; padding: 0.75rem 1rem; font-size: 0.72rem; color: var(--tmm-subtle); line-height: 1.5; font-style: italic; margin-bottom: 0.75rem; }

/* Equity */
.tmm-equity-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin-bottom: 0.75rem; }
.tmm-equity-card { background: #fff; border: 1px solid var(--tmm-border); border-radius: 8px; overflow: hidden; display: flex; flex-direction: column; }
.tmm-equity-top { background: var(--tmm-navy); padding: 0.875rem 1.25rem; }
.tmm-equity-title { font-size: 0.875rem; font-weight: 600; color: #f8f6f1; margin-bottom: 0.2rem; }
.tmm-equity-sub { font-size: 0.65rem; color: #90aecb; }
.tmm-equity-body { padding: 0.875rem 1.25rem; flex: 1; display: flex; flex-direction: column; gap: 0.5rem; }
.tmm-equity-factor { font-size: 0.72rem; color: #2d3748; line-height: 1.5; }
.tmm-equity-factor strong { color: var(--tmm-navy); font-weight: 600; }
.tmm-equity-note { background: #fffbeb; border: 1px solid #fcd34d; border-radius: 6px; padding: 0.625rem 0.875rem; font-size: 0.68rem; color: #92400e; line-height: 1.5; margin-top: auto; }

/* Three Lanes */
.tmm-lanes-intro { background: #fff; border: 1px solid var(--tmm-border); border-radius: 8px; padding: 1rem 1.25rem; margin-bottom: 0.75rem; font-size: 0.8rem; color: #2d3748; line-height: 1.6; }
.tmm-lanes-intro strong { color: var(--tmm-navy); }
.tmm-lanes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-bottom: 0.75rem; }
.tmm-lane-card { background: #fff; border: 1px solid var(--tmm-border); border-radius: 8px; overflow: hidden; display: grid; grid-template-rows: auto 1fr; }
.tmm-lane-s { border-top: 3px solid var(--tmm-blue); }
.tmm-lane-t { border-top: 3px solid var(--tmm-green); }
.tmm-lane-r { border-top: 3px solid var(--tmm-navy); }
.tmm-lane-top { padding: 0.875rem 1.25rem; border-bottom: 1px solid #f0f4f8; }
.tmm-lane-title { font-size: 0.875rem; font-weight: 700; color: var(--tmm-navy); margin-bottom: 0.2rem; }
.tmm-lane-q { font-size: 0.72rem; color: var(--tmm-subtle); font-style: italic; }
.tmm-lane-body { padding: 0.875rem 1.25rem; }
.tmm-lane-measure { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--tmm-muted); margin-bottom: 0.5rem; }
.tmm-lane-desc { font-size: 0.78rem; color: var(--tmm-text); line-height: 1.6; }

/* 7 Dimensions */
.tmm-dim-list { display: flex; flex-direction: column; gap: 0.5rem; }
.tmm-dim-item { background: #fff; border: 1px solid var(--tmm-border); border-radius: 8px; overflow: hidden; }
.tmm-dim-trigger { width: 100%; display: flex; align-items: center; gap: 0.875rem; padding: 0.875rem 1.25rem; background: none; border: none; cursor: pointer; text-align: left; min-height: unset; min-width: unset; }
.tmm-dim-num { font-size: 0.65rem; font-weight: 700; color: #a0aec0; flex-shrink: 0; width: 22px; }
.tmm-dim-title { font-size: 0.875rem; font-weight: 700; color: var(--tmm-navy); flex: 1; }
.tmm-dim-q { font-size: 0.72rem; color: var(--tmm-muted); font-style: italic; margin-right: 0.5rem; }
.tmm-dim-chev { font-size: 1.1rem; color: var(--tmm-muted); transition: transform 0.2s ease; flex-shrink: 0; display: inline-block; }
.tmm-dim-body { display: none; border-top: 1px solid #f0f4f8; padding: 0.875rem 1.25rem; }
.tmm-dim-body.open { display: block; }
.tmm-dim-section-label { font-size: 0.6rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #a0aec0; margin-bottom: 0.3rem; }
.tmm-dim-section-text { font-size: 0.78rem; color: #2d3748; line-height: 1.6; margin-bottom: 0.75rem; }
.tmm-dim-working { color: #276749; }
.tmm-dim-starter { font-size: 0.78rem; color: var(--tmm-blue); line-height: 1.5; font-style: italic; }

/* Bottom strip */
.tmm-bottom-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    background: var(--tmm-light);
    border: 0.5px solid var(--tmm-border);
    border-radius: var(--tmm-radius);
    padding: 20px 28px;
    margin: 12px 0 0;
}
body .tmm-page-wrap .tmm-bottom-strip { width: 100%; }
.tmm-bottom-text { font-size: 0.875rem; font-weight: 600; color: var(--tmm-navy); line-height: 1.4; flex: 1; margin: 0; }
.tmm-bottom-btn {
    background: var(--tmm-navy) !important;
    color: #ffffff !important;
    font-size: 0.85rem !important;
    font-weight: 700 !important;
    padding: 10px 20px !important;
    border-radius: var(--tmm-radius-sm) !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    display: inline-block !important;
    flex-shrink: 0 !important;
    border: none !important;
    min-height: unset !important;
    min-width: unset !important;
}
.tmm-bottom-btn:hover { background: var(--tmm-blue) !important; color: #ffffff !important; }


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 9: CANONICAL COMPONENTS v2                         ║
   ╚══════════════════════════════════════════════════════════════╝ */

/* PAGE HERO */
body .tmm-page-hero { text-align: center; padding: 36px 32px 28px; background: var(--tmm-light); border-bottom: 1px solid var(--tmm-border); }
body .tmm-page-hero-name { font-size: clamp(1.1rem, 3vw, 1.5rem); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--tmm-navy); display: block; margin-bottom: 8px; }
body .tmm-page-hero-rule { height: 0.5px; background: var(--tmm-border); max-width: 320px; margin: 0 auto 10px; border: none; display: block; }
body .tmm-page-hero-tagline { font-size: 11px; font-style: italic; letter-spacing: 0.06em; text-transform: uppercase; color: var(--tmm-muted); display: block; }
body .tmm-page-hero-sub { font-size: 13px; color: var(--tmm-subtle); max-width: 560px; margin: 8px auto 0; line-height: 1.6; }

/* STRIP — navy */
body .tmm-strip { background: var(--tmm-navy); border-radius: 8px; overflow: hidden; margin-bottom: 12px; }
body .tmm-strip-header { padding: 12px 20px; border-bottom: 0.5px solid rgba(255,255,255,0.15); display: flex; align-items: center; gap: 12px; }
body .tmm-strip-label { font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: white; }
body .tmm-strip-rule { flex: 1; height: 0.5px; background: rgba(255,255,255,0.2); }
body .tmm-strip-body { padding: 16px 20px; }
body .tmm-strip-body p,
body .tmm-strip-body p strong,
body .tmm-strip-body p em,
body .tmm-strip-body h2,
body .tmm-strip-body h3,
body .tmm-strip-body h4 { color: #e2e8f0 !important; font-weight: 500; }

/* WHITE STRIP VARIANT */
body .tmm-strip-white { background: white; border: 0.5px solid var(--tmm-border); border-radius: 8px; overflow: hidden; margin-bottom: 12px; }
body .tmm-strip-white .tmm-strip-header { border-bottom: 0.5px solid var(--tmm-border); background: white; padding: 12px 20px; display: flex; align-items: center; gap: 12px; }
body .tmm-strip-white .tmm-strip-label { color: var(--tmm-navy); }
body .tmm-strip-white .tmm-strip-rule { background: var(--tmm-border); }
body .tmm-strip-white .tmm-strip-body p { color: #2d3748; }
body .tmm-strip-white .tmm-card-title-white { color: var(--tmm-navy); }
body .tmm-strip-white .tmm-card-desc-white { color: #2d3748; }

/* NAVY BLOCK */
body .tmm-navy-block { background: var(--tmm-navy); border-radius: 8px; overflow: hidden; margin-bottom: 12px; }
body .tmm-navy-block-header { padding: 12px 20px; border-bottom: 0.5px solid rgba(255,255,255,0.15); display: flex; align-items: center; gap: 12px; }
body .tmm-navy-block-label { font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: white; }
body .tmm-navy-block-rule { flex: 1; height: 0.5px; background: rgba(255,255,255,0.2); }
body .tmm-navy-block-body { padding: 16px 20px; }
body .tmm-navy-block-body p,
body .tmm-navy-block-body p strong,
body .tmm-navy-block-body p em,
body .tmm-navy-block-body h2,
body .tmm-navy-block-body h3,
body .tmm-navy-block-body h4 { color: #e2e8f0 !important; font-weight: 500; }

/* CARD GRIDS — FIX 22: min-width: 0 on all grid children */
body .tmm-card-grid { display: grid; gap: 12px; }
body .tmm-card-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; width: 100%; min-width: 0; }
body .tmm-card-grid-2 > * { min-width: 0; }
body .tmm-card-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; width: 100%; min-width: 0; }
body .tmm-card-grid-3 > * { min-width: 0; }
body .tmm-card-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; width: 100%; min-width: 0; }
body .tmm-card-grid-4 > * { min-width: 0; }
body .tmm-card { border-radius: 8px; padding: 18px; display: flex; flex-direction: column; }
body .tmm-card-navy { background: var(--tmm-navy); }
body .tmm-card-white { background: white; border: 1px solid #d1d9e0; }

/* Card labels */
body .tmm-card-label-navy { font-size: 10px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: white; margin-bottom: 6px; }
body .tmm-card-label-white { font-size: 10px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--tmm-navy); margin-bottom: 6px; }

/* Card titles */
body .tmm-card-title-navy { font-size: 14px; font-weight: 700; color: white; margin-bottom: 6px; line-height: 1.3; }
body .tmm-card-title-white { font-size: 14px; font-weight: 700; color: var(--tmm-navy); margin-bottom: 6px; line-height: 1.3; }

/* Card descriptions */
body .tmm-card-desc-navy { font-size: 12px; font-weight: 500; color: #e2e8f0; line-height: 1.55; flex: 1; }
body .tmm-card-desc-white { font-size: 12px; font-weight: 500; color: #2d3748; line-height: 1.55; flex: 1; }

/* Card meta */
body .tmm-card-meta-navy { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: white; margin-top: 8px; }
body .tmm-card-meta-white { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #2d3748; margin-top: 8px; }

/* Card dividers */
body .tmm-card-divider-navy { height: 0.5px; background: rgba(255,255,255,0.15); margin: 12px 0; }
body .tmm-card-divider-white { height: 0.5px; background: var(--tmm-border); margin: 12px 0; }

/* Links on navy backgrounds */
body .tmm-card-navy a,
body .tmm-strip a,
body .tmm-navy-block a,
body .tmm-collapse-navy a { color: #e2e8f0 !important; }
body .tmm-card-navy a:hover,
body .tmm-strip a:hover,
body .tmm-navy-block a:hover,
body .tmm-collapse-navy a:hover { color: white !important; }

/* FIX 23 — catch-all white links on navy contexts */
body .tmm-form-navy-wrapper a,
body .tmm-milestone-hero a,
body .tmm-collapse-navy .tmm-collapse-body a,
body .tmm-page-hero a { color: #FFFFFF !important; }
body .tmm-form-navy-wrapper a:hover,
body .tmm-milestone-hero a:hover,
body .tmm-collapse-navy .tmm-collapse-body a:hover { color: #e2e8f0 !important; }
body .tmm-realign-card-navy a { color: #e2e8f0 !important; }
body .tmm-realign-card-navy a:hover { color: white !important; }

/* COLLAPSE BOX */
body .tmm-collapse { border-radius: 6px; overflow: hidden; cursor: pointer; user-select: none; margin-top: 8px; }
body .tmm-collapse-navy { background: var(--tmm-navy); border: 0.5px solid rgba(255,255,255,0.2); }
body .tmm-collapse-white { background: white; border: 0.5px solid #d1d9e0; }
body .tmm-collapse-trigger { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; }
body .tmm-collapse-label-navy { font-size: 11px; font-weight: 700; color: white; }
body .tmm-collapse-label-white { font-size: 11px; font-weight: 700; color: var(--tmm-navy); }
body .tmm-collapse-arrow { font-size: 13px; transition: transform 0.2s ease; display: inline-block; }
body .tmm-collapse-arrow-navy { color: rgba(255,255,255,0.6); }
body .tmm-collapse-arrow-white { color: var(--tmm-navy); }
body .tmm-collapse-body { display: none; padding: 0 14px 14px; }
body .tmm-collapse-body.open { display: block; }

/* iBox */
body .tmm-ibox-navy { background: rgba(255,255,255,0.08); border: 0.5px solid rgba(255,255,255,0.15); border-radius: 4px; padding: 7px 10px; flex: 1; }
body .tmm-ibox-white { background: var(--tmm-light); border: 0.5px solid var(--tmm-border); border-radius: 4px; padding: 7px 10px; flex: 1; }
body .tmm-ibox-label-navy { font-size: 9px; font-weight: 600; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 2px; }
body .tmm-ibox-label-white { font-size: 9px; font-weight: 600; color: var(--tmm-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 2px; }
body .tmm-ibox-value-navy { font-size: 11px; color: white; font-weight: 600; }
body .tmm-ibox-value-white { font-size: 11px; color: var(--tmm-navy); font-weight: 600; }
body .tmm-collapse-divider-navy { height: 0.5px; background: rgba(255,255,255,0.15); margin-bottom: 12px; }
body .tmm-collapse-divider-white { height: 0.5px; background: var(--tmm-border); margin-bottom: 12px; }
body .tmm-collapse-cta-navy { font-size: 12px; font-weight: 600; color: white !important; text-decoration: none; display: block; }
body .tmm-collapse-cta-white { font-size: 12px; font-weight: 600; color: var(--tmm-navy) !important; text-decoration: none; display: block; }

/* CTA STRIP */
body .tmm-cta-strip { background: white; border: 0.5px solid var(--tmm-border); border-radius: 8px; padding: 20px; margin-bottom: 12px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
body .tmm-cta-left { flex: 1; }
body .tmm-cta-eyebrow { font-size: 10px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: #a0aec0; margin-bottom: 4px; }
body .tmm-cta-title { font-size: 15px; font-weight: 700; color: var(--tmm-navy); margin-bottom: 4px; }
body .tmm-cta-desc { font-size: 12px; color: var(--tmm-muted); line-height: 1.4; }
body .tmm-cta-btns { display: flex; flex-direction: column; gap: 8px; flex-shrink: 0; min-width: 180px; }

/* TMM BUTTONS */
body .tmm-btn-primary,
body .tmm-btn-primary:link,
body .tmm-btn-primary:visited {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: white !important;
    background: var(--tmm-navy) !important;
    border-radius: 4px !important;
    padding: 9px 20px !important;
    text-decoration: none !important;
    display: block !important;
    text-align: center !important;
    border: none !important;
    cursor: pointer;
    min-height: unset !important;
    min-width: unset !important;
}
body .tmm-btn-primary:hover { background: var(--tmm-blue) !important; color: white !important; }
body .tmm-btn-secondary,
body .tmm-btn-secondary:link,
body .tmm-btn-secondary:visited {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--tmm-navy) !important;
    background: var(--tmm-light) !important;
    border: 0.5px solid var(--tmm-border) !important;
    border-radius: 4px !important;
    padding: 9px 20px !important;
    text-decoration: none !important;
    display: block !important;
    text-align: center !important;
    cursor: pointer;
    min-height: unset !important;
    min-width: unset !important;
}
body .tmm-btn-secondary:hover { background: #edf2f7 !important; color: var(--tmm-navy) !important; }

/* TRUST BAR */
body .tmm-trust-bar { border-top: 0.5px solid var(--tmm-border); padding: 12px 20px; text-align: center; background: var(--tmm-light); }
body .tmm-trust-text { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: #2d3748; }
body .tmm-trust-text span { color: var(--tmm-navy); }

/* ROUTING STRIP */
body .tmm-routing-strip { background: white; border-top: 1px solid var(--tmm-border); border-bottom: 1px solid var(--tmm-border); padding: 16px 32px; display: flex; align-items: flex-start; gap: 24px; }
body .tmm-routing-label { font-size: 11px; font-weight: 700; color: var(--tmm-navy); text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; flex-shrink: 0; padding-top: 1px; }
body .tmm-routing-links { display: flex; flex-direction: column; gap: 7px; }
body .tmm-routing-link { font-size: 12px; color: var(--tmm-navy); text-decoration: none; display: flex; align-items: center; gap: 6px; }
body .tmm-routing-link:hover { color: var(--tmm-blue); }

/* PAGE WRAPPER — FIX 21: 900px → 1060px, padding → 24px 3% */
body .tmm-page-wrap { max-width: 1060px; margin: 0 auto; padding: 24px 3%; display: flex; flex-direction: column; gap: 12px; padding-bottom: 0 !important; margin-bottom: 0 !important; }

/* TWO BOX ROW */
body .tmm-two-box { display: flex; align-items: stretch; gap: 6px; margin-bottom: 12px; }
body .tmm-two-box-arrow { font-size: 11px; display: flex; align-items: center; padding: 0 4px; flex-shrink: 0; }
body .tmm-two-box-arrow-navy { color: white; }
body .tmm-two-box-arrow-white { color: var(--tmm-navy); }


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 10: PRIVACY POLICY                                 ║
   ╚══════════════════════════════════════════════════════════════╝ */

.tmm-policy-content { max-width: 800px; margin: 0 auto; padding: 0 0 40px; }
.tmm-policy-content h2 { font-size: 1.1rem; color: var(--tmm-navy); margin: 32px 0 12px; padding-bottom: 8px; border-bottom: 1px solid var(--tmm-border); }
.tmm-policy-content h3 { font-size: 0.95rem; color: var(--tmm-navy); margin: 24px 0 8px; }
.tmm-policy-content p { font-size: 0.9rem; line-height: 1.7; color: var(--tmm-text); margin: 0 0 12px; }
.tmm-policy-content ul { margin: 0 0 16px; padding-left: 20px; }
.tmm-policy-content li { font-size: 0.88rem; line-height: 1.7; color: var(--tmm-text); margin-bottom: 6px; }
.tmm-policy-content hr { border: none; border-top: 1px solid var(--tmm-border); margin: 28px 0; }
.tmm-policy-content table { border-collapse: collapse; width: 100%; margin: 16px 0; }
.tmm-policy-content th { background: var(--tmm-light); color: var(--tmm-navy); text-align: left; padding: 10px 16px; font-weight: 700; font-size: 0.88rem; border: 1px solid var(--tmm-border); }
.tmm-policy-content td { padding: 10px 16px; border: 1px solid var(--tmm-border); font-size: 0.88rem; color: var(--tmm-text); }
.tmm-policy-content strong { color: var(--tmm-navy); }


/* ╔══════════════════════════════════════════════════════════════╗
   ║  SECTION 11: RESPONSIVE                                     ║
   ╚══════════════════════════════════════════════════════════════╝ */

@media (max-width: 768px) {
    h1 { font-size: 1.8rem; }

    body .tmm-card-grid-2,
    body .tmm-card-grid-3,
    body .tmm-card-grid-4 { grid-template-columns: 1fr; }
    body .tmm-cta-strip { flex-direction: column; align-items: flex-start; }
    body .tmm-cta-btns { width: 100%; min-width: unset; }
    body .tmm-routing-strip { flex-direction: column; gap: 12px; padding: 16px 20px; }
    body .tmm-page-wrap { padding: 16px; }
    body .tmm-page-hero { padding: 20px 16px 16px; }
    body .tmm-strip-body .tmm-card-grid-3 { grid-template-columns: 1fr; }

    /* Realign */
    .tmm-realign-grid { grid-template-columns: 1fr !important; }
    .tmm-preview-grid, .tmm-inside-grid { grid-template-columns: 1fr; }
    .tmm-tab-btn { padding: 10px 14px; font-size: 0.82rem; }
    .tmm-realign-amber { flex-direction: column; gap: 8px; text-align: center; }

    /* Explore */
    .tmm-archetype-grid,
    .tmm-equity-row,
    .tmm-lanes-grid { grid-template-columns: 1fr; }
    .tmm-bottom-strip { flex-direction: column; align-items: flex-start; }
    .tmm-bottom-btn { width: 100% !important; text-align: center !important; }

    /* About */
    .tmm-about-split { flex-direction: column; gap: 40px; }
    .tmm-about-visual { width: 100%; }
    .tmm-video-card { position: relative; top: 0; aspect-ratio: 16/9; }
    .tmm-about-text h2 { font-size: 2rem; }
    .tmm-evolution-grid { grid-template-columns: 1fr; }

    .tmm-form-navy-wrapper { margin: auto 20px; }
}

@media (max-width: 480px) {
    body .tmm-page-hero-name { font-size: 1.1rem; }
    body .tmm-cta-title { font-size: 14px; }
    body .tmm-card { padding: 14px; }
    body .tmm-strip-body, body .tmm-navy-block-body { padding: 12px 14px; }
}

@media (min-width: 769px) and (max-width: 900px) {
    .tmm-about-split { flex-direction: column; gap: 40px; }
    .tmm-about-visual { width: 100%; }
    .tmm-video-card { position: relative; top: 0; aspect-ratio: 16/9; }
    .tmm-evolution-grid { grid-template-columns: 1fr; }
}
