/* 
 * TheToenailClinicNYC.com — Global Clinical Design System v3.0
 * -----------------------------------------------------------------------
 * Single source of truth for ALL pages, components, templates & widgets.
 * Reference: DESIGN-SYSTEM.md (check that file for governance rules)
 * Brand: Inter (body) + Outfit (headings) | Navy + Blue + Teal palette
 */

/* ======================================================================
   1. CSS CUSTOM PROPERTIES (Design Tokens)
   All brand colors, spacing, radius & shadow defined once here.
   ====================================================================== */
:root {
    /* === PRIMARY BRAND COLORS === */
    --color-navy:        #1a365d;   /* Deep Indigo Navy — headings, authority text */
    --color-blue:        #2b6cb0;   /* Clinical Blue — links, buttons, badges */
    --color-teal:        #236c6a;   /* Darkened Teal — Better contrast for AA (from #319795) */
    --color-teal-light:  #319795;   /* Original teal as light variant */

    /* Legacy aliases (backward compat with older components) */
    --brand-primary:     #1a365d;
    --brand-secondary:   #2c5282;
    --brand-accent:      #2b6cb0;
    --brand-highlight:   #ebf8ff;
    --brand-emerald:     #319795;
    --brand-red:         #c53030;

    /* === SEMANTIC COLORS === */
    --color-danger:      #c53030;
    --color-danger-bg:   #fff5f5;
    --color-danger-border: #fc8181;

    --color-caution:     #b7791f;
    --color-caution-bg:  #fffbeb;
    --color-caution-border: #f6ad55;

    --color-success:     #276749;
    --color-success-bg:  #f0fff4;
    --color-success-border: #68d391;

    --color-info:        #2b6cb0;
    --color-info-bg:     #ebf8ff;
    --color-info-border: #90cdf4;

    /* === TEXT COLORS === */
    --color-text-primary:   #1a365d;   /* Headings */
    --color-text-body:      #2d3748;   /* Prose */
    --color-text-secondary: #4a5568;   /* Supporting text */
    --color-text-muted:     #606f7b;   /* Darkened from #718096 for better contrast */
    --color-text-disabled:  #a0aec0;   /* Decorative only */

    /* Legacy text aliases */
    --text-main:   #2d3748;
    --text-muted:  #718096;

    /* === BACKGROUND COLORS === */
    --color-bg:          #ffffff;
    --color-bg-subtle:   #f7fafc;
    --color-bg-card:     #ffffff;
    --color-bg-sidebar:  #f7fafc;
    --color-bg-hero:     #1a365d;
    --color-bg-clinical: #ebf8ff;

    /* Legacy bg aliases */
    --bg-light: #f7fafc;

    /* === BORDER COLORS === */
    --color-border:        #e2e8f0;
    --color-border-medium: #cbd5e0;
    --color-border-brand:  #2b6cb0;

    /* Legacy border alias */
    --border-light: #e2e8f0;

    /* === SPACING SCALE === */
    --space-1:  0.25rem;
    --space-2:  0.5rem;
    --space-3:  0.75rem;
    --space-4:  1rem;
    --space-5:  1.25rem;
    --space-6:  1.5rem;
    --space-8:  2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;

    /* === BORDER RADIUS (max: 1.5rem per governance) === */
    --radius-sm:      0.375rem;   /*  6px — badges, tags */
    --radius-md:      0.75rem;    /* 12px — buttons, inputs */
    --radius-lg:      1rem;       /* 16px — standard cards */
    --radius-xl:      1.5rem;     /* 24px — major cards, sections (MAXIMUM) */
    --radius-full:    9999px;     /* pills, avatars */

    /* Legacy radius aliases */
    --radius-premium: 1.5rem;
    --radius-card:    1.5rem;
    --radius-inner:   1rem;

    /* === SHADOWS === */
    --shadow-sm:   0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
    --shadow-md:   0 4px 12px rgba(43,108,176,0.10);
    --shadow-lg:   0 8px 24px rgba(43,108,176,0.15);
    --shadow-soft: 0 10px 25px -5px rgba(0,0,0,0.05), 0 8px 10px -6px rgba(0,0,0,0.05);

    /* === FONTS === */
    --font-heading: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ======================================================================
   2. GLOBAL BASE STYLES
   Applied to the entire site, not just silo pages.
   ====================================================================== */
*, *::before, *::after {
    box-sizing: border-box;
}

body {
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.75;
    color: var(--color-text-body);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Global heading baseline */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--color-text-primary);
    line-height: 1.25;
}

/* Heading weights — per DESIGN-SYSTEM.md Section 2.2 */
h1 { font-weight: 700; font-size: 2.75rem; letter-spacing: -0.02em; color: var(--color-navy); }
h2 { font-weight: 700; font-size: 1.875rem; letter-spacing: -0.01em; color: var(--color-navy); }
h3 { font-weight: 700; font-size: 1.375rem; color: var(--color-navy); }
h4 { font-weight: 700; font-size: 1.125rem; color: var(--color-navy); }
h5 { font-weight: 600; font-size: 0.875rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-secondary); }
h6 { font-weight: 600; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-muted); }

/* Links */
a { color: var(--color-blue); text-decoration: none; }
a:hover { color: var(--color-navy); }
a:visited { color: #553c9a; }

/* Focus states — WCAG AA requirement */
:focus-visible {
    outline: 2px solid #63b3ed;
    outline-offset: 3px;
    border-radius: 4px;
}
:focus:not(:focus-visible) { outline: none; }

/* ======================================================================
   3. UTILITY CLASSES (Brand Tokens as CSS classes)
   ====================================================================== */

/* Containers */
.ttnc-container    { max-width: 1280px; margin: 0 auto; padding: 0 1.5rem; }
.ttnc-container-sm { max-width: 720px;  margin: 0 auto; padding: 0 1.5rem; }
.ttnc-prose-width  { max-width: 68ch; }

/* Colors */
.text-navy  { color: var(--color-navy)  !important; }
.text-blue  { color: var(--color-blue)  !important; }
.text-teal  { color: var(--color-teal)  !important; }
.text-muted { color: var(--color-text-muted) !important; }
.text-body  { color: var(--color-text-body) !important; }

/* Backgrounds */
.bg-brand-primary   { background-color: var(--color-navy)       !important; }
.bg-brand-secondary { background-color: var(--color-blue)       !important; }
.bg-brand-accent    { background-color: var(--color-teal)       !important; }
.bg-brand-highlight { background-color: var(--color-bg-clinical)!important; }
.bg-subtle          { background-color: var(--color-bg-subtle)  !important; }
.bg-navy { 
    background-color: var(--color-navy) !important; 
    color: #ffffff !important; 
}

/* Ensure child text inside navy sections is visible */
.bg-navy p, 
.bg-navy span:not(.bg-white *), 
.bg-navy div:not(.bg-white *),
.bg-navy li {
    color: rgba(255, 255, 255, 0.9) !important;
}

.bg-navy h1, .bg-navy h2, .bg-navy h3, .bg-navy h4 {
    color: #ffffff !important;
}

.bg-clinical        { background-color: var(--color-bg-clinical); }

/* Override Tailwind utility colors with brand palette */
.bg-slate-900   { background-color: var(--color-navy) !important; }
.bg-blue-600    { background-color: var(--color-blue) !important; }
.bg-red-600     { background-color: var(--color-danger) !important; }
.bg-emerald-50  { background-color: var(--color-success-bg) !important; }
.bg-slate-50, .bg-slate-100 { background-color: var(--color-bg-subtle) !important; }

.text-blue-600  { color: var(--color-blue) !important; }
.text-slate-900 { color: var(--color-navy) !important; }
.text-slate-600 { color: var(--color-text-secondary) !important; }
.text-slate-500 { color: var(--color-text-muted) !important; }
.text-slate-400 { color: var(--color-text-muted) !important; }
.text-emerald-500, .text-emerald-600 { color: var(--color-teal) !important; }

.border-slate-100, .border-slate-200 { border-color: var(--color-border) !important; }

/* Spacing utilities */
.mt-block   { margin-top: var(--space-8); }
.mb-block   { margin-bottom: var(--space-8); }
.mt-section { margin-top: var(--space-16); }
.mb-section { margin-bottom: var(--space-16); }

/* Table scroll wrapper */
.table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    margin: 1.5rem 0;
}

/* Accessibility — screen reader only */
.sr-only {
    position: absolute; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* Override oversize border radii (Governance Rule 11.1) */
.font-black     { font-weight: 700 !important; }
.uppercase      { letter-spacing: 0.05em; }
.tracking-tighter { letter-spacing: -0.01em; }

/* Cap oversized border radius values from legacy markup */
.rounded-\[4rem\]   { border-radius: var(--radius-xl) !important; }
.rounded-\[3rem\]   { border-radius: var(--radius-xl) !important; }
.rounded-\[3\.5rem\] { border-radius: var(--radius-xl) !important; }
.rounded-\[2\.5rem\] { border-radius: var(--radius-xl) !important; }
.rounded-\[2rem\]   { border-radius: var(--radius-xl) !important; }

/* ======================================================================
   4. TOPIC WRAPPER & LAYOUT
   ====================================================================== */
.medical-card {
    background: var(--color-bg-card);
    padding: 2rem;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    transition: transform 200ms, box-shadow 200ms;
}

.medical-card--blue {
    background: #f0f7ff !important;
    border-color: #bee3f8 !important;
}

.medical-card--teal {
    background: #e6fffa !important;
    border-color: #b2f5ea !important;
}

.medical-card--caution {
    background: #fffaf0 !important;
    border-color: #fbd38d !important;
}

.medical-card--alert {
    background: #fff5f5 !important;
    border-color: #feb2b2 !important;
}

.medical-card--dark {
    background: var(--color-navy) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
}

.topic-wrapper {
    font-family: var(--font-body);
    color: var(--color-text-body);
    line-height: 1.75;
    background-color: var(--color-bg);
}

.topic-wrapper h1,
.topic-wrapper h2,
.topic-wrapper h3,
.topic-wrapper h4 {
    font-family: var(--font-heading);
    color: var(--color-text-primary);
    font-weight: 700;
    letter-spacing: -0.01em;
    line-height: 1.25;
}

/* Hero Section */
.topic-hero {
    background: linear-gradient(135deg, #1a365d 0%, #2a4365 60%, #2b6cb0 100%);
    padding: 7rem 0 6rem;
    color: white;
    position: relative;
    overflow: hidden;
}

.topic-hero h1, .topic-hero h2 {
    color: #ffffff !important;
}

.topic-hero p, .topic-hero span {
    color: rgba(255, 255, 255, 0.9) !important;
}

/* Main content grid */
.topic-main {
    max-width: 1200px;
    margin: -4rem auto 6rem;
    padding: 0 1.5rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
}

@media (min-width: 1024px) {
    .topic-main {
        grid-template-columns: 8fr 4fr;
    }
}

/* Main content card */
.topic-content-card {
    background: var(--color-bg-card);
    border-radius: var(--radius-xl);
    padding: 3rem;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-soft);
}

/* ======================================================================
   5. MEDICAL CARD COMPONENT
   ====================================================================== */
.medical-card {
    background: var(--color-bg-card);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: box-shadow 200ms ease, transform 200ms ease;
    display: block;
}

.medical-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.medical-card h4 {
    font-family: var(--font-heading);
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 0.5rem;
}

.medical-card p {
    font-size: 0.9375rem;
    color: var(--color-text-secondary);
    line-height: 1.65;
}

/* Card Variants */
.medical-card--blue   { border-top: 3px solid var(--color-blue); }
.medical-card--teal   { border-top: 3px solid var(--color-teal); }
.medical-card--dark   { background: var(--color-navy); color: #fff; }
.medical-card--alert  { background: var(--color-danger-bg); border-color: var(--color-danger-border); }

/* ======================================================================
   6. BUTTON SYSTEM
   ====================================================================== */
.btn-primary {
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--color-blue); color: #ffffff;
    padding: 0.75rem 1.5rem; border-radius: var(--radius-md);
    font-family: var(--font-body); font-weight: 700; font-size: 0.9375rem;
    border: none; cursor: pointer; text-decoration: none;
    transition: background 200ms, transform 150ms;
    min-height: 44px; /* WCAG touch target */
}
.btn-primary:hover  { background: var(--color-navy); color: #fff; transform: translateY(-1px); }
.btn-primary:active { transform: translateY(0); }

.btn-secondary {
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent; color: var(--color-blue);
    border: 2px solid var(--color-blue);
    padding: 0.625rem 1.375rem; border-radius: var(--radius-md);
    font-family: var(--font-body); font-weight: 600; font-size: 0.875rem;
    cursor: pointer; text-decoration: none; transition: all 200ms;
    min-height: 44px;
}
.btn-secondary:hover { background: var(--color-bg-clinical); color: var(--color-navy); }

.btn-teal {
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--color-teal); color: #ffffff;
    padding: 0.75rem 1.5rem; border-radius: var(--radius-md);
    font-family: var(--font-body); font-weight: 700; font-size: 0.9375rem;
    border: none; cursor: pointer; text-decoration: none;
    transition: background 200ms; min-height: 44px;
}
.btn-teal:hover { background: #2c7a7b; color: #fff; }

/* ======================================================================
   7. SIDEBAR NAVIGATION CARD
   ====================================================================== */
.sidebar-nav-card {
    background: var(--color-bg-subtle);
    border-radius: var(--radius-xl);
    padding: 2rem;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.nav-section-title {
    font-family: var(--font-heading);
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 1.25rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.nav-link {
    display: block;
    padding: 0.625rem 0.75rem;
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: background 150ms, color 150ms;
    min-height: 44px;
    display: flex;
    align-items: center;
}

.nav-link:hover {
    background: var(--color-bg-clinical);
    color: var(--color-blue);
}

.nav-link.active {
    background: var(--color-blue);
    color: #ffffff;
    font-weight: 600;
}

/* ======================================================================
   8. FAQ BLOCKS
   ====================================================================== */
.faq-block {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 0.75rem;
}

.faq-q {
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text-primary);
    padding: 1rem 1.25rem;
    background: var(--color-bg-card);
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin: 0;
    cursor: pointer;
}

.faq-q span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    min-width: 1.75rem;
    background: var(--color-blue);
    color: white;
    border-radius: 50%;
    font-size: 0.75rem;
    font-weight: 700;
}

.faq-a {
    padding: 0 1.25rem 1.25rem 3.75rem;
    background: var(--color-bg-card);
    font-size: 0.9375rem;
    line-height: 1.6;
    color: var(--color-text-body);
}

.faq-a p {
    margin-bottom: 0.75rem;
}

/* ======================================================================
   9. TABLE SYSTEM
   ====================================================================== */
.premium-table-wrapper {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.premium-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9375rem;
}

.premium-table th {
    background: var(--color-navy);
    color: #ffffff;
    padding: 0.875rem 1rem;
    font-family: var(--font-body);
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-align: left;
}

.premium-table td {
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--color-border);
    font-size: 0.9375rem;
    color: var(--color-text-body);
    line-height: 1.5;
}

.premium-table tr:nth-child(even) {
    background: var(--color-bg-subtle);
}

.premium-table tr:last-child td {
    border-bottom: none;
}

/* ======================================================================
   10. BRAND BADGE & EEAT ELEMENTS
   ====================================================================== */
.brand-badge {
    display: inline-block;
    padding: 0.2rem 0.625rem;
    background: var(--color-bg-clinical);
    color: var(--color-blue);
    border-radius: var(--radius-sm);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* EEAT Author Box */
.eeat-author {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    margin-bottom: 2rem;
}

.eeat-author__label {
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    display: block;
}

.eeat-author__name {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--color-text-primary);
    display: block;
}

.eeat-author__title {
    font-size: 0.8125rem;
    color: var(--color-teal);
    font-weight: 500;
    display: block;
}

/* ======================================================================
   11. ALERT / MEDICAL WARNING BLOCKS
   ====================================================================== */
.alert {
    padding: 1rem 1.25rem;
    border-radius: var(--radius-md);
    border-left: 4px solid;
    margin: 1.5rem 0;
    font-size: 0.9375rem;
    line-height: 1.65;
}

.alert-title {
    font-weight: 700;
    font-size: 0.9375rem;
    margin-bottom: 0.25rem;
    display: block;
}

.alert-danger  { background: var(--color-danger-bg);  border-color: var(--color-danger-border);  color: #742a2a; }
.alert-caution { background: var(--color-caution-bg); border-color: var(--color-caution-border); color: #744210; }
.alert-success { background: var(--color-success-bg); border-color: var(--color-success-border); color: #22543d; }
.alert-info    { background: var(--color-info-bg);    border-color: var(--color-info-border);    color: var(--color-navy); }

/* ======================================================================
   12. CLINICAL NAVIGATOR SECTION
   ====================================================================== */
.clinical-navigator {
    font-family: var(--font-body);
}

.clinical-navigator h3 {
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--color-text-primary);
}

/* ======================================================================
   13. MOBILE-FIRST RESPONSIVE RULES
   Per DESIGN-SYSTEM.md Section 8
   ====================================================================== */
@media (max-width: 640px) {
    h1 { font-size: 1.875rem !important; line-height: 1.3; }
    h2 { font-size: 1.375rem !important; }
    h3 { font-size: 1.125rem !important; }

    body { font-size: 0.9375rem; }

    .topic-hero     { padding: 4rem 1rem 5rem; text-align: left; }
    .topic-main     { margin-top: -2rem; padding: 0 1rem; gap: 1.5rem; }
    .topic-content-card { padding: 1.5rem 1.25rem; border-radius: var(--radius-lg); }

    .medical-card  { padding: 1.25rem; }

    /* Prevent horizontal scroll from oversized elements */
    .grid { grid-template-columns: 1fr !important; }

    /* Table mobile scroll hint */
    .table-scroll::after {
        content: "← Scroll to see more →";
        display: block; text-align: center;
        font-size: 0.75rem; color: var(--color-text-muted);
        padding: 0.5rem; background: var(--color-bg-subtle);
    }
}

@media (max-width: 768px) {
    .topic-hero     { padding: 4rem 0 6rem; }
    .topic-hero h1  { font-size: 2rem; }
    .topic-main     { margin-top: -3rem; padding: 0 1.25rem; gap: 2rem; }
    .topic-content-card { padding: 2rem 1.5rem; }
    .medical-card  { padding: 1.5rem; }
}

/* ======================================================================
   14. GRID OVERRIDES & LAYOUT HELPERS
   ====================================================================== */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }

@media (max-width: 1024px) {
    .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* Tailwind gap/margin overrides for visual rhythm consistency */
.gap-16  { gap: 3rem; }
.mb-24   { margin-bottom: 4rem; }
.mb-20   { margin-bottom: 3.5rem; }

/* ======================================================================
   15. PERFORMANCE: GLASS / EFFECTS GOVERNANCE
   Per DESIGN-SYSTEM.md Section 7 — subtle glass only on dark hero areas
   ====================================================================== */
.glass-subtle {
    background: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.15);
}

/* Entrance animation — once only, GPU only */
.animate-premium {
    animation: fadeInUp 400ms ease forwards;
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ======================================================================
   16. GLOBAL SITE-WIDE BRAND HARMONIZATION
   Enforcing DESIGN-SYSTEM.md across default theme elements (Kadence).
   ====================================================================== */

/* Global Link & Interactive Consistency */
a {
    transition: color 0.2s ease, border-color 0.2s ease;
}

a:focus-visible, 
button:focus-visible, 
input:focus-visible, 
textarea:focus-visible {
    outline: 3px solid var(--color-blue) !important;
    outline-offset: 3px !important;
    border-radius: var(--radius-sm) !important;
}

/* Header & Navigation Harmony */
#site-header, .site-header-inner {
    background-color: #ffffff !important;
    border-bottom: 1px solid var(--color-border) !important;
}

.main-navigation a {
    color: var(--color-navy) !important;
    font-weight: 600 !important;
    font-family: var(--font-heading) !important;
    font-size: 0.9375rem !important;
}

.main-navigation a:hover {
    color: var(--color-blue) !important;
}

/* Footer Harmony */
#site-footer, .site-footer-inner {
    background-color: var(--color-navy) !important;
    color: #ffffff !important;
    padding-top: var(--space-12) !important;
    padding-bottom: var(--space-12) !important;
}

#site-footer a {
    color: rgba(255, 255, 255, 0.8) !important;
}

#site-footer a:hover {
    color: #ffffff !important;
    text-decoration: underline !important;
}

#site-footer h1, #site-footer h2, #site-footer h3, #site-footer h4 {
    color: #ffffff !important;
}

/* Global Button Override (Kadence/Gutenberg) */
.wp-block-button__link, 
button, 
input[type="submit"], 
.kb-button {
    background-color: var(--color-blue) !important;
    color: #ffffff !important;
    font-family: var(--font-body) !important;
    font-weight: 700 !important;
    border-radius: var(--radius-md) !important;
    padding: 0.75rem 1.5rem !important;
    border: none !important;
    transition: all 0.2s ease !important;
}

.wp-block-button__link:hover, 
button:hover, 
input[type="submit"]:hover, 
.kb-button:hover {
    background-color: var(--color-navy) !important;
    transform: translateY(-1px) !important;
    box-shadow: var(--shadow-md) !important;
}

/* Form Consistency */
input[type="text"], 
input[type="email"], 
input[type="tel"], 
input[type="search"], 
textarea, 
select {
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    padding: 0.75rem 1rem !important;
    font-family: var(--font-body) !important;
    color: var(--color-text-body) !important;
    background-color: #ffffff !important;
}

input:focus, textarea:focus {
    border-color: var(--color-blue) !important;
    box-shadow: 0 0 0 1px var(--color-blue) !important;
}

/* Global Typography Polish */
p {
    margin-bottom: var(--space-5);
    color: var(--color-text-body);
}

strong, b {
    color: var(--color-navy);
    font-weight: 700;
}

/* END OF DESIGN SYSTEM v3.0 */
