/*
 * Responsive Typography and Layout Enhancements
 * Leadership Coach WordPress Theme
 */

/* ===================================
   RESPONSIVE TYPOGRAPHY SYSTEM
   =================================== */

/* Base responsive typography */
html {
    font-size: 16px;
}

/* Mobile First - Small devices (up to 576px) */
@media screen and (max-width: 576px) {
    :root {
        --font-size-xs: 0.7rem;
        --font-size-sm: 0.8rem;
        --font-size-base: 0.9rem;
        --font-size-lg: 1rem;
        --font-size-xl: 1.1rem;
        --font-size-2xl: 1.3rem;
        --font-size-3xl: 1.5rem;
        --font-size-4xl: 1.8rem;
        --font-size-5xl: 2rem;
        
        --spacing-xs: 0.2rem;
        --spacing-sm: 0.4rem;
        --spacing-md: 0.8rem;
        --spacing-lg: 1.2rem;
        --spacing-xl: 1.6rem;
        --spacing-2xl: 2.4rem;
        --spacing-3xl: 3.2rem;
    }
    
    body {
        font-size: var(--font-size-sm);
    }
    
    h1 {
        font-size: var(--font-size-4xl);
        line-height: 1.1;
    }
    
    h2 {
        font-size: var(--font-size-3xl);
        line-height: 1.2;
    }
    
    h3 {
        font-size: var(--font-size-2xl);
        line-height: 1.3;
    }
    
    .btn-readmore,
    .btn-readmore.btn-two {
        font-size: var(--font-size-xs);
        padding: var(--spacing-sm) var(--spacing-md);
    }
}

/* Small devices (576px to 768px) */
@media screen and (min-width: 577px) and (max-width: 768px) {
    :root {
        --font-size-xs: 0.75rem;
        --font-size-sm: 0.85rem;
        --font-size-base: 0.95rem;
        --font-size-lg: 1.05rem;
        --font-size-xl: 1.15rem;
        --font-size-2xl: 1.35rem;
        --font-size-3xl: 1.6rem;
        --font-size-4xl: 1.9rem;
        --font-size-5xl: 2.2rem;
    }
    
    body {
        font-size: var(--font-size-base);
    }
    
    h1 {
        font-size: var(--font-size-4xl);
    }
    
    h2 {
        font-size: var(--font-size-3xl);
    }
}

/* Medium devices (769px to 1024px) */
@media screen and (min-width: 769px) and (max-width: 1024px) {
    :root {
        --font-size-5xl: 2.5rem;
        --font-size-4xl: 2rem;
        --font-size-3xl: 1.7rem;
    }
    
    h1 {
        font-size: var(--font-size-5xl);
    }
    
    h2 {
        font-size: var(--font-size-4xl);
    }
    
    h3 {
        font-size: var(--font-size-3xl);
    }
}

/* Large devices (1025px to 1200px) */
@media screen and (min-width: 1025px) and (max-width: 1200px) {
    :root {
        --font-size-5xl: 2.8rem;
        --font-size-4xl: 2.2rem;
        --font-size-3xl: 1.8rem;
    }
}

/* Extra large devices (1201px and up) */
@media screen and (min-width: 1201px) {
    :root {
        --font-size-5xl: 3.2rem;
        --font-size-4xl: 2.5rem;
        --font-size-3xl: 2rem;
    }
}

/* ===================================
   RESPONSIVE LAYOUT ENHANCEMENTS
   =================================== */

/* Mobile navigation improvements */
@media screen and (max-width: 1024px) {
    .mobile-header {
        background-color: var(--light-background);
        border-bottom: 1px solid var(--secondary-lilac);
    }
    
    .mobile-header .header-block a,
    .mobile-header .header-block svg {
        color: var(--dark-text);
    }
    
    .mobile-header .toggle-btn .toggle-bar {
        background: var(--primary-purple);
    }
    
    .mobile-header .toggle-btn:hover .toggle-bar {
        background: var(--secondary-lilac);
    }
}

/* Header responsive improvements */
@media screen and (max-width: 768px) {
    .site-header.style-two .container {
        padding-left: 5%;
        padding-right: 5%;
    }
    
    .site-header.style-two .header-top .header-block {
        font-size: var(--font-size-xs);
    }
    
    .site-header.style-two .header-top .header-block + .header-block {
        margin-left: var(--spacing-md);
    }
}

/* Button responsive improvements */
@media screen and (max-width: 576px) {
    .btn-readmore,
    .btn-readmore.btn-two {
        display: block;
        width: 100%;
        text-align: center;
        margin-bottom: var(--spacing-md);
    }
}

/* Form responsive improvements */
@media screen and (max-width: 768px) {
    input[type="text"],
    input[type="email"],
    input[type="url"],
    input[type="password"],
    input[type="search"],
    input[type="number"],
    input[type="tel"],
    textarea,
    select {
        width: 100%;
        margin-bottom: var(--spacing-sm);
    }
}

/* ===================================
   RESPONSIVE SPACING SYSTEM
   =================================== */

/* Container spacing adjustments */
@media screen and (max-width: 576px) {
    .container {
        padding-left: var(--spacing-md);
        padding-right: var(--spacing-md);
    }
    
    .site-banner {
        padding: var(--spacing-lg) var(--spacing-md);
    }
}

@media screen and (min-width: 577px) and (max-width: 768px) {
    .container {
        padding-left: var(--spacing-lg);
        padding-right: var(--spacing-lg);
    }
    
    .site-banner {
        padding: var(--spacing-xl) var(--spacing-lg);
    }
}

@media screen and (min-width: 769px) {
    .site-banner {
        padding: var(--spacing-2xl) var(--spacing-xl);
    }
}

/* ===================================
   ACCESSIBILITY RESPONSIVE FEATURES
   =================================== */

/* Touch-friendly targets on mobile */
@media screen and (max-width: 768px) {
    a,
    button,
    input[type="button"],
    input[type="submit"],
    .btn-readmore {
        min-height: 44px;
        min-width: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
}

/* High DPI display optimizations */
@media screen and (-webkit-min-device-pixel-ratio: 2),
       screen and (min-resolution: 192dpi) {
    .btn-readmore,
    .btn-readmore.btn-two {
        border-width: 0.5px;
    }
}

/* Print styles */
@media print {
    :root {
        --primary-purple: #000000;
        --secondary-lilac: #666666;
        --dark-text: #000000;
        --light-background: #ffffff;
    }
    
    .site-header,
    .site-footer,
    .btn-readmore,
    .mobile-header {
        display: none !important;
    }
    
    body {
        font-size: 12pt;
        line-height: 1.4;
    }
    
    h1, h2, h3, h4, h5, h6 {
        page-break-after: avoid;
    }
}

/* Ensure hamburger/mobile header is hidden on large screens */
@media screen and (min-width: 1025px) {
    /* Parent theme outputs a .mobile-header container for the mobile menu */
    .mobile-header { 
        display: none !important; 
    }

    /* Also hide the header-top secondary off-canvas menu toggle on desktop */
    .site-header.style-two .header-top .secondary-menu {
        display: none !important;
    }
}
