/* ====================================================
   GASOIL FOOTWEAR — LUXURY DESIGN V2
   Porto Child Theme V2 — gf-styles.css
   ==================================================== */

/* ── GOOGLE FONTS ───────────────────────────────────── */
/* Playfair Display est déjà chargé via Porto Custom Google Fonts */
/* On charge uniquement DM Sans pour le corps de texte */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

/* ── CSS VARIABLES — LUXURY PALETTE ─────────────────── */
:root {
    --gf-black:     #111111;
    --gf-dark:      #1a1a1a;
    --gf-gold:      #C9A96E;
    --gf-gold-lt:   #e8d5b0;
    --gf-white:     #ffffff;
    --gf-off-white: #FAFAF8;
    --gf-warm-grey: #F5F3F0;
    --gf-border:    #E8E5E0;
    --gf-mid-grey:  #888888;
    --gf-display:   'Playfair Display', Georgia, serif;
    --gf-body:      'DM Sans', system-ui, -apple-system, sans-serif;
    --gf-ease:      cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ── BASE ───────────────────────────────────────────── */
body {
    font-family: var(--gf-body) !important;
    background-color: var(--gf-off-white) !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ── TYPOGRAPHY ─────────────────────────────────────── */
h1, h2, h3, h4, h6 {
    font-family: var(--gf-display) !important;
    font-weight: 400 !important;
    letter-spacing: 0.03em;
    color: var(--gf-black);
}

h5 {
    font-family: var(--gf-body) !important;
    font-size: 16px !important;
    line-height: 22px !important;
}

/* Section headings */
h2.selection_css_h2,
h2.vc_custom_heading.mb-1.best_sellers_h2 {
    font-family: var(--gf-display) !important;
    font-weight: 400 !important;
    font-size: 2rem !important;
    text-transform: none !important;
    letter-spacing: 0.05em;
    color: var(--gf-black) !important;
    margin-bottom: 10px !important;
}

h2.selection_css_h2::after,
h2.vc_custom_heading.mb-1.best_sellers_h2::after {
    content: '';
    display: block;
    width: 40px;
    height: 1px;
    background-color: var(--gf-gold);
    margin: 14px auto 0;
}

h5.selection_css_h5,
h5.best_sellers_h5 {
    font-family: var(--gf-body) !important;
    font-weight: 300 !important;
    font-size: 15px !important;
    color: var(--gf-mid-grey) !important;
    width: 70%;
    margin: 0px auto;
    letter-spacing: 0.02em;
    line-height: 24px !important;
}

.header_gf_inner h2.vc_custom_heading {
    font-family: var(--gf-display) !important;
    font-weight: 400 !important;
    text-transform: none !important;
    margin-bottom: 17px !important;
    font-size: 2.5rem;
    line-height: 1.2;
    letter-spacing: 0.05em;
}

.header_gf_inner h5.vc_custom_heading.mb-4 {
    font-family: var(--gf-body) !important;
    font-weight: 300 !important;
    width: 70%;
    font-size: 16px !important;
    line-height: 24px !important;
    margin: 0px auto;
    color: var(--gf-mid-grey) !important;
}

/* ── NAVIGATION ─────────────────────────────────────── */
.page-header.type1 .navigation:not(.side-megamenu) .level0 .level-top {
    font-family: var(--gf-body) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.12em !important;
    color: var(--gf-dark) !important;
    transition: color 0.25s ease;
}

.page-header.type1 .navigation:not(.side-megamenu) .level0 .level-top:hover {
    color: var(--gf-gold) !important;
}

.sticky-header div#store\.menu {
    background: var(--gf-off-white) !important;
    border-bottom: 1px solid var(--gf-border) !important;
}

.page-header.type1.sticky-header .cart-design-2 .action.showcart .minicart-icon {
    border-color: var(--gf-dark) !important;
}

.page-header.type1.sticky-header .minicart-wrapper .action.showcart,
.page-header.type1.sticky-header .minicart-wrapper .action.showcart:before,
.page-header.type1.sticky-header .minicart-wrapper .action.showcart.active:before {
    color: var(--gf-dark) !important;
}

/* Megamenu */
.sw-megamenu.navigation li.level0.fullwidth .submenu li.level1 > a,
.sw-megamenu.navigation li.level0.staticwidth .submenu li.level1 > a {
    font-family: var(--gf-display) !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    letter-spacing: 0.03em !important;
    color: var(--gf-dark) !important;
}

.sw-megamenu.navigation li.level0.fullwidth .submenu a,
.sw-megamenu.navigation li.level0.staticwidth .submenu a {
    font-family: var(--gf-body) !important;
    font-size: 13px !important;
    font-weight: 400 !important;
}

.sw-megamenu.navigation li.level0.fullwidth > .submenu a:hover,
.sw-megamenu.navigation li.level0.staticwidth > .submenu a:hover {
    color: var(--gf-gold) !important;
}

/* ── HEADER PANEL ───────────────────────────────────── */
.header.panel > .header.links > li > a,
.page-header.type1 .header.panel > .header.links > li > a,
.header.panel > .header.links > li.greet.welcome {
    font-family: var(--gf-body) !important;
    font-size: 12px !important;
    font-weight: 400;
    letter-spacing: 0.04em;
    padding: 5px 10px;
    text-transform: capitalize;
}

.page-header .switcher strong,
.page-footer .switcher strong {
    font-family: var(--gf-body) !important;
    font-size: 12px !important;
    font-weight: 400;
}

span.not-logged-in {
    color: #fff !important;
}

/* ── TRUST BAR ──────────────────────────────────────── */
html .porto-sicon-header h3.porto-sicon-title {
    font-family: var(--gf-body) !important;
    font-size: 11px !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    font-weight: 500 !important;
    color: var(--gf-dark) !important;
}

.top-icon .porto-icon,
.top-icon .porto-sicon-img,
.top-icon .porto-sicon-header,
.top-icon .porto-sicon-description {
    display: block;
    margin: 0 auto;
    color: var(--gf-dark) !important;
}

/* ── PRODUCT CARDS ──────────────────────────────────── */
.products .product-item {
    box-shadow: none !important;
    border: 1px solid transparent;
    transition: border-color 0.3s var(--gf-ease), box-shadow 0.3s var(--gf-ease);
}

.products .product-item:hover {
    border-color: var(--gf-border) !important;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06) !important;
}

.products-grid .product-item .product-item-info {
    position: relative;
    padding-bottom: 1px;
}

.product-item-name,
.product-item-name a {
    font-family: var(--gf-body) !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: var(--gf-dark) !important;
    letter-spacing: 0.01em;
}

/* Price — dark/elegant instead of red */
.price-box .price,
.product-item .price-box .price,
.product-options-bottom .price-box .price,
.product-info-price .price-box .price {
    color: var(--gf-dark) !important;
    font-family: var(--gf-body) !important;
    font-weight: 500 !important;
    font-size: 15px !important;
    letter-spacing: 0.01em;
}

#maincontent.myclassBlack .product-info-price .price-box .price {
    color: var(--gf-dark) !important;
}

.product-options-bottom .price-box .old-price .price-container > span,
.product-info-price .price-box .old-price .price-container > span {
    color: var(--gf-mid-grey) !important;
    text-decoration: line-through;
}

/* Labels */
.product-labels .product-label.new-label {
    background-color: var(--gf-dark) !important;
}

.product-labels .product-label.sale-label {
    background-color: #c0392b !important;
}

/* ── BUTTONS (GLOBAL) ───────────────────────────────── */
html .action.primary,
html .btn-primary {
    color: #fff !important;
    background-color: var(--gf-dark) !important;
    border-color: var(--gf-dark) !important;
    font-family: var(--gf-body) !important;
    font-weight: 500 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    font-size: 12px !important;
    line-height: normal !important;
    border-radius: 0 !important;
    transition: background-color 0.25s ease, border-color 0.25s ease !important;
}

html .action.primary:hover,
html .btn-primary:hover {
    background-color: var(--gf-gold) !important;
    border-color: var(--gf-gold) !important;
    color: #fff !important;
}

/* ── ADD TO CART ────────────────────────────────────── */
.box-tocart .action.tocart {
    height: 3rem;
    padding: 0 2em;
    margin-bottom: 0;
    overflow: hidden;
    text-transform: uppercase;
    font-family: var(--gf-body) !important;
    font-size: 12px !important;
    letter-spacing: 0.08em !important;
    font-weight: 500 !important;
    line-height: 3rem;
    border: none;
    border-radius: 0 !important;
    background: var(--gf-dark) !important;
    transition: background-color 0.25s ease !important;
}

/* Fix: gold hover instead of green */
.box-tocart .action.tocart:hover,
.cart-summary .checkout-methods-items .action.primary.checkout:hover,
.form.forget .actions-toolbar > .primary .action:hover,
#review-form .action.primary:hover,
.cart-empty .btn-go-shop:hover,
html .account .action.primary:hover,
html .account .btn-primary:hover {
    background-color: var(--gf-gold) !important;
    border-color: var(--gf-gold) !important;
}

.product-item-actions > .actions-primary button.action.tocart.primary:hover {
    background-color: var(--gf-gold) !important;
    border-color: var(--gf-gold) !important;
}

/* ── IBANNER / CATEGORY BANNERS ─────────────────────── */
html .porto-ibanner .btn-dark,
.box-gotoproduct #product-gotoproduct-button {
    color: #fff;
    background-color: var(--gf-dark);
    border: 1px solid var(--gf-dark);
    font-family: var(--gf-body) !important;
    font-weight: 500 !important;
    font-size: 11px !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    border-radius: 0 !important;
    line-height: normal;
    padding: 10px 28px !important;
    width: max-content;
    transition: all 0.25s ease;
}

html .porto-ibanner .btn-dark a,
html .porto-ibanner .btn-dark a:hover {
    color: #fff;
    font-weight: 500;
}

html .porto-ibanner .btn-dark:hover,
.box-gotoproduct #product-gotoproduct-button:hover {
    background: transparent !important;
    color: #fff !important;
    border-color: rgba(255, 255, 255, 0.7) !important;
}

.porto-ibanner .heading-primary {
    color: var(--gf-dark);
    font-family: var(--gf-display) !important;
    font-weight: 400 !important;
    background: rgba(255, 255, 255, 0.92);
    padding: 6px 14px;
    width: max-content;
    letter-spacing: 0.06em;
}

.home_banner_ctg .porto-ibanner .heading-primary {
    color: var(--gf-dark);
    font-family: var(--gf-display) !important;
    font-weight: 400 !important;
    background: rgba(255, 255, 255, 0.92);
    padding: 6px 14px;
    width: max-content;
    text-align: center;
    margin: 0px auto;
    letter-spacing: 0.06em;
}

.ibanner_ctg .porto-ibanner .porto-ibanner-desc.no-padding {
    padding: 0;
    border: 1px solid rgba(200, 200, 200, 0.35);
}

.porto-ibanner .porto-ibanner-desc,
.porto-ibanner .porto-ibanner-link {
    position: absolute;
    display: block !important;
    width: 100%;
    bottom: 2.5%;
    left: 0;
    height: auto;
    top: inherit;
}

.porto-ibanner.ibanner_gf .porto-ibanner-desc {
    position: absolute;
    display: block !important;
    width: 100%;
    bottom: 10%;
    left: 0;
    padding: 15px !important;
    height: auto;
    top: inherit;
}

.porto-ibanner-layer {
    text-align: center !important;
    font-size: 1rem;
    width: 100% !important;
    margin: 0px auto;
    padding: 10px 0px;
}

.porto-ibanner.ibanner_gf h3.vc_custom_heading.mb-3.custom-font4.align-left {
    font-family: var(--gf-display) !important;
    font-size: 20px !important;
    font-weight: 400 !important;
    color: #fff !important;
    text-align: center;
    letter-spacing: 0.05em;
}

.porto-ibanner.ibanner_gf h3 a,
.porto-ibanner.ibanner_gf h3 a:hover,
.porto-ibanner.ibanner_gf h3 {
    color: #fff !important;
    text-align: center;
}

/* ── MINICART ───────────────────────────────────────── */
.minicart-items {
    margin: 0;
    padding: 0;
    display: block !important;
    list-style: none none;
}

.minicart-wrapper .action.showcart .counter.qty {
    background-color: var(--gf-gold) !important;
}

.minicart-wrapper .action.showcart .counter.qty.empty {
    background-color: #aaa !important;
}

.block-minicart .block-content > .actions > .primary .action.primary {
    font-family: var(--gf-body) !important;
    font-size: 12px !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    padding: 12px 1.5rem !important;
    border-radius: 0 !important;
    float: none;
    width: 100%;
    font-weight: 500 !important;
    margin-bottom: 10px;
    height: auto;
    line-height: inherit;
    color: #fff;
    background-color: var(--gf-dark) !important;
    border: none;
    transition: background-color 0.25s ease !important;
}

.block-minicart .block-content > .actions > .primary .action.primary:hover {
    background-color: var(--gf-gold) !important;
}

/* ── SEARCH ─────────────────────────────────────────── */
.search-category {
    display: none !important;
}

.block-search input {
    font-family: var(--gf-body) !important;
    font-size: 15px !important;
    border-radius: 0 !important;
}

button.action.search.primary {
    background: var(--gf-dark) !important;
    border: none;
    padding: 8px 24px !important;
    height: auto;
    font-weight: 500;
    border-radius: 0 !important;
    transition: background-color 0.25s ease !important;
}

button.action.search.primary:hover {
    background: var(--gf-gold) !important;
}

/* ── NEWSLETTER ─────────────────────────────────────── */
html .newsletter .action.primary {
    color: #fff;
    background-color: var(--gf-dark) !important;
    border-color: var(--gf-dark) !important;
    transition: background-color 0.25s ease !important;
}

html .newsletter .action.primary:hover,
.box-gotoproduct #product-gotoproduct-button:hover {
    background-color: var(--gf-gold) !important;
    border-color: var(--gf-gold) !important;
    color: #fff;
}

.single-subscribe .newsletter input {
    height: 51px !important;
    padding-left: 1.5em;
    padding-right: 15px;
    border-radius: 0 !important;
    font-size: 0.875rem;
    color: #777;
    border: 1px solid #ccc !important;
    margin: 0;
    font-family: var(--gf-body) !important;
}

div#newsletter-error {
    position: absolute;
}

#newsletter_popup input[type="email"] {
    height: 3rem;
    border: none;
    border-radius: 0 !important;
    background: #e0dede;
    box-shadow: none !important;
    padding-left: 1.375rem;
}

/* ── FORMS & INPUTS ─────────────────────────────────── */
input[type="email"],
input[type="number"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="text"],
input[type="url"],
input[type="color"],
input[type="date"],
input[type="datetime"],
input[type="datetime-local"],
input[type="month"],
input[type="time"],
input[type="week"],
textarea,
select {
    background-color: #ffffff;
    color: #000 !important;
    border-color: var(--gf-border) !important;
    border-radius: 0 !important;
    height: auto;
    padding: 10px 14px;
    font-size: 0.875rem;
    font-family: var(--gf-body) !important;
    transition: border-color 0.2s ease;
}

input:focus,
textarea:focus,
select:focus {
    border-color: var(--gf-gold) !important;
    outline: none;
    box-shadow: none !important;
}

.fieldset > .field .label,
.fieldset > .fields > .field .label {
    font-family: var(--gf-body) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

form .line-height-xl {
    line-height: 22px !important;
}

form .fieldset > .field input.input-text {
    line-height: 22px !important;
}

.fieldset > .legend {
    color: var(--gf-dark) !important;
    font-family: var(--gf-display) !important;
    font-weight: 400 !important;
    letter-spacing: 0.04em;
}

/* ── CHECKOUT ───────────────────────────────────────── */
.opc-progress-bar-item._active:before,
.opc-progress-bar-item._active > span:before {
    background: var(--gf-dark) !important;
}

html #checkoutSteps .action.primary {
    font-family: var(--gf-body) !important;
    font-size: 13px !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: #fff !important;
    background-color: var(--gf-dark) !important;
    border-color: var(--gf-dark) !important;
    border-radius: 0 !important;
    padding: 12px 30px !important;
    font-weight: 500 !important;
    height: auto;
    transition: all 0.25s ease !important;
}

html #checkoutSteps .action.primary:hover {
    background-color: var(--gf-gold) !important;
    border-color: var(--gf-gold) !important;
}

.cart-summary .checkout-methods-items .action.primary.checkout {
    width: 100%;
    font-family: var(--gf-body) !important;
    font-size: 13px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #fff;
    border-radius: 0 !important;
    padding: 12px 15px;
    font-weight: 500;
    line-height: normal;
    height: auto;
    background-color: var(--gf-dark) !important;
    border: none;
    transition: background-color 0.25s ease;
}

.abs-action-cart-button button.action:not(:hover),
.cart.actions button.action:not(:hover),
.cart-discount .actions-toolbar button.action:not(:hover) {
    background-color: var(--gf-warm-grey);
    color: var(--gf-dark);
    font-weight: 500;
}

.cart.actions button.action:hover {
    font-weight: 500 !important;
}

.cart-empty .btn-go-shop {
    width: max-content;
    padding: 12px 30px;
    border-radius: 0 !important;
    font-family: var(--gf-body) !important;
    font-size: 12px;
    letter-spacing: 0.1em;
    text-align: center;
    color: #fff;
    background-color: var(--gf-dark);
    border: none;
    line-height: 1.5;
    font-weight: 500;
    text-transform: uppercase;
    display: inline-block;
    transition: background-color 0.25s ease;
}

/* ── ACCOUNT / LOGIN ────────────────────────────────── */
.login-container .block .actions-toolbar > .primary .action,
.login-container .block .actions-toolbar > .secondary .action,
.form.create.account .actions-toolbar > .primary .action,
.form.create.account .actions-toolbar > .secondary .action {
    width: 100%;
    text-align: center;
    padding: 12px 30px !important;
    margin: 0;
    font-family: var(--gf-body) !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
    background-color: var(--gf-dark) !important;
    float: none;
    line-height: 21px;
    height: auto;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 12px !important;
    transition: background-color 0.25s ease !important;
}

html .account .action.primary,
html .account .btn-primary,
.form.forget .actions-toolbar > .primary .action {
    color: #fff !important;
    padding: 12px 20px !important;
    line-height: normal !important;
    height: max-content !important;
    font-family: var(--gf-body) !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
    background-color: var(--gf-dark) !important;
    border: none !important;
    letter-spacing: 0.08em !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    transition: background-color 0.25s ease !important;
}

html .account .products-grid.wishlist .product-item .tocart {
    font-size: 10px;
    padding: 8px 10px !important;
}

html .account .box-tocart .action.tocart:before {
    display: none;
}

/* ── REVIEWS ────────────────────────────────────────── */
#review-form .action.primary {
    color: #fff;
    background: var(--gf-dark) !important;
    border: none;
    padding: 12px 30px !important;
    height: auto;
    font-family: var(--gf-body) !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
    letter-spacing: 0.08em !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    transition: background-color 0.25s ease !important;
}

/* ── CONTACT PAGE ───────────────────────────────────── */
.contact-index-index .fieldset > .legend,
.contact-index-index .contact-info .contacts-title {
    color: var(--gf-dark);
    font-family: var(--gf-display) !important;
    font-size: 24px !important;
    margin-bottom: 20px;
    font-weight: 400 !important;
    letter-spacing: 0.05em;
    text-transform: none !important;
}

form#contact-form .submit {
    background: var(--gf-dark) !important;
    border: none;
    padding: 12px 30px !important;
    height: auto;
    font-family: var(--gf-body) !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
    letter-spacing: 0.08em !important;
    font-size: 12px !important;
    text-transform: uppercase !important;
    transition: background-color 0.25s ease !important;
}

form#contact-form .submit:hover {
    background: var(--gf-gold) !important;
}

.contact-index-index .page-main .contact-info p {
    margin-left: 55px;
    margin-bottom: 0;
    font-family: var(--gf-body) !important;
    font-size: 16px;
    line-height: 22px;
}

/* ── FOOTER ─────────────────────────────────────────── */
.footer .widgettitle,
.footer .widget-title {
    font-family: var(--gf-display) !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    letter-spacing: 0.06em;
}

.footer .widget p {
    margin-top: -3px;
    margin-bottom: 13px;
    font-family: var(--gf-body) !important;
    font-size: 14px;
    line-height: 22px;
    color: #666;
}

.footer-bottom address {
    order: 1;
    padding: 10px 8px 10px 0;
    text-align: left;
    font-family: var(--gf-body) !important;
    font-size: 13px;
    margin-right: auto;
    flex: auto;
}

.footer .contact-info .contact-details strong {
    line-height: 1em;
    color: var(--gf-dark) !important;
    font-family: var(--gf-body) !important;
    font-weight: 500;
    font-size: 14px;
}

.footer-middle .contact-details li {
    flex: 0 0 50%;
    max-width: 50%;
    font-family: var(--gf-body) !important;
    font-size: 14px;
    line-height: 22px;
    padding-right: 1em;
}

.footer-middle a {
    font-family: var(--gf-body) !important;
    color: #666;
    font-size: 14px;
    transition: color 0.2s ease;
}

.footer-middle a:hover {
    color: var(--gf-gold) !important;
}

.footer .follow-us .share-links a:not(:hover) {
    background: none;
    color: #444 !important;
}

.footer .follow-us .share-links a:hover {
    color: var(--gf-gold) !important;
}

.politique_footer {
    text-align: center;
}

ul.politique_footer li {
    display: inline-block;
    margin-left: 20px;
}

.footer .footer-middle .col-lg-12 .col-lg-12:before {
    margin: 10px 0 15px !important;
}

.widget:first-child,
.footer .widget:first-child {
    margin-top: 0;
    margin-bottom: 8px;
}

/* ── BRAND SECTION ──────────────────────────────────── */
.brand_logo {
    padding: 15px;
    text-align: center;
    width: 100%;
}

.brand_logo h4 {
    font-family: var(--gf-display) !important;
    font-size: 22px !important;
    font-weight: 400 !important;
    text-transform: none !important;
    letter-spacing: 0.08em;
    margin-bottom: 18px !important;
}

/* ── ABOUT PAGE ─────────────────────────────────────── */
.top_about em {
    color: #fff !important;
    font-family: var(--gf-display) !important;
    font-size: 28px !important;
    text-align: center;
}

.top_about h2 {
    color: #fff !important;
    text-align: center;
    font-family: var(--gf-display) !important;
    font-weight: 400 !important;
}

.container.content_about ul {
    margin: 0px auto;
    text-align: center;
}

.container.content_about ul li {
    margin: 0px auto;
    text-align: center;
    list-style: none;
}

.content-row p {
    font-family: var(--gf-body) !important;
    font-size: 14px;
    line-height: 22px !important;
    color: var(--gf-dark) !important;
}

/* ── STORE BANNER ───────────────────────────────────── */
.magasin_visite .custom-font4 {
    font-family: var(--gf-display) !important;
    letter-spacing: 0.05em;
}

.magasin_visite i {
    color: #fff;
}

html .magasin_visite .heading-light a {
    color: #ffffff !important;
}

/* ── PRODUCT DETAIL ─────────────────────────────────── */
.product.data.items > .item.content p {
    font-family: var(--gf-body) !important;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.005em;
    line-height: 24px;
    margin: 7px 0px;
    color: var(--gf-dark);
}

/* ── MISC ───────────────────────────────────────────── */
.limiter-options {
    width: auto;
    margin: 0;
    margin-left: 8px;
}

.message.notice {
    background: #c9a030;
    color: #ffffff;
}

.message.success {
    width: max-content;
    margin: 8px auto;
}

.message.success a {
    color: var(--gf-dark);
}

/* ── COOKIE BANNER ──────────────────────────────────── */
.message.global.noscript,
.message.global.cookie {
    margin: 0;
    padding: 12px 1em 12px 1.25em;
    display: block;
    font-size: 1rem;
    background: var(--gf-dark);
    border-color: #333;
    color: #aaa;
    z-index: 9000;
}

.message.global.noscript a,
.message.global.cookie a {
    color: var(--gf-gold);
}

html .message.global.cookie .action.primary {
    color: #fff !important;
    background-color: var(--gf-gold) !important;
    border-color: var(--gf-gold) !important;
    font-family: var(--gf-body) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    border-radius: 0 !important;
}

.message.global p {
    margin: 0;
    font-family: var(--gf-body) !important;
    font-size: 14px !important;
    text-align: center;
}

.message.global.cookie .actions {
    margin: 0.5em auto;
    text-align: center;
}

/* ── OWL CAROUSEL NAV ───────────────────────────────── */
.owl-carousel.nav-pos-outside .owl-nav .owl-next {
    right: 20px !important;
}

.owl-carousel.nav-pos-outside .owl-nav .owl-prev {
    left: 20px !important;
}

/* ── DESKTOP ────────────────────────────────────────── */
@media screen and (min-width: 992px) {
    .sticky-logo .logo img {
        height: 42px;
    }
}

/* ── MOBILE ─────────────────────────────────────────── */
@media (max-width: 480px) {
    .logo {
        max-width: 100px !important;
        z-index: auto;
    }

    .top-bar .porto-sicon-box {
        justify-content: center !important;
        padding-left: 10px;
    }

    .header_gf_inner h5.vc_custom_heading.mb-4 {
        width: 100%;
        font-size: 14px;
        line-height: 20px !important;
        margin: 0px auto;
    }

    .porto-ibanner-layer {
        font-size: 11px;
        line-height: 16px;
        width: 100% !important;
        margin: 0px auto;
        padding: 10px 0px;
        text-align: center !important;
    }

    h3.vc_custom_heading.mb-0.align-left.text-uppercase.heading-light {
        font-size: 24px !important;
        line-height: 28px !important;
    }

    html .newsletter .action.primary {
        height: 51px;
    }

    span.not-logged-in {
        color: #000 !important;
        font-size: 14px;
        line-height: 10px !important;
        text-align: center;
        margin: 0px auto;
    }

    .nav-sections .header.links li.greet.welcome {
        font-weight: 400;
        padding: 12px 20px;
        text-align: center;
        line-height: 20px;
    }

    header .navigation a {
        color: var(--gf-dark) !important;
    }

    .page-header.type1 .main-panel-top {
        border-bottom: 1px solid var(--gf-border);
        display: none;
    }

    .header-row .header-left,
    .header-row .header-right,
    .header-row .header-center {
        padding: 10px 0 !important;
    }

    .nav-sections .header.links a,
    .nav-sections .header.links a:hover {
        color: var(--gf-dark) !important;
        text-decoration: none;
        display: block;
        font-weight: 400;
        padding: 12px 20px;
    }

    .customer-account-login .block .block-title,
    .customer-account-login .field.note {
        text-align: center;
    }

    .contact-index-index .contact-info {
        margin-top: 30px;
    }

    .top_about em {
        font-size: 22px !important;
        padding: 0px !important;
    }

    .top_about h2 {
        padding: 0px !important;
    }

    .block.category.event,
    .footer.content,
    .header.content,
    .navigation,
    .page-main,
    .page-wrapper > .breadcrumbs ul,
    .page-wrapper > .page-bottom,
    .page-wrapper > .widget,
    .top-container,
    .page-wrapper > .breadcrumbs .items,
    .container {
        max-width: 100%;
        padding-left: 15px;
        padding-right: 15px;
    }

    .container.content_about ul {
        margin: 0px auto !important;
        text-align: center !important;
        padding: 0px !important;
    }

    .container.content_about img {
        margin: 20px 0px !important;
    }

    .content-row h2 {
        font-size: 20px !important;
    }

    .home-slider .porto-ibanner.mb-0 {
        height: auto;
        min-height: auto !important;
    }

    h2.selection_css_h2,
    h2.vc_custom_heading.mb-1.best_sellers_h2 {
        font-size: 1.6rem !important;
    }

    h5.selection_css_h5,
    h5.best_sellers_h5 {
        width: 100%;
    }
}

/* ── OVERRIDES PORTO ADMIN CUSTOM STYLE ─────────────── */
/* heading-primary / secondary — remplace orange #e9846b et rouge #ee3d43 */
html .heading-primary,
html .lnk-primary,
html .text-color-primary {
    color: var(--gf-gold) !important;
}

html .heading-secondary,
html .lnk-secondary,
html .text-color-secondary {
    color: var(--gf-dark) !important;
}

html .background-color-secondary {
    background-color: var(--gf-gold) !important;
}

/* Sticky header nav — remplace background #222529 par fond clair */
@media (min-width: 992px) {
    header.page-header.type1.sticky-header .nav-sections {
        background-color: var(--gf-off-white) !important;
    }

    /* Nav level-top dans sticky header — texte dark au lieu de blanc */
    header.page-header.type1.sticky-header .navigation:not(.side-megamenu) .level0 .level-top {
        color: var(--gf-dark) !important;
    }
}


/* ======================================================
   GASOIL FOOTWEAR - HOMEPAGE REDESIGN SS26
   ====================================================== */

/* -- HERO SLIDER ---------------------------------------- */
.gf-hero-slider { position: relative; overflow: hidden; background: var(--gf-warm-grey); }
.gf-hero-slide {
    position: relative; width: 100%; height: 580px;
    background-size: cover; background-position: center; background-repeat: no-repeat;
    display: flex !important; align-items: center;
}
.gf-hero-slide::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(to right, rgba(250,250,248,0.55) 0%, transparent 60%);
    pointer-events: none;
}
.gf-hero-slide.dark::after { background: linear-gradient(to right, rgba(10,10,10,0.55) 0%, transparent 65%); }
.gf-hero-content { position: relative; z-index: 2; padding: 0 80px; max-width: 520px; }
.gf-hero-content--right { margin-left: auto; text-align: right; padding: 0 80px; }
.gf-hero-brand {
    font-family: var(--gf-body) !important; font-size: 10px; font-weight: 500;
    letter-spacing: 0.25em; text-transform: uppercase; color: var(--gf-gold);
    display: block; margin-bottom: 14px;
}
.gf-hero-title {
    font-family: var(--gf-display) !important; font-size: 3.2rem !important;
    font-weight: 400 !important; line-height: 1.1 !important;
    color: var(--gf-dark) !important; margin: 0 0 28px 0 !important; letter-spacing: 0.02em !important;
}
.gf-hero-slide.dark .gf-hero-title { color: #fff !important; }
.gf-hero-btn {
    display: inline-block; font-family: var(--gf-body) !important;
    font-size: 11px !important; font-weight: 500 !important;
    letter-spacing: 0.18em !important; text-transform: uppercase !important;
    color: var(--gf-dark) !important; border-bottom: 1px solid var(--gf-dark);
    padding-bottom: 4px; transition: color 0.25s ease, border-color 0.25s ease;
    text-decoration: none !important;
}
.gf-hero-btn:hover, .gf-hero-btn:focus {
    color: var(--gf-gold) !important; border-color: var(--gf-gold) !important; text-decoration: none !important;
}
.gf-hero-slide.dark .gf-hero-btn { color: #fff !important; border-color: #fff; }
.gf-hero-slide.dark .gf-hero-btn:hover { color: var(--gf-gold) !important; border-color: var(--gf-gold) !important; }
.gf-hero-slider .owl-dots { position: absolute; bottom: 22px; width: 100%; text-align: center; }
.gf-hero-slider .owl-dot span {
    width: 24px !important; height: 2px !important; border-radius: 0 !important;
    background-color: rgba(0,0,0,0.25) !important; margin: 5px 4px !important;
    transition: background-color 0.3s ease, width 0.3s ease !important;
}
.gf-hero-slider .owl-dot.active span { background-color: var(--gf-gold) !important; width: 40px !important; }
@media (max-width: 991px) {
    .gf-hero-slide { height: 440px; }
    .gf-hero-title { font-size: 2.4rem !important; }
    .gf-hero-content, .gf-hero-content--right { padding: 0 40px; }
}
@media (max-width: 575px) {
    .gf-hero-slide { height: 300px; }
    .gf-hero-title { font-size: 1.7rem !important; }
    .gf-hero-content { padding: 0 24px; max-width: 260px; }
    .gf-hero-content--right { padding: 0 24px; }
}

/* -- CATEGORY BANNERS ----------------------------------- */
.gf-cat-banners { padding: 0; margin: 0; }
.gf-cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; }
.gf-cat-item {
    position: relative; display: block; overflow: hidden;
    aspect-ratio: 3/4; text-decoration: none !important;
}
.gf-cat-img {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; object-position: center top;
    transition: transform 0.7s var(--gf-ease); display: block;
}
.gf-cat-item:hover .gf-cat-img { transform: scale(1.05); }
.gf-cat-overlay {
    position: absolute; bottom: 0; left: 0; right: 0; padding: 80px 28px 30px;
    background: linear-gradient(to top, rgba(0,0,0,0.72) 0%, transparent 100%);
    display: flex; flex-direction: column; align-items: flex-start; transition: padding 0.3s ease;
}
.gf-cat-item:hover .gf-cat-overlay { padding-bottom: 36px; }
.gf-cat-label {
    font-family: var(--gf-display) !important; font-size: 1.9rem; font-weight: 400;
    color: #fff !important; letter-spacing: 0.03em; line-height: 1; margin-bottom: 12px; display: block;
}
.gf-cat-cta {
    font-family: var(--gf-body) !important; font-size: 10px; font-weight: 500;
    color: var(--gf-gold-lt) !important; letter-spacing: 0.2em; text-transform: uppercase;
    border-bottom: 1px solid rgba(201,169,110,0.35); padding-bottom: 3px;
    transition: border-color 0.25s ease, color 0.25s ease; display: block;
}
.gf-cat-item:hover .gf-cat-cta { border-color: var(--gf-gold); color: var(--gf-gold) !important; }
@media (max-width: 767px) {
    .gf-cat-grid { grid-template-columns: 1fr; gap: 2px; }
    .gf-cat-item { aspect-ratio: 4/3; }
    .gf-cat-label { font-size: 1.6rem; }
}

/* -- EDITORIAL SPLIT ------------------------------------ */
.gf-editorial-split { display: grid; grid-template-columns: 1fr 1fr; min-height: 500px; margin: 50px 0; }
.gf-editorial-image { position: relative; overflow: hidden; min-height: 460px; }
.gf-editorial-image img {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; object-position: center; display: block; transition: transform 0.8s var(--gf-ease);
}
.gf-editorial-split:hover .gf-editorial-image img { transform: scale(1.03); }
.gf-editorial-text {
    background: var(--gf-warm-grey); display: flex; flex-direction: column;
    justify-content: center; padding: 60px 70px;
}
.gf-editorial-overline {
    font-family: var(--gf-body) !important; font-size: 10px; font-weight: 500;
    letter-spacing: 0.25em; text-transform: uppercase; color: var(--gf-gold); display: block; margin-bottom: 20px;
}
.gf-editorial-text h2 {
    font-family: var(--gf-display) !important; font-size: 2.4rem !important; font-weight: 400 !important;
    line-height: 1.15 !important; color: var(--gf-dark) !important;
    margin: 0 0 20px 0 !important; letter-spacing: 0.03em !important;
}
.gf-editorial-text p {
    font-family: var(--gf-body) !important; font-size: 15px; line-height: 1.85;
    color: var(--gf-mid-grey); margin-bottom: 32px;
}
.gf-editorial-link {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--gf-body) !important; font-size: 11px; font-weight: 500;
    letter-spacing: 0.18em; text-transform: uppercase; color: var(--gf-dark) !important;
    text-decoration: none !important; border-bottom: 1px solid var(--gf-dark);
    padding-bottom: 4px; transition: color 0.25s ease, border-color 0.25s ease;
}
.gf-editorial-link:hover { color: var(--gf-gold) !important; border-color: var(--gf-gold); text-decoration: none !important; }
@media (max-width: 991px) {
    .gf-editorial-split { grid-template-columns: 1fr; margin: 30px 0; }
    .gf-editorial-image { min-height: 320px; }
    .gf-editorial-text { padding: 40px 30px; }
    .gf-editorial-text h2 { font-size: 1.9rem !important; }
}

/* -- BOUTIQUE SECTION ----------------------------------- */
.gf-boutique-section { position: relative; background-color: var(--gf-dark); overflow: hidden; margin: 0; }
.gf-boutique-section.has-photo { background-size: cover; background-position: center; }
.gf-boutique-section.has-photo::before {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(17,17,17,0.88) 0%, rgba(17,17,17,0.55) 100%);
}
.gf-boutique-inner {
    position: relative; z-index: 2; max-width: 1140px; margin: 0 auto; padding: 80px 40px;
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.gf-boutique-overline {
    font-family: var(--gf-body) !important; font-size: 10px; font-weight: 500;
    letter-spacing: 0.25em; text-transform: uppercase; color: var(--gf-gold); display: block; margin-bottom: 18px;
}
.gf-boutique-section h2 {
    font-family: var(--gf-display) !important; font-size: 2.4rem !important; font-weight: 400 !important;
    color: #fff !important; line-height: 1.15 !important; margin: 0 0 18px 0 !important; letter-spacing: 0.03em !important;
}
.gf-boutique-section p {
    font-family: var(--gf-body) !important; font-size: 15px; line-height: 1.85;
    color: rgba(255,255,255,0.65); margin-bottom: 28px;
}
.gf-boutique-info { list-style: none; padding: 0; margin: 0 0 32px 0; }
.gf-boutique-info li {
    font-family: var(--gf-body) !important; font-size: 14px; color: rgba(255,255,255,0.80);
    padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,0.08); display: flex; gap: 10px; line-height: 1.5;
}
.gf-boutique-info li:first-child { border-top: 1px solid rgba(255,255,255,0.08); }
.gf-boutique-info li strong { color: rgba(255,255,255,0.45); font-weight: 400; min-width: 80px; }
.gf-boutique-link {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--gf-body) !important; font-size: 11px; font-weight: 500;
    letter-spacing: 0.18em; text-transform: uppercase; color: var(--gf-gold) !important;
    text-decoration: none !important; border-bottom: 1px solid rgba(201,169,110,0.35);
    padding-bottom: 4px; transition: border-color 0.25s ease;
}
.gf-boutique-link:hover { border-color: var(--gf-gold); text-decoration: none !important; }
.gf-boutique-photo-placeholder {
    background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.10);
    min-height: 320px; display: flex; align-items: center; justify-content: center;
    flex-direction: column; gap: 12px; color: rgba(255,255,255,0.22);
    font-family: var(--gf-body) !important; font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase;
}
.gf-boutique-photo { width: 100%; height: 100%; min-height: 320px; object-fit: cover; object-position: center; display: block; }
@media (max-width: 991px) {
    .gf-boutique-inner { grid-template-columns: 1fr; gap: 36px; padding: 60px 24px; }
    .gf-boutique-section h2 { font-size: 1.9rem !important; }
    .gf-boutique-photo-placeholder { min-height: 200px; }
}
