/*
Theme Name: Accelsiors Modern FSE
Theme URI: https://accelsiors.com
Author: Accelsiors Dev Team (Ioannis Passalidis i.passalidis@accelsiors.com)
Author URI: https://accelsiors.com
Description: Custom FSE theme based on 2026 Rebranding Proposal. Focus on HexaHelix & Speed.
Version: 2.2.1
Requires at least: 6.4
Tested up to: 6.9
Requires PHP: 7.4
*/

/* =====================================================
   Global Styles & Typography
===================================================== */

*, *::before, *::after {
    box-sizing: border-box;
}

html, body {
    overflow-x: hidden;
}

body,
h1, h2, h3, h4, h5, h6,
p, a, li, button, input, textarea {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
}

:root {
    --accelsiors-header-height: 100px;
}

body {
    margin: 0;
}

/* Sticky Header (Fixed) */
.sticky-header {
    position: fixed !important;
    top: var(--wp-admin--admin-bar--height, 0px) !important;
    height: 100px;
    left: 0;
    right: 0;
    /*width: 100% !important;*/
    z-index: 9999;
    transition: transform 0.4s ease-in-out;
    backdrop-filter: blur(10px);
}

.sticky-header.header-hidden {
    transform: translateY(-100%);
}

.site-header {
    align-items: center;
    gap: 1.5rem;
}

.site-header .wp-block-site-logo,
.site-header .wp-block-navigation,
.site-header .wp-block-buttons,
.site-header p {
    margin: 0;
}

.site-header .wp-block-navigation-item__content {
    font-weight: 600;
    font-size: 1rem;
}

.site-header .wp-block-navigation__submenu-container,
.mega-menu-container .wp-block-navigation__submenu-container {
    position: fixed !important;
    top: var(--accelsiors-header-height, 80px) !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    padding: 2rem 5% !important;
    border-radius: 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
}

.wp-block-navigation__responsive-container:not(.is-menu-open) {
    z-index: 10 !important;
}

/* Force hide menu during Barba transitions */
html[data-barba-transitioning] .is-menu-open {
    display: none !important;
}

/* =====================================================
   Mega Menu Custom Layout (Native Navigation Block)
===================================================== */
/* Κληρονομεί το πλάτος του content και χρησιμοποιεί CSS Grid */
.wp-block-navigation-item.mega-menu {
    position: static;
}

.wp-block-navigation-item.mega-menu > .wp-block-navigation__submenu-container {
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    max-width: var(--wp--style--global--content-size, 1400px);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--wp--style--block-gap, 1.5rem);
    padding: 2rem;
    box-sizing: border-box;
}

@media (max-width: 991px) {
    .wp-block-navigation-item.mega-menu > .wp-block-navigation__submenu-container {
        position: static;
        width: 100%;
        max-width: 100%;
        grid-template-columns: 1fr;
        padding: 1rem 0;
    }
}

.search-overlay-container {
    position: fixed !important;
    inset: 0;
    width: 100vw;
    height: 100vh;
    z-index: 10050;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
    padding: clamp(1.5rem, 4vw, 4rem);
}

.search-overlay-container.search-active {
    opacity: 1;
    pointer-events: auto;
}

.search-overlay-inner {
    width: 100%;
    min-height: 100%;
    display: flex;
    flex-direction: column;
}

.search-overlay-form {
    margin-top: clamp(3rem, 12vh, 8rem);
    width: min(1100px, 100%);
    margin-left: auto;
    margin-right: auto;
}

.search-overlay-form .wp-block-search {
    width: 100%;
}

.search-overlay-form .wp-block-search__inside-wrapper {
    border: 0 !important;
    box-shadow: none !important;
    padding: 0;
}

.search-overlay-form .wp-block-search__input {
    font-size: clamp(2rem, 5vw, 3rem);
    line-height: 1.1;
    border: 0 !important;
    padding: 0.5rem 0;
}

.search-overlay-form .wp-block-search__button {
    font-size: 1rem;
}

body.search-overlay-open {
    overflow: hidden;
}

/* Zero Radius Enforcement */
.wp-block-button__link,
.wp-block-image img,
.wp-block-search__input,
input, textarea,
.card {
    border-radius: 0 !important;
}

/* Button Structure (Colors Controlled via Global Styles) */
.wp-block-button__link {
    transition: all 0.3s ease;
}

/* Secondary Button (Outline Structure Only) */
.is-style-outline .wp-block-button__link {
    border-width: 1px !important;
    border-style: solid !important;
}

/* Barba.js Page Transitions */
.barba-container {
    transition: transform 0.8s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.8s ease;
    width: 100%;
    opacity: 1;
    flex: 1;
}

.is-leaving {
    opacity: 0;
    transform: translateX(-80px);
}

.is-entering {
    opacity: 0;
    transform: translateX(80px);
}

.is-active {
    opacity: 1;
    transform: translateX(0);
}

/* Barba transition scrolling fix */
html[data-barba-transitioning="true"].has-modal-open,
body[data-barba-transitioning="true"].has-modal-open {
    overflow: auto !important;
}

/* Barba Wrapper Fixes */
[data-barba="wrapper"] {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
    margin: 0;
    position: relative;
    z-index: 1;
}

[data-barba="container"] {
    width: 100% !important;
    max-width: 100% !important;
    flex: 1;
    display: flex;
    flex-direction: column;
    position: relative;
    z-index: 1;
}

/* Main Content Spacer */
main, #primary {
    margin-top: clamp(80px, 10vh, 120px);
}

/* Alignments */
.alignfull {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    box-sizing: border-box;
}

.alignwide {
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
}

/* Full Width Cover Fix */
.wp-block-cover.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    border-radius: 0 !important;
}

/* Footer Base */
.site-footer {
    padding-top: 4rem;
    padding-bottom: 2rem;
}

.site-footer a {
    text-decoration: none;
}

.site-footer a:hover {
    opacity: 1;
}

.site-footer ul {
    list-style: none !important;
    padding-left: 0;
    margin-left: 0;
}

.site-footer li a {
    font-size: 0.95rem;
    transition: color 0.3s ease;
}

.site-footer li a:hover {
    text-decoration: underline;
}

.site-footer .wp-block-column {
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
}

/* =====================================================
   Desktop Styles (Hero, Cards, Hover)
===================================================== */

/* Hero Section */
.hero-cover.wp-block-cover {
    width: 100% !important;
    left: 0;
    background-image: none !important;
    background-color: var(--wp--preset--color--primary, #050A30) !important;
    padding: 140px 20px !important;
}

.hero-cover .wp-block-cover__inner-container {
    max-width: 1400px;
    margin: 0 auto;
}

/* Αυξημένο specificity αντί για !important για την αποφυγή conflict με το Barba.js */
body .wp-site-blocks .hero-cover h1.wp-block-heading,
body .wp-site-blocks .hero-cover h2.wp-block-heading,
body .wp-site-blocks .hero-cover h3.wp-block-heading,
body .wp-site-blocks .hero-cover p,
body .wp-site-blocks .hero-cover a {
    color: var(--wp--preset--color--white, #ffffff);
}

.hero-cover img.wp-block-cover__image-background[src=""] {
    display: none !important;
}

/* Fade In Animation for Hero Text */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.wp-block-cover__inner-container h1,
.wp-block-cover__inner-container p {
    animation: fadeInUp 0.8s ease-out forwards;
}

/* --- HERO BASE (Common) --- */
.hero-cover > .wp-block-cover__inner-container {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.hero-cinematic-wrapper {
    display: flex !important;
    align-items: center !important;
    width: 90% !important;
    max-width: 1600px !important;
    margin: 0 auto !important;
    gap: 5% !important;
}

/* --- OPTION A: CINEMATIC SPLIT (Default) --- */
/* Applies when 'Cinematic' is chosen OR no style is chosen */
.hero-cinematic-wrapper:not(.is-style-hero-centered) {
    flex-direction: row !important;
    justify-content: space-between !important;
    text-align: left !important;
}

.hero-cinematic-wrapper:not(.is-style-hero-centered) .hero-left-col {
    width: 55% !important;
    flex: 0 0 55% !important;
    text-align: left !important;
}

.hero-cinematic-wrapper:not(.is-style-hero-centered) .hero-right-col {
    width: 40% !important;
    flex: 0 0 40% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
}

/* --- OPTION B: CENTERED STACK --- */
/* Applies ONLY when 'Centered Stack' is chosen */
.hero-cinematic-wrapper.is-style-hero-centered {
    flex-direction: column !important;
    justify-content: center !important;
    text-align: center !important;
    padding-top: 4rem;
}

.hero-cinematic-wrapper.is-style-hero-centered .hero-left-col,
.hero-cinematic-wrapper.is-style-hero-centered .hero-right-col {
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 900px !important;
    align-items: center !important;
    display: flex !important;
    flex-direction: column !important;
}

.hero-cinematic-wrapper.is-style-hero-centered .hero-accent-line {
    margin: 0 auto 1.5rem auto !important;
}

.hero-cinematic-wrapper.is-style-hero-centered .hero-buttons {
    justify-content: center !important;
}

.hero-cinematic-wrapper.is-style-hero-centered .hero-title,
.hero-cinematic-wrapper.is-style-hero-centered .hero-subheadline,
.hero-cinematic-wrapper.is-style-hero-centered .hero-description {
    text-align: center !important;
}

/* --- TYPOGRAPHY --- */
.hero-title {
    font-size: clamp(3.5rem, 6vw, 7.5rem) !important;
    line-height: 0.95 !important;
    font-weight: 800 !important;
    color: var(--wp--preset--color--white, #ffffff);
    margin: 0 !important;
}

.hero-accent-line {
    width: 60px !important;
    height: 4px !important;
    background-color: var(--wp--preset--color--accent, #663399) !important;
    border: none !important;
    margin: 0 0 1.5rem 0 !important;
}

.hero-subheadline {
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    margin-bottom: 1rem !important;
    text-align: left !important;
}

.hero-buttons {
    justify-content: flex-start !important;
}

/* --- TYPOGRAPHY & MOBILE --- */
@media (max-width: 991px) {
    .hero-cinematic-wrapper,
    .hero-cinematic-wrapper:not(.is-style-hero-centered) {
        flex-direction: column !important;
        text-align: left !important;
        width: 100% !important;
        padding: 0 20px !important;
    }

    /* Νικάμε τον κανόνα του Desktop για να απλώσει σε όλο το πλάτος */
    .hero-cinematic-wrapper .hero-left-col,
    .hero-cinematic-wrapper .hero-right-col,
    .hero-cinematic-wrapper:not(.is-style-hero-centered) .hero-left-col,
    .hero-cinematic-wrapper:not(.is-style-hero-centered) .hero-right-col {
        width: 100% !important;
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
    
    /* Εξασφαλίζουμε ότι και το ίδιο το κείμενο έχει χώρο να απλώσει */
    .hero-cinematic-wrapper p,
    .hero-cinematic-wrapper h1 {
        max-width: 100% !important;
    }

    .hero-title {
        font-size: clamp(2rem, 8vw, 2.5rem) !important; /* Δυναμικό μέγεθος, πολύ μικρότερο */
        line-height: 1.1 !important;
        margin-bottom: 1rem !important;
    }

    .hero-subheadline {
        font-size: 1.1rem !important; /* Μικρότερη περιγραφή */
        margin-bottom: 1.5rem !important;
    }

    /* Μίκρυνση των κουμπιών στο κινητό */
    .hero-buttons .wp-block-button__link {
        padding: 0.6rem 1.2rem !important;
        font-size: 0.95rem !important;
        width: 100% !important; /* Απλώνονται όμορφα στο κινητό */
        text-align: center;
    }
}

/* Hover Effects */
.wp-block-button__link {
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* =========================================
   HEXAHELIX GRID SYSTEM (Group + CSS Grid)
========================================= */
.hexa-smart-wrapper h2,
.hexa-smart-wrapper > p {
    text-align: center !important;
    max-width: 900px;
    margin-left: auto !important;
    margin-right: auto !important;
}

.wp-block-group.hexa-grid-container {
    display: grid;
    width: 100%;
    max-width: 1400px !important; /* Βεβαιώνει ότι δεν θα ξεχειλώσει στο άπειρο */
    margin-left: auto !important; /* Κεντράρισμα αριστερά */
    margin-right: auto !important; /* Κεντράρισμα δεξιά */
    gap: var(--wp--style--block-gap, 0px); 
    
    align-items: stretch;
    margin-bottom: 3rem;
}

.hexa-grid-container > * {
    height: 100%;
    display: flex;
}

.wp-block-group.hexa-grid-container,
.wp-block-group.hexa-grid-container.is-style-hexa-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.wp-block-group.hexa-grid-container.is-style-hexa-grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

.hexa-card-cover {
    position: relative;
    overflow: hidden;
    border: 1px solid #e0e0e0;
    width: 100%;
    height: 100%;
    min-height: 500px;
    display: flex;
    isolation: isolate;
    margin: 0 !important;
}

.hexa-card-cover .wp-block-cover__background {
    display: none !important;
}

.hexa-card-cover .wp-block-cover__inner-container {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    height: 100%;
    padding: 0 !important;
    margin: 0 !important;
}

.hexa-card-cover .wp-block-cover__image-background {
    transition: transform 0.55s ease;
    transform-origin: center;
}

.hexa-card-content {
    position: absolute !important;
    inset: 0;
    z-index: 2;
    padding: 1.75rem !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.78) 10%, rgba(0, 0, 0, 0.38) 55%, rgba(0, 0, 0, 0.18) 100%);
}

.hexa-top-content {
    position: absolute;
    top: 1.75rem;
    left: 1.75rem;
    right: 1.75rem;
    transform: translateY(0);
    transition: transform 0.45s ease;
}

.hexa-bottom-reveal {
    position: absolute;
    left: 1.75rem;
    right: 1.75rem;
    bottom: 1.75rem;
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 0.45s ease, transform 0.45s ease;
    pointer-events: none;
}

.hexa-card-cover:hover .hexa-bottom-reveal,
.hexa-card-cover:focus-within .hexa-bottom-reveal {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.hexa-card-cover:hover .hexa-top-content,
.hexa-card-cover:focus-within .hexa-top-content {
    transform: translateY(-4px);
}

.hexa-card-cover:hover .wp-block-cover__image-background,
.hexa-card-cover:focus-within .wp-block-cover__image-background {
    transform: scale(1.08);
}

.hexa-eyebrow {
    font-size: 0.8rem !important;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--wp--preset--color--white, #ffffff) !important;
    margin: 0 0 0.5rem !important;
    font-weight: 700;
}

.hexa-title {
    font-size: clamp(1.7rem, 2.1vw, 2.25rem) !important;
    font-weight: 700 !important;
    line-height: 1.1 !important;
    color: var(--wp--preset--color--white, #ffffff) !important;
    margin: 0 !important;
}

.hexa-bottom-reveal p {
    color: rgba(255, 255, 255, 0.92) !important;
    font-size: 1rem;
    line-height: 1.5;
    margin: 0 0 1rem;
}

@media (min-width: 992px) {
    .hexa-card-content {
        padding: 1.1rem !important;
    }

    .hexa-top-content {
        top: 1.1rem;
        left: 1.1rem;
        right: 1.1rem;
        width: auto;
        max-width: none;
    }

    .hexa-bottom-reveal {
        left: 1.1rem;
        right: 1.1rem;
        bottom: 1.1rem;
        width: auto;
        max-width: none;
    }

    .hexa-title,
    .hexa-bottom-reveal p {
        width: 100%;
        max-width: none;
    }
}

.hexa-link a {
    color: var(--wp--preset--color--white, #ffffff) !important;
    text-decoration: none;
    font-weight: 600;
    font-size: 1.1rem;
    border-bottom: 1px solid transparent;
}

.hexa-link a::after {
    content: ' →';
    margin-left: 5px;
    transition: margin 0.3s;
}

.hexa-link a:hover::after,
.hexa-link a:focus-visible::after {
    margin-left: 10px;
}

@media (max-width: 1199px) {
    .wp-block-group.hexa-grid-container,
    .wp-block-group.hexa-grid-container.is-style-hexa-grid-3,
    .wp-block-group.hexa-grid-container.is-style-hexa-grid-4 {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 767px) {
    /* Μετατρέπουμε το Grid σε οριζόντιο Slider */
    .wp-block-group.hexa-grid-container,
    .wp-block-group.hexa-grid-container.is-style-hexa-grid-3,
    .wp-block-group.hexa-grid-container.is-style-hexa-grid-4 {
        display: flex !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scroll-snap-type: x mandatory !important; /* Μαγνητίζει την κάρτα στο κέντρο */
        padding-bottom: 1.5rem !important; /* Χώρος για την μπάρα */
        gap: 1rem !important;
        
        /* Στυλ διακριτικής μπάρας (Firefox) */
        scrollbar-width: thin;
        scrollbar-color: #663399 #e0e0e0; 
    }

    /* Στυλ διακριτικής μπάρας (Chrome, Safari, iOS) */
    .wp-block-group.hexa-grid-container::-webkit-scrollbar {
        height: 4px; /* Πολύ λεπτή και κομψή */
    }
    .wp-block-group.hexa-grid-container::-webkit-scrollbar-track {
        background: #e0e0e0; /* Γκρι ανοιχτό φόντο */
        border-radius: 10px;
    }
    .wp-block-group.hexa-grid-container::-webkit-scrollbar-thumb {
        background-color: #663399; /* Το μωβ χρώμα σου για την ένδειξη */
        border-radius: 10px;
    }

    /* Ρυθμίσεις για την κάθε κάρτα μέσα στο slider */
    .wp-block-group.hexa-grid-container > * {
        flex: 0 0 85% !important; /* Πιάνει το 85% της οθόνης για να φαίνεται η άκρη της επόμενης! */
        scroll-snap-align: center !important; /* Κεντράρει την κάρτα όταν αφήνεις το δάχτυλο */
    }

    /* Κενό στην πρώτη και την τελευταία κάρτα για να μην ακουμπάνε στα άκρα της οθόνης */
    .wp-block-group.hexa-grid-container > :first-child {
        margin-left: 1rem !important;
    }
    
    .wp-block-group.hexa-grid-container > :last-child {
        margin-right: 1rem !important;
    }
}

/* Service Cards */
.service-card {
    border: 1px solid #e0e0e0;
    padding: 2.5rem;
    transition: all 0.3s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background: #fff;
}

.service-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.08);
    border-color: #663399;
}

/* =====================================================
   Mobile Media Query (< 992px)
===================================================== */
@media (max-width: 991px) {
    .site-header {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-wrap: nowrap !important;
        gap: 0.75rem !important;
        padding: 0.625rem 1rem !important;
    }

    .site-header > .wp-block-site-logo {
        flex: 0 0 auto;
    }

    .site-header > .wp-block-navigation {
        margin-left: auto !important;
        flex: 0 0 auto;
    }

    .site-header > .wp-block-group {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        flex-wrap: nowrap !important;
        gap: 0.5rem !important;
        margin-left: 0 !important;
        flex: 0 0 auto;
    }

    .site-header > .wp-block-group > .wp-block-buttons:last-child {
        display: none !important;
    }

    .site-header .wp-block-navigation__responsive-container.is-menu-open {
        position: fixed !important;
        inset: 0 !important;
        width: 100vw !important;
        height: 100vh !important;
        min-height: 100vh !important;
        max-height: 100vh !important;
        margin: 0 !important;
        z-index: 100000 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        overflow-x: hidden !important;
        overflow-y: auto !important;
    }

    .site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-close {
        position: absolute !important;
        top: 1rem !important;
        right: 1rem !important;
        padding: 0.75rem !important;
        z-index: 2;
    }

    .site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
        width: 100%;
        min-height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 4rem 1.5rem 2rem;
    }

    .site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 1rem;
        text-align: center;
    }

    .site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item,
    .site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
        width: 100%;
        text-align: center;
        justify-content: center;
    }

    .site-header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container {
        position: static !important;
        inset: auto !important;
        transform: none !important;
        width: 100% !important;
        padding: 0.5rem 0 0 !important;
        margin: 0 !important;
        display: flex !important;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0.5rem;
        border: 0 !important;
        box-shadow: none !important;
    }

    /* Hero Section (Stacked Layout for all hero styles) */
    .hero-cover.wp-block-cover {
        padding: 80px 15px 40px 15px !important;
    }

    .hero-cover .wp-block-cover__inner-container {
        padding-left: 10px;
        padding-right: 10px;
    }

    /* Προσθήκη κενού (padding) δεξιά-αριστερά στις στήλες (όπως το About Home) στο κινητό */
    .wp-block-columns.alignwide {
        padding-left: 15px !important;
        padding-right: 15px !important;
    }
    
    /* Για να μην κολλάει η εικόνα κάτω από το κείμενο, δίνουμε ένα μικρό κενό ανάμεσα στις στήλες όταν στοιβάζονται */
    .wp-block-column {
        margin-bottom: 2rem; 
    }
    .wp-block-column:last-child {
        margin-bottom: 0;
    }

    /* Footer Stack */
    .site-footer .wp-block-columns {
        display: flex;
        flex-direction: column;
        gap: 1.5rem;
    }

    .site-footer .wp-block-column {
        width: 100% !important;
        flex-basis: 100% !important;
    }
}

/* =====================================================
   Contact Page
===================================================== */
.acc-contact-hero {
    background: linear-gradient(120deg, #041d4f 0%, #0e2b69 60%, #164283 100%);
    color: #fff;
    padding: 4rem 1.5rem;
}

.acc-contact-hero__inner {
    max-width: 980px;
}

.acc-contact-hero h1 {
    margin-bottom: 1rem;
    color: #fff;
}

.acc-contact-hero p {
    max-width: 860px;
    margin: 0;
    color: rgba(255, 255, 255, 0.95);
}

.acc-contact-main {
    background: #f5f7fb;
    padding: 3rem 1.5rem 4rem;
}

.acc-contact-layout {
    max-width: 1200px;
    margin: 0 auto;
    gap: 2rem;
}

.acc-contact-sidebar {
    background: #ffffff;
    padding: 1.75rem;
    border: 1px solid #e1e6ef;
}

.acc-contact-sidebar h3 {
    margin: 0 0 0.6rem;
    font-size: 1.45rem;
}

.acc-contact-sidebar p,
.acc-contact-sidebar li {
    margin-top: 0;
    color: #2f3e58;
}

.acc-contact-sidebar a {
    color: #0a5cb4;
    text-decoration: none;
}

.acc-contact-links {
    list-style: none;
    padding: 0;
    margin: 0 0 1.3rem;
}

.acc-contact-links li {
    margin-bottom: 0.4rem;
}

.acc-contact-form-col {
    background: #fff;
    border: 1px solid #e1e6ef;
    padding: 1.75rem;
}

.acc-contact-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.acc-contact-form label {
    display: block;
    color: #55627a;
    font-size: 0.92rem;
}

.acc-contact-form input,
.acc-contact-form select,
.acc-contact-form textarea {
    margin-top: 0.35rem;
    width: 100%;
    border: 1px solid #cdd6e5;
    background: #fff;
    padding: 0.72rem 0.85rem;
    box-sizing: border-box;
}

.acc-contact-consent {
    font-size: 0.92rem;
}

.acc-contact-form button {
    background: #67b3db;
    color: #fff;
    border: 0;
    padding: 0.8rem 1.6rem;
    border-radius: 999px;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 0.03em;
}

@media (max-width: 781px) {
    .acc-contact-form-grid {
        grid-template-columns: 1fr;
    }

    .acc-contact-sidebar,
    .acc-contact-form-col {
        padding: 1.2rem;
    }
}

/* =====================================================
   Custom Block Styles
===================================================== */

/* Stacked Media & Text Block */
.wp-block-media-text.is-style-stacked {
    grid-template-columns: 100% !important; /* Override core grid styles */
    gap: 1.5rem; /* Add space between image and text */
}

.wp-block-media-text.is-style-stacked .wp-block-media-text__media {
    grid-column: 1;
    grid-row: 1;
    width: 100%;
    margin-bottom: 0;
}

.wp-block-media-text.is-style-stacked .wp-block-media-text__content {
    grid-column: 1;
    grid-row: 2;
    padding: 0;
}

/* =====================================================
   Video Block Layout Shift Fix
===================================================== */
body .wp-block-video {
    width: 100%;
    max-width: var(--wp--style--global--content-size, 1400px);
    margin-left: auto;
    margin-right: auto;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

body .is-layout-constrained > .wp-block-video:not(.alignwide):not(.alignfull) {
    max-width: var(--wp--style--global--content-size, 1200px);
}

body .is-layout-constrained > .wp-block-video.alignwide {
    max-width: var(--wp--style--global--wide-size, 1400px);
}

body .wp-block-video.alignfull {
    max-width: 100vw;
}

body .wp-block-video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* =====================================================
   YouTube Embed Layout Fix
===================================================== */
body .wp-block-embed-youtube {
    width: 100%;
    max-width: var(--wp--style--global--content-size, 1400px);
    margin-left: auto;
    margin-right: auto;
}

body .is-layout-constrained > .wp-block-embed-youtube:not(.alignwide):not(.alignfull) {
    max-width: var(--wp--style--global--content-size, 1200px);
}

body .is-layout-constrained > .wp-block-embed-youtube.alignwide {
    max-width: var(--wp--style--global--wide-size, 1400px);
}

body .wp-block-embed-youtube.alignfull {
    max-width: 100vw;
}

body .wp-block-embed-youtube .wp-block-embed__wrapper {
    width: 100%;
}

body .wp-block-embed-youtube .wp-block-embed__wrapper iframe {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    display: block;
}
}
