/*
 Theme Name:   Prokon-Theme
 Theme URI:    https://prokon.server.codeagentur.de
 Description:  Child-Theme für Storefront - Max Schmidt - PWF Solution
 Author:       Max Schmidt - PWF Solution
 Author URI:   https://prokon.server.codeagentur.de
 Template:     storefront
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  prokon-theme
*/

/* ==========================================================================
   PROKON DESIGN TOKENS
   ========================================================================== */

:root {
    /* Brand Colors */
    --prokon-orange:        #FF7F00;
    --prokon-orange-dark:   #E66D00;
    --prokon-orange-light:  #FFF3E5;
    --prokon-purple:        #7B2D8E;
    --prokon-purple-dark:   #5A1F68;
    
    /* Legacy green variables (now pointing to orange) */
    --prokon-green:         #FF7F00;
    --prokon-green-dark:    #E66D00;
    --prokon-green-light:   #FFF3E5;
    
    /* Logo Rotor Colors (sekundär) */
    --prokon-blue:          #0077B6;
    --prokon-red:           #E63E12;
    --prokon-yellow:        #FFB800;
    
    /* Logo Grau */
    --prokon-logo-gray:     #444f50;
    --prokon-logo-gray-dark:#353e3f;

    /* Neutrals */
    --prokon-white:         #FFFFFF;
    --prokon-gray-50:       #F5F5F5;
    --prokon-gray-100:      #E0E0E0;
    --prokon-gray-400:      #9E9E9E;
    --prokon-gray-600:      #666666;
    --prokon-gray-800:      #333333;
    --prokon-black:         #1A1A1A;
    
    /* Shadows */
    --shadow-card:          0 2px 8px rgba(0, 0, 0, 0.08);
    --shadow-hover:         0 4px 16px rgba(0, 0, 0, 0.12);
}

/* ==========================================================================
   TYPOGRAPHY
   ========================================================================== */

body,
.site-content,
.widget {
    font-family: 'Open Sans', sans-serif;
    font-size: 14px;
    line-height: 1.6;
    color: var(--prokon-gray-600);
}

h1, h2, h3, h4, h5, h6,
.site-title,
.woocommerce-loop-product__title,
.entry-title {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-size: 24px;
    line-height: 26px;
    color: var(--prokon-gray-800);
    margin: 0 0 26px 0;
}

h2 { font-size: 20px; }
h3 { font-size: 18px; }
h4, h5, h6 { font-size: 16px; }

/* ==========================================================================
   GLOBAL ELEMENTS
   ========================================================================== */

/* Links – wie Original: gleiche Farbe wie Text */
a {
    color: var(--prokon-gray-600);
    text-decoration: none;
    transition: color 0.3s ease-in-out;
}

a:hover,
a:focus {
    color: var(--prokon-green);
    text-decoration: underline;
}

/* Buttons */
button,
input[type="submit"],
.button,
.wp-block-button__link,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.added_to_cart {
    background-color: var(--prokon-logo-gray) !important;
    color: var(--prokon-white) !important;
    border: none !important;
    border-radius: 4px !important;
    font-weight: 600;
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
}

button:hover,
input[type="submit"]:hover,
.button:hover,
.wp-block-button__link:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.added_to_cart:hover {
    background-color: var(--prokon-logo-gray-dark) !important;
    color: var(--prokon-white) !important;
}

/* Alt-Buttons (outlined) */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.checkout-button {
    background-color: var(--prokon-logo-gray) !important;
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
    background-color: var(--prokon-logo-gray-dark) !important;
}

/* ==========================================================================
   HEADER – exakte Nachbildung prokon-shop.de
   ========================================================================== */

/* Wrapper */
.prokon-wrp {
    max-width: 1580px;
    margin: 0 auto;
    padding: 0 20px;
    box-sizing: border-box;
}

@media (max-width: 1920px) {
    .prokon-wrp { max-width: 1400px; }
}

@media (max-width: 1440px) {
    .prokon-wrp { max-width: 96%; }
}

/* Reset Storefront header styles */

/* CRITICAL: Override Storefront overflow-x:hidden on body and .site – needed for position:sticky */
body,
.site {
    overflow-x: clip !important; /* clip prevents horizontal scroll like hidden but does NOT break sticky */
}

.prokon-header {
    background-color: transparent;
    border-bottom: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
    position: relative;
}

/* 1) Color Bar – ausgeblendet wie im Original */
.prokon-color-bar {
    display: none;
}

/* 2) Top Header – 36px, weiß wie im Original */
.prokon-top-header {
    height: 36px;
    background: #ffffff;
    font-size: 12px;
    line-height: 36px;
    color: var(--prokon-gray-600);
}

.prokon-top-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 36px;
}

.prokon-top-left {
    flex: 1;
}

.prokon-top-right {
    display: flex;
    align-items: center;
    gap: 0;
}

.prokon-top-right > * {
    margin-left: -3px;
    padding: 0 10px;
    border-left: 1px dashed #bfbfbf;
}

.prokon-top-right > *:first-child {
    border-left: none;
}

.prokon-top-link,
.prokon-dropdown-toggle {
    color: var(--prokon-gray-600);
    text-decoration: none;
    font-size: 12px;
    line-height: 20px;
    display: inline-block;
    cursor: pointer;
    transition: color 0.3s ease-in-out;
}

.prokon-top-link:hover,
.prokon-dropdown-toggle:hover {
    color: var(--prokon-green);
    text-decoration: none;
}

.prokon-caret {
    font-size: 9px;
    margin-left: 3px;
}

/* Top-Header Dropdowns */
.prokon-dropdown {
    position: relative;
}

.prokon-dropdown-menu {
    display: none;
    position: absolute;
    top: 36px;
    right: 0;
    background: #fff;
    border: 1px solid #dadada;
    min-width: 180px;
    z-index: 1000;
    list-style: none;
    margin: 0;
    padding: 0;
    box-shadow: 0 3px 8px rgba(0,0,0,0.1);
}

.prokon-dropdown.is-open .prokon-dropdown-menu {
    display: block;
}

.prokon-dropdown-menu li a {
    display: block;
    padding: 8px 15px;
    color: var(--prokon-gray-600);
    font-size: 12px;
    line-height: 1.5;
    text-decoration: none;
    transition: background 0.15s;
}

.prokon-dropdown-menu li a:hover {
    background: #f2f2f2;
    color: var(--prokon-green);
    text-decoration: none;
}

/* 3) Main Header */
.prokon-main-header {
    background-image: url('assets/images/vignette-desktop-fmm-IV.png');
    background-color: transparent;
    background-position-x: center;
    background-repeat: no-repeat;
    min-height: 220px;
    margin-bottom: -125px;
    position: relative;
    z-index: 2;
}

.prokon-header-inner {
    display: flex;
    align-items: center;
    height: 110px;
    position: relative;
    /*background-color: #fff; */
}

/* Logo – kleiner wie im Original */
.prokon-header-logo {
    flex: 0 0 250px;
    display: flex;
    align-items: center;
}

.prokon-header-logo a {
    display: block;
    line-height: 0;
}

.prokon-logo {
    width: auto;
    max-width: 250px;
    max-height: 70px;
    height: auto;
}

/* Search – like original: button inside input */
.prokon-header-search {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 40px;
}

.prokon-header-search form {
    position: relative;
    width: 100%;
    max-width: 600px;
    height: 50px;
    margin-bottom: 0em!important;
}

.prokon-header-search .search-field,
.prokon-header-search input[type="search"] {
    width: 100%;
    height: 50px;
    border: none;
    border-radius: 25px;
    padding: 0 100px 0 20px;
    font-size: 14px;
    font-family: 'Open Sans', sans-serif;
    color: var(--prokon-gray-600);
    background: #f2f2f2;
    outline: none;
    box-shadow: none;
    -webkit-appearance: none;
    margin: 0;
    box-sizing: border-box;
}

.prokon-header-search .search-field:focus,
.prokon-header-search input[type="search"]:focus {
    border-color: #b0b0b0;
    outline: none;
}

.prokon-header-search button,
.prokon-header-search input[type="submit"] {
    position: absolute;
    right: 0;
    top: 0;
    height: 50px;
    width: auto;
    min-width: 80px;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 25px 25px 0 !important;
    color: var(--prokon-gray-600) !important;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 600;
    font-family: 'Open Sans', sans-serif;
    padding: 0 20px !important;
    margin: 0;
    box-shadow: none !important;
    transition: all 0.3s ease-in-out;
}

.prokon-header-search button:hover,
.prokon-header-search input[type="submit"]:hover {
    background: #e5e5e5 !important;
}

/* Cart */
.prokon-header-cart {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
}

/* Home-Button – runder Kreis wie Hamburger */
.prokon-home-link {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f2f2f2;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    padding: 0;
    margin-right: 12px;
    width: 50px;
    height: 50px;
    color: var(--prokon-gray-600);
    text-decoration: none;
    transition: background 0.3s ease;
}

.prokon-home-link:hover {
    background: #e0e0e0;
    color: var(--prokon-gray-600);
    text-decoration: none;
}

.prokon-home-link svg {
    width: 22px;
    height: 22px;
}

/* Cart – runder Kreis */
.prokon-cart-link {
    display: block;
    position: relative;
    height: 50px;
    width: 50px;
    border: none;
    border-radius: 50%;
    color: var(--prokon-gray-600);
    text-decoration: none;
    font-size: 14px;
    background: var(--prokon-purple);
    transition: all 0.3s ease-in-out;
}

.prokon-cart-link:hover {
    color: var(--prokon-gray-600);
    text-decoration: none;
}

.prokon-cart-text {
    display: none;
}

.prokon-cart-icon {
    position: absolute;
    width: 100%;
    height: 100%;
    right: 0;
    top: 0;
    background: transparent;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    transition: all 0.3s ease-in-out;
}

.prokon-cart-icon:hover {
    background: rgba(255,255,255,0.15);
}

.prokon-cart-icon svg {
    width: 20px;
    height: 20px;
}

.prokon-cart-count {
    display: block;
    position: absolute;
    border-radius: 50%;
    background: #b2b2b2;
    color: #fff;
    font-size: 12px;
    text-align: center;
    line-height: 20px;
    width: 20px;
    height: 20px;
    right: -8px;
    top: -18px;
}

/* Hamburger Menu Toggle – immer sichtbar */
.prokon-menu-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f2f2f2 !important;
    border: none !important;
    border-radius: 50%!important;
    cursor: pointer;
    padding: 0 !important;
    margin-left: 12px;
    width: 50px;
    height: 50px;
    box-shadow: none !important;
    transition: background 0.3s ease;
}

.prokon-menu-toggle:hover {
    background: #e0e0e0 !important;
}

.prokon-hamburger {
    display: block;
    width: 24px;
    height: 2px;
    background: var(--prokon-gray-600);
    position: relative;
    transition: background 0.2s;
}

.prokon-hamburger::before,
.prokon-hamburger::after {
    content: '';
    display: block;
    width: 24px;
    height: 2px;
    background: var(--prokon-gray-600);
    position: absolute;
    left: 0;
    transition: transform 0.2s;
}

.prokon-hamburger::before { top: -7px; }
.prokon-hamburger::after { top: 7px; }

/* Offcanvas Mobile Menu */
.prokon-offcanvas {
    position: fixed;
    top: 0;
    right: -320px;
    width: 320px;
    height: 100%;
    background: #fff;
    z-index: 10000;
    overflow-y: auto;
    transition: right 0.3s ease;
    box-shadow: -3px 0 10px rgba(0,0,0,0.2);
}

.prokon-offcanvas.is-open {
    right: 0;
}

.prokon-offcanvas-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.4);
    z-index: 9999;
}

body.prokon-offcanvas-open .prokon-offcanvas-overlay {
    display: block;
}

.prokon-offcanvas-inner {
    padding: 20px;
}

.prokon-offcanvas-close {
    position: absolute;
    top: 10px;
    right: 15px;
    font-size: 28px;
    background: none !important;
    border: none !important;
    color: var(--prokon-gray-600) !important;
    cursor: pointer;
    padding: 5px !important;
    box-shadow: none !important;
    line-height: 1;
}

.prokon-offcanvas-list {
    list-style: none;
    margin: 40px 0 0;
    padding: 0;
}

.prokon-offcanvas-list li {
    border-bottom: none;
}

.prokon-offcanvas-list li a {
    display: block;
    padding: 12px 0;
    color: var(--prokon-gray-600);
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
}

.prokon-offcanvas-list li a:hover {
    color: var(--prokon-green);
}

.prokon-offcanvas-list .sub-menu {
    list-style: none;
    padding: 0 0 0 20px;
    margin: 0;
}

.prokon-offcanvas-list .sub-menu li a {
    font-weight: 400;
    font-size: 14px;
}

.prokon-offcanvas-meta {
    margin-top: 30px;
    padding-top: 20px;
    border-top: none;
}

.prokon-offcanvas-meta a {
    display: block;
    padding: 8px 0;
    color: var(--prokon-gray-600);
    font-size: 14px;
    text-decoration: none;
}

.prokon-offcanvas-meta a:hover {
    color: var(--prokon-green);
}

/* Hide Storefront's default elements that conflict with our custom header */
.site-header-cart,
.storefront-handheld-footer-bar,
.storefront-primary-navigation,
.secondary-navigation {
    display: none !important;
}

/* Hide page title on front page */
.home .entry-header,
.page-template-default.home .entry-title {
    display: none !important;
}

/* Override Storefront inline CSS for our custom header */
.prokon-header.site-header {
    background-color: transparent !important;
    border-bottom: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin-bottom: 0 !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
}

/* Content-Bereich: kein eigener Hintergrund, damit Swoosh sichtbar bleibt */
#content.site-content {
    position: relative;
    z-index: 1;
}

/* Abstand zwischen Header und Content auf allen Seiten außer Startseite */
body:not(.home) .site-content {
    margin-top: 85px;
}

/* Storefront setzt margin-bottom auf dem Header über Klassen – überschreiben */
.home.blog .site-header,
.home.page .site-header,
.home.post-type-archive-product .site-header,
.no-wc-breadcrumb .site-header {
    margin-bottom: 0 !important;
}

/* Breadcrumbs ggf. hinter Swoosh */
.storefront-breadcrumb {
    position: relative;
    z-index: 1;
}

/* Storefront skip-links: keep accessible but don't break layout */
.storefront-skip-link {
    position: absolute;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

.site-footer {
    background-color: #444f50 !important;
    color: #fff;
    padding: 10px 0 !important;
}

.site-footer a {
    color: rgba(255, 255, 255, 0.85);
}

.site-footer a:hover {
    color: var(--prokon-white);
    text-decoration: underline;
}

.site-footer .widget-title,
.site-footer h1,
.site-footer h2,
.site-footer h3 {
    color: var(--prokon-white);
}

.footer-widgets {
    background-color: #444f50;
    padding: 0 !important;
}

.site-info {
    background-color: transparent;
    color: rgba(255, 255, 255, 0.8);
    padding: 8px 0;
    text-align: center;
    font-size: 13px;
    line-height: 1.4;
}

.site-info a {
    color: rgba(255, 255, 255, 0.85);
}

/* ==========================================================================
   HOMEPAGE
   ========================================================================== */

/* Hero Cover Block */
.wp-block-cover.alignfull {
    margin-top: 0;
}

/* Category Cards */
.wp-block-columns .wp-block-column {
    text-align: center;
}

.wp-block-columns .wp-block-image img {
    border-radius: 8px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.wp-block-columns .wp-block-image img:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-hover);
}

/* ==========================================================================
   WOOCOMMERCE - PRODUCT CARDS
   ========================================================================== */

ul.products li.product {
    text-align: center;
    transition: box-shadow 0.3s ease;
    border-radius: 8px;
    padding-bottom: 15px;
}

ul.products li.product:hover {
    box-shadow: var(--shadow-hover);
}

ul.products li.product .woocommerce-loop-product__title {
    font-size: 16px;
    color: var(--prokon-gray-800);
}

ul.products li.product .price {
    color: var(--prokon-green);
    font-weight: 700;
}

.woocommerce-product-gallery {
    margin-bottom: 2em;
}

/* Sale Badge */
.woocommerce span.onsale {
    background-color: var(--prokon-green);
    color: var(--prokon-white);
    border-radius: 4px;
    padding: 4px 10px;
    font-weight: 600;
}

/* Star Rating */
.star-rating span::before,
.star-rating::before {
    color: var(--prokon-yellow);
}

/* ==========================================================================
   WOOCOMMERCE - CHECKOUT / CART
   ========================================================================== */

.woocommerce-cart .cart-collaterals .cart_totals {
    background-color: var(--prokon-gray-50);
    border-radius: 8px;
    padding: 20px;
}

/* ==========================================================================
   BREADCRUMBS
   ========================================================================== */

.woocommerce-breadcrumb,
.storefront-breadcrumb {
    background-color: transparent;
    padding: 12px 0;
    font-size: 14px;
    color: var(--prokon-gray-600);
}

.woocommerce-breadcrumb a {
    color: var(--prokon-green);
}

/* ==========================================================================
   STOREFRONT OVERRIDES
   ========================================================================== */

/* Remove sidebar on homepage */
.page-template-default .content-area,
.page-template-template-fullwidth .content-area {
    width: 100%;
}

/* Storefront handheld bar */
.storefront-handheld-footer-bar ul li > a,
.storefront-handheld-footer-bar ul li.cart .count {
    background-color: var(--prokon-green);
    color: var(--prokon-white);
}

/* Focus/Accent Override */
.storefront-primary-navigation {
    background-color: transparent;
}

/* WooCommerce Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
    border-bottom-color: var(--prokon-green);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: var(--prokon-green);
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

/* Tablet/Medium */
@media (max-width: 1024px) {
    .prokon-header-search {
        display: none;
    }

    .prokon-header-inner {
        height: 84px;
        justify-content: space-between;
    }

    .prokon-header-logo {
        flex: 1 1 auto;
        text-align: center;
        order: 1;
    }

    .prokon-header-home {
        flex: 0 0 auto;
        order: 2;
    }

    .prokon-header-cart {
        flex: 0 0 auto;
        order: 3;
    }

    .prokon-menu-toggle {
        order: 4;
    }

    .prokon-logo {
        max-width: 180px;
        max-height: 55px;
        margin: 0 auto;
    }

    .prokon-cart-link {
        width: 50px;
        height: 50px;
    }

    .prokon-cart-text {
        display: none;
    }

    .prokon-cart-icon {
        width: 42px;
        height: 42px;
        right: 3px;
        top: 3px;
    }

    .prokon-header-swoosh {
        bottom: -120px;
        height: 120px;
    }

    .prokon-header.site-header {
        margin-bottom: 0 !important;
    }
}

/* Small Tablet */
@media (max-width: 768px) {
    .prokon-top-header {
        display: none;
    }

    .prokon-header-inner {
        height: 72px;
    }

    .prokon-logo {
        max-width: 140px;
        max-height: 50px;
    }

    .wp-block-columns {
        flex-direction: column;
    }
    
    .wp-block-column {
        margin-bottom: 30px;
    }

    .prokon-header-swoosh {
        bottom: -100px;
        height: 100px;
    }

    .prokon-header.site-header {
        margin-bottom: 0 !important;
    }
}

/* Mobile */
@media (max-width: 480px) {
    .prokon-header-inner {
        height: 62px;
    }

    .prokon-logo {
        max-width: 110px;
        max-height: 42px;
    }

    .prokon-cart-link {
        width: 44px;
        height: 44px;
        border: none;
    }

    .prokon-cart-icon {
        width: 36px;
        height: 36px;
        right: 3px;
        top: 3px;
    }

    .prokon-home-link {
        width: 44px;
        height: 44px;
        margin-right: 8px;
    }

    .prokon-home-link svg {
        width: 18px;
        height: 18px;
    }

    .prokon-menu-toggle {
        width: 44px;
        height: 44px;
        margin-left: 8px;
    }

    .prokon-header-swoosh {
        bottom: -80px;
        height: 80px;
    }

    .prokon-header.site-header {
        margin-bottom: 0 !important;
    }
}



