/*
Theme Name: Boutique URB
Author: OpenAI
Version: 1.4 - Organized CSS
*/

/* =========================================================
   1. BASE & VARIABLES
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&display=swap');

:root {
    /* Colors */
    --color-bg: #000;
    --color-surface: #fff;
    --color-text: #111;
    --color-text-muted: rgba(255, 255, 255, 0.75);
    --color-border: rgba(0, 0, 0, 0.05);
    --color-border-strong: #e5e5e5;
    --color-accent: #d1d1d1;
    
    /* Typography */
    --font-body: Arial, sans-serif;
    --font-display: 'Bebas Neue', Arial, sans-serif;
    
    /* Layout */
    --sidebar-width: 350px;
    --sidebar-width-wide: 500px;
    --mobile-header-height: 90px;
    --mobile-footer-height: 90px;
    --content-max-width: 1400px;
    --content-max-width-wide: 1800px;
    
    /* Transitions */
    --transition-fast: 0.2s ease;
    --transition-base: 0.3s ease;
}

/* Reset & Base */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
    min-height: 100%;
}

body {
    min-height: 100vh;
    font-family: var(--font-body);
    color: var(--color-text);
    background: var(--color-bg);
    overflow: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    display: block;
    max-width: 100%;
    height: auto;
}

/* =========================================================
   2. LAYOUT GLOBAL
   ========================================================= */

.shop-layout {
    display: flex;
    width: 100%;
    min-height: 100vh;
}

.content-panel {
    width: calc(100% - var(--sidebar-width));
    height: 100vh;
    margin-left: var(--sidebar-width);
    overflow-x: hidden;
    overflow-y: auto;
    scroll-behavior: smooth;
}

/* Mobile Layout */
@media (max-width: 768px) {
    body {
        overflow-x: hidden;
        overflow-y: hidden;
    }
    
    .shop-layout {
        flex-direction: column;
    }
    
    .content-panel {
        width: 100%;
        height: 100svh;
        margin-left: 0;
        padding-top: var(--mobile-header-height);
        padding-bottom: calc(var(--mobile-footer-height) + 30px);
        overflow-x: hidden;
        overflow-y: auto;
    }
    
    .content-panel.home-panel {
        height: 100svh;
        padding-top: 0;
        padding-bottom: 0;
        overscroll-behavior-y: contain;
        -webkit-overflow-scrolling: touch;
    }
}

/* Large Screens */
@media (min-width: 2200px) {
    .content-panel {
        width: calc(100% - var(--sidebar-width-wide));
        margin-left: var(--sidebar-width-wide);
    }
}

/* =========================================================
   3. SIDEBAR
   ========================================================= */

/* 3.1 Structure */
.sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 20;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: var(--sidebar-width);
    min-width: var(--sidebar-width);
    height: 100vh;
    color: var(--color-surface);
    background: var(--color-bg);
}

@media (min-width: 2200px) {
    .sidebar {
        width: var(--sidebar-width-wide);
        min-width: var(--sidebar-width-wide);
    }
}

@media (max-width: 768px) {
    .sidebar {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        min-width: 0;
        height: var(--mobile-header-height);
        padding: 0 20px;
        z-index: 100;
        border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }
}

/* 3.2 Branding */
.site-branding {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding-top: 40px;
}

.site-branding a {
    display: inline-block;
}

.site-branding img {
    width: 170px;
}

.season-label {
    margin-top: 14px;
    font-size: 16px;
    letter-spacing: 2px;
    text-transform: uppercase;
    text-align: center;
    opacity: 0.75;
}

@media (min-width: 2200px) {
    .site-branding img {
        width: 200px;
    }
    
    .season-label {
        font-size: 20px;
    }
}

@media (max-width: 768px) {
    .site-branding {
        flex-direction: row;
        width: auto;
        padding-top: 0;
        gap: 12px;
    }
    
    .site-branding img {
        width: 90px;
    }
    
    .season-label {
        display: none;
    }
}

/* 3.3 Navigation Menu */
.burger {
    display: none;
}

.mobile-header-actions {
    display: none;
}

.home-menu {
    display: flex;
    flex: 0 0 auto;
    justify-content: center;
    width: 100%;
    padding-top: 0;
    text-align: center;
}

.sidebar-navigation-stack {
    display: flex;
    flex: 1;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    padding: 42px 0 0;
}

.home-menu ul {
    width: auto;
    margin: 0;
    padding: 0;
    list-style: none;
}

.home-menu li {
    margin: 16px 0;
}

.home-menu a {
    position: relative;
    display: inline-block;
    color: var(--color-surface);
    font-size: 20px;
    font-weight: 500;
}

.home-menu a::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -4px;
    width: 0;
    height: 2px;
    background: var(--color-accent);
    transform: translateX(-50%);
    transition: width var(--transition-base);
}

.home-menu a:hover::after,
.home-menu a.is-active::after {
    width: 100%;
}

.sidebar-secondary-nav {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    width: 100%;
    margin-top: auto;
    margin-bottom: auto;
    padding: 0 24px;
}

.sidebar-secondary-nav__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgb(255, 255, 255);
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.01em;
    transition: color var(--transition-base), opacity var(--transition-base);
}

.sidebar-secondary-nav__link:hover {
    color: #fff;
}

.sidebar-secondary-nav__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    width: 240px;
    max-width: 100%;
    padding: 0 22px;
    color: #111;
    background: #000000;
    border: 1px solid #ffffff;
    color: #ffffff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.sidebar-secondary-nav__button:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.92);
    color : rgb(0, 0, 0);
}

@media (min-width: 2200px) {
    .home-menu a {
        font-size: 25px;
    }
}

@media (max-width: 768px) {
    .burger {
        z-index: 110;
        display: flex;
        flex-direction: column;
        gap: 5px;
        padding: 8px;
        cursor: pointer;
    }
    
    .burger span {
        display: block;
        width: 26px;
        height: 2px;
        background: var(--color-surface);
        border-radius: 2px;
        transform-origin: center;
        transition: transform var(--transition-base), opacity var(--transition-base);
    }

    .mobile-header-actions {
        display: flex;
        align-items: center;
        gap: 16px;
        margin-left: auto;
        margin-right: 8px;
    }

    .mobile-header-link {
        position: relative;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        color: var(--color-surface);
        font-size: 22px;
    }

    .mobile-header-count {
        position: absolute;
        top: -4px;
        right: -8px;
        min-width: 18px;
        height: 18px;
        padding: 0 5px;
        font-size: 11px;
    }
    
    .burger.is-open span:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }
    
    .burger.is-open span:nth-child(2) {
        opacity: 0;
        transform: scaleX(0);
    }
    
    .burger.is-open span:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }
    
    .sidebar-navigation-stack {
        position: fixed;
        top: calc(var(--mobile-header-height) + 10px);
        right: 12px;
        display: grid;
        gap: 18px;
        width: min(280px, calc(100vw - 24px));
        padding: 18px 16px;
        background: rgba(10, 10, 10, 0.96);
        border: 1px solid rgba(255, 255, 255, 0.12);
        border-radius: 18px;
        box-shadow: 0 18px 40px rgba(0, 0, 0, 0.28);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transform: translateY(-8px);
        transition: opacity var(--transition-base), transform var(--transition-base), visibility var(--transition-base);
        z-index: 105;
    }

    .sidebar-navigation-stack.is-open {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateY(0);
    }

    .home-menu {
        display: block;
        width: 100%;
        padding-top: 0;
        text-align: left;
    }

    .home-menu ul {
        display: grid;
        gap: 12px;
        width: 100%;
    }

    .home-menu li {
        margin: 0;
    }

    .home-menu a {
        font-size: 18px;
        font-weight: 600;
    }

    .sidebar-secondary-nav {
        display: grid;
        justify-items: stretch;
        gap: 10px;
        margin: 0;
        padding: 16px 0 0;
        border-top: 1px solid rgba(255, 255, 255, 0.12);
    }

    .sidebar-secondary-nav__button {
        width: 100%;
    }
}

/* 3.4 Sidebar Footer */
.sidebar-footer {
    width: 100%;
    padding: 20px 24px 30px;
}

.footer-links {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.footer-links a,
.footer-socials a {
    opacity: 0.7;
    transition: opacity var(--transition-base), transform var(--transition-base);
}

.footer-links a {
    font-size: 16px;
    text-align: center;
}

.footer-links__group {
    position: relative;
}

.footer-links__group summary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    list-style: none;
    opacity: 0.7;
    transition: opacity var(--transition-base);
    font-size: 16px;

}

.footer-links__group summary::-webkit-details-marker {
    display: none;
}

.footer-links__group[open] summary,
.footer-links__group summary:hover {
    opacity: 1;
}

.footer-links__submenu {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 12px);
    display: grid;
    gap: 8px;
    min-width: 220px;
    padding: 14px 16px;
    background: rgba(8, 8, 8, 0.96);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
    transform: translateX(-50%);
}

.footer-links__submenu a {
    font-size: 16px;
    text-align: center;
}

.footer-socials {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    width: 100%;
    margin-top: 20px;
}

.footer-socials a {
    font-size: 25px;
}

.footer-links a:hover,
.footer-socials a:hover {
    opacity: 1;
}

.footer-socials a:hover {
    transform: translateY(-2px);
}

@media (min-width: 2200px) {
    .footer-links a {
        font-size: 20px;
    }
    
    .footer-socials a {
        font-size: 24px;
    }
}

@media (max-width: 768px) {
    .sidebar .sidebar-footer {
        display: none;
    }
}

/* =========================================================
   4. HOME PAGE - HERO SECTIONS
   ========================================================= */

/* 4.1 Base Panel Structure */
.hero-noise-filter {
    position: absolute;
    width: 0;
    height: 0;
}

.home-panel {
    scroll-snap-type: y mandatory;
}

.panel {
    position: relative;
    width: 100%;
    min-height: 100vh;
    scroll-snap-align: start;
}

.panel-bg {
    position: absolute;
    inset: 0;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.panel-bg--mobile {
    display: none;
}

.panel-bg--desktop {
    display: block;
}

.panel-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.1);
}

.panel-content {
    position: relative;
    z-index: 2;
    display: flex;
    height: 100%;
    min-height: 100vh;
    padding: 60px;
    color: var(--color-surface);
}

@media (max-width: 768px) {
    .panel-bg--mobile {
        display: block;
    }
    
    .panel-bg--desktop {
        display: none;
    }
    
    .home-panel .panel {
        scroll-snap-stop: always;
        min-height: 100svh;
    }
    
    .home-panel .panel-content {
        height: 100svh;
        min-height: 100svh;
        padding-top: calc(var(--mobile-header-height) + 28px);
    }
}

/* 4.2 Panel 1 - Hero */
.panel-content-1 {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 90px;
    padding: 120px 40px;
    text-align: center;
}

.panel-1-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
}

.panel-1-title {
    width: 100%;
    margin: 0 0 120px;
    font-family: var(--font-display);
    color: var(--color-surface);
    font-size: clamp(48px, 6vw, 180px);
    line-height: 1;
    letter-spacing: 0.06em;
    text-align: center;
    text-transform: uppercase;
    -webkit-text-stroke: 0.5px rgba(255, 255, 255, 0.6);
    filter: url(#grunge);
    opacity: 0.95;
}

.panel-1-text {
    width: 100%;
    margin: 0;
    font-family: var(--font-display);
    color: var(--color-surface);
    font-size: clamp(80px, 12vw, 320px);
    line-height: 0.9;
    letter-spacing: 0.03em;
    text-align: center;
    text-transform: uppercase;
    -webkit-text-stroke: 2px rgba(255, 255, 255, 0.6);
    filter: url(#grunge);
    mix-blend-mode: hard-light;
    opacity: 0.95;
}

@media (max-width: 768px) {
    .panel-content-1 {
        justify-content: space-between;
        align-items: center;
        gap: 32px;
        padding: 28px 24px 120px;
        text-align: center;
    }
    
    .panel-1-content {
        width: 100%;
        padding-inline: 6px;
    }
    
    .panel-1-title {
        margin: 0 0 32px;
        font-size: clamp(52px, 16vw, 88px);
        line-height: 0.92;
        letter-spacing: 0.04em;
    }
    
    .panel-1-text {
        font-size: clamp(72px, 22vw, 128px);
        line-height: 0.88;
    }
}

/* 4.3 Panel 2 - Pack Kid */
.panel-content-2 {
    align-items: top;
    justify-content: flex-start;
    padding-left: 120px;
}

.panel-2-content {
    max-width: 500px;
    color: var(--color-surface);
}

.panel-2-title {
    margin: 0 0 20px;
    font-family: var(--font-display);
    color: var(--color-surface);
    font-size: clamp(60px, 8vw, 140px);
    line-height: 0.9;
    text-transform: uppercase;
}

.panel-2-text,
.panel-2-text2 {
    font-size: 20px;
    line-height: 1.5;
    opacity: 0.9;
}

.panel-2-text {
    margin: 0 0 30px;
    max-width: 400px;
}

.panel-2-text2 {
    margin: 0 0 30px;
    max-width: 260px;
}

.panel-2-button {
    display: inline-block;
    padding: 14px 28px;
    color: var(--color-bg);
    background: var(--color-surface);
    border-radius: 3px;
    font-size: 16px;
    font-weight: 600;
    transition: background var(--transition-fast), color var(--transition-fast);
}

.panel-2-button:hover {
    color: var(--color-bg);
    background: var(--color-accent);
}

@media (max-width: 768px) {
    .panel-content-2 {
        align-items: flex-start;
        justify-content: flex-end;
        padding: 28px 20px 36px;
    }
    
    .panel-2-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }
    
    .panel-2-title {
        width: auto;
        margin-bottom: 14px;
        font-size: clamp(44px, 13vw, 72px);
    }
    
    .panel-2-text,
    .panel-2-text2 {
        width: 100%;
        max-width: 240px;
        font-size: 16px;
        line-height: 1.45;
    }
    
    .panel-2-text2 {
        width: 200px;
        padding-top: 0;
        padding-bottom: 0;
        margin-bottom: 18px;
    }
    
    .panel-2-button {
        padding: 12px 20px;
        font-size: 15px;
    }
}

/* 4.4 Panel 3 - Maillots */
.panel-content-3 {
    align-items: top;
    justify-content: flex-start;
    padding-left: 120px;
}

.panel-3-content {
    max-width: 500px;
    color: var(--color-surface);
}

.panel-3-title {
    margin: 0 0 20px;
    font-family: var(--font-display);
    color: var(--color-surface);
    font-size: clamp(60px, 8vw, 140px);
    line-height: 0.9;
    text-transform: uppercase;
}

.panel-3-text,
.panel-3-text2 {
    max-width: 500px;
    font-size: 20px;
    line-height: 1.5;
    opacity: 0.9;
}

.panel-3-text {
    margin: 0 0 30px;
}

.panel-3-text2 {
    margin: 0 0 30px;
}

.panel-3-button {
    display: inline-block;
    padding: 14px 28px;
    color: var(--color-bg);
    background: var(--color-surface);
    border-radius: 3px;
    font-size: 16px;
    font-weight: 600;
    transition: background var(--transition-fast), color var(--transition-fast);
}

.panel-3-button:hover {
    color: var(--color-bg);
    background: var(--color-accent);
}

@media (max-width: 768px) {
    .panel-content-3 {
        align-items: flex-start;
        justify-content: flex-end;
        padding: 28px 20px 36px;
    }
    
    .panel-3-content {
        width: 100%;
        max-width: none;
        padding: 0;
    }
    
    .panel-3-title {
        width: auto;
        margin-bottom: 14px;
        font-size: clamp(44px, 13vw, 72px);
    }
    
    .panel-3-text,
    .panel-3-text2 {
        width: 100%;
        max-width: 240px;
        font-size: 16px;
        line-height: 1.45;
    }
    
    .panel-3-text2 {
        width: 200px;
        padding-top: 0;
        padding-bottom: 0;
        margin-bottom: 18px;
    }
    
    .panel-3-button {
        padding: 12px 20px;
        font-size: 15px;
    }
}

/* 4.5 Navigation Elements */
.scroll-indicator {
    position: absolute;
    bottom: 40px;
    left: 50%;
    color: var(--color-surface);
    cursor: pointer;
    opacity: 0.8;
    transform: translateX(-50%);
}

.scroll-bounce {
    animation: scroll-bounce 1.4s infinite ease-in-out;
}

.scroll-arrow {
    width: 20px;
    height: 20px;
    border-right: 4px solid var(--color-surface);
    border-bottom: 4px solid var(--color-surface);
    transform: rotate(45deg);
}

.section-nav {
    position: fixed;
    top: 50%;
    right: 30px;
    z-index: 50;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transform: translateY(-50%);
}

.dot {
    width: 8px;
    height: 8px;
    padding: 0;
    background: rgba(255, 255, 255, 0.4);
    border: 0;
    border-radius: 50%;
    cursor: pointer;
    transition: transform var(--transition-base), background var(--transition-base);
}

.dot:hover,
.dot.active {
    background: var(--color-surface);
}

.dot.active {
    transform: scale(1.4);
}

@media (max-width: 768px) {
    .section-nav {
        display: none;
    }
    
    .scroll-indicator {
        bottom: 130px;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 54px;
        height: 54px;
        background: rgba(0, 0, 0, 0.28);
        border: 1px solid rgba(255, 255, 255, 0.25);
        border-radius: 999px;
        backdrop-filter: blur(6px);
    }
    
    .scroll-arrow {
        width: 16px;
        height: 16px;
        border-right-width: 3px;
        border-bottom-width: 3px;
    }
}

/* =========================================================
   5. CATEGORY / SHOP PAGES
   ========================================================= */

/* 5.1 Layout & Header */
.category-panel,
.page-panel {
    background: #f3f3f3;
    scroll-snap-type: none;
}

.category-header-bar {
    position: sticky;
    top: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 30px 80px;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border-strong);
}

.category-header-bar h1,
.shop-category-header h1 {
    margin: 0;
    color: var(--color-text);
    font-size: 35px;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.category-header-actions {
    display: flex;
    align-items: center;
    gap: 24px;
}

.header-cart,
.header-account {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--color-text);
    font-size: 20px;
    transition: opacity var(--transition-fast);
}

.header-cart:hover,
.header-account:hover {
    opacity: 0.7;
}

.header-cart i,
.header-account i {
    font-size: 20px;
}

.cart-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    color: var(--color-surface);
    background: var(--color-text);
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
}

.shop-category-content {
    min-height: calc(100vh - 127px);
    padding: 50px 40px 80px;
}

.shop-category-inner,
.shop-category-header {
    width: 100%;
    max-width: var(--content-max-width);
    margin: 0 auto;
}

.shop-category-header {
    text-align: center;
}

.shop-category-content.is-contact-page {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 56px 40px;
    background:
        linear-gradient(135deg, rgba(6, 6, 8, 0.68), rgba(6, 6, 8, 0.34)),
        url("images/contact.webp") center center / cover no-repeat;
}

.content-panel.page-panel.is-contact-panel {
    background: #090909;
}

.shop-category-inner.is-contact-card {
    position: relative;
    width: min(100%, 760px);
    margin: 0 auto;
    padding: 42px 40px;
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 28px;
    box-shadow: 0 28px 80px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(5px) saturate(1.5);
    -webkit-backdrop-filter: blur(5px) saturate(1.5);
}

.shop-category-inner.is-contact-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 28px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    pointer-events: none;
}

.shop-category-content.is-contact-page .shop-category-header {
    max-width: none;
    margin-bottom: 28px;
    text-align: center;
}

.shop-category-content.is-contact-page .shop-category-header h1 {
    color: #fff;
    font-size: clamp(40px, 4vw, 58px);
    font-weight: 700;
    letter-spacing: -0.04em;
    text-shadow: 0 10px 28px rgba(0, 0, 0, 0.28);
}

.shop-category-inner.is-contact-card > :last-child {
    margin-bottom: 0;
}

.shop-category-content.is-contact-page .entry-content,
.shop-category-content.is-contact-page .wpcf7 {
    width: 100%;
}

.shop-category-content.is-contact-page form,
.shop-category-content.is-contact-page .wpcf7-form {
    display: grid;
    gap: 18px;
}

.shop-category-content.is-contact-page form p,
.shop-category-content.is-contact-page .wpcf7-form p {
    margin: 0;
}

.shop-category-content.is-contact-page label,
.shop-category-content.is-contact-page .wpcf7-form label {
    display: grid;
    gap: 8px;
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.shop-category-content.is-contact-page label.is-placeholder-label,
.shop-category-content.is-contact-page .wpcf7-form label.is-placeholder-label {
    display: block;
    font-size: 0;
    line-height: 0;
    color: transparent;
}

.shop-category-content.is-contact-page label.is-placeholder-label > .wpcf7-form-control-wrap,
.shop-category-content.is-contact-page .wpcf7-form label.is-placeholder-label > .wpcf7-form-control-wrap,
.shop-category-content.is-contact-page label.is-placeholder-label > input,
.shop-category-content.is-contact-page label.is-placeholder-label > textarea {
    display: block;
}

.shop-category-content.is-contact-page input[type="text"],
.shop-category-content.is-contact-page input[type="email"],
.shop-category-content.is-contact-page input[type="tel"],
.shop-category-content.is-contact-page input[type="url"],
.shop-category-content.is-contact-page textarea,
.shop-category-content.is-contact-page .wpcf7-text,
.shop-category-content.is-contact-page .wpcf7-email,
.shop-category-content.is-contact-page .wpcf7-textarea {
    width: 100%;
    min-height: 56px;
    padding: 14px 18px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 16px;
    line-height: 1.4;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: border-color var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);
}

.shop-category-content.is-contact-page textarea,
.shop-category-content.is-contact-page .wpcf7-textarea {
    min-height: 180px;
    resize: vertical;
}

.shop-category-content.is-contact-page input::placeholder,
.shop-category-content.is-contact-page textarea::placeholder {
    color: rgba(255, 255, 255, 0.877);
}

.shop-category-content.is-contact-page input:focus,
.shop-category-content.is-contact-page textarea:focus,
.shop-category-content.is-contact-page .wpcf7-text:focus,
.shop-category-content.is-contact-page .wpcf7-email:focus,
.shop-category-content.is-contact-page .wpcf7-textarea:focus {
    outline: none;
    border-color: rgba(255, 255, 255, 0.72);
    background: rgba(255, 255, 255, 0.18);
    box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.12);
}

.shop-category-content.is-contact-page input[type="submit"],
.shop-category-content.is-contact-page button[type="submit"],
.shop-category-content.is-contact-page .wpcf7-submit {
    justify-self: start;
    min-height: 50px;
    padding: 0 22px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    background: #fff;
    color: #111;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: transform var(--transition-fast), background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.shop-category-content.is-contact-page input[type="submit"]:hover,
.shop-category-content.is-contact-page button[type="submit"]:hover,
.shop-category-content.is-contact-page .wpcf7-submit:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.863);
    color: #000000;
    border-color: rgba(255, 255, 255, 0.34);
}

.shop-category-content.is-contact-page .wpcf7-response-output,
.shop-category-content.is-contact-page .wpcf7-not-valid-tip {
    color: #fff;
}

.boutique-physique-panel {
    background: rgb(255, 255, 255);
}

.boutique-physique-page {
    padding: 48px 40px 88px;
}

.boutique-physique-page__inner {
    display: grid;
    gap: 30px;
}

.boutique-physique-page__hero {
    width: 100%;
    max-width: 1000px;
    padding: 42px 44px;
    background: white;
    border: 1px solid rgba(17, 17, 17, 0.08);
    text-align: left;
    box-shadow: 0 20px 50px rgba(17, 17, 17, 0.08);
}

.boutique-physique-page__hero-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 440px);
    align-items: start;
    gap: 28px;
}

.boutique-physique-page__hero-copy {
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 16px;
    min-height: 100%;
}

.boutique-physique-page__hero-media {
    justify-self: end;
    width: 100%;
}

.boutique-physique-page__hero-media img {
    width: 100%;
    height: auto;
    border: 1px solid rgba(17, 17, 17, 0.08);
}

.boutique-physique-page__eyebrow {
    margin: 0 0 12px;
    color: rgba(17, 17, 17, 0.56);
    font-size: 26px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.boutique-physique-page__hero h1 {
    margin-bottom: 12px;
    font-size: 35px;
    line-height: 0.96;
    letter-spacing: -0.05em;
}

.boutique-physique-page__intro {
    max-width: 60ch;
    margin: 0;
    align-self: stretch;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(17, 17, 17, 0.7);
    font-size: 18px;
    line-height: 1.7;
    text-align: justify;
}

.boutique-physique-page__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 46px;
    justify-self: center;
    margin-top: 12px;
    padding: 0 18px;
    border: 1px solid #111;
    background: #fff;
    color: #111;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.04em;
    transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}

.boutique-physique-page__cta:hover {
    background: #111;
    color: #fff;
    transform: translateY(-1px);
}

.boutique-physique-page__grid {
    display: grid;
    gap: 26px;
}

.boutique-physique-card {
    display: grid;
    grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.1fr);
    min-height: 420px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(17, 17, 17, 0.08);
    overflow: hidden;
    box-shadow: 0 18px 50px rgba(17, 17, 17, 0.08);
}

.boutique-physique-card--snack {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
    min-height: 0;
}

.boutique-physique-card__menu-panel {
    display: grid;
    align-content: start;
    padding: 20px 20px 18px;
    background: rgba(255, 255, 255, 0.56);
}

.boutique-physique-card__media {
    min-height: 100%;
    background-size: cover;
    background-position: center;
}

.boutique-physique-card__media--shop {
    background-image:
        linear-gradient(180deg, rgba(10, 10, 10, 0.08), rgba(10, 10, 10, 0.22)),
        url("images/boutique.webp");
}

.boutique-physique-card__content {
    display: grid;
    align-content: center;
    gap: 18px;
    padding: 38px 40px;
}

.boutique-physique-card__kicker {
    margin: 0;
    color: rgba(17, 17, 17, 0.48);
    font-size: 26px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.boutique-physique-card__content h2 {
    margin: 0;
    font-size: 38px;
    line-height: 1;
    letter-spacing: -0.04em;
}

.boutique-physique-card__content p {
    margin: 0;
    color: rgba(17, 17, 17, 0.72);
    line-height: 1.75;
}

.boutique-physique-list,
.boutique-physique-menu__list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.boutique-physique-list {
    display: grid;
    gap: 10px;
}

.boutique-physique-list li {
    position: relative;
    padding-left: 18px;
    color: #111;
    font-weight: 500;
}

.boutique-physique-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 5px;
    width: 8px;
    height: 8px;
    background: #111;
    border-radius: 999px;
}

.boutique-physique-menu {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.boutique-physique-menu__section {
    padding: 14px 16px;
    background: #f6f2ea;
    border: 1px solid rgba(17, 17, 17, 0.06);
}

.boutique-physique-menu__section h3 {
    margin: 0 0 14px;
    font-size: 15px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.boutique-physique-menu__list {
    display: grid;
    gap: 10px;
}

.boutique-physique-menu__list li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    color: rgba(17, 17, 17, 0.74);
}

.boutique-physique-menu__list strong {
    color: #111;
    font-size: 14px;
}

.category-description {
    margin: 16px 0 0;
    color: rgba(17, 17, 17, 0.75);
    font-size: 18px;
}

@media (min-width: 2200px) {
    .category-header-bar {
        padding: 24px 60px;
    }
    
    .category-header-bar h1 {
        font-size: 32px;
    }
    
    .shop-category-content {
        padding: 60px 60px 100px;
    }
    
    .shop-category-inner,
    .shop-category-header {
        max-width: var(--content-max-width-wide);
    }
}

@media (max-width: 768px) {
    .content-panel.category-panel {
        padding-top: var(--mobile-header-height);
    }

    .content-panel.page-panel {
        padding-top: var(--mobile-header-height);
    }

    .page-panel .shop-category-content {
        padding-top: 16px;
    }

    .product-page__actions,
    .category-header-bar .category-header-actions {
        display: none;
    }

    .category-header-bar {
        top: 0;
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
        padding: 20px;
        margin-bottom: 12px;
    }
    
    .category-header-bar h1,
    .shop-category-header h1 {
        font-size: 28px;
    }
    
    .category-header-actions {
        gap: 18px;
        flex-wrap: wrap;
    }
    
    .header-cart,
    .header-account {
        font-size: 18px;
    }
    
    .shop-category-content {
        min-height: auto;
        padding: 0 20px 40px;
    }

    .shop-category-content.is-contact-page {
        min-height: calc(100svh - var(--mobile-footer-height));
        padding: 28px 16px calc(var(--mobile-footer-height) + 28px);
        align-items: flex-start;
        background-position: center top;
    }

    .shop-category-inner.is-contact-card {
        width: min(100%, 560px);
        padding: 24px 18px;
        border-radius: 24px;
    }

    .shop-category-content.is-contact-page .shop-category-header {
        margin-bottom: 18px;
        padding-top: 4px;
    }

    .shop-category-content.is-contact-page .shop-category-header h1 {
        font-size: clamp(28px, 8vw, 34px);
        line-height: 1.05;
        letter-spacing: -0.05em;
    }

    .shop-category-content.is-contact-page form,
    .shop-category-content.is-contact-page .wpcf7-form {
        gap: 14px;
    }

    .shop-category-content.is-contact-page input[type="text"],
    .shop-category-content.is-contact-page input[type="email"],
    .shop-category-content.is-contact-page input[type="tel"],
    .shop-category-content.is-contact-page input[type="url"],
    .shop-category-content.is-contact-page textarea,
    .shop-category-content.is-contact-page .wpcf7-text,
    .shop-category-content.is-contact-page .wpcf7-email,
    .shop-category-content.is-contact-page .wpcf7-textarea {
        min-height: 52px;
        padding: 13px 16px;
        border-radius: 14px;
    }

    .shop-category-content.is-contact-page textarea,
    .shop-category-content.is-contact-page .wpcf7-textarea {
        min-height: 160px;
    }

    .shop-category-content.is-contact-page input[type="submit"],
    .shop-category-content.is-contact-page button[type="submit"],
    .shop-category-content.is-contact-page .wpcf7-submit {
        width: 100%;
        justify-self: stretch;
    }

    .boutique-physique-page {
        padding: 24px 20px 40px;
    }

    .boutique-physique-page__hero {
        padding: 28px 24px;
    }

    .boutique-physique-page__hero-main {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .boutique-physique-page__hero-media {
        display: none;
    }

    .boutique-physique-page__hero h1 {
        font-size: 28px;
    }

    .boutique-physique-page__intro {
        font-size: 16px;
    }

    .boutique-physique-card,
    .boutique-physique-card--snack {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .boutique-physique-card__media {
        min-height: 220px;
    }

    .boutique-physique-card__content {
        padding: 28px 24px;
    }

    .boutique-physique-card__content h2 {
        font-size: 30px;
    }

    .boutique-physique-menu {
        grid-template-columns: 1fr;
    }

    .boutique-physique-page__cta {
        width: fit-content;
        min-width: 0;
        margin-top: 22px;
    }
}

/* 5.2 Product Grid */
.category-panel ul.products {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 24px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.category-panel ul.products::before,
.category-panel ul.products::after {
    display: none;
    content: none;
}

.category-panel ul.products li.product {
    width: 100%;
    margin: 0;
    float: none;
}

@media (min-width: 2200px) {
    .category-panel ul.products {
        grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
        gap: 40px;
    }
}

@media (max-width: 768px) {
    .category-panel ul.products {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .category-panel ul.products li.product,
    .category-panel ul.products li.urb-product-card {
        width: 100% !important;
        max-width: none;
        margin: 0 !important;
    }
}

/* 5.3 Product Card */
.urb-product-card {
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.urb-product-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.08);
    border-color: rgba(0, 0, 0, 0.14);
}

.urb-product-card__image {
    display: block;
    padding: 18px;
    background: #ffffff;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.urb-product-card__image img {
    width: 100%;
    height: 240px;
    object-fit: contain;
    object-position: center;
    transition: transform 0.25s ease;
}

.urb-product-card:hover .urb-product-card__image img {
    transform: scale(1.03);
}

.urb-product-card__content {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 16px 14px 18px;
    background: #fff;
}

.urb-product-card__title {
    margin: 0;
    color: #111;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.3;
    text-align: center;
    text-transform: uppercase;
}

.urb-product-card__price {
    color: rgba(17, 17, 17, 0.8);
    font-size: 15px;
    font-weight: 500;
    text-align: center;
}

.urb-product-card__price .amount {
    color: #111;
    font-weight: 600;
}

@media (min-width: 2200px) {
    .urb-product-card__image img {
        height: 400px;
    }
    
    .urb-product-card__title,
    .urb-product-card__price {
        font-size: 20px;
    }
}

@media (max-width: 768px) {
    .urb-product-card__image img {
        height: 240px;
    }
}

/* =========================================================
   6. SINGLE PRODUCT PAGE
   ========================================================= */

/* 6.1 Layout Structure */
.product-panel {
    background: #f3f3f3;
}

.product-page {
    min-height: 100vh;
    padding: 32px 40px 60px;
    background: #f3f3f3;
}

.product-page__inner {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
}

.product-page__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
    margin-bottom: 24px;
}

.product-page__breadcrumb,
.product-page__breadcrumb a,
.woocommerce-breadcrumb,
.woocommerce-breadcrumb a {
    color: rgba(17, 17, 17, 0.7);
    font-size: 14px;
}

.product-page__actions {
    gap: 18px;
}

.urb-single-product {
    display: grid;
    grid-template-columns: minmax(420px, 760px) minmax(320px, 1fr);
    gap: 48px;
    align-items: start;
}

.urb-single-product__main-column,
.urb-single-product__aside-column,
.urb-single-product__gallery,
.urb-single-product__summary,
.product-info-card--description {
    min-width: 0;
}

.urb-single-product__main-column,
.urb-single-product__aside-column {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.urb-single-product__main-column {
    grid-column: 1;
}

.urb-single-product__aside-column {
    grid-column: 2;
}

.product-info-card--description-mobile {
    display: none;
}

@media (max-width: 1200px) {
    .urb-single-product {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    
    .urb-single-product__summary {
        position: static;
    }
}

@media (max-width: 768px) {
    .urb-single-product {
        display: flex;
        flex-direction: column;
        gap: 20px;
    }

    .urb-single-product__main-column,
    .urb-single-product__aside-column {
        display: flex;
    }

    .urb-single-product__gallery {
        order: 1;
    }

    .urb-single-product__summary {
        order: 2;
    }

    .product-info-card--description {
        order: 3;
    }

    .product-info-card--description-desktop {
        display: none;
    }

    .product-info-card--description-mobile {
        display: block;
    }

    .product-page {
        padding: 24px 20px 40px;
    }

    .product-page__top {
        align-items: flex-start;
    }

    .product-page__actions {
        width: 100%;
    }
}

/* 6.2 Gallery */
.urb-single-product__gallery {
    background: #fff;
    padding: 24px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    min-height: auto;
}

.urb-single-product__gallery .woocommerce-product-gallery {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

.urb-single-product__gallery .flex-viewport {
    background: #fff;
    margin-bottom: 28px;
}

.urb-single-product__gallery .woocommerce-product-gallery__wrapper {
    width: 100%;
}

.urb-single-product__gallery .woocommerce-product-gallery__image {
    text-align: center;
}

.urb-single-product__gallery .woocommerce-product-gallery__image a {
    display: block;
    width: 100%;
    text-align: center;
}

.urb-single-product__gallery .woocommerce-product-gallery__image img {
    display: inline-block;
    width: auto;
    max-width: 360px;
    height: auto;
    margin: 0 auto;
    object-fit: contain;
}

/* Thumbnails */
.urb-single-product__gallery .flex-control-thumbs {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 16px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.urb-single-product__gallery .flex-control-thumbs li {
    width: 74px !important;
    margin: 0 !important;
    float: none !important;
    flex: 0 0 74px;
}

.urb-single-product__gallery .flex-control-thumbs li img {
    display: block;
    width: 100%;
    height: auto;
    border: 1px solid transparent;
    border-radius: 6px;
    opacity: 0.78;
    transition: opacity 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.urb-single-product__gallery .flex-control-thumbs li img:hover,
.urb-single-product__gallery .flex-control-thumbs li img.flex-active {
    opacity: 1;
    border-color: #bdbdbd;
    transform: translateY(-1px);
}

@media (max-width: 768px) {
    .urb-single-product__gallery {
        padding: 20px;
    }
    
    .urb-single-product__gallery .woocommerce-product-gallery__image img {
        max-width: 280px;
    }

    .urb-single-product__gallery .flex-control-thumbs {
        flex-wrap: wrap;
        justify-content: center;
        gap: 12px;
    }
    
    .urb-single-product__gallery .flex-control-thumbs li {
        width: calc((100% - 24px) / 3) !important;
        max-width: 72px;
        flex: 0 0 calc((100% - 24px) / 3);
    }
    
    .urb-single-product__gallery .woocommerce-product-gallery__trigger {
        width: 46px;
        height: 46px;
    }
}

/* 6.3 Summary (Product Info) */
.urb-single-product__summary {
    position: sticky;
    top: 30px;
}

.urb-single-product__summary-inner {
    background: #fff;
    padding: 32px;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.urb-single-product__summary .product_title {
    margin: 0 0 14px;
    color: #111;
    font-size: 42px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.urb-single-product__summary .price {
    margin: 0 0 24px;
    color: #a79200;
    font-size: 28px;
    font-weight: 700;
}

.woocommerce-Price-amount {
    color: #a79200 !important;
    font-size: 28px;
}

.urb-product-card__content .woocommerce-Price-amount {
    color: #000000 !important;
    font-size: 16px;
}

.urb-single-product__short-description {
    margin-bottom: 24px;
    color: rgba(17, 17, 17, 0.78);
    font-size: 16px;
    line-height: 1.6;
}

/* Cart Form */
.urb-single-product__summary form.cart {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.urb-single-product__summary form.cart:not(.variations_form) {
    flex-direction: row;
    align-items: flex-end;
    flex-wrap: wrap;
}

.urb-single-product__summary .variations {
    width: 100%;
    margin: 0;
    border-collapse: collapse;
}

.urb-single-product__summary .variations td,
.urb-single-product__summary .variations th {
    padding: 0 0 8px;
    vertical-align: middle;
}

.urb-single-product__summary .variations label {
    color: #111;
    font-size: 15px;
    font-weight: 600;
}

.urb-single-product__summary select {
    width: 100%;
    height: 50px;
    padding: 0 14px;
    border: 1px solid rgba(0, 0, 0, 0.14);
    background: #fff;
    color: #111;
    font-size: 15px;
}

.urb-single-product__summary select option:disabled {
    color: #8f8f8f;
    background: #f2f2f2;
}

.urb-single-product__summary .reset_variations,
.urb-single-product__summary a.reset_variations,
.urb-single-product__summary .reset_variations[style] {
    display: none !important;
}

.urb-custom-fields {
    margin-top: 4px;
}

.urb-single-product__summary .single_variation_wrap {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.urb-single-product__summary .woocommerce-variation-price {
    color: #111;
    font-weight: 700;
}

.urb-single-product__summary .woocommerce-variation-availability,
.urb-single-product__summary .woocommerce-variation-availability p,
.urb-single-product__summary p.stock {
    margin: 0 0 12px;
}

.urb-single-product__summary .quantity {
    display: inline-flex;
    align-items: center;
    height: 50px;
}

.urb-single-product__summary .quantity input.qty {
    width: 78px;
    height: 100%;
    border: 1px solid rgba(0, 0, 0, 0.14);
    text-align: center;
    font-size: 16px;
    background: #fff;
    color: #111;
}

.urb-single-product__summary .single_add_to_cart_button.button {
    height: 50px;
    padding: 0 26px;
    background: #000000 !important;
    color: #fff !important;
    border: 0;
    border-radius: 0;
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    box-shadow: none;
}

.urb-single-product__summary form.cart:not(.variations_form) .single_add_to_cart_button.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: auto;
    min-width: 210px;
    margin: 0;
}

.urb-single-product__summary .single_add_to_cart_button.button:hover {
    background: #222 !important;
    color: #fff !important;
}

.urb-single-product__summary .product_meta {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    color: rgba(17, 17, 17, 0.7);
    font-size: 14px;
    line-height: 1.7;
}

.urb-single-product__summary .product_meta a {
    color: #111;
}

@media (max-width: 768px) {
    .urb-single-product__summary-inner {
        padding: 20px;
    }
    
    .urb-single-product__summary .product_title {
        font-size: 32px;
    }
    
    .urb-single-product__summary .price {
        font-size: 24px;
    }
}

.product-info-card {
    background: #fff;
    padding: 28px;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.product-info-card h2,
.product-info-card h3 {
    margin: 0 0 14px;
    color: #111;
    font-size: 24px;
    font-weight: 700;
}

.product-info-card p,
.product-info-card li,
.product-info-card__content {
    color: rgba(17, 17, 17, 0.8);
    font-size: 16px;
    line-height: 1.7;
}

.product-info-card__content::after {
    content: "";
    display: block;
    clear: both;
}

.product-info-card__content p {
    margin: 0 0 1.2em;
}

.product-info-card__content img {
    display: block;
    max-width: 100%;
    height: auto;
}

.product-info-card__content .alignleft {
    float: left;
    display: inline;
    margin: 0.2em 1.5em 1em 0;
}

.product-info-card__content .alignright {
    float: right;
    display: inline;
    margin: 0.2em 0 1em 1.5em;
}

.product-info-card__content .aligncenter {
    display: block;
    margin: 0 auto 1.5em;
}

.product-info-card__content .wp-caption,
.product-info-card__content .wp-block-image {
    max-width: 100%;
    margin-bottom: 1.5em;
}

.product-info-card__content .wp-caption img,
.product-info-card__content .wp-block-image img {
    display: block;
}

.product-info-card__content .wp-caption-text,
.product-info-card__content figcaption {
    margin-top: 0.6em;
    color: rgba(17, 17, 17, 0.62);
    font-size: 13px;
    line-height: 1.5;
}

@media (max-width: 768px) {
    .product-info-card {
        padding: 20px;
    }
}

/* =========================================================
   7. PERSONNALISATION MAILLOT
   ========================================================= */

.urb-custom-fields {
    margin: 8px 0 24px;
    padding: 24px;
    background: #fff;
    border: 1px solid rgba(0,0,0,0.08);
}

.urb-custom-fields__title {
    margin: 0 0 8px;
    margin-bottom: 10px;
    font-size: 22px;
    font-weight: 700;
    color: #111;
}

.urb-custom-fields__help,
.urb-custom-fields__rules {
    margin: 0 0 14px;
    margin-bottom: 18px;
    font-size: 14px;
    line-height: 1.5;
    color: rgba(17, 17, 17, 0.72);
}

.urb-custom-fields .form-row {
    margin-bottom: 14px;
}

.urb-custom-fields label {
    display: block;
    margin-bottom: 8px;
    font-size: 15px;
    font-weight: 600;
    color: #111;
}

.urb-custom-fields input[type="text"],
.urb-custom-fields input[type="number"] {
    width: 100%;
    height: 48px;
    padding: 0 14px;
    border: 1px solid rgba(0, 0, 0, 0.14);
    border-radius: 0;
    font-size: 16px;
    color: #111;
    background: #fff;
    box-shadow: none;
}

.urb-custom-fields input[type="text"]:focus,
.urb-custom-fields input[type="number"]:focus {
    outline: none;
    border-color: #111;
}

.urb-custom-fields__choice {
    margin-bottom: 18px;
}

.urb-custom-fields__choice .woocommerce-input-wrapper {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.urb-custom-fields__choice label.radio {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    margin: 0 0 10px 0 !important;
    padding: 0 !important;
    cursor: pointer;
}

.urb-custom-fields__choice label.radio span {
    display: inline !important;
}

.urb-custom-fields__choice label.radio input[type="radio"] {
    width: 16px !important;
    height: 16px !important;
    margin: 0 8px 0 0 !important;
    flex-shrink: 0 !important;
}

.urb-personalization-fields.is-hidden {
    display: none;
}

@media (max-width: 768px) {
    .urb-custom-fields {
        padding: 16px;
    }
    
    .urb-custom-fields__title {
        font-size: 20px;
    }
}

/* =========================================================
   8. WOOCOMMERCE GLOBAL (Cart, Checkout, Account)
   ========================================================= */

/* 8.1 Layout Adjustments */
.page .shop-category-inner,
.woocommerce-cart .shop-category-inner,
.woocommerce-checkout .shop-category-inner,
.woocommerce-account .shop-category-inner {
    max-width: 1200px;
}

.woocommerce {
    color: #111;
}

/* 8.2 Tables */
.woocommerce table.shop_table {
    width: 100%;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-collapse: collapse;
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
    padding: 16px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    text-align: left;
    vertical-align: middle;
}

@media (max-width: 768px) {
    .woocommerce table.shop_table th,
    .woocommerce table.shop_table td {
        padding: 12px;
    }
}

/* 8.3 Forms & Boxes */
.woocommerce .cart_totals,
.woocommerce-checkout-review-order,
.woocommerce-form-login,
.woocommerce-form-coupon,
.woocommerce-MyAccount-content,
.woocommerce-Addresses,
.woocommerce-address-fields,
.woocommerce-account .addresses .title,
.woocommerce-billing-fields,
.woocommerce-shipping-fields {
    background: #fff;
    padding: 24px;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.woocommerce-account .woocommerce {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 36px;
    align-items: start;
}

.woocommerce-account .woocommerce::before,
.woocommerce-account .woocommerce::after {
    display: none !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
    float: none !important;
    width: auto !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    padding: 18px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 8px;
}

.woocommerce-account .woocommerce-MyAccount-navigation li {
    margin: 0;
    list-style: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation-link a {
    display: flex;
    align-items: center;
    min-height: 48px;
    padding: 12px 16px;
    color: #111;
    background: #f5f3ee;
    border: 1px solid transparent;
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}

.woocommerce-account .woocommerce-MyAccount-navigation-link a:hover {
    background: #111;
    border-color: #111;
    color: #fff;
    transform: translateX(2px);
}

.woocommerce-account .woocommerce-MyAccount-navigation-link.is-active a {
    background: #111;
    border-color: #111;
    color: #fff;
}

.woocommerce-account .woocommerce-MyAccount-content {
    min-width: 0;
    line-height: 1.65;
}

.woocommerce-account .woocommerce-MyAccount-content > :first-child {
    margin-top: 0;
}

.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
    margin-top: 0;
}

.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info,
.woocommerce-account .woocommerce-error {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.woocommerce-account .woocommerce-info::before,
.woocommerce-account .woocommerce-message::before,
.woocommerce-account .woocommerce-error::before {
    display: none !important;
    content: none !important;
}

.woocommerce-account .woocommerce-MyAccount-content .woocommerce-info,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-message,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-error {
    padding: 24px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-left: 1px solid rgba(0, 0, 0, 0.08);
    background: #fff;
    box-shadow: none;
}

.woocommerce-account .woocommerce-message .button,
.woocommerce-account .woocommerce-info .button,
.woocommerce-account .woocommerce-error .button {
    flex-shrink: 0;
}

.woocommerce-account .woocommerce-orders-table,
.woocommerce-account .woocommerce-table--order-details,
.woocommerce-account .woocommerce-Addresses {
    margin-top: 0;
}

.woocommerce-account .woocommerce-Addresses {
    display: grid;
    gap: 24px;
}

.woocommerce-account .woocommerce-Addresses .addresses {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.woocommerce-account .woocommerce-Addresses .addresses .col-1,
.woocommerce-account .woocommerce-Addresses .addresses .col-2,
.woocommerce-account .woocommerce-Addresses .u-column1,
.woocommerce-account .woocommerce-Addresses .u-column2 {
    float: none !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
}

.woocommerce-account .woocommerce-Address {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: 24px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.woocommerce-account .woocommerce-Address .title {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    margin: 0 0 18px;
    padding: 0;
    background: transparent;
    border: 0;
}

.woocommerce-account .woocommerce-Address .title h3 {
    margin: 0;
    font-size: 22px;
    line-height: 1.2;
}

.woocommerce-account .woocommerce-Address .title .edit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    color: #111;
    border: 1px solid rgba(17, 17, 17, 0.12);
    border-radius: 999px;
    background: transparent;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.woocommerce-account .woocommerce-Address .title .edit:hover {
    background: #111;
    border-color: #111;
    color: #fff;
}

.woocommerce-account .woocommerce-Address address {
    margin: 0;
    padding: 18px 0 0;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    font-style: normal;
    line-height: 1.8;
}

@media (max-width: 980px) {
    .woocommerce-account .woocommerce {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        padding: 14px;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        gap: 10px;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation-link a {
        min-height: 44px;
        padding: 10px 14px;
    }

    .woocommerce-account .woocommerce-MyAccount-content .woocommerce-info,
    .woocommerce-account .woocommerce-MyAccount-content .woocommerce-message,
    .woocommerce-account .woocommerce-MyAccount-content .woocommerce-error {
        flex-direction: column;
        align-items: flex-start;
    }

    .woocommerce-account .woocommerce-Addresses .addresses {
        grid-template-columns: 1fr;
    }

    .woocommerce-account .woocommerce-Addresses .addresses .col-1,
    .woocommerce-account .woocommerce-Addresses .addresses .col-2,
    .woocommerce-account .woocommerce-Addresses .u-column1,
    .woocommerce-account .woocommerce-Addresses .u-column2 {
        width: 100% !important;
    }
}

.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="password"],
.woocommerce input[type="number"],
.woocommerce select,
.woocommerce textarea {
    width: 100%;
    min-height: 48px;
    padding: 12px 14px;
    border: 1px solid rgba(0, 0, 0, 0.14);
    background: #fff;
    color: #111;
    font-size: 16px;
}

.woocommerce textarea {
    min-height: 120px;
}

/* 8.4 Buttons */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    padding: 14px 22px;
    background: #111;
    color: #fff;
    border: 0;
    border-radius: 0;
    font-weight: 600;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    background: #222;
    color: #fff;
}

/* 8.5 Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    margin-bottom: 24px;
    padding: 16px 18px;
    background: #fff;
    border-left: 4px solid #111;
    color: #111;
}

.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice {
    position: fixed;
    top: 50%;
    left: 50%;
    z-index: 200;
    width: min(460px, calc(100vw - 32px));
    margin: 0;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    list-style: none;
    transform: translate(-50%, -50%);
    animation: urbNoticeFadeIn 0.28s ease;
    border: 0 !important;
    border-left: 0 !important;
    outline: 0 !important;
}

body.urb-popup-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 190;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.55), rgba(255, 255, 255, 0.18) 58%, rgba(245, 243, 238, 0.28) 100%);
    backdrop-filter: blur(18px) saturate(0.9);
    -webkit-backdrop-filter: blur(18px) saturate(0.9);
}

.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice::before,
.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice li::before {
    display: none !important;
    content: none !important;
}

.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice li {
    margin: 0;
    padding: 0;
    list-style: none;
}

.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice,
.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice li,
.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice a.button,
.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice button.button,
.woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice input.button {
    box-shadow: none !important;
}

.urb-add-to-cart-notice {
    position: relative;
    padding: 28px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(17, 17, 17, 0.08);
    border-radius: 18px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.12);
    backdrop-filter: blur(10px);
}

.urb-add-to-cart-notice::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.65);
    pointer-events: none;
}

.urb-add-to-cart-notice__close {
    position: absolute;
    top: 12px;
    right: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    border: 0;
    background: transparent;
    color: rgba(17, 17, 17, 0.45);
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    transition: background var(--transition-fast), color var(--transition-fast);
}

.urb-add-to-cart-notice__close:hover {
    background: rgba(17, 17, 17, 0.04);
    color: #111;
}

.urb-add-to-cart-notice__title {
    margin: 0 40px 10px 0;
    color: #111;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.03em;
}

.urb-add-to-cart-notice__text {
    margin: 0 0 24px;
    color: rgba(17, 17, 17, 0.68);
    font-size: 15px;
    line-height: 1.6;
}

.urb-add-to-cart-notice__actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.urb-add-to-cart-notice__button.button {
    appearance: none;
    -webkit-appearance: none;
    min-height: 42px;
    padding: 0 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 600;
    flex: 1 1 0;
    margin: 0 !important;
    border: 0;
    border-radius: 999px;
    text-decoration: none;
    text-align: center;
    line-height: 1;
    vertical-align: middle;
    box-shadow: none !important;
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.urb-add-to-cart-notice__button.button > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 42px;
    text-align: center;
}

.urb-add-to-cart-notice__button--primary.button {
    background: transparent !important;
    color: #111 !important;
    border: 1px solid rgba(17, 17, 17, 0.12) !important;
}

.urb-add-to-cart-notice__button--secondary.button {
    background: transparent !important;
    color: #111 !important;
    border: 1px solid rgba(17, 17, 17, 0.12) !important;
}

.urb-add-to-cart-notice__button--primary.button:hover,
.urb-add-to-cart-notice__button--secondary.button:hover {
    background: rgba(17, 17, 17, 0.05) !important;
    color: #111 !important;
}

@keyframes urbNoticeFadeIn {
    from {
        opacity: 0;
        transform: translate(-50%, calc(-50% + 16px)) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1);
    }
}

@media (max-width: 768px) {
    .woocommerce-notices-wrapper .woocommerce-message.has-urb-popup-notice {
        top: 50%;
        left: 50%;
        width: calc(100vw - 32px);
        transform: translate(-50%, -50%);
    }

    .urb-add-to-cart-notice {
        padding: 20px;
        border-radius: 16px;
    }

    .urb-add-to-cart-notice__title {
        font-size: 17px;
    }

    .urb-add-to-cart-notice__actions {
        flex-direction: column;
    }
}

/* 8.6 Cart Page */
.woocommerce-cart-form,
.cart-collaterals,
.woocommerce-checkout-review-order-table,
.woocommerce-checkout-payment {
    margin-top: 24px;
}

.woocommerce-cart .cart-collaterals {
    display: grid;
    justify-content: end;
}

.woocommerce-cart .cart_totals {
    min-width: 320px;
}

@media (max-width: 768px) {
    .woocommerce-cart .cart_totals {
        min-width: 100%;
    }
}

/* =========================================================
   9. MOBILE FOOTER
   ========================================================= */

.mobile-footer {
    display: none;
}

@media (max-width: 768px) {
    .mobile-footer {
        position: fixed;
        bottom: 0;
        left: 0;
        z-index: 100;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: var(--mobile-footer-height);
        gap: 20px;
        color: var(--color-surface);
        background: var(--color-bg);
    }
    
    .mobile-footer .footer-links {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        gap: 2px 20px;
        margin-bottom: 0;
        padding-top: 1px;
    }
    
    .mobile-footer .footer-links a {
        font-size: 14px;
    }
    
    .mobile-footer .footer-socials {
        gap: 24px;
        margin-top: 0;
    }
    
    .mobile-footer .footer-socials a {
        font-size: 22px;
    }
    
    .home-panel + .mobile-footer {
        display: none;
    }
}

/* =========================================================
   10. UTILITIES & STATES
   ========================================================= */

/* 10.1 Animations */
@keyframes scroll-bounce {
    0%,
    100% {
        transform: translateY(0);
    }
    
    50% {
        transform: translateY(12px);
    }
}

/* 10.2 Cleanup (hide default WooCommerce elements) */
.single-product .woocommerce-tabs,
.single-product .related.products,
.single-product .up-sells {
    display: none;
}

/* Bundle product cleanup */
.urb-single-product__summary .asnp-productList-wrapper,
.urb-single-product__summary .asnp-product-Price,
.urb-single-product__summary .asnp-productList-price,
.urb-single-product__summary .asnp-BundleGridItem-product-info {
    display: none !important;
}

.asnp-modal-wrapper {
    height: auto !important;
    max-height: min(80vh, 720px);
    overflow-y: auto !important;
}

.asnp-modal-wrapper .asnp-App-GridItem-wrapper {
    align-items: flex-start;
    gap: 18px;
    margin: 0;
}

.asnp-modal-wrapper .asnp-emptyList-productSelect,
.asnp-modal-wrapper .asnp-productList-selectProduct,
.asnp-modal-wrapper .asnp-onHover-textSize,
.asnp-modal-wrapper .asnp-productBox-hover:hover .asnp-emptyList-productSelect {
    color: #111 !important;
}

.asnp-modal-wrapper .asnp-productBox-hover:hover .asnp-onHover {
    background-color: rgba(0, 0, 0, 0.78) !important;
}

.asnp-modal-wrapper .asnp-product-quantity-field .asnp-product-quantity-button:hover {
    background-color: #111 !important;
}

.asnp-modal-wrapper .asnp-post-grid-wrapper {
    overflow: hidden;
    border: 1px solid rgba(17, 17, 17, 0.08) !important;
    border-radius: 14px !important;
    background: #fff !important;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12) !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.asnp-modal-wrapper .asnp-post-grid-wrapper:hover {
    border-color: rgba(17, 17, 17, 0.22) !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.16) !important;
    transform: translateY(-2px);
}

.asnp-modal-wrapper .asnp-post-grid-img {
    background: linear-gradient(180deg, #fafafa 0%, #f1f1f1 100%) !important;
}

.asnp-modal-wrapper .asnp-post-grid-content {
    padding: 12px 14px 16px !important;
    border-top: 1px solid rgba(17, 17, 17, 0.08) !important;
}

.asnp-modal-wrapper .asnp-post-grid-info h3,
.asnp-modal-wrapper .asnp-post-grid-info h3 a,
.asnp-modal-wrapper .asnp-product-name {
    color: #111 !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    text-align: center !important;
}

.asnp-modal-wrapper .asnp-post-grid-price,
.asnp-modal-wrapper .asnp-show-options-wrapper,
.asnp-modal-wrapper .asnp-product-Price,
.asnp-modal-wrapper .asnp-emptyList-productSelect,
.asnp-modal-wrapper .asnp-productList-selectProduct,
.asnp-modal-wrapper .asnp-show-options-button {
    display: none !important;
}
