/* ============================================================
   GPP HEADER — Full redesign matching GPP design system
============================================================ */

.gpp-header {
    background: #0D1B2A !important;
    width: 100% !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 9999 !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.3) !important;
}

.gpp-header-inner {
    max-width: 1200px !important;
    margin: 0 auto !important;
    height: 64px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 0 2rem !important;
    gap: 2rem !important;
}

/* LOGO */
.gpp-logo a {
    display: flex !important;
    align-items: center !important;
    text-decoration: none !important;
    gap: 10px !important;
}

.gpp-logo img {
    height: 36px !important;
    width: auto !important;
}

/* If you want text logo instead of image, add this and hide img */
.gpp-logo-text {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 1.4rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: .03em;
}

.gpp-logo-text span { color: #F4801A; }

.gpp-logo-badge {
    background: #F4801A;
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 3px;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-family: 'Barlow', sans-serif;
}

/* NAV LINKS */
.gpp-main-nav ul {
    display: flex !important;
    gap: 1.75rem !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    align-items: center !important;
}

.gpp-main-nav ul li a {
    color: rgba(255,255,255,0.75) !important;
    text-decoration: none !important;
    font-family: 'Barlow', sans-serif !important;
    font-size: .875rem !important;
    font-weight: 500 !important;
    letter-spacing: .03em !important;
    transition: color .2s !important;
    white-space: nowrap !important;
}

.gpp-main-nav ul li a:hover {
    color: #F4801A !important;
}

/* Active page highlight */
.gpp-main-nav ul li.current-menu-item a,
.gpp-main-nav ul li a.active {
    color: #F4801A !important;
}

/* ICONS */
.gpp-icons {
    display: flex !important;
    align-items: center !important;
    gap: .75rem !important;
}

/* Search icon — style as button */
.gpp-icons a.gpp-icon:first-child {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    background: rgba(255,255,255,0.08) !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    font-size: 16px !important;
    transition: background .2s !important;
}

.gpp-icons a.gpp-icon:first-child:hover {
    background: rgba(255,255,255,0.15) !important;
}

/* Cart icon */
.cart-contents {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: rgba(255,255,255,0.08) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    color: #fff !important;
    padding: 6px 12px !important;
    border-radius: 5px !important;
    font-family: 'Barlow', sans-serif !important;
    font-size: .82rem !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: background .2s !important;
}

.cart-contents:hover {
    background: rgba(255,255,255,0.15) !important;
    color: #fff !important;
}

.cart-count {
    background: #F4801A !important;
    color: #fff !important;
    font-size: .65rem !important;
    font-weight: 800 !important;
    width: 18px !important;
    height: 18px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-family: 'Barlow', sans-serif !important;
    line-height: 1 !important;
}

/* HAMBURGER */
.gpp-hamburger {
    display: none !important;
    flex-direction: column !important;
    gap: 5px !important;
    background: rgba(255,255,255,0.08) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    border-radius: 5px !important;
    padding: 8px !important;
    cursor: pointer !important;
    width: 38px !important;
    height: 38px !important;
    align-items: center !important;
    justify-content: center !important;
}

.gpp-hamburger span {
    width: 18px !important;
    height: 2px !important;
    background: #fff !important;
    display: block !important;
    border-radius: 2px !important;
}

/* MOBILE DRAWER */
.gpp-mobile-drawer {
    position: fixed !important;
    top: 0 !important;
    right: -280px !important;
    width: 280px !important;
    height: 100vh !important;
    background: #0D1B2A !important;
    box-shadow: -4px 0 20px rgba(0,0,0,0.4) !important;
    padding: 1.5rem !important;
    transition: right .3s ease !important;
    z-index: 99999 !important;
    border-left: 1px solid rgba(255,255,255,0.08) !important;
}

.gpp-mobile-drawer.open { right: 0 !important; }

.gpp-close-drawer {
    background: none !important;
    border: none !important;
    color: rgba(255,255,255,0.6) !important;
    font-size: 1.8rem !important;
    cursor: pointer !important;
    margin-bottom: 1.5rem !important;
    display: block !important;
    padding: 0 !important;
    line-height: 1 !important;
    transition: color .15s !important;
}

.gpp-close-drawer:hover { color: #fff !important; }

.gpp-mobile-drawer ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.gpp-mobile-drawer ul li {
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}

.gpp-mobile-drawer ul li a {
    display: block !important;
    padding: 1rem 0 !important;
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
    color: rgba(255,255,255,0.75) !important;
    text-decoration: none !important;
    transition: color .15s !important;
}

.gpp-mobile-drawer ul li a:hover { color: #F4801A !important; }

/* RESPONSIVE */
@media (max-width: 900px) {
    .gpp-main-nav { display: none !important; }
    .gpp-hamburger { display: flex !important; }
    .gpp-header-inner { padding: 0 1rem !important; }
}

@media (max-width: 480px) {
    .gpp-logo img { height: 30px !important; }
}

/* Remove Astra header wrapper gap */
#ast-desktop-header > div > div > div.site-primary-header-wrap.ast-builder-grid-row-container.site-header-focus-item.ast-container {
    display: none !important;
}

/* Fix category strip pill sizing */
.gpp-shop-cat-strip {
    overflow-x: auto !important;
    white-space: nowrap !important;
}

.gpp-shop-cat-inner {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: .4rem !important;
}

.gpp-cat-pill {
    font-size: .75rem !important;
    padding: 5px 12px !important;
    flex-shrink: 0 !important;
    white-space: nowrap !important;
}

/* Category strip full width scroll fix */
.gpp-shop-cat-strip {
    width: 100vw !important;
    max-width: 100vw !important;
    overflow-x: scroll !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
}

.gpp-shop-cat-strip::-webkit-scrollbar {
    display: none !important;
}

.gpp-shop-cat-inner {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: .4rem !important;
    width: max-content !important;
    padding: .85rem 2rem !important;
}

.gpp-cat-pill {
    flex-shrink: 0 !important;
    white-space: nowrap !important;
    font-size: .78rem !important;
    padding: 5px 12px !important;
}

/* ============================================================
   CART & CHECKOUT — GPP STYLING
============================================================ */

/* Full width fix for cart and checkout */
.woocommerce-cart .entry-content,
.woocommerce-cart .site-content,
.woocommerce-cart .content-area,
.woocommerce-cart #content,
.woocommerce-cart .ast-container,
.woocommerce-checkout .entry-content,
.woocommerce-checkout .site-content,
.woocommerce-checkout .content-area,
.woocommerce-checkout #content,
.woocommerce-checkout .ast-container {
    max-width: 900px !important;
    margin: 0 auto !important;
    padding: 2rem !important;
}

/* Page title */
.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 2.5rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    color: #0D1B2A !important;
    margin-bottom: 1.5rem !important;
}

/* Cart table */
.woocommerce-cart table.shop_table {
    border: 1.5px solid #E8EDF2 !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    font-family: 'Barlow', sans-serif !important;
}

.woocommerce-cart table.shop_table th {
    background: #F4F6F9 !important;
    font-family: 'Barlow', sans-serif !important;
    font-size: .72rem !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    color: #4A5568 !important;
    padding: .85rem 1rem !important;
    border-bottom: 1px solid #E8EDF2 !important;
}

.woocommerce-cart table.shop_table td {
    padding: 1rem !important;
    border-bottom: 1px solid #F4F6F9 !important;
    font-family: 'Barlow', sans-serif !important;
    vertical-align: middle !important;
}

/* Product name in cart */
.woocommerce-cart table.shop_table td.product-name a {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: #0D1B2A !important;
    text-decoration: none !important;
}

.woocommerce-cart table.shop_table td.product-name a:hover {
    color: #F4801A !important;
}

/* Price in cart */
.woocommerce-cart table.shop_table .woocommerce-Price-amount {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-weight: 800 !important;
    color: #0D1B2A !important;
}

/* Cart totals box */
.woocommerce-cart .cart_totals {
    background: #fff !important;
    border: 1.5px solid #E8EDF2 !important;
    border-radius: 8px !important;
    padding: 1.5rem !important;
}

.woocommerce-cart .cart_totals h2 {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 1.2rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    color: #0D1B2A !important;
    margin-bottom: 1rem !important;
}

/* Proceed to checkout button */
.woocommerce-cart .checkout-button {
    background: #F4801A !important;
    color: #fff !important;
    border: none !important;
    padding: 14px 28px !important;
    border-radius: 5px !important;
    font-family: 'Barlow', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    width: 100% !important;
    text-align: center !important;
    transition: background .2s !important;
}

.woocommerce-cart .checkout-button:hover {
    background: #C0600E !important;
}

/* Update cart button */
.woocommerce-cart .actions .button {
    background: #0D1B2A !important;
    color: #fff !important;
    border: none !important;
    padding: 10px 20px !important;
    border-radius: 5px !important;
    font-family: 'Barlow', sans-serif !important;
    font-weight: 700 !important;
    font-size: .875rem !important;
}

.woocommerce-cart .actions .button:hover {
    background: #F4801A !important;
}

/* Empty cart */
.woocommerce-cart .cart-empty {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: #4A5568 !important;
}

.woocommerce-cart .return-to-shop .button {
    background: #F4801A !important;
    color: #fff !important;
    border: none !important;
    padding: 12px 24px !important;
    border-radius: 5px !important;
    font-family: 'Barlow', sans-serif !important;
    font-weight: 700 !important;
    font-size: .875rem !important;
    text-decoration: none !important;
}

/* Cart & checkout full width */
.woocommerce-cart .entry-content,
.woocommerce-cart .site-content,
.woocommerce-cart .content-area,
.woocommerce-cart #content,
.woocommerce-cart .ast-container,
.woocommerce-cart .container,
.woocommerce-cart article,
.woocommerce-cart .post-inner,
.woocommerce-checkout .entry-content,
.woocommerce-checkout .site-content,
.woocommerce-checkout .content-area,
.woocommerce-checkout #content,
.woocommerce-checkout .ast-container,
.woocommerce-checkout .container,
.woocommerce-checkout article,
.woocommerce-checkout .post-inner {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
}

/* Then constrain just the cart content itself */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce {
    max-width: 900px !important;
    margin: 2rem auto !important;
    padding: 0 2rem !important;
}

/* ============================================================
   CART PAGE — GPP HEADER + LAYOUT
============================================================ */

/* Hide the default entry title */
.woocommerce-cart .entry-title,
.woocommerce-cart .ast-breadcrumbs-wrapper {
    display: none !important;
}

/* Remove the big empty gap at top */
.woocommerce-cart #content,
.woocommerce-cart .site-content {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* Add a GPP-style header bar above the cart */
.woocommerce-cart .woocommerce::before {
    content: 'Your Cart';
    display: block;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 2.5rem;
    font-weight: 800;
    text-transform: uppercase;
    color: #0D1B2A;
    padding: 2rem 0 1.5rem;
    border-bottom: 2px solid #E8EDF2;
    margin-bottom: 1.5rem;
    letter-spacing: .02em;
}

/* Keep content centred with breathing room */
.woocommerce-cart .woocommerce {
    max-width: 960px !important;
    margin: 0 auto !important;
    padding: 0 2rem 3rem !important;
}

/* Add pale background to the whole page */
.woocommerce-cart .site-content,
.woocommerce-cart #content {
    background: #F4F6F9 !important;
    padding-bottom: 3rem !important;
}

/* Remove white gap on cart page */
.woocommerce-cart .ast-container,
.woocommerce-cart .content-area,
.woocommerce-cart #primary {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* ============================================================
   CART & CHECKOUT — GPP COLOUR FIXES
============================================================ */

/* All WooCommerce buttons — navy base, orange hover */
.woocommerce-cart .button,
.woocommerce-cart .button.alt,
.woocommerce-cart input.button,
.woocommerce-cart a.button {
    background: #0D1B2A !important;
    color: #fff !important;
    border: none !important;
    border-radius: 5px !important;
    font-family: 'Barlow', sans-serif !important;
    font-weight: 700 !important;
    letter-spacing: .03em !important;
    transition: background .2s !important;
}

.woocommerce-cart .button:hover,
.woocommerce-cart .button.alt:hover,
.woocommerce-cart input.button:hover,
.woocommerce-cart a.button:hover {
    background: #F4801A !important;
    color: #fff !important;
}

/* Checkout button — orange primary */
.woocommerce-cart a.checkout-button,
.woocommerce-cart .checkout-button {
    background: #F4801A !important;
    color: #fff !important;
}

.woocommerce-cart a.checkout-button:hover,
.woocommerce-cart .checkout-button:hover {
    background: #C0600E !important;
}

/* Remove to cart cross button — subtle */
.woocommerce-cart .product-remove a {
    color: #4A5568 !important;
    font-size: 1.2rem !important;
}

.woocommerce-cart .product-remove a:hover { color: #B91C1C !important; }

/* Quantity input */
.woocommerce-cart .qty {
    border: 1.5px solid #E8EDF2 !important;
    border-radius: 4px !important;
    font-family: 'Barlow', sans-serif !important;
    color: #0D1B2A !important;
    text-align: center !important;
}

/* Coupon input */
.woocommerce-cart #coupon_code {
    border: 1.5px solid #E8EDF2 !important;
    border-radius: 5px !important;
    padding: 10px 14px !important;
    font-family: 'Barlow', sans-serif !important;
    color: #0D1B2A !important;
}

.woocommerce-cart #coupon_code:focus {
    border-color: #F4801A !important;
    outline: none !important;
}

/* Cart totals */
.woocommerce-cart .cart_totals h2 {
    font-family: 'Barlow Condensed', sans-serif !important;
    font-size: 1.3rem !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    color: #0D1B2A !important;
}

/* Return to shop link */
.woocommerce-cart .return-to-shop .button {
    background: #F4801A !important;
    color: #fff !important;
}

.woocommerce-cart .return-to-shop .button:hover {
    background: #C0600E !important;
}