/** Shopify CDN: Minification failed

Line 31:4 "@import" is only valid at the top level

**/
/* ============================================================================
   TABLE OF CONTENTS
   ============================================================================
   1. CSS Variables & Root Overrides
   2. Base & Reset Styles
   3. Layout & Container Components
   4. Typography & Text Styles
   5. Navigation & Header
   6. Footer Components
   7. Product Display Page (PDP)
   8. Collection & Banner Components
   9. Tables & Data Display
   10. Color Swatches
   11. Third-party Integrations (Boost)
   12. Enhanced Product Grid Styles
   13. Utility Classes
   14. Media Queries & Responsive Design
   ============================================================================ */


/* ============================================================================
   1. CSS VARIABLES & ROOT OVERRIDES
   ============================================================================ */

:root { 
    @import url('//www.golfapparelshop.com/cdn/shop/t/456/assets/pei-color-names.css?v=53726353808136247631763225119');

    /* Footer text color override */
    --colorFooterText: #ffffff !important;
    
    /* Typography weight */
    --typeHeaderWeight: 600 !important;

    /* Atlas Drawer button */
    --atlas-button-primary: #1a3768 !important;
    --atlas-button-border-radius-normal: 0 !important;

    --boostsd-product-list-gap-mobile: 15px !important;
}


/* ============================================================================
   2. BASE & RESET STYLES
   ============================================================================ */

/* Remove default button text letter spacing */
.btn, 
.rte .btn, 
.shopify-payment-button .shopify-payment-button__button--unbranded {
    letter-spacing: normal;
}

/* ============================================================================
   3. LAYOUT & CONTAINER COMPONENTS
   ============================================================================ */

/* Main page container - max width and centering */
.page-width:not(.page-content) {
    margin: 0 auto;
    max-width: 1920px; 
}


/* ============================================================================
   4. TYPOGRAPHY & TEXT STYLES
   ============================================================================ */

.btn--large { 
    font-size: 16px;
}

/* Announcement bar */
.announcement-text {
    font-size: 1rem;
    letter-spacing: 0;
}

/* Hero section text */
.hero__subtitle {
    font-size: 2.2em;
}

.hero__top-subtitle {
    letter-spacing: 0;
}

.hero__text-content .btn {
    font-size: max(calc(var(--typeBaseSize)), 13px);
}

.hero__image {
    object-position: top;
}


/* ============================================================================
   5. NAVIGATION & HEADER
   ============================================================================ */

/* Site header */
[data-section-type="header"] {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1), 
                0 2px 4px rgba(0, 0, 0, 0.05);
}

.site-header {
    box-shadow: none !important;
}

.template-page .site-header {
    border-bottom: 1px solid #f1f1f1;
    margin-bottom: 10px;
}

/* Navigation links */
.site-nav__link .icon-chevron-down {
    display: none;
}

.site-header--heading-style .site-nav__link {
    font-weight: var(--typeHeaderWeight) !important;
}

/* Breadcrumb navigation */
.breadcrumb {
    text-align: left !important;
    margin-top: 10px;
}

.breadcrumb a {
    text-decoration: underline;
}

/* Search bar overlap fix */
.predictive-overflow-hidden .site-nav--has-dropdown,
.predictive-overflow-hidden .header-item--logo {
    z-index: 0;
}

div[id^="scrolling_text"] {
    background: #f6f6f6;
}


/* ============================================================================
   6. FOOTER COMPONENTS
   ============================================================================ */

/* Footer title styling */
.footer__title {
    font-size: 1.2em;
    font-weight: bold;
    letter-spacing: 0;
}

.h4.footer__title, 
.site-footer a, 
.site-footer [data-type=newsletter] a.btn {
    color: #fff;
}

/* Footer button styling */
.footer__collapsible .btn {
    border: solid 1px #fff;
    font-size: 1rem;
}

/* Footer small text sections */
footer .footer__small-text:nth-of-type(1) {
    margin-top: 30px;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    padding-top: 20px;
    padding-bottom: 20px;
}

footer .footer__small-text:nth-of-type(2) {
    display: none;
}


/* ============================================================================
   7. PRODUCT DISPLAY PAGE (PDP)
   ============================================================================ */

.boost-sd__button--transparent {
    background: none !important;
}

/* Free shipping info banner */
.pdp-fs {
    text-align: center;
    font-size: 1rem;
    font-weight: 500;
    font-style: normal;
    color: #333;
    padding: 8px 20px;
    width: 100%;
    margin-top: 15px;
    background: #eee;
    border-radius: 50px;
}

.product-single__title {
    margin-bottom: 0px;
}

h1.product-single__title flair-badges { 
    margin-bottom: 10px; 
}

flair-badges[tags="sizes-area"] {
    --flair-padding: 0 0 10px 0;
}

.pdp-container {
    text-align: center !important;
    margin: 0 auto !important;
    max-width: 1200px;
    width: 100%;
}

.product-single__meta .product-block {
    margin-bottom: 8px;
}

.product-block--price + .product-block {
    margin: 0;
}

/* Variant selector styling */
.variant-input-wrap label {
    box-shadow: 0 0 0 2px #cfcfcf; 
}

.variant-input-wrap label.disabled {
    background-color: #000;
    opacity: 0.3;
}

.variant-input:has(input:disabled) {
  display: none;
}

/* Hide "more payment options" link */
a#more-payment-options-link {
    display: none;
}

.product-single__meta .yotpo-reviews-star-ratings-widget {
    margin-bottom: 0px !important;
}

.cart-link {
    position: relative;
    display: inline-block;
}
        
.cart-link__bubble {
    position: absolute;
    top: -8px;
    right: -8px;
    background-color: #1a3768;
    color: white;
    border-radius: 50%;
    min-width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: bold;
    opacity: 0;
    transition: opacity 0.2s ease;
    padding: 8px;
 }
        
.cart-link__bubble--visible {
    opacity: 1;
}
        
.cart-link__bubble-text {
    line-height: 1;
}

.product__price.product__price--compare, .sticky-cart-price-compare {
    opacity: 0.6;
    font-size: 16px;
    padding-right: 0;
}

.product__price-savings {
    font-weight: bold;
}

/* Sticky Add to cart */
.sticky-cart-info-wrap .fa-star:before, .sticky-cart-info-wrap .fa-star-half-o:before {
    color: #2a4d89;
}

.sticky-cart-buttons button {
    font-weight: bold;
    font-size: 16px;
}

/* ============================================================================
   8. COLLECTION & BANNER COMPONENTS
   ============================================================================ */

#collection-tile-banner {
    padding: 0 10px 0px 0;
}

#collection-tile-banner img {
    pointer-events: none !important;
    display: block;
    margin: 0 auto;
}

#collection-tile-banner a.rte__image:hover {
    opacity: 0.8;
}


/* ============================================================================
   9. TABLES & DATA DISPLAY
   ============================================================================ */

.size-table th {
    font-size: .8rem !important;
    background: #163a6a !important;
    color: #fff;
    text-align: center;
}


/* ============================================================================
   10. COLOR SWATCHES
   ============================================================================ */

/* Color swatch button backgrounds */
button[title*="Beige"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Clear) !important;
}

button[title*="Black"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Black) !important;
}

button[title*="Brown"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Brown) !important;
}

button[title*="Blue"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Blue) !important;
}

button[title*="Gray"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Grey) !important;
}

button[title*="Green"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Green) !important;
}

button[title*="Orange"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--VibrantOrange) !important;
}

button[title*="Pink"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Pink) !important;
}

button[title*="Purple"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Purple) !important;
}

button[title*="Red"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--Red) !important;
}

button[title*="White"] .boost-sd__filter-option-swatch-item-img {
    background-color: var(--White) !important;
    border: 1px solid #ddd;
}


/* ============================================================================
   11. THIRD-PARTY INTEGRATIONS (BOOST, YOTPO)
   ============================================================================ */

/* Boost recommendation layout */
/* .boost-sd-layout {
    padding: 0 15px;
} */

/* Boost recommendation title styling */
.boost-sd__recommendation-title--left:before, 
.boost-sd__recommendation-title--left:after {
    width: 50% !important;
}

.boost-sd__recommendation-title-text {
    font-family: 'Roboto' !important;
    font-weight: 500 !important;
    font-size: 18px !important;
    text-transform: uppercase;
}

.boost-sd__product-title {
    font-size: 1em !important;
    letter-spacing: 0 !important;
}

.boost-sd__product-price-wrapper {
    font-size: 16px !important;
}

.boost-sd__product-price--compare {
    opacity: 0.7;
}

span.boost-sd__product-price--saving {
    padding-left: 5px !important;
}

.boost-sd__product-vendor {
    font-size: 0.9em !important;
    letter-spacing: 0 !important;
}

/* Boost slider dots styling */
.boost-sd__slider .slick-dots li:not(.slick-active) button:before {
    color: #ccc;
    background-color: #ccc;
}

.boost-sd__search-form-wrapper {
    background-color: transparent !important;
}

.slick-dots li button:before {
    opacity: 1;
}

.yotpo-main-widget-tabs .ugc-storefront-widgets-tabs-container__tab.selected {
    border-bottom: 1px solid var(--yotpo-pure-black) !important;
}

.yotpo-sr-bottom-line-button .yotpo-sr-bottom-line-text {
    text-decoration: underline;
}

.toolbar__item {
    padding-top: 10px;
}

.toolbar__item .faux-select {
    padding-bottom: 0px;
}


/* ============================================================================
   12. ENHANCED PRODUCT GRID STYLES
   ============================================================================ */

/* Product Grid Wrapper */
.product-grid-wrapper {
    min-height: 100vh;
    background: linear-gradient(to bottom right, #f9fafb, #f3f4f6);
    padding: 2rem;
}

.product-grid-container {
    max-width: 90%;
    margin: 0 auto;
}

/* Product Grid Header - matching boost-sd__recommendation-title */
.product-grid-header {
    margin-bottom: 3rem;
    position: relative;
    text-align: center;
}

.product-grid-title {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0;
    color: #111827;
    display: inline-block;
    padding: 0 1rem;
    background: linear-gradient(to bottom right, #f9fafb, #f3f4f6);
    position: relative;
    z-index: 10;
}

.product-grid-title::before {
    content: '';
    position: absolute;
    top: 50%;
    right: 100%;
    width: 50vw;
    height: 1px;
    background-color: #d1d5db;
    transform: translateY(-50%);
}

.product-grid-title::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 100%;
    width: 50vw;
    height: 1px;
    background-color: #d1d5db;
    transform: translateY(-50%);
}

/* Product Grid Layout */
.product-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

/* Product Card */
.product-card {
    background: white;
    border-radius: 0.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    transition: all 0.3s ease;
    border: 1px solid #e5e7eb;
}

.product-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1), 0 2px 4px rgba(0, 0, 0, 0.05);
    transform: translateY(-2px);
}

/* Product Image Wrapper */
.product-card .product-image-wrapper {
    position: relative;
    background: #f9fafb;
    overflow: hidden;
    aspect-ratio: auto;
    /* min-height: 250px; */
}

.product-card .product-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
    transition: transform 0.5s ease;
}

.product-card:hover .product-image {
    transform: scale(1.05);
}

/* Product Badge */
.product-badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    background: #dc2626;
    color: white;
    padding: 0.25rem 0.75rem;
    border-radius: 0.25rem;
    font-weight: 700;
    font-size: 0.75rem;
}

/* Product Content Area */
.product-card .product-content {
    padding: 1.25rem;
}

/* Product Vendor - matching boost-sd__product-vendor */
.product-card .product-vendor {
    font-size: 0.9em;
    letter-spacing: 0;
    font-weight: 600;
    color: #1a3768;
    text-transform: uppercase;
    margin-bottom: 0.5rem;
    display: block;
    text-align: left;
}

/* Product Title - matching boost-sd__product-title */
.product-card .product-title {
    font-size: 1em;
    letter-spacing: 0;
    font-weight: var(--typeHeaderWeight);
    color: #111827;
    margin-bottom: 1rem;
    line-height: 1.5;
    text-align: left;
}

/* Price Wrapper - matching boost-sd__product-price-wrapper */
.product-card .product-price-wrapper {
    font-size: 16px;
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
    text-align: left;
}

.product-card .product-price-compare {
    opacity: 0.7;
    text-decoration: line-through;
    color: #9ca3af;
    font-size: 1rem;
}

.product-card .product-price-current {
    font-size: 1.5rem;
    font-weight: 700;
    color: #111827;
}

.product-card .product-price-cents {
    font-size: 1rem;
    font-weight: 700;
    color: #111827;
    vertical-align: super;
    line-height: 1;
}

.product-card .product-price-to {
    font-size: 1rem;
    font-weight: 700;
    color: #6b7280;
}

/* Price Savings - matching boost-sd__product-price--saving */
.product-card .product-price-saving {
    padding-left: 5px;
    color: #dc2626;
    font-weight: bold;
    font-size: 1rem;
    width: 100%;
}

/* Event Banner - matching pdp-fs style */
.product-card .product-event-banner {
    background: #1a3768;
    border-radius: 0.25rem;
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
    text-align: center;
}

.product-card .product-event-text {
    font-size: 0.875rem;
    font-weight: 700;
    color: #ffffff;
    letter-spacing: 0;
}

/* Color Swatches */
.product-card .product-colors {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.product-card .color-swatch {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.375rem;
    transition: all 0.2s ease;
    cursor: pointer;
    box-shadow: 0 0 0 2px #cfcfcf;
    border: none;
}

.product-card .color-swatch:hover {
    transform: scale(1.05);
    box-shadow: 0 0 0 2px #1a3768;
}

.product-card .color-swatch-more {
    background: white;
    box-shadow: 0 0 0 2px #cfcfcf;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: #4b5563;
    font-size: 0.875rem;
}


/* ============================================================================
   13. UTILITY CLASSES
   ============================================================================ */

/* Add any utility classes here */


/* ============================================================================
   14. MEDIA QUERIES & RESPONSIVE DESIGN
   ============================================================================ */

/* Mobile styles (max-width: 768px) */

@media only screen and (max-width: 768px) {

    /** PDP title, price & flair callout moved to top on mobile **/

    .page-content--product .grid {
        position: relative;
        padding-top: 8.5rem;
    }
    .product-block.product-block--header {
        position: absolute;
        top: 0rem;
        left: 0;
        right: 0;
        text-align: center;
        width: 100%;
    }
    .product-block--price {
        position: absolute;
        top: 3.1rem;
        text-align: center;
        width: 100%;
    }
    .page-content--product flair-banners {
        position: absolute;
        top: 5.1rem;
        text-align: center;
        width: 100%;
    }
    .product-single__title flair-badges {
        display: none !important;
    }

    #collection-tile-banner {
        display: none !important;
    }

    /* Enhanced Product Grid Mobile */
    .product-grid-wrapper {
        padding: 1rem;
    }
    
    .product-grid-header {
        margin-bottom: 2rem;
    }
    
    .product-grid {
        gap: 1rem;
    }

    .product-card .product-image-wrapper {
        /* min-height: 250px; */
    }

    .product-card .product-content {
        padding: 1rem;
    }

    /* Footer support bar mobile adjustments */
    .footer__support_bar {
        border: 0;
        line-height: 2rem; 
    }

    .product__main-photos .flickity-page-dots {
        display: none;
    }
    
    .footer__support_bar .btn--secondary.btn--small {
        font-size: .8rem; 
    }
    
    .footer__support_bar .footer__social {
        float: none; 
    } 
    .template-collection .sitewide {
        margin: 0;
    }
    .predict-placement button {
        display: block;
        margin: 0 auto;
        justify-content: center;
        align-items: center; 
    }
    .yotpo-bottom-line-scroll-panel {
        display: inherit !important;
    }
    .boost-sd__product-price-wrapper {
        flex-direction: column;
        align-items: center;
    }
    .boost-sd__product-price-content {
        width: 100%;
        justify-content: center !important;
    }
    .boost-sd__product-price--saving {
        text-align: center;
    }
    .boost-sd__product-image-wrapper {
        aspect-ratio: auto !important;
        /* min-height: 250px; */
    }
    
    .boost-sd__product-image-img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    flair-badges {
        display: flex !important;
        justify-content: left !important;
        width: 100% !important; 
        margin: 0 auto !important;
        margin-bottom: 10px !important;
        --flair-layout-display: flex;
        --flair-layout-direction: row;
        --flair-layout-justify-content: left;
        --flair-layout-align-items: left;
        
    }
    flair-badges[tags="plp-image-badge"] {
        --flair-font-size: 10px;
    }
}

/* Tablet styles (min-width: 769px) */
@media only screen and (min-width: 769px) {
    /* Enhanced Product Grid Tablet */
    .product-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 2rem;
    }
    
    .product-card .product-image-wrapper {
        height: 350px;
    }

    .template-collection .index-section {
        margin: 15px 0; 
    }
    
    a#more-payment-options-link {
        display: none;
    }

    .hero__top-subtitle {
        font-size: 1.5em;
    }

    .hero__text-content {
        padding: 45px 5%;
    }

    .site-footer {
        padding-bottom: 0px;
    }

    .announcement-slider__slide:first-child,
    .announcement-slider__slide:nth-child(2) {
        border-right: 1px solid #fff;
    }

    .site-navigation .medium-up--one-fifth {
        width: 15%;
    }
}

/* Desktop styles (min-width: 992px) */
@media only screen and (min-width: 992px) {
    /* Enhanced Product Grid Desktop */
    .product-grid-container {
        max-width: 90% !important;
    }

    .product-grid {
        gap: 2rem;
    }

    .product-card .product-image-wrapper {
        height: 400px;
    }

    /* Boost layout desktop optimization */
    .boost-sd-layout {
        display: flex;
        max-width: 90% !important;
        margin: 0 auto;
    }
    .variant-wrapper:nth-of-type(2) {
        display: inline-block;
        vertical-align: middle;
    }

    .template-collection .boost-sd__product-item-grid-view-layout-image .boost-sd__product-image-wrapper {
        width: 100%; /* Keep this */
        position: relative;
        overflow: hidden;
        aspect-ratio: unset !important; /* Try to remove the aspect-ratio property */
    }

    .template-collection .boost-sd__product-item-grid-view-layout-image .boost-sd__product-image-img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        display: block;
    }

}

/* Camouflage CSS To Hide the Correct Sizes in the PDP Page When No inventory */
fieldset.variant-input-wrap[name="Size"] .hide-oos-disable {
  display: inline-block !important;
}

fieldset.variant-input-wrap[name="Length"] .hide-oos-disable {
  display: inline-block !important;
}

fieldset.variant-input-wrap label.disabled.hide-oos-disable {
  /* border: 1px solid var(--colorBorder);  Updated border color to match the image */
  position: relative;           /* Ensures the strikethrough is positioned inside */
  color: var(--colorBorder) !important;
}

fieldset.variant-input-wrap label.disabled.hide-oos-disable:before {
  border-left: 1px solid;
  border-color:var(--colorBorder); 
  bottom: 0;
  content: "";
  left: 50%;
  position: absolute;
  top: 0;
  transform: rotate(45deg);
}

fieldset.variant-input-wrap label.disabled {
  opacity: .75;
} 

button.hc-store-change-button-7707336540238.hc-text.hc-pointer.hc-text-uppercase.hc-font-s
{
  color: black !important;
}

button.hc-store-change-button-7705448906830.hc-text.hc-pointer.hc-text-uppercase.hc-font-s 
{
	color:black !important
}

button[title="Find product with Color is Beige"]
{
  background-color: #deb887 !important;

}


/*
 * 1. Defines the "Aggressive Pulse-Shake" animation
 */
@keyframes aggressive-pulse-shake {
  /* --- PAUSE for the first 70% of the 3-second cycle --- */
  0%, 70%, 100% {
    transform: scale(1) translateX(0);
  }

  /* --- RAPID SHAKE (all happens in the last 30% of the cycle) --- */
  75% {
    transform: scale(1.2) translateX(-7px); /* Pulse up, shake hard left */
  }
  80% {
    transform: scale(1.2) translateX(7px);  /* Stay pulsed, shake hard right */
  }
  85% {
    transform: scale(1.2) translateX(-7px); /* Shake left again */
  }
  90% {
    transform: scale(1.2) translateX(7px);  /* Shake right again */
  }
  95% {
    transform: scale(1.2) translateX(0);    /* Settle the shake before pause */
  }
}

/*
 * 2. Applies the new animation to the Impulse search icon
 * (3-second duration, loops forever)
 */
a.js-search-header {
  animation: aggressive-pulse-shake 4s infinite ease-in-out;
  display: inline-block; /* Ensures the transform works correctly */
}


/* --- CSS for Mobile Menu Search Bar --- */
.drawer__search-bar {
  position: relative;
}

.drawer__search-bar .search-form {
  position: relative;
  display: flex;
}

.drawer__search-bar .search-form__input {
  width: 100%;
  padding-right: 40px; /* Make room for the button */
  /* The theme's default input styles should apply */
}

.drawer__search-bar .search-form__submit {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  height: 100%;
  width: 60px; /* Adjust as needed */
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}

.drawer__search-bar .search-form__submit .icon-search {
  width: 18px; /* Adjust icon size */
  height: 18px;
}

.drawer__header {border-bottom: none !important }


/* Add images to the mobile mneu */
.mobile_menu_image {
  align-self:center;
  max-width:40px;
  max-height:40px;
  border-radius:100%;
  margin-left: 20px;
}

/* ================= PLP mobile banner fix ================== */

img.boost-sd__product-banner-image { 
    padding-left: 0 !important; 
    padding-right: 0 !important; 
    max-width: 100% !important; 
    max-height: fit-content;
}

/* ================= Custom Footer Terms ================== */
#footer-terms{
    display: block;
    text-align: left;
    font-size: 10px;
    padding: 2rem 0 0 0;
}
#footer-terms p strong{
    font-size: 12px;
    font-weight: 600;
    margin-bottom: .5rem;
    line-height: .5rem;
}
#footer-terms p{
    font-size: 11px !important;
    max-width: 200ch;
    margin-left: auto;
    margin-right: auto;
    color:#ffffff;
}
#footer-terms p a{
    color:#ffffff;
    text-decoration: underline;
}

@media screen and (max-width: 39.9375em) {
  .product-single__meta {
 text-align: left;
  }




}