/* 
 * Shared Responsive Styles
 * ARISE Landing Page
 * Contains responsive styles for header, footer, font controls, hero, and page container
 * Used across all pages
 */

/* ============================================
   PAGE CONTAINER & HERO RESPONSIVE STYLES
   ============================================ */

@media (max-width: 1919px) and (min-width: 1400px) {
    .page-container {
        padding-left: 80px;
        padding-right: 80px;
    }
    
    .page-hero .hero-cta-button {
        padding: 28px 120px;
        font-size: 1.75rem;
    }
}

@media (max-width: 1399px) and (min-width: 1200px) {
    .page-container {
        padding-left: 60px;
        padding-right: 60px;
    }
    
    .page-hero .hero-cta-button {
        padding: 22px 100px;
        font-size: 1.5rem;
    }
}

@media (max-width: 1199px) and (min-width: 992px) {
    .page-container {
        padding-left: 40px;
        padding-right: 40px;
    }
    
    .page-hero .hero-cta-button {
        padding: 18px 80px;
        font-size: 1.25rem;
    }
}

@media (max-width: 991px) {
    .page-container {
        padding-left: 20px;
        padding-right: 20px;
    }
    
    .page-hero .hero-cta-button {
        padding: 15px 60px;
        font-size: 1.125rem;
    }
}

@media (max-width: 767px) {
    .page-hero .hero-cta-button {
        padding: 12px 40px;
        font-size: 1rem;
    }
}

/* ============================================
   HEADER RESPONSIVE STYLES
   ============================================ */

@media (max-width: 1919px) and (min-width: 1400px) {
    .site-header {
        padding: 35px 80px;
    }
    .site-header .logo {
        height: 48px;
    }
    .site-header .nav-link {
        font-size: 1.0625rem;
        padding: 8px 18px !important;
    }
    
    body.mic-toolbox-fonts-simple .site-header {
        padding: 35px 40px;
    }
    body.mic-toolbox-fonts-simple .site-header .nav-link {
        font-size: 0.875rem;
        padding: 8px 10px !important;
    }
    body.mic-toolbox-fonts-simple .site-header .logo {
        height: 40px;
    }
    body.mic-toolbox-fonts-simple .site-header .navbar-brand {
        font-size: 1.125rem !important;
    }
    body.mic-toolbox-fonts-simple .site-header .dropdown-toggle {
        font-size: 0.875rem !important;
        padding: 8px 10px !important;
    }
    body.mic-toolbox-fonts-simple .font-controls {
        gap: 0px;
        margin-right: 12px !important;
    }
    body.mic-toolbox-fonts-simple .btn-font-size {
        width: 30px;
        height: 30px;
        padding-bottom: 5px !important;
    }
}

@media (max-width: 1399px) and (min-width: 1200px) {
    .site-header {
        padding: 30px 60px;
    }
    .site-header .logo {
        height: 44px;
    }
    .site-header .nav-link {
        font-size: 1.0rem;
        padding: 8px 16px !important;
    }
    
    body.mic-toolbox-fonts-simple .site-header {
        padding: 30px 30px;
    }
    body.mic-toolbox-fonts-simple .site-header .nav-link {
        font-size: 0.8125rem;
        padding: 6px 10px !important;
    }
    body.mic-toolbox-fonts-simple .site-header .logo {
        height: 36px;
    }
    body.mic-toolbox-fonts-simple .site-header .navbar-brand {
        font-size: 1.0625rem !important;
    }
    body.mic-toolbox-fonts-simple .site-header .dropdown-toggle {
        font-size: 0.8125rem !important;
        padding: 6px 10px !important;
    }
    body.mic-toolbox-fonts-simple .font-controls {
        gap: 0px;
        margin-right: 12px !important;
    }
    body.mic-toolbox-fonts-simple .btn-font-size {
        width: 28px;
        height: 28px;
        padding-bottom: 4px !important;
    }
}

@media (max-width: 1199px) and (min-width: 992px) {
    .site-header {
        padding: 25px 40px;
    }
    .site-header .logo {
        height: 40px;
    }
    .site-header .nav-link {
        font-size: 0.9375rem;
        padding: 8px 14px !important;
    }
    
    body.mic-toolbox-fonts-simple .site-header {
        padding: 25px 20px;
    }
    body.mic-toolbox-fonts-simple .site-header .nav-link {
        font-size: 0.75rem;
        padding: 6px 8px !important;
    }
    body.mic-toolbox-fonts-simple .site-header .logo {
        height: 32px;
    }
    body.mic-toolbox-fonts-simple .site-header .navbar-brand {
        font-size: 1.0rem !important;
    }
    body.mic-toolbox-fonts-simple .site-header .dropdown-toggle {
        font-size: 0.75rem !important;
        padding: 6px 8px !important;
    }
    body.mic-toolbox-fonts-simple .font-controls {
        gap: 0px;
        margin-right: 10px !important;
    }
    body.mic-toolbox-fonts-simple .btn-font-size {
        width: 26px;
        height: 26px;
        padding-bottom: 4px !important;
    }
    body.mic-toolbox-fonts-simple .font-size-label {
        font-size: 0.75rem;
    }
}

@media (max-width: 991px) {
    .site-header {
        padding: 20px 30px;
    }
    .site-header .logo {
        height: 36px;
    }
    .site-header .navbar-brand {
        font-size: 1.25rem !important;
    }
    .site-header .nav-link {
        font-size: 1.0rem;
        padding: 8px 16px !important;
    }
    .header-menus {
        width: 100%;
        justify-content: flex-start;
        padding-top: 20px;
    }
    
    .header-menus .navbar-nav {
        flex-direction: column;
        align-items: flex-start !important;
    }
    
    .header-controls {
        flex-direction: column;
        align-items: flex-start !important;
        margin-top: 15px;
        margin-left: 0;
        width: 100%;
    }
    .nav-item.dropdown {
        margin-top: 10px;
    }
    
    body.mic-toolbox-fonts-simple .site-header {
        padding: 20px 20px;
    }
    body.mic-toolbox-fonts-simple .site-header .logo {
        height: 32px;
    }
    body.mic-toolbox-fonts-simple .site-header .navbar-brand {
        font-size: 1.125rem !important;
    }
    body.mic-toolbox-fonts-simple .site-header .nav-link {
        font-size: 0.875rem;
        padding: 8px 12px !important;
    }
}

@media (max-width: 767px) {
    .site-header {
        padding: 15px 20px;
    }
    .site-header .logo {
        height: 32px;
    }
    .site-header .navbar-brand {
        font-size: 1.125rem !important;
    }
    .site-header .nav-link {
        font-size: 0.9375rem;
        padding: 8px 12px !important;
    }
    .site-header .dropdown-toggle {
        font-size: 0.9375rem !important;
        padding: 8px 12px !important;
    }
    
    body.mic-toolbox-fonts-simple .site-header {
        padding: 15px 15px;
    }
    body.mic-toolbox-fonts-simple .site-header .logo {
        height: 28px;
    }
    body.mic-toolbox-fonts-simple .site-header .navbar-brand {
        font-size: 1.0rem !important;
    }
    body.mic-toolbox-fonts-simple .site-header .nav-link {
        font-size: 0.8125rem;
        padding: 8px 10px !important;
    }
    body.mic-toolbox-fonts-simple .site-header .dropdown-toggle {
        font-size: 0.8125rem !important;
        padding: 8px 10px !important;
    }
}

/* ============================================
   FONT CONTROLS RESPONSIVE STYLES
   ============================================ */

@media (max-width: 991px) {
    .font-controls {
        margin-right: 10px !important;
    }
    .btn-font-size {
        width: 32px;
        height: 32px;
    }
    .btn-font-size.btn-decrease-font .font-size-label {
        font-size: 0.875rem;
    }
    .btn-font-size.btn-default-font .font-size-label {
        font-size: 1.125rem;
    }
    .btn-font-size.btn-increase-font .font-size-label {
        font-size: 1.375rem;
    }
}

@media (max-width: 767px) {
    .font-controls {
        margin-right: 8px !important;
    }
    .btn-font-size {
        width: 30px;
        height: 30px;
    }
    .btn-font-size.btn-decrease-font .font-size-label {
        font-size: 0.8125rem;
    }
    .btn-font-size.btn-default-font .font-size-label {
        font-size: 1.0rem;
    }
    .btn-font-size.btn-increase-font .font-size-label {
        font-size: 1.25rem;
    }
}

/* ============================================
   FOOTER RESPONSIVE STYLES
   ============================================ */

@media (max-width: 1919px) and (min-width: 1400px) {
    .footer-main {
        padding: 40px 0;
    }
    .footer-logo {
        height: 55px;
    }
    .footer-description {
        font-size: 1.125rem;
    }
    .social-link {
        width: 48px;
        height: 48px;
    }
    .social-icon {
        width: 28px;
        height: 28px;
    }
    .footer-links a {
        font-size: 1.125rem;
    }
    .footer-right {
        padding: 35px;
    }
    .eu-flag {
        height: 65px;
    }
    .eu-disclaimer {
        font-size: 1.125rem;
    }
}

@media (max-width: 1399px) and (min-width: 1200px) {
    .footer-main {
        padding: 60px 0;
    }
    .footer-logo {
        height: 50px;
    }
    .footer-description {
        font-size: 1.0625rem;
    }
    .social-link {
        width: 45px;
        height: 45px;
    }
    .social-icon {
        width: 26px;
        height: 26px;
    }
    .footer-links a {
        font-size: 1.0625rem;
    }
    .footer-right {
        padding: 30px;
    }
    .eu-flag {
        height: 60px;
    }
    .eu-disclaimer {
        font-size: 1.0625rem;
    }
}

@media (max-width: 1199px) and (min-width: 992px) {
    .footer-main {
        padding: 50px 0;
    }
    .footer-logo {
        height: 45px;
    }
    .footer-description {
        font-size: 1rem;
        margin-bottom: 25px;
    }
    .social-link {
        width: 42px;
        height: 42px;
    }
    .social-icon {
        width: 24px;
        height: 24px;
    }
    .footer-links {
        gap: 2px;
    }
    .footer-links a {
        font-size: 1rem;
        padding: 0 3px;
    }
    .footer-right {
        padding: 25px;
    }
    .eu-flag {
        height: 55px;
        margin-bottom: 15px;
    }
    .eu-disclaimer {
        font-size: 1rem;
    }
    .footer-bottom {
        padding: 22px 0;
    }
}

@media (max-width: 991px) {
    .footer-main {
        padding: 45px 0;
    }
    .footer-left {
        margin-bottom: 40px;
    }
    .footer-right {
        justify-content: flex-start;
    }
    .footer-logo {
        height: 40px;
    }
    .footer-description {
        font-size: 1.0625rem;
        margin-bottom: 20px;
    }
    .social-link {
        width: 45px;
        height: 45px;
    }
    .social-icon {
        width: 26px;
        height: 26px;
    }
    .footer-links {
        gap: 8px;
    }
    .footer-links a {
        font-size: 1.0625rem;
    }
    .footer-right {
        padding: 30px;
    }
    .eu-flag {
        height: 60px;
        margin-bottom: 18px;
    }
    .eu-disclaimer {
        font-size: 1.0625rem;
    }
    .footer-bottom {
        padding: 20px 0;
    }
    .footer-bottom .copyright {
        font-size: 0.8125rem;
    }
}

@media (max-width: 767px) {
    .footer-main {
        padding: 40px 0;
    }
    .footer-left {
        margin-bottom: 0;
    }
    .footer-logo {
        height: 35px;
        margin-bottom: 20px;
    }
    .footer-description {
        font-size: 0.9375rem;
        margin-bottom: 18px;
    }
    .social-links {
        gap: 12px;
        margin-bottom: 20px;
    }
    .social-link {
        width: 40px;
        height: 40px;
    }
    .social-icon {
        width: 22px;
        height: 22px;
    }
    .footer-links {
        display: none;
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    .footer-links .link-separator {
        display: none;
    }
    .footer-links a {
        font-size: 1.125rem;
    }
    .footer-right {
        padding: 25px;
    }
    .eu-flag {
        height: 50px;
        margin-bottom: 15px;
    }
    .eu-disclaimer {
        font-size: 0.9375rem;
    }
    .footer-bottom {
        padding: 18px 0;
    }
    .footer-bottom .copyright {
        font-size: 0.75rem;
    }
}

@media (max-width: 575px) {
    .footer-main {
        padding: 35px 0;
    }
    .footer-logo {
        height: 30px;
        margin-bottom: 18px;
        margin-left: auto;
        margin-right: auto;
    }
    .footer-description {
        font-size: 0.875rem;
        margin-bottom: 15px;
        text-align: center;
    }
    .social-links {
        gap: 10px;
        margin-bottom: 18px;
        justify-content: center;
    }
    .social-link {
        width: 36px;
        height: 36px;
    }
    .social-icon {
        width: 20px;
        height: 20px;
    }
    .footer-links {
        gap: 6px;
        align-items: center;
    }
    .footer-links a {
        font-size: 1rem;
    }
    .footer-right {
        padding: 20px;
    }
    .eu-flag {
        height: 45px;
        margin-bottom: 12px;
    }
    .eu-disclaimer {
        font-size: 0.875rem;
    }
    .footer-bottom {
        padding: 15px 0;
    }
    .footer-bottom .copyright {
        font-size: 0.6875rem;
    }
    .footer-links a:first-child {
        padding-left: 10px;
    }
}
