/**
 * Vykroyka B2B Ecosystem - Global Design System
 * Version: 2.1.0 (Premium Industrial + Archive Grid)
 */

:root {
    /* Colors */
    --ag-dark: #191A1C;
    --ag-gray-deep: #2F3034;
    --ag-gray-mid: #6B7280;
    --ag-gray-light: #F3F4F6;
    --ag-accent: #000000;
    --ag-glass: rgba(255, 255, 255, 0.7);
    --ag-glass-dark: rgba(25, 26, 28, 0.85);
    --ag-border: rgba(0, 0, 0, 0.08);
    --ag-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.1);
    
    /* Typography */
    --ag-font: 'Cormorant Garamond', Georgia, serif;
    
    /* Brand Colors */
    --ag-orange: var(--ag-brand-orange);
}

/* Global Reset & Body */
body {
    font-family: var(--ag-font);
    color: var(--ag-dark);
    background-color: #FAFAFA;
    -webkit-font-smoothing: antialiased;
    scroll-behavior: smooth;
    overscroll-behavior-y: none;
}

/* Premium Containers */
.ag-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Glassmorphism Cards */
.ag-premium-card {
    background: var(--ag-glass);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 20px;
    padding: 30px;
    box-shadow: var(--ag-shadow);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.ag-premium-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 20px 40px -15px rgba(0, 0, 0, 0.15);
    border-color: rgba(0, 0, 0, 0.1);
}

/* Typography Scale */
h1, h2, h3, h4 {
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.ag-gradient-text {
    background: linear-gradient(135deg, #000 0%, #444 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Premium Buttons */
.ag-btn-premium {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 28px;
    background: var(--ag-dark);
    color: #FFF !important;
    border-radius: 12px;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.3s ease;
    border: none;
    cursor: pointer;
    gap: 10px;
}

.ag-btn-premium:hover {
    background: #000;
    transform: scale(1.02);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

/* Forms */
.ag-input-group label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--ag-gray-deep);
}

.ag-input {
    width: 100%;
    padding: 14px;
    background: #FFF;
    border: 1px solid #E5E7EB;
    border-radius: 12px;
    font-family: inherit;
    transition: all 0.2s;
}

.ag-input:focus {
    outline: none;
    border-color: var(--ag-dark);
    box-shadow: 0 0 0 4px rgba(0,0,0,0.05);
}

/* Animations */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

.ag-animate-up {
    animation: fadeInUp 0.6s ease-out forwards;
}

/* Blog & Article Styles */
.post, .type-post {
    margin-bottom: 60px;
    animation: fadeInUp 0.8s ease-out;
}

.entry-title {
    font-size: 42px;
    margin-bottom: 20px;
    color: var(--ag-dark);
}

.entry-content {
    font-size: 18px;
    line-height: 1.8;
    color: var(--ag-gray-deep);
}

/* Master Classes (Video focus) */
.category-master-klassy .entry-content iframe {
    width: 100%;
    aspect-ratio: 16/9;
    border-radius: 24px;
    box-shadow: 0 30px 60px -12px rgba(0,0,0,0.25);
    margin: 30px 0;
}

/* Product (Patterns) Override */
.product {
    display: flex;
    gap: 40px;
    align-items: flex-start;
}

.woocommerce-product-gallery {
    flex: 0 0 450px;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: var(--ag-shadow);
}

.product_title {
    font-size: 36px;
    margin-bottom: 10px !important;
}

.price {
    font-size: 24px;
    color: var(--ag-dark);
    font-weight: 700;
}

/* Premium Grid Archive */
.ag-premium-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 30px;
    padding: 20px 0;
}

.ag-post-card {
    background: #FFF;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,0.05);
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    cursor: pointer;
    border: 1px solid var(--ag-border);
    animation: fadeInUp 0.6s ease-out;
}

.ag-post-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 60px -12px rgba(0,0,0,0.12);
}

.ag-card-media {
    position: relative;
    height: 240px;
    overflow: hidden;
}

.ag-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}

.ag-post-card:hover .ag-card-media img {
    transform: scale(1.05);
}

.ag-video-badge {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(8px);
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid rgba(255,255,255,0.3);
}

.ag-card-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.7), transparent);
    padding: 20px;
    color: #FFF;
    font-weight: 600;
    font-size: 14px;
    opacity: 0;
    transition: opacity 0.3s;
}

.ag-post-card:hover .ag-card-overlay {
    opacity: 1;
}

.ag-card-body {
    padding: 25px;
}

.ag-card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1.2px;
}

.ag-card-cat {
    color: #FFF;
    background: var(--ag-dark);
    padding: 4px 12px;
    border-radius: 4px;
}

.ag-card-title {
    font-size: 20px;
    line-height: 1.4;
    margin: 0 0 12px 0;
    color: var(--ag-dark);
    font-weight: 800;
}

.ag-card-excerpt {
    font-size: 14px;
    color: #6B7280;
    line-height: 1.6;
    margin: 0;
}

/* Filters */
.ag-btn-filter {
    background: #FFF;
    border: 1px solid var(--ag-border);
    padding: 10px 24px;
    border-radius: 100px;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s;
}

.ag-btn-filter.active, .ag-btn-filter:hover {
    background: var(--ag-dark);
    color: #FFF;
    border-color: var(--ag-dark);
    box-shadow: 0 4px 15px rgba(0,0,0,0.1);
}

/* Widgets Override */
.widget {
    background: #FFF;
    border: 1px solid var(--ag-border);
    border-radius: 16px;
    padding: 25px;
    margin-bottom: 30px;
}

.widget-title {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--ag-dark);
}

/* Mobile Responsiveness */
@media (max-width: 1024px) {
    .ag-premium-grid {
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    }
}

@media (max-width: 768px) {
    .ag-onboarding-container {
        grid-template-columns: 1fr !important;
        padding: 0 15px;
    }
    
    .entry-title {
        font-size: 32px;
    }
    
    .product {
        flex-direction: column !important;
    }
}

/* --- PREMIUM HEADER UNIFICATION --- */

/* Fixed (Sticky) Header Logic */
header, 
.elementor-location-header, 
.site-header, 
.ag-header-wrapper,
.ag-dynamic-header,
.ekit-template-content-header {
    position: sticky !important;
    top: 0;
    width: 100%;
    z-index: 10000;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    background: transparent !important; /* Made transparent to allow section backgrounds */
}

.elementor-element.ag-header-top,
.elementor-element-b53e2c7 {
    background-color: #2F3034 !important;
}
.elementor-element.ag-header-logo-wrap,
.elementor-element-605d42e {
    background-color: #191A1C !important;
}
.elementor-element.ag-header-nav,
.elementor-element-64cf1ef {
    background-color: #2F3034 !important;
}



/* Admin Bar Offset */
.admin-bar header,
.admin-bar .elementor-location-header,
.admin-bar .site-header,
.admin-bar .ag-header-wrapper,
.admin-bar .ag-dynamic-header,
.admin-bar .ekit-template-content-header {
    top: 32px !important;
}

@media screen and (max-width: 782px) {
    .admin-bar header,
    .admin-bar .elementor-location-header,
    .admin-bar .site-header,
    .admin-bar .ag-header-wrapper,
    .admin-bar .ag-dynamic-header,
    .admin-bar .ekit-template-content-header {
        top: 46px !important;
    }
}

/* Fix for Astra and Elementor containers that break sticky */
#page, .site, .ast-container, .elementor, .elementor-inner, .elementor-section-wrap {
    overflow: visible !important;
}

/* Ensure no shift on landing pages */
.ag-header-wrapper, .ag-catalog-archive-wrapper {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body.is-scrolled #masthead.ag-dynamic-header,
body.is-scrolled header,
body.is-scrolled .elementor-location-header,
body.is-scrolled .site-header,
body.is-scrolled .ag-header-wrapper,
body.is-scrolled .ag-dynamic-header,
body.is-scrolled .ekit-template-content-header {
    position: fixed !important; /* Force fixed on scroll to stick correctly regardless of parent overflow */
    top: var(--wp-admin--admin-bar--height, 0px) !important;
    left: 0 !important;
    right: 0 !important;
    background: rgba(26, 26, 26, 0.95) !important; /* Dark background to match header theme */
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.25);
    padding: 0 !important; /* Remove padding to eliminate bottom border/gap */
}

#page {
    transition: padding-top 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body.is-scrolled #page {
    padding-top: var(--ag-header-height, 71px) !important;
}

/* Shrink effect: Hide top bar on scroll smoothly */
.ag-header-top,
.ag-top-bar,
.ast-above-header {
    max-height: 100px;
    opacity: 1;
    overflow: hidden;
    transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1), padding 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body.is-scrolled .ag-header-top,
body.is-scrolled .ag-top-bar,
body.is-scrolled .ast-above-header {
    max-height: 0 !important;
    opacity: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    border: none !important;
}

/* Unify Catalog Header to look like Home Page */
.ag-catalog-archive-wrapper {
    background: transparent !important;
}

/* Ensure mobile toggle is visible on white background */
.ag-mobile-nav-toggle span {
    background: #191A1C !important;
}
body.is-scrolled .ag-mobile-nav-toggle span {
    background: #FFFFFF !important;
}

/* Orange Hover Effects for Navigation */
.ekit-menu-nav-link, 
.ekit-menu-main > li > a,
.elementor-nav-menu a,
.ekit-menu-nav-link > a {
    transition: color 0.3s ease !important;
}

.ekit-menu-nav-link:hover, 
.ekit-menu-main > li > a:hover,
.elementor-nav-menu a:hover,
.ekit-menu-nav-link.active,
.ekit-menu-nav-link:hover > a {
    color: var(--ag-orange) !important;
}

/* Social Icons Hover */
.elementskit-social-share-icon,
.ekit_social_media a,
.elementor-social-icon,
.ekit-team-social-list a {
    transition: all 0.3s ease !important;
}

.elementskit-social-share-icon:hover,
.ekit_social_media a:hover i,
.elementor-social-icon:hover,
.ekit-team-social-list a:hover {
    background-color: var(--ag-orange) !important;
    color: #FFF !important;
    transform: translateY(-2px);
}

/* Header Buttons Hover */
.ag-header-btn:hover,
.elementor-button:hover,
.ekit-menu-nav-link.ag-btn-premium:hover {
    background-color: var(--ag-orange) !important;
    border-color: var(--ag-orange) !important;
    color: #FFF !important;
}

/* Language Switcher Fixes */
.wpml-ls-item a,
.pll-parent-menu-item a,
.ekit-menu-nav-link.pll-parent-menu-item a {
    transition: color 0.3s ease;
}

.wpml-ls-item a:hover,
.pll-parent-menu-item a:hover,
.ekit-menu-nav-link.pll-parent-menu-item a:hover {
    color: var(--ag-orange) !important;
}

/* Sticky Header Refinement */
.elementor-sticky--effects {
    background: var(--ag-glass-dark) !important;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* Search Icon Hover */
.ekit-search-icon:hover,
.elementor-search-form__icon:hover,
.ekit-btn-search:hover {
    color: var(--ag-orange) !important;
}

/* Hamburger Menu Hover */
.elementskit-menu-hamburger:hover span {
    background-color: var(--ag-orange) !important;
}

/* --- END PREMIUM HEADER --- */
